/* Grand Trivia Night — design system
   Festive but elegant: deep indigo night, gold accents, cream cards. Mobile-first. */
:root {
  --indigo-900: #1a1340;
  --indigo-800: #241a57;
  --indigo-700: #322474;
  --violet: #6d4ed6;
  --gold: #f4c84a;
  --gold-deep: #d8a72b;
  --cream: #fbf7ec;
  --ink: #221b3a;
  --muted: #6b6486;
  --green: #2fae66;
  --red: #e0556b;
  --amber: #e8a13c;
  --card-radius: 18px;
  --shadow: 0 12px 40px rgba(10, 6, 38, 0.28);
  --serif: "Iowan Old Style", "Palatino Linotype", Palatino, "Georgia", serif;
  --sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: var(--sans);
  color: var(--ink);
  background:
    radial-gradient(1200px 600px at 50% -10%, var(--indigo-700), transparent 60%),
    linear-gradient(160deg, var(--indigo-900), var(--indigo-800));
  min-height: 100vh;
  -webkit-font-smoothing: antialiased;
}

a { color: var(--violet); }
.center { text-align: center; }
.muted { color: var(--muted); }
.hidden { display: none !important; }

/* Layout */
.wrap { max-width: 760px; margin: 0 auto; padding: 24px 18px 64px; }
.wrap-wide { max-width: 1100px; }

/* Logo + header */
.brandbar { text-align: center; padding: 18px 0 8px; }
.brandbar img { max-height: 110px; max-width: 80%; object-fit: contain; }
.brandbar h1 {
  font-family: var(--serif);
  color: var(--cream);
  font-size: clamp(1.6rem, 6vw, 2.6rem);
  margin: 10px 0 2px;
  letter-spacing: 0.5px;
}
.subtle { color: #cfc6ef; font-size: 0.95rem; }

/* Cards */
.card {
  background: var(--cream);
  border-radius: var(--card-radius);
  box-shadow: var(--shadow);
  padding: 22px;
  margin: 16px 0;
}
.card h2 { font-family: var(--serif); margin: 0 0 12px; }

/* Forms */
label { display: block; font-weight: 600; margin: 14px 0 6px; }
input[type=text], input[type=password], input[type=number], textarea, select {
  width: 100%;
  padding: 13px 14px;
  border: 1.5px solid #ddd6c8;
  border-radius: 12px;
  font-size: 1rem;
  font-family: inherit;
  background: #fff;
}
input:focus, textarea:focus, select:focus {
  outline: none; border-color: var(--violet);
  box-shadow: 0 0 0 3px rgba(109, 78, 214, 0.18);
}
textarea { min-height: 64px; resize: vertical; }

/* Buttons */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  border: none; cursor: pointer; font-family: inherit; font-size: 1rem; font-weight: 700;
  padding: 13px 22px; border-radius: 12px; text-decoration: none;
  transition: transform .06s ease, filter .15s ease;
}
.btn:active { transform: translateY(1px); }
.btn-primary { background: linear-gradient(180deg, var(--gold), var(--gold-deep)); color: #3b2c05; }
.btn-primary:hover { filter: brightness(1.05); }
.btn-violet { background: var(--violet); color: #fff; }
.btn-ghost { background: transparent; border: 1.5px solid #cdc6b6; color: var(--ink); }
.btn-block { display: flex; width: 100%; }
.btn:disabled, .btn.disabled { opacity: .5; cursor: not-allowed; }
.btn-sm { padding: 8px 12px; font-size: .9rem; border-radius: 9px; }

/* Round list (player hub) */
.round-list { list-style: none; padding: 0; margin: 0; }
.round-item {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px; border-radius: 14px; margin: 10px 0;
  background: #fff; border: 1.5px solid #ece5d4;
}
.round-item.locked { opacity: .6; background: #f3eee2; }
.round-item .rname { font-family: var(--serif); font-size: 1.15rem; font-weight: 600; }
.round-item .rmeta { font-size: .85rem; color: var(--muted); }
.pill { font-size: .72rem; font-weight: 700; padding: 3px 9px; border-radius: 999px; text-transform: uppercase; letter-spacing: .04em; }
.pill.live { background: #e7f8ee; color: var(--green); }
.pill.locked { background: #eee9da; color: #9a917a; }
.pill.graded { background: #fff3d6; color: var(--gold-deep); }
.pill.submitted { background: #ece7ff; color: var(--violet); }

/* Score code */
.codebox { text-align: center; margin: 18px 0; }
.codebox .code { font-family: var(--serif); font-size: 2.6rem; letter-spacing: .35em; color: var(--indigo-800); font-weight: 700; }

/* Question blocks (answer page) */
.qblock { padding: 16px 0; border-bottom: 1px solid #ece5d4; }
.qblock:last-child { border-bottom: none; }
.qnum { font-weight: 700; color: var(--violet); font-size: 1.05rem; display: block; margin-bottom: 14px; }
.qprompt { margin: 4px 0 12px; }
.double-box { margin-top: 18px; padding: 14px 16px; border-radius: 12px; background: #fff7e0; border: 1.5px solid var(--gold); }
.double-box.forced { background: #fff3d6; border-color: var(--gold-deep); }
.qimg { width: 100%; max-width: 560px; border-radius: 12px; display: block; margin: 6px auto 12px; }
.bonus-label { font-size: .85rem; color: var(--amber); font-weight: 700; margin-top: 10px; }

/* Review / grade rows */
.graderow { padding: 14px 0; border-bottom: 1px solid #ece5d4; }
.answer-given { background: #fff; border-radius: 10px; padding: 8px 12px; border: 1px solid #ece5d4; }
.answer-correct { color: var(--green); font-weight: 600; }
.verdict { font-weight: 700; }
.verdict.correct { color: var(--green); }
.verdict.half { color: var(--amber); }
.verdict.wrong { color: var(--red); }
.markbtns { display: flex; gap: 8px; margin-top: 8px; }
.markbtn { border: 1.5px solid #d8d0bf; background: #fff; border-radius: 10px; padding: 8px 12px; cursor: pointer; font-weight: 700; }
.markbtn.sel.correct { background: var(--green); color: #fff; border-color: var(--green); }
.markbtn.sel.half { background: var(--amber); color: #fff; border-color: var(--amber); }
.markbtn.sel.wrong { background: var(--red); color: #fff; border-color: var(--red); }

/* Tables (admin) */
table.grid { width: 100%; border-collapse: collapse; background: var(--cream); border-radius: 12px; overflow: hidden; }
table.grid th, table.grid td { padding: 10px 12px; text-align: left; border-bottom: 1px solid #ece5d4; font-size: .92rem; }
table.grid th { background: #efe8d6; font-family: var(--serif); }

/* Banners */
.banner {
  background: linear-gradient(180deg, var(--gold), var(--gold-deep));
  color: #3b2c05; border-radius: 14px; padding: 18px; text-align: center;
  font-family: var(--serif); font-size: 1.3rem; font-weight: 700; margin: 16px 0;
}
.flash-error { background: #fde8ec; color: #9c2740; padding: 12px 14px; border-radius: 10px; margin: 10px 0; }
.flash-ok { background: #e7f8ee; color: #1c7a47; padding: 12px 14px; border-radius: 10px; margin: 10px 0; }

/* Footer / instagram */
.foot { text-align: center; color: #b7aee0; margin-top: 28px; font-size: .9rem; }
.foot a { color: var(--gold); text-decoration: none; font-weight: 700; }

/* Toast */
#toast { position: fixed; bottom: 18px; left: 50%; transform: translateX(-50%);
  background: #221b3a; color: #fff; padding: 10px 16px; border-radius: 10px; opacity: 0;
  transition: opacity .2s; pointer-events: none; z-index: 50; }
#toast.show { opacity: .96; }

@media (max-width: 520px) {
  .wrap { padding: 16px 12px 56px; }
  .card { padding: 16px; }
}
