:root {
  --bg: #0b0b0d;
  --bg-2: #131316;
  --panel: #1a1a1e;
  --panel-2: #222227;
  --gold: #d4af37;
  --gold-soft: #b8962e;
  --gold-dim: #6b5a1f;
  --ink: #f4f1e8;
  --muted: #9a958a;
  --line: #2c2c32;
  --danger: #d9534f;
  --success: #4caf76;
  --warn: #e0a83e;
  --info: #5a9bd4;
}

* { box-sizing: border-box; }
body {
  margin: 0;
  background: linear-gradient(180deg, var(--bg) 0%, #08080a 100%);
  color: var(--ink);
  font-family: 'Inter', system-ui, -apple-system, sans-serif;
  min-height: 100vh;
}
a { color: var(--gold); text-decoration: none; }
a:hover { color: var(--ink); }

h1, h2, h3, .brand { font-family: 'Cinzel', Georgia, serif; letter-spacing: .5px; }
.metric, .mono { font-family: 'JetBrains Mono', monospace; }

/* ---- nav ---- */
.nav {
  display: flex; align-items: center; gap: 22px;
  padding: 16px 28px; border-bottom: 1px solid var(--line);
  background: rgba(10,10,12,.85); backdrop-filter: blur(8px);
  position: sticky; top: 0; z-index: 50;
}
.nav .brand { font-size: 1.45rem; color: var(--gold); }
.nav .brand span { color: var(--ink); }
.nav a.link { color: var(--muted); font-weight: 500; font-size: .95rem; }
.nav a.link:hover, .nav a.active { color: var(--gold); }
.nav .spacer { flex: 1; }
.cart-pill {
  background: var(--panel-2); border: 1px solid var(--gold-dim);
  border-radius: 20px; padding: 6px 14px; color: var(--gold); font-size: .85rem;
}

.container { max-width: 1080px; margin: 0 auto; padding: 28px; }
.narrow { max-width: 640px; }

/* ---- buttons ---- */
.btn {
  display: inline-block; padding: 11px 20px; border-radius: 8px;
  font-weight: 600; cursor: pointer; border: 1px solid transparent;
  font-size: .95rem; transition: .15s; background: var(--panel-2); color: var(--ink);
}
.btn:hover { border-color: var(--gold-dim); }
.btn-gold { background: linear-gradient(135deg, var(--gold), var(--gold-soft)); color: #0b0b0d; }
.btn-gold:hover { color: #0b0b0d; filter: brightness(1.08); }
.btn-ghost { background: transparent; border: 1px solid var(--line); color: var(--muted); }
.btn-danger { background: transparent; border: 1px solid var(--danger); color: var(--danger); }
.btn-sm { padding: 6px 12px; font-size: .82rem; }

/* ---- cards / panels ---- */
.grid { display: grid; gap: 20px; }
.grid-2 { grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); }
.grid-3 { grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); }

.card {
  background: var(--panel); border: 1px solid var(--line); border-radius: 12px;
  overflow: hidden; transition: .15s;
}
.card:hover { border-color: var(--gold-dim); transform: translateY(-2px); }
.card .body { padding: 18px; }
.card .cat {
  font-size: .72rem; text-transform: uppercase; letter-spacing: 1.5px;
  color: var(--gold); font-weight: 600;
}
.card h3 { margin: 6px 0 8px; font-size: 1.1rem; }
.card .meta { color: var(--muted); font-size: .85rem; }
.card .thumb {
  height: 140px; background: linear-gradient(135deg, #1c1c20, #0f0f12);
  display: flex; align-items: center; justify-content: center;
  color: var(--gold-dim); font-family: 'Cinzel', serif; font-size: 1.4rem;
  border-bottom: 1px solid var(--line);
}
.price-tag { color: var(--gold); font-weight: 700; font-family: 'JetBrains Mono', monospace; }

.panel {
  background: var(--panel); border: 1px solid var(--line);
  border-radius: 12px; padding: 22px; margin-bottom: 20px;
}

/* ---- hero ---- */
.hero {
  padding: 60px 28px; text-align: center;
  border-bottom: 1px solid var(--line);
  background: radial-gradient(ellipse at top, rgba(212,175,55,.08), transparent 60%);
}
.hero h1 { font-size: 2.6rem; color: var(--gold); margin: 0 0 12px; }
.hero p { color: var(--muted); max-width: 560px; margin: 0 auto 22px; }

/* ---- forms ---- */
label { display: block; font-size: .85rem; color: var(--muted); margin: 14px 0 6px; }
input, select, textarea {
  width: 100%; padding: 11px 13px; border-radius: 8px;
  background: var(--bg-2); border: 1px solid var(--line); color: var(--ink);
  font-size: .95rem; font-family: inherit;
}
input:focus, select:focus, textarea:focus { outline: none; border-color: var(--gold); }
.form-row { display: flex; gap: 16px; }
.form-row > div { flex: 1; }

/* ---- tables ---- */
table { width: 100%; border-collapse: collapse; }
th, td { text-align: left; padding: 11px 14px; border-bottom: 1px solid var(--line); font-size: .9rem; }
th { color: var(--gold); font-size: .75rem; text-transform: uppercase; letter-spacing: 1px; }
tr:hover td { background: var(--bg-2); }

/* ---- badges ---- */
.badge {
  display: inline-block; padding: 3px 10px; border-radius: 12px;
  font-size: .72rem; font-weight: 600; text-transform: uppercase; letter-spacing: .5px;
}
.badge.on_sale, .badge.paid, .badge.valid, .badge.admitted { background: rgba(76,175,118,.15); color: var(--success); }
.badge.pending, .badge.draft { background: rgba(224,168,62,.15); color: var(--warn); }
.badge.cancelled, .badge.refunded, .badge.used, .badge.sold_out { background: rgba(217,83,79,.15); color: var(--danger); }

/* ---- flash ---- */
.flash { padding: 12px 18px; border-radius: 8px; margin-bottom: 14px; font-size: .9rem; border:1px solid; }
.flash.success { background: rgba(76,175,118,.1); border-color: var(--success); color: var(--success); }
.flash.danger  { background: rgba(217,83,79,.1); border-color: var(--danger); color: var(--danger); }
.flash.warning { background: rgba(224,168,62,.1); border-color: var(--warn); color: var(--warn); }
.flash.info    { background: rgba(90,155,212,.1); border-color: var(--info); color: var(--info); }

/* ---- stats ---- */
.stats { display: grid; grid-template-columns: repeat(auto-fill, minmax(160px,1fr)); gap: 16px; }
.stat { background: var(--panel); border: 1px solid var(--line); border-radius: 12px; padding: 18px; }
.stat .n { font-family: 'JetBrains Mono', monospace; font-size: 1.8rem; color: var(--gold); }
.stat .l { color: var(--muted); font-size: .8rem; text-transform: uppercase; letter-spacing: 1px; }

/* ---- ticket ---- */
.ticket {
  max-width: 420px; margin: 20px auto; background: var(--panel);
  border: 1px solid var(--gold-dim); border-radius: 16px; overflow: hidden;
}
.ticket .top { background: linear-gradient(135deg, var(--gold), var(--gold-soft)); color: #0b0b0d; padding: 20px; }
.ticket .qr { text-align: center; padding: 24px; }
.ticket .qr img { width: 220px; border-radius: 12px; }
.muted { color: var(--muted); }
.gold { color: var(--gold); }
.right { text-align: right; }
.center { text-align: center; }
hr { border: none; border-top: 1px solid var(--line); margin: 18px 0; }
.tag-pills { display: flex; flex-wrap: wrap; gap: 8px; }
.scan-result { padding: 24px; border-radius: 12px; text-align: center; font-size: 1.3rem; font-weight: 700; }
