: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); } .button.button-sm { padding: 0.35rem 0.55rem; font-size: 0.82rem; } 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; } .grid-2 { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 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; } .edit-panel { margin-top: 0.8rem; } .edit-panel summary { cursor: pointer; color: #7dd3fc; } .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; } .pill.warning { border-color: #f59e0b; color: #fde68a; } .pill.success { border-color: #22c55e; color: #86efac; } .pill.running { border-color: #38bdf8; color: #bae6fd; } .pill.queued { border-color: #a78bfa; color: #ddd6fe; } .pill.partial { border-color: #f59e0b; color: #fde68a; } .pill.sqlite { border-color: #f59e0b; color: #fde68a; } .pill.pending { border-color: var(--border); color: var(--muted); } .target-list { margin: 0.25rem 0 0.75rem; padding-left: 1.1rem; display: grid; gap: 0.3rem; } .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); } textarea { 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; resize: vertical; } .muted { margin: 0.75rem 0 0; color: var(--muted); } .muted.inline { margin-left: 0.5rem; } .throbber { display: inline-block; width: 0.9rem; height: 0.9rem; margin-left: 0.45rem; border: 2px solid color-mix(in srgb, #38bdf8 35%, transparent); border-top-color: #38bdf8; border-radius: 50%; animation: spin 0.8s linear infinite; vertical-align: -1px; } .hidden { display: none; } @keyframes spin { from { transform: rotate(0deg); } to { transform: rotate(360deg); } } a { color: #7dd3fc; }