
@font-face { font-family: "JetBrains Mono"; font-style: normal; font-weight: 400; font-display: swap; src: url("/fonts/jetbrains-mono-400.woff2") format("woff2"); }
@font-face { font-family: "JetBrains Mono"; font-style: normal; font-weight: 700; font-display: swap; src: url("/fonts/jetbrains-mono-700.woff2") format("woff2"); }
@font-face { font-family: "Archivo Black"; font-style: normal; font-weight: 400; font-display: swap; src: url("/fonts/archivo-black-400.woff2") format("woff2"); }
:root { --ink:#0a0a0a; --bg:#FFD60A; --card:#ffffff; --soft:#f6f1e0; --mute:#6b6b6b; }
*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; min-height: 100%; }
body {
  background: var(--bg); color: var(--ink);
  font-family: "JetBrains Mono", ui-monospace, monospace;
  font-size: 14px; line-height: 1.4;
  display: flex; flex-direction: column; min-height: 100vh;
}
a { color: inherit; }
.bar { padding: 20px 24px 0; display: flex; justify-content: space-between; align-items: center;
  font-size: 11px; letter-spacing: 0.08em; font-weight: 700; }
.wrap { flex: 1; display: flex; align-items: center; justify-content: center; padding: 24px 20px; }
.wrap-scroll { flex: 1; padding: 24px 20px 28px; overflow: auto; }
.card { background: var(--card); border: 2px solid var(--ink); box-shadow: 12px 12px 0 0 var(--ink);
  padding: 28px 24px; width: 100%; max-width: 360px; margin: 0 auto; }
.chip { display: inline-flex; align-items: center; gap: 10px; border: 2px solid var(--ink);
  padding: 6px 12px 6px 6px; margin-bottom: 22px; }
.chip-initial { background: var(--bg); color: var(--ink); width: 26px; height: 26px;
  display: grid; place-items: center; font-weight: 900;
  font-family: "Archivo Black", "Helvetica Neue", sans-serif; font-size: 16px; }
.chip-name { font-weight: 500; font-size: 13px; }
.headline { font-family: "Archivo Black", "Helvetica Neue", sans-serif; font-weight: 900;
  font-size: 38px; line-height: 1.02; letter-spacing: -0.02em; margin: 0 0 14px; }
.highlight { background: var(--bg); padding: 0 4px;
  box-decoration-break: clone; -webkit-box-decoration-break: clone; }
.sub { color: var(--mute); font-size: 13px; margin: 0 0 22px; line-height: 1.45; }
.sub strong { color: var(--ink); font-weight: 700; }
.label { font-size: 11px; font-weight: 700; letter-spacing: 0.1em; margin-bottom: 6px; }
input[type=email], input[type=text] {
  background: var(--soft); border: 2px solid var(--ink); padding: 14px;
  font-size: 16px; font-family: "JetBrains Mono", ui-monospace, monospace;
  width: 100%; display: block; margin-bottom: 12px; color: var(--ink);
  border-radius: 0; -webkit-appearance: none; appearance: none;
}
input:focus, button:focus { outline: 2px solid var(--ink); outline-offset: 3px; }
.primary { background: var(--ink); color: var(--bg); border: 2px solid var(--ink);
  padding: 15px 18px; display: flex; align-items: center; justify-content: space-between;
  font-weight: 700; font-size: 15px; width: 100%; font-family: inherit;
  cursor: pointer; text-align: left; text-decoration: none; margin: 0; }
.primary:hover { filter: brightness(1.15); }
.primary::after { content: "\2192"; margin-left: 12px; }
.secondary { background: var(--card); color: var(--ink); border: 2px solid var(--ink);
  padding: 14px 18px; display: flex; align-items: center; justify-content: center;
  font-weight: 600; font-size: 14px; gap: 8px; width: 100%; font-family: inherit;
  cursor: pointer; text-decoration: none; margin: 0; }
.secondary:hover { background: var(--soft); }
.gap { height: 10px; }
.gap-lg { height: 22px; }
.divider { display: flex; align-items: center; gap: 10px; margin: 18px 0;
  font-size: 11px; font-weight: 700; }
.divider::before, .divider::after { content: ""; flex: 1; height: 2px; background: var(--ink); }
.footer { padding: 10px 18px; display: flex; justify-content: space-between; align-items: center;
  font-size: 10px; color: var(--mute); letter-spacing: 0.04em; }
.callout { border: 2px solid var(--ink); padding: 14px; background: var(--soft);
  font-size: 12px; margin-bottom: 14px; }
.callout-title { font-weight: 700; margin-bottom: 4px; }
.callout-mute { color: var(--mute); }
.tag-step { font-size: 11px; font-weight: 700; letter-spacing: 0.1em; margin-bottom: 14px; }
.badge-tag { display: inline-block; background: var(--ink); color: var(--bg);
  padding: 8px 10px; font-size: 11px; font-weight: 700; letter-spacing: 0.08em; margin-bottom: 18px; }
.badge-warn { background: #fff7a8; color: var(--ink); border: 2px solid var(--ink);
  padding: 10px; font-size: 11px; font-weight: 700; letter-spacing: 0.08em;
  margin-bottom: 18px; display: block; }
.badge-danger { background: #0a0a0a; color: #ff7a7a; border: 2px solid var(--ink);
  padding: 8px 10px; font-size: 11px; font-weight: 700; letter-spacing: 0.08em;
  margin-bottom: 18px; display: inline-block; }
.list-row { border: 2px solid var(--ink); padding: 12px; margin-bottom: 8px;
  display: flex; justify-content: space-between; align-items: center; }
.list-row-title { font-weight: 600; font-size: 13px; }
.list-row-meta { font-size: 11px; color: var(--mute); margin-top: 2px; }
.row-action { font-size: 11px; font-weight: 700; text-decoration: underline;
  background: none; border: 0; padding: 0; color: var(--ink); cursor: pointer;
  font-family: inherit; }
.trace { text-align: center; margin-top: 16px; font-size: 11px;
  color: var(--mute); font-family: inherit; }
.status { font-size: 12px; color: var(--mute); margin: 14px 0 0;
  min-height: 1.2em; text-align: center; }
.linklike { text-align: center; margin-top: 16px; font-size: 12px; text-decoration: underline;
  background: none; border: 0; padding: 0; color: var(--ink); font-family: inherit;
  cursor: pointer; display: block; width: 100%; }
.signed-out-x { background: var(--ink); color: var(--bg); width: 44px; height: 44px;
  display: grid; place-items: center; font-size: 26px; margin-bottom: 18px;
  border: 2px solid var(--ink); }
.kv { border: 2px solid var(--ink); padding: 12px; margin-bottom: 14px;
  font-size: 11px; line-height: 1.7; }
.kv .k { color: var(--mute); }
form.inline { margin: 0; }
h1.headline { font-family: "Archivo Black", "Helvetica Neue", sans-serif; }
