:root {
  --bg: #0f1117;
  --panel: #181b24;
  --panel-2: #1f2330;
  --border: #2a2f3d;
  --text: #e6e8ee;
  --muted: #9aa3b2;
  --accent: #7c5cff;
  --accent-2: #5b8cff;
  --danger: #e5484d;
  --green: #46a758;
  --amber: #ffb224;

  /* ---- Railway-style Architecture canvas (warm/magenta cast, measured from goal.png) ---- */
  --rl-bg:         #0e0a14;  /* canvas, purple-tinted near-black */
  --rl-topbar:     #0e0a14;  /* app bar tint on canvas/panel view (matches canvas) */
  --rl-panel:      #191322;  /* node + member card surface */
  --rl-surface:    #13111c;  /* slide-over panel surface (sits above canvas) */
  --rl-panel-2:    #221a2e;  /* chip / subtle raised */
  --rl-group:      #16121b;  /* group box — recessed (darker than cards) */
  --rl-inset:      #120d18;  /* volume / foot sub-row */
  --rl-border:     #2a2333;  /* card border */
  --rl-border-grp: #342f3e;  /* group border + connectors */
  --rl-border-hi:  #4a4560;  /* hover/focus border */
  --rl-text:       #e1e1e3;
  --rl-muted:      #8b8693;
  --rl-accent:     #8b2fe6;  /* avatar / focus / primary / active tab */
  --rl-link:       #c178ee;  /* subtitle/domain tint */
  --rl-pink:       #e5398f;  /* reserved accent */
  --rl-green:      #73ba98;  /* status check */
  --rl-logkey:     #77c09d;  /* log JSON keys */
  --rl-logval:     #587bcc;  /* log JSON values */
  --rl-logdate:    #726f7b;  /* log timestamp column */
  --rl-dot:        #221d29;  /* dot-grid dot */

  --rl-card-w:     256px;
  --rl-group-w:    286px;
  --rl-chip:       26px;
}

* { box-sizing: border-box; }
body {
  margin: 0;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
  background: var(--bg);
  color: var(--text);
  line-height: 1.5;
}
a { color: var(--accent-2); text-decoration: none; }
a:hover { text-decoration: underline; }

.topbar {
  display: flex; align-items: center; justify-content: space-between; gap: 1.5rem;
  padding: 0.6rem 1.25rem;
  background: var(--panel);
  border-bottom: 1px solid var(--border);
}
.topbar-left { display: flex; align-items: center; gap: 0.6rem; }
.brand { font-weight: 700; font-size: 1.05rem; color: var(--text); }
.crumb-sep { color: var(--muted); }
.crumb { color: var(--text); }
.env-select select {
  background: var(--panel-2); color: var(--text); border: 1px solid var(--border);
  border-radius: 6px; padding: 0.3rem 0.5rem; font-size: 0.85rem;
}
.topbar-right { display: flex; align-items: center; gap: 0.25rem; flex-wrap: wrap; }
.tab {
  color: var(--muted); padding: 0.4rem 0.7rem; border-radius: 6px;
  font-size: 0.9rem; border-bottom: 2px solid transparent;
}
.tab:hover { color: var(--text); text-decoration: none; background: var(--panel-2); }
.tab.active { color: var(--text); border-bottom-color: var(--accent); }
.tab-sep { width: 1px; height: 20px; background: var(--border); margin: 0 0.4rem; }

main { max-width: 1040px; margin: 0 auto; padding: 1.5rem; }
.canvas-head { display: flex; align-items: center; justify-content: space-between; }
.small { font-size: 0.82rem; }
h1 { font-size: 1.6rem; }
h2 { font-size: 1.15rem; margin-top: 1.5rem; }
.muted { color: var(--muted); }
.mono { font-family: ui-monospace, "SF Mono", Menlo, monospace; font-size: 0.85em; }

.cards { display: flex; gap: 1rem; flex-wrap: wrap; margin: 1rem 0 2rem; }
.card {
  display: flex; flex-direction: column; gap: 0.25rem;
  background: var(--panel); border: 1px solid var(--border);
  border-radius: 10px; padding: 1rem 1.5rem; min-width: 120px; color: var(--text);
}
.card:hover { border-color: var(--accent); text-decoration: none; }
.card-num { font-size: 1.8rem; font-weight: 700; }
.card span:last-child { color: var(--muted); }

table { width: 100%; border-collapse: collapse; margin: 0.5rem 0; }
th, td { text-align: left; padding: 0.55rem 0.6rem; border-bottom: 1px solid var(--border); }
th { color: var(--muted); font-weight: 600; font-size: 0.85rem; text-transform: uppercase; letter-spacing: 0.03em; }

.panel {
  background: var(--panel); border: 1px solid var(--border);
  border-radius: 10px; padding: 1.25rem; margin: 1.5rem 0;
}
form label { display: block; margin: 0.6rem 0; color: var(--muted); font-size: 0.9rem; }
form input[type=text], form input:not([type]), form input[type=password],
form textarea, form select {
  display: block; width: 100%; margin-top: 0.25rem;
  background: var(--panel-2); color: var(--text);
  border: 1px solid var(--border); border-radius: 6px; padding: 0.5rem 0.6rem;
  font-size: 0.95rem;
}
form textarea { font-family: ui-monospace, monospace; }
.row { display: flex; gap: 0.6rem; align-items: flex-end; flex-wrap: wrap; }
.row input { width: auto; flex: 1; }
form.inline { display: inline; }
/* Read-only value shown like an input but clearly not editable. */
.static-field {
  display: block; margin-top: 0.25rem; padding: 0.5rem 0.6rem;
  background: var(--panel); color: var(--muted);
  border: 1px dashed var(--border); border-radius: 6px; font-size: 0.95rem;
}
/* Custom two-column server-type picker */
.stype { position: relative; margin-top: 0.25rem; }
.stype-toggle {
  display: flex; align-items: center; justify-content: space-between; gap: 0.6rem;
  width: 100%; cursor: pointer; text-align: left;
  background: var(--panel-2); color: var(--text);
  border: 1px solid var(--border); border-radius: 6px; padding: 0.5rem 0.6rem;
  font-size: 0.95rem;
}
.stype-toggle:hover { border-color: var(--accent); }
.stype-toggle[aria-expanded="true"] { border-color: var(--accent); }
.stype-caret { color: var(--muted); font-size: 0.8rem; }

.stype-panel {
  position: absolute; z-index: 30; top: calc(100% + 4px); left: 0;
  display: grid; grid-template-columns: 1fr 1fr; gap: 0.5rem;
  min-width: 100%; padding: 0.5rem;
  background: var(--panel); border: 1px solid var(--border); border-radius: 8px;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.45);
}
/* `display: grid` above outranks the UA [hidden] rule, so restate it. */
.stype-panel[hidden] { display: none; }
.stype-col { min-width: 0; }
.stype-col-head {
  font-size: 0.72rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.04em;
  color: var(--muted); padding: 0.3rem 0.4rem; border-bottom: 1px solid var(--border);
  margin-bottom: 0.25rem; white-space: nowrap;
}
.stype-opt {
  display: flex; align-items: baseline; justify-content: space-between; gap: 0.75rem;
  width: 100%; cursor: pointer; text-align: left;
  background: transparent; color: var(--text); border: 1px solid transparent;
  border-radius: 5px; padding: 0.4rem 0.45rem; font-size: 0.9rem;
}
.stype-opt:hover { background: var(--panel-2); }
.stype-opt[aria-selected="true"] { border-color: var(--accent); background: var(--panel-2); }
.stype-opt-name { white-space: nowrap; }
.stype-opt-price { color: var(--muted); white-space: nowrap; font-variant-numeric: tabular-nums; }
.stype-empty { padding: 0.4rem 0.45rem; font-size: 0.85rem; }

@media (max-width: 560px) {
  .stype-panel { grid-template-columns: 1fr; }
}

.btn, .btn-secondary, .btn-danger {
  display: inline-block; border: none; border-radius: 6px; cursor: pointer;
  padding: 0.5rem 1rem; font-size: 0.9rem; font-weight: 600; color: #fff;
}
.btn { background: var(--accent); }
.btn:hover { background: #6b4cf0; }
.btn:disabled { background: var(--border); cursor: not-allowed; }
.btn-secondary { background: var(--panel-2); border: 1px solid var(--border); color: var(--text); }
.btn-danger { background: var(--danger); }
.btn-sm { padding: 0.2rem 0.5rem; font-size: 0.8rem; }

.badge {
  display: inline-block; padding: 0.1rem 0.55rem; border-radius: 999px;
  font-size: 0.78rem; font-weight: 600; background: var(--panel-2); color: var(--muted);
}
.badge-ready, .badge-running { background: rgba(70,167,88,0.18); color: var(--green); }
.badge-provisioning, .badge-deploying, .badge-building,
.badge-cloning, .badge-pending { background: rgba(255,178,36,0.18); color: var(--amber); }
.badge-error, .badge-failed { background: rgba(229,72,77,0.18); color: var(--danger); }

dl.kv { display: grid; grid-template-columns: max-content 1fr; gap: 0.3rem 1.5rem; margin: 1rem 0; }
dl.kv dt { color: var(--muted); }
dl.kv dd { margin: 0; }

.logbox {
  background: #0a0c12; border: 1px solid var(--border); border-radius: 8px;
  padding: 1rem; overflow-x: auto; white-space: pre-wrap; word-break: break-word;
  font-family: ui-monospace, monospace; font-size: 0.82rem; max-height: 60vh;
}
.logbox.error { color: var(--danger); }
.deploy-log { margin-top: 0.9rem; max-height: 320px; overflow-y: auto; }

.flashes { margin-bottom: 1rem; }
.flash { padding: 0.6rem 0.9rem; border-radius: 6px; margin-bottom: 0.5rem; }
.flash-success { background: rgba(70,167,88,0.15); border: 1px solid var(--green); }
.flash-error { background: rgba(229,72,77,0.15); border: 1px solid var(--danger); }

ul { padding-left: 1.2rem; }
li { margin: 0.3rem 0; }
details summary { cursor: pointer; color: var(--muted); margin: 0.5rem 0; }

/* ---------- searchable combobox (GitHub repo picker) ---------- */
.combo { position: relative; margin-top: 0.25rem; }
.combo-list {
  position: absolute; z-index: 40; top: calc(100% + 4px); left: 0; right: 0;
  margin: 0; padding: 0.3rem; list-style: none; max-height: 240px; overflow-y: auto;
  background: var(--panel); border: 1px solid var(--border); border-radius: 8px;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.45);
}
.combo-opt {
  padding: 0.4rem 0.5rem; border-radius: 5px; cursor: pointer;
  font-size: 0.9rem; white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.combo-opt:hover, .combo-opt.active { background: var(--panel-2); }
.combo-empty { padding: 0.4rem 0.5rem; font-size: 0.85rem; }

/* ---------- provisioning progress bar ---------- */
.provision {
  margin: 1.25rem 0; padding: 1.1rem 1.25rem;
  background: var(--panel); border: 1px solid var(--border); border-radius: 12px;
}
.provision-head {
  display: flex; align-items: baseline; justify-content: space-between; gap: 1rem;
  margin-bottom: 0.6rem;
}
.provision-label { font-size: 1.05rem; font-weight: 600; }
.provision-count { font-size: 0.85rem; }
.provision-track {
  height: 14px; border-radius: 999px; overflow: hidden;
  background: var(--panel-2); border: 1px solid var(--border);
}
.provision-fill {
  height: 100%; border-radius: 999px; background: var(--accent);
  transition: width 0.6s ease;
}
.provision-ready .provision-fill { background: var(--green); }
.provision-error .provision-fill { background: var(--danger); }
/* Subtle barber-pole animation while work is in flight. */
.provision-provisioning .provision-fill {
  background-image: linear-gradient(
    45deg,
    rgba(255, 255, 255, 0.18) 25%, transparent 25%,
    transparent 50%, rgba(255, 255, 255, 0.18) 50%,
    rgba(255, 255, 255, 0.18) 75%, transparent 75%, transparent
  );
  background-size: 1.25rem 1.25rem;
  animation: provision-stripe 1s linear infinite;
}
@keyframes provision-stripe { from { background-position: 0 0; } to { background-position: 1.25rem 0; } }
.provision-steps {
  list-style: none; padding: 0; margin: 0.9rem 0 0;
  display: flex; flex-wrap: wrap; gap: 0.4rem 1.1rem; font-size: 0.85rem;
}
.provision-steps li { color: var(--muted); padding-left: 1.3rem; position: relative; }
.provision-steps li::before { content: "○"; position: absolute; left: 0; }
.provision-steps li.done { color: var(--text); }
.provision-steps li.done::before { content: "✓"; color: var(--green); }
.provision-steps li.active { color: var(--text); }
.provision-steps li.active::before { content: "◍"; color: var(--accent); }
.provision-steps li.failed { color: var(--text); }
.provision-steps li.failed::before { content: "✗"; color: var(--danger); }

/* ---------- architecture graph ---------- */
.empty-canvas {
  text-align: center; padding: 3rem 1rem; border: 1px dashed var(--border);
  border-radius: 12px; margin-top: 1.5rem;
}
.graph {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 1rem; margin-top: 1.25rem;
}
.node {
  display: flex; flex-direction: column; gap: 0.5rem; color: var(--text);
  background: var(--panel); border: 1px solid var(--border);
  border-radius: 12px; padding: 0.9rem 1rem; transition: border-color .15s;
}
.node:hover { border-color: var(--accent); text-decoration: none; }
.node-web { border-left: 3px solid var(--accent-2); }
.node-worker { border-left: 3px solid #b48cff; }
.node-cron { border-left: 3px solid var(--amber); }
.node-database { border-left: 3px solid var(--green); }
.node-top { display: flex; align-items: center; gap: 0.5rem; }
.node-icon { font-size: 1.1rem; }
.node-name { font-weight: 600; flex: 1; }
.node-type {
  font-size: 0.7rem; text-transform: uppercase; letter-spacing: .04em;
  color: var(--muted); background: var(--panel-2); padding: 0.1rem 0.45rem; border-radius: 999px;
}
.node-sub { color: var(--muted); word-break: break-all; }
.node-status { display: flex; align-items: center; gap: 0.5rem; }
.vol { color: var(--muted); }

/* A service plus its grouped (compose-detected) components. */
.canvas-actions { display: flex; align-items: center; gap: 0.5rem; }
.service-group { display: flex; flex-direction: column; gap: 0.6rem; }
.components {
  display: flex; flex-direction: column; gap: 0.5rem;
  padding: 0.6rem; border: 1px dashed var(--border); border-radius: 12px;
  background: rgba(255, 255, 255, 0.02);
}
.components-head {
  font-size: 0.7rem; text-transform: uppercase; letter-spacing: 0.04em; color: var(--muted);
}
.node-component { padding: 0.7rem 0.85rem; background: var(--panel-2); }

/* ---------- modal ---------- */
.modal {
  border: 1px solid var(--border); border-radius: 12px; background: var(--panel);
  color: var(--text); padding: 0; max-width: 540px; width: 92%;
}
.modal::backdrop { background: rgba(0,0,0,0.6); }
.modal-form { padding: 1.5rem; }
.modal-form h2 { margin-top: 0; }
.modal-actions { display: flex; justify-content: flex-end; gap: 0.6rem; margin: 1rem 0 0; padding: 0; }
label.check { display: flex; align-items: center; gap: 0.5rem; }
label.check input { width: auto; margin: 0; }

/* ---------- metrics ---------- */
.metric-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 1rem; margin-top: 1.25rem;
}
.metric-card { background: var(--panel); border: 1px solid var(--border); border-radius: 12px; padding: 1rem; }
.metric-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 0.75rem; }
.gauges { display: flex; flex-direction: column; gap: 0.6rem; }
.gauge-label { font-size: 0.78rem; color: var(--muted); }
.bar { height: 8px; background: var(--panel-2); border-radius: 999px; overflow: hidden; margin: 0.2rem 0; }
.bar-fill { height: 100%; background: var(--accent-2); border-radius: 999px; }
.bar-fill.mem { background: var(--green); }
.gauge-val { font-size: 0.82rem; color: var(--text); }
.spark { display: flex; align-items: flex-end; gap: 2px; height: 36px; margin-top: 0.75rem; }
.spark-bar { flex: 1; background: var(--accent); border-radius: 1px; min-height: 1px; }
.metric-foot { margin-top: 0.5rem; }

/* ---------- auth ---------- */
.login-wrap { display: flex; justify-content: center; padding-top: 6vh; }
.login-panel { width: 340px; max-width: 92%; }
.login-panel h1 { margin: 0 0 0.25rem; }
.logout-btn { background: none; border: none; cursor: pointer; font: inherit; }
.logout-btn:hover { color: var(--text); background: var(--panel-2); }

/* ============================ Railway-style Architecture canvas ============================ */
/* Full-bleed canvas layout (scoped to pages that render .rl-canvas). */
body:has(.rl-canvas) { height: 100vh; display: flex; flex-direction: column; overflow: hidden; }
body:has(.rl-canvas) main { flex: 1; min-height: 0; max-width: none; margin: 0; padding: 0; display: flex; flex-direction: column; }
body:has(.rl-canvas) .topbar { background: var(--rl-topbar); }
body:has(.rl-canvas) .tab.active { border-bottom-color: var(--rl-accent); color: var(--text); }

.rl-canvas {
  position: relative; flex: 1; min-height: 0; overflow: hidden;
  background-color: var(--rl-bg);
  background-image: radial-gradient(var(--rl-dot) 1.1px, transparent 1.1px);
  background-size: 20px 20px;
}
.rl-viewport { position: absolute; inset: 0; overflow: auto; }
.rl-flow {
  min-height: 100%; box-sizing: border-box;
  display: flex; flex-wrap: wrap; align-content: center; justify-content: center;
  gap: 48px; padding: 90px 48px;
  transform-origin: 50% 0; transition: transform .18s ease; will-change: transform;
}
.rl-row { display: flex; align-items: center; }

/* icons */
.rl-i { width: 18px; height: 18px; display: block; flex: 0 0 auto; }
.rl-chip .rl-i { width: 16px; height: 16px; }
.rl-btn .rl-i, .rl-vol .rl-i { width: 15px; height: 15px; }
.rl-box-chev .rl-i, .rl-act-chev .rl-i, .rl-box-folder .rl-i { width: 16px; height: 16px; }
.rl-pip { width: 16px; height: 16px; flex: 0 0 auto; display: block; }

/* node card */
.rl-node {
  display: block; width: var(--rl-card-w); overflow: hidden; color: var(--rl-text); text-decoration: none;
  background: var(--rl-panel); border: 1px solid var(--rl-border); border-radius: 12px;
  transition: border-color .15s ease, transform .05s ease;
  animation: rl-pop .26s cubic-bezier(.2,.7,.3,1) both;
}
.rl-node:hover { border-color: var(--rl-border-hi); text-decoration: none; }
/* failed-to-deploy node: red border + tint, and the logo chip turns red */
.rl-node--failed { border-color: color-mix(in srgb, var(--danger) 60%, var(--rl-border));
  background: color-mix(in srgb, var(--danger) 8%, var(--rl-panel)); }
.rl-node--failed:hover { border-color: var(--danger); }
.rl-node--failed .rl-chip { color: var(--danger);
  background: color-mix(in srgb, var(--danger) 16%, transparent);
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--danger) 45%, transparent); }
.rl-node--failed .rl-lang { color: var(--danger); }
.rl-node:active { transform: translateY(1px); }
.rl-node:focus-visible { outline: none; box-shadow: 0 0 0 2px var(--rl-bg), 0 0 0 4px var(--rl-accent); }
.rl-node-body { padding: 16px 18px; }
.rl-node-h { display: flex; align-items: center; gap: 10px; }
.rl-chip {
  display: grid; place-items: center; flex: 0 0 auto;
  width: var(--rl-chip); height: var(--rl-chip); border-radius: 7px;
  color: var(--c, var(--accent-2));
  background: color-mix(in srgb, var(--c, var(--accent-2)) 12%, transparent);
}
.rl-node-name { font-weight: 600; font-size: 1rem; color: var(--rl-text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.rl-node-sub { margin-top: 6px; font-size: .8rem; color: var(--rl-link); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.rl-status { display: flex; align-items: center; gap: 8px; margin-top: 12px; font-size: .82rem; color: var(--rl-muted); }
.rl-vol { display: flex; align-items: center; gap: 8px; padding: 10px 16px; border-top: 1px solid var(--rl-border); background: var(--rl-inset); font-size: .8rem; color: var(--rl-muted); }
.rl-vol .rl-i { color: var(--rl-muted); }
.rl-node-m { width: auto; }

/* grouped box */
.rl-box {
  width: var(--rl-group-w); padding: 10px;
  background: var(--rl-group); border: 1px solid var(--rl-border-grp); border-radius: 14px;
  animation: rl-pop .3s cubic-bezier(.2,.7,.3,1) both;
}
.rl-box-h { display: flex; align-items: center; gap: 8px; padding: 6px 8px 12px; }
.rl-box-folder { color: var(--rl-muted); display: inline-grid; place-items: center; }
.rl-box-title { font-weight: 600; font-size: .9rem; color: var(--rl-muted); }
.rl-box-count { font-size: .72rem; color: var(--rl-muted); background: var(--rl-panel); border: 1px solid var(--rl-border); border-radius: 999px; padding: 0 7px; line-height: 1.5; }
.rl-box-chev { margin-left: auto; color: var(--rl-muted); display: inline-grid; place-items: center; }
.rl-box-b { display: flex; flex-direction: column; gap: 12px; }

/* connector */
.rl-connector { position: relative; align-self: center; width: 56px; height: 2px; flex: 0 0 auto;
  background: repeating-linear-gradient(90deg, var(--rl-border-grp) 0 6px, transparent 6px 12px); }
.rl-port { position: absolute; top: 50%; width: 7px; height: 7px; transform: translateY(-50%);
  background: var(--rl-group); border: 1.5px solid var(--rl-border-grp); border-radius: 2px; }
.rl-connector .rl-port:first-child { left: -3px; }
.rl-connector .rl-port:last-child { right: -3px; }

/* floating left toolbar */
.rl-tools { position: absolute; left: 20px; top: 20px; z-index: 6; display: flex; flex-direction: column; gap: 12px; }
.rl-tool { width: 34px; height: 34px; display: grid; place-items: center; cursor: pointer;
  color: var(--rl-muted); background: var(--rl-panel); border: 1px solid var(--rl-border);
  border-radius: 9px; box-shadow: 0 6px 18px rgba(0,0,0,.4); }
.rl-tool:hover { color: var(--rl-text); border-color: var(--rl-border-hi); }
.rl-tool:focus-visible { outline: none; box-shadow: 0 0 0 2px var(--rl-bg), 0 0 0 4px var(--rl-accent); }
.rl-zoom { display: flex; flex-direction: column; overflow: hidden; background: var(--rl-panel);
  border: 1px solid var(--rl-border); border-radius: 9px; box-shadow: 0 6px 18px rgba(0,0,0,.4); }
.rl-zoom .rl-tool { border: 0; border-radius: 0; box-shadow: none; }
.rl-zoom .rl-tool + .rl-tool { border-top: 1px solid var(--rl-border); }

/* top-right actions */
.rl-actions { position: absolute; right: 24px; top: 20px; z-index: 6; display: flex; align-items: center; gap: 8px; }
.rl-actions .inline { display: inline; margin: 0; }
.rl-btn { display: inline-flex; align-items: center; gap: 7px; height: 34px; padding: 0 13px;
  font-size: .88rem; font-family: inherit; color: var(--rl-text); cursor: pointer;
  background: var(--rl-panel); border: 1px solid var(--rl-border); border-radius: 9px;
  box-shadow: 0 6px 18px rgba(0,0,0,.4); }
.rl-btn:hover { border-color: var(--rl-border-hi); }
.rl-btn:focus-visible { outline: none; box-shadow: 0 0 0 2px var(--rl-bg), 0 0 0 4px var(--rl-accent); }
.rl-btn:active { transform: translateY(1px); }
.rl-btn-primary { border-color: var(--rl-border-hi); }

/* activity pill */
.rl-activity { position: absolute; right: 24px; bottom: 16px; z-index: 6; width: 320px;
  display: flex; flex-direction: column; align-items: stretch; }
.rl-activity-tab { display: flex; align-items: center; gap: 10px; height: 40px; padding: 0 14px; cursor: pointer;
  background: var(--rl-panel); border: 1px solid var(--rl-border); border-radius: 11px; color: var(--rl-text);
  font-family: inherit; box-shadow: 0 10px 28px rgba(0,0,0,.5); }
.rl-activity-open .rl-activity-tab { border-radius: 0 0 11px 11px; }
.rl-act-i { color: var(--rl-muted); display: inline-grid; place-items: center; }
.rl-act-t { flex: 1; text-align: left; font-size: .85rem; color: var(--rl-text); }
.rl-act-chev { color: var(--rl-muted); display: inline-grid; place-items: center; transition: transform .15s ease; }
.rl-activity-open .rl-act-chev { transform: rotate(180deg); }
.rl-activity-tab:focus-visible { outline: none; box-shadow: 0 0 0 2px var(--rl-bg), 0 0 0 4px var(--rl-accent); }
.rl-activity-body { max-height: 46vh; overflow: auto; margin-bottom: -1px;
  background: var(--rl-panel); border: 1px solid var(--rl-border); border-bottom: 0; border-radius: 11px 11px 0 0;
  box-shadow: 0 10px 28px rgba(0,0,0,.5); }
.rl-activity-list { display: flex; flex-direction: column; padding: 6px; }
.rl-activity-item { display: grid; grid-template-columns: 18px 1fr auto; column-gap: 10px; align-items: center;
  padding: 8px 10px; border-radius: 8px; color: var(--rl-text); text-decoration: none; }
.rl-activity-item:hover { background: var(--rl-panel-2); text-decoration: none; }
.rl-act-pip { grid-row: 1 / 3; grid-column: 1; display: inline-grid; place-items: center; }
.rl-act-pip .rl-pip { width: 15px; height: 15px; }
.rl-act-svc { grid-column: 2; font-weight: 600; font-size: .88rem; }
.rl-act-desc { grid-column: 2; font-size: .77rem; color: var(--rl-muted); }
.rl-act-when { grid-row: 1 / 3; grid-column: 3; align-self: center; font-size: .75rem; color: var(--rl-muted); white-space: nowrap; }
.rl-activity-empty { padding: 16px; font-size: .85rem; }

/* empty state */
.rl-empty { position: absolute; inset: 0; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 8px; text-align: center; }
.rl-empty h2 { margin: 8px 0 0; font-size: 1.05rem; }
.rl-chip-lg { width: 56px; height: 56px; border-radius: 16px; }
.rl-chip-lg .rl-i { width: 26px; height: 26px; }

/* top-bar additions */
.rl-share { display: inline-flex; align-items: center; gap: 6px; color: var(--muted); font-size: .9rem; padding: .3rem .55rem; border-radius: 6px; }
.rl-share:hover { color: var(--text); text-decoration: none; }
.rl-avatar { display: grid; place-items: center; width: 26px; height: 26px; border-radius: 50%;
  background: var(--rl-accent); color: #fff; font-size: .72rem; font-weight: 700; user-select: none; }

/* motion */
.rl-spin { animation: rl-spin .8s linear infinite; transform-origin: 50% 50%; }
@keyframes rl-spin { to { transform: rotate(360deg); } }
@keyframes rl-pop { from { opacity: 0; transform: translateY(6px) scale(.985); } to { opacity: 1; transform: none; } }
@media (prefers-reduced-motion: reduce) {
  .rl-node, .rl-box { animation: none; }
  .rl-flow { transition: none; }
  .rl-spin { animation: none; }
}
@media (max-width: 720px) {
  .rl-row { flex-direction: column; align-items: stretch; }
  .rl-connector { width: 2px; height: 36px; margin: 0 auto;
    background: repeating-linear-gradient(180deg, var(--rl-border-grp) 0 6px, transparent 6px 12px); }
}

/* ============================ Service detail slide-over panel ============================ */
.rl-overlay { position: absolute; inset: 0; z-index: 20; }
.rl-backdrop { position: absolute; inset: 0; background: rgba(8,6,12,.55); animation: rl-fade .15s ease both; }
.rl-panel {
  position: absolute; top: 0; right: 0; bottom: 0; width: min(62%, 900px);
  display: flex; flex-direction: column; overflow: hidden;
  background: var(--rl-surface); border-left: 1px solid var(--rl-border-grp);
  box-shadow: -24px 0 70px rgba(0,0,0,.55);
  animation: rl-slide .22s cubic-bezier(.2,.7,.3,1) both;
}
.rl-panel--full { width: 100%; border-left: 0; animation: none; }
@keyframes rl-slide { from { transform: translateX(28px); opacity: 0; } to { transform: none; opacity: 1; } }
@keyframes rl-fade { from { opacity: 0; } to { opacity: 1; } }

.rl-panel-head { flex: 0 0 auto; display: flex; align-items: center; gap: 12px; padding: 18px 20px 14px; }
.rl-panel-head .rl-chip { width: 30px; height: 30px; }
.rl-panel-id { display: flex; align-items: baseline; gap: 8px; min-width: 0; }
.rl-panel-name { font-size: 1.15rem; font-weight: 700; color: var(--rl-text); }
.rl-panel-sep { color: var(--rl-muted); }
.rl-panel-sha { font-family: ui-monospace, monospace; font-size: .95rem; color: var(--rl-muted); }
.rl-panel-date { margin-left: auto; font-size: .8rem; color: var(--rl-muted); white-space: nowrap; }
.rl-icon-btn { display: grid; place-items: center; width: 30px; height: 30px; border: 0; background: none; color: var(--rl-muted); cursor: pointer; border-radius: 7px; }
.rl-icon-btn:hover { color: var(--rl-text); background: var(--rl-panel); }
.rl-icon-btn .rl-i { width: 18px; height: 18px; }
.rl-menu { position: relative; }
.rl-menu-pop { position: absolute; right: 0; top: 36px; z-index: 30; min-width: 176px; padding: 6px; display: flex; flex-direction: column;
  background: var(--rl-panel); border: 1px solid var(--rl-border); border-radius: 10px; box-shadow: 0 12px 32px rgba(0,0,0,.5); }
.rl-menu-pop form { margin: 0; }
.rl-menu-item { display: block; width: 100%; text-align: left; padding: 8px 10px; border: 0; background: none; color: var(--rl-text); font-size: .88rem; font-family: inherit; border-radius: 6px; cursor: pointer; }
.rl-menu-item:hover { background: var(--rl-panel-2); text-decoration: none; }
.rl-menu-danger { color: var(--danger); }

#rlPanelMain { display: flex; flex-direction: column; flex: 1; min-height: 0; }
.rl-panel-statusrow { flex: 0 0 auto; padding: 0 20px 14px; }
.rl-sbadge { display: inline-flex; align-items: center; padding: 4px 12px; border-radius: 7px; font-size: .72rem; font-weight: 700; letter-spacing: .05em; border: 1px solid transparent; }
.rl-sb-ok  { color: var(--rl-green); border-color: color-mix(in srgb, var(--rl-green) 55%, transparent); background: color-mix(in srgb, var(--rl-green) 13%, transparent); }
.rl-sb-bad { color: var(--danger);   border-color: color-mix(in srgb, var(--danger) 55%, transparent);   background: color-mix(in srgb, var(--danger) 13%, transparent); }
.rl-sb-run { color: var(--accent-2); border-color: color-mix(in srgb, var(--accent-2) 55%, transparent); background: color-mix(in srgb, var(--accent-2) 13%, transparent); }
.rl-sb-mut { color: var(--rl-muted); border-color: var(--rl-border-grp); background: var(--rl-panel); }

.rl-tabs { flex: 0 0 auto; display: flex; flex-wrap: wrap; gap: 4px; padding: 8px 14px; border-bottom: 1px solid var(--rl-border); }
.rl-tab { padding: 7px 14px; border: 1px solid transparent; border-radius: 8px; background: none; color: var(--rl-muted); font-size: .9rem; font-family: inherit; cursor: pointer; }
.rl-tab:hover { color: var(--rl-text); }
.rl-tab.is-active { color: var(--rl-text); border-color: #6e32aa; background: color-mix(in srgb, #6e32aa 14%, transparent); }

.rl-tabpane { flex: 1; min-height: 0; overflow: auto; padding: 6px 20px 20px; }
.rl-kv { margin: 0; }
.rl-kv > div { display: grid; grid-template-columns: 132px 1fr; gap: 12px; padding: 10px 0; border-bottom: 1px solid var(--rl-border); }
.rl-kv dt { color: var(--rl-muted); font-size: .85rem; margin: 0; }
.rl-kv dd { margin: 0; color: var(--rl-text); font-size: .88rem; word-break: break-word; }

.rl-logbar { flex: 0 0 auto; display: flex; align-items: center; gap: 8px; margin: 14px 20px 8px; }
.rl-log-filter { flex: 1; height: 38px; padding: 0 12px; outline: none;
  background: var(--rl-panel); border: 1px solid var(--rl-border); border-radius: 8px;
  color: var(--rl-text); font-size: .85rem; font-family: ui-monospace, Menlo, monospace; }
.rl-log-filter:focus { border-color: var(--rl-border-hi); }
.rl-log-filter::placeholder { color: var(--rl-muted); }
.rl-logbar-btn { width: 38px; height: 38px; flex: 0 0 auto; display: grid; place-items: center;
  border: 1px solid var(--rl-border); border-radius: 8px; background: var(--rl-panel); color: var(--rl-muted); cursor: pointer; }
.rl-logbar-btn:hover { color: var(--rl-text); border-color: var(--rl-border-hi); }
.rl-logbar-btn .rl-i { width: 16px; height: 16px; }

.rl-logwrap { position: relative; flex: 1; min-height: 0; display: flex; flex-direction: column; }
.rl-log-head, .rl-log-row { display: flex; gap: 10px; }
.rl-log-head { flex: 0 0 auto; padding: 8px 20px; color: var(--rl-muted); font-size: .78rem;
  border-bottom: 1px solid var(--rl-border); }
.rl-logs { flex: 1; min-height: 0; overflow: auto; padding: 6px 20px 18px;
  font-family: ui-monospace, "SF Mono", Menlo, monospace; font-size: .8rem; line-height: 1.6; }
.rl-log-row { padding: 0 4px; border-radius: 3px; white-space: pre-wrap; word-break: break-word; }
.rl-log-row:hover { background: rgba(255,255,255,.04); }
/* failing build/runtime lines — red highlight */
.rl-log-row--err { background: color-mix(in srgb, var(--danger) 16%, transparent);
  box-shadow: inset 2px 0 0 var(--danger); }
.rl-log-row--err:hover { background: color-mix(in srgb, var(--danger) 22%, transparent); }
.rl-log-row--err .rl-log-msg { color: color-mix(in srgb, var(--danger) 35%, var(--rl-text)); }
.rl-log-row--err .rl-log-tick { background: var(--danger); }
.rl-log-tick { flex: 0 0 3px; align-self: stretch; min-height: 1.15em; background: var(--rl-logval); border-radius: 2px; }
.rl-log-tick--ghost { background: transparent; }
.rl-log-date { flex: 0 0 132px; color: var(--rl-logdate); font-variant-numeric: tabular-nums; }
.rl-log-msg { flex: 1; color: #b4b3b7; }
.rl-log-key { color: var(--rl-logkey); }
.rl-log-val { color: var(--rl-logval); }

.rl-log-fabs { position: absolute; right: 16px; bottom: 16px; display: flex; flex-direction: column; gap: 8px; }
.rl-fab { width: 30px; height: 30px; display: grid; place-items: center; cursor: pointer;
  border: 1px solid var(--rl-border); border-radius: 8px; background: var(--rl-panel); color: var(--rl-muted);
  box-shadow: 0 6px 16px rgba(0,0,0,.4); }
.rl-fab:hover { color: var(--rl-text); border-color: var(--rl-border-hi); }
.rl-fab .rl-i { width: 16px; height: 16px; }

/* ghost Sync button on the canvas */
.rl-btn-ghost { background: none; border-color: transparent; box-shadow: none; }
.rl-btn-ghost:hover { background: var(--rl-panel); border-color: var(--rl-border); }
.rl-btn-danger { color: var(--danger); border-color: color-mix(in srgb, var(--danger) 50%, transparent); background: color-mix(in srgb, var(--danger) 12%, transparent); }
.rl-btn-danger:hover { border-color: var(--danger); }
.rl-btn[disabled] { opacity: .5; cursor: not-allowed; }

/* ---- complete service panel: tab content (details/deployments/vars/settings) ---- */
.rl-node-type { font-size: .72rem; color: var(--rl-muted); text-transform: capitalize; padding: 2px 8px; border: 1px solid var(--rl-border); border-radius: 6px; }
.rl-panel-deploying { font-size: .8rem; color: var(--accent-2); }
.rl-acts { display: flex; flex-wrap: wrap; gap: 8px; margin: 4px 0 16px; }
.rl-acts form { margin: 0; }
.rl-pad { padding: 14px 2px; }
.rl-managed { padding: 12px 0; color: var(--rl-muted); font-size: .9rem; }

.rl-panel-error { display: flex; align-items: center; gap: 8px; margin: 12px 20px 0; padding: 9px 12px; font-size: .85rem;
  color: var(--danger); border: 1px solid color-mix(in srgb, var(--danger) 45%, transparent);
  background: color-mix(in srgb, var(--danger) 12%, transparent); border-radius: 8px; }
.rl-panel-error .rl-i { width: 15px; height: 15px; flex: 0 0 auto; }

.rl-dtable, .rl-vtable { width: 100%; border-collapse: collapse; font-size: .85rem; }
.rl-dtable th { text-align: left; color: var(--rl-muted); font-weight: 600; font-size: .76rem; padding: 6px 8px; border-bottom: 1px solid var(--rl-border); }
.rl-dtable td, .rl-vtable td { padding: 9px 8px; border-bottom: 1px solid var(--rl-border); vertical-align: middle; }
.rl-drow { cursor: pointer; }
.rl-drow:hover { background: var(--rl-panel-2); }
.rl-dstatus { display: inline-flex; align-items: center; gap: 6px; text-transform: capitalize; }
.rl-dstatus .rl-pip { width: 14px; height: 14px; }
.rl-vkey { color: var(--rl-text); white-space: nowrap; }
.rl-vval { color: var(--rl-muted); word-break: break-all; }
.rl-vx { width: 1%; text-align: right; }
.rl-xbtn { display: grid; place-items: center; width: 26px; height: 26px; border: 0; background: none; color: var(--rl-muted); cursor: pointer; border-radius: 6px; }
.rl-xbtn:hover { color: var(--danger); background: var(--rl-panel); }
.rl-xbtn .rl-i { width: 15px; height: 15px; }

.rl-form-row { display: flex; gap: 8px; margin-top: 14px; flex-wrap: wrap; }
.rl-form-row input { flex: 1 1 120px; min-width: 0; height: 34px; padding: 0 11px;
  background: var(--rl-panel); border: 1px solid var(--rl-border); border-radius: 8px;
  color: var(--rl-text); font-size: .85rem; font-family: ui-monospace, Menlo, monospace; }
.rl-form-row input:focus { outline: none; border-color: var(--rl-border-hi); }
.rl-form-row .rl-btn { flex: 0 0 auto; }
.rl-form-row select { flex: 1 1 150px; min-width: 0; height: 34px; padding: 0 10px;
  background: var(--rl-panel); border: 1px solid var(--rl-border); border-radius: 8px;
  color: var(--rl-text); font-size: .85rem; }
.rl-form-row select:focus { outline: none; border-color: var(--rl-border-hi); }
.rl-dot-sep { align-self: center; color: var(--rl-muted); font-weight: 700; }
.rl-dns-hint { margin-top: 8px; }

.rl-dom-list { list-style: none; margin: 0 0 6px; padding: 0; display: flex; flex-direction: column; gap: 4px; }
.rl-dom-list li { display: flex; align-items: center; justify-content: space-between; gap: 10px;
  padding: 8px 10px; background: var(--rl-panel); border: 1px solid var(--rl-border); border-radius: 8px; }
.rl-dom-list form { margin: 0; }

.rl-sec { margin: 4px 0 8px; font-size: .82rem; font-weight: 700; letter-spacing: .03em; color: var(--rl-muted); text-transform: uppercase; }
.rl-sec-danger { margin-top: 26px; color: var(--danger); }

.rl-log-ctx { display: flex; gap: 8px; align-items: center; padding: 10px 20px 0; font-size: .8rem; }
.rl-linkbtn { border: 0; background: none; color: var(--accent-2); cursor: pointer; font: inherit; padding: 0; text-decoration: underline; }

@media (max-width: 720px) { .rl-panel { width: 100%; } }
@media (prefers-reduced-motion: reduce) { .rl-panel, .rl-backdrop { animation: none; } }

/* ============================ Interactive graph plane ============================ */
.rl-viewport { overflow: hidden; cursor: grab; touch-action: none; }
.rl-canvas.rl-panning, .rl-canvas.rl-panning .rl-viewport { cursor: grabbing; }
.rl-plane { position: absolute; top: 0; left: 0; width: 4000px; height: 3000px;
  transform-origin: 0 0; will-change: transform; }
.rl-edges { position: absolute; top: 0; left: 0; width: 100%; height: 100%; overflow: visible; pointer-events: none; z-index: 0; }
.rl-edge { fill: none; stroke: var(--rl-border-grp); stroke-width: 2; stroke-dasharray: 6 7; stroke-linecap: round; opacity: .9; }
/* Positioned peer nodes (override the old flex-flow card) */
.rl-node { position: absolute; top: 0; left: 0; z-index: 1; cursor: grab; touch-action: none; user-select: none; -webkit-user-select: none; }
.rl-node.rl-dragging { z-index: 3; }
.rl-node.rl-dragging, .rl-canvas.rl-panning .rl-node { cursor: grabbing; }
.rl-node-link { display: block; color: inherit; text-decoration: none; }
.rl-node-link:hover, .rl-node-link:focus { text-decoration: none; outline: none; }
.rl-node:focus-within { border-color: var(--rl-border-hi); box-shadow: 0 0 0 2px var(--rl-bg), 0 0 0 4px var(--rl-accent); }
.rl-lang { font: 700 .58rem/1 ui-monospace, "SF Mono", Menlo, monospace; letter-spacing: -.03em; color: var(--c, var(--accent-2)); }

/* ---- Metrics graphs ---- */
.rl-metrics { display: flex; flex-direction: column; gap: 14px; }
.rl-metric-ranges { display: flex; gap: 4px; }
.rl-metric-range {
  background: var(--rl-surface-2, #1b1b25); color: var(--rl-muted, #9a9ab0);
  border: 1px solid var(--rl-border, #2a2a38); border-radius: 6px;
  padding: 3px 10px; font-size: 12px; cursor: pointer;
}
.rl-metric-range.is-active { color: #fff; border-color: var(--accent-2, #9b6dff); background: rgba(155,109,255,.16); }
.rl-metric-card {
  background: var(--rl-surface-2, #15151d); border: 1px solid var(--rl-border, #2a2a38);
  border-radius: 10px; padding: 12px 14px;
}
.rl-metric-title { font-size: 13px; font-weight: 600; margin-bottom: 6px; }
.rl-metric-chart { width: 100%; min-height: 120px; }
.rl-metric-svg { width: 100%; height: 180px; display: block; }
.rl-metric-grid { stroke: var(--rl-border, #2a2a38); stroke-width: 1; opacity: .5; }
.rl-metric-axis { fill: var(--rl-muted, #9a9ab0); font-size: 10px; }
.rl-metric-line { fill: none; stroke: var(--accent-2, #9b6dff); stroke-width: 2;
  stroke-linejoin: round; stroke-linecap: round; }
.rl-metric-empty { padding: 28px 0; text-align: center; }

/* ---- Backups tab ---- */
.rl-bk-card { background: var(--rl-panel); border: 1px solid var(--rl-border);
  border-radius: 12px; padding: 14px 16px; margin: 0 0 16px; }
.rl-bk-card.rl-bk-card--danger { border-color: color-mix(in srgb, var(--danger) 32%, var(--rl-border)); }
.rl-bk-head { display: flex; justify-content: space-between; align-items: center; gap: 14px; }
.rl-bk-head h3 { margin: 0 0 3px; font-size: .95rem; font-weight: 650; color: var(--rl-text);
  letter-spacing: 0; text-transform: none; }
.rl-bk-head .muted { margin: 0; }
.rl-bk-head form { margin: 0; flex: 0 0 auto; }
.rl-bk-actions { display: flex; flex-wrap: wrap; gap: 10px 16px; align-items: flex-start; }
.rl-bk-actions .rl-form-row { margin-top: 0; flex: 1 1 220px; }
.rl-bk-sched { display: flex; flex-wrap: wrap; gap: 12px; align-items: flex-end; }
.rl-bk-sched label { display: flex; flex-direction: column; gap: 5px; flex: 1 1 160px;
  font-size: .78rem; color: var(--rl-muted); }
.rl-bk-sched select { height: 34px; padding: 0 10px; background: var(--rl-inset);
  color: var(--rl-text); border: 1px solid var(--rl-border); border-radius: 8px; }
.rl-bk-sched select:focus { outline: none; border-color: var(--rl-border-hi); }
.rl-bk-sched .rl-btn { flex: 0 0 auto; }
.rl-bk-runrow { display: flex; align-items: center; gap: 12px; flex-wrap: wrap;
  margin-top: 14px; padding-top: 14px; border-top: 1px solid var(--rl-border); }
.rl-bk-runrow form { margin: 0; }
.rl-bk-note { margin: 10px 0 0; }
.rl-bk-pillrow { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; margin: 0 0 12px; }
.rl-bk-pill { display: inline-flex; align-items: center; gap: 6px; height: 24px; padding: 0 10px;
  border-radius: 999px; font-size: .74rem; font-weight: 600; background: var(--rl-panel-2);
  color: var(--rl-muted); border: 1px solid var(--rl-border); }
.rl-bk-pill .rl-bk-dot { margin: 0; }

/* backup list table — matches .rl-dtable */
.rl-bk-table { width: 100%; border-collapse: collapse; font-size: .85rem; }
.rl-bk-table th { text-align: left; color: var(--rl-muted); font-weight: 600; font-size: .72rem;
  text-transform: uppercase; letter-spacing: .03em; padding: 0 10px 8px; }
.rl-bk-table td { padding: 9px 10px; border-top: 1px solid var(--rl-border); vertical-align: middle; }
.rl-bk-table tbody tr:hover { background: var(--rl-panel-2); }
.rl-bk-when { font-variant-numeric: tabular-nums; }
.rl-bk-kind { display: inline-block; padding: 1px 8px; border-radius: 6px; font-size: .72rem;
  text-transform: uppercase; letter-spacing: .03em; background: var(--rl-panel-2);
  border: 1px solid var(--rl-border); color: var(--rl-muted); }
.rl-bk-status { display: inline-flex; align-items: center; gap: 7px; text-transform: capitalize; }
.rl-bk-dot { display: inline-block; width: 8px; height: 8px; border-radius: 50%; flex: 0 0 auto;
  background: var(--rl-muted); }
.rl-bk-dot--complete { background: var(--green); box-shadow: 0 0 0 3px color-mix(in srgb, var(--green) 22%, transparent); }
.rl-bk-dot--running, .rl-bk-dot--pending { background: var(--amber);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--amber) 22%, transparent); }
.rl-bk-dot--failed { background: var(--danger);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--danger) 22%, transparent); }
.rl-bk-empty { padding: 18px 0; text-align: center; }
.rl-bk-log { margin-top: 10px; max-height: 240px; overflow: auto; }
.rl-bk-log:empty { display: none; }

/* restore form */
.rl-bk-restore { display: flex; flex-wrap: wrap; gap: 12px; align-items: flex-end; margin-top: 4px; }
.rl-bk-restore label { display: flex; flex-direction: column; gap: 5px; flex: 1 1 200px;
  font-size: .78rem; color: var(--rl-muted); }
.rl-bk-restore input { height: 34px; padding: 0 11px; background: var(--rl-inset);
  color: var(--rl-text); border: 1px solid var(--rl-border); border-radius: 8px; }
.rl-bk-restore input:focus { outline: none; border-color: var(--rl-border-hi); }
.rl-bk-restore .rl-btn { flex: 0 0 auto; }

/* ---- HTTP access logs ---- */
.rl-acc-row, .rl-acc-head { display: grid;
  grid-template-columns: 96px 48px 60px 1fr 56px 110px; gap: 8px; align-items: baseline; }
.rl-acc-head { color: var(--rl-muted, #9a9ab0); font-size: 11px; padding: 4px 10px; }
.rl-acc-row { padding: 2px 10px; font-size: 12px; font-family: var(--mono, monospace); }
.rl-acc-uri { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.rl-acc-status { font-weight: 600; }
.rl-log-row--warn { background: rgba(224,161,106,.10); box-shadow: inset 2px 0 0 var(--amber, #e0a16a); }
.rl-log-row--warn .rl-acc-status { color: var(--amber, #e0a16a); }
.rl-log-row--err .rl-acc-status { color: #e5484d; }

/* ---- Docs page (WAL/PITR explainer) ---- */
.rl-docs { max-width: 760px; margin: 0 auto; padding: 8px 20px 48px; line-height: 1.6; }
.rl-docs h1 { font-size: 1.5rem; margin: 8px 0 14px; }
.rl-docs h2 { font-size: 1.05rem; margin: 26px 0 8px; color: var(--text); }
.rl-docs p { margin: 8px 0; }
.rl-docs ul { margin: 8px 0; padding-left: 22px; }
.rl-docs li { margin: 4px 0; }
.rl-docs code { background: var(--rl-panel-2, #221a2e); border: 1px solid var(--rl-border);
  border-radius: 5px; padding: 1px 5px; font-family: ui-monospace, Menlo, monospace; font-size: .85em; }
.rl-doc-code { background: var(--rl-inset, #120d18); border: 1px solid var(--rl-border);
  border-radius: 10px; padding: 12px 14px; overflow-x: auto; font-family: ui-monospace, Menlo, monospace;
  font-size: .82rem; line-height: 1.5; color: var(--rl-text); }
.rl-doc-code code { background: none; border: none; padding: 0; }
.rl-doc-back { margin: 4px 0 8px; }
