/* Vikii v0 — palette + look-and-feel lifted verbatim from
   vikii-architecture-v0.html so the new service has a coherent visual
   identity from day one. Keep these in sync if the architecture HTML moves. */

:root {
  --bg:#0b0d10;
  --panel:#13171c;
  --panel2:#181d23;
  --line:#262d36;
  --text:#e7edf3;
  --muted:#9aa6b2;
  --accent:#6ee7b7;
  --warn:#f59e0b;
  --bad:#ef4444;
  --ok:#10b981;
  --info:#60a5fa;
  --mono: ui-monospace,SFMono-Regular,Menlo,monospace;
}

* { box-sizing: border-box; }

html, body {
  background: var(--bg);
  color: var(--text);
  margin: 0;
  font: 15px/1.6 -apple-system, BlinkMacSystemFont, "Segoe UI", Inter, sans-serif;
  -webkit-font-smoothing: antialiased;
}

a { color: var(--accent); text-decoration: none; border-bottom: 1px dotted #3a4452; }
a:hover { color: #fff; }

.wrap { max-width: 1180px; margin: 0 auto; padding: 48px 28px 96px; }

h1 { font-size: 32px; margin: 0 0 6px; letter-spacing: -.01em; }
h2 { font-size: 22px; margin: 54px 0 10px; letter-spacing: -.01em; padding-bottom: 10px; border-bottom: 1px solid var(--line); }
h3 { font-size: 17px; margin: 28px 0 8px; color: #fff; }
h4 { font-size: 14px; margin: 18px 0 6px; color: var(--muted); text-transform: uppercase; letter-spacing: .08em; }

p { color: #cfd6de; }
.lede { color: var(--muted); font-size: 14px; }
.meta { color: var(--muted); font-size: 13px; margin: 4px 0 0; }

code {
  background: #0e1217;
  border: 1px solid var(--line);
  padding: 1px 6px;
  border-radius: 5px;
  font-size: 12.5px;
  font-family: var(--mono);
  color: #e7edf3;
}

pre {
  background: #0e1217;
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 14px 16px;
  overflow: auto;
  font-size: 12.5px;
  line-height: 1.55;
  font-family: var(--mono);
  color: #dfe6ee;
}

.card {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 16px 18px;
}

.grid { display: grid; gap: 14px; }
.g2 { grid-template-columns: 1fr 1fr; }
.g3 { grid-template-columns: repeat(3, 1fr); }
@media (max-width: 880px) { .g2, .g3 { grid-template-columns: 1fr; } }

table { width: 100%; border-collapse: collapse; font-size: 13.5px; margin: 8px 0 0; }
th, td { text-align: left; padding: 9px 10px; border-bottom: 1px solid var(--line); vertical-align: top; }
th { font-weight: 600; color: #cfd6de; background: var(--panel2); }

.pill {
  display: inline-block;
  font-size: 11px;
  padding: 2px 8px;
  border-radius: 999px;
  border: 1px solid var(--line);
  color: var(--muted);
  margin-right: 4px;
}
.pill.ok   { color: #a7f3d0; border-color: #1f4f3d; }
.pill.warn { color: #fcd34d; border-color: #5a3f0f; }
.pill.bad  { color: #fca5a5; border-color: #5a1a1a; }
.pill.info { color: #bfdbfe; border-color: #1e3a5a; }

.toc {
  background: var(--panel2);
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 14px 18px;
  margin: 18px 0 0;
  font-size: 14px;
}

.organ {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  border: 1px solid var(--line);
  background: var(--panel2);
  border-radius: 10px;
  padding: 14px 16px;
  margin: 8px 0;
}
.organ .dot {
  width: 10px; height: 10px;
  border-radius: 50%;
  background: var(--accent);
  margin-top: 7px;
  flex: 0 0 10px;
}
.organ h3 { margin: 0 0 4px; font-size: 16px; }
.organ p { margin: 0; color: #cfd6de; }
.organ small { color: var(--muted); font-size: 12.5px; }

.kbd {
  display: inline-block;
  font-family: var(--mono);
  font-size: 12px;
  background: #0e1217;
  border: 1px solid var(--line);
  border-radius: 4px;
  padding: 1px 6px;
  color: #e7edf3;
}

.dot-status {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--muted);
  margin-right: 6px;
  vertical-align: middle;
}
.dot-status.up   { background: var(--ok); }
.dot-status.down { background: var(--bad); }
.dot-status.warn { background: var(--warn); }

.footnote {
  color: var(--muted);
  font-size: 12.5px;
  border-top: 1px dashed var(--line);
  padding-top: 10px;
  margin-top: 24px;
}
