:root{
  --bg:#0f1020; --card:#1b1c33; --fg:#f2f2f7; --muted:#9aa0b4;
  --pink:#ff4f81; --green:#34d399; --red:#f87171; --line:#2a2c47;
}
*{box-sizing:border-box}
body{margin:0;font-family:system-ui,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--fg)}
a{color:var(--pink);text-decoration:none}
a:hover{text-decoration:underline}
.topbar{display:flex;align-items:center;justify-content:space-between;
  padding:.8rem 1.2rem;background:var(--card);border-bottom:1px solid var(--line)}
.brand{font-weight:700;font-size:1.2rem;color:var(--pink)}
.topbar nav a{margin-left:1rem;color:var(--fg)}
.container{max-width:680px;margin:1.5rem auto;padding:0 1rem}
.footer{text-align:center;color:var(--muted);padding:2rem 1rem;font-size:.85rem}
h1{font-size:1.5rem}
.muted{color:var(--muted)}
.card{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:1.2rem;margin:1rem 0}
.form label{display:block;margin:.6rem 0}
.form input,.form select,.form textarea{width:100%;padding:.6rem;border-radius:8px;
  border:1px solid var(--line);background:#0e0f1f;color:var(--fg);margin-top:.2rem}
button,.button{display:inline-block;cursor:pointer;border:0;border-radius:10px;
  padding:.65rem 1.1rem;background:var(--pink);color:#fff;font-weight:600}
button:hover,.button:hover{filter:brightness(1.08);text-decoration:none}
.link-danger{background:none;color:var(--red);padding:.3rem .4rem;font-weight:600}
.error{background:#3a1620;color:#ffb4c4;padding:.7rem 1rem;border-radius:10px;margin:1rem 0}
.flash{background:#13322a;color:#9ff0d4;padding:.7rem 1rem;border-radius:10px;margin:1rem 0}
.notice{background:#2a2440;color:#d9d2ff;padding:.8rem 1rem;border-radius:10px;margin:1rem 0;border:1px solid var(--line)}
.hint{color:#ffd479;font-weight:600}
.role{color:var(--green)}

/* Swipe */
.deck{position:relative;height:440px;margin:1rem 0}
.swipe-card{position:absolute;inset:0;background:var(--card);border:1px solid var(--line);
  border-radius:18px;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 10px 30px rgba(0,0,0,.4);
  transition:transform .3s,opacity .3s}
.swipe-card .photo{flex:1;background-size:cover;background-position:center;background-color:#23263f}
.swipe-card .meta{padding:1rem}
.swipe-card .meta h2{margin:.2rem 0}
.swipe-actions{display:flex;gap:1.5rem;justify-content:center;margin:1rem 0}
.btn-nope,.btn-like{width:64px;height:64px;border-radius:50%;font-size:1.6rem;line-height:1}
.btn-nope{background:#2a2c47;color:var(--red)}
.btn-like{background:#2a2c47;color:var(--green)}
.match-banner{text-align:center}
.hidden{display:none}

/* Matches */
.match-list{list-style:none;padding:0}
.match-row{display:flex;align-items:center;gap:1rem}
.avatar{width:54px;height:54px;border-radius:50%;background-size:cover;background-position:center;background-color:#23263f;flex:none}
.grow{flex:1}
.actions{display:flex;align-items:center;gap:.6rem}
.badge{display:inline-block;font-size:.72rem;padding:.15rem .5rem;border-radius:999px;background:#33365a;color:#cdd}
.badge-game{background:#4a3a13;color:#ffd479}
.badge-chat{background:#13322a;color:#9ff0d4}

/* Game */
.frage{font-size:1.1rem;font-weight:600}
#game-area input[type=range]{width:100%}
.row{display:flex;gap:1rem;align-items:center;margin-top:.6rem}

/* Chat */
.chat{display:flex;flex-direction:column;height:60vh;background:var(--card);
  border:1px solid var(--line);border-radius:14px;overflow:hidden}
.messages{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:.4rem}
.msg{max-width:75%;padding:.5rem .8rem;border-radius:14px;background:#2a2c47}
.msg.me{align-self:flex-end;background:var(--pink);color:#fff}
.chat-form{display:flex;gap:.5rem;padding:.6rem;border-top:1px solid var(--line)}
.chat-form input{flex:1;padding:.6rem;border-radius:8px;border:1px solid var(--line);background:#0e0f1f;color:var(--fg)}

/* Premium */
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
@media(max-width:600px){.grid2{grid-template-columns:1fr}}
.table{width:100%;border-collapse:collapse}
.table th,.table td{text-align:left;padding:.5rem;border-bottom:1px solid var(--line);font-size:.92rem}
