* { box-sizing: border-box; }
:root {
  color-scheme: dark;
  font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  background: #0d0a14;
  color: #eee8ff;
}
body {
  margin: 0;
  min-height: 100vh;
  background:
    radial-gradient(circle at top left, rgba(121, 74, 255, .26), transparent 34rem),
    linear-gradient(180deg, #120d20, #08070d);
}
.shell {
  width: min(960px, 100%);
  margin: 0 auto;
  padding: 20px;
}
.hero, .panel, .room {
  border: 1px solid rgba(255,255,255,.1);
  background: rgba(20, 16, 32, .82);
  box-shadow: 0 20px 60px rgba(0,0,0,.25);
  border-radius: 20px;
}
.hero {
  display: flex;
  justify-content: space-between;
  gap: 20px;
  padding: 24px;
  align-items: center;
}
.eyebrow, .muted, small, .label { color: #a99bc8; }
h1, h2, p { margin-top: 0; }
h1 { margin-bottom: 8px; font-size: clamp(32px, 7vw, 58px); }
h2 { margin-bottom: 12px; }
.badge {
  width: 86px;
  height: 86px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  background: rgba(138, 92, 255, .22);
  border: 1px solid rgba(180, 146, 255, .4);
}
.badge span { grid-area: 1 / 1; align-self: start; margin-top: 14px; color: #a99bc8; }
.badge strong { font-size: 34px; margin-top: 14px; }
.panel { padding: 18px; margin-top: 16px; }
.stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}
.stats div {
  background: rgba(255,255,255,.05);
  border-radius: 16px;
  padding: 14px;
}
.stats span { display: block; color: #a99bc8; margin-bottom: 6px; }
.stats strong { font-size: 24px; }
.grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin-top: 16px;
}
.room { padding: 16px; }
.room strong { display: block; font-size: 18px; }
.room span { color: #c9b8ff; }
.room p { color: #a99bc8; margin: 8px 0 0; }
.section-title {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.quests { display: grid; gap: 10px; }
.quest, .entry {
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.045);
  border-radius: 16px;
  padding: 14px;
}
.quest {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
}
.quest.done { opacity: .55; }
.quest p, .entry p { margin: 6px 0; color: #d8cff1; }
button, input, textarea {
  font: inherit;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.12);
}
button {
  cursor: pointer;
  background: #7c4dff;
  color: white;
  padding: 10px 14px;
  font-weight: 700;
}
button:disabled { cursor: default; background: #3c354f; color: #aaa; }
input, textarea {
  width: 100%;
  margin: 6px 0 12px;
  padding: 12px;
  background: rgba(0,0,0,.25);
  color: #fff;
}
.label { display: block; font-size: 14px; }
.log {
  overflow: auto;
  min-height: 50px;
  padding: 12px;
  border-radius: 14px;
  background: rgba(0,0,0,.28);
  color: #d8cff1;
}
.journal { display: grid; gap: 10px; }
@media (max-width: 680px) {
  .shell { padding: 12px; }
  .hero { padding: 18px; }
  .stats, .grid { grid-template-columns: 1fr; }
  .quest { align-items: stretch; flex-direction: column; }
}
