/* JAS Cleaning status page styles — ported verbatim from src/website/status.html <style> block.
   Linked from the Next /status route via PageStyles (precedence jas-4-page) so the page renders
   pixel-for-pixel like the finalized static page. */

  .st-summary { background: var(--leaf-bg); border: 1px solid #B8CFA1; border-radius: var(--r-lg); padding: 32px 40px; margin-bottom: 28px; display: flex; gap: 24px; align-items: center; }
  .st-summary .indicator { width: 18px; height: 18px; border-radius: 999px; background: var(--leaf); box-shadow: 0 0 0 6px rgba(46, 107, 58, 0.15); animation: pulse 1.6s infinite; flex-shrink: 0; }
  @keyframes pulse { 50% { opacity: 0.55; } }
  .st-summary h2 { font-family: var(--display); font-size: 32px; letter-spacing: -0.02em; color: var(--moss); font-weight: 400; }
  .st-summary p { color: var(--moss); margin-top: 4px; font-size: 14px; }

  .st-service-row { display: grid; grid-template-columns: 1fr 100px 80px 120px; gap: 18px; padding: 18px 24px; border-bottom: 1px solid var(--line-soft); align-items: center; }
  .st-service-row:last-child { border-bottom: 0; }
  .st-service-row.head { background: var(--surface-2); font-family: var(--mono); font-size: 10.5px; color: var(--ink-3); letter-spacing: 0.12em; text-transform: uppercase; }
  .st-service-row .name { font-weight: 500; font-size: 15px; }
  .st-service-row .name .desc { font-family: var(--mono); font-size: 11px; color: var(--ink-3); margin-top: 4px; letter-spacing: 0.04em; }
  .st-service-row .uptime { font-family: var(--mono); font-size: 14px; font-weight: 600; color: var(--leaf); }
  .st-status-dot { display: inline-flex; align-items: center; gap: 6px; font-size: 12px; font-weight: 500; }
  .st-status-dot::before { content: ""; width: 8px; height: 8px; border-radius: 999px; background: currentColor; }
  .st-status-dot.ok { color: var(--leaf); }
  .st-status-dot.degraded { color: var(--gold); }
  .st-status-dot.down { color: var(--coral); }

  .st-bars { display: flex; gap: 3px; height: 36px; }
  .st-bar { flex: 1; background: var(--leaf); border-radius: 2px; min-width: 2px; }
  .st-bar.warn { background: var(--gold); }
  .st-bar.err { background: var(--coral); }
  .st-bar.future { background: var(--surface-2); }

  .st-uptime-card { background: var(--paper); border: 1px solid var(--line); border-radius: var(--r-lg); padding: 28px 32px; margin-bottom: 24px; }
  .st-uptime-card h3 { font-family: var(--display); font-size: 24px; letter-spacing: -0.01em; margin-bottom: 16px; }

  .st-incidents-list { background: var(--paper); border: 1px solid var(--line); border-radius: var(--r-lg); padding: 28px 32px; }
  .st-incidents-list h3 { font-family: var(--display); font-size: 24px; letter-spacing: -0.01em; margin-bottom: 16px; }
  .st-incident { padding: 18px 0; border-bottom: 1px solid var(--line-soft); }
  .st-incident:last-child { border-bottom: 0; }
  .st-incident .date { font-family: var(--mono); font-size: 11px; color: var(--ink-3); letter-spacing: 0.06em; }
  .st-incident .title { font-family: var(--display); font-size: 19px; letter-spacing: -0.01em; margin-top: 4px; }
  .st-incident .desc { font-size: 14px; color: var(--ink-2); margin-top: 6px; line-height: 1.55; }
  .st-incident.resolved .title::after { content: " · Resolved"; color: var(--leaf); font-family: var(--mono); font-size: 11px; letter-spacing: 0.06em; text-transform: uppercase; }

  .st-subscribe { background: var(--ink); color: var(--paper); border-radius: var(--r-lg); padding: 28px 32px; margin-top: 24px; display: flex; gap: 24px; align-items: center; flex-wrap: wrap; }
  .st-subscribe h3 { font-family: var(--display); font-size: 24px; color: var(--paper); letter-spacing: -0.01em; }
  .st-subscribe p { font-size: 14px; color: rgba(244, 239, 230, 0.7); margin-top: 4px; }
  .st-subscribe .actions { display: flex; gap: 8px; margin-left: auto; flex-wrap: wrap; }

  @media (max-width: 900px) {
    .st-summary { flex-wrap: wrap; padding: 24px; }
    .st-service-row { grid-template-columns: 1fr; gap: 6px; padding: 14px 18px; }
    .st-service-row.head { display: none; }
  }

  /* Honest pre-launch additions (2026-06): neutral chrome while no real monitoring
     exists — no green "Operational" dots, no pulsing live indicator. Real states
     (.ok/.degraded/.down, live bars) return when telemetry does. Pinned by
     scripts/next-honest-status.mjs. */
  .st-status-dot.pre { color: var(--ink-3); }
  .st-summary .indicator.pre { background: var(--ink-3); box-shadow: 0 0 0 6px rgba(58, 56, 51, 0.08); animation: none; }
