:root { --bg:#111827; --panel:#1f2937; --line:#374151; --text:#f9fafb; --muted:#9ca3af; --accent:#f59e0b; --danger:#ef4444; --ok:#22c55e; }
*{box-sizing:border-box} body{margin:0;font-family:Arial,Helvetica,sans-serif;background:var(--bg);color:var(--text)} a{color:inherit;text-decoration:none}.topbar{display:flex;justify-content:space-between;align-items:center;padding:14px 20px;background:#0b1220;border-bottom:1px solid var(--line)}.brand{font-weight:700;color:var(--accent)}nav{display:flex;gap:14px;align-items:center}.inline{display:inline}.inline button{background:none;border:0;color:var(--text);cursor:pointer;font:inherit}.container{max-width:1100px;margin:0 auto;padding:24px}.card{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:22px;box-shadow:0 12px 40px rgba(0,0,0,.25)}.hero{text-align:center;padding:55px 22px}.btn,button{background:var(--accent);border:0;border-radius:10px;color:#111827;padding:10px 16px;font-weight:700;cursor:pointer}.btn.secondary{background:#4b5563;color:white}.form-card{max-width:460px;margin:30px auto}label{display:block;margin:14px 0;color:var(--muted)}input,select{width:100%;padding:11px;border-radius:10px;border:1px solid var(--line);background:#111827;color:var(--text)}.error,.success{padding:12px;border-radius:10px;margin:12px 0}.error{background:rgba(239,68,68,.15);border:1px solid var(--danger)}.success{background:rgba(34,197,94,.15);border:1px solid var(--ok)}.chat-card{height:calc(100vh - 135px);display:flex;flex-direction:column}.chat-head{display:flex;justify-content:space-between;gap:12px;align-items:center;border-bottom:1px solid var(--line);padding-bottom:12px}.chat-head h1{margin:0}.chat-head span{color:var(--muted)}.messages{flex:1;overflow:auto;padding:16px 0}.message{margin-bottom:12px;padding:12px;border-radius:12px;background:#111827;border:1px solid var(--line);background-size:cover;background-position:center}.message.role-moderator{border-color:var(--accent)}.message.role-admin{border-color:#ef4444}.meta{display:flex;gap:10px;align-items:center;color:var(--muted);font-size:13px}.meta strong{color:white;font-size:15px}.message p{margin:8px 0 0;white-space:pre-wrap;word-break:break-word}.chat-form{display:flex;gap:10px;border-top:1px solid var(--line);padding-top:12px}.chat-form input{flex:1}.table-wrap{overflow:auto}table{width:100%;border-collapse:collapse}td,th{border-bottom:1px solid var(--line);padding:10px;text-align:left;vertical-align:top}.row-form{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.row-form select,.row-form input{width:auto;min-width:140px}.thumb{width:90px;height:50px;object-fit:cover;border-radius:8px;border:1px solid var(--line)}@media(max-width:700px){.topbar,.chat-head,.chat-form{flex-direction:column;align-items:stretch}nav{flex-wrap:wrap}.chat-card{height:auto;min-height:75vh}.row-form{display:block}.row-form>*{margin:4px 0;width:100%!important}}
.hint{color:var(--muted);line-height:1.5}.profile-preview{width:100%;max-height:220px;object-fit:cover;border-radius:12px;border:1px solid var(--line);margin:10px 0 18px}.online-moderators{margin:12px 0;border:1px solid var(--line);border-radius:14px;padding:12px;background:#111827}.online-title{font-weight:700;color:var(--accent);margin-bottom:10px}.online-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px}.online-card{min-height:90px;border-radius:12px;padding:12px;background:#0b1220;background-size:cover;background-position:center;border:1px solid var(--accent);display:flex;flex-direction:column;justify-content:flex-end;box-shadow:inset 0 -50px 50px rgba(0,0,0,.35)}.online-card.role-admin{border-color:#ef4444}.online-card strong{font-size:18px;text-shadow:1px 1px 4px #000}.online-card span{color:#f3f4f6;text-shadow:1px 1px 4px #000}.smiley-bar{display:flex;gap:6px;flex-wrap:wrap;border-top:1px solid var(--line);padding-top:10px;margin-top:4px}.smiley-bar button{background:#111827;color:white;border:1px solid var(--line);border-radius:8px;padding:7px 9px;font-size:18px;line-height:1}.smiley-bar button:hover{border-color:var(--accent)}

/* Vollflächiger Moderatoren-Hintergrund im Chatbereich */
.chat-card{background-color:var(--panel);background-size:cover;background-position:center;background-repeat:no-repeat;transition:background-image .35s ease-in-out}
.chat-card.has-mod-bg{border-color:var(--accent);box-shadow:0 12px 45px rgba(245,158,11,.18)}
.chat-card.has-mod-bg .chat-head,.chat-card.has-mod-bg .messages,.chat-card.has-mod-bg .smiley-bar,.chat-card.has-mod-bg .chat-form,.chat-card.has-mod-bg .online-moderators{position:relative;z-index:1}
.chat-card.has-mod-bg .messages{background:rgba(0,0,0,.18);border-radius:12px;padding-left:10px;padding-right:10px;margin-top:12px}
.chat-card.has-mod-bg .message{background:rgba(17,24,39,.78);backdrop-filter:blur(2px)}
.online-moderators{background:rgba(17,24,39,.80)}

/* Moderator-Status-Schalter */
.mod-status{display:flex;gap:10px;align-items:center;justify-content:flex-end;flex-wrap:wrap}
.mod-status span{color:var(--muted);font-weight:700}

/* v4: Moderatorenbild in das Chatfenster einpassen, nicht abschneiden */
.chat-card.has-mod-bg{
  background-size:contain;
  background-position:center center;
  background-repeat:no-repeat;
  background-color:#05070c;
}
.chat-card.has-mod-bg .messages{
  background:rgba(0,0,0,.10);
}

/* v5: Userliste, Profile, Admin-Werkzeuge, Wunschbox */
textarea{width:100%;padding:11px;border-radius:10px;border:1px solid var(--line);background:#111827;color:var(--text);font-family:inherit;resize:vertical}.wide{max-width:760px}.chat-layout.with-users{display:grid;grid-template-columns:minmax(0,1fr) 280px;gap:18px}.user-panel{height:calc(100vh - 135px);overflow:auto}.user-panel h2{margin-top:0}.user-list{display:flex;flex-direction:column;gap:8px}.user-row{display:flex;gap:10px;align-items:center;padding:9px;border:1px solid var(--line);border-radius:12px;background:#111827}.user-row:hover{border-color:var(--accent)}.user-row span{display:flex;flex-direction:column}.user-row small{color:var(--muted);margin-top:2px}.user-row.role-moderator{border-color:rgba(245,158,11,.7)}.user-row.role-admin{border-color:rgba(239,68,68,.7)}.user-row.onair{box-shadow:0 0 0 2px rgba(245,158,11,.22)}.avatar{width:34px;height:34px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;background:#374151;background-size:cover;background-position:center;color:white;font-weight:800;border:1px solid var(--line);flex:0 0 auto}.avatar.role-moderator{border-color:var(--accent)}.avatar.role-admin{border-color:#ef4444}.avatar.big{width:96px;height:96px;font-size:38px}.message-user{display:inline-flex;align-items:center;gap:8px;color:white}.message-user .avatar{width:24px;height:24px;font-size:12px}.profile-top{display:flex;gap:18px;align-items:center;flex-wrap:wrap}.profile-text{line-height:1.6;background:#111827;border:1px solid var(--line);padding:14px;border-radius:12px}.avatar-preview{width:120px;height:120px;object-fit:cover;border-radius:50%;border:1px solid var(--line);display:block;margin:10px 0 18px}.admin-section{margin-top:18px}.mini-form{margin-top:8px}.danger-btn{background:var(--danger)!important;color:white!important}.chips{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}.chip{display:inline-flex;align-items:center;gap:8px;padding:6px 8px;border:1px solid var(--line);border-radius:999px;background:#111827}.chip button{padding:2px 8px;border-radius:999px}.request-list{display:flex;flex-direction:column;gap:10px}.request-item{border:1px solid var(--line);border-radius:12px;background:#111827;padding:12px}.request-item.done{opacity:.6}.request-item p{margin:8px 0 0;white-space:pre-wrap;word-break:break-word}.request-form{margin-bottom:22px}hr{border:0;border-top:1px solid var(--line);margin:24px 0}
@media(max-width:900px){.chat-layout.with-users{grid-template-columns:1fr}.user-panel{height:auto}.chat-card{height:auto;min-height:75vh}}

/* v6: Webplayer, Wunschbox-Modal, separate Profil/Admin-Seiten */
.radio-player{
  display:grid;
  grid-template-columns:112px minmax(0,1fr) auto;
  gap:16px;
  align-items:center;
  padding:14px;
  margin-bottom:14px;
  border:1px solid rgba(245,158,11,.55);
  border-radius:18px;
  background:linear-gradient(135deg, rgba(245,158,11,.18), rgba(17,24,39,.92));
  box-shadow:0 14px 35px rgba(0,0,0,.25);
}
.player-mod-image{
  width:112px;
  height:86px;
  border-radius:16px;
  border:1px solid var(--line);
  background:#0b1220;
  background-size:contain;
  background-position:center;
  background-repeat:no-repeat;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:34px;
  overflow:hidden;
}
.player-mod-image.active{border-color:var(--accent);box-shadow:0 0 0 3px rgba(245,158,11,.16)}
.player-kicker{font-size:12px;text-transform:uppercase;letter-spacing:.14em;color:var(--accent);font-weight:800;margin-bottom:4px}
.player-title{font-size:24px;font-weight:900;line-height:1.15;margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.player-mod-name{color:var(--muted);font-weight:700;margin-bottom:8px}
.player-main audio{width:100%;height:34px;display:block}
.player-main audio[hidden]{display:none}
.player-actions{display:flex;gap:8px;align-items:center;justify-content:flex-end;flex-wrap:wrap}
.player-actions .btn{white-space:nowrap;text-align:center}
.inner-card{background:#111827;margin-bottom:18px;padding:16px}.settings-form{max-width:720px}
.modal[hidden]{display:none}.modal{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:18px}.modal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.72);backdrop-filter:blur(4px)}.modal-card{position:relative;z-index:1;width:min(720px,100%);max-height:86vh;overflow:auto}.modal-close{position:absolute;top:12px;right:12px;width:38px;height:38px;border-radius:50%;padding:0;background:#111827;color:#fff;border:1px solid var(--line);font-size:26px;line-height:1}.modal-request-list{max-height:300px;overflow:auto}.modal-open{overflow:hidden}
@media(max-width:900px){.radio-player{grid-template-columns:86px minmax(0,1fr)}.player-actions{grid-column:1/-1;justify-content:stretch}.player-actions .btn{flex:1}.player-mod-image{width:86px;height:72px}.player-title{font-size:20px}}
@media(max-width:560px){.radio-player{grid-template-columns:1fr}.player-mod-image{width:100%;height:150px}.player-actions{flex-direction:column}.player-actions .btn{width:100%}}

/* v8: Design-Feinschliff, Admin-Komfort, Logo, Themes, Regeln, eigene Smileys */
.brand{display:inline-flex;align-items:center;gap:10px}.brand-logo{height:34px;max-width:170px;object-fit:contain;border-radius:8px}.admin-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}.color-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.color-grid input[type=color]{height:44px;padding:4px}.logo-preview{max-width:260px;max-height:90px;object-fit:contain;background:#111827;border:1px solid var(--line);border-radius:12px;padding:10px;margin:8px 0 14px}.custom-smiley-list{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}.custom-smiley-item{display:inline-flex;align-items:center;gap:8px;background:#111827;border:1px solid var(--line);padding:8px;border-radius:12px}.custom-smiley-item img{width:32px;height:32px;object-fit:contain}.chat-rules{margin:12px 0;border:1px solid var(--line);border-radius:14px;background:rgba(17,24,39,.78);overflow:hidden}.chat-rules summary{cursor:pointer;padding:12px 14px;font-weight:800;color:var(--accent)}.chat-rules div{padding:0 14px 14px;color:var(--text);line-height:1.5}.custom-smiley-button img{width:24px;height:24px;object-fit:contain;display:block}.inline-smiley{width:28px;height:28px;object-fit:contain;vertical-align:middle;margin:0 2px}.theme-neon{--line:#3b0764;--muted:#d8b4fe;background:radial-gradient(circle at top left, rgba(168,85,247,.28), transparent 35%), var(--bg)}.theme-neon .card,.theme-neon .radio-player{box-shadow:0 0 35px rgba(168,85,247,.25)}.theme-radio{background:linear-gradient(135deg,#141414,#311100 48%,var(--bg))}.theme-radio .topbar{background:rgba(0,0,0,.55)}.theme-radio .card{border-radius:22px}.theme-clean{--line:#d1d5db;--text:#111827;--muted:#4b5563;background:#f3f4f6;color:#111827}.theme-clean .topbar,.theme-clean .card,.theme-clean input,.theme-clean textarea,.theme-clean select,.theme-clean .message,.theme-clean .user-row,.theme-clean .inner-card,.theme-clean .request-item,.theme-clean .chat-rules{background:#fff;color:#111827}.theme-clean .meta strong,.theme-clean .message-user{color:#111827}.theme-clean .btn.secondary{background:#e5e7eb;color:#111827}
@media(max-width:800px){.admin-grid,.color-grid{grid-template-columns:1fr}.brand-logo{max-width:120px}}

/* v9: Moderation direkt im Chat, Systemmeldungen, Willkommen */
.welcome-box{
  margin:12px 0;
  padding:14px 16px;
  border:1px solid rgba(245,158,11,.55);
  border-radius:16px;
  background:linear-gradient(135deg, rgba(245,158,11,.18), rgba(17,24,39,.82));
  color:var(--text);
  line-height:1.55;
  font-weight:700;
}
.system-message{
  text-align:center;
  border-style:dashed;
  background:rgba(75,85,99,.32)!important;
  color:var(--text);
}
.system-message p{margin:0;font-weight:800}
.system-message small{display:block;margin-top:5px;color:var(--muted)}
.system-join{border-color:rgba(34,197,94,.65)}
.system-leave{border-color:rgba(156,163,175,.65)}
.system-onair{border-color:rgba(245,158,11,.9);box-shadow:0 0 0 2px rgba(245,158,11,.12)}
.system-warn,.system-timeout,.system-kick{border-color:rgba(245,158,11,.75)}
.system-ban{border-color:rgba(239,68,68,.85)}
.system-clear{border-color:rgba(96,165,250,.8)}
.user-row-wrap{border:1px solid var(--line);border-radius:14px;background:rgba(17,24,39,.66);overflow:hidden}
.user-row-wrap .user-row{border:0;border-radius:0;background:transparent}
.user-mod-tools{display:flex;gap:5px;flex-wrap:wrap;padding:0 8px 8px 8px}
.mini-btn,.mini-danger{font-size:11px;padding:5px 7px;border-radius:8px;background:#374151;color:#fff}
.mini-btn:hover{background:var(--accent);color:#111827}.mini-danger{background:var(--danger);color:#fff}
.theme-clean .welcome-box{background:#fff8eb;color:#111827}.theme-clean .system-message,.theme-clean .user-row-wrap{background:#fff!important;color:#111827}

.theme-classic{background:radial-gradient(circle at top, rgba(250,204,21,.18), transparent 38%),#0b0b0b}.theme-classic .card,.theme-classic .radio-player{box-shadow:0 0 0 1px rgba(250,204,21,.16),0 22px 55px rgba(0,0,0,.38)}
.theme-midnight{background:radial-gradient(circle at top right, rgba(56,189,248,.22), transparent 36%),linear-gradient(135deg,#020617,#0f172a)}.theme-midnight .topbar{background:rgba(2,6,23,.72)}
.theme-sunset{background:radial-gradient(circle at top left, rgba(251,113,133,.24), transparent 35%),linear-gradient(135deg,#1f0a12,#451a03)}.theme-sunset .card{border-color:rgba(251,113,133,.22)}
.theme-ocean{background:radial-gradient(circle at top left, rgba(34,211,238,.22), transparent 34%),linear-gradient(135deg,#06202a,#082f49)}.theme-ocean .radio-player{box-shadow:0 0 34px rgba(34,211,238,.16)}
.theme-forest{background:radial-gradient(circle at top, rgba(74,222,128,.18), transparent 36%),linear-gradient(135deg,#07130b,#0f2a17)}.theme-forest .card{border-color:rgba(74,222,128,.18)}
.theme-royal{background:radial-gradient(circle at top right, rgba(250,204,21,.15), transparent 28%),linear-gradient(135deg,#16051f,#2e1065)}.theme-royal .card,.theme-royal .radio-player{box-shadow:0 18px 60px rgba(88,28,135,.32)}
.theme-candy{--line:#f9a8d4;--text:#831843;--muted:#9d174d;background:linear-gradient(135deg,#fff1f7,#ffe4ef);color:#831843}.theme-candy .topbar,.theme-candy .card,.theme-candy input,.theme-candy textarea,.theme-candy select,.theme-candy .message,.theme-candy .user-row,.theme-candy .inner-card,.theme-candy .request-item,.theme-candy .chat-rules{background:#fff;color:#831843}.theme-candy .message-user,.theme-candy .meta strong{color:#831843}.theme-candy .btn.secondary{background:#fce7f3;color:#831843}.theme-candy .welcome-box{background:#fff;color:#831843}
.theme-graphite{background:linear-gradient(135deg,#111,#262626)}.theme-graphite .card,.theme-graphite .radio-player{box-shadow:0 20px 50px rgba(0,0,0,.34)}
.theme-cyberpunk{background:radial-gradient(circle at 15% 15%, rgba(0,245,255,.24), transparent 28%),radial-gradient(circle at 85% 5%, rgba(255,0,128,.2), transparent 30%),#05000a}.theme-cyberpunk .card,.theme-cyberpunk .radio-player{box-shadow:0 0 30px rgba(0,245,255,.15),0 0 55px rgba(255,0,128,.1)}
.theme-galaxy{background:radial-gradient(circle at 10% 10%, rgba(192,132,252,.26), transparent 30%),radial-gradient(circle at 80% 20%, rgba(59,130,246,.18), transparent 28%),linear-gradient(135deg,#07001a,#16002e)}.theme-galaxy .card,.theme-galaxy .radio-player{box-shadow:0 22px 70px rgba(88,28,135,.35)}


/* v10: kompakter Chatkopf, mehr Platz für den Chat */
.chat-layout.with-users{
  max-width:1380px;
  margin:0 auto;
  grid-template-columns:minmax(0,1fr) 260px;
}
.chat-card{
  height:calc(100vh - 92px);
  padding:14px;
}
.user-panel{
  height:calc(100vh - 92px);
  padding:14px;
}
.compact-player.radio-player{
  grid-template-columns:72px minmax(0,1fr) auto;
  gap:10px;
  padding:9px 10px;
  margin-bottom:8px;
  border-radius:14px;
}
.compact-player .player-mod-image{
  width:72px;
  height:54px;
  border-radius:12px;
  font-size:24px;
}
.compact-player .player-topline{
  display:flex;
  gap:10px;
  align-items:center;
  justify-content:space-between;
  min-width:0;
  margin-bottom:2px;
}
.compact-player .player-kicker{
  margin:0;
  font-size:11px;
  white-space:nowrap;
}
.compact-player .player-title{
  font-size:18px;
  margin-bottom:4px;
}
.compact-player .player-mod-name{
  margin:0;
  font-size:12px;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  max-width:240px;
}
.compact-player .player-main audio{
  height:28px;
}
.compact-player .player-actions{
  gap:6px;
}
.compact-player .player-actions .btn{
  padding:7px 10px;
  border-radius:9px;
  font-size:13px;
}
.chat-toolbar{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:10px;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  padding:7px 0;
  margin-bottom:6px;
}
.chat-userline{
  display:flex;
  align-items:center;
  gap:10px;
  min-width:0;
}
.chat-userline strong{font-size:16px;color:var(--text)}
.chat-userline span{color:var(--muted);font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.compact-status{
  display:flex;
  align-items:center;
  gap:8px;
  white-space:nowrap;
}
.compact-status span{font-size:13px;color:var(--muted)}
.compact-status .btn{padding:7px 10px;border-radius:9px;font-size:13px}
.chat-info-collapsed{
  margin:0 0 6px 0;
  border:1px solid var(--line);
  border-radius:12px;
  background:rgba(17,24,39,.62);
  overflow:hidden;
}
.chat-info-collapsed summary{
  cursor:pointer;
  padding:7px 10px;
  font-weight:800;
  color:var(--accent);
  font-size:13px;
}
.chat-info-collapsed .welcome-box,
.chat-info-collapsed .chat-rules-inline{
  margin:0;
  border:0;
  border-top:1px solid var(--line);
  border-radius:0;
  padding:10px 12px;
  line-height:1.45;
  background:rgba(0,0,0,.12);
}
.compact-welcome{font-weight:700}
.messages{
  padding:8px 0;
}
.chat-card.has-mod-bg .messages{
  margin-top:6px;
}
.smiley-bar{
  padding-top:6px;
  margin-top:4px;
}
.chat-form{
  padding-top:8px;
}
.message{margin-bottom:8px;padding:10px}
.user-panel .hint{display:none}
.user-list{gap:6px}
.user-row{padding:7px}
.user-mod-tools{padding:0 7px 7px 7px}
@media(max-width:900px){
  .chat-card,.user-panel{height:auto;min-height:78vh}
  .compact-player.radio-player{grid-template-columns:58px minmax(0,1fr)}
  .compact-player .player-mod-image{width:58px;height:48px}
  .compact-player .player-actions{grid-column:1/-1;display:grid;grid-template-columns:repeat(3,1fr)}
  .chat-toolbar{align-items:stretch;flex-direction:column}
  .compact-status{justify-content:space-between}
}
@media(max-width:560px){
  .container{padding:10px}
  .compact-player.radio-player{grid-template-columns:1fr}
  .compact-player .player-mod-image{display:none}
  .compact-player .player-actions{grid-template-columns:1fr 1fr 1fr}
  .compact-player .player-title{font-size:16px}
  .compact-player .player-mod-name{max-width:160px}
}

/* v11: Badges, Profil-Erweiterung, Spam-Schutz und Moderatorbild-Übergang */
.chat-card{position:relative;overflow:hidden;background-image:none!important}
.mod-bg-layer{position:absolute;inset:0;background-position:center;background-repeat:no-repeat;background-size:contain;opacity:0;transform:scale(1.015);transition:opacity .7s ease,transform 1.2s ease;z-index:0;pointer-events:none}
.mod-bg-layer::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.28),rgba(0,0,0,.38))}
.mod-bg-layer.active{opacity:1;transform:scale(1)}
.chat-card>*:not(.mod-bg-layer){position:relative;z-index:1}
.badge-list{display:inline-flex!important;flex-direction:row!important;gap:4px;flex-wrap:wrap;align-items:center}
.user-badge{display:inline-flex!important;align-items:center;border:1px solid rgba(245,158,11,.55);border-radius:999px;padding:2px 7px;background:rgba(245,158,11,.13);color:#fbbf24;font-size:11px;font-weight:800;line-height:1.2;white-space:nowrap}
.meta .badge-list{margin-left:2px}.meta .user-badge{font-size:10px;padding:1px 6px}.user-row .badge-list{margin-top:3px}.user-row .user-badge{font-size:10px}.profile-details{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin:18px 0}.profile-detail{background:#111827;border:1px solid var(--line);border-radius:12px;padding:12px}.profile-detail small{display:block;color:var(--muted);margin-bottom:4px}.profile-detail strong{display:block}.settings-inline{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.spam-settings-note{margin-top:8px;color:var(--muted);font-size:13px}@media(max-width:700px){.profile-details,.settings-inline{grid-template-columns:1fr}}


/* v14: Albumcover im Webplayer + stabileres Moderatorenbild im Chat */
.player-cover-image{
  width:72px;
  height:54px;
  border-radius:12px;
  border:1px solid var(--line);
  background:#0b1220;
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:24px;
  overflow:hidden;
  transition:background-image .35s ease, box-shadow .35s ease, transform .35s ease;
}
.player-cover-image.active{border-color:var(--accent);box-shadow:0 0 0 3px rgba(245,158,11,.16);transform:scale(1.01)}
.compact-player .player-cover-image{width:72px;height:54px;border-radius:12px;font-size:24px}
@media(max-width:900px){.compact-player .player-cover-image{width:58px;height:48px}}
@media(max-width:560px){.compact-player .player-cover-image{display:none}}
.mod-bg-layer{background-size:contain;background-position:center center}
.chat-card.has-mod-bg .messages{background:rgba(0,0,0,.16)}

/* v15: Wunschbox Moderation */
.request-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}
.btn.tiny{padding:5px 9px;border-radius:9px;font-size:12px;line-height:1;white-space:nowrap}

/* v17: übersichtlicher Adminbereich mit Navigation */
.admin-shell-card{padding:0;overflow:visible;background:transparent;border:0;box-shadow:none}.admin-topline{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:16px;background:var(--panel);border:1px solid var(--line);border-radius:18px;padding:18px 20px;box-shadow:0 12px 40px rgba(0,0,0,.22)}.admin-topline h1{margin:0 0 6px}.admin-dashboard{display:grid;grid-template-columns:245px minmax(0,1fr);gap:18px;align-items:start}.admin-nav-panel{position:sticky;top:14px;background:var(--panel);border:1px solid var(--line);border-radius:18px;padding:14px;box-shadow:0 12px 40px rgba(0,0,0,.22)}.admin-nav-panel strong{display:block;color:var(--accent);margin:4px 8px 10px;text-transform:uppercase;letter-spacing:.08em;font-size:12px}.admin-nav-panel a{display:flex;align-items:center;gap:8px;padding:10px 12px;border-radius:12px;color:var(--text);border:1px solid transparent}.admin-nav-panel a:hover{border-color:var(--accent);background:rgba(245,158,11,.1)}.admin-content-panel{display:flex;flex-direction:column;gap:18px;min-width:0}.admin-block{background:var(--panel);border:1px solid var(--line);border-radius:18px;padding:18px;box-shadow:0 12px 40px rgba(0,0,0,.22);scroll-margin-top:16px}.admin-block-head{display:flex;justify-content:space-between;align-items:center;gap:12px;border-bottom:1px solid var(--line);padding-bottom:12px;margin-bottom:16px}.admin-block-head h2{margin:0}.admin-block-head span{font-size:12px;font-weight:800;color:var(--accent);border:1px solid rgba(245,158,11,.45);background:rgba(245,158,11,.12);border-radius:999px;padding:4px 10px;white-space:nowrap}.admin-stat-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.admin-stat{background:#111827;border:1px solid var(--line);border-radius:16px;padding:14px}.admin-stat small{display:block;color:var(--muted);margin-bottom:6px}.admin-stat strong{display:block;font-size:26px;color:var(--accent)}.admin-hint-box{margin-top:14px;background:rgba(245,158,11,.1);border:1px solid rgba(245,158,11,.28);border-radius:14px;padding:14px;line-height:1.5}.admin-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.admin-form-grid label{margin:0}.admin-form-actions{grid-column:1/-1}.admin-two-cols{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.admin-mini-card{background:#111827;border:1px solid var(--line);border-radius:16px;padding:16px}.admin-mini-card h3{margin-top:0}.admin-inline-form{display:flex;gap:12px;align-items:end;flex-wrap:wrap}.admin-inline-form label{min-width:240px;margin:0}.admin-table-wrap{border:1px solid var(--line);border-radius:16px;background:#111827}.admin-table-wrap table{min-width:850px}.admin-status{display:inline-flex;border-radius:999px;padding:3px 8px;font-size:12px;font-weight:800}.admin-status.ok{background:rgba(34,197,94,.14);color:#86efac;border:1px solid rgba(34,197,94,.35)}.admin-status.warn{background:rgba(245,158,11,.14);color:#fbbf24;border:1px solid rgba(245,158,11,.35)}.admin-status.bad{background:rgba(239,68,68,.14);color:#fca5a5;border:1px solid rgba(239,68,68,.35)}.admin-user-actions{display:grid;grid-template-columns:1fr;gap:10px}.admin-user-card{display:grid;grid-template-columns:220px minmax(0,1fr);gap:14px;align-items:center;background:#111827;border:1px solid var(--line);border-radius:16px;padding:12px}.admin-user-card strong{display:block}.admin-user-card small{display:block;color:var(--muted);margin-top:3px}.admin-danger-zone{border:1px solid rgba(239,68,68,.35);background:rgba(239,68,68,.08);border-radius:16px;padding:16px}.admin-danger-zone h3{margin-top:0}
.design-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:4px}.design-preset-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:16px}.design-preset-card{display:grid;grid-template-columns:58px minmax(0,1fr) auto;gap:10px;align-items:center;background:#0f172a;border:1px solid var(--line);border-radius:14px;padding:10px;text-align:left}.design-preset-card.active{border-color:var(--accent);box-shadow:0 0 0 1px rgba(245,158,11,.22)}.design-preset-card strong{display:block}.design-preset-card small{display:block;color:var(--muted);font-size:12px;margin-top:2px}.design-swatch{width:58px;height:42px;border-radius:12px;background:var(--sw-bg);border:1px solid rgba(255,255,255,.14);position:relative;overflow:hidden}.design-swatch span{position:absolute;left:8px;top:8px;width:28px;height:20px;background:var(--sw-panel);border-radius:7px}.design-swatch i{position:absolute;right:8px;bottom:8px;width:18px;height:18px;background:var(--sw-accent);border-radius:999px}.theme-clean .design-preset-card,.theme-candy .design-preset-card{background:#fff}.theme-clean .design-preset-card small,.theme-candy .design-preset-card small{color:var(--muted)}@media(max-width:760px){.design-preset-grid{grid-template-columns:1fr}.design-preset-card{grid-template-columns:50px minmax(0,1fr)}.design-preset-card .btn{grid-column:1/-1}}
.theme-clean .admin-stat,.theme-clean .admin-mini-card,.theme-clean .admin-table-wrap,.theme-clean .admin-user-card{background:#fff;color:#111827}.theme-clean .admin-nav-panel,.theme-clean .admin-block,.theme-clean .admin-topline{background:#fff;color:#111827}@media(max-width:980px){.admin-dashboard{grid-template-columns:1fr}.admin-nav-panel{position:relative;top:auto;display:flex;flex-wrap:wrap;gap:6px}.admin-nav-panel strong{width:100%}.admin-nav-panel a{padding:8px 10px}.admin-stat-grid,.admin-two-cols,.admin-form-grid{grid-template-columns:1fr}.admin-user-card{grid-template-columns:1fr}.admin-topline{flex-direction:column}.admin-table-wrap table{min-width:720px}}@media(max-width:560px){.admin-block{padding:14px}.admin-topline{padding:14px}.admin-nav-panel{padding:10px}.admin-nav-panel a{font-size:13px}.admin-block-head{align-items:flex-start;flex-direction:column}.admin-stat strong{font-size:22px}}


/* v20: breiter Radio-Admin und besser lesbare Designanpassungen */
.admin-shell-card{width:100%;}
.admin-dashboard{grid-template-columns:260px minmax(0,1fr);}
.admin-two-cols{grid-template-columns:minmax(460px,1fr) minmax(320px,.65fr);}
#design .admin-two-cols{grid-template-columns:minmax(680px,1.35fr) minmax(320px,.65fr);}
.color-grid{grid-template-columns:repeat(auto-fit,minmax(190px,1fr));align-items:end;}
.color-grid label{display:flex;flex-direction:column;gap:7px;min-width:0;}
.color-grid input[type=color]{width:100%;min-width:0;}
.design-preset-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));}
.design-preset-card{grid-template-columns:64px minmax(0,1fr) auto;}
.design-preset-card strong,.design-preset-card small{min-width:0;overflow-wrap:anywhere;}
.check-row{display:flex!important;align-items:center;gap:10px;margin:14px 0;color:var(--text);}
.check-row input[type=checkbox]{width:auto;min-width:auto;flex:0 0 auto;}
.small-hint{font-size:13px;margin-top:-4px;}
.design-overlay-toggle{background:#111827;border:1px solid var(--line);border-radius:12px;padding:11px 12px;}
.chat-card.mod-overlay-off .mod-bg-layer::after{display:none;}
.chat-card.mod-overlay-off.has-mod-bg .messages{background:rgba(0,0,0,.04);}
@media(max-width:1200px){#design .admin-two-cols,.admin-two-cols{grid-template-columns:1fr;}.admin-dashboard{grid-template-columns:230px minmax(0,1fr);}}
@media(max-width:980px){.admin-dashboard{grid-template-columns:1fr}.design-preset-grid{grid-template-columns:1fr}.design-preset-card{grid-template-columns:58px minmax(0,1fr)}}


/* v22: Chat volle Breite + Datenschutzbereich */
.chat-layout-full{width:100%;max-width:none;grid-template-columns:minmax(0,1fr) 300px;}
.chat-layout-full .chat-card,.chat-layout-full .user-panel{height:calc(100vh - 110px);}
.chat-layout-full .messages{min-height:0;}
.privacy-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));}
.privacy-settings-form .privacy-note{background:rgba(245,158,11,.1);border:1px solid rgba(245,158,11,.28);border-radius:14px;padding:12px;line-height:1.5;color:var(--text)}
.privacy-info-card ul{margin:10px 0 0 20px;padding:0;line-height:1.7;color:var(--muted)}
.privacy-info-card code{color:var(--accent)}
@media(max-width:900px){.chat-layout-full{grid-template-columns:1fr}.chat-layout-full .chat-card,.chat-layout-full .user-panel{height:auto;min-height:75vh}}


/* v23: Full-width Chat Fix - parent container also expands */
.container:has(.chat-layout-full){max-width:none;width:100%;padding-left:18px;padding-right:18px;}
.chat-layout.with-users.chat-layout-full{width:100%;max-width:none;grid-template-columns:minmax(0,1fr) 300px;}
.chat-layout.with-users.chat-layout-full .chat-card{height:calc(100vh - 105px);}
.chat-layout.with-users.chat-layout-full .user-panel{height:calc(100vh - 105px);}
@media(max-width:900px){
  .container:has(.chat-layout-full){padding-left:10px;padding-right:10px;}
  .chat-layout.with-users.chat-layout-full{grid-template-columns:1fr;}
  .chat-layout.with-users.chat-layout-full .chat-card,.chat-layout.with-users.chat-layout-full .user-panel{height:auto;min-height:75vh;}
}


/* v24: Meine Daten / Datenschutz-Selbstverwaltung */
.privacy-self-card { max-width: 1400px; margin: 0 auto; }
.privacy-grid-view { display: grid; grid-template-columns: minmax(0, 1fr) minmax(320px, .8fr); gap: 16px; margin: 16px 0; }
.data-list { display: grid; grid-template-columns: 190px minmax(0, 1fr); gap: 8px 14px; margin: 0; }
.data-list dt { color: var(--muted, #9ca3af); font-weight: 700; }
.data-list dd { margin: 0; word-break: break-word; }
.compact-stats { grid-template-columns: repeat(2, minmax(0,1fr)); }
.privacy-data-details { margin-top: 14px; }
.privacy-data-details summary { cursor: pointer; font-weight: 800; color: var(--accent, #f59e0b); }
.privacy-delete-card { margin-top: 16px; border-color: rgba(239,68,68,.35); }
@media (max-width: 900px) {
  .privacy-grid-view { grid-template-columns: 1fr; }
  .data-list { grid-template-columns: 1fr; }
}


/* v26 Gästezugang */
.guest-login-box {
  margin-top: 22px;
  padding: 16px;
  border-radius: 14px;
  background: rgba(245, 158, 11, .10);
  border: 1px solid rgba(245, 158, 11, .35);
}
.guest-login-box h2 { margin-top: 0; }
.guest-login-box p { color: rgba(255,255,255,.76); }
.guest-settings-form .privacy-note { max-width: 900px; }
.user-badge:first-child { margin-left: 0; }
.role-user .user-badge, .role-user.avatar { }


/* v27: Umfragen und Moderatorenbild-Galerie */
.poll-modal-card{max-width:780px;width:min(96vw,780px);max-height:90vh;overflow:auto}.poll-panel{margin:12px 0;padding:12px;border:1px solid rgba(255,255,255,.12);border-radius:14px;background:rgba(0,0,0,.18)}
.poll-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}.btn.mini{padding:7px 10px;font-size:.85rem}.poll-create{display:grid;gap:10px;margin:10px 0;padding:10px;border-radius:12px;background:rgba(255,255,255,.04)}.poll-create textarea,.poll-create input{width:100%}.poll-list{display:grid;gap:10px}.poll-card{padding:12px;border-radius:12px;background:rgba(255,255,255,.055);border:1px solid rgba(255,255,255,.1)}.poll-question{font-weight:800;font-size:1.02rem;margin-bottom:4px}.poll-options{display:grid;gap:7px;margin-top:9px}.poll-option{position:relative;overflow:hidden;display:flex;justify-content:space-between;align-items:center;gap:10px;width:100%;padding:9px 10px;border:1px solid rgba(255,255,255,.16);border-radius:10px;background:rgba(0,0,0,.22);color:inherit;cursor:pointer;text-align:left}.poll-option:hover{border-color:var(--accent,#f59e0b)}.poll-option.voted{outline:2px solid var(--accent,#f59e0b)}.poll-bar{position:absolute;inset:0 auto 0 0;background:rgba(245,158,11,.22);z-index:0;transition:width .25s ease}.poll-option-text,.poll-option strong{position:relative;z-index:1}.poll-actions{display:flex;gap:8px;margin-top:9px}.mini-btn,.mini-danger{border:0;border-radius:8px;padding:6px 9px;cursor:pointer}.mini-btn{background:rgba(255,255,255,.14);color:#fff}.mini-danger{background:#7f1d1d;color:#fff}.mod-image-grid,.admin-mod-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px;margin:12px 0}.mod-image-tile,.admin-mod-img{border:1px solid rgba(255,255,255,.14);border-radius:14px;padding:10px;background:rgba(255,255,255,.045)}.mod-image-tile.active,.admin-mod-img.active{border-color:var(--accent,#f59e0b);box-shadow:0 0 0 2px rgba(245,158,11,.22)}.mod-image-tile img,.admin-mod-img img{width:100%;aspect-ratio:16/9;object-fit:cover;border-radius:10px;margin-bottom:8px}.inline-actions{display:flex;gap:7px;flex-wrap:wrap;margin-top:8px}.admin-mod-img .row-form{display:flex;gap:4px;flex-wrap:wrap}.admin-mod-gallery{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}.admin-mod-img .thumb{height:auto!important;max-height:none!important}.btn.danger{background:#7f1d1d;color:#fff}

/* v29: zentrale Chat-Navigation */
.main-nav{display:flex;gap:10px;align-items:center;flex-wrap:wrap;justify-content:flex-end}
.main-nav a,.main-nav .nav-button,.main-nav .inline button{display:inline-flex;align-items:center;justify-content:center;min-height:34px;padding:7px 11px;border-radius:999px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.06);color:var(--text);font-weight:800;font-size:13px;line-height:1;text-decoration:none;cursor:pointer}
.main-nav a:hover,.main-nav .nav-button:hover,.main-nav .inline button:hover{border-color:var(--accent);background:rgba(245,158,11,.14);color:var(--accent)}
.player-actions-clean{min-width:0;align-items:center;justify-content:flex-end}
.player-action-hint{font-size:12px;color:var(--muted);white-space:nowrap}
@media(max-width:760px){.topbar{align-items:flex-start}.main-nav{justify-content:flex-start;width:100%}.main-nav a,.main-nav .nav-button,.main-nav .inline button{font-size:12px;padding:7px 9px}.player-action-hint{display:none}}


/* v30: Professioneller, aufgeräumter Webplayer ohne Zusatztexte neben dem Player */
.radio-player.compact-player{
  grid-template-columns:86px minmax(0,1fr);
  gap:14px;
  padding:12px 14px;
  margin-bottom:10px;
  border-radius:20px;
  border:1px solid color-mix(in srgb, var(--accent) 45%, transparent);
  background:
    radial-gradient(circle at 12% 15%, color-mix(in srgb, var(--accent) 22%, transparent), transparent 36%),
    linear-gradient(135deg, rgba(3,7,18,.96), rgba(17,24,39,.88));
  box-shadow:0 18px 55px rgba(0,0,0,.35), inset 0 1px 0 rgba(255,255,255,.06);
  overflow:hidden;
  position:relative;
}
.radio-player.compact-player::after{
  content:'';
  position:absolute;
  inset:0;
  pointer-events:none;
  background:linear-gradient(90deg, transparent, rgba(255,255,255,.045), transparent);
  opacity:.55;
}
.compact-player .player-cover-image{
  width:86px;
  height:70px;
  border-radius:16px;
  background-color:#05070c;
  box-shadow:0 10px 28px rgba(0,0,0,.35);
  position:relative;
  z-index:1;
}
.compact-player .player-main{
  min-width:0;
  position:relative;
  z-index:1;
}
.compact-player .player-topline{
  justify-content:flex-start;
  margin-bottom:4px;
}
.compact-player .player-kicker{
  display:inline-flex;
  align-items:center;
  gap:7px;
  font-size:11px;
  letter-spacing:.16em;
}
.live-dot{
  width:8px;
  height:8px;
  border-radius:999px;
  background:#ef4444;
  box-shadow:0 0 0 4px rgba(239,68,68,.16), 0 0 18px rgba(239,68,68,.75);
  display:inline-block;
}
.compact-player .player-title{
  font-size:20px;
  letter-spacing:-.02em;
  margin-bottom:7px;
}
.compact-player .player-mod-name,
.player-actions-clean,
.player-action-hint{
  display:none!important;
}
.compact-player .player-main audio{
  width:100%;
  height:32px;
  border-radius:999px;
  filter:drop-shadow(0 4px 10px rgba(0,0,0,.2));
}
@media(max-width:760px){
  .radio-player.compact-player{grid-template-columns:70px minmax(0,1fr);padding:10px}
  .compact-player .player-cover-image{width:70px;height:58px}
  .compact-player .player-title{font-size:17px}
}
@media(max-width:520px){
  .radio-player.compact-player{grid-template-columns:1fr}
  .compact-player .player-cover-image{display:none}
}


/* v31: Moderatorenbild sauber in den Chatbereich einpassen */
.chat-card .mod-bg-layer{background-repeat:no-repeat;background-position:center center;}
.chat-card.mod-bg-fit-contain .mod-bg-layer{background-size:contain;}
.chat-card.mod-bg-fit-cover .mod-bg-layer{background-size:cover;}
.chat-card.mod-bg-fit-stretch .mod-bg-layer{background-size:100% 100%;}
.chat-card.has-mod-bg .messages{background:rgba(0,0,0,.10);border-radius:14px;}
.chat-card.mod-overlay-off.has-mod-bg .messages{background:rgba(0,0,0,.02);}


/* v32: deutliche On-Air-Markierung in der rechten Userliste */
.online-moderators{display:none!important}
.user-row.onair{
  position:relative;
  border-color:#ef4444!important;
  background:linear-gradient(135deg, rgba(239,68,68,.22), rgba(245,158,11,.10), rgba(17,24,39,.72))!important;
  box-shadow:0 0 0 1px rgba(239,68,68,.55), 0 0 22px rgba(239,68,68,.22)!important;
}
.user-row-wrap.onair-wrap{
  border-color:rgba(239,68,68,.70)!important;
  box-shadow:0 0 22px rgba(239,68,68,.18);
}
.user-name-line{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.onair-badge{
  display:inline-flex;
  align-items:center;
  gap:5px;
  border-radius:999px;
  padding:3px 8px;
  background:#ef4444;
  color:#fff;
  font-size:10px;
  font-weight:900;
  letter-spacing:.08em;
  line-height:1;
  box-shadow:0 0 12px rgba(239,68,68,.65);
}
.onair-badge::before{
  content:'';
  width:6px;
  height:6px;
  border-radius:50%;
  background:#fff;
  box-shadow:0 0 8px rgba(255,255,255,.9);
}
.user-row.onair .avatar{border-color:#ef4444;box-shadow:0 0 0 2px rgba(239,68,68,.35), 0 0 18px rgba(239,68,68,.35)}
.theme-clean .user-row.onair{background:linear-gradient(135deg,#fff1f2,#fff7ed)!important}
