/* ─────────────────────────────────────────────────────────────────────────
   Design tokens — verbatim from the Claude Design system (gothic storybook).
   ───────────────────────────────────────────────────────────────────────── */
:root{
  --ink-900:#0E0B09; --ink-850:#141009; --ink-800:#17120D;
  --ink-700:#1F1812; --ink-600:#2A2118; --ink-550:#332819; --ink-500:#3D2F1E;
  --line:#3A2E1E; --line-soft:rgba(176,42,42,.16);
  --parchment:#F4ECD8; --parchment-2:#E7D8B6; --text:#E9DCBE; --text-muted:#A8987A;
  --text-faint:#7C6F58;
  /* Accent ramp — dark red (was gold). 300 = light rose for readable accent text on dark,
     400 = crimson for eyebrows/icons, 500/600 = deep reds for fills/borders. */
  --gold-300:#E7A6A0; --gold-400:#CF5A4E; --gold-500:#9E2B2B; --gold-600:#5E1818;
  --oxblood-700:#511010; --oxblood-600:#6E1717; --oxblood-500:#8E2020; --oxblood-400:#A93030;
  --team-townsfolk:#3E72C4; --team-outsider:#2FA0A8; --team-minion:#DB6326; --team-demon:#9E1212;
  --good:#3E72C4; --evil:#9E1212;
  --success:#4E9A5B; --warning:#D89A2E; --danger:#B33232; --danger-bg:#2A1410;
  --r-xs:3px; --r-sm:5px; --r-md:8px; --r-lg:13px; --r-xl:20px; --r-pill:999px;
  --sh-1:0 1px 2px rgba(0,0,0,.4); --sh-2:0 4px 14px rgba(0,0,0,.45);
  --sh-3:0 14px 40px rgba(0,0,0,.55); --sh-inset:inset 0 1px 0 rgba(231,206,138,.10);
  --glow-gold:0 0 22px rgba(176,42,42,.32);
  --font-display:'Cormorant Garamond', Georgia, serif;
  --font-ui:'Manrope', system-ui, sans-serif;
}
[data-theme="parchment"]{
  --ink-900:#E4D6B5; --ink-850:#E8DBBC; --ink-800:#EADDBF; --ink-700:#F1E7CE;
  --ink-600:#F6EFDC; --ink-550:#EFE3C6; --ink-500:#E0CEA3;
  --line:#C9B07E; --line-soft:rgba(124,92,34,.20);
  --parchment:#3A2A14; --parchment-2:#4A3617; --text:#3A2A14; --text-muted:#7A6238;
  --text-faint:#9C8657;
  --gold-300:#9A7322; --gold-400:#8A6519; --gold-500:#6E4E12;
  --sh-2:0 4px 14px rgba(74,54,20,.18); --sh-3:0 14px 40px rgba(74,54,20,.22);
  --glow-gold:0 0 18px rgba(138,101,25,.22);
}

*{box-sizing:border-box}
html,body{margin:0}
body{background:var(--ink-900); color:var(--text); font-family:var(--font-ui);
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;}
#app{min-height:100vh; background:var(--ink-900); color:var(--text);}
a{color:inherit;}
::selection{background:rgba(176,42,42,.32); color:var(--parchment);}
input::placeholder, textarea::placeholder{color:var(--text-faint); opacity:1;}
*::-webkit-scrollbar{width:11px; height:11px;}
*::-webkit-scrollbar-track{background:transparent;}
*::-webkit-scrollbar-thumb{background:var(--ink-500); border-radius:99px; border:3px solid transparent; background-clip:content-box;}
*::-webkit-scrollbar-thumb:hover{background:var(--gold-600); background-clip:content-box;}
@keyframes toastIn{from{opacity:0; transform:translateX(-50%) translateY(14px) scale(.96);} to{opacity:1; transform:translateX(-50%);}}
@keyframes overlayIn{from{opacity:0;} to{opacity:1;}}
@keyframes modalIn{from{opacity:0; transform:translateY(18px) scale(.97);} to{opacity:1; transform:none;}}
@keyframes spin{to{transform:rotate(360deg);}}

/* ── header ── */
.app-header{display:flex; align-items:center; justify-content:space-between; gap:16px; padding:14px 26px;
  background:linear-gradient(180deg,#1c150d,var(--ink-800)); border-bottom:1px solid var(--gold-600);
  box-shadow:0 2px 0 rgba(0,0,0,.4), 0 14px 30px -20px rgba(0,0,0,.8); position:sticky; top:0; z-index:30;}
.brand{display:flex; align-items:center; gap:14px; min-width:0; cursor:pointer; background:none; border:none; padding:0;}
.brand-mark{width:42px; height:42px; flex:0 0 auto; border-radius:var(--r-sm);
  background:radial-gradient(circle at 40% 30%,#3a2c19,#140e07); border:1.5px solid var(--gold-500);
  display:flex; align-items:center; justify-content:center; font-size:21px; color:var(--gold-300); box-shadow:var(--glow-gold);}
.brand-title{font-family:var(--font-display); font-weight:700; font-size:22px; line-height:1; color:var(--parchment); letter-spacing:.01em;}
.brand-sub{font-size:11px; letter-spacing:.22em; text-transform:uppercase; color:var(--gold-400); margin-top:4px;}
.header-nav{display:flex; align-items:center; gap:4px;}
.header-actions{display:flex; align-items:center; gap:10px;}

/* ── sub navigation (editor) ── */
.subnav{display:flex; align-items:center; gap:4px; padding:0 22px; background:var(--ink-850);
  border-bottom:1px solid var(--line); position:sticky; top:71px; z-index:25; overflow-x:auto;}
.subnav-tag{font-size:11px; color:var(--text-faint); letter-spacing:.14em; text-transform:uppercase; padding-right:4px;}

/* ── buttons ── */
.btn{font-family:var(--font-ui); font-weight:600; font-size:13.5px; padding:10px 18px; border-radius:var(--r-sm);
  cursor:pointer; border:1px solid transparent; display:inline-flex; align-items:center; gap:6px;
  transition:all .16s ease; white-space:nowrap; line-height:1; text-decoration:none;}
.btn:disabled{opacity:.5; cursor:not-allowed;}
.btn-lg{font-size:15px; padding:14px 24px;}
.btn-sm{font-size:12px; padding:7px 12px;}
.btn-block{width:100%; justify-content:center;}
.btn-primary{background:linear-gradient(180deg,var(--oxblood-500),var(--oxblood-700)); color:#F4ECD8; border:1px solid var(--oxblood-400); box-shadow:var(--sh-inset), var(--sh-1);}
.btn-primary:hover{background:linear-gradient(180deg,var(--oxblood-400),var(--oxblood-600)); color:#fff; box-shadow:0 0 18px rgba(169,48,48,.4);}
.btn-gold{background:linear-gradient(180deg,#B5403A,#7E1E1E); color:#F4ECD8; border:1px solid #C2453B; box-shadow:var(--sh-1);}
.btn-gold:hover{background:linear-gradient(180deg,#C24A43,#8E2424); color:#fff; box-shadow:var(--glow-gold);}
.btn-ghost{background:var(--ink-700); color:var(--text); border:1px solid var(--line);}
.btn-ghost:hover{background:var(--ink-600); color:var(--parchment); border-color:var(--gold-600);}
.btn-quiet{background:transparent; color:var(--text-muted); border:1px solid var(--line);}
.btn-quiet:hover{background:var(--ink-600); color:var(--parchment); border-color:var(--gold-600);}
.btn-danger{background:transparent; color:var(--danger); border:1px solid var(--oxblood-500);}
.btn-danger:hover{background:var(--oxblood-600); color:#F4ECD8; border-color:var(--oxblood-400);}
.btn-danger-solid{background:var(--oxblood-500); color:#F4ECD8; border:1px solid var(--oxblood-400);}
.btn-danger-solid:hover{background:var(--oxblood-600); color:#F4ECD8; border-color:var(--oxblood-400);}

/* ── inputs ── */
.input,.textarea{width:100%; font-family:var(--font-ui); font-size:14px; color:var(--text); background:var(--ink-800);
  border:1px solid var(--line); border-radius:var(--r-sm); padding:11px 13px; outline:none;
  transition:border-color .16s ease, box-shadow .16s ease;}
.textarea{min-height:84px; resize:vertical; line-height:1.55;}
.textarea-sm{min-height:60px;}
.input:focus,.textarea:focus{border-color:var(--gold-500); box-shadow:0 0 0 3px rgba(176,42,42,.16);}
.input.err,.textarea.err{border-color:var(--danger); box-shadow:0 0 0 3px rgba(179,50,50,.14);}
.input-sm{font-size:13px; padding:8px 11px;}
.input-w90{width:90px;}
.input-mono{font-family:ui-monospace,monospace; font-size:12px;}
.search{width:260px; padding:10px 14px 10px 34px;}

/* ── labels & misc text ── */
.label{display:block; font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--text-muted); margin-bottom:7px; font-weight:600;}
.label-flat{margin-bottom:0;}
.muted-note{font-size:11.5px; color:var(--text-faint); margin-top:7px; line-height:1.5;}
.counter{font-size:11px; font-family:ui-monospace,monospace; color:var(--text-faint);}
.counter.over{color:var(--danger);}
.err-line{font-size:12px; color:var(--danger); margin-top:8px; display:flex; align-items:center; gap:5px;}
.eyebrow{font-size:12px; letter-spacing:.24em; text-transform:uppercase; color:var(--gold-400);}
.badge{font-size:11px; font-weight:700; letter-spacing:.06em; padding:3px 9px; border-radius:var(--r-pill); display:inline-flex; align-items:center;}

/* ── chips / segments / pills ── */
.chip{font-family:var(--font-ui); font-weight:600; font-size:12.5px; padding:8px 14px; border-radius:var(--r-pill);
  cursor:pointer; border:1px solid var(--line); background:var(--ink-700); color:var(--text-muted); transition:all .16s ease; white-space:nowrap;}
.chip:hover{color:var(--text); border-color:var(--gold-600);}
.chip.on{color:var(--gold-300); background:rgba(176,42,42,.14); border:1px solid var(--gold-500);}
.tab-row{display:flex; gap:6px; flex-wrap:wrap;}
.pill{font-family:var(--font-ui); font-weight:600; font-size:13px; padding:9px 15px; border-radius:var(--r-sm);
  cursor:pointer; border:1px solid var(--line); background:transparent; color:var(--text-muted); transition:all .16s ease; white-space:nowrap;
  display:inline-flex; align-items:center; gap:6px;}
.pill:hover{color:var(--text); border-color:var(--gold-600);}
.pill.on{color:var(--gold-300); background:rgba(176,42,42,.12); border:1px solid var(--gold-500);}
.pill.dashed{border-style:dashed; color:var(--text-faint);}

/* ── panels & cards ── */
.panel{background:var(--ink-700); border:1px solid var(--line); border-radius:var(--r-lg); box-shadow:var(--sh-inset); padding:22px;}
.panel-summary{background:var(--ink-700); border:1px solid var(--line); border-radius:var(--r-lg); box-shadow:var(--sh-inset); padding:18px 20px;}
.token-panel{background:radial-gradient(120% 130% at 50% 0%, #20180f, var(--ink-700)); border:1px solid var(--line);
  border-radius:var(--r-lg); box-shadow:var(--sh-inset); padding:24px; text-align:center;}
.pack-card{background:var(--ink-700); border:1px solid var(--line); border-radius:var(--r-lg); box-shadow:var(--sh-inset);
  padding:18px 19px; cursor:pointer; transition:all .18s ease;}
.pack-card:hover{border-color:var(--gold-600); box-shadow:var(--glow-gold), var(--sh-2); transform:translateY(-3px);}
.role-card{background:var(--ink-700); border:1px solid var(--line); border-radius:var(--r-lg); box-shadow:var(--sh-inset);
  padding:14px; cursor:pointer; transition:all .18s ease; display:flex; gap:13px; align-items:center;}
.role-card:hover{border-color:var(--gold-600); box-shadow:var(--glow-gold), var(--sh-2); transform:translateY(-3px);}
.add-tile{display:flex; flex-direction:column; align-items:center; justify-content:center; gap:8px; min-height:100px;
  border:1.5px dashed var(--line); border-radius:var(--r-lg); background:transparent; cursor:pointer; transition:all .16s ease; font-family:var(--font-ui);}
.add-tile:hover{border-color:var(--gold-500); background:rgba(176,42,42,.05);}
.empty-state{border:1.5px dashed var(--line); border-radius:var(--r-xl); padding:64px 24px; text-align:center;
  background:radial-gradient(120% 130% at 50% 0%, #1c150d, var(--ink-800));}

/* ── icon buttons ── */
.icon-btn{width:30px; height:30px; border-radius:var(--r-sm); border:1px solid var(--line); background:var(--ink-600);
  color:var(--text-muted); cursor:pointer; font-size:13px; display:flex; align-items:center; justify-content:center; transition:all .15s ease;}
.icon-btn:hover{border-color:var(--gold-600); background:var(--ink-550); color:var(--gold-300);}
.icon-btn.danger{color:var(--text-faint);}
.icon-btn.danger:hover{border-color:var(--oxblood-500); background:var(--oxblood-600); color:#F4ECD8;}

/* ── nav links ── */
.nav-link{font-family:var(--font-ui); font-weight:600; font-size:13.5px; color:var(--text-muted); background:transparent;
  border:1px solid transparent; border-radius:var(--r-sm); padding:8px 13px; cursor:pointer; transition:all .16s ease; text-decoration:none;}
.nav-link:hover{color:var(--text); background:rgba(176,42,42,.06);}
.nav-link.active{color:var(--gold-300); background:rgba(176,42,42,.12); border:1px solid var(--gold-600);}
.seg-nav{display:inline-flex; align-items:center; gap:8px; font-family:var(--font-ui); font-weight:600; font-size:13.5px;
  padding:14px 16px; cursor:pointer; background:transparent; border:none; border-bottom:2px solid transparent;
  color:var(--text-muted); white-space:nowrap; transition:all .16s ease;}
.seg-nav:hover{color:var(--text);}
.seg-nav.active{border-bottom-color:var(--gold-400); color:var(--gold-300);}

/* ── role-type segment (4 teams) ── */
.type-seg{flex:1; display:flex; flex-direction:column; align-items:center; gap:2px; padding:12px 8px; cursor:pointer;
  text-align:center; border-radius:var(--r-sm); border:1px solid var(--line); background:var(--ink-700);
  color:var(--text-muted); transition:all .18s ease;}
.type-seg-title{font-family:var(--font-display); font-size:15px; font-weight:700; line-height:1.05; white-space:nowrap;}
.type-seg-sub{font-size:10px; letter-spacing:.1em; text-transform:uppercase; opacity:.8;}

/* ── headings & layout ── */
.stage{padding:30px 26px;}
.h2{font-family:var(--font-display); font-weight:700; font-size:24px; color:var(--parchment); margin:0 0 16px; padding-bottom:8px; border-bottom:1px solid var(--line);}
.page-title{font-family:var(--font-display); font-weight:700; font-size:38px; margin:0; color:var(--parchment); line-height:1;}
.section-title{font-family:var(--font-display); font-weight:700; color:var(--parchment);}
.row{display:flex; align-items:center;}
.spacer{flex:1;}

/* ── overlay / modal / toast ── */
.overlay{position:fixed; inset:0; background:rgba(8,5,3,.72); backdrop-filter:blur(3px); display:flex; align-items:center;
  justify-content:center; z-index:50; animation:overlayIn .2s ease; padding:24px;}
.modal{width:460px; max-width:100%; background:linear-gradient(180deg,var(--ink-700),var(--ink-800)); border:1px solid var(--oxblood-600);
  border-radius:var(--r-lg); padding:28px; box-shadow:var(--sh-3), 0 0 60px rgba(110,23,23,.3); animation:modalIn .26s cubic-bezier(.2,.8,.2,1);}
.modal-warn{width:52px; height:52px; border-radius:50%; background:var(--danger-bg); border:1px solid var(--oxblood-500);
  display:flex; align-items:center; justify-content:center; font-size:24px; color:var(--oxblood-400); margin-bottom:16px;}
.toast{position:fixed; bottom:26px; left:50%; transform:translateX(-50%); display:flex; align-items:center; gap:11px;
  background:var(--ink-600); border:1px solid var(--line); border-radius:var(--r-md); padding:12px 18px 12px 14px;
  box-shadow:var(--sh-3); z-index:60; animation:toastIn .3s ease; min-width:240px; max-width:460px;}
.toast-icon{width:22px; height:22px; flex:0 0 auto; border-radius:50%; display:flex; align-items:center; justify-content:center;
  font-size:12px; font-weight:800; color:#160f06;}

/* ── grids ── */
.grid-cards{display:grid; grid-template-columns:repeat(auto-fill,minmax(330px,1fr)); gap:16px;}
.grid-roles{display:grid; grid-template-columns:repeat(auto-fill,minmax(252px,1fr)); gap:12px;}
.grid-player{display:grid; grid-template-columns:repeat(auto-fill,minmax(230px,1fr)); gap:14px;}

/* ── role token (component) ── */
.token-wrap{display:inline-flex; flex-direction:column; align-items:center; font-family:var(--font-ui);}
.token-circle{position:relative; border-radius:50%; display:flex; align-items:center; justify-content:center;
  transition:box-shadow .25s ease, transform .2s ease; overflow:visible;}
.token-deco{position:absolute; border-radius:50%; pointer-events:none;}
.token-initial{font-family:var(--font-display); font-weight:600; line-height:1; text-shadow:0 1px 3px rgba(0,0,0,.7); user-select:none; margin-top:2px;}
.token-img{position:absolute; border-radius:50%; object-fit:cover; inset:6%;}
.token-badge{position:absolute; top:-4px; right:-4px; border-radius:999px; background:linear-gradient(180deg,#E3C77E,#C49A3F);
  color:#1a1206; font-family:var(--font-ui); font-weight:800; display:flex; align-items:center; justify-content:center;
  border:1.5px solid #0E0B09; box-shadow:0 2px 6px rgba(0,0,0,.5); padding:0 4px;}
.token-warn{position:absolute; bottom:-3px; right:-3px; border-radius:999px; background:#9E1212; color:#F4ECD8;
  font-family:var(--font-ui); font-weight:800; display:flex; align-items:center; justify-content:center;
  border:1.5px solid #0E0B09; box-shadow:0 2px 6px rgba(0,0,0,.5);}
.token-name{font-family:var(--font-display); font-weight:600; line-height:1.1; color:var(--text); text-align:center; letter-spacing:.01em;}

/* ── spinner ── */
.spinner{width:42px; height:42px; border-radius:50%; border:3px solid var(--line); border-top-color:var(--gold-400); animation:spin .9s linear infinite;}
.center-pad{display:grid; place-items:center; padding:80px 24px; gap:16px; color:var(--text-muted);}

/* ── language switch ── */
.lang-switch{display:inline-flex; border:1px solid var(--line); border-radius:var(--r-pill); overflow:hidden;}
.lang-opt{font-family:var(--font-ui); font-weight:700; font-size:12px; letter-spacing:.04em; color:var(--text-muted);
  background:transparent; border:none; padding:6px 11px; cursor:pointer; transition:all .15s ease;}
.lang-opt:hover{color:var(--text);}
.lang-opt.on{background:rgba(176,42,42,.16); color:var(--gold-300);}

/* ── inline help (ID explainer, etc.) ── */
.help-details{margin-top:10px; border:1px solid var(--line); border-radius:var(--r-sm); background:var(--ink-700); overflow:hidden;}
.help-details summary{cursor:pointer; list-style:none; padding:9px 12px; font-size:12.5px; font-weight:600; color:var(--gold-300);}
.help-details summary::-webkit-details-marker{display:none;}
.help-details[open] summary{border-bottom:1px solid var(--line);}
.help-body{padding:11px 13px; font-size:12.5px; line-height:1.6; color:var(--text-muted);}

/* ── subtle moderator login (top-right, unobtrusive) ── */
.mod-key{width:34px; height:34px; border-radius:var(--r-sm); border:1px solid var(--line); background:transparent;
  color:var(--text-faint); cursor:pointer; font-size:14px; display:inline-flex; align-items:center; justify-content:center;
  text-decoration:none; transition:all .16s ease; opacity:.65;}
.mod-key:hover{opacity:1; color:var(--text-muted); border-color:var(--gold-600);}

/* ── home hero ── */
@keyframes drift{0%{transform:scale(1.06) translate(0,0);} 100%{transform:scale(1.16) translate(-1.5%,-2%);}}
.hero-grid{display:grid; grid-template-columns:1.05fr .95fr; gap:26px; align-items:stretch;}
.hero-copy{display:flex; flex-direction:column; justify-content:center; padding:18px 4px;}
.hero-cta{display:flex; gap:12px; flex-wrap:wrap; margin-bottom:24px;}
.hero-promos{display:flex; gap:12px; flex-wrap:wrap;}
.promo-card{display:flex; align-items:center; gap:12px; flex:1 1 200px; min-width:180px; padding:13px 15px;
  border:1px solid var(--line); border-radius:var(--r-md); background:var(--ink-700); text-decoration:none;
  transition:all .16s ease;}
.promo-card:hover{transform:translateY(-2px); box-shadow:var(--sh-2);}
.promo-ico{font-size:22px; line-height:1; width:38px; height:38px; flex:0 0 auto; display:flex; align-items:center; justify-content:center;
  border-radius:var(--r-sm); border:1px solid var(--line);}
.promo-card b{display:block; color:var(--parchment); font-size:14px; line-height:1.2;}
.promo-sub{font-size:11.5px; color:var(--text-muted); line-height:1.4;}
.promo-boosty{ } .promo-boosty:hover{border-color:#F2693E;} .promo-boosty .promo-ico{color:#F2693E; border-color:rgba(242,105,62,.4);}
.promo-discord:hover{border-color:#5865F2;} .promo-discord .promo-ico{color:#7C86F5; border-color:rgba(88,101,242,.4);}

.hero-stage{position:relative; border:1px solid var(--gold-600); border-radius:var(--r-xl); overflow:hidden;
  min-height:480px; box-shadow:var(--sh-3); background:var(--ink-900);}
.hero-video{position:absolute; inset:0; width:100%; height:100%; object-fit:cover; animation:drift 22s ease-in-out infinite alternate;}
.hero-scrim{position:absolute; inset:0; background:linear-gradient(180deg, rgba(14,11,9,.25), rgba(14,11,9,.82)); pointer-events:none;}
.hero-ring{position:absolute; top:50%; left:50%; border-radius:50%; border:1px solid rgba(176,42,42,.16); pointer-events:none;}
.hero-stats{position:absolute; left:0; right:0; bottom:0; z-index:2; display:flex; justify-content:space-around; gap:12px;
  padding:20px 18px; background:linear-gradient(180deg,transparent,rgba(8,5,3,.72));}
.hero-stat{text-align:center;}
.hero-stat-n{font-family:var(--font-display); font-weight:700; font-size:28px; line-height:1; color:var(--parchment);}
.hero-stat-n.accent{color:var(--gold-300);}
.hero-stat-l{font-size:10px; letter-spacing:.14em; text-transform:uppercase; color:var(--text-muted); margin-top:5px;}
@media (max-width:880px){
  .hero-grid{grid-template-columns:1fr;}
  .hero-stage{min-height:300px;}
}
