:root { color-scheme: light dark; --bg: #0f172a; --fg: #e2e8f0; --muted: #94a3b8; --card: #111827; --border: #334155; } * { box-sizing: border-box; } body { margin: 0; min-height: 100vh; display: grid; place-items: center; background: radial-gradient(circle at top, #1e293b 0, var(--bg) 55%); color: var(--fg); font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, sans-serif; } .card { width: min(680px, calc(100vw - 2rem)); border: 1px solid var(--border); background: color-mix(in srgb, var(--card) 85%, black); border-radius: 16px; padding: 2rem; } .dashboard-card { width: min(980px, calc(100vw - 2rem)); } .eyebrow { margin: 0 0 0.75rem; text-transform: uppercase; letter-spacing: 0.08em; color: var(--muted); font-size: 0.8rem; } h1 { margin: 0; font-size: 2rem; } .row { display: flex; gap: 0.75rem; margin-top: 1rem; align-items: center; } .split { justify-content: space-between; align-items: flex-start; flex-wrap: wrap; } .stack { display: grid; gap: 0.5rem; } .auth-card { width: min(480px, calc(100vw - 2rem)); } .button { display: inline-flex; align-items: center; justify-content: center; border-radius: 10px; border: 1px solid transparent; background: #38bdf8; color: #082f49; font-weight: 700; text-decoration: none; padding: 0.65rem 1rem; cursor: pointer; } .button:hover { filter: brightness(1.05); } .button.ghost { background: transparent; color: var(--fg); border-color: var(--border); } input { width: 100%; border: 1px solid var(--border); border-radius: 10px; background: color-mix(in srgb, var(--card) 75%, black); color: var(--fg); padding: 0.6rem 0.75rem; } .error { border: 1px solid #ef4444; background: color-mix(in srgb, #ef4444 22%, transparent); border-radius: 10px; color: #fecaca; margin: 0.75rem 0; padding: 0.6rem 0.75rem; } .notice { border: 1px solid #22c55e; background: color-mix(in srgb, #22c55e 18%, transparent); border-radius: 10px; color: #bbf7d0; margin: 0.75rem 0; padding: 0.6rem 0.75rem; } section { margin-top: 1.5rem; } h2 { margin: 0 0 0.75rem; font-size: 1.2rem; } .status-list { list-style: none; margin: 0; padding: 0; display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 0.75rem; } .status { border: 1px solid var(--border); border-radius: 12px; padding: 0.6rem 0.75rem; display: grid; gap: 0.3rem; } .status.installed { border-color: #22c55e; } .status.missing { border-color: #ef4444; } .workflow { margin: 0; padding-left: 1.2rem; display: grid; gap: 0.75rem; } .workflow-step p { margin: 0.4rem 0 0; color: var(--muted); } .grid-3 { display: grid; grid-template-columns: repeat(auto-fit, minmax(190px, 1fr)); gap: 0.75rem; align-items: end; } .site-card { border: 1px solid var(--border); border-radius: 12px; padding: 0.9rem; margin-top: 0.8rem; } .site-head { display: flex; justify-content: space-between; align-items: center; gap: 0.75rem; } .site-head h3 { margin: 0; } .pill { display: inline-block; text-transform: uppercase; font-size: 0.75rem; letter-spacing: 0.04em; border: 1px solid var(--border); border-radius: 999px; padding: 0.15rem 0.55rem; } .pill.ok { border-color: #22c55e; color: #86efac; } .pill.failed { border-color: #ef4444; color: #fecaca; } .output { white-space: pre-wrap; overflow-wrap: anywhere; border: 1px solid var(--border); border-radius: 10px; padding: 0.6rem; margin-top: 0.6rem; background: color-mix(in srgb, var(--card) 80%, black); } .muted { margin: 0.75rem 0 0; color: var(--muted); } a { color: #7dd3fc; }