:root{
  --bg:#0b0d10;
  --surface:#161a20;
  --surface-2:#1d222a;
  --border:#272d36;
  --text:#e7eaee;
  --muted:#8b94a3;
  --accent:#6c8cff;
  --accent-2:#8a6cff;
  --radius:14px;
  --shadow:0 14px 40px rgba(0,0,0,.5);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  background:radial-gradient(1200px 600px at 85% -15%, #1b2233 0%, var(--bg) 55%) fixed;
  color:var(--text);
  min-height:100vh;
  -webkit-font-smoothing:antialiased;
}

/* ---------- Topbar ---------- */
.topbar{
  display:flex;align-items:center;gap:16px;
  padding:18px 24px;
  padding-top:max(18px, env(safe-area-inset-top));
  padding-left:max(24px, env(safe-area-inset-left));
  padding-right:max(24px, env(safe-area-inset-right));
  border-bottom:1px solid var(--border);
  background:rgba(11,13,16,.7);
  backdrop-filter:blur(10px);
  position:sticky;top:0;z-index:10;
}
.search{margin-left:auto}
.brand{display:flex;align-items:center;gap:12px}
.brand__logo{
  width:46px;height:46px;object-fit:contain;display:block;
  filter:drop-shadow(0 6px 14px rgba(108,140,255,.3));
}
.brand__name{margin:0;font-size:20px;font-weight:800;letter-spacing:.3px}
.brand__tag{margin:0;font-size:12px;color:var(--muted)}
.search input{
  width:min(320px,40vw);
  padding:10px 14px;border-radius:10px;
  border:1px solid var(--border);background:var(--surface);color:var(--text);
  font-size:14px;outline:none;transition:border-color .15s,box-shadow .15s;
}
.search input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(108,140,255,.18)}
.search input::placeholder{color:var(--muted)}

/* ---------- Main ---------- */
.main{max-width:1200px;margin:0 auto;padding:28px 24px 64px}
.section-title{font-size:18px;font-weight:700;margin:6px 0 20px}
.count{color:var(--muted);font-weight:500}
.empty{color:var(--muted);text-align:center;padding:60px 0}

/* ---------- Grid + Karten ---------- */
.grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(200px,1fr));
  gap:18px;
}
.card{
  text-align:left;cursor:pointer;
  border:1px solid var(--border);border-radius:var(--radius);
  background:var(--surface);color:inherit;padding:0;overflow:hidden;
  transition:transform .15s,border-color .15s,box-shadow .15s;
  font:inherit;
}
.card:hover{transform:translateY(-4px);border-color:#3a4252;box-shadow:var(--shadow)}
.card:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.card__cover{
  position:relative;aspect-ratio:4/3;overflow:hidden;display:grid;place-items:center;
  background:linear-gradient(135deg,var(--surface-2),#10141a);
}
.card__cover img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.card__ph{font-size:40px;font-weight:800;color:var(--muted)}
.card__info{padding:12px 14px;display:flex;flex-direction:column;gap:4px}
.card__title{font-weight:700;font-size:15px}
.card__type{font-size:12px;color:var(--muted)}

/* ---------- Badges ---------- */
.badge{
  display:inline-flex;align-items:center;gap:6px;
  font-size:12px;padding:5px 10px;border-radius:999px;
  background:var(--surface-2);border:1px solid var(--border);color:var(--text);
  white-space:nowrap;
}
.badge--type{background:rgba(108,140,255,.14);border-color:rgba(108,140,255,.35);color:#bcc9ff}

/* ---------- Modal ---------- */
.modal{position:fixed;inset:0;z-index:50;display:grid;place-items:center;padding:20px}
.modal[hidden]{display:none}
.modal__backdrop{position:absolute;inset:0;background:rgba(0,0,0,.65);backdrop-filter:blur(4px)}
.modal__card{
  position:relative;z-index:1;width:min(560px,100%);
  background:var(--surface);border:1px solid var(--border);border-radius:18px;
  overflow:hidden;box-shadow:var(--shadow);
  animation:pop .18s ease;
}
@keyframes pop{from{transform:scale(.96);opacity:0}to{transform:scale(1);opacity:1}}
.modal__close{
  position:absolute;top:12px;right:12px;z-index:2;
  width:34px;height:34px;border-radius:9px;cursor:pointer;
  border:1px solid var(--border);background:rgba(0,0,0,.4);color:var(--text);font-size:14px;
}
.modal__close:hover{background:rgba(0,0,0,.65)}
.modal__cover{aspect-ratio:16/9;background:var(--surface-2)}
.modal__cover img{width:100%;height:100%;object-fit:cover;display:block}
.modal__body{padding:20px}
.modal__head{display:flex;align-items:center;gap:12px;justify-content:space-between;margin-bottom:14px}
.modal__head h3{margin:0;font-size:22px}
.tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px}
.platforms{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px}
.modal__desc{color:var(--muted);line-height:1.6;font-size:15px;margin:0 0 22px}

/* ---------- Buttons ---------- */
.btn{
  border:0;border-radius:11px;cursor:pointer;font:inherit;font-weight:700;
  padding:12px 20px;font-size:15px;transition:filter .15s,background .15s;
}
.btn--play{
  width:100%;color:#fff;
  background:linear-gradient(135deg,var(--accent),var(--accent-2));
  box-shadow:0 8px 22px rgba(108,140,255,.35);
}
.btn--play:hover{filter:brightness(1.08)}
.btn--ghost{background:var(--surface-2);color:var(--text);border:1px solid var(--border)}
.btn--ghost:hover{background:#262c36}

/* ---------- Vollbild-Spieler ---------- */
.player{position:fixed;inset:0;z-index:100;background:#000;display:flex;flex-direction:column}
.player[hidden]{display:none}
.player__bar{
  display:flex;align-items:center;gap:14px;padding:10px 14px;
  background:var(--surface);border-bottom:1px solid var(--border);
}
.player__title{font-weight:700}
.player__frame{flex:1;width:100%;border:0;background:#000}

/* ---------- Account / Topbar rechts ---------- */
.topbar__right{display:flex;align-items:center;gap:14px;margin-left:auto}
.account{display:flex;align-items:center;gap:10px}
.account__name{font-size:14px;color:var(--text);white-space:nowrap}
.btn--sm{padding:9px 14px;font-size:13px}
a.btn{text-decoration:none;display:inline-flex;align-items:center}

/* ---------- Auth-Modal ---------- */
.modal__card--auth{width:min(400px,100%)}
.auth{padding:26px}
.auth__tabs{display:flex;gap:8px;margin-bottom:18px}
.auth__tab{
  flex:1;padding:10px;border:1px solid var(--border);background:var(--surface-2);
  color:var(--muted);border-radius:10px;cursor:pointer;font:inherit;font-weight:600;
}
.auth__tab.is-active{background:rgba(108,140,255,.16);border-color:rgba(108,140,255,.4);color:#bcc9ff}
.auth__form{display:flex;flex-direction:column;gap:12px}
.auth__form input{
  padding:12px 14px;border-radius:10px;border:1px solid var(--border);
  background:var(--surface-2);color:var(--text);font-size:15px;outline:none;
}
.auth__form input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(108,140,255,.18)}

/* ---------- Login-Gate (Anmeldung erzwungen) ---------- */
.gate{
  position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;
  padding:20px;background:radial-gradient(1000px 500px at 50% -10%, #1b2233 0%, var(--bg) 60%);
}
.gate[hidden]{display:none}
.gate__card{
  width:min(400px,100%);background:var(--surface);border:1px solid var(--border);
  border-radius:18px;box-shadow:var(--shadow);padding:30px;
}
.gate__brand{text-align:center;margin-bottom:22px}
.gate__logo{width:64px;height:64px;object-fit:contain;filter:drop-shadow(0 6px 14px rgba(108,140,255,.3))}
.gate__title{margin:10px 0 4px;font-size:24px}
.gate__sub{margin:0;color:var(--muted);font-size:14px}
.auth__msg{
  color:#ffb4b4;font-size:14px;margin:0;
  background:rgba(255,90,90,.1);border:1px solid rgba(255,90,90,.3);
  padding:9px 12px;border-radius:9px;
}

/* ---------- Avatar ---------- */
.avatar{
  display:inline-flex;align-items:center;justify-content:center;
  width:30px;height:30px;border-radius:50%;font-size:16px;line-height:1;flex:none;
}
.avatar--lg{width:64px;height:64px;font-size:34px}

/* ---------- Account-Dropdown ---------- */
.account{position:relative}
.account__btn{
  display:flex;align-items:center;gap:8px;cursor:pointer;
  background:var(--surface);border:1px solid var(--border);border-radius:11px;
  padding:6px 10px 6px 6px;color:var(--text);font:inherit;
}
.account__btn:hover{background:var(--surface-2)}
.account__caret{color:var(--muted);font-size:12px}
.account__burger{display:none;font-size:20px;line-height:1;color:var(--text)}
.dropdown{
  position:absolute;top:calc(100% + 8px);right:0;z-index:40;
  min-width:210px;background:var(--surface);border:1px solid var(--border);
  border-radius:12px;box-shadow:var(--shadow);padding:6px;
}
.dropdown[hidden]{display:none}
.dropdown__item{
  display:block;width:100%;text-align:left;text-decoration:none;
  padding:10px 12px;border:0;border-radius:8px;cursor:pointer;
  background:none;color:var(--text);font:inherit;font-size:14px;
}
.dropdown__item:hover{background:var(--surface-2)}
.dropdown__item--danger{color:#ff9b9b}

/* ---------- Kontoeinstellungen ---------- */
.settings__title{margin:0 0 16px;font-size:20px}
.settings__preview{display:flex;align-items:center;gap:14px;margin-bottom:6px}
.settings__pname{font-size:18px;font-weight:700}
.settings__label{display:block;font-size:13px;color:var(--muted);margin:16px 0 8px}
.settings__input{
  width:100%;padding:11px 14px;border-radius:10px;border:1px solid var(--border);
  background:var(--surface-2);color:var(--text);font-size:15px;outline:none;
}
.settings__input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(108,140,255,.18)}
.picker{display:flex;flex-wrap:wrap;gap:8px}
.picker-scroll{max-height:200px;overflow-y:auto;padding-right:6px;margin-right:-2px}
.picker-scroll::-webkit-scrollbar{width:8px}
.picker-scroll::-webkit-scrollbar-thumb{background:var(--border);border-radius:8px}
.picker-scroll::-webkit-scrollbar-track{background:transparent}
.picker__cat{font-size:12px;color:var(--muted);font-weight:600;margin:12px 2px 8px}
.picker__cat:first-child{margin-top:0}
.picker__item{
  width:42px;height:42px;font-size:20px;cursor:pointer;
  border:1px solid var(--border);border-radius:10px;background:var(--surface-2);
  display:flex;align-items:center;justify-content:center;
}
.picker__item.is-active{border-color:var(--accent);box-shadow:0 0 0 2px rgba(108,140,255,.35)}
.picker--colors{gap:10px}
.picker__color{
  width:34px;height:34px;border-radius:50%;cursor:pointer;border:2px solid transparent;
}
.picker__color.is-active{border-color:#fff;box-shadow:0 0 0 2px rgba(255,255,255,.25)}
#set-save{margin-top:22px;width:100%}
#set-msg{margin-top:16px}

/* ---------- Mobile ---------- */
@media (max-width:600px){
  .topbar{flex-wrap:wrap;row-gap:12px;padding:14px 16px;
    padding-top:max(14px, env(safe-area-inset-top));}
  .brand{order:1}
  .account{order:2;margin-left:auto}          /* Zeile 1: Marke links, Konto rechts */
  .search{order:3;flex-basis:100%;margin-left:0}/* Zeile 2: Suche über volle Breite */
  .search input{width:100%}
  .brand__logo{width:38px;height:38px}
  .brand__name{font-size:18px}
  /* Konto-Menü als Burger */
  .account__btn{padding:8px 10px}
  .account__burger{display:block}
  .account__btn .avatar,
  .account__name,
  .account__caret{display:none}
  .grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:14px}
  .modal__head h3{font-size:19px}
}
