/* ===== RESET & BASE ===== */
* { margin:0; padding:0; box-sizing:border-box; }
:root {
  --neon-pink: #ff2d95;
  --neon-cyan: #00f0ff;
  --neon-purple: #b026ff;
  --neon-yellow: #ffe600;
  --dark-bg: #0b0a1a;
  --panel-bg: rgba(18,16,40,0.88);
  --font-display: 'Orbitron', monospace;
  --font-body: 'Rajdhani', sans-serif;
  --shadow-neon: 0 0 40px rgba(255,45,149,0.15);
}
html, body { height:100%; background:var(--dark-bg); color:#e0e8f0; font-family:var(--font-body); overflow:hidden; }
body::before {
  content:''; position:fixed; inset:0; background-image:linear-gradient(rgba(0,240,255,0.03) 1px,transparent 1px),linear-gradient(90deg,rgba(0,240,255,0.03) 1px,transparent 1px); background-size:40px 40px; pointer-events:none; z-index:0;
}
body::after {
  content:''; position:fixed; inset:0; background:repeating-linear-gradient(0deg, rgba(0,0,0,0) 0px, rgba(0,0,0,0) 2px, rgba(0,0,0,0.06) 2px, rgba(0,0,0,0.06) 4px); pointer-events:none; z-index:9999;
}
::-webkit-scrollbar { width:5px; }
::-webkit-scrollbar-track { background:rgba(0,0,0,0.3); }
::-webkit-scrollbar-thumb { background:var(--neon-cyan); border-radius:10px; box-shadow:0 0 20px var(--neon-cyan); }
#app { position:relative; z-index:1; display:flex; flex-direction:column; height:100vh; max-height:100vh; background:radial-gradient(ellipse at 50% 0%, rgba(176,38,255,0.06) 0%, transparent 70%), radial-gradient(ellipse at 80% 100%, rgba(0,240,255,0.04) 0%, transparent 50%); }

/* ===== LOGIN ===== */
#login-screen { display:none; flex-direction:column; align-items:center; justify-content:center; height:100vh; padding:2rem; text-align:center; animation:fadeIn 0.6s ease; }
#login-screen.active { display:flex; }
.login-box { background:var(--panel-bg); border:1px solid rgba(0,240,255,0.2); border-radius:24px; padding:3rem 3.5rem; max-width:440px; width:100%; box-shadow:var(--shadow-neon), inset 0 0 80px rgba(0,240,255,0.02); backdrop-filter:blur(12px); position:relative; overflow:hidden; }
.login-box::before { content:''; position:absolute; top:-2px; left:-2px; right:-2px; bottom:-2px; border-radius:24px; background:linear-gradient(45deg,var(--neon-pink),var(--neon-cyan),var(--neon-purple)); z-index:-1; opacity:0.25; filter:blur(8px); animation:borderPulse 3s ease-in-out infinite; }
@keyframes borderPulse { 0%,100%{opacity:0.2;} 50%{opacity:0.5;} }
@keyframes fadeIn { 0%{opacity:0;transform:scale(0.97);} 100%{opacity:1;transform:scale(1);} }
.login-box .logo { font-family:var(--font-display); font-size:2.6rem; font-weight:900; background:linear-gradient(135deg,var(--neon-cyan),var(--neon-purple)); -webkit-background-clip:text; -webkit-text-fill-color:transparent; text-shadow:0 0 60px rgba(0,240,255,0.15); letter-spacing:4px; }
.login-box .sub { font-size:0.85rem; color:rgba(255,255,255,0.35); letter-spacing:6px; text-transform:uppercase; margin-bottom:2rem; font-weight:300; }
.login-box .sub i { color:var(--neon-pink); margin:0 6px; }
.login-box .field { margin-bottom:1rem; text-align:left; }
.login-box .field label { display:block; font-size:0.75rem; text-transform:uppercase; letter-spacing:2px; color:rgba(255,255,255,0.4); margin-bottom:0.3rem; }
.login-box .field input { width:100%; padding:0.8rem 1.2rem; background:rgba(0,0,0,0.5); border:1px solid rgba(0,240,255,0.1); border-radius:12px; color:#fff; font-size:1rem; font-family:var(--font-body); transition:all 0.3s; outline:none; }
.login-box .field input:focus { border-color:var(--neon-cyan); box-shadow:0 0 30px rgba(0,240,255,0.06); }
.login-box .btn-login { margin-top:0.5rem; width:100%; padding:0.9rem; background:linear-gradient(135deg,var(--neon-pink),var(--neon-purple)); border:none; border-radius:12px; color:#fff; font-family:var(--font-display); font-size:1rem; font-weight:700; letter-spacing:3px; cursor:pointer; transition:all 0.3s; text-transform:uppercase; box-shadow:0 0 40px rgba(255,45,149,0.15); }
.login-box .btn-login:hover { transform:scale(1.02); box-shadow:0 0 60px rgba(255,45,149,0.3); }
.login-box .btn-login:active { transform:scale(0.97); }
.login-box .login-links { display:flex; justify-content:space-between; margin-top:1rem; font-size:0.8rem; }
.login-box .login-links a { color:rgba(255,255,255,0.3); text-decoration:none; cursor:pointer; transition:color 0.2s; font-weight:500; letter-spacing:0.5px; }
.login-box .login-links a:hover { color:var(--neon-cyan); }
.login-error, .login-success { font-size:0.85rem; margin-top:0.6rem; min-height:1.4rem; opacity:0; transition:opacity 0.3s; }
.login-error { color:var(--neon-pink); }
.login-success { color:var(--neon-cyan); }
.login-error.show, .login-success.show { opacity:1; }

/* ===== MAIN APP ===== */
#main-app { display:none; flex-direction:column; height:100vh; opacity:0; transition:opacity 0.5s ease; }
#main-app.active { display:flex; opacity:1; }

/* TOPBAR */
.topbar { display:flex; align-items:center; justify-content:space-between; padding:0.5rem 1.5rem; background:rgba(11,10,26,0.9); backdrop-filter:blur(12px); border-bottom:1px solid rgba(0,240,255,0.06); flex-shrink:0; min-height:56px; z-index:10; gap:0.8rem; flex-wrap:wrap; }
.topbar .brand { font-family:var(--font-display); font-size:1.2rem; font-weight:900; background:linear-gradient(135deg,var(--neon-cyan),var(--neon-purple)); -webkit-background-clip:text; -webkit-text-fill-color:transparent; letter-spacing:2px; display:flex; align-items:center; gap:8px; flex-shrink:0; }
.topbar .brand i { font-size:1.3rem; color:var(--neon-pink); -webkit-text-fill-color:var(--neon-pink); }
.topbar .search-wrap { flex:1; max-width:420px; min-width:140px; position:relative; }
.topbar .search-wrap input { width:100%; padding:0.5rem 1rem 0.5rem 2.4rem; background:rgba(0,0,0,0.4); border:1px solid rgba(0,240,255,0.06); border-radius:30px; color:#fff; font-family:var(--font-body); font-size:0.85rem; outline:none; transition:all 0.3s; }
.topbar .search-wrap input:focus { border-color:rgba(0,240,255,0.2); box-shadow:0 0 30px rgba(0,240,255,0.03); }
.topbar .search-wrap input::placeholder { color:rgba(255,255,255,0.15); letter-spacing:1px; }
.topbar .search-wrap i { position:absolute; left:12px; top:50%; transform:translateY(-50%); color:rgba(255,255,255,0.15); }
.topbar .search-results { position:absolute; top:100%; left:0; right:0; background:var(--panel-bg); border:1px solid rgba(0,240,255,0.06); border-radius:12px; margin-top:6px; max-height:300px; overflow-y:auto; backdrop-filter:blur(20px); display:none; z-index:50; padding:0.5rem 0; }
.topbar .search-results.active { display:block; }
.topbar .search-results .result-item { padding:0.5rem 1.2rem; cursor:pointer; font-size:0.85rem; display:flex; align-items:center; gap:10px; transition:background 0.15s; color:rgba(255,255,255,0.7); }
.topbar .search-results .result-item:hover { background:rgba(0,240,255,0.04); }
.topbar .search-results .result-item .tag { font-size:0.6rem; text-transform:uppercase; letter-spacing:2px; color:rgba(255,255,255,0.15); background:rgba(255,255,255,0.04); padding:0.1rem 0.6rem; border-radius:10px; }
.topbar .search-results .result-item i { color:var(--neon-cyan); opacity:0.4; width:18px; }
.topbar .right-group { display:flex; align-items:center; gap:1rem; flex-shrink:0; }
.topbar .right-group .notif-btn { background:transparent; border:none; color:rgba(255,255,255,0.3); font-size:1.1rem; cursor:pointer; position:relative; padding:4px 8px; border-radius:8px; transition:all 0.2s; }
.topbar .right-group .notif-btn:hover { color:#fff; background:rgba(255,255,255,0.03); }
.topbar .right-group .notif-btn .badge { position:absolute; top:-4px; right:-4px; background:var(--neon-pink); color:#fff; font-size:0.55rem; font-weight:700; padding:0.1rem 0.45rem; border-radius:10px; min-width:18px; text-align:center; font-family:var(--font-body); }
.topbar .right-group .username { color:rgba(255,255,255,0.5); font-weight:600; font-size:0.85rem; letter-spacing:0.5px; }
.topbar .right-group .username i { color:var(--neon-cyan); margin-right:4px; }
.topbar .right-group .btn-logout { background:transparent; border:1px solid rgba(255,45,149,0.2); color:var(--neon-pink); padding:0.3rem 1.2rem; border-radius:20px; font-family:var(--font-body); font-weight:600; cursor:pointer; transition:all 0.3s; font-size:0.75rem; letter-spacing:1px; }
.topbar .right-group .btn-logout:hover { background:rgba(255,45,149,0.1); box-shadow:0 0 30px rgba(255,45,149,0.08); }

/* NAV */
.nav-tabs { display:flex; gap:0.1rem; padding:0 1.5rem; background:rgba(11,10,26,0.5); border-bottom:1px solid rgba(0,240,255,0.04); flex-shrink:0; overflow-x:auto; }
.nav-tabs .tab { padding:0.6rem 1.4rem; font-family:var(--font-body); font-weight:600; font-size:0.8rem; letter-spacing:2px; text-transform:uppercase; color:rgba(255,255,255,0.25); cursor:pointer; border-bottom:2px solid transparent; transition:all 0.3s; white-space:nowrap; background:transparent; border-top:none; border-left:none; border-right:none; }
.nav-tabs .tab:hover { color:rgba(255,255,255,0.6); }
.nav-tabs .tab.active { color:var(--neon-cyan); border-bottom-color:var(--neon-cyan); box-shadow:0 4px 30px rgba(0,240,255,0.04); }
.nav-tabs .tab i { margin-right:6px; }

/* CONTENT */
.content-area { flex:1; overflow:hidden; position:relative; padding:1.2rem 1.8rem 1.8rem 1.8rem; }
.page { display:none; height:100%; overflow-y:auto; animation:fadeSlide 0.3s ease; }
.page.active { display:block; }
@keyframes fadeSlide { 0%{opacity:0;transform:translateY(10px);} 100%{opacity:1;transform:translateY(0);} }

/* DASHBOARD */
.dash-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(160px,1fr)); gap:1rem; margin-bottom:1.8rem; }
.stat-card { background:var(--panel-bg); border:1px solid rgba(0,240,255,0.06); border-radius:14px; padding:1.2rem 1.5rem; backdrop-filter:blur(8px); }
.stat-card .num { font-family:var(--font-display); font-size:2rem; font-weight:700; color:var(--neon-cyan); text-shadow:0 0 30px rgba(0,240,255,0.08); }
.stat-card .label { font-size:0.7rem; text-transform:uppercase; letter-spacing:2px; color:rgba(255,255,255,0.25); margin-top:0.1rem; }
.stat-card .label i { color:var(--neon-pink); margin-right:4px; }
.section-title { font-family:var(--font-display); font-size:1rem; font-weight:700; letter-spacing:2px; color:rgba(255,255,255,0.6); margin-bottom:1rem; display:flex; align-items:center; gap:10px; }
.section-title i { color:var(--neon-pink); opacity:0.7; }
.section-title .badge { font-size:0.55rem; background:rgba(0,240,255,0.06); color:var(--neon-cyan); padding:0.1rem 0.7rem; border-radius:20px; font-weight:400; letter-spacing:1px; }
.playlist-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(180px,1fr)); gap:0.8rem; margin-bottom:1.5rem; }
.playlist-card { background:var(--panel-bg); border:1px solid rgba(0,240,255,0.05); border-radius:12px; padding:1rem 1.2rem; cursor:pointer; transition:all 0.25s; backdrop-filter:blur(8px); }
.playlist-card:hover { border-color:rgba(0,240,255,0.15); transform:translateY(-2px); box-shadow:0 8px 40px rgba(0,0,0,0.2); }
.playlist-card .name { font-weight:700; font-size:0.95rem; color:#fff; display:flex; align-items:center; gap:6px; }
.playlist-card .name i { color:var(--neon-purple); font-size:0.8rem; }
.playlist-card .meta { font-size:0.7rem; color:rgba(255,255,255,0.25); margin-top:0.2rem; letter-spacing:0.5px; }
.playlist-card .meta span { color:var(--neon-cyan); }
.empty-state { text-align:center; padding:2.5rem 1rem; color:rgba(255,255,255,0.15); }
.empty-state i { font-size:2.5rem; margin-bottom:0.8rem; color:rgba(255,255,255,0.04); }
.empty-state p { font-size:0.9rem; letter-spacing:1px; }

/* RANDOM */
.random-params { display:flex; flex-wrap:wrap; gap:0.8rem; background:var(--panel-bg); border-radius:14px; padding:1.2rem 1.5rem; border:1px solid rgba(0,240,255,0.04); margin-bottom:1rem; align-items:flex-end; }
.random-params .field { display:flex; flex-direction:column; gap:0.15rem; }
.random-params .field label { font-size:0.6rem; text-transform:uppercase; letter-spacing:2px; color:rgba(255,255,255,0.15); }
.random-params .field input, .random-params .field select { padding:0.35rem 0.9rem; background:rgba(0,0,0,0.4); border:1px solid rgba(0,240,255,0.04); border-radius:8px; color:#fff; font-family:var(--font-body); outline:none; min-width:100px; font-size:0.85rem; }
.random-params .field input:focus, .random-params .field select:focus { border-color:rgba(0,240,255,0.15); }
.random-params .btn { margin-left:auto; }

/* BUTTONS */
.btn { padding:0.45rem 1.4rem; border-radius:30px; border:none; font-family:var(--font-body); font-weight:600; font-size:0.8rem; letter-spacing:1px; cursor:pointer; transition:all 0.25s; display:inline-flex; align-items:center; gap:6px; text-transform:uppercase; }
.btn-primary { background:linear-gradient(135deg,var(--neon-pink),var(--neon-purple)); color:#fff; box-shadow:0 0 30px rgba(255,45,149,0.08); }
.btn-primary:hover { transform:scale(1.03); box-shadow:0 0 50px rgba(255,45,149,0.15); }
.btn-secondary { background:rgba(0,240,255,0.05); color:var(--neon-cyan); border:1px solid rgba(0,240,255,0.08); }
.btn-secondary:hover { background:rgba(0,240,255,0.1); }
.btn-outline { background:transparent; color:rgba(255,255,255,0.3); border:1px solid rgba(255,255,255,0.06); }
.btn-outline:hover { border-color:rgba(255,255,255,0.15); color:#fff; }
.btn-danger { background:rgba(255,45,149,0.08); color:var(--neon-pink); border:1px solid rgba(255,45,149,0.08); }
.btn-danger:hover { background:rgba(255,45,149,0.15); }
.btn-sm { padding:0.25rem 1rem; font-size:0.7rem; }
.btn-xs { padding:0.15rem 0.7rem; font-size:0.6rem; letter-spacing:1px; }

/* LIBRARY TABLE */
.lib-toolbar { display:flex; flex-wrap:wrap; gap:0.8rem; margin-bottom:1rem; align-items:center; justify-content:space-between; }
.lib-toolbar .left { display:flex; gap:0.6rem; flex-wrap:wrap; }
.lib-toolbar .right { display:flex; gap:0.6rem; align-items:center; font-size:0.75rem; color:rgba(255,255,255,0.15); }
.song-table-wrap { background:var(--panel-bg); border-radius:14px; border:1px solid rgba(0,240,255,0.04); overflow:auto; backdrop-filter:blur(8px); max-height:calc(100vh - 380px); }
.song-table { width:100%; border-collapse:collapse; font-size:0.85rem; }
.song-table th { text-align:left; padding:0.7rem 1.2rem; font-weight:600; text-transform:uppercase; letter-spacing:2px; font-size:0.6rem; color:rgba(255,255,255,0.2); border-bottom:1px solid rgba(0,240,255,0.04); background:rgba(0,0,0,0.2); position:sticky; top:0; z-index:2; }
.song-table td { padding:0.6rem 1.2rem; border-bottom:1px solid rgba(0,240,255,0.02); vertical-align:middle; }
.song-table tr:hover td { background:rgba(0,240,255,0.01); }
.song-table .song-title { font-weight:600; color:#fff; }
.song-table .song-artist { color:rgba(255,255,255,0.4); }
.song-table .song-actions { display:flex; gap:4px; justify-content:flex-end; }
.song-table .song-actions button { background:transparent; border:none; color:rgba(255,255,255,0.15); cursor:pointer; padding:3px 8px; border-radius:6px; transition:all 0.2s; font-size:0.85rem; }
.song-table .song-actions button:hover { color:var(--neon-cyan); background:rgba(0,240,255,0.04); }
.song-table .song-actions button.del:hover { color:var(--neon-pink); background:rgba(255,45,149,0.04); }
.song-table .uploader-tag { font-size:0.6rem; color:rgba(255,255,255,0.12); background:rgba(255,255,255,0.02); padding:0.1rem 0.6rem; border-radius:10px; letter-spacing:0.5px; }

/* UPLOAD */
.upload-area { display:grid; grid-template-columns:1fr 1fr; gap:1.5rem; }
@media (max-width:760px){ .upload-area { grid-template-columns:1fr; } }
.upload-box { background:var(--panel-bg); border:1px solid rgba(0,240,255,0.04); border-radius:14px; padding:1.8rem; backdrop-filter:blur(8px); min-height:200px; display:flex; flex-direction:column; align-items:center; justify-content:center; text-align:center; transition:all 0.3s; border-style:dashed; border-color:rgba(0,240,255,0.06); }
.upload-box.dragover { border-color:var(--neon-cyan); background:rgba(0,240,255,0.02); }
.upload-box i { font-size:2.5rem; color:rgba(255,255,255,0.05); margin-bottom:0.6rem; }
.upload-box .title { font-weight:700; font-size:1rem; color:rgba(255,255,255,0.5); }
.upload-box .sub { font-size:0.75rem; color:rgba(255,255,255,0.12); margin-top:0.1rem; }
.upload-box .btn { margin-top:0.8rem; }
.upload-box input[type="file"] { display:none; }
.upload-progress { margin-top:0.8rem; width:100%; height:3px; background:rgba(255,255,255,0.04); border-radius:10px; overflow:hidden; }
.upload-progress .bar { height:100%; width:0%; background:linear-gradient(90deg,var(--neon-pink),var(--neon-cyan)); border-radius:10px; transition:width 0.3s; }
.upload-status { font-size:0.75rem; color:rgba(255,255,255,0.15); margin-top:0.3rem; min-height:1.2rem; }

/* PLAYER */
.player-bar { flex-shrink:0; background:rgba(11,10,26,0.94); backdrop-filter:blur(16px); border-top:1px solid rgba(0,240,255,0.04); padding:0.6rem 1.5rem; display:flex; align-items:center; gap:1.2rem; flex-wrap:wrap; z-index:10; min-height:68px; }
.player-bar .now-playing { display:flex; align-items:center; gap:0.8rem; min-width:150px; }
.player-bar .now-playing .art { width:40px; height:40px; border-radius:8px; background:linear-gradient(135deg,var(--neon-purple),var(--neon-pink)); display:flex; align-items:center; justify-content:center; font-size:1.1rem; color:#fff; box-shadow:0 0 30px rgba(255,45,149,0.08); flex-shrink:0; }
.player-bar .now-playing .info .track { font-weight:700; font-size:0.85rem; color:#fff; }
.player-bar .now-playing .info .artist { font-size:0.7rem; color:rgba(255,255,255,0.2); }
.player-bar .controls { display:flex; align-items:center; gap:0.4rem; flex:1; justify-content:center; }
.player-bar .controls button { background:transparent; border:none; color:rgba(255,255,255,0.3); font-size:1rem; cursor:pointer; padding:4px 8px; border-radius:8px; transition:all 0.2s; }
.player-bar .controls button:hover { color:#fff; background:rgba(255,255,255,0.03); }
.player-bar .controls .play-btn { font-size:1.6rem; color:var(--neon-cyan); text-shadow:0 0 30px rgba(0,240,255,0.08); }
.player-bar .controls .play-btn:hover { transform:scale(1.04); }
.player-bar .progress-wrap { flex:2; min-width:100px; display:flex; align-items:center; gap:0.6rem; }
.player-bar .progress-wrap .time { font-size:0.6rem; color:rgba(255,255,255,0.15); font-family:var(--font-display); min-width:32px; }
.player-bar .progress-wrap .track-progress { flex:1; height:3px; background:rgba(255,255,255,0.04); border-radius:10px; cursor:pointer; position:relative; }
.player-bar .progress-wrap .track-progress .fill { height:100%; width:0%; background:linear-gradient(90deg,var(--neon-pink),var(--neon-cyan)); border-radius:10px; box-shadow:0 0 20px rgba(0,240,255,0.06); transition:width 0.05s linear; }
.vu-meter { display:flex; align-items:center; gap:2px; height:24px; margin-left:0.3rem; }
.vu-meter .bar { width:3px; height:6px; background:rgba(0,240,255,0.04); border-radius:2px; transition:height 0.06s ease; }
.vu-meter .bar.active { background:var(--neon-cyan); box-shadow:0 0 8px var(--neon-cyan); }
.vu-meter .bar.active.hot { background:var(--neon-pink); box-shadow:0 0 8px var(--neon-pink); }

/* MODAL */
.modal-overlay { display:none; position:fixed; inset:0; background:rgba(0,0,0,0.7); backdrop-filter:blur(8px); z-index:100; align-items:center; justify-content:center; padding:2rem; }
.modal-overlay.active { display:flex; }
.modal-box { background:var(--panel-bg); border:1px solid rgba(0,240,255,0.06); border-radius:18px; padding:2rem 2.2rem; max-width:600px; width:100%; max-height:80vh; overflow-y:auto; box-shadow:var(--shadow-neon); animation:fadeSlide 0.25s ease; }
.modal-box .modal-title { font-family:var(--font-display); font-size:1.1rem; font-weight:700; color:#fff; margin-bottom:1rem; display:flex; align-items:center; gap:8px; }
.modal-box .modal-title i { color:var(--neon-purple); }
.modal-box .close-modal { margin-left:auto; background:transparent; border:none; color:rgba(255,255,255,0.15); font-size:1.2rem; cursor:pointer; padding:0 8px; }
.modal-box .close-modal:hover { color:#fff; }
.modal-box .modal-body { margin-top:0.3rem; }
.modal-box .modal-body .pl-song { display:flex; justify-content:space-between; align-items:center; padding:0.5rem 0; border-bottom:1px solid rgba(255,255,255,0.02); }
.modal-box .modal-body .pl-song .name { font-weight:500; font-size:0.9rem; }
.modal-box .modal-body .pl-song .artist { color:rgba(255,255,255,0.25); font-size:0.75rem; }
.modal-box .modal-body .pl-song .remove-btn { background:transparent; border:none; color:rgba(255,45,149,0.2); cursor:pointer; font-size:0.85rem; padding:3px 8px; border-radius:6px; transition:all 0.2s; }
.modal-box .modal-body .pl-song .remove-btn:hover { color:var(--neon-pink); background:rgba(255,45,149,0.04); }
.modal-box .modal-body .add-song-row { display:flex; gap:0.6rem; margin-top:1rem; }
.modal-box .modal-body .add-song-row select { flex:1; padding:0.5rem 1rem; background:rgba(0,0,0,0.4); border:1px solid rgba(0,240,255,0.06); border-radius:10px; color:#fff; font-family:var(--font-body); outline:none; }
.modal-box .modal-body .add-song-row select:focus { border-color:rgba(0,240,255,0.12); }
.modal-box .modal-body .share-row { display:flex; gap:0.6rem; margin-top:0.8rem; align-items:center; }
.modal-box .modal-body .share-row input { flex:1; padding:0.5rem 1rem; background:rgba(0,0,0,0.4); border:1px solid rgba(0,240,255,0.06); border-radius:10px; color:#fff; font-family:var(--font-body); outline:none; font-size:0.85rem; }
.modal-box .modal-body .share-row input:focus { border-color:rgba(0,240,255,0.12); }
.modal-box .modal-body .shared-with { display:flex; flex-wrap:wrap; gap:0.4rem; margin-top:0.5rem; }
.modal-box .modal-body .shared-with .pill { background:rgba(0,240,255,0.04); border:1px solid rgba(0,240,255,0.06); border-radius:20px; padding:0.1rem 0.8rem; font-size:0.7rem; color:rgba(255,255,255,0.3); display:inline-flex; align-items:center; gap:6px; }
.modal-box .modal-body .shared-with .pill i { color:var(--neon-pink); cursor:pointer; font-size:0.6rem; }

/* MESSAGES */
.msg-list { display:flex; flex-direction:column; gap:0.6rem; max-height:calc(100vh - 480px); overflow-y:auto; }
.msg-item { background:var(--panel-bg); border:1px solid rgba(0,240,255,0.03); border-radius:12px; padding:0.8rem 1.2rem; transition:all 0.2s; }
.msg-item:hover { border-color:rgba(0,240,255,0.06); }
.msg-item .msg-header { display:flex; justify-content:space-between; font-size:0.75rem; color:rgba(255,255,255,0.2); }
.msg-item .msg-header .from { color:var(--neon-cyan); font-weight:600; }
.msg-item .msg-body { margin-top:0.2rem; font-size:0.9rem; color:rgba(255,255,255,0.6); }
.msg-item .msg-body .preview { color:rgba(255,255,255,0.2); font-size:0.8rem; }
.msg-item.unread { border-left:2px solid var(--neon-cyan); }
.msg-compose { background:var(--panel-bg); border:1px solid rgba(0,240,255,0.04); border-radius:14px; padding:1.2rem 1.5rem; margin-bottom:1.2rem; }
.msg-compose .row { display:flex; gap:0.6rem; flex-wrap:wrap; margin-bottom:0.6rem; }
.msg-compose .row input, .msg-compose .row textarea { flex:1; padding:0.5rem 1rem; background:rgba(0,0,0,0.4); border:1px solid rgba(0,240,255,0.04); border-radius:10px; color:#fff; font-family:var(--font-body); outline:none; font-size:0.85rem; min-width:120px; }
.msg-compose .row textarea { min-height:60px; resize:vertical; }
.msg-compose .row input:focus, .msg-compose .row textarea:focus { border-color:rgba(0,240,255,0.1); }

/* USERS */
.user-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(160px,1fr)); gap:0.8rem; max-height:calc(100vh - 350px); overflow-y:auto; }
.user-card { background:var(--panel-bg); border:1px solid rgba(0,240,255,0.03); border-radius:12px; padding:1rem 1.2rem; text-align:center; transition:all 0.25s; }
.user-card:hover { border-color:rgba(0,240,255,0.06); }
.user-card .avatar { font-size:2rem; color:rgba(255,255,255,0.05); margin-bottom:0.2rem; }
.user-card .uname { font-weight:600; font-size:0.9rem; color:#fff; }
.user-card .joined { font-size:0.6rem; color:rgba(255,255,255,0.1); letter-spacing:1px; }
.user-card .actions { margin-top:0.5rem; display:flex; gap:0.3rem; justify-content:center; flex-wrap:wrap; }

/* RESPONSIVE */
@media (max-width:700px) {
  .topbar { padding:0.4rem 0.8rem; gap:0.4rem; }
  .topbar .brand { font-size:0.9rem; }
  .topbar .search-wrap { max-width:100%; min-width:80px; order:10; flex-basis:100%; }
  .topbar .right-group .username { display:none; }
  .nav-tabs { padding:0 0.5rem; gap:0; }
  .nav-tabs .tab { padding:0.4rem 0.8rem; font-size:0.65rem; letter-spacing:1px; }
  .nav-tabs .tab i { margin-right:3px; }
  .content-area { padding:0.8rem; }
  .login-box { padding:2rem 1.5rem; }
  .login-box .logo { font-size:2rem; }
  .player-bar { padding:0.4rem 0.8rem; gap:0.5rem; }
  .player-bar .now-playing { min-width:100px; }
  .player-bar .now-playing .art { width:32px; height:32px; font-size:0.8rem; }
  .player-bar .now-playing .info .track { font-size:0.75rem; }
  .player-bar .controls .play-btn { font-size:1.2rem; }
  .dash-grid { grid-template-columns:1fr 1fr; gap:0.6rem; }
  .stat-card { padding:0.8rem 1rem; }
  .stat-card .num { font-size:1.5rem; }
  .playlist-grid { grid-template-columns:1fr 1fr; }
  .upload-area { grid-template-columns:1fr; }
  .vu-meter { display:none; }
  .random-params { flex-direction:column; align-items:stretch; }
  .random-params .btn { margin-left:0; }
  .modal-box { padding:1.2rem 1rem; margin:1rem; }
  .song-table th, .song-table td { padding:0.4rem 0.6rem; font-size:0.7rem; }
  .song-table .song-actions button { padding:2px 4px; font-size:0.7rem; }
  .msg-compose .row { flex-direction:column; }
  .user-grid { grid-template-columns:1fr 1fr; }
}
@media (max-width:450px) {
  .dash-grid { grid-template-columns:1fr; }
  .playlist-grid { grid-template-columns:1fr; }
  .user-grid { grid-template-columns:1fr; }
}
.text-cyber { color:var(--neon-cyan); }
.text-pink { color:var(--neon-pink); }
.text-muted { color:rgba(255,255,255,0.15); }
.mt-1 { margin-top:0.8rem; }
.mb-1 { margin-bottom:0.8rem; }
.flex-between { display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:0.6rem; }