:root {
  --bg: #0b1020;
  --panel: rgba(255, 255, 255, 0.06);
  --panel2: rgba(255, 255, 255, 0.09);
  --text: rgba(255, 255, 255, 0.92);
  --muted: rgba(255, 255, 255, 0.62);
  --border: rgba(255, 255, 255, 0.12);
  --shadow: rgba(0, 0, 0, 0.45);
}

* { box-sizing: border-box; }
html, body { height: 100%; margin: 0; }
body {
  background: radial-gradient(1200px 800px at 20% 20%, #18244a 0%, var(--bg) 55%);
  color: var(--text);
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;
}

#app { display: grid; grid-template-columns: 360px 1fr; height: 100vh; }

.sidebar {
  padding: 14px;
  overflow: auto;
  border-right: 1px solid var(--border);
  background: linear-gradient(180deg, rgba(255,255,255,0.03), rgba(255,255,255,0.01));
}

.header { margin-bottom: 12px; }
.title { font-size: 18px; font-weight: 700; letter-spacing: 0.2px; }
.subtitle { font-size: 12px; color: var(--muted); margin-top: 2px; }

.card {
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 12px;
  margin-bottom: 12px;
  box-shadow: 0 10px 30px var(--shadow);
}

.card-title {
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--muted);
  margin-bottom: 10px;
}

.row { margin: 10px 0; }
.row-inline { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; }

.label { font-size: 12px; color: var(--muted); display: block; margin-bottom: 6px; }

.input, .select {
  width: 100%;
  background: var(--panel2);
  border: 1px solid var(--border);
  color: var(--text);
  padding: 10px 10px;
  border-radius: 10px;
  outline: none;
}
.select { padding: 9px 10px; width: auto; }
.input.file { padding: 8px; }

.btn {
  background: transparent;
  border: 1px solid var(--border);
  color: var(--text);
  padding: 9px 10px;
  border-radius: 10px;
  cursor: pointer;
}
.btn:hover { border-color: rgba(255,255,255,0.22); }
.btn.primary { background: rgba(255,255,255,0.12); }
.btn.tab { flex: 1; }
.btn.tab.active { background: rgba(255,255,255,0.12); }

.status {
  font-size: 12px;
  color: var(--muted);
  padding: 8px 10px;
  border-radius: 10px;
  border: 1px dashed rgba(255,255,255,0.18);
}

.hint { font-size: 12px; color: var(--muted); line-height: 1.3; }

.mono { font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace; }
.small { font-size: 12px; }
.tiny { display: flex; gap: 10px; font-size: 12px; color: var(--muted); margin-top: 6px; }
.spacer { flex: 1; }

.toggles { display: grid; gap: 8px; }
.toggle {
  display: flex; align-items: center; gap: 8px;
  padding: 8px 10px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 12px;
}
.swatch { width: 10px; height: 10px; border-radius: 99px; background: white; }
.toggle label { flex: 1; font-size: 12px; color: var(--text); }
.toggle input { transform: translateY(1px); }

.logs { height: 420px; display: flex; flex-direction: column; }
.loglist {
  flex: 1;
  overflow: auto;
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 12px;
  background: rgba(0,0,0,0.12);
}
.logitem {
  padding: 8px 10px;
  border-bottom: 1px solid rgba(255,255,255,0.08);
}
.logitem:last-child { border-bottom: none; }
.logitem .idx { color: rgba(255,255,255,0.55); font-size: 11px; }
.logitem .txt { white-space: pre-wrap; word-break: break-word; font-size: 12px; }

.main { position: relative; }
.viewport { position: absolute; inset: 0; }
.overlay {
  position: absolute;
  left: 12px;
  bottom: 12px;
  pointer-events: none;
}
.pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 12px;
  border-radius: 999px;
  background: rgba(0,0,0,0.32);
  border: 1px solid rgba(255,255,255,0.12);
  backdrop-filter: blur(8px);
  box-shadow: 0 10px 30px rgba(0,0,0,0.5);
}
.dot { width: 8px; height: 8px; border-radius: 999px; background: rgba(255,255,255,0.7); }
