/* Werwölfe vom Düsterwald – düsteres Kartenstil-Theme */
:root{
  --bg:#140a1e;              /* tiefes Nachtviolett */
  --bg2:#1e0f2b;
  --panel:#241433;
  --panel2:#2e1a40;
  --ink:#f3e9df;            /* warmes Pergament-Weiß */
  --muted:#a891b8;
  --accent:#c0392b;         /* Blutrot (Kartenrand) */
  --accent2:#8e44ad;        /* Magisches Violett */
  --gold:#d9a441;
  --good:#3fae6b;
  --bad:#e05a4b;
  --line:rgba(255,255,255,.10);
  --radius:16px;
  --shadow:0 10px 40px rgba(0,0,0,.55);
  --font: "Trebuchet MS", "Segoe UI", system-ui, sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:var(--font);
  color:var(--ink);
  background:
    radial-gradient(1200px 600px at 50% -10%, rgba(142,68,173,.35), transparent 60%),
    radial-gradient(900px 500px at 90% 110%, rgba(192,57,43,.25), transparent 60%),
    linear-gradient(160deg, var(--bg), var(--bg2));
  min-height:100vh;
  -webkit-font-smoothing:antialiased;
}
a{color:var(--gold);text-decoration:none}
.wrap{max-width:960px;margin:0 auto;padding:20px}
.center{min-height:100vh;display:flex;align-items:center;justify-content:center;flex-direction:column}

h1,h2,h3{font-weight:800;letter-spacing:.5px;margin:.2em 0}
.brand{display:flex;align-items:center;gap:12px;justify-content:center;margin-bottom:8px}
.brand .moon{font-size:2rem;filter:drop-shadow(0 0 10px var(--accent2))}
.title{font-size:1.8rem;text-align:center;
  background:linear-gradient(180deg,#fff,#d9a441);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.subtitle{color:var(--muted);text-align:center;margin-top:0}

.card{
  background:linear-gradient(180deg,var(--panel),var(--panel2));
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:22px;
}
.card + .card{margin-top:16px}

label{display:block;font-size:.85rem;color:var(--muted);margin:14px 0 6px}
input[type=text],input[type=email]{
  width:100%;padding:14px 16px;border-radius:12px;
  border:1px solid var(--line);background:rgba(0,0,0,.25);color:var(--ink);
  font-size:1rem;outline:none;
}
input:focus{border-color:var(--accent2);box-shadow:0 0 0 3px rgba(142,68,173,.25)}

.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  width:100%;padding:15px 18px;border:0;border-radius:12px;cursor:pointer;
  font-size:1.05rem;font-weight:800;letter-spacing:.4px;color:#fff;
  background:linear-gradient(180deg,#d1483a,var(--accent));
  box-shadow:0 6px 18px rgba(192,57,43,.35);transition:transform .06s ease,filter .2s;
}
.btn:hover{filter:brightness(1.08)}
.btn:active{transform:translateY(1px)}
.btn.secondary{background:linear-gradient(180deg,#5b3a78,var(--accent2));box-shadow:0 6px 18px rgba(142,68,173,.35)}
.btn.ghost{background:transparent;border:1px solid var(--line);box-shadow:none;color:var(--ink)}
.btn.small{width:auto;padding:8px 14px;font-size:.85rem;border-radius:10px}
.btn:disabled{opacity:.5;cursor:not-allowed}

.code-badge{font-size:2.6rem;font-weight:900;letter-spacing:8px;color:var(--gold);
  text-align:center;padding:10px 0;text-shadow:0 2px 12px rgba(217,164,65,.4)}
.hint{color:var(--muted);font-size:.85rem}
.error{color:var(--bad);font-size:.9rem;margin-top:10px;min-height:1.2em}
.row{display:flex;gap:12px;align-items:center}
.row.wrap{flex-wrap:wrap}
.spacer{flex:1}

/* Avatar-Uploader */
.avatar-pick{display:flex;flex-direction:column;align-items:center;gap:10px}
.avatar-ring{
  width:110px;height:110px;border-radius:50%;overflow:hidden;cursor:pointer;
  border:3px solid var(--gold);background:rgba(0,0,0,.3);
  display:flex;align-items:center;justify-content:center;color:var(--muted);
  box-shadow:0 0 24px rgba(217,164,65,.25)
}
.avatar-ring img{width:100%;height:100%;object-fit:cover}

/* Spielerliste (Beamer) */
.players{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:14px}
.player{background:rgba(0,0,0,.25);border:1px solid var(--line);border-radius:14px;
  padding:12px;text-align:center;position:relative}
.player .pic{width:64px;height:64px;border-radius:50%;object-fit:cover;margin:0 auto 8px;
  border:2px solid var(--accent2);background:#000;display:block}
.player .nm{font-weight:700;font-size:.95rem;word-break:break-word}
.player.dead{opacity:.45;filter:grayscale(1)}
.player .kick{position:absolute;top:6px;right:6px;background:rgba(224,90,75,.9);
  border:0;color:#fff;border-radius:50%;width:24px;height:24px;cursor:pointer;font-weight:900;line-height:1}

/* Rollenkarte (Handy) */
.role-card{max-width:340px;margin:0 auto;text-align:center;border-radius:22px;padding:26px 22px;
  border:2px solid var(--gold);background:linear-gradient(180deg,#2a1140,#3a0f22);
  box-shadow:0 16px 50px rgba(0,0,0,.6)}
.role-card .emoji{font-size:4rem;filter:drop-shadow(0 0 16px rgba(217,164,65,.5))}
.role-card .rname{font-size:1.8rem;font-weight:900;margin:6px 0}
.role-card .team{display:inline-block;padding:4px 12px;border-radius:999px;font-size:.8rem;font-weight:800;margin-top:6px}
.team-werewolf{background:rgba(192,57,43,.25);color:#ff8a7a;border:1px solid rgba(192,57,43,.5)}
.team-village{background:rgba(63,174,107,.2);color:#8ff0b5;border:1px solid rgba(63,174,107,.5)}
.role-card .desc{color:var(--muted);margin-top:14px;line-height:1.5}

.pill{display:inline-block;padding:4px 10px;border-radius:999px;background:rgba(0,0,0,.3);
  border:1px solid var(--line);font-size:.8rem;color:var(--muted)}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.toggle{display:flex;align-items:center;justify-content:space-between;gap:10px;
  padding:12px 14px;border:1px solid var(--line);border-radius:12px;background:rgba(0,0,0,.2)}
.switch{position:relative;width:46px;height:26px;flex:none}
.switch input{display:none}
.switch span{position:absolute;inset:0;background:#4a3a58;border-radius:999px;transition:.2s}
.switch span:before{content:"";position:absolute;width:20px;height:20px;left:3px;top:3px;background:#fff;border-radius:50%;transition:.2s}
.switch input:checked + span{background:var(--good)}
.switch input:checked + span:before{transform:translateX(20px)}

.muted{color:var(--muted)}
.qr{background:#fff;padding:12px;border-radius:14px;display:inline-block}
.tag{font-size:.7rem;text-transform:uppercase;letter-spacing:1px;color:var(--muted)}
.big-stage{text-align:center;padding:30px}
.hidden{display:none!important}
