body { background:#f5f4ef; }
.tog-btn { width:36px;height:36px;border-radius:9999px;cursor:pointer;font-family:var(--mg-font-mono);font-weight:600;font-size:13px;border:1px solid #e6e3d8;transition:all 120ms; background:#f5f4ef; color:#14161c; }
.tog-btn--active { background:#14161c; color:#fff; }

/* ── Hero ── */
.talisman-hero { background:#000; color:#fff; padding:56px 32px 72px; position:relative; overflow:hidden; }
.talisman-hero__glow { position:absolute; right:-80px; top:20%; width:500px; height:500px; background:radial-gradient(circle,rgba(93,42,138,0.3) 0%,transparent 65%); pointer-events:none; }
.talisman-hero__inner { max-width:1200px; margin:0 auto; position:relative; }
.talisman-hero__back { font-family:var(--mg-font-mono); font-size:12px; color:rgba(255,255,255,0.65); text-decoration:none; }
.talisman-hero__eyebrow { font-family:var(--mg-font-pixel); font-size:10px; color:#c97afb; letter-spacing:1.5px; margin:20px 0 16px; }
.talisman-hero__title { font-family:var(--mg-font-display); font-weight:600; font-size:clamp(44px,5.5vw,80px); line-height:1.0; letter-spacing:-0.025em; margin:0 0 18px; }
.talisman-hero__lede { font-family:var(--mg-font-body); font-size:17px; line-height:1.55; color:rgba(255,255,255,0.75); max-width:560px; margin:0; }

/* ── Tools section ── */
.talisman-tools { background:#f5f4ef; padding:48px 32px 96px; }
.talisman-tools__inner { max-width:900px; margin:0 auto; display:flex; flex-direction:column; gap:24px; }

/* ── Tool cards ── */
.tool-card { background:#fff; border:1px solid #e6e3d8; border-radius:20px; padding:32px; }
.tool-card__header { display:flex; align-items:flex-start; gap:16px; margin-bottom:22px; padding-bottom:22px; border-bottom:1px solid #e6e3d8; }
.tool-card__accent { width:6px; height:48px; border-radius:3px; flex:none; }
.tool-card__accent--purple { background:#5d2a8a; }
.tool-card__accent--blue { background:#0c4f8d; }
.tool-card__accent--green { background:#3a9928; }
.tool-card__eyebrow { font-family:var(--mg-font-pixel); font-size:9px; letter-spacing:1.5px; margin-bottom:6px; }
.tool-card__eyebrow--purple { color:#5d2a8a; }
.tool-card__eyebrow--blue { color:#0c4f8d; }
.tool-card__eyebrow--green { color:#3a9928; }
.tool-card__title { font-family:var(--mg-font-display); font-weight:600; font-size:24px; color:#14161c; margin:0; letter-spacing:-0.3px; }
.tool-card__desc { font-family:var(--mg-font-body); font-size:14px; color:#4f5764; margin:4px 0 0; }

/* ── Character lottery ── */
.char-controls { display:flex; gap:10px; align-items:center; margin-bottom:20px; flex-wrap:wrap; }
.char-controls__label { font-family:var(--mg-font-mono); font-size:12px; color:#636b78; text-transform:uppercase; letter-spacing:0.5px; }
.char-controls__btns { display:flex; gap:6px; }
.char-controls__draw { margin-left:auto; }
.char-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:10px; }
.char-card { background:#f5f4ef; border-radius:12px; padding:14px 18px; display:flex; align-items:center; gap:14px; }
.char-card__avatar { width:40px; height:40px; border-radius:9999px; background:#5d2a8a; display:flex; align-items:center; justify-content:center; font-family:var(--mg-font-pixel); font-size:10px; color:#fff; letter-spacing:0.5px; flex:none; }
.char-card__name { font-family:var(--mg-font-display); font-weight:600; font-size:17px; color:#14161c; }
.char-card__stats { font-family:var(--mg-font-mono); font-size:11px; color:#4f5764; margin-top:2px; }
.char-card__info { flex:1; }

/* ── Hex board ── */
.board-controls { display:flex; justify-content:space-between; align-items:center; margin-bottom:16px; }
.board-seed { font-family:var(--mg-font-mono); font-size:12px; color:#636b78; }
.board-wrap { background:#0a0d2a; border-radius:14px; padding:20px; overflow:hidden; }
.board-legend { display:flex; gap:12px; margin-top:14px; flex-wrap:wrap; }
.board-legend__chip { display:flex; align-items:center; gap:6px; }
.board-legend__swatch { width:12px; height:12px; border-radius:2px; }
.board-legend__label { font-family:var(--mg-font-body); font-size:12px; color:#4f5764; }

/* ── Encounter ── */
.encounter-filters { display:flex; gap:8px; flex-wrap:wrap; margin-bottom:20px; }
.encounter-card { min-height:160px; }
.encounter-card__inner { background:#f5f4ef; border-radius:14px; padding:24px; }
.encounter-card__eyebrow { font-family:var(--mg-font-pixel); font-size:9px; letter-spacing:1.5px; margin-bottom:10px; }
.encounter-card__title { font-family:var(--mg-font-display); font-weight:600; font-size:22px; letter-spacing:-0.3px; color:#14161c; margin:0 0 12px; }
.encounter-card__text { font-family:var(--mg-font-body); font-size:15px; line-height:1.65; color:#1f2228; margin:0; }
.encounter-draw { margin-top:20px; }

/* ── Ring filter buttons ── */
.ring-btn { font-family:var(--mg-font-body); font-weight:600; font-size:13px; height:34px; padding:0 14px; border-radius:9999px; cursor:pointer; transition:all 150ms; }
.ring-btn--inactive { border:1px solid #c3c5cc; background:transparent; color:#14161c; }

@media (max-width: 768px) {
  .talisman-tools { padding: 36px 20px 64px; }
  .tool-card { padding: 20px; }
  .char-grid { grid-template-columns: 1fr; }
  .char-controls { flex-direction:column; align-items:stretch; }
  .char-controls__btns { justify-content:center; }
  .char-controls__draw { margin-left:0; width:100%; }
  .board-controls { flex-direction:column; align-items:stretch; gap:12px; }
  .board-controls .mg-btn { width:100%; }
  .tool-card { text-align:center; }
  .tool-card__header { flex-direction:column; align-items:center; text-align:center; }
  .tool-card__accent { display:none; }
}
