.forecast-section {
  margin: 34px 0 28px;
  padding: 0 0 8px;
  border-top: 1px solid var(--line);
}

.forecast-heading {
  width: fit-content;
  min-width: 238px;
  margin: 28px 0 22px;
  padding: 18px 22px 16px;
  border: 1px solid rgba(255,185,82,.7);
  border-radius: 3px;
  background: #080b10;
  box-shadow: 0 0 24px rgba(255,185,82,.16), inset 0 0 0 1px rgba(255,255,255,.05);
}

.forecast-heading h2 {
  margin: 0;
  color: #fff;
  font-size: clamp(1.9rem, 2.25vw, 2.45rem);
  line-height: .94;
  font-weight: 950;
  letter-spacing: 0;
  text-transform: uppercase;
}

.forecast-heading h2::after {
  content: "";
  display: block;
  width: 76px;
  height: 3px;
  margin-top: 13px;
  background: #ffd16c;
}
.forecast-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}

.forecast-card {
  min-height: 230px;
  padding: 18px;
  border: 1px solid var(--line);
  border-radius: 4px;
  background: color-mix(in srgb, var(--panel) 94%, transparent);
  box-shadow: 0 10px 28px rgba(0,0,0,.12);
}

.forecast-top {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: flex-start;
  margin-bottom: 18px;
}

.forecast-symbol {
  font-size: .85rem;
  font-weight: 950;
  color: var(--muted);
}

.forecast-name {
  margin-top: 4px;
  font-size: 1.12rem;
  font-weight: 950;
  color: var(--ink);
}
.forecast-price {
  text-align: right;
}

.forecast-target {
  display: block;
  color: var(--green);
  font-size: clamp(1.75rem, 2.4vw, 2.45rem);
  font-weight: 950;
  line-height: .9;
  text-shadow: 0 0 18px color-mix(in srgb, var(--green) 35%, transparent);
}

.forecast-rating {
  display: block;
  margin-top: 6px;
  color: var(--muted);
  font-size: .72rem;
  font-weight: 950;
  text-transform: uppercase;
}

.forecast-bars {
  display: grid;
  gap: 9px;
  margin: 14px 0 18px;
}

.forecast-bar {
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr) 58px;
  gap: 10px;
  align-items: center;
  font-size: .76rem;
  font-weight: 950;
  color: var(--muted);
  text-transform: uppercase;
}

.forecast-track {
  height: 6px;
  overflow: hidden;
  border-radius: 999px;
  background: color-mix(in srgb, var(--line) 70%, transparent);
}
.forecast-fill {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, #ffbf57, #26e7a6);
}

.forecast-note {
  position: relative;
  display: flex;
  align-items: center;
  gap: 12px;
  color: var(--muted);
  font-size: .82rem;
}

.forecast-analyst-toggle {
  border: 1px solid rgba(255,185,82,.72);
  border-radius: 3px;
  background: #07090c;
  color: #ffd16c;
  padding: 8px 12px 7px;
  font: inherit;
  font-size: .76rem;
  font-weight: 950;
  text-transform: uppercase;
  cursor: pointer;
  box-shadow: 0 0 14px rgba(255,185,82,.15);
}

.forecast-analyst-popover {
  position: absolute;
  z-index: 20;
  left: 0;
  top: calc(100% + 10px);
  display: none;
  min-width: 260px;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 4px;
  background: var(--panel);
  box-shadow: 0 18px 40px rgba(0,0,0,.28);
}
.forecast-analyst-popover.open {
  display: block;
}

.forecast-analyst-popover h4 {
  margin: 0 0 10px;
  color: var(--ink);
  font-size: .82rem;
  font-weight: 950;
  text-transform: uppercase;
}

.forecast-analyst-row {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  padding: 8px 0;
  border-top: 1px solid var(--line);
}

.forecast-analyst-name {
  color: var(--muted);
  font-size: .82rem;
}

.forecast-analyst-target {
  color: var(--ink);
  font-weight: 950;
}

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

@media (max-width: 720px) {
  .forecast-grid { grid-template-columns: 1fr; }
  .forecast-card { min-height: 0; }
}
