/* =========================================================================
   DASHBOARD WIDGET STYLES
   -------------------------------------------------------------------------
   This file contains only reusable widget-specific styles. The permanent
   factory dashboard page structure and shared card chrome belong in
   factory-dashboard.css.
   ========================================================================= */

/* ------------------------------------------------------------- uPlot widget */

:root{
  --markdown_header_color: rgb(56 189 248)
  
}

.uplot-host {
  position: absolute;
  inset: 6px 8px 4px;
  overflow: hidden;
  padding: 3px;
  /* border: 1px solid var(--border); */
  /* border-radius: 7px; */
  background: color-mix(in srgb, var(--surface) 94%, transparent);
}

.uplot-host .uplot {
  width: 100%;
  font-family: var(--chart-font);
}

/* Live value badge. This replaces uPlot's DOM legend to keep height bounded. */
.chart-readout {
  position: absolute;
  top: 10px;
  right: 12px;
  z-index: 5;
  padding: 3px 9px;
  color: var(--text);
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 500;
  background: color-mix(in srgb, var(--surface-2) 88%, transparent);
  border: 1px solid var(--border);
  border-radius: 7px;
  pointer-events: none;
  backdrop-filter: blur(2px);
}

/* -------------------------------------------------------- text-value widget */
.text-value-widget {
  --text-value-number-size: 48px;
  --text-value-secondary-size: 11px;
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px;
  overflow: hidden;
  padding: 18px;
  text-align: center !important;;
}

.text-value-number {
  width: 100%;
  overflow: hidden;
  color: var(--text);
  font-family: var(--font-mono);
  font-size: var(--text-value-number-size);
  font-weight: 600;
  line-height: 0.95;
  letter-spacing: -0.045em;
  text-align: center !important;;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.text-value-status {
  width: fit-content;
  max-width: 100%;
  padding: 4px 8px;
  color: var(--text-muted);
  font-family: var(--font-mono);
  font-size: var(--text-value-secondary-size);
  font-weight: 600;
  letter-spacing: 0.04em;
  text-align: center !important;
  text-transform: uppercase;
  background: var(--surface-2);
  border: 1px solid var(--border);
  border-radius: 999px;
}

.text-value-status--ok {
  color: var(--status-ok);
  border-color: color-mix(in srgb, var(--status-ok) 45%, var(--border));
  background: color-mix(in srgb, var(--status-ok) 10%, var(--surface));
}

.text-value-status--warning {
  color: var(--status-warning);
  border-color: color-mix(in srgb, var(--status-warning) 45%, var(--border));
  background: color-mix(in srgb, var(--status-warning) 10%, var(--surface));
}

.text-value-status--critical {
  color: var(--status-critical);
  border-color: color-mix(in srgb, var(--status-critical) 45%, var(--border));
  background: color-mix(in srgb, var(--status-critical) 10%, var(--surface));
}

.text-value-status--stale,
.text-value-status--idle {
  color: var(--text-muted);
}

.text-value-time {
  width: 100%;
  color: var(--text-muted);
  font-family: var(--font-mono);
  font-size: var(--text-value-secondary-size);
  text-align: center !important;
}

/* ---------------------------------------------------------- markdown widget */
.markdown-widget {
  --markdown-font-size: 13px;
  position: absolute;
  inset: 0;
  box-sizing: border-box;
  overflow: hidden;
  padding: 1.08em 1.23em;
  color: var(--text);
  font-size: var(--markdown-font-size);
  line-height: 1.55;
}

/* Creates a measurable natural-height content box for proportional fitting. */
.markdown-widget-content {
  display: flow-root;
  min-height: 0;
}

.markdown-widget-content > :first-child { margin-top: 0; }
.markdown-widget-content > :last-child { margin-bottom: 0; }

.markdown-widget h1,
.markdown-widget h2,
.markdown-widget h3,
.markdown-widget h4,
.markdown-widget h5,
.markdown-widget h6 {
  margin: 0.8em 0 0.35em;
  line-height: 1.2;
  color: var(--markdown_header_color)
}

.markdown-widget h1 { font-size: 2em; }
.markdown-widget h2 { font-size: 1.5em; }
.markdown-widget h3 { font-size: 1.17em; }
.markdown-widget h4 { font-size: 1em; }
.markdown-widget h5 { font-size: 0.83em; }
.markdown-widget h6 { font-size: 0.67em; }

.markdown-widget p { margin: 0.55em 0; }

.markdown-widget ul,
.markdown-widget ol {
  margin: 0.55em 0;
  padding-left: 1.5em;
}

.markdown-widget blockquote {
  margin: 0.65em 0;
  padding: 0.2em 0.85em;
  color: var(--text-muted);
  border-inline-start: 0.25em solid var(--border);
}

.markdown-widget blockquote p { margin: 0.35em 0; }

.markdown-widget code {
  padding: 0.08em 0.31em;
  font-family: var(--font-mono);
  font-size: 0.92em;
  background: var(--surface-2);
  border: 0.08em solid var(--border);
  border-radius: 0.31em;
}

.markdown-widget pre {
  overflow: auto;
  margin: 0.65em 0;
  padding: 0.77em;
  background: var(--surface-2);
  border: 0.08em solid var(--border);
  border-radius: 0.54em;
}

.markdown-widget pre code {
  padding: 0;
  font-size: 0.92em;
  border: 0;
}

.markdown-widget table {
  width: 100%;
  margin: 0.65em 0;
  border-collapse: collapse;
}

.markdown-widget th,
.markdown-widget td {
  padding: 0.38em 0.54em;
  border: 0.08em solid var(--border);
}

.markdown-widget hr {
  margin: 0.9em 0;
  border: 0;
  border-top: 0.08em solid var(--border);
}

.markdown-widget img {
  max-width: 100%;
  height: auto;
}

.markdown-widget,
.markdown-widget * {
  direction: ltr !important;
  text-align: left !important;
}

/* Keep list indentation on the left */
.markdown-widget ul,
.markdown-widget ol {
  padding-left: 1.5em !important;
  padding-right: 0 !important;
}