:root {
  --bg: #0f1115;
  --panel: #171a21;
  --panel-2: #1d212b;
  --border: #272c38;
  --text: #e6e9ef;
  --muted: #8b93a7;
  --accent: #4f8cff;
  --accent-2: #3a6fd8;
  --green: #34d399;
  --red: #f87171;
  --yellow: #fbbf24;
  --gray: #6b7280;
  --console-bg: #0a0c10;
  --overlay: rgba(0,0,0,.6);
}
:root[data-theme="light"] {
  --bg: #f3f5fa;
  --panel: #ffffff;
  --panel-2: #f0f2f7;
  --border: #e2e6f0;
  --text: #1c2230;
  --muted: #6b7280;
  --accent: #2f6bf0;
  --accent-2: #2257d6;
  --green: #15803d;
  --red: #dc2626;
  --yellow: #b45309;
  --gray: #9aa1b1;
  --console-bg: #0e1117;
  --overlay: rgba(20,24,33,.45);
}
:root[data-theme="light"] .badge.running { background: #e7f6ee; border-color: #b7e3c8; }
:root[data-theme="light"] .badge.failed  { background: #fdeaea; border-color: #f3c2c2; }
:root[data-theme="light"] .badge.deploying,
:root[data-theme="light"] .badge.partial { background: #fbf2e3; border-color: #ecd9b0; }
html { color-scheme: dark; }
html[data-theme="light"] { color-scheme: light; }
body, .card, .modal, button, input, select, textarea { transition: background-color .15s, border-color .15s, color .15s; }
* { box-sizing: border-box; }
body {
  margin: 0;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  background: var(--bg);
  color: var(--text);
  font-size: 14px;
}
a { color: var(--accent); text-decoration: none; }
button {
  font: inherit;
  cursor: pointer;
  border: 1px solid var(--border);
  background: var(--panel-2);
  color: var(--text);
  padding: 8px 14px;
  border-radius: 8px;
  transition: background .15s, border-color .15s;
}
button:hover { background: #232836; }
button:disabled { opacity: .5; cursor: not-allowed; }
button.primary { background: var(--accent); border-color: var(--accent); color: #fff; }
button.primary:hover { background: var(--accent-2); }
button.danger { color: var(--red); border-color: #4a2727; }
button.danger:hover { background: #2a1c1c; }
button.sm { padding: 5px 10px; font-size: 12px; }
input, select, textarea {
  font: inherit;
  background: var(--bg);
  color: var(--text);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 9px 11px;
  width: 100%;
}
input:focus, select:focus, textarea:focus { outline: none; border-color: var(--accent); }
label { display: block; font-size: 12px; color: var(--muted); margin: 0 0 5px; }
.field { margin-bottom: 14px; }
.hidden { display: none !important; }
.row { display: flex; gap: 10px; align-items: center; }
.row.wrap { flex-wrap: wrap; }
.spacer { flex: 1; }
.muted { color: var(--muted); }
.mono { font-family: ui-monospace, SFMono-Regular, Menlo, monospace; }

/* layout */
header.topbar {
  display: flex; align-items: center; gap: 12px;
  padding: 14px 22px; border-bottom: 1px solid var(--border); background: var(--panel);
}
header.topbar .brand { font-weight: 700; font-size: 16px; }
header.topbar .brand span { color: var(--accent); }
.container { max-width: 1080px; margin: 0 auto; padding: 24px 22px; }

/* login */
.login-wrap { display: grid; place-items: center; min-height: 100vh; }
.login-card { width: 360px; background: var(--panel); border: 1px solid var(--border); border-radius: 14px; padding: 28px; }
.login-card h1 { margin: 0 0 4px; font-size: 20px; }

/* cards */
.grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 14px; }
.card {
  background: var(--panel); border: 1px solid var(--border); border-radius: 12px;
  padding: 16px; cursor: pointer; transition: border-color .15s, transform .05s;
}
.card:hover { border-color: var(--accent); }
.card h3 { margin: 0 0 4px; font-size: 15px; }
.card .domain { font-size: 13px; }
.card .meta { margin-top: 10px; display: flex; gap: 8px; align-items: center; }

.badge { font-size: 11px; padding: 3px 9px; border-radius: 20px; border: 1px solid var(--border); text-transform: uppercase; letter-spacing: .03em; }
.badge.running { color: var(--green); border-color: #1f4d3a; background: #11261d; }
.badge.stopped { color: var(--gray); }
.badge.failed  { color: var(--red); border-color: #4a2727; background: #241818; }
.badge.deploying, .badge.partial { color: var(--yellow); border-color: #4a3f1f; background: #241f12; }
.badge.created { color: var(--muted); }

.tag { font-size: 11px; padding: 2px 8px; border-radius: 6px; background: var(--panel-2); color: var(--muted); border: 1px solid var(--border); }

/* modal — anchored near the top so it doesn't jump vertically between tabs */
.overlay { position: fixed; inset: 0; background: var(--overlay); display: flex; align-items: flex-start; justify-content: center; padding: 6vh 14px 24px; z-index: 50; overflow-y: auto; }
.modal { width: min(760px, 96vw); max-height: 86vh; overflow: auto; background: var(--panel); border: 1px solid var(--border); border-radius: 14px; }
.modal header { position: sticky; top: 0; background: var(--panel); display: flex; align-items: center; padding: 16px 20px; border-bottom: 1px solid var(--border); z-index: 2; }
.modal header h2 { margin: 0; font-size: 17px; }
.modal .body { padding: 20px; }
.modal.small { width: min(460px, 96vw); }

/* tabs */
.tabs { display: flex; gap: 4px; border-bottom: 1px solid var(--border); margin-bottom: 16px; }
.tabs button { border: none; background: none; border-radius: 0; border-bottom: 2px solid transparent; color: var(--muted); padding: 8px 12px; }
.tabs button.active { color: var(--text); border-bottom-color: var(--accent); }

pre.console {
  background: var(--console-bg); color: #d6dae3; border: 1px solid var(--border); border-radius: 10px;
  padding: 14px; font-family: ui-monospace, SFMono-Regular, Menlo, monospace; font-size: 12.5px;
  white-space: pre-wrap; word-break: break-word; max-height: 420px; overflow: auto; margin: 0;
}
table { width: 100%; border-collapse: collapse; }
th, td { text-align: left; padding: 8px 10px; border-bottom: 1px solid var(--border); font-size: 13px; }
th { color: var(--muted); font-weight: 500; }

.kv-row { display: grid; grid-template-columns: 1fr 1fr auto; gap: 8px; margin-bottom: 8px; }
.toast {
  position: fixed; bottom: 20px; right: 20px; z-index: 100;
  background: var(--panel-2); border: 1px solid var(--border); border-radius: 10px; padding: 12px 16px; max-width: 360px;
}
.toast.err { border-color: #4a2727; color: var(--red); }
.toast.ok { border-color: #1f4d3a; color: var(--green); }
.err-text { color: var(--red); font-size: 13px; min-height: 18px; }

/* metrics */
.metrics-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: 12px; margin-bottom: 18px; }
.stat { background: var(--panel-2); border: 1px solid var(--border); border-radius: 10px; padding: 14px; }
.stat .lbl { font-size: 11px; color: var(--muted); text-transform: uppercase; letter-spacing: .04em; }
.stat .big { font-size: 22px; font-weight: 700; margin-top: 2px; }
.bar { height: 8px; background: #0a0c10; border: 1px solid var(--border); border-radius: 6px; overflow: hidden; margin-top: 8px; }
.bar > i { display: block; height: 100%; background: var(--accent); }
.bar > i.warn { background: var(--yellow); }
.bar > i.crit { background: var(--red); }
.cols { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }

@media (max-width: 640px) {
  .cols { grid-template-columns: 1fr; }
  header.topbar { flex-wrap: wrap; gap: 8px; padding: 10px 14px; }
  header.topbar .brand { font-size: 15px; }
  header.topbar #who { display: none; }
  header.topbar button { padding: 6px 11px; font-size: 12px; }
  .container { padding: 16px 14px; }
  .grid { grid-template-columns: 1fr; }
  .overlay { padding: 2vh 8px 16px; }
  .modal { max-height: 94vh; }
  .modal .body { padding: 16px; }
  .modal table { display: block; overflow-x: auto; white-space: nowrap; }
  pre.console { font-size: 11.5px; max-height: 50vh; }
}
