@font-face {
  font-family: 'Cinzel';
  font-style: normal;
  font-weight: 700 900;
  font-display: swap;
  src: url('../../assets/fonts/cinzel.woff2') format('woff2');
}

:root {
  /* parchment + ink */
  --parch: #ecdab0;
  --parch-2: #e6d2a0;
  --parch-3: #e0cb95;
  --parch-edge: #b18a4f;
  --parch-inset: #dcc488;
  --header-tan: #cdb172;
  --ink: #5a3e1b;
  --ink-2: #7a5a2e;
  --ink-dim: #9a7e54;
  /* sky */
  --sky-top: #16235f;
  --sky-mid: #4a4690;
  --sky-low: #b07ea8;
  /* gold + green */
  --gold: #ffcc33;
  --gold-edge: #caa14a;
  --green: #5a9e2f;
  --green-2: #86cf4e;
  --green-edge: #3e6b1e;
  --title: #6e4a1c;
  --radius: 8px;
  --font-display: 'Cinzel', Georgia, "Palatino Linotype", "Book Antiqua", serif;
  --font-body: "Trebuchet MS", "Segoe UI", system-ui, -apple-system, sans-serif;
}

* { box-sizing: border-box; }

body {
  margin: 0;
  min-height: 100vh;
  color: var(--ink);
  font-family: var(--font-body);
  background: linear-gradient(180deg, var(--sky-top) 0%, #283278 26%, var(--sky-mid) 50%, #7d5f9e 70%, var(--sky-low) 86%, #cf9bb2 100%);
  background-attachment: fixed;
}

h1, h2, h3 { font-family: var(--font-display); color: var(--title); margin: 0; }

.panel {
  background:
    radial-gradient(ellipse at 28% 18%, rgba(176,138,82,0.10), transparent 55%),
    radial-gradient(ellipse at 78% 82%, rgba(150,110,60,0.12), transparent 50%),
    var(--parch);
  border: 3px solid var(--parch-edge);
  border-radius: var(--radius);
  box-shadow: inset 0 0 0 2px var(--parch-inset);
}

.btn-green {
  font-family: var(--font-display); font-weight: 900; color: #fff;
  background: linear-gradient(var(--green-2), var(--green));
  border: 2px solid var(--green-edge); border-radius: var(--radius);
  box-shadow: 0 3px 0 var(--green-edge); cursor: pointer; padding: 9px 14px;
}
.btn-gold {
  font-family: var(--font-display); font-weight: 900; color: #4a2a06;
  background: linear-gradient(#f6b84a, #d9892a);
  border: 2px solid #a5641d; border-radius: var(--radius);
  box-shadow: 0 3px 0 #a5641d; cursor: pointer; padding: 8px 14px;
}
.btn-green:active, .btn-gold:active { transform: translateY(2px); box-shadow: none; }

.coin {
  display: inline-block; width: 16px; height: 16px; border-radius: 50%;
  background: var(--gold); border: 2px solid var(--gold-edge); vertical-align: middle;
}
.coin.lg { width: 30px; height: 30px; border-width: 3px; }
