/* ===== Dark theme (default) — high-contrast ===== */
:root {
	--bg: #0d1117;
	--panel: #161c24;
	--panel-2: #1f2732;
	--border: #323c4a;
	--text: #f6f8fc;        /* near-white body text */
	--muted: #c2ccda;       /* brightened for contrast (was #9aa4b2) */
	--faint: #8b96a6;       /* only for small non-essential hints */
	--accent: #5c9bff;
	--accent-2: #3f78e0;
	--danger: #ff6b7a;
	--danger-strong: #ff8791;
	--ok: #3dd69b;
	--shadow: 0 20px 60px rgba(0,0,0,.5);
}

/* ===== Light theme ===== */
:root[data-theme="light"] {
	--bg: #eef1f6;
	--panel: #ffffff;
	--panel-2: #f2f5f9;
	--border: #cfd8e3;
	--text: #10151d;        /* very dark text for max contrast */
	--muted: #3f4a5a;       /* dark-enough grey on white */
	--faint: #64708192;
	--accent: #2f6fe0;
	--accent-2: #245bc0;
	--danger: #d12a3a;
	--danger-strong: #b31f2e;
	--ok: #157a52;
	--shadow: 0 16px 44px rgba(19,38,68,.14);
}

* { box-sizing: border-box; }

body {
	margin: 0;
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
	background: radial-gradient(1200px 600px at 70% -10%, color-mix(in srgb, var(--accent) 12%, var(--bg)) 0%, var(--bg) 60%);
	color: var(--text);
	min-height: 100vh;
	-webkit-font-smoothing: antialiased;
}

a { color: var(--accent); }

.center {
	min-height: 100vh;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 24px;
}

.card {
	width: 100%;
	max-width: 380px;
	background: var(--panel);
	border: 1px solid var(--border);
	border-radius: 14px;
	padding: 32px 28px;
	box-shadow: var(--shadow);
}

.brand { display: flex; align-items: center; gap: 10px; margin-bottom: 22px; }
.brand .dot { width: 12px; height: 12px; border-radius: 50%; background: var(--accent); box-shadow: 0 0 14px var(--accent); }
.brand h1 { font-size: 17px; margin: 0; letter-spacing: .3px; color: var(--text); }
.brand small { color: var(--muted); display: block; font-weight: 500; }

label { display: block; font-size: 13px; color: var(--muted); font-weight: 600; margin: 14px 0 6px; }

input[type=text], input[type=email], input[type=password] {
	width: 100%;
	padding: 11px 12px;
	background: var(--panel-2);
	border: 1px solid var(--border);
	border-radius: 9px;
	color: var(--text);
	font-size: 14px;
	outline: none;
	transition: border-color .15s;
}
input::placeholder { color: var(--faint); }
input:focus { border-color: var(--accent); box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 25%, transparent); }

button {
	width: 100%;
	margin-top: 20px;
	padding: 11px 14px;
	background: linear-gradient(180deg, var(--accent), var(--accent-2));
	color: #fff;
	border: 0;
	border-radius: 9px;
	font-size: 14px;
	font-weight: 700;
	cursor: pointer;
}
button:hover { filter: brightness(1.06); }

.msg {
	display: none;
	margin-top: 16px;
	padding: 10px 12px;
	border-radius: 9px;
	font-size: 13px;
	font-weight: 600;
	border: 1px solid transparent;
}
.msg.show { display: block; }
.msg.error { background: color-mix(in srgb, var(--danger) 14%, transparent); border-color: color-mix(in srgb, var(--danger) 45%, transparent); color: var(--danger-strong); }
.msg.ok { background: color-mix(in srgb, var(--ok) 14%, transparent); border-color: color-mix(in srgb, var(--ok) 45%, transparent); color: var(--ok); }

.foot { margin-top: 18px; text-align: center; color: var(--muted); font-size: 12px; font-weight: 500; }

/* theme toggle */
.theme-toggle {
	position: fixed;
	top: 16px;
	right: 16px;
	width: auto;
	margin: 0;
	padding: 7px 12px;
	background: var(--panel);
	color: var(--text);
	border: 1px solid var(--border);
	border-radius: 20px;
	font-size: 12px;
	font-weight: 600;
	box-shadow: var(--shadow);
}
.theme-toggle:hover { filter: none; border-color: var(--accent); }

/* error pages */
.err-code { font-size: 64px; font-weight: 800; letter-spacing: 2px; margin: 0; color: var(--text); }
.err-code.c403 { color: var(--danger-strong); }
.err-msg { color: var(--muted); margin: 8px 0 20px; font-weight: 500; }

/* dashboard */
.wrap { width: 100%; max-width: none; margin: 0; padding: 24px 32px 60px; }
.nav a.active { background: color-mix(in srgb, var(--accent) 16%, transparent); color: var(--accent); border-color: var(--accent); }
.topbar { display: flex; align-items: center; justify-content: space-between; margin-bottom: 26px; gap: 12px; }
.topbar .user { color: var(--muted); font-size: 13px; font-weight: 600; }
.jobs { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 14px; }
.job { background: var(--panel); border: 1px solid var(--border); border-radius: 12px; padding: 16px; }
.job h3 { margin: 0 0 6px; font-size: 15px; color: var(--text); }
.job p { margin: 0 0 12px; color: var(--muted); font-size: 12.5px; line-height: 1.5; font-weight: 500; }
.tag { display: inline-block; font-size: 11px; font-weight: 700; padding: 2px 8px; border-radius: 20px; margin-left: 8px; vertical-align: middle; }
.tag.mut { background: color-mix(in srgb, var(--danger) 15%, transparent); color: var(--danger-strong); border: 1px solid color-mix(in srgb, var(--danger) 40%, transparent); }
.tag.ro { background: color-mix(in srgb, var(--ok) 15%, transparent); color: var(--ok); border: 1px solid color-mix(in srgb, var(--ok) 40%, transparent); }
.linkbtn { background: none; color: var(--accent); border: 1px solid var(--border); width: auto; margin: 0; padding: 7px 12px; font-weight: 600; }
.linkbtn:hover { border-color: var(--accent); filter: none; }

/* ===== shared components (nav, forms, tables, logs) ===== */
.nav { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.lead { color: var(--muted); font-size: 13.5px; margin: 0 0 20px; font-weight: 500; }
a.job { text-decoration: none; display: block; transition: border-color .15s, transform .05s; }
a.job:hover { border-color: var(--accent); }
a.job .open { color: var(--accent); font-size: 12.5px; font-weight: 600; }

.panel { background: var(--panel); border: 1px solid var(--border); border-radius: 12px; padding: 20px; margin-bottom: 16px; }
.panel h2 { margin: 0 0 6px; font-size: 18px; color: var(--text); }
.panel .help { color: var(--muted); font-size: 13.5px; line-height: 1.6; font-weight: 500; margin: 0 0 4px; }

.field { margin-top: 16px; }
.field .hint { color: var(--faint); font-size: 12px; margin-top: 4px; font-weight: 500; }
.field.inline { display: flex; align-items: center; gap: 10px; }
.field.inline label { margin: 0; }
input[type=checkbox] { width: 16px; height: 16px; accent-color: var(--accent); }
select { width: 100%; padding: 11px 12px; background: var(--panel-2); border: 1px solid var(--border); border-radius: 9px; color: var(--text); font-size: 14px; }

.row { display: flex; gap: 10px; flex-wrap: wrap; align-items: flex-end; }
.btn-primary { width: auto; margin: 0; }
.btn-danger { width: auto; margin: 0; background: linear-gradient(180deg, var(--danger), var(--danger-strong)); }
.btn-row { display: flex; gap: 10px; margin-top: 20px; flex-wrap: wrap; }

table { width: 100%; border-collapse: collapse; font-size: 13px; }
th, td { text-align: left; padding: 9px 10px; border-bottom: 1px solid var(--border); color: var(--text); }
th { color: var(--muted); font-weight: 700; font-size: 11.5px; text-transform: uppercase; letter-spacing: .4px; }
tr:hover td { background: color-mix(in srgb, var(--accent) 6%, transparent); }
td a { color: var(--accent); text-decoration: none; }

.badge { display: inline-block; font-size: 11px; font-weight: 700; padding: 2px 8px; border-radius: 20px; }
.badge.SUCCEEDED { background: color-mix(in srgb, var(--ok) 16%, transparent); color: var(--ok); }
.badge.RUNNING, .badge.QUEUED { background: color-mix(in srgb, var(--accent) 16%, transparent); color: var(--accent); }
.badge.FAILED { background: color-mix(in srgb, var(--danger) 16%, transparent); color: var(--danger-strong); }
.badge.ABORTED { background: color-mix(in srgb, #8a94a6 20%, transparent); color: #8a94a6; }
.badge.warn { background: color-mix(in srgb, #e8a33d 18%, transparent); color: #e8a33d; }
.badge.dry { background: color-mix(in srgb, var(--ok) 14%, transparent); color: var(--ok); }
.badge.live { background: color-mix(in srgb, var(--danger) 16%, transparent); color: var(--danger-strong); }
.badge.trash { background: color-mix(in srgb, #8a94a6 20%, transparent); color: #8a94a6; }

.log {
	background: #0a0d12;
	color: #d6dde7;
	border: 1px solid var(--border);
	border-radius: 9px;
	padding: 14px;
	font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
	font-size: 12px;
	line-height: 1.5;
	white-space: pre-wrap;
	word-break: break-word;
	max-height: 520px;
	overflow: auto;
}
:root[data-theme="light"] .log { background: #0e1420; color: #dfe6ef; }
.back { color: var(--accent); text-decoration: none; font-size: 13px; font-weight: 600; }
