/* ═══════════════════════════════════════════════════════════════
   SKU View — Forecast Panel
   Extracted from app/views/skus/_forecast_panel.html.erb (was ~96
   inline style= attributes with ~50 hex literals). Reuses tokens
   from application.css. Per ai_reference/design_system: no inline
   raw hex; use class names or var(--token).
   ═══════════════════════════════════════════════════════════════ */

/* Badge color variants — extends .skv-badge from sku_view.css.
   `--*-tint` background + base color pairs match the design system. */
.skv-badge--success  { background: var(--green-tint);   color: var(--green);  }
.skv-badge--warning  { background: var(--amber-tint);   color: var(--amber);  }
.skv-badge--error    { background: var(--red-tint);     color: var(--red);    }
.skv-badge--purple   { background: var(--purple-tint);  color: var(--purple); }
.skv-badge--info     { background: var(--blue-tint);    color: #2563eb;       }
.skv-badge--neutral  { background: var(--border-light); color: var(--light);  }
/* Override Active = warmer amber-yellow than --amber-tint, intentionally distinct */
.skv-badge--override { background: #fef3c7;             color: #92400e;       }

/* Per-model accent helpers (used to color icons + accuracy values).
   Mirror the model badge colors for consistency. */
.skv-c-model-hw             { color: var(--green);  }
.skv-c-model-croston        { color: var(--amber);  }
.skv-c-model-hyper-seasonal { color: var(--purple); }
.skv-c-model-ww             { color: var(--blue);   }
/* Dark amber for "override active" attribution text — not in --amber */
.skv-c-amber-dark           { color: #92400e; }

/* Info-popover panel (Stimulus controller="info-popover" target="panel").
   Default is a 300px floating panel inside flow; --wide bumps to 320px;
   --anchored absolutely positions to its parent (used in metadata rows). */
.skv-popover {
  display: none;
  width: 300px;
  padding: 14px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
  font-size: 12px;
  line-height: 1.5;
  color: var(--ink);
  z-index: 100;
}
.skv-popover--wide { width: 320px; }
.skv-popover--anchored {
  position: absolute;
  top: 100%;
  left: 0;
  margin-top: 6px;
}
.skv-popover-title { font-weight: 600; margin-bottom: 6px; }
.skv-popover-body  { margin: 0 0 8px; color: var(--muted); }
.skv-popover-divider {
  margin-top: 10px;
  padding-top: 8px;
  border-top: 1px solid var(--border);
}

/* Legend grid (used in popovers — colored key + description rows) */
.skv-popover-legend {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 3px 10px;
  font-size: 11px;
}
.skv-popover-legend-key { font-weight: 600; }

/* Inline "?" help mark next to clickable popover triggers */
.skv-help-mark {
  font-size: 9px;
  vertical-align: middle;
}

/* Wrapper around an info-popover trigger that floats a panel */
.skv-popover-trigger {
  position: relative;
  cursor: pointer;
}

/* Sub-line under the accuracy value (e.g. "wMAPE: 12.3%", "▼ under") */
.skv-forecast-mape-subline {
  font-size: 10px;
  margin-top: 2px;
  color: var(--light);
}

/* "current" indicator under the active hyper-seasonal ADD value */
.skv-forecast-current-label {
  font-size: 10px;
  font-weight: 600;
  margin-top: 2px;
}

/* Cold-start "no availability adjustment" footer note */
.skv-forecast-note-light {
  font-size: 10px;
  color: var(--light);
  margin-top: 4px;
}

/* "(net X% returns)" tag inside the Final ADD label */
.skv-forecast-returns-tag {
  font-weight: 400;
  font-size: 9px;
  color: var(--green);
}

/* Bottom-margin wrapper for the WW per-window detail table */
.skv-forecast-window-table { margin-bottom: 12px; }

/* Bold-700 helper used inside the WW grid cells */
.skv-fw-bold { font-weight: 700; }

/* Override-banner accent text */
.skv-forecast-override-banner-title {
  font-size: 12px;
  font-weight: 700;
  color: #92400e;
}
.skv-forecast-override-banner-strong { color: var(--amber); }
.skv-forecast-override-attribution-perm { font-weight: 500; }
.skv-forecast-override-banner-aside {
  color: var(--light);
  font-size: 11px;
}

/* Override controls row helper text */
.skv-forecast-override-arrow,
.skv-forecast-override-for,
.skv-forecast-override-days {
  font-size: 12px;
  color: var(--light);
}
.skv-forecast-override-pct-label {
  font-size: 13px;
  font-weight: 700;
  color: var(--light);
}
.skv-forecast-override-checkbox {
  width: 16px;
  height: 16px;
  margin: 0;
}

/* Pending-review banner — amber wash matching the model_change_notice */
.skv-forecast-pending-review {
  background: var(--amber-tint);
  border-color: #fde68a;
}
.skv-forecast-pending-review-link {
  color: #92400e;
  font-weight: 600;
}

/* Model-reason note box (small italic explanation under metadata) */
.skv-forecast-model-reason {
  font-size: 12px;
  color: var(--muted);
  margin-bottom: 12px;
  padding: 8px;
  background: var(--surface);
  border-radius: 4px;
  border: 1px solid var(--border);
}

/* Hyper-seasonal demand-concentration metadata accent */
.skv-c-purple-em { color: var(--purple); }

/* Avail-window table uplift cell color (>1 = amber, else light) */
.skv-c-uplift-amber { color: var(--amber); }

/* Legacy class compatibility: kept for forecast-strip flex override */
.skv-forecast-strip--cold-start > .skv-forecast-box { flex: 1; }
