/* ===========================================================
   ET-Chat · Component styles (entrance + chat)
   =========================================================== */

/* ---------- NOW PLAYING CARD ---------- */
.np-card{display:flex;flex-direction:column;gap:16px}
.np-art{
  position:relative;border-radius:var(--r-md);overflow:hidden;
  background:radial-gradient(120% 90% at 50% 0%,#2a0e05,#0d0605);
  border:1px solid var(--line);aspect-ratio:1.45/1;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;
}
.np-play{position:absolute;top:10px;right:10px;z-index:3;width:42px;height:42px;border-radius:50%;
  border:1px solid rgba(255,255,255,.2);background:rgba(10,8,7,.55);backdrop-filter:blur(4px);
  color:#fff;cursor:pointer;display:grid;place-items:center;transition:.15s}
.np-play:hover{background:var(--orange);border-color:transparent;transform:scale(1.06)}
.np-play svg{width:20px;height:20px;display:block}
.np-card.compact .np-play{width:38px;height:38px;top:8px;right:8px}
.np-art-glow{position:absolute;inset:-30% 10% auto;height:70%;
  background:radial-gradient(circle,var(--orange-glow),transparent 65%);filter:blur(18px);opacity:.7}
.np-logo{position:relative;font-family:var(--display);font-weight:800;font-size:26px;line-height:.92;
  text-align:center;letter-spacing:.01em}
.np-logo span{color:var(--orange)}
.np-eq{position:relative}
.np-meta{display:flex;flex-direction:column;gap:5px}
.np-title{font-family:var(--display);font-weight:800;font-size:18px;line-height:1.1}
.np-artist{color:var(--text-mut);font-size:13px}
.np-onair{margin-top:6px;display:flex;align-items:center;gap:8px;font-size:12px;color:var(--orange-hi);
  font-family:var(--display);font-weight:700;letter-spacing:.04em}
.np-onair .dot{width:7px;height:7px;border-radius:50%;background:var(--orange);animation:pulse 2.4s infinite}
.np-card.compact .np-art{aspect-ratio:2.4/1;gap:6px}
.np-card.compact .np-logo{font-size:18px}
.np-card.compact .np-title{font-size:14px}

/* ---------- ROLE TAGS ---------- */
.role{font-family:var(--display);font-weight:700;font-size:9px;letter-spacing:.14em;
  padding:2px 6px;border-radius:5px;text-transform:uppercase;flex:none}
.role.onair{background:var(--orange);color:#1a0a04}
.role.mod{background:rgba(255,178,77,.16);color:#ffb24d;border:1px solid rgba(255,178,77,.3)}
.role.admin{background:linear-gradient(180deg,#ff5f2e,#d63a12);color:#fff}
.role.guest{background:rgba(255,255,255,.06);color:var(--text-mut)}
.role.user{background:rgba(255,255,255,.05);color:var(--text-dim);border:1px solid var(--line)}
.role.onair{background:var(--orange);color:#1a0a04;animation:oaBlink 1.6s ease-in-out infinite}
@keyframes oaBlink{0%,100%{opacity:1}50%{opacity:.55}}

/* Rollen-Auswahl im Admin-Panel */
.role-sel{font-family:var(--body);font-size:13px;color:var(--text);background:var(--bg);
  border:1px solid var(--line-strong);border-radius:9px;padding:7px 9px;cursor:pointer;outline:none}
.role-sel:focus{border-color:var(--orange)}

/* ===========================================================
   ENTRANCE
   =========================================================== */
.enter-wrap{position:relative;height:100%;overflow-y:auto;overflow-x:hidden}
.enter-wrap::after{content:'';position:fixed;inset:0;z-index:0;pointer-events:none;
  background:radial-gradient(72% 50% at 50% 120%,rgba(255,77,31,.09),transparent 72%)}
.enter-glow{position:fixed;top:-12%;right:-6%;width:58vw;height:58vw;max-width:820px;max-height:820px;
  background:radial-gradient(circle,rgba(255,77,31,.22),transparent 60%);filter:blur(24px);pointer-events:none;z-index:0}

.enter-top{position:relative;z-index:2;display:flex;align-items:center;justify-content:space-between;
  padding:26px clamp(20px,5vw,64px)}
.enter-top-right{display:flex;align-items:center;gap:16px}
.enter-online{font-size:13px;color:var(--text-mut)}
.enter-online b{color:var(--text);font-family:var(--display)}

.enter-main{position:relative;z-index:1;display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(28px,5vw,72px);
  align-items:center;max-width:1240px;margin:0 auto;padding:clamp(10px,2vh,28px) clamp(20px,5vw,64px) 40px}

.dot-i{width:7px;height:7px;border-radius:50%;background:var(--orange);box-shadow:0 0 0 4px rgba(255,77,31,.18)}
.enter-h1{font-size:clamp(38px,4.4vw,60px);font-weight:800;line-height:1.02}
.enter-sub{color:var(--text-dim);font-size:clamp(14px,1.1vw,16px);line-height:1.5;max-width:30em;margin:14px 0 0}

.enter-stats{display:flex;align-items:center;gap:22px;margin:20px 0 0}
.enter-stat-n{font-family:var(--display);font-weight:800;font-size:26px;line-height:1}
.enter-stat-l{color:var(--text-mut);font-size:12px;margin-top:3px}
.enter-div{width:1px;height:32px;background:var(--line-strong)}
.enter-faces{display:flex;align-items:center;margin-top:16px;min-height:30px}
.enter-faces .rr{width:30px;height:30px;font-size:11px;margin-left:-9px;box-shadow:0 0 0 3px var(--bg);transition:transform .15s}
.enter-faces .rr:first-child{margin-left:0}
.enter-faces .rr:hover{transform:translateY(-3px)}
.enter-faces-more{margin-left:12px;font-size:12.5px;color:var(--text-mut)}
.enter-faces-more b{color:var(--text);font-family:var(--display)}
.enter-np-side{margin-top:20px;max-width:320px;display:block}

/* join card */
.enter-card-wrap{display:flex;justify-content:center}
.enter-card{position:relative;width:100%;max-width:448px;padding:30px 28px;overflow:hidden;
  box-shadow:0 44px 100px -34px rgba(0,0,0,.92),inset 0 1px 0 rgba(255,255,255,.05);
  display:flex;flex-direction:column;gap:18px}
.enter-card::before{content:'';position:absolute;top:0;left:24px;right:24px;height:1px;
  background:linear-gradient(90deg,transparent,rgba(255,122,77,.75),transparent)}
.enter-card-head{display:flex;align-items:center;justify-content:space-between;gap:12px}
.enter-tabs{display:flex;gap:3px;background:var(--bg);border:1px solid var(--line);border-radius:11px;padding:4px}
.etab{font-family:var(--display);font-weight:700;font-size:12px;color:var(--text-mut);background:none;border:none;
  padding:8px 14px;border-radius:8px;cursor:pointer;transition:.15s;white-space:nowrap}
.etab:hover{color:var(--text-dim)}
.etab.on{background:linear-gradient(180deg,var(--surface-3),var(--surface-2));color:var(--text);
  box-shadow:0 2px 8px -3px rgba(0,0,0,.6),inset 0 1px 0 rgba(255,255,255,.05)}

.enter-row{display:flex;flex-direction:column;gap:9px}
.enter-nick{display:flex;align-items:center;gap:11px}
.enter-preview{display:flex;align-items:center;gap:7px;font-size:13.5px;background:var(--bg);
  border:1px solid var(--line);border-radius:9px;padding:9px 12px}
.enter-preview-l{color:var(--text-faint);font-size:11px;font-family:var(--display);font-weight:700;letter-spacing:.08em;text-transform:uppercase}

.swatches{display:flex;flex-wrap:wrap;gap:9px}
.sw{width:34px;height:34px;border-radius:9px;border:1px solid var(--line-strong);background:var(--bg);
  display:grid;place-items:center;cursor:pointer;padding:0;transition:.15s}
.sw span{width:18px;height:18px;border-radius:5px;display:block;transition:.15s}
.sw:hover{border-color:var(--sw)}
.sw.on{border-color:var(--sw);box-shadow:0 0 0 2px var(--sw)}
.sw.on span{width:22px;height:22px}

.avatars{display:flex;flex-wrap:wrap;gap:9px}
.av-pick{padding:3px;border-radius:12px;border:1px solid transparent;background:none;cursor:pointer;transition:.15s;line-height:0}
.av-pick:hover{border-color:var(--line-strong)}
.av-pick.on{border-color:var(--orange);box-shadow:0 0 0 2px rgba(255,77,31,.25)}

.enter-rules{display:flex;align-items:flex-start;gap:12px;background:var(--bg);border:1px solid var(--line);
  border-radius:12px;padding:14px;cursor:pointer;transition:.15s}
.enter-rules.on{border-color:rgba(255,77,31,.4);background:rgba(255,77,31,.05)}
.enter-rules input{position:absolute;opacity:0;width:0;height:0}
.checkmark{width:22px;height:22px;border-radius:7px;border:1.5px solid var(--line-strong);flex:none;margin-top:1px;
  display:grid;place-items:center;transition:.15s}
.enter-rules.on .checkmark{background:var(--orange);border-color:var(--orange)}
.enter-rules.on .checkmark::after{content:'✓';color:#1a0a04;font-weight:900;font-size:14px}
.enter-rules-txt{font-size:14px;line-height:1.5;color:var(--text-dim)}
.enter-rules-txt b{color:var(--text)}
.enter-rules-more{display:block;color:var(--text-mut);font-size:12px;margin-top:2px}

.enter-submit{width:100%;padding:16px;font-size:15px;margin-top:2px}
.enter-foot{text-align:center;color:var(--text-faint);font-size:11.5px;line-height:1.5}

/* ===========================================================
   CHAT
   =========================================================== */
.chat-shell{height:100%;display:flex;flex-direction:column}
.chat-top{display:flex;align-items:center;gap:18px;padding:14px clamp(14px,2.5vw,26px);
  border-bottom:1px solid var(--line);background:rgba(13,10,9,.7);backdrop-filter:blur(8px);z-index:5}
.chat-top-l{display:flex;align-items:center;gap:14px;flex:1;min-width:0}
.chat-sep{width:1px;height:24px;background:var(--line-strong)}
.chat-top-c{flex:0 1 auto}
.chat-np-mini{display:flex;align-items:center;gap:11px;background:var(--surface);border:1px solid var(--line);
  border-radius:12px;padding:8px 14px}
.chat-np-t{font-family:var(--display);font-weight:700;font-size:13px;white-space:nowrap}
.chat-np-t span{color:var(--text-mut);font-weight:400}
.chat-np-s{font-size:11px;color:var(--orange-hi);font-weight:700;font-family:var(--display);letter-spacing:.03em}
.chat-top-r{display:flex;align-items:center;gap:12px;flex:1;justify-content:flex-end}
.chat-online{display:flex;align-items:center;gap:7px;font-size:13px;color:var(--text-dim);white-space:nowrap}
.chat-online .dot{width:7px;height:7px;border-radius:50%;background:#54d6a6}
.chat-online b{color:var(--text);font-family:var(--display)}
.chat-leave,.chat-users-btn{font-size:13px;padding:9px 15px}
.chat-users-btn{display:none}

.chat-body{flex:1;display:grid;grid-template-columns:minmax(0,1fr) 288px;min-height:0}

/* users */
.chat-users{grid-column:2;border-left:1px solid var(--line);display:flex;flex-direction:column;min-height:0;background:var(--bg-2)}
.chat-users-head{display:flex;align-items:center;justify-content:space-between;padding:18px 18px 12px}
.chat-users-close{display:none;background:none;border:none;color:var(--text-mut);font-size:16px;cursor:pointer}
.chat-users-list{flex:1;overflow-y:auto;overflow-x:hidden;padding:0 12px;display:flex;flex-direction:column;gap:2px}
.user-row{display:flex;align-items:center;gap:11px;padding:9px 10px;border-radius:11px;transition:.12s}
.user-row:hover{background:var(--surface)}
.user-row.you{background:rgba(255,77,31,.07);border:1px solid rgba(255,77,31,.2)}
.user-meta{flex:1;min-width:0}
.user-nick{font-weight:700;font-size:14px;display:flex;align-items:center;gap:7px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.you-tag{font-family:var(--display);font-size:8px;letter-spacing:.1em;background:var(--orange);color:#1a0a04;padding:2px 5px;border-radius:4px;flex:none}
.user-status{font-size:11.5px;color:var(--text-mut);margin-top:1px}
.chat-users-foot{padding:14px;border-top:1px solid var(--line)}
.chat-users-np{padding:14px;border-bottom:1px solid var(--line)}

/* stream */
.chat-main{grid-column:1;display:flex;flex-direction:column;min-height:0;min-width:0;position:relative}
.chat-stream{flex:1;overflow-y:auto;padding:22px clamp(16px,3vw,38px);display:flex;flex-direction:column;gap:16px}
.chat-day{align-self:center;font-family:var(--display);font-weight:700;font-size:11px;letter-spacing:.16em;
  text-transform:uppercase;color:var(--text-faint);background:var(--surface);border:1px solid var(--line);
  padding:5px 13px;border-radius:999px;margin-bottom:2px}
.msg-system{align-self:flex-start;text-align:left;color:var(--text-mut);font-size:12.5px;
  background:none;border:none;padding:2px 2px 2px 48px;border-radius:0;max-width:100%}
.msg-np{align-self:center;display:flex;align-items:center;gap:10px;color:var(--orange-hi);font-size:13px;
  font-family:var(--display);font-weight:700;letter-spacing:.02em;
  background:rgba(255,77,31,.07);border:1px solid rgba(255,77,31,.25);padding:8px 16px;border-radius:999px}

.msg{display:flex;gap:12px;max-width:78%}
.msg-bubble-wrap{display:flex;flex-direction:column;gap:5px;min-width:0}
.msg-head{display:flex;align-items:center;gap:8px}
.msg-nick{font-weight:700;font-size:13.5px}
.msg-time{font-size:11px;color:var(--text-faint)}
.msg-bubble{background:var(--surface);border:1px solid var(--line);border-radius:4px 14px 14px 14px;
  padding:11px 15px;font-size:15px;line-height:1.5;color:var(--text);width:fit-content;max-width:100%;word-break:break-word}
/* eigene Nachrichten: links wie alle, nur dezent hervorgehoben */
.msg.mine{align-self:flex-start}
.msg.mine .msg-bubble{
  background:linear-gradient(180deg,rgba(255,77,31,.15),rgba(255,77,31,.07));border-color:rgba(255,77,31,.28)}

/* Ansage / Moderations-Banner */
.msg-announce{align-self:stretch;display:flex;align-items:flex-start;gap:12px;
  background:linear-gradient(180deg,rgba(255,77,31,.16),rgba(255,77,31,.06));
  border:1px solid rgba(255,77,31,.4);border-radius:14px;padding:13px 17px;
  color:var(--text);font-size:15px;line-height:1.5;word-break:break-word}
.msg-announce .ann-ic{font-family:var(--display);font-weight:800;font-size:10px;letter-spacing:.12em;
  color:#1a0a04;background:var(--orange);padding:4px 8px;border-radius:6px;flex:none;margin-top:1px}

/* composer */
.composer{position:relative;display:flex;align-items:center;gap:11px;padding:16px clamp(16px,3vw,38px);
  border-top:1px solid var(--line);background:rgba(13,10,9,.8);backdrop-filter:blur(8px)}
.composer-smiley{width:46px;height:46px;flex:none;border-radius:12px;border:1px solid var(--line-strong);
  background:var(--surface-2);color:var(--text-dim);font-size:20px;cursor:pointer;transition:.15s}
.composer-smiley:hover,.composer-smiley.on{background:var(--surface-3);color:var(--orange-hi);border-color:rgba(255,77,31,.4)}
.composer-input{flex:1;height:46px;background:var(--bg);border:1px solid var(--line-strong);border-radius:12px;
  color:var(--text);font-family:var(--body);font-size:15px;padding:0 50px 0 16px;outline:none;transition:.15s;min-width:0}
.composer-input:focus{border-color:var(--orange);box-shadow:0 0 0 3px rgba(255,77,31,.14)}
.composer-color{position:absolute;right:calc(clamp(16px,3vw,38px) + 116px);width:12px;height:12px;border-radius:50%;
  box-shadow:0 0 0 3px var(--bg);pointer-events:none}
.composer-send{height:46px;padding:0 24px;flex:none}

/* smileybox */
.smileybox{position:absolute;bottom:calc(100% + 10px);left:clamp(16px,3vw,38px);width:480px;max-width:calc(100vw - 32px);
  background:var(--surface);border:1px solid var(--line-strong);border-radius:16px;padding:14px;box-shadow:var(--shadow);z-index:20}
.smileybox-head{margin-bottom:10px}
.smiley-tabs{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:10px}
.smiley-tab{font-family:var(--display);font-weight:700;font-size:13px;color:var(--text-mut);
  background:var(--bg);border:1px solid var(--line);border-radius:9px;padding:9px 15px;cursor:pointer;transition:.12s}
.smiley-tab:hover{color:var(--text)}
.smiley-tab.on{background:var(--surface-3);color:var(--text);border-color:rgba(255,77,31,.4)}
.smiley-grid{display:grid;grid-template-columns:repeat(10,1fr);gap:3px}
.smiley{aspect-ratio:1;border:none;background:none;font-size:19px;border-radius:8px;cursor:pointer;transition:.1s;
  display:flex;align-items:center;justify-content:center;padding:2px}
.smiley:hover{background:var(--surface-3);transform:scale(1.15)}
.smiley-img{width:100%;height:100%;object-fit:contain;display:block}
.smiley-grid.img-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:8px;max-height:340px;overflow-y:auto}
.img-grid .smiley{aspect-ratio:1;padding:4px;border:1px solid var(--line);background:var(--bg)}
.img-grid .smiley:hover{transform:none;border-color:rgba(255,77,31,.4)}
.img-grid .smiley-img{max-width:150px;max-height:150px}
.chat-smiley{max-width:100px;max-height:100px;width:auto;height:auto;vertical-align:middle;border-radius:6px;margin:2px 1px;display:inline-block}
/* Diebstahlschutz: kein Ziehen, kein Speichern, keine Auswahl */
.chat-smiley,.smiley-img{-webkit-user-drag:none;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none}
.smiley-img{pointer-events:none}
.chat-smiley{cursor:pointer}
.admin-smiley[draggable="true"]{cursor:grab}
.admin-smiley.dragging{opacity:.4;cursor:grabbing}
.admin-smiley{position:relative;aspect-ratio:1;background:var(--bg);border:1px solid var(--line);border-radius:8px;
  display:flex;align-items:center;justify-content:center;padding:4px}
.admin-smiley .smiley-img{width:100%;height:100%}
.admin-smiley-del{position:absolute;top:-6px;right:-6px;width:18px;height:18px;border-radius:50%;border:none;
  background:#d63a12;color:#fff;font-size:10px;line-height:1;cursor:pointer;display:grid;place-items:center}
.smiley-drop{border:2px dashed var(--line-strong);border-radius:12px;padding:18px;text-align:center;color:var(--text-mut);
  font-size:13px;cursor:pointer;transition:.15s;line-height:1.55}
.smiley-drop b{color:var(--text)}
.smiley-drop:hover{border-color:rgba(255,77,31,.4);color:var(--text-dim)}
.smiley-drop.over{border-color:var(--orange);background:rgba(255,77,31,.08);color:var(--text)}

.chat-scrim{display:none}

/* ===========================================================
   ZAHNRAD + ADMIN-PANEL
   =========================================================== */
.composer-gear,.composer-leave{width:46px;height:46px;flex:none;border-radius:12px;border:1px solid var(--line-strong);
  background:var(--surface-2);color:var(--text-dim);cursor:pointer;transition:.18s;display:grid;place-items:center}
.composer-gear:hover,.composer-gear.on{background:var(--surface-3);color:var(--orange-hi);
  border-color:rgba(255,77,31,.4);transform:rotate(40deg)}
.composer-leave:hover{background:rgba(224,73,42,.14);color:#ff7a4d;border-color:rgba(224,73,42,.45)}
.composer-gear svg,.composer-leave svg{width:20px;height:20px;display:block}

/* On-Air-Schalter im Composer */
.composer-onair{display:inline-flex;align-items:center;gap:7px;flex:none;height:46px;padding:0 14px;white-space:nowrap;
  border-radius:12px;border:1px solid var(--line-strong);background:var(--surface-2);color:var(--text-dim);
  font-family:var(--display);font-weight:800;font-size:11px;letter-spacing:.12em;cursor:pointer;transition:.15s}
.composer-onair:hover{border-color:rgba(84,214,166,.5);color:var(--text)}
.composer-onair .oa-dot{width:10px;height:10px;border-radius:50%;background:#54d6a6;
  box-shadow:0 0 0 0 rgba(84,214,166,.5);transition:.2s}
.composer-onair.on{background:linear-gradient(180deg,#e0492a,#b5300f);border-color:transparent;color:#fff;
  box-shadow:0 10px 26px -10px rgba(224,73,42,.7)}
.composer-onair.on .oa-dot{background:#fff;animation:oaPulse 1.3s infinite}
@keyframes oaPulse{0%{box-shadow:0 0 0 0 rgba(255,255,255,.55)}70%{box-shadow:0 0 0 7px rgba(255,255,255,0)}100%{box-shadow:0 0 0 0 rgba(255,255,255,0)}}

/* On-Air-Recht-Schalter in der Rollen-Verwaltung */
.oa-switch{display:inline-flex;align-items:center;gap:8px;background:var(--bg);border:1px solid var(--line-strong);
  color:var(--text-mut);font-family:var(--display);font-weight:700;font-size:12px;letter-spacing:.04em;
  padding:9px 13px;border-radius:9px;cursor:pointer;transition:.15s}
.oa-switch.sm{padding:7px 11px;font-size:11px}
.oa-switch .oa-dot{width:10px;height:10px;border-radius:50%;background:var(--text-faint);transition:.15s}
.oa-switch:hover{color:var(--text-dim)}
.oa-switch.on{border-color:rgba(84,214,166,.5);color:#54d6a6;background:rgba(84,214,166,.08)}
.oa-switch.on .oa-dot{background:#54d6a6;box-shadow:0 0 8px rgba(84,214,166,.7)}
.oa-switch.cam.on{border-color:rgba(90,184,255,.5);color:#5ab8ff;background:rgba(90,184,255,.08)}
.oa-switch.cam.on .oa-dot{background:#5ab8ff;box-shadow:0 0 8px rgba(90,184,255,.7)}

/* Kamera-Button im Composer (links neben dem Zahnrad) */
.composer-cam{width:46px;height:46px;flex:none;border-radius:12px;border:1px solid var(--line-strong);
  background:var(--surface-2);color:var(--text-dim);cursor:pointer;transition:.15s;display:grid;place-items:center}
.composer-cam:hover{background:var(--surface-3);color:#5ab8ff;border-color:rgba(90,184,255,.45)}
.composer-cam.on{background:rgba(90,184,255,.14);color:#7cc4ff;border-color:rgba(90,184,255,.55)}
.composer-cam svg{width:20px;height:20px;display:block}

/* Live-Kamera-Leiste — fix oben im Chat, mehrere Kameras nebeneinander */
.cam-bar{flex:none;border-bottom:1px solid var(--line);background:#0b0908}
.cam-grid{display:grid;gap:8px;padding:10px 14px;max-width:760px;margin:0 auto;
  grid-template-columns:repeat(auto-fit,minmax(0,1fr))}
.cam-grid[data-count="1"]{max-width:300px}
.cam-grid[data-count="2"]{max-width:480px}
.cam-grid[data-count="3"]{max-width:600px}
.cam-grid[data-count="4"]{grid-template-columns:repeat(2,1fr);max-width:400px}
.cam-tile{position:relative;border-radius:10px;overflow:hidden;background:#000;border:1px solid var(--line);aspect-ratio:4/3}
.cam-tile-img{display:block;width:100%;height:100%;object-fit:cover;transform:scaleX(-1)}
.cam-bar-meta{position:absolute;left:8px;top:8px;display:flex;align-items:center;gap:6px}
.cam-bar-live{display:inline-flex;align-items:center;gap:5px;font-family:var(--display);font-weight:800;font-size:9px;
  letter-spacing:.1em;color:#fff;background:rgba(214,58,18,.9);padding:2px 6px;border-radius:5px}
.cam-bar-live .dot{width:5px;height:5px;border-radius:50%;background:#fff;animation:pulse 1.3s infinite}
.cam-bar-nick{font-family:var(--display);font-weight:700;font-size:11px;color:#fff;
  background:rgba(0,0,0,.55);padding:2px 7px;border-radius:5px;max-width:120px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cam-bar-stop{position:absolute;right:7px;top:7px;width:22px;height:22px;border-radius:50%;border:none;
  background:rgba(0,0,0,.6);color:#fff;font-size:11px;cursor:pointer;display:grid;place-items:center}
.cam-bar-stop:hover{background:#d63a12}

/* Kamera-Einstellungs-Dialog */
.cam-setup-overlay{position:fixed;inset:0;z-index:70;display:grid;place-items:center;padding:20px;
  background:rgba(0,0,0,.62);backdrop-filter:blur(5px);animation:fadeOv .18s ease both}
.cam-setup{width:100%;max-width:400px;max-height:92vh;overflow-y:auto;background:linear-gradient(180deg,var(--surface),var(--bg-2));
  border:1px solid var(--line-strong);border-radius:var(--r-lg);box-shadow:var(--shadow)}
.cam-setup-head{position:sticky;top:0;display:flex;align-items:flex-start;justify-content:space-between;padding:16px 18px;border-bottom:1px solid var(--line);background:var(--surface);z-index:1}
.cam-setup-title{font-family:var(--display);font-weight:800;font-size:18px;line-height:1;margin-top:4px}
.cam-setup-body{padding:16px 18px;display:flex;flex-direction:column;gap:13px}
.cam-setup-preview{position:relative;border-radius:12px;overflow:hidden;background:#000;border:1px solid var(--line);aspect-ratio:4/3;max-height:230px}
.cam-setup-video{display:block;width:100%;height:100%;object-fit:cover;transform:scaleX(-1)}
.cam-setup-hint{position:absolute;inset:0;display:grid;place-items:center;color:var(--text-dim);font-size:13px;text-align:center;padding:16px}
.cam-setup-row{display:flex;flex-direction:column;gap:6px}
.cam-setup-row .txt{width:100%}
.cam-setup-note{font-size:12px;color:var(--text-mut);line-height:1.5}
.cam-setup-foot{display:flex;justify-content:flex-end;gap:9px;margin-top:2px}

.admin-overlay{position:fixed;inset:0;z-index:60;display:grid;place-items:center;padding:20px;
  background:rgba(0,0,0,.62);backdrop-filter:blur(5px);animation:fadeOv .18s ease both}
@keyframes fadeOv{from{opacity:0}to{opacity:1}}
.admin-panel{width:100%;max-width:470px;max-height:88vh;overflow-y:auto;
  background:linear-gradient(180deg,var(--surface),var(--bg-2));
  border:1px solid var(--line-strong);border-radius:var(--r-lg);box-shadow:var(--shadow)}
.admin-head{display:flex;align-items:flex-start;justify-content:space-between;padding:20px 22px;
  border-bottom:1px solid var(--line);position:sticky;top:0;
  background:linear-gradient(180deg,var(--surface),rgba(21,17,15,.96));z-index:1}
.admin-title{font-family:var(--display);font-weight:800;font-size:21px;line-height:1;margin-top:5px}
.admin-close{background:none;border:none;color:var(--text-mut);font-size:17px;cursor:pointer;
  width:34px;height:34px;border-radius:8px;flex:none}
.admin-close:hover{background:var(--surface-3);color:var(--text)}
.admin-body{padding:20px 22px;display:flex;flex-direction:column;gap:22px}
.admin-sec{display:flex;flex-direction:column;gap:11px}
.admin-sec-title{font-family:var(--display);font-weight:700;font-size:11px;letter-spacing:.14em;
  text-transform:uppercase;color:var(--orange)}
.admin-grid2{display:grid;grid-template-columns:1fr 1fr;gap:9px}
.admin-row{display:flex;gap:9px;align-items:center}
.admin-row .txt{flex:1}
.admin-hint{font-size:12px;color:var(--text-mut);line-height:1.5}
.admin-msg{font-size:13px;color:var(--orange-hi);min-height:17px;font-weight:600}
.admin-ban-list{display:flex;flex-direction:column;gap:6px;max-height:190px;overflow-y:auto}
.admin-ban-row{display:flex;align-items:center;gap:10px;padding:8px 8px 8px 11px;
  background:var(--bg);border:1px solid var(--line);border-radius:10px}
.admin-ban-row .u-nick{flex:1;min-width:0;font-weight:700;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.admin-empty{font-size:13px;color:var(--text-faint);padding:6px 2px}
.btn.danger{background:linear-gradient(180deg,#e0492a,#b5300f);border-color:transparent;color:#fff;
  box-shadow:0 8px 22px -10px rgba(224,73,42,.6)}
.btn.danger:hover{filter:brightness(1.07)}
.btn.sm{padding:8px 14px;font-size:12px;border-radius:9px}
.admin-login{padding:24px 22px;display:flex;flex-direction:column;gap:14px}

/* Großes Panel mit linkem Navigator */
.admin-panel.admin-wide{max-width:820px;width:100%;height:min(86vh,600px);max-height:none;display:flex;flex-direction:column;overflow:hidden}
.admin-wide .admin-split{flex:1;display:flex;min-height:0}
.admin-nav{width:216px;flex:none;border-right:1px solid var(--line);background:var(--bg-2);
  padding:16px 12px;display:flex;flex-direction:column;gap:4px;overflow-y:auto}
.admin-nav-item{font-family:var(--display);font-weight:700;font-size:13.5px;text-align:left;
  background:none;border:none;color:var(--text-dim);padding:12px 13px;border-radius:10px;cursor:pointer;transition:.15s}
.admin-nav-item:hover{background:var(--surface);color:var(--text)}
.admin-nav-item.on{background:var(--surface-3);color:var(--text);box-shadow:inset 3px 0 0 var(--orange)}
.admin-content{flex:1;min-width:0;overflow-y:auto;padding:22px;display:flex;flex-direction:column;gap:14px}
.admin-pane-title{font-family:var(--display);font-weight:800;font-size:22px;line-height:1}
@media(max-width:640px){
  .admin-panel.admin-wide{height:min(92vh,640px)}
  .admin-wide .admin-split{flex-direction:column}
  .admin-nav{width:auto;flex-direction:row;overflow-x:auto;border-right:none;border-bottom:1px solid var(--line);padding:10px}
  .admin-nav-item{white-space:nowrap;font-size:12.5px;padding:9px 12px}
  .admin-nav-item.on{box-shadow:inset 0 -3px 0 var(--orange)}
}

/* ===========================================================
   RESPONSIVE
   =========================================================== */
@media(max-width:1080px){
  .chat-top-c{display:none}
}
@media(max-width:920px){
  .enter-main{grid-template-columns:1fr;gap:28px}
  .enter-pitch{order:2}
  .enter-card-wrap{order:1}
  .enter-np-side{display:none}
  .enter-h1{font-size:clamp(40px,11vw,64px)}
}
@media(max-width:760px){
  .chat-body{grid-template-columns:1fr}
  .chat-users{position:fixed;top:0;right:0;bottom:0;left:auto;width:300px;max-width:84vw;z-index:40;
    transform:translateX(100%);transition:transform .25s cubic-bezier(.2,.7,.2,1);box-shadow:var(--shadow)}
  .chat-users.open{transform:none}
  .chat-users-close{display:block}
  .chat-users-btn{display:inline-flex}
  .chat-scrim{display:block;position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:35}
  .chat-leave{display:none}
  .msg{max-width:90%}
  .composer-color{display:none}
  .composer-send{padding:0 16px}
}
@media(max-width:560px){
  .chat-online{display:none}
  .smiley-grid{grid-template-columns:repeat(8,1fr)}
}
