/* Status page styling. Pairs with status.html + status-page.js.
   Uses the project's design tokens (style.css :root + [data-theme="dark"])
   so light/dark toggling stays in sync with the rest of the site. */

.status-banner {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 18px 22px;
  border-radius: var(--r-lg);
  font-weight: 600;
  font-size: 1.1rem;
  margin: 0 0 28px;
  border: 1px solid var(--c-border);
  background: var(--c-bg-alt);
  color: var(--c-text);
}
.status-banner--operational {
  background: var(--c-bg-green);
  color: var(--c-green);
  border-color: var(--c-green-mid);
}
.status-banner--degraded {
  background: rgba(217, 119, 6, 0.10);
  color: var(--c-amber);
  border-color: rgba(217, 119, 6, 0.35);
}
.status-banner--outage {
  background: rgba(220, 38, 38, 0.10);
  color: var(--c-error);
  border-color: rgba(220, 38, 38, 0.35);
}

.status-dot {
  display: inline-block;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--c-subtle);
  flex-shrink: 0;
}
.status-dot--operational { background: var(--c-green-vivid); }
.status-dot--degraded    { background: var(--c-amber); }
.status-dot--outage      { background: var(--c-error); }
.status-dot--unknown     { background: var(--c-subtle); }
.status-dot--external    { background: var(--c-navy-mid); }

.status-components {
  list-style: none;
  padding: 0;
  margin: 0 0 24px;
  border: 1px solid var(--c-border);
  border-radius: var(--r-lg);
  background: var(--c-bg);
  overflow: hidden;
}
.status-component {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  padding: 16px 20px;
  border-bottom: 1px solid var(--c-border);
  gap: 10px;
  color: var(--c-text);
}
.status-component:last-child { border-bottom: none; }
.status-component__name {
  font-weight: 600;
  font-size: 1rem;
  color: var(--c-text);
}
.status-component__state {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 0.92rem;
  color: var(--c-muted);
  font-weight: 500;
}
.status-component__note {
  flex-basis: 100%;
  font-size: 0.86rem;
  color: var(--c-muted);
  margin-top: 4px;
  line-height: 1.5;
}

.status-meta {
  font-size: 0.88rem;
  color: var(--c-muted);
  margin: 0 0 32px;
}
.status-meta a {
  color: var(--c-green-vivid);
}

.status-explainer {
  border-top: 1px solid var(--c-border);
  padding-top: 24px;
  margin-top: 8px;
}
.status-explainer h2 {
  font-size: 1.1rem;
  margin: 0 0 14px;
  color: var(--c-text);
}
.status-explainer dl {
  display: grid;
  grid-template-columns: max-content 1fr;
  gap: 10px 20px;
  margin: 0;
  font-size: 0.92rem;
}
.status-explainer dt {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-weight: 600;
  color: var(--c-text);
  white-space: nowrap;
}
.status-explainer dd {
  margin: 0;
  color: var(--c-muted);
  line-height: 1.55;
}

/* Dark-mode tweaks: keep tinted banners readable on the slate background. */
[data-theme="dark"] .status-banner--operational {
  background: rgba(22, 163, 74, 0.14);
  color: var(--c-green-mid);
  border-color: rgba(22, 163, 74, 0.4);
}
[data-theme="dark"] .status-banner--degraded {
  background: rgba(217, 119, 6, 0.16);
  color: #fcd34d;
  border-color: rgba(217, 119, 6, 0.45);
}
[data-theme="dark"] .status-banner--outage {
  background: rgba(220, 38, 38, 0.16);
  color: #fca5a5;
  border-color: rgba(220, 38, 38, 0.45);
}
[data-theme="dark"] .status-components { background: var(--c-bg-alt); }
