:root {
  --parchment: #f6efe0;
  --parchment-edge: #e9dcbd;
  --ink: #2b2317;
  --ink-soft: #5b4a2d;
  --accent: #6b1e1e;
  --accent-soft: #8a2a2a;
  --gold: #b08a3e;
  --success-bg: #e8efe0;
  --success-ink: #2f4a1f;
  --error-bg: #f4e1dc;
  --error-ink: #6b1e1e;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; min-height: 100%; }

body {
  font-family: Georgia, "Iowan Old Style", "Palatino Linotype", serif;
  color: var(--ink);
  background:
    radial-gradient(circle at 20% 10%, rgba(176, 138, 62, 0.12), transparent 45%),
    radial-gradient(circle at 80% 90%, rgba(107, 30, 30, 0.10), transparent 50%),
    var(--parchment);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  padding: 1.25rem 1rem 2rem;
}

.topnav {
  width: 100%;
  max-width: 760px;
  display: flex;
  gap: 1.25rem;
  justify-content: center;
  margin-bottom: 1.25rem;
  padding-bottom: 0.75rem;
  border-bottom: 1px solid var(--parchment-edge);
}
.topnav a {
  color: var(--accent);
  text-decoration: none;
  font-variant: small-caps;
  letter-spacing: 0.06em;
  font-size: 1.05rem;
}
.topnav a:hover { color: var(--accent-soft); text-decoration: underline; }

.card {
  width: 100%;
  max-width: 620px;
  background: #fffaec;
  border: 1px solid var(--parchment-edge);
  border-radius: 6px;
  padding: 2.25rem 2rem 1.5rem;
  box-shadow: 0 1px 0 rgba(0,0,0,0.04), 0 10px 30px rgba(43,35,23,0.08);
}

header { text-align: center; margin-bottom: 1.5rem; border-bottom: 1px solid var(--parchment-edge); padding-bottom: 1rem; }
.eyebrow { letter-spacing: 0.25em; text-transform: uppercase; font-size: 0.75rem; color: var(--gold); margin: 0 0 0.25rem; }
h1 { font-size: 1.75rem; margin: 0 0 0.25rem; color: var(--accent); font-variant: small-caps; letter-spacing: 0.02em; }
h2 { color: var(--accent); font-variant: small-caps; font-size: 1.2rem; }
.sub { margin: 0; color: var(--ink-soft); font-style: italic; font-size: 0.95rem; }

.notice { padding: 0.75rem 1rem; border-radius: 4px; margin-bottom: 1rem; font-size: 0.95rem; }
.notice-success { background: var(--success-bg); color: var(--success-ink); border: 1px solid #c4d4b0; }
.notice-error { background: var(--error-bg); color: var(--error-ink); border: 1px solid #d9b4ac; }
.receipt-link { text-align: center; margin: -0.5rem 0 1rem; }
.receipt-link a, .spell-detail a { color: var(--accent); }

form label { display: block; margin-bottom: 1rem; }
form label span { display: block; font-size: 0.85rem; color: var(--ink-soft); margin-bottom: 0.35rem; letter-spacing: 0.05em; text-transform: uppercase; }
input[type="text"] { width: 100%; padding: 0.65rem 0.75rem; border: 1px solid var(--parchment-edge); border-radius: 4px; font: inherit; background: #fffdf6; color: var(--ink); }
input[type="text"]:focus { outline: none; border-color: var(--gold); box-shadow: 0 0 0 3px rgba(176,138,62,0.2); }

button { padding: 0.65rem 1rem; background: var(--accent); color: #fdf6e3; border: 1px solid var(--accent-soft); border-radius: 4px; font: inherit; font-size: 1rem; letter-spacing: 0.05em; cursor: pointer; transition: background 120ms ease; }
button:hover { background: var(--accent-soft); }
form > button[type="submit"] { width: 100%; margin-top: 0.25rem; }

.searchbar { display: flex; gap: 0.5rem; margin-bottom: 1.25rem; }
.searchbar input { flex: 1; }
.searchbar button { white-space: nowrap; }

.results-for { color: var(--ink-soft); font-style: italic; }

.catalog-list, .wizard-list, .spell-list { list-style: none; padding: 0; margin: 0; }
.catalog-list li, .wizard-list li, .spell-list li { padding: 0.75rem 0; border-bottom: 1px solid var(--parchment-edge); }
.cat-name, .wiz-name { font-weight: bold; color: var(--ink); }
.cat-tag, .wiz-house, .wiz-era, .wiz-tag { display: inline-block; margin-left: 0.5rem; font-size: 0.75rem; color: var(--gold); text-transform: uppercase; letter-spacing: 0.08em; }
.cat-price { float: right; color: var(--ink-soft); font-style: italic; }
.cat-blurb, .wiz-bio { margin: 0.35rem 0 0; color: var(--ink-soft); font-size: 0.9rem; }
.empty { color: var(--ink-soft); font-style: italic; }

.contribute { margin-top: 1.5rem; border-top: 1px solid var(--parchment-edge); padding-top: 1rem; }
.contribute summary { cursor: pointer; color: var(--accent); font-variant: small-caps; letter-spacing: 0.05em; }

.spell-detail dt { font-size: 0.8rem; text-transform: uppercase; letter-spacing: 0.06em; color: var(--gold); margin-top: 0.75rem; }
.spell-detail dd { margin: 0.15rem 0 0; }

footer { text-align: center; margin-top: 1.25rem; color: var(--ink-soft); font-style: italic; font-size: 0.85rem; }
