*, *::before, *::after {
  font-family: 'Inter', system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif !important;
}
:root{
  --bg:#0b0b10;
  --panel:#0f1117;
  --panel-2:#0b0d12;
  --muted:#a3a8b8;
  --text:#e7e9f0;
  --accent:#7c5cff;
  --accent-2:#1db954;
  --danger:#ff4d4f;
  --blue:#3b82f6;
  --shadow: 0 20px 40px rgba(0,0,0,.35);
  --radius: 18px;
  --radius-sm: 12px;
  --glass: linear-gradient(135deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  --border: 1px solid rgba(255,255,255,.08);
  --gradient:
    radial-gradient(1200px 600px at 10% -10%, rgba(124,92,255,.25), transparent 60%),
    radial-gradient(1000px 700px at 110% 10%, rgba(29,185,84,.18), transparent 60%),
    radial-gradient(800px 600px at 50% 120%, rgba(255,199,95,.16), transparent 60%);
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
  color:var(--text);
  background: var(--bg);
  background-image: var(--gradient);
  background-attachment: fixed;
}
a{color:var(--accent)}
.shell{max-width:1670px;margin:0 auto;padding:28px}
.topbar{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:22px;}
.brand{display:flex;align-items:center;gap:12px;}
h1{font-size:clamp(1.35rem,2.2vw,1.7rem);margin:0}
.status{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:999px;background:var(--glass);border:var(--border)}
.dot{width:10px;height:10px;border-radius:50%;background:#ff4d4f;box-shadow:0 0 0 0 rgba(255,77,79,.7);animation:pulse 2s infinite}
.dot.online{background:#22c55e}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(34,197,94,.7)}70%{box-shadow:0 0 0 14px rgba(34,197,94,0)}100%{box-shadow:0 0 0 0 rgba(34,197,94,0)}}

.banner{position:fixed;left:50%;transform:translateX(-50%);top:10px;background:#1a202c;color:#fff;border:1px solid rgba(255,255,255,.12);padding:10px 14px;border-radius:10px;box-shadow:var(--shadow);z-index:9999;display:none}
.banner.error{background:#2a1111;border-color:#5c1a1a}

#muteBtn{background: rgba(255,255,255,.06);min-width:45px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
#muteBtn:hover, #muteBtn:active { background: linear-gradient(135deg, #ff5c5c, #ff3b3b); border: none; }
@media(max-width:700px){ #muteBtn span{display:none} }

.grid{display:grid;grid-template-columns:1.7fr 1fr;gap:22px;}
@media (max-width:980px){.grid{grid-template-columns:1fr}}
.panel{background:var(--panel);border:var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}
.panel .inner{padding:22px}
.panel-header{display:flex;align-items:center;justify-content:space-between;padding:16px 22px;border-bottom:var(--border);background:var(--panel-2)}
.panel-title{font-weight:700;letter-spacing:.3px}

.player-top{display:grid;grid-template-columns:360px 1fr;gap:28px;align-items:start}
@media (max-width:720px){.player-top{grid-template-columns:1fr}}

.media-slot{
  position:relative;width:360px;height:360px;border-radius:16px;overflow:hidden;
  background:#000;border:var(--border);box-shadow:0 10px 20px rgba(0,0,0,.4);
  flex:0 0 360px;
}
.media-layer{position:absolute;inset:0;transition:opacity .2s ease}
.media-layer.hidden{opacity:0;pointer-events:none}
.media-layer.visible{opacity:1;pointer-events:auto}

.cover-img{width:100%;height:100%;object-fit:cover;display:block}

.video-wrap{position:absolute;inset:0;background:#000}
.video-container{position:absolute;inset:0;overflow:hidden;border-radius:12px}
.video-container iframe{
  position:absolute;top:0;left:50%;
  height:100%;width:177.78%;
  transform:translateX(-50%);
  border:0;display:block;
}
.video-toggle{
  position:absolute;right:8px;top:8px;width:32px;height:32px;border-radius:8px;
  border:var(--border);background:rgba(0,0,0,.55);color:#fff;font-size:16px;cursor:pointer;
  backdrop-filter:blur(6px);z-index:2
}

.titles{display:flex;flex-direction:column;gap:6px;min-height:64px}
.title{font-weight:800;font-size:clamp(1.1rem,1.7vw,1.4rem);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.subtitle{color:var(--muted);text-transform:uppercase;letter-spacing:.12em;font-size:.8rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.badges{display:flex;align-items:center;gap:8px;margin-top:8px;min-height:26px}
.badge{font-size:.72rem;padding:.25rem .55rem;border-radius:999px;border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.06)}
.badge.youtube{border-color:#f44336;color:#ffb3ae}
.badge.spotify{border-color:#1db954;color:#abf0c8}
.badge.soundcloud{border-color:#ff8800;color:#ffd0a6}

.controls{display:flex;align-items:center;gap:12px;margin-top:18px;flex-wrap:wrap}
.controls .flex-row{display:flex;gap:12px;align-items:center;flex-wrap:wrap;max-width:100%}
.btn{
  appearance:none;border:none;color:#fff;background:var(--glass);border:var(--border);
  padding:12px 14px;border-radius:14px;cursor:pointer;transition:.2s;display:inline-flex;align-items:center;gap:8px;
  white-space:nowrap;min-width:0;max-width:100%;
}
.btn:hover{transform:translateY(-1px)}
.btn-icon{width:46px;height:46px;justify-content:center;border-radius:14px}
.btn-large{width:64px;height:64px;border-radius:16px;font-size:20px}
.btn-chip{padding:8px 12px;border-radius:999px;font-size:.9rem}
#repeatBtn{overflow:hidden;text-overflow:ellipsis}

#playPauseBtn{background:rgba(255,255,255,.06)}
#playPauseBtn:hover,#playPauseBtn:active{background:linear-gradient(135deg,#22c55e,#16a34a);border:none}
#stopBtn{background:rgba(255,255,255,.06)}
#stopBtn:hover,#stopBtn:active{background:linear-gradient(135deg,#ff5c5c,#ff3b3b);border:none}
#skipBtn{background:rgba(255,255,255,.06)}
#skipBtn:hover{background:linear-gradient(135deg,#60a5fa,#3b82f6);border:none}
#playBtn{background:rgba(255,255,255,.06)}
#playBtn:hover,#playBtn:active{background:linear-gradient(135deg,#22c55e,#16a34a);border:none}

.volume{display:flex;align-items:center;gap:12px;margin-left:auto;flex:1 1 340px;min-width:260px}
.vol-slider{width:100%;height:6px;background:#1a1d27;border-radius:999px;outline:none;-webkit-appearance:none}
.vol-slider::-webkit-slider-thumb{appearance:none;width:18px;height:18px;background:var(--accent-2);border-radius:50%;box-shadow:0 2px 8px rgba(29,185,84,.4)}
.vol-text{min-width:64px;text-align:right;color:var(--muted);white-space:nowrap;font-variant-numeric:tabular-nums}

.playbar{display:grid;grid-template-columns:1fr auto auto;gap:12px;margin-top:16px}
.input{width:100%;padding:14px 14px;border-radius:12px;border:var(--border);background:rgba(255,255,255,.04);color:var(--text);outline:none}
.input::placeholder{color:#8c92a6}
.hint{color:var(--muted);font-size:.9rem;margin-top:8px}

.flex-row{display:flex;gap:12px;align-items:center}
.stack{display:flex;flex-direction:column;gap:12px;min-width:0}

.queue-list{display:flex;flex-direction:column;gap:10px;max-height:520px;overflow:auto;padding:12px}
.q-item{position:relative;display:grid;grid-template-columns:36px 1fr auto;gap:12px;align-items:center;background:rgba(255,255,255,.05);border:var(--border);border-radius:12px;padding:12px}
.q-idx{width:36px;height:36px;border-radius:10px;background:rgba(255,255,255,.09);display:flex;align-items:center;justify-content:center;font-weight:700;color:#cbd1e4}
.q-title{font-weight:600}
.q-sub{font-size:.8rem;color:var(--muted)}
.q-actions{display:flex;gap:8px}
.btn-ghost{background:transparent;border:var(--border)}

.stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-top: 24px;
}
.stat {
  background: var(--panel);
  border: var(--border);
  border-radius: var(--radius-sm);
  padding: 18px;
  text-align: center;
}
.stat .value { font-size: 1.8rem; font-weight: 800; }
.stat .label { color: var(--muted); font-size: 0.95rem; margin-top: 4px; }

.progress{height:8px;background:#161923;border-radius:999px;overflow:hidden;margin-top:16px}
.progress>div{height:100%;width:0%;background:linear-gradient(90deg,#7c5cff,#1db954)}

.timecodes{
  display:flex;justify-content:space-between;align-items:center;gap:12px;
  color:var(--muted);font-size:.92rem;white-space:nowrap;
  font-variant-numeric:tabular-nums;min-height:22px;
}

.search-results{position:absolute;top:52px;left:0;right:0;background:var(--panel-2);border:var(--border);border-radius:12px;box-shadow:var(--shadow);max-height:320px;overflow:auto;z-index:20;padding:6px 6px}
.search-item{display:flex;gap:10px;padding:8px;border-radius:10px;align-items:center;cursor:pointer}
.search-item:hover{background:rgba(255,255,255,.06)}
.thumb{width:52px;height:52px;border-radius:10px;object-fit:cover;border:var(--border)}

.now-playing{display:none;gap:12px;align-items:center;border:var(--border);border-radius:14px;background:rgba(255,255,255,.04);padding:12px;margin:12px}
.now-thumb{width:64px;height:64px;border-radius:10px;object-fit:cover;border:var(--border);background:#111}

.next-up{display:none;gap:12px;align-items:center;border:var(--border);border-radius:14px;background:rgba(255,255,255,.04);padding:12px;margin:0 12px 12px}
.next-up .actions{margin-left:auto;display:flex;gap:8px}
.mini-thumb{width:56px;height:56px;border-radius:10px;object-fit:cover;border:var(--border);background:#111}

.ctx{position:absolute;z-index:999;display:none;min-width:180px;background:#11151f;border:1px solid rgba(255,255,255,.14);border-radius:10px;box-shadow:var(--shadow)}
.ctx button{width:100%;text-align:left;padding:10px 12px;background:transparent;border:none;color:#e7e9f0;cursor:pointer}
.ctx button:hover{background:rgba(255,255,255,.06)}

.mini-player{position:fixed;right:18px;bottom:18px;padding:10px 12px;background:#0f1117;border:var(--border);border-radius:14px;display:none;align-items:center;gap:10px;box-shadow:var(--shadow);backdrop-filter:blur(6px)}
.mini-title{max-width:220px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

.modal{position:fixed;inset:0;background:rgba(0,0,0,.45);display:none;align-items:center;justify-content:center;z-index:9998}
.modal .box{background:#0f1117;border:var(--border);border-radius:14px;box-shadow:var(--shadow);padding:18px;max-width:520px;width:90%}
.kbd{padding:2px 6px;border-radius:6px;border:1px solid rgba(255,255,255,.2);background:rgba(255,255,255,.08)}

@media (max-width:700px){
  .volume{min-width:200px;flex:1 1 200px}
  .vol-text{min-width:52px}
}

.lang-select { position: relative; margin-left: 8px; }
.lang-btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 6px 10px; border-radius: 10px;
  background: transparent; border: var(--border); color: var(--text);
  cursor: pointer; user-select: none;
}
.lang-btn:focus { outline: 2px solid rgba(255,255,255,.2) }
.lang-menu {
  position: absolute; right: 0; top: calc(100% + 6px);
  background: var(--panel-2); border: var(--border); border-radius: 10px;
  box-shadow: var(--shadow); min-width: 200px; padding: 6px;
  display: none; z-index: 50;
}
.lang-menu.open { display: block; }
.lang-item {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 10px; border-radius: 8px; cursor: pointer;
}
.lang-item:hover { background: rgba(255,255,255,.06); }
.flag { width: 24px; height: 16px; border-radius: 2px; overflow: hidden; flex: 0 0 24px; }
.flag svg { display:block; width:100%; height:100%; }

#serverPicker select.input{
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  position: relative;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.16);
  color: var(--text);
  padding: 12px 44px 12px 14px;
  border-radius: 12px;
  font-weight: 600;
  letter-spacing: .2px;
  outline: none;
  transition: border-color .15s ease, box-shadow .15s ease, background .15s ease, transform .05s ease;
  box-shadow: inset 0 0 0 1px rgba(0,0,0,.15);
}
#serverPicker select.input:hover{
  background: rgba(255,255,255,.08);
  border-color: rgba(255,255,255,.24);
}
#serverPicker select.input:focus{
  border-color: var(--accent);
  box-shadow:
    0 0 0 3px rgba(124,92,255,.25),
    var(--shadow);
  background: rgba(255,255,255,.08);
}
#serverPicker select.input{
  background-image:
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%23cbd1e4' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");
  background-repeat: no-repeat;
  background-position: right 12px center;
}
#serverPicker select.input option{
  background: #0f1117;
  color: #e7e9f0;
  font-weight: 500;
}
#serverPicker select.input:disabled{
  opacity: .55;
  cursor: not-allowed;
  filter: grayscale(.15);
  background: rgba(255,255,255,.04);
  border-color: rgba(255,255,255,.12);
}
.select-wrap{ position: relative; min-width: 240px; }
.select-wrap .disabled-overlay{ display: none; }
.select-wrap.is-disabled .disabled-overlay{
  display: flex; align-items: center; justify-content: center;
  position: absolute; inset: 0; border-radius: 12px;
  background: rgba(15,17,23,.55); border: 1px solid rgba(255,255,255,.08);
  font-size: .85rem; color: var(--muted); pointer-events: none;
}
.select-label{
  display: block; font-size: .78rem;
  text-transform: uppercase; letter-spacing: .16em;
  color: var(--muted); margin-bottom: 6px;
}

.btn-invite{
  background: rgba(124,92,255,.10);
  border-color: rgba(124,92,255,.35);
}
.btn-invite:hover{
  transform: translateY(-1px);
  background: linear-gradient(135deg, #7c5cff, #1db954);
  color: #fff;
  border: none;
}

.footer {
  text-align: center;
  font-size: 0.85rem;
  color: var(--muted);
  padding: 20px 0;
  margin-top: 40px;
  border-top: 1px solid rgba(255,255,255,.08);
}
.footer a { color: var(--accent); text-decoration: none; }
.footer a:hover { text-decoration: underline; }

.panel.panel-small {
  font-size: 0.8rem;
  margin-top: 8px;
  padding: 4px 8px;
}
.panel.panel-small .panel-header { padding: 4px 6px; }
.panel.panel-small .panel-title { font-size: 0.9rem; font-weight: 600; }
.panel.panel-small .inner { padding: 4px 6px; line-height: 1.3; }

#aboutFaq.panel {
  width: 100%;
  max-width: 1620px;
  margin: 8px auto;
  box-sizing: border-box;
  padding: 6px 10px;
}
#aboutFaq.panel { align-self: center; }
#aboutFaq .panel-header { padding: 4px 6px; }
#aboutFaq .panel-title  { font-size: 0.9rem; font-weight: 600; }
#aboutFaq .inner        { padding: 4px 6px; line-height: 1.3; }

.gate{
  min-height:100vh;
  display:flex;align-items:center;justify-content:center;
  padding:24px;position:relative;
  background:var(--bg);background-image:var(--gradient);
}

.login-card{
  max-width:520px;width:100%;
  background:rgba(255,255,255,.04);
  border:var(--border);border-radius:16px;
  box-shadow:var(--shadow);padding:22px;text-align:center;color:var(--text);
}
.login-logo{width:192px;height:auto;margin:0 auto 10px;display:block;}

.btn-discord{
  display:inline-flex;align-items:center;gap:10px;
  background:#5865F2;color:#fff;text-decoration:none;
  padding:12px 16px;border-radius:12px;font-weight:700;border:0;
}

.lang-select--abs{position:absolute;top:16px;right:16px;z-index:1001;}


#loginGate .title{
  font-weight: 800;
  font-size: 1.6rem;
  line-height: 1.2;
  margin: 4px 0 10px;
  text-transform: none;
  letter-spacing: 0;
  color: var(--text);
}
#loginGate .subtitle{
  opacity: .8;
  margin-bottom: 16px;
  font-size: 1rem;
  text-transform: none;
  letter-spacing: 0;
  white-space: normal;
  overflow: visible;
  text-overflow: unset;
  line-height: 1.4;
  max-width: 100%;
  word-break: break-word;
}
#loginGate .hint{
  white-space: normal;
  overflow: visible;
  text-overflow: unset;
  line-height: 1.4;
  max-width: 100%;
  word-break: break-word;
  margin-top: 12px;
  font-size: .9rem;
  opacity: .8;
}
#loginGate .login-card{
  text-align: center;
}

.user-controls{
  display:inline-flex; gap:8px; align-items:center; margin-left:8px;
}
.user-box{
  background:rgba(255,255,255,.06);
  padding:6px 10px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.12);
}
.logout-form{ display:inline; }

.kbd {
  display: inline-block;
  min-width: 1.6em;
  padding: 2px 6px;
  margin: 0 4px 8px 4px; 
  font-family: monospace;
  font-size: 0.9em;
  border: 1px solid currentColor;
  border-radius: 4px;
  background: transparent; 
  color: inherit;
  line-height: 1.8;
  text-align: center;
  vertical-align: middle;
}

#hotkeysList li {
  margin-bottom: 1px;
}
