/* Landing dashboard — re-uses .hero / .hero-strip from daily-detail.css. */

.dash-content {
  max-width: 1400px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 22px;
}

.dash-card {
  border: 1px solid var(--border);
  border-radius: 14px;
  background: var(--bg-2);
  padding: 16px 18px;
}
.dash-card-head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: 12px;
}
.dash-card-title {
  font: 700 13px var(--font-sans);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--muted-2);
}
.dash-card-sub {
  font: 12px var(--font-mono);
  color: var(--muted);
}

.spark-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
}
.spark-card {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 12px;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: var(--bg);
  text-decoration: none;
  color: inherit;
  transition: background 0.12s, border-color 0.12s;
}
.spark-card:hover { background: var(--bg-3); border-color: var(--accent); }
.spark-label {
  font: 600 11px var(--font-sans);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--muted-2);
}
.spark-row { display: flex; align-items: center; gap: 12px; }
.spark-val { font: 700 22px var(--font-mono); color: var(--text); min-width: 80px; }
.spark { flex: 1; height: 44px; min-width: 0; }

.quick-links {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
}
.ql-item {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 14px;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: var(--bg);
  text-decoration: none;
  color: inherit;
  transition: background 0.12s, border-color 0.12s;
}
.ql-item:hover { background: var(--bg-3); border-color: var(--accent); }
.ql-label { font: 600 14px var(--font-sans); color: var(--text); }
.ql-sub   { font: 11px var(--font-mono); color: var(--muted); }

/* ===== S1 — NOW zone (live system health summary at top of dashboard) ===== */
.now-zone {
  display: grid;
  grid-template-columns: minmax(260px, 1fr) 2.4fr;
  gap: 1px;
  background: var(--border);
  border-radius: 14px;
  border: 1px solid var(--border-strong);
  overflow: hidden;
}
.now-zone.now-is-ok    { background: linear-gradient(135deg, rgba(22,163,74,0.18) 0%, transparent 55%), var(--border); }
.now-zone.now-is-warn  { background: linear-gradient(135deg, rgba(202,138,4,0.18) 0%, transparent 55%), var(--border); }
.now-zone.now-is-err   { background: linear-gradient(135deg, rgba(220,38,38,0.22) 0%, transparent 55%), var(--border); }
.now-zone.now-is-muted { background: var(--border); }

.now-head {
  padding: 22px 24px;
  background: var(--bg);
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.now-label {
  font: 600 11px var(--font-sans);
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--muted);
}
.now-status {
  font: 700 26px var(--font-sans);
  letter-spacing: -0.01em;
  text-transform: capitalize;
}
.now-status-is-ok    { color: #4ade80; }
.now-status-is-warn  { color: #fbbf24; }
.now-status-is-err   { color: #f87171; }
.now-status-is-muted { color: var(--muted); }
.now-sub {
  font: 12px var(--font-mono);
  color: var(--muted);
}

.now-checks {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  background: var(--bg);
}
.now-cell {
  padding: 16px 16px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  border-left: 1px solid var(--border);
  text-decoration: none;
  color: inherit;
  transition: background 0.12s;
}
.now-cell:first-child { border-left: none; }
.now-cell:hover { background: var(--bg-3); }
.now-cell-name {
  font: 600 11px var(--font-sans);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--muted);
}
.now-cell-row {
  display: flex;
  align-items: center;
  gap: 8px;
}
.now-cell-latency {
  font: 600 15px var(--font-mono);
  font-variant-numeric: tabular-nums;
  color: var(--text);
}
.now-pill {
  display: inline-flex;
  padding: 1px 8px;
  border-radius: 999px;
  font: 600 10px var(--font-sans);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  border: 1px solid;
}
.now-pill.is-ok    { background: rgba(22,163,74,0.13);  color: #4ade80; border-color: rgba(22,163,74,0.35); }
.now-pill.is-warn  { background: rgba(202,138,4,0.13);  color: #fbbf24; border-color: rgba(202,138,4,0.35); }
.now-pill.is-err   { background: rgba(220,38,38,0.13);  color: #f87171; border-color: rgba(220,38,38,0.35); }
.now-pill.is-muted { background: rgba(156,163,175,0.13);color: #9ca3af; border-color: rgba(156,163,175,0.30); }
.now-cell-detail {
  font: 11px var(--font-mono);
  color: var(--muted-2);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* ===== S2 — KPI + Watchlist side-by-side under hero-top ===== */
.hero-body--has-watchlist {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 16px;
  align-items: start;
}
.watchlist {
  background: rgba(248, 113, 113, 0.06);
  border: 1px solid rgba(248, 113, 113, 0.22);
  border-radius: 12px;
  padding: 14px 16px;
}
.watchlist-head {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 12px;
}
.watchlist-title {
  font: 600 11px var(--font-sans);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--muted);
}
.watchlist-badge {
  background: rgba(248, 113, 113, 0.18);
  color: #f87171;
  font: 600 10px var(--font-sans);
  letter-spacing: 0.04em;
  padding: 1px 8px;
  border-radius: 999px;
}
.watchlist-list { display: flex; flex-direction: column; gap: 10px; }
.watchlist-item {
  padding-bottom: 10px;
  border-bottom: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.watchlist-item:last-child { border-bottom: none; padding-bottom: 0; }
.watchlist-row1 {
  display: flex; justify-content: space-between; align-items: baseline;
  gap: 8px;
}
.watchlist-name { font: 600 13px var(--font-sans); color: var(--text); }
.watchlist-value {
  font: 600 13px var(--font-mono);
  font-variant-numeric: tabular-nums;
  color: #f87171;
}
.watchlist-item.sev-warning .watchlist-value { color: #fbbf24; }
.watchlist-why {
  font: 11px var(--font-sans);
  color: var(--muted);
  line-height: 1.45;
}
.watchlist-cta {
  font: 600 11px var(--font-sans);
  color: var(--accent);
  text-decoration: none;
  margin-top: 2px;
}
.watchlist-cta:hover { text-decoration: underline; }

@media (max-width: 1100px) {
  .now-zone { grid-template-columns: 1fr; }
  .now-checks { grid-template-columns: repeat(2, 1fr); }
  .now-cell { border-left: none; border-top: 1px solid var(--border); }
  .now-cell:first-child, .now-cell:nth-child(2) { border-top: none; }
  .hero-body--has-watchlist { grid-template-columns: 1fr; }
}

@media (max-width: 900px) {
  .spark-grid    { grid-template-columns: repeat(2, 1fr); }
  .quick-links   { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 520px) {
  .spark-grid    { grid-template-columns: 1fr; }
  .quick-links   { grid-template-columns: 1fr; }
  .now-checks    { grid-template-columns: 1fr; }
  .now-cell:nth-child(2) { border-top: 1px solid var(--border); }
}
