@keyframes fadeIn{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn .3s ease-out}.video-player-float{width:240px;height:180px;background:#000;border-radius:12px;overflow:hidden;position:relative;box-shadow:0 8px 24px #0009,inset 0 0 0 1px #ffffff0d;transition:transform .25s ease,box-shadow .25s ease}.video-player-float:hover{transform:translateY(-4px);box-shadow:0 14px 32px #000c,inset 0 0 0 1px #ffffff14}.video-player-float iframe{width:100%;height:135px;border:none}.video-info{position:absolute;bottom:0;left:0;width:100%;background:linear-gradient(to top,#000000d9,#0000008c,#0000);color:#fff;padding:8px 10px;font-size:13px;z-index:10;display:flex;justify-content:space-between;align-items:center;pointer-events:none}.close-btn{pointer-events:auto;background:#ffffff1f;border:none;color:#fff;width:22px;height:22px;border-radius:50%;cursor:pointer;font-size:13px;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.close-btn:hover{background:#ffffff47;transform:scale(1.1)}.close-btn:active{transform:scale(.95)}.video-placeholder{width:100%;height:100%;display:flex;justify-content:center;align-items:center;background:#222}.placeholder-text{color:#fff;text-align:center;font-size:1rem;font-weight:700;animation:none!important;transition:none!important}@keyframes playerPulse{0%{opacity:.45}50%{opacity:1}to{opacity:.45}}.video-player-float.placeholder{background:linear-gradient(135deg,#111,#1a1a1a)}.listener-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:8px 12px;background:#0009;color:#fff;border-radius:8px}.current-singer{font-size:14px;white-space:nowrap}.listen-btn{flex-shrink:0;padding:6px 12px;border-radius:6px;border:none;cursor:pointer}.admin-btn,.admin-header button,.admin-pagination button{margin-left:6px;padding:6px 10px;border-radius:6px;border:none;cursor:pointer;background-color:#1976d2;color:#fff;font-size:13px;font-weight:500;transition:background .2s}.admin-btn:hover,.admin-header button:hover,.admin-pagination button:hover:not(:disabled){background-color:#1565c0}.admin-pagination button:disabled{opacity:.5;cursor:default}.admin-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:1000;display:flex;justify-content:center;align-items:center}.admin-header{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;border-bottom:1px solid #ddd;background-color:#f5f5f5}.admin-header h3{margin:0;font-size:16px;font-weight:600}.admin-table-wrapper{flex:1;overflow:auto;padding:10px}.admin-table{width:100%;border-collapse:collapse;font-size:13px}.admin-table th,.admin-table td{padding:6px 8px;border-bottom:1px solid #eee;text-align:left;white-space:nowrap;color:#222}.admin-table th{background:#f5f5f5;position:sticky;top:0;z-index:1;font-weight:600}.admin-table tr:hover{background:#f0f7ff}.admin-pagination{display:flex;justify-content:center;align-items:center;margin-top:8px;gap:6px}.admin-error{font-size:12px;color:red;margin-top:4px}.admin-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#0006;z-index:9999;display:flex;justify-content:center;align-items:center}.admin-modal{background-color:#e3f2fd;padding:12px;border-radius:8px;width:700px;max-width:90%;box-shadow:0 2px 10px #0000004d;color:#0d47a1}.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.admin-header h3{margin:0;font-size:1rem;color:#0d47a1}.admin-btn{background-color:#1976d2;color:#fff;border:none;border-radius:4px;padding:4px 8px;cursor:pointer;font-size:.85rem;transition:background-color .2s}.admin-btn:hover:not(:disabled){background-color:#1565c0}.admin-btn:disabled{background-color:#90caf9;cursor:not-allowed}.admin-search{display:flex;gap:6px;flex-wrap:wrap;align-items:center;margin-bottom:6px}.admin-search input,.admin-search select{padding:2px 6px;font-size:.85rem;border-radius:4px;border:1px solid #64b5f6;background-color:#bbdefb;color:#0d47a1;width:auto;flex:none}.admin-search input[type=text],.admin-search select{min-width:120px}.admin-search input.keyword{min-width:180px}.admin-table-wrapper{overflow-x:auto}.admin-table th,.admin-table td{padding:6px 8px;text-align:left;border:1px solid #90caf9;font-size:.85rem;vertical-align:top}.admin-table th{background-color:#64b5f6;color:#fff}.admin-pagination{margin-top:6px;display:flex;flex-wrap:wrap;gap:4px;justify-content:center}.admin-level-panel{display:flex;flex-direction:column;gap:10px;font-size:14px}.level-toolbar{display:flex;gap:6px}.level-toolbar input{flex:1;padding:6px 8px;border-radius:4px;border:1px solid #ccc}.level-toolbar button{padding:6px 12px;border-radius:4px;border:none;background:#444;color:#fff;cursor:pointer}.level-toolbar button:hover{background:#222}.level-table{width:100%;border-collapse:collapse}.level-table th,.level-table td{padding:6px 8px;border-bottom:1px solid #ddd;text-align:left}.level-table th{background:#f3f3f3;font-weight:700}.level-table tr:hover{background:#fafafa}.level-table select{padding:4px 6px;border-radius:4px;border:1px solid #bbb;background:#fff;cursor:pointer}.level-table select:disabled{background:#eee;color:#888;cursor:not-allowed}.admin-level-panel>div{color:#666}.admin-table select{padding:4px 6px;border-radius:4px;border:1px solid #bbb}.admin-table select:disabled{background:#eee;color:#999;cursor:not-allowed}.admin-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.admin-modal{background:#fff;border-radius:8px;width:80%;max-width:900px;max-height:80vh;overflow-y:auto;padding:16px;box-sizing:border-box}.admin-table-wrapper{overflow-y:auto;max-height:50vh;margin-bottom:10px}.admin-table{width:100%;border-collapse:collapse}.admin-table th,.admin-table td{padding:8px;border:1px solid #ccc;text-align:left}.admin-btn{padding:4px 8px;margin:2px;background:#1976d2;color:#fff;border:none;border-radius:4px;cursor:pointer}.admin-btn:disabled{background:#ccc;cursor:not-allowed}.admin-tool{position:relative;display:inline-block}.admin-tool .admin-btn{padding:4px 6px;font-size:14px;border-radius:6px;border:none;background-color:#1976d2;color:#fff;cursor:pointer;transition:background .2s}.admin-tool .admin-btn:hover{background-color:#1565c0}.admin-tool .admin-popup{position:absolute;bottom:36px;left:0;width:260px;max-height:360px;background:#fff;border-radius:10px;box-shadow:0 8px 24px #00000040;display:flex;flex-direction:column;overflow:hidden;z-index:999}.admin-tool .admin-tabs{display:flex;background:#f2f3f5;padding:4px;gap:4px}.admin-tool .admin-tabs button{flex:1;padding:4px 0;font-size:12px;border:none;background:transparent;cursor:pointer;color:#555;border-radius:4px;transition:background .2s}.admin-tool .admin-tabs button.active{background:#fff;font-weight:600;box-shadow:0 1px 4px #00000026}.admin-tool .admin-content{padding:6px;overflow:auto;background:#fafafa;flex:1}.admin-modal .admin-btn,.admin-modal .admin-header button,.admin-modal .admin-pagination button,.admin-tool .admin-tabs button.active{margin-left:6px;padding:6px 10px;border-radius:6px;border:none;cursor:pointer;background-color:#1976d2;color:#fff;font-size:13px;font-weight:500;transition:background .2s}.admin-modal .admin-btn:hover,.admin-modal .admin-header button:hover,.admin-modal .admin-pagination button:hover:not(:disabled),.admin-tool .admin-tabs button:hover{background-color:#1565c0}.admin-modal .admin-pagination button:disabled{opacity:.5;cursor:default}.admin-modal .admin-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:1000;display:flex;justify-content:center;align-items:center}.admin-modal{background:#fff;color:#222;width:90%;max-width:1000px;max-height:80%;border-radius:10px;display:flex;flex-direction:column;box-shadow:0 10px 30px #00000040;overflow:hidden;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.admin-modal .admin-header{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;border-bottom:1px solid #ddd;background-color:#f5f5f5}.admin-modal .admin-header h3{margin:0;font-size:16px;font-weight:600}.admin-modal .admin-table-wrapper{flex:1;overflow:auto;padding:10px}.admin-modal .admin-table{width:100%;border-collapse:collapse;font-size:13px}.admin-modal .admin-table th,.admin-modal .admin-table td{padding:6px 8px;border-bottom:1px solid #eee;text-align:left;white-space:nowrap;color:#222}.admin-modal .admin-table th{background:#f5f5f5;position:sticky;top:0;z-index:1;font-weight:600}.admin-modal .admin-table tr:hover{background:#f0f7ff}.admin-modal .admin-pagination{display:flex;justify-content:center;align-items:center;margin-top:8px;gap:6px}.admin-modal .admin-error{font-size:12px;color:red;margin-top:4px}.announcement-floating{position:fixed;left:20px;top:80px;width:320px;max-height:400px;background:#1e1e1e;color:#fff;border:1px solid #444;box-shadow:0 4px 12px #0009;padding:12px;z-index:1000;display:flex;flex-direction:column;border-radius:8px;cursor:grab;-webkit-user-select:none;user-select:none;font-family:sans-serif}.announcement-floating-header{display:flex;justify-content:space-between;align-items:center;font-weight:700;margin-bottom:8px;gap:6px}.announcement-floating-header button{background:#444;border:none;border-radius:4px;color:#fff;cursor:pointer;padding:2px 6px;font-size:.8rem;transition:background .2s}.announcement-floating-header button:hover{background:#666}.announcement-floating-content{flex:1;display:flex;flex-direction:column}.announcement-floating textarea,.announcement-content textarea{flex:1;width:100%;resize:vertical;background:#2b2b2b;color:#fff;border:1px solid #555;border-radius:6px;padding:6px 8px;box-sizing:border-box;font-family:inherit;font-size:.9rem}.announcement-floating pre,.announcement-text{flex:1;overflow-y:auto;white-space:pre-wrap;background:#111;color:#eee;padding:6px 8px;border-radius:6px;border:1px solid #444;box-sizing:border-box;font-family:inherit;font-size:.9rem}.announcement-floating .save-btn,.save-btn{margin-top:6px;width:100%;padding:6px;background:#4caf50;border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:700;transition:background .2s}.announcement-floating .save-btn:hover,.save-btn:hover{background:#3a7}.announcement-floating-content button{background:#555;color:#fff;border:none;border-radius:4px;cursor:pointer;padding:4px 8px;font-size:.85rem;transition:background .2s}.announcement-floating-content button:hover{background:#777}.announcement-floating-content div{display:flex;gap:6px;margin-top:6px;flex-wrap:wrap;justify-content:flex-start}.message-board-overlay{position:fixed;top:0;right:0;width:350px;height:100%;background:#0000004d;z-index:9999;display:flex;justify-content:flex-end}.message-board{width:100%;max-width:350px;height:100%;background:#1a1a1a;color:#fff;display:flex;flex-direction:column;padding:10px;box-shadow:-3px 0 5px #00000080}.message-board-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.close-btn{background:transparent;border:none;color:#fff;font-size:1.2rem;cursor:pointer}.message-input{display:flex;flex-direction:column;margin-bottom:10px}.message-input textarea{width:100%;resize:none;padding:6px;border-radius:4px;border:1px solid #444;background:#222;color:#fff}.message-input label{font-size:.8rem;margin:4px 0}.message-input button{margin-top:4px;padding:6px;border:none;border-radius:4px;background:#007bff;color:#fff;cursor:pointer}.message-list{flex:1;overflow-y:auto;padding-right:4px}.message-item{padding:6px;margin-bottom:6px;border-bottom:1px solid #333}.message-item.private{background:#333;color:#fc0}.message-meta{display:flex;justify-content:space-between;font-size:.75rem;margin-top:2px;color:#aaa}.delete-btn{background:transparent;border:none;color:#f55;cursor:pointer}body{margin:0;padding:0;background-color:#121212;color:#fff;font-family:Arial,sans-serif;min-height:100vh;box-sizing:border-box}.chat-title-bar{display:flex;align-items:center;justify-content:space-between;padding-right:6px}.announce-btn{background:transparent;border:none;font-size:1.2rem;cursor:pointer;color:#39f;transition:color .2s}.announce-btn:hover{color:#66b2ff}.chat-layout{width:100%;height:100vh;display:flex;gap:12px;padding:16px;box-sizing:border-box}.chat-left{flex:100;display:flex;flex-direction:column;gap:10px;height:100%}.chat-right{flex:0 0 330px;display:flex;flex-direction:column;gap:10px;height:100%}.message-list{flex:1 1 auto;min-height:200px;max-height:70vh;overflow-y:auto;display:flex;flex-direction:column;gap:4px;padding:10px;border-radius:4px;border:1px solid #555;background-color:#1a1a1a;word-break:break-word;white-space:pre-wrap;overflow-wrap:break-word}.chat-title{font-size:1.2rem;font-weight:700}.chat-toolbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.chat-toolbar button{margin-left:6px;padding:4px 8px;background:#6200ee;border:none;border-radius:4px;color:#fff;cursor:pointer}.video-request{display:flex;align-items:center;gap:6px}.video-request input{width:200px;padding:4px 6px;font-size:.85rem;background:#1a1a1a;border:1px solid #555;color:#fff;border-radius:4px}.message-row{display:flex;align-items:flex-end;margin-bottom:4px}.chat-message{max-width:75%;padding:4px 8px;border-radius:6px;font-size:.85rem;word-break:break-word;white-space:pre-wrap;overflow-wrap:break-word}.chat-message.self{background-color:#2a2a2a;margin-left:auto}.chat-message.other{background-color:#222}.chat-message.ai{background-color:#3d1a5f}.chat-message.system{font-weight:700;color:#f90;background:transparent}.message-avatar,.user-avatar{width:24px;height:24px;border-radius:50%;margin-right:6px;object-fit:cover}.chat-input{display:flex;flex-wrap:wrap;gap:4px;align-items:center}.chat-input input[type=text]{flex:1 1 auto;min-width:80px;padding:4px 6px;background:#1a1a1a;border:1px solid #555;color:#fff;border-radius:4px}.chat-input input[type=color]{flex:0 0 auto;width:24px;height:24px;padding:0;border:1px solid #ccc;border-radius:4px}.chat-input input,.chat-input select{padding:6px 8px;background:#1a1a1a;border:1px solid #555;color:#fff;border-radius:4px}.chat-input input{flex:1}.chat-input select{flex:0 0 140px}.chat-input button{padding:6px 12px;background:#6200ee;border:none;border-radius:4px;color:#fff;cursor:pointer}.youtube-container{flex:0 0 200px;background:#121212;border-radius:8px;overflow:hidden}.video-player-float iframe{width:100%;height:100%;border-radius:4px}.video-info{display:flex;justify-content:space-between;font-size:.8rem;margin-top:4px}.video-info button{background:none;border:none;color:#fff;cursor:pointer}.user-list{flex:1 1 auto;background-color:#1a1a1a;border-radius:4px;border:1px solid #555;overflow-y:auto}.user-list.collapsed{max-height:36px;overflow:hidden}.user-list-header{padding:6px 10px;background:#222;cursor:pointer;font-weight:700}.user-item{padding:6px 10px;border-bottom:1px solid #333;cursor:pointer;display:flex;align-items:center;gap:6px}.user-item:hover,.user-item.selected{background-color:#2a2a2a}.song-panel-inline{display:flex;flex-direction:column;gap:6px;background:#121212;border-radius:8px;padding:8px;border:1px solid #555}.song-panel-inline.collapsed .song-body{display:none}.song-header-inline{display:flex;justify-content:space-between;align-items:center;cursor:pointer}.song-header-inline h4{margin:0;font-size:.95rem}.song-header-inline button{background:none;border:none;color:#fff;cursor:pointer;font-size:.85rem}.exp-tip-inline,.levelup-tip-inline{display:inline-block;margin-left:5px;position:relative}.exp-tip,.levelup-tip{position:absolute;left:100%;top:-2px;font-size:.9em;color:#ff0;font-weight:700;animation:fadeUp 1s ease-out forwards}.levelup-tip{color:orange;font-size:1em}.kick-btn{background-color:#ff4d4f;color:#fff;border:none;border-radius:4px;padding:2px 6px;font-size:12px;cursor:pointer}.kick-btn:hover{background-color:#ff7875}@keyframes fadeUp{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-20px)}}@media (max-width: 480px){.chat-layout{flex-direction:column;padding:10px}.chat-right{width:100%}.user-list{max-height:120px}.video-player-float iframe{height:90px}.video-request input{width:140px}.chat-input input{flex:1 1 100%}.message-list{max-height:40vh;min-height:200px}.song-panel-inline{width:100%}}
