:root {
  color-scheme: dark;
  --bg: #101318;
  --panel: #171c22;
  --panel-soft: #1f2630;
  --text: #eef3f8;
  --muted: #9aa8b7;
  --line: #2c3542;
  --up: #44d07b;
  --down: #ff6673;
  --flat: #ffcc66;
  --accent: #64b5ff;
}

* {
  box-sizing: border-box;
}

body {
  margin: 0;
  background: var(--bg);
  color: var(--text);
  font-family: Arial, "Noto Sans KR", sans-serif;
}

.topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  padding: 18px 24px;
  border-bottom: 1px solid var(--line);
  background: #12171e;
}

h1,
h2,
h3,
p {
  margin: 0;
}

h1 {
  font-size: 22px;
}

h2 {
  font-size: 16px;
}

p,
.muted {
  color: var(--muted);
}

main {
  width: min(1480px, 100%);
  margin: 0 auto;
  padding: 18px;
}

.health,
button,
select {
  color: var(--text);
  background: var(--panel-soft);
  border: 1px solid var(--line);
  border-radius: 6px;
}

.health {
  padding: 8px 10px;
  color: var(--muted);
  font-size: 13px;
}

.navButton {
  display: inline-flex;
  align-items: center;
  min-height: 36px;
  padding: 0 11px;
  border: 1px solid var(--line);
  border-radius: 6px;
  color: var(--text);
  background: var(--panel-soft);
  text-decoration: none;
  font-size: 13px;
  font-weight: 800;
}

.navButton:hover {
  border-color: var(--accent);
}

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

button,
select {
  padding: 8px 10px;
}

button {
  cursor: pointer;
}

button:hover {
  border-color: var(--accent);
}

.scoreBoard {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 10px;
  margin-bottom: 14px;
}

.scoreItem,
.decisionCard,
.panel {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 8px;
}

.scoreItem {
  padding: 12px;
}

.scoreItem span {
  display: block;
  color: var(--muted);
  font-size: 12px;
}

.scoreItem strong {
  display: block;
  margin-top: 6px;
  font-size: 19px;
}

.recommendationBoard {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 10px;
  margin-bottom: 14px;
}

.engineStatusStrip {
  display: grid;
  grid-template-columns: 1.1fr repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin-bottom: 14px;
}

.engineStatusCard {
  min-width: 0;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--panel);
}

.engineStatusCard.primary {
  border-color: rgba(100, 181, 255, 0.45);
  background: linear-gradient(180deg, rgba(100, 181, 255, 0.08), rgba(23, 28, 34, 1));
}

.engineStatusCard span,
.engineStatusCard small {
  display: block;
  color: var(--muted);
  font-size: 12px;
}

.engineStatusCard strong {
  display: block;
  margin-top: 6px;
  font-size: 18px;
  overflow-wrap: anywhere;
}

.engineStatusCard small {
  margin-top: 5px;
  line-height: 1.4;
}

.accuracyBoard {
  display: grid;
  grid-template-columns: minmax(230px, 0.9fr) minmax(0, 2.1fr);
  gap: 10px;
  margin-bottom: 14px;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--panel);
}

.accuracyTraceHead span,
.accuracyTraceItem span,
.accuracyTraceItem small {
  display: block;
  color: var(--muted);
  font-size: 12px;
}

.accuracyTraceHead strong {
  display: block;
  margin-top: 5px;
  font-size: 18px;
}

.accuracyTraceHead small {
  display: block;
  margin-top: 4px;
  color: var(--muted);
  font-size: 12px;
}

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

.accuracyTraceItem {
  padding: 9px;
  border: 1px solid rgba(44, 53, 66, 0.85);
  border-radius: 6px;
  background: rgba(31, 38, 48, 0.72);
}

.accuracyTraceItem strong {
  display: block;
  margin-top: 4px;
  font-size: 16px;
}

.recommendationDistribution {
  display: grid;
  grid-template-columns: 1.1fr repeat(4, minmax(0, 0.7fr));
  gap: 10px;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--panel);
}

.recommendationDistribution span {
  display: block;
  color: var(--muted);
  font-size: 12px;
}

.recommendationDistribution strong {
  display: block;
  margin-top: 5px;
  font-size: 17px;
}

.distributionCompare {
  grid-template-columns: 1.05fr repeat(3, minmax(0, 1fr));
}

.distributionCompare strong span {
  display: inline;
  font-size: inherit;
}

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

.decisionCard {
  padding: 16px;
}

.assetHeader {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.assetHeader h2 {
  font-size: 17px;
}

.recommend {
  padding: 5px 9px;
  border-radius: 999px;
  background: var(--panel-soft);
  font-size: 13px;
  font-weight: 700;
}

.currentPrice {
  margin-top: 12px;
  font-size: 29px;
  font-weight: 800;
}

.mainForecast {
  display: grid;
  grid-template-columns: 0.9fr 1.1fr;
  gap: 10px;
  margin-top: 12px;
}

.forecastBox {
  padding: 12px;
  background: var(--panel-soft);
  border-radius: 6px;
}

.forecastBox span,
.prob span,
.miniStat span {
  display: block;
  color: var(--muted);
  font-size: 12px;
}

.forecastBox strong {
  display: block;
  margin-top: 6px;
  font-size: 20px;
}

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

.prob {
  padding: 9px;
  background: var(--panel-soft);
  border-radius: 6px;
}

.prob strong,
.miniStat strong {
  display: block;
  margin-top: 4px;
  font-size: 15px;
}

.miniStats {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
  margin-top: 10px;
}

.miniStat {
  padding: 9px;
  background: rgba(31, 38, 48, 0.7);
  border-radius: 6px;
}

.panel {
  padding: 16px;
  margin-bottom: 14px;
  overflow-x: auto;
}

.panelHeader {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 12px;
}

.panelHeader p {
  margin-top: 4px;
  font-size: 13px;
}

.chartControls {
  display: flex;
  gap: 8px;
  align-items: center;
  flex: 0 0 auto;
}

.chartOptionGrid {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 4px 0 12px;
}

.chartPanel > .chartOptionGrid:not(.visibleChartOptions) {
  display: none;
}

.chartToolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin: 4px 0 10px;
  flex-wrap: wrap;
}

.segmented {
  display: inline-flex;
  align-items: center;
  gap: 2px;
  padding: 3px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: #141a21;
}

.segmented button {
  min-width: 42px;
  min-height: 30px;
  padding: 6px 9px;
  border: 0;
  border-radius: 4px;
  background: transparent;
  color: var(--muted);
  font-size: 12px;
}

.segmented button.active {
  background: var(--panel-soft);
  color: var(--text);
}

.chartOptionGrid label {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-height: 30px;
  padding: 6px 9px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: #141a21;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.25;
  white-space: nowrap;
}

.chartOptionGrid input {
  width: 14px;
  height: 14px;
  accent-color: var(--accent);
}

.chartPanel {
  overflow: hidden;
}

#priceChart {
  display: block;
  width: 100%;
  height: 430px;
  background: #121820;
  border: 1px solid var(--line);
  border-radius: 6px;
  cursor: grab;
  touch-action: none;
  user-select: none;
}

.tvChart {
  display: none;
  width: 100%;
  height: 430px;
  overflow: hidden;
  background: #121820;
  border: 1px solid var(--line);
  border-radius: 6px;
}

.chartPanel.tradingview-ready .tvChart {
  display: block;
}

.chartPanel.tradingview-ready #priceChart {
  display: none;
}

#priceChart:active {
  cursor: grabbing;
}

.chartInfo {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 18px;
  margin-top: 10px;
  color: var(--muted);
  font-size: 13px;
}

.chartInfo strong {
  color: var(--text);
}

.analysisPanel {
  overflow: hidden;
}

.analysisText {
  display: grid;
  gap: 8px;
  padding: 13px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #141a21;
  line-height: 1.55;
}

.analysisText strong {
  color: var(--accent);
}

.driverInfluenceGrid {
  display: grid;
  gap: 8px;
  margin-top: 10px;
}

.driverFlow {
  display: grid;
  gap: 8px;
  margin-top: 10px;
  padding: 10px;
  border: 1px solid rgba(100, 181, 255, 0.22);
  border-radius: 8px;
  background: rgba(100, 181, 255, 0.06);
}

.driverFlowTitle {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 10px;
  flex-wrap: wrap;
}

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

.driverFlowRow {
  display: grid;
  grid-template-columns: 28px minmax(160px, 1.2fr) repeat(4, minmax(82px, 0.7fr));
  gap: 8px;
  width: 100%;
  min-height: 48px;
  padding: 8px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: #141a21;
  color: var(--text);
  text-align: left;
}

.driverFlowRow:hover,
.driverFlowRow.selected,
.driverInfluenceRow.selected {
  border-color: var(--accent);
  background: rgba(100, 181, 255, 0.12);
}

.driverFlowRow span,
.driverFlowRow b,
.driverFlowRow small {
  min-width: 0;
  overflow-wrap: anywhere;
}

.driverFlowRow small {
  display: block;
  margin-top: 2px;
  color: var(--muted);
  font-size: 11px;
}

.driverRank {
  display: grid;
  place-items: center;
  width: 24px;
  height: 24px;
  border-radius: 999px;
  background: var(--panel-soft);
  color: var(--accent);
  font-weight: 700;
}

.driverInfluenceRow {
  display: grid;
  grid-template-columns: minmax(180px, 1.2fr) repeat(4, minmax(72px, 0.55fr));
  gap: 8px;
  align-items: center;
  padding: 8px 9px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: rgba(31, 38, 48, 0.65);
  font-size: 12px;
}

.driverInfluenceRow strong,
.driverInfluenceRow span {
  min-width: 0;
  overflow-wrap: anywhere;
}

.driverInfluenceRow span {
  color: var(--muted);
}

.analysisColumns {
  display: grid;
  grid-template-columns: 1fr 0.85fr;
  gap: 14px;
  margin-top: 14px;
}

.analysisColumns h3 {
  margin-bottom: 8px;
  font-size: 14px;
}

.adjustmentList {
  display: grid;
  gap: 7px;
  margin-top: 10px;
}

.adjustmentList h4 {
  margin: 0;
  font-size: 13px;
  color: var(--muted);
}

.adjustmentItem {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  min-height: 28px;
  padding: 7px 9px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: #141a21;
  font-size: 12px;
}

.adjustmentItem span {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.adjustmentItem strong {
  flex: 0 0 auto;
}

.impactPanel {
  overflow: hidden;
}

.sourceStatus {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 12px;
}

.sourceChip {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 5px 8px;
  border: 1px solid var(--line);
  border-radius: 999px;
  color: var(--muted);
  background: rgba(31, 38, 48, 0.65);
  font-size: 12px;
  white-space: nowrap;
}

.sourceChip.connected {
  color: var(--up);
  border-color: rgba(68, 208, 123, 0.35);
}

.sourceChip.fallback,
.sourceChip.stale {
  color: var(--flat);
  border-color: rgba(255, 204, 102, 0.35);
}

.sourceChip.error,
.sourceChip.disconnected {
  color: var(--down);
  border-color: rgba(255, 102, 115, 0.35);
}

.sourceChip.waiting {
  color: var(--flat);
  border-color: rgba(255, 204, 102, 0.35);
}

.sourceChip.not_connected {
  color: var(--muted);
}

.sourceChip.not_implemented {
  color: var(--muted);
  border-color: rgba(154, 168, 183, 0.28);
}

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

.impactCard {
  min-width: 0;
  padding: 13px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #141a21;
}

.impactCard.selected {
  border-color: rgba(100, 181, 255, 0.75);
}

.impactCardHead {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.impactCardHead h3 {
  font-size: 15px;
}

.impactCardHead span {
  display: block;
  margin-top: 4px;
  color: var(--muted);
  font-size: 12px;
}

.impactCardHead strong {
  flex: 0 0 auto;
  font-size: 18px;
}

.impactMeter {
  height: 7px;
  margin: 11px 0;
  overflow: hidden;
  border-radius: 999px;
  background: rgba(238, 243, 248, 0.08);
}

.impactMeter span {
  display: block;
  height: 100%;
  min-width: 3px;
  border-radius: inherit;
  background: var(--flat);
}

.impactMeter.up span {
  background: var(--up);
}

.impactMeter.down span {
  background: var(--down);
}

.impactFactors {
  display: grid;
  gap: 8px;
}

.impactFactor {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  align-items: start;
  padding-top: 8px;
  border-top: 1px solid rgba(44, 53, 66, 0.8);
}

.impactFactor strong,
.impactFactor span,
.impactFactor b {
  overflow-wrap: anywhere;
}

.impactFactor strong {
  display: block;
  font-size: 13px;
}

.impactFactor span {
  display: block;
  margin-top: 3px;
  color: var(--muted);
  font-size: 12px;
}

.impactFactor b {
  font-size: 12px;
  white-space: nowrap;
}

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

.impactSubStats span {
  display: block;
  padding: 7px;
  border-radius: 6px;
  background: rgba(31, 38, 48, 0.75);
  color: var(--muted);
  font-size: 12px;
}

.impactSubStats strong {
  display: block;
  margin-top: 3px;
  color: var(--text);
}

.impactNote {
  margin-top: 11px;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.5;
}

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

.scenarioCard {
  min-width: 0;
  padding: 13px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #141a21;
}

.scenarioCard.selected {
  border-color: rgba(100, 181, 255, 0.55);
}

.scenarioCard h3 {
  font-size: 15px;
}

.scenarioRows {
  display: grid;
  gap: 8px;
  margin-top: 10px;
}

.scenarioRow {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 8px;
  width: 100%;
  padding-top: 8px;
  border: 0;
  border-top: 1px solid rgba(44, 53, 66, 0.8);
  border-radius: 0;
  background: transparent;
  color: var(--text);
  text-align: left;
}

.scenarioAction {
  cursor: pointer;
}

.scenarioAction:hover,
.scenarioAction.selected {
  padding: 8px;
  border: 1px solid rgba(100, 181, 255, 0.55);
  border-radius: 6px;
  background: rgba(100, 181, 255, 0.09);
}

.scenarioRow span {
  display: block;
  color: var(--muted);
  font-size: 12px;
}

.scenarioRow strong {
  display: block;
  margin-top: 3px;
}

.sourceTable {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  margin-top: 12px;
}

.sourceItem {
  padding: 11px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #141a21;
}

.sourceItem.connected {
  border-color: rgba(68, 208, 123, 0.22);
}

.sourceItem.fallback,
.sourceItem.stale {
  border-color: rgba(255, 204, 102, 0.25);
}

.sourceItem.error,
.sourceItem.disconnected {
  border-color: rgba(255, 102, 115, 0.25);
}

.sourceItem.not_implemented {
  opacity: 0.76;
}

.sourceItemHead {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 8px;
}

.sourceItemHead .sourceChip {
  min-height: 24px;
  padding: 3px 7px;
}

.sourceStatusSummary {
  margin-top: 10px;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.5;
}

.sourceItem strong,
.sourceItem span {
  display: block;
}

.sourceItem span {
  margin-top: 4px;
  color: var(--muted);
  font-size: 12px;
}

.twoCol {
  display: grid;
  grid-template-columns: 1fr 0.85fr;
  gap: 14px;
}

.reasonGroup {
  margin-top: 12px;
}

.reasonGroup:first-child {
  margin-top: 0;
}

.reasonGroup h3 {
  font-size: 14px;
  margin-bottom: 6px;
}

.reasonItem {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 8px;
  padding: 8px 0;
  border-bottom: 1px solid var(--line);
  font-size: 14px;
}

.summaryList {
  display: grid;
  gap: 10px;
}

.summaryList div {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  padding-bottom: 9px;
  border-bottom: 1px solid var(--line);
}

.summaryList span {
  color: var(--muted);
}

.detailPanel summary {
  cursor: pointer;
  font-weight: 700;
}

table {
  width: 100%;
  min-width: 980px;
  border-collapse: collapse;
  table-layout: auto;
  margin-top: 12px;
}

th,
td {
  padding: 10px 8px;
  border-bottom: 1px solid var(--line);
  text-align: left;
  font-size: 13px;
  white-space: nowrap;
}

th {
  color: var(--muted);
  font-weight: 600;
}

.badge {
  display: inline-flex;
  min-width: 54px;
  justify-content: center;
  padding: 4px 8px;
  border-radius: 999px;
  background: var(--panel-soft);
  font-size: 12px;
}

.hint {
  margin-top: 10px;
  color: var(--muted);
  font-size: 13px;
}

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

.down {
  color: var(--down);
}

.flat {
  color: var(--flat);
}

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

  .recommendationDistribution,
  .accuracyBoard,
  .decisionGrid,
  .impactGrid,
  .scenarioGrid,
  .sourceTable,
  .analysisColumns,
  .twoCol {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 720px) {
  .topbar,
  .panelHeader {
    align-items: flex-start;
    flex-direction: column;
  }

  .mainForecast,
  .miniStats,
  .recommendationDistribution,
  .accuracyTraceGrid,
  .driverFlowRow {
    grid-template-columns: 1fr;
  }

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

.hiddenSelect {
  position: absolute;
  width: 1px;
  height: 1px;
  opacity: 0;
  pointer-events: none;
}

.basicShell {
  display: grid;
  gap: 14px;
}

.basicSelector {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 10px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #151a21;
}

.selectorGroup {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.assetTab,
.selectorGroup .timeframeButton,
.chartActionButton,
.expertToggle {
  min-height: 36px;
  border-radius: 6px;
  font-weight: 700;
}

.assetTab.active,
.selectorGroup .timeframeButton.active,
.chartActionButton.active {
  color: #06120b;
  border-color: transparent;
  background: var(--up);
}

.basicHero {
  display: grid;
  grid-template-columns: minmax(0, 1.25fr) minmax(320px, 0.75fr);
  gap: 14px;
}

.basicDecision,
.basicProbability,
.basicAccuracy {
  min-width: 0;
  padding: 18px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--panel);
}

.decisionEyebrow {
  color: var(--muted);
  font-size: 13px;
  font-weight: 700;
}

.decisionMain {
  display: flex;
  align-items: baseline;
  gap: 12px;
  margin-top: 10px;
}

.decisionMain span {
  color: var(--muted);
  font-size: 14px;
}

.decisionMain strong {
  font-size: clamp(34px, 5vw, 56px);
  letter-spacing: 0;
}

.decisionSub {
  margin-top: 10px;
  color: var(--text);
  line-height: 1.55;
}

.decisionNumbers {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 8px;
  margin-top: 16px;
}

.decisionNumbers div {
  min-width: 0;
  padding: 10px;
  border: 1px solid rgba(44, 53, 66, 0.78);
  border-radius: 6px;
  background: rgba(31, 38, 48, 0.72);
}

.decisionNumbers span,
.probabilityHeader span,
.basicAccuracy span,
.basicAccuracy small {
  display: block;
  color: var(--muted);
  font-size: 12px;
}

.decisionNumbers strong {
  display: block;
  margin-top: 5px;
  font-size: 16px;
  overflow-wrap: anywhere;
}

.probabilityHeader {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
}

.probabilityHeader strong {
  font-size: 24px;
}

.probabilityBar {
  display: flex;
  width: 100%;
  height: 26px;
  margin-top: 14px;
  overflow: hidden;
  border: 1px solid rgba(238, 243, 248, 0.08);
  border-radius: 6px;
  background: #0d1117;
}

.probabilityBar span {
  min-width: 2px;
}

.probUp {
  background: var(--up);
}

.probDown {
  background: var(--down);
}

.probFlat {
  background: var(--flat);
}

.basicProbability p {
  margin-top: 10px;
  line-height: 1.5;
}

.basicAccuracy {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
}

.basicAccuracy strong {
  font-size: 24px;
}

.basicChartPanel {
  margin-bottom: 0;
}

.chartPanel:not(.performanceMode) .visibleChartOptions {
  display: none;
}

.chartActionButton.active {
  background: var(--accent);
  color: #06111e;
}

.basicReasons {
  margin-bottom: 0;
}

.basicReasonItem {
  display: grid;
  grid-template-columns: 32px 1fr;
  gap: 10px;
  align-items: center;
  min-height: 46px;
  padding: 10px 0;
  border-bottom: 1px solid var(--line);
}

.basicReasonItem:last-child {
  border-bottom: 0;
}

.basicReasonItem b {
  display: grid;
  place-items: center;
  width: 28px;
  height: 28px;
  border-radius: 999px;
  background: var(--panel-soft);
}

.basicReasonItem span {
  line-height: 1.5;
}

.expertToggleWrap {
  display: flex;
  justify-content: center;
  padding: 4px 0 14px;
}

.expertToggle {
  min-width: 180px;
  border-color: rgba(100, 181, 255, 0.55);
  background: rgba(100, 181, 255, 0.12);
}

.expertShell {
  margin-top: 6px;
}

.expertShell[hidden] {
  display: none;
}

@media (max-width: 1050px) {
  .basicHero,
  .decisionNumbers {
    grid-template-columns: 1fr;
  }

  .basicSelector,
  .basicAccuracy {
    align-items: stretch;
    flex-direction: column;
  }

  .selectorGroup {
    width: 100%;
  }

  .assetTab,
  .selectorGroup .timeframeButton {
    flex: 1 1 96px;
  }
}
