/* vault.css — the vault's unlock/create modal, styled to match the egui dark theme so it reads as part
   of the app even though it is a separate (vault) origin. Presentation only; loaded under `style-src
   'self'`. No external resources (default-src 'none' blocks them), so a tampered CSS cannot exfiltrate. */

:root {
  --bg: #141414;          /* egui dark panel */
  --card: #242424;        /* egui window fill */
  --border: #3a3a3a;      /* egui faint stroke */
  --text: #dcdcdc;        /* egui text */
  --muted: #9a9a9a;
  --accent: #5790d8;      /* egui-ish selection blue */
  --err: #e06c75;
  --mono: ui-monospace, "Cascadia Code", Consolas, monospace;
}

html, body { margin: 0; height: 100%; background: var(--bg); color: var(--text);
  font: 14px/1.5 system-ui, -apple-system, "Segoe UI", sans-serif; }

#log { display: none; } /* debug log stays hidden; the modal is the UI */

.vault-modal { position: fixed; inset: 0; display: flex; align-items: center; justify-content: center;
  background: rgba(0, 0, 0, 0.45); padding: 16px; box-sizing: border-box; }

.vault-card { width: 100%; max-width: 320px; background: var(--card); border: 1px solid var(--border);
  border-radius: 8px; padding: 20px; box-shadow: 0 8px 32px rgba(0, 0, 0, 0.5); box-sizing: border-box; }

.vault-title { margin: 0 0 6px; font-size: 16px; font-weight: 600; color: #fff; }
.vault-sub { margin: 0 0 14px; font-size: 12.5px; color: var(--muted); }
.vault-err { margin: 0 0 12px; font-size: 12.5px; color: var(--err); }

.vault-input { display: block; width: 100%; box-sizing: border-box; margin: 0 0 10px; padding: 8px 10px;
  background: #1b1b1b; color: var(--text); border: 1px solid var(--border); border-radius: 5px; font-size: 14px; }
.vault-input:focus { outline: none; border-color: var(--accent); }

.vault-btn { width: 100%; padding: 9px 12px; margin-top: 4px; background: var(--accent); color: #0b0b0b;
  border: 0; border-radius: 5px; font-size: 14px; font-weight: 600; cursor: pointer; }
.vault-btn:hover { filter: brightness(1.1); }

.vault-mnemonic { font-family: var(--mono); font-size: 13px; line-height: 1.7; color: #fff;
  background: #1b1b1b; border: 1px solid var(--border); border-radius: 6px; padding: 12px; margin: 0 0 14px;
  word-spacing: 4px; }

.vault-fp { font-family: var(--mono); font-size: 13px; color: var(--accent); letter-spacing: 0.5px;
  background: #1b1b1b; border: 1px solid var(--border); border-radius: 6px; padding: 10px; text-align: center; }

/* signing ceremony */
.vault-rows { background: #1b1b1b; border: 1px solid var(--border); border-radius: 6px; padding: 8px 12px; margin: 0 0 14px; }
.vault-row { display: flex; justify-content: space-between; gap: 12px; padding: 4px 0; font-size: 12.5px; }
.vault-row + .vault-row { border-top: 1px solid var(--border); }
.vault-k { color: var(--muted); white-space: nowrap; }
.vault-v { color: var(--text); font-family: var(--mono); text-align: right; word-break: break-all; }
.vault-actions { display: flex; gap: 10px; }
.vault-actions .vault-btn { flex: 1; margin-top: 0; }
.vault-btn-ghost { background: transparent; color: var(--text); border: 1px solid var(--border); }
.vault-btn-ghost:hover { filter: none; background: #2f2f2f; }
