:root{--primary: #667eea;--primary-dark: #5568d3;--primary-light: #7c8ef0;--secondary: #764ba2;--accent: #f59e0b;--success: #22c55e;--warning: #f59e0b;--error: #ef4444;--info: #3b82f6;--gray-50: #f9fafb;--gray-100: #f3f4f6;--gray-200: #e5e7eb;--gray-300: #d1d5db;--gray-400: #9ca3af;--gray-500: #6b7280;--gray-600: #4b5563;--gray-700: #374151;--gray-750: #2d3748;--gray-800: #1f2937;--gray-900: #111827;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--spacing-2xl: 48px;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px rgba(0, 0, 0, .15);--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:var(--gray-900);color:var(--gray-100);line-height:1.5;overflow-x:hidden}*::-webkit-scrollbar{width:8px;height:8px}*::-webkit-scrollbar-track{background:var(--gray-800);border-radius:4px}*::-webkit-scrollbar-thumb{background:var(--gray-600);border-radius:4px;transition:background var(--transition-fast)}*::-webkit-scrollbar-thumb:hover{background:var(--gray-500)}*::-webkit-scrollbar-thumb:active{background:var(--gray-400)}*{scrollbar-width:thin;scrollbar-color:var(--gray-600) var(--gray-800)}.hidden{display:none!important}.text-center{text-align:center}.text-muted{color:var(--gray-400)}.text-success{color:var(--success)}.text-warning{color:var(--warning)}.text-error{color:var(--error)}.mb-sm{margin-bottom:var(--spacing-sm)}.mb-md{margin-bottom:var(--spacing-md)}.mb-lg{margin-bottom:var(--spacing-lg)}.mt-sm{margin-top:var(--spacing-sm)}.mt-md{margin-top:var(--spacing-md)}.mt-lg{margin-top:var(--spacing-lg)}.spinner{width:40px;height:40px;border:4px solid var(--gray-600);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}.empty-state{text-align:center;padding:var(--spacing-2xl);color:var(--gray-400)}.empty-state-icon{font-size:64px;margin-bottom:var(--spacing-md);opacity:.5}.empty-state-title{font-size:18px;font-weight:600;color:var(--gray-300);margin-bottom:var(--spacing-sm)}.empty-state-description{font-size:14px;color:var(--gray-400)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes scaleIn{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}@keyframes slideDown{0%{opacity:0;transform:translate(-50%) translateY(-20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.app-container{display:flex;flex-direction:column;height:100vh;overflow:hidden}.top-nav{background:var(--gray-800);border-bottom:1px solid var(--gray-700);padding:var(--spacing-md) var(--spacing-lg);display:flex;align-items:center;justify-content:space-between;height:64px;z-index:100}.nav-left{display:flex;align-items:center;gap:var(--spacing-lg)}.nav-logo{display:flex;align-items:center;gap:var(--spacing-sm);font-size:20px;font-weight:700;color:#fff;text-decoration:none}.nav-logo-icon{font-size:28px}.nav-room-info{display:flex;flex-direction:column;gap:2px}.nav-room-name{font-size:14px;font-weight:600;color:var(--gray-100)}.nav-room-status{font-size:12px;color:var(--gray-400);display:flex;align-items:center;gap:6px}.status-dot{width:8px;height:8px;border-radius:50%;background:var(--success);animation:pulse 2s infinite}.nav-right{display:flex;align-items:center;gap:var(--spacing-sm)}.main-content{display:flex;flex:1;overflow:hidden}.mixer-panel{width:320px;background:var(--gray-800);border-right:1px solid var(--gray-700);display:flex;flex-direction:column;overflow:hidden;box-shadow:2px 0 10px #0000004d;transition:transform var(--transition-base)}.mixer-panel.hidden{transform:translate(-100%)}.mixer-header{padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--gray-700);display:flex;align-items:center;justify-content:space-between;background:var(--gray-800)}.mixer-title{display:flex;align-items:center;gap:var(--spacing-sm);font-size:16px;font-weight:700;color:#fff}.mixer-title-icon{font-size:20px}.mixer-toggle-btn{width:32px;height:32px;border-radius:var(--radius-sm);background:transparent;color:var(--gray-400);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;transition:all var(--transition-base)}.mixer-toggle-btn:hover{background:var(--gray-700);color:#fff}.mixer-content{flex:1;overflow-y:auto;background:var(--gray-900)}.mixer-toggle-control{position:fixed;left:12px;top:76px;z-index:150;width:40px;height:40px;border-radius:var(--radius-md);background:linear-gradient(135deg,var(--primary),var(--secondary));border:1px solid rgba(255,255,255,.1);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-base);box-shadow:0 4px 12px #0000004d;font-size:18px}.mixer-toggle-control:hover{transform:translate(2px);box-shadow:0 6px 16px #667eea66}.mixer-toggle-control.hidden{display:none}.side-panel{width:360px;background:var(--gray-800);border-left:1px solid var(--gray-700);display:flex;flex-direction:column;overflow:hidden}.side-panel.hidden{display:none}.panel-header{padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--gray-700);display:flex;align-items:center;justify-content:space-between}.panel-title{font-size:16px;font-weight:700;color:#fff}.panel-content{flex:1;overflow-y:auto;padding:var(--spacing-md)}.control-bar{background:var(--gray-800);border-top:1px solid var(--gray-700);padding:var(--spacing-md) var(--spacing-lg);display:flex;align-items:center;justify-content:space-between;height:80px}.control-group{display:flex;gap:var(--spacing-sm);align-items:center}.tabs{display:flex;gap:var(--spacing-xs);border-bottom:1px solid var(--gray-700);padding:0 var(--spacing-lg)}.tab{padding:var(--spacing-md) var(--spacing-lg);font-size:14px;font-weight:600;color:var(--gray-400);cursor:pointer;border-bottom:2px solid transparent;transition:all var(--transition-base)}.tab:hover{color:var(--gray-200)}.tab.active{color:var(--primary);border-bottom-color:var(--primary)}@media (max-width: 1024px){.side-panel{width:320px}.mixer-panel{width:280px}}@media (max-width: 768px){.top-nav{padding:var(--spacing-sm) var(--spacing-md)}.nav-room-info{display:none}.side-panel{position:fixed;right:0;top:64px;bottom:80px;width:100%;max-width:360px;z-index:200;box-shadow:var(--shadow-xl)}.mixer-panel{position:fixed;left:0;top:64px;bottom:80px;width:100%;max-width:320px;z-index:200;box-shadow:var(--shadow-xl)}.control-bar{padding:var(--spacing-sm) var(--spacing-md);height:70px}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);font-size:14px;font-weight:600;cursor:pointer;border:none;transition:all var(--transition-base);white-space:nowrap;-webkit-user-select:none;user-select:none}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-icon{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;background:var(--gray-700);color:#fff;border:none;cursor:pointer;transition:all var(--transition-base);position:relative}.btn-icon:hover:not(:disabled){background:var(--gray-600);transform:scale(1.05)}.btn-icon:active:not(:disabled){transform:scale(.95)}.btn-icon.active{background:var(--primary)}.btn-icon.danger{background:var(--error)}.btn-icon.danger:hover:not(:disabled){background:#dc2626}.btn-primary{background:linear-gradient(135deg,var(--primary),var(--secondary));color:#fff}.btn-primary:hover:not(:disabled){opacity:.9;transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-secondary{background:var(--gray-700);color:#fff}.btn-secondary:hover:not(:disabled){background:var(--gray-600)}.btn-danger{background:var(--error);color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626}.btn-text{background:transparent;color:var(--gray-300);padding:var(--spacing-sm)}.btn-text:hover:not(:disabled){color:#fff;background:var(--gray-700)}.btn-icon-sm{width:32px;height:32px;min-width:32px;border-radius:var(--radius-sm);background:transparent;border:none;color:var(--gray-400);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;transition:all var(--transition-base);flex-shrink:0}.btn-icon-sm:hover{background:var(--gray-600);color:#fff}.btn-icon-sm:active{transform:scale(.95)}.input{width:100%;padding:var(--spacing-sm) var(--spacing-md);background:var(--gray-800);border:1px solid var(--gray-600);border-radius:var(--radius-sm);color:#fff;font-size:14px;transition:all var(--transition-base)}.input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #667eea1a}.input:disabled{opacity:.5;cursor:not-allowed}.slider{width:100%;height:6px;border-radius:3px;background:var(--gray-600);outline:none;-webkit-appearance:none;cursor:pointer}.slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:var(--primary);cursor:pointer;box-shadow:0 2px 4px #0000004d;transition:all var(--transition-base)}.slider::-webkit-slider-thumb:hover{transform:scale(1.1)}.slider::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:var(--primary);cursor:pointer;border:none;box-shadow:0 2px 4px #0000004d;transition:all var(--transition-base)}.slider::-moz-range-thumb:hover{transform:scale(1.1)}.slider-value{display:inline-block;min-width:50px;text-align:right;font-weight:700;color:var(--primary);font-size:14px}.settings-section{margin-bottom:var(--spacing-lg)}.settings-section-title{font-size:12px;font-weight:700;color:var(--gray-400);text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--spacing-md)}.setting-item{background:var(--gray-700);border-radius:var(--radius-md);padding:var(--spacing-md);margin-bottom:var(--spacing-sm)}.setting-label{font-size:14px;font-weight:600;color:var(--gray-100);margin-bottom:var(--spacing-sm);display:flex;align-items:center;justify-content:space-between}.setting-description{font-size:12px;color:var(--gray-400);margin-bottom:var(--spacing-sm)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:2000;animation:fadeIn .2s ease}.modal{background:var(--gray-800);border-radius:var(--radius-lg);max-width:500px;width:90%;max-height:90vh;overflow:hidden;box-shadow:var(--shadow-xl);animation:scaleIn .2s ease}.modal-header{padding:var(--spacing-lg);border-bottom:1px solid var(--gray-700);display:flex;align-items:center;justify-content:space-between}.modal-title{font-size:18px;font-weight:700;color:#fff}.modal-body{padding:var(--spacing-lg);overflow-y:auto;max-height:calc(90vh - 140px)}.modal-footer{padding:var(--spacing-lg);border-top:1px solid var(--gray-700);display:flex;gap:var(--spacing-sm);justify-content:flex-end}.notification{position:fixed;top:80px;right:var(--spacing-lg);background:var(--gray-800);border:1px solid var(--gray-700);border-radius:var(--radius-md);padding:var(--spacing-md);box-shadow:var(--shadow-xl);max-width:400px;z-index:1000;animation:slideIn .3s ease}.notification.success{border-left:4px solid var(--success)}.notification.warning{border-left:4px solid var(--warning)}.notification.error{border-left:4px solid var(--error)}.notification.info{border-left:4px solid var(--info)}.notification-title{font-size:14px;font-weight:700;color:#fff;margin-bottom:var(--spacing-xs)}.notification-message{font-size:13px;color:var(--gray-300);line-height:1.5}@media (max-width: 768px){.btn-icon{width:44px;height:44px;font-size:18px}}.mixer-master{padding:var(--spacing-lg);border-bottom:1px solid var(--gray-700);background:var(--gray-800)}.master-label{font-size:12px;font-weight:700;color:var(--gray-400);text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--spacing-md)}.master-fader{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--gray-700);border-radius:var(--radius-md)}.master-fader-label{font-size:14px;color:var(--gray-300);white-space:nowrap}.master-fader-value{min-width:45px;text-align:right;font-weight:700;color:var(--primary);font-size:14px}.mixer-category{border-bottom:1px solid var(--gray-700)}.mixer-category-header{padding:var(--spacing-md) var(--spacing-lg);background:var(--gray-800);display:flex;align-items:center;justify-content:space-between;cursor:pointer;transition:background var(--transition-base);-webkit-user-select:none;user-select:none}.mixer-category-header:hover{background:var(--gray-750)}.mixer-category-title{display:flex;align-items:center;gap:var(--spacing-sm);font-size:13px;font-weight:700;color:var(--gray-300);text-transform:uppercase;letter-spacing:.5px}.mixer-category-icon{font-size:16px}.mixer-category-count{font-size:11px;padding:2px 8px;border-radius:var(--radius-full);background:var(--gray-700);color:var(--gray-400);font-weight:600}.mixer-category-toggle{font-size:12px;color:var(--gray-500);transition:transform var(--transition-base)}.mixer-category.collapsed .mixer-category-toggle{transform:rotate(-90deg)}.mixer-category-content{padding:var(--spacing-sm) var(--spacing-md);background:var(--gray-900);max-height:1000px;overflow:hidden;transition:max-height var(--transition-base)}.mixer-category.collapsed .mixer-category-content{max-height:0;padding:0 var(--spacing-md)}.mixer-channel{background:var(--gray-800);border:1px solid var(--gray-700);border-radius:var(--radius-md);padding:var(--spacing-md);margin-bottom:var(--spacing-sm);transition:all var(--transition-base)}.mixer-channel:hover{border-color:var(--primary);background:var(--gray-750);transform:translate(2px)}.mixer-channel:last-child{margin-bottom:0}.mixer-channel-header{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-sm)}.mixer-channel-icon{width:32px;height:32px;border-radius:var(--radius-sm);background:linear-gradient(135deg,var(--primary),var(--secondary));display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0;box-shadow:0 2px 4px #667eea4d}.mixer-channel-info{flex:1;min-width:0}.mixer-channel-name{font-size:13px;font-weight:600;color:var(--gray-100);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:2px}.mixer-channel-role{font-size:10px;color:var(--gray-500);text-transform:uppercase;letter-spacing:.5px}.mixer-channel-controls{display:flex;align-items:center;gap:var(--spacing-xs)}.mixer-channel-btn{width:24px;height:24px;border-radius:var(--radius-sm);background:transparent;border:1px solid var(--gray-600);color:var(--gray-400);display:flex;align-items:center;justify-content:center;font-size:12px;cursor:pointer;transition:all var(--transition-base)}.mixer-channel-btn:hover{background:var(--gray-700);border-color:var(--gray-500);color:#fff}.mixer-channel-btn.active{background:var(--primary);border-color:var(--primary);color:#fff}.mixer-channel-fader{display:flex;align-items:center;gap:var(--spacing-sm)}.mixer-channel-slider{flex:1;height:4px;border-radius:2px;background:linear-gradient(to right,var(--gray-700) 0%,var(--gray-700) 33.33%,var(--warning) 33.33%,var(--warning) 100%);outline:none;-webkit-appearance:none;cursor:pointer}.mixer-channel-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:var(--primary);cursor:pointer;box-shadow:0 2px 4px #0000004d;transition:all var(--transition-base)}.mixer-channel-slider::-webkit-slider-thumb:hover{transform:scale(1.2);box-shadow:0 0 0 4px #667eea33}.mixer-channel-slider::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:var(--primary);cursor:pointer;border:none;box-shadow:0 2px 4px #0000004d;transition:all var(--transition-base)}.mixer-channel-slider::-moz-range-thumb:hover{transform:scale(1.2);box-shadow:0 0 0 4px #667eea33}.mixer-channel-value{min-width:45px;text-align:right;font-weight:600;color:var(--primary);font-size:12px}.mixer-empty{padding:var(--spacing-xl) var(--spacing-md);text-align:center;color:var(--gray-500)}.mixer-empty-icon{font-size:48px;margin-bottom:var(--spacing-sm);opacity:.3}.mixer-empty-text{font-size:12px;color:var(--gray-500);line-height:1.5}.participant-list-item{background:var(--gray-700);border-radius:var(--radius-md);padding:var(--spacing-md);margin-bottom:var(--spacing-sm);display:flex;align-items:center;gap:var(--spacing-md);transition:all var(--transition-base)}.participant-list-item:hover{background:var(--gray-600)}.participant-list-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--secondary));display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:600;color:#fff;flex-shrink:0}.participant-list-info{flex:1;min-width:0}.participant-list-name{font-size:14px;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.participant-list-status{font-size:12px;color:var(--gray-400);display:flex;align-items:center;gap:var(--spacing-xs)}.participant-list-controls{display:flex;gap:var(--spacing-xs);align-items:center}.video-area{flex:1;display:flex;flex-direction:column;background:var(--gray-900);position:relative;overflow:hidden}.video-grid{flex:1;display:grid;gap:var(--spacing-sm);padding:var(--spacing-md);overflow-y:auto}.video-grid[data-count="1"]{grid-template-columns:1fr}.video-grid[data-count="2"],.video-grid[data-count="3"],.video-grid[data-count="4"]{grid-template-columns:repeat(2,1fr)}.video-grid[data-count="5"],.video-grid[data-count="6"],.video-grid[data-count="7"],.video-grid[data-count="8"],.video-grid[data-count="9"]{grid-template-columns:repeat(3,1fr)}.participant-tile{background:var(--gray-800);border-radius:var(--radius-md);position:relative;overflow:hidden;aspect-ratio:16 / 9;display:flex;align-items:center;justify-content:center;border:2px solid transparent;transition:border-color var(--transition-base)}.participant-tile.speaking{border-color:var(--primary);box-shadow:0 0 0 2px var(--primary)}.participant-tile.self{border-color:var(--accent)}.participant-video{width:100%;height:100%;object-fit:cover}.participant-tile.main-video{position:relative}.participant-tile.main-video .participant-video{object-fit:contain;background:#000}.participant-avatar{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--secondary));display:flex;align-items:center;justify-content:center;font-size:36px;color:#fff;font-weight:600;overflow:hidden;position:relative}.participant-avatar-img{width:100%;height:100%;object-fit:cover;border-radius:50%}.participant-info-overlay{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,rgba(0,0,0,.8),transparent);padding:var(--spacing-md);display:flex;align-items:center;justify-content:space-between}.participant-name-tag{font-size:14px;font-weight:600;color:#fff;display:flex;align-items:center;gap:var(--spacing-sm)}.participant-role-badge{font-size:11px;padding:2px 8px;border-radius:var(--radius-sm);background:var(--primary);color:#fff;font-weight:600;text-transform:uppercase}.participant-indicators{display:flex;gap:var(--spacing-xs)}.indicator-icon{width:24px;height:24px;border-radius:var(--radius-sm);background:#0009;display:flex;align-items:center;justify-content:center;font-size:14px}.indicator-icon.muted{color:var(--error)}.video-area.screen-sharing-mode{flex-direction:column}.video-area.screen-sharing-mode .video-grid{display:flex;flex-direction:column;gap:0;padding:0;overflow:hidden}.participant-tile.screen-share{grid-column:span 2;aspect-ratio:16 / 9;border-color:var(--info)}.participant-tile.screen-share .participant-video{object-fit:contain;background:#000}.screen-share-video{image-rendering:crisp-edges;image-rendering:-webkit-optimize-contrast}.participant-tile.main-video.screen-share{grid-column:1 / -1;aspect-ratio:16 / 9}.screen-share-main{flex:1;display:flex;align-items:center;justify-content:center;background:#000;padding:var(--spacing-md);overflow:hidden}.screen-share-main .participant-tile.screen-share{width:100%;height:100%;max-width:100%;max-height:100%;aspect-ratio:auto;border:none;border-radius:0}.screen-share-main .participant-tile.screen-share .participant-video{width:100%;height:100%;object-fit:contain}.video-thumbnails-strip{display:flex;gap:var(--spacing-sm);padding:var(--spacing-sm);background:var(--gray-800);border-bottom:1px solid var(--gray-700);overflow-x:auto;overflow-y:hidden;flex-shrink:0;max-height:120px;scrollbar-width:thin;scrollbar-color:var(--gray-600) var(--gray-800)}.video-thumbnails-strip::-webkit-scrollbar{height:6px}.video-thumbnails-strip::-webkit-scrollbar-track{background:var(--gray-800)}.video-thumbnails-strip::-webkit-scrollbar-thumb{background:var(--gray-600);border-radius:3px}.video-thumbnails-strip::-webkit-scrollbar-thumb:hover{background:var(--gray-500)}.video-thumbnails-strip .participant-tile{flex-shrink:0;width:160px;height:90px;aspect-ratio:16 / 9;border-radius:var(--radius-sm)}.video-thumbnails-strip .participant-tile .participant-avatar{width:40px;height:40px;font-size:20px}.video-thumbnails-strip .participant-tile .participant-info-overlay{padding:var(--spacing-xs)}.video-thumbnails-strip .participant-tile .participant-name-tag{font-size:11px}.video-thumbnails-strip .participant-tile .participant-role-badge{font-size:9px;padding:1px 4px}.video-thumbnails-strip .participant-tile .indicator-icon{width:18px;height:18px;font-size:11px}.thumbnails-scroll-btn{position:absolute;top:50%;transform:translateY(-50%);width:32px;height:32px;background:#000000b3;border:none;border-radius:50%;color:#fff;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:10;transition:background var(--transition-base)}.thumbnails-scroll-btn:hover{background:#000000e6}.thumbnails-scroll-btn.left{left:8px}.thumbnails-scroll-btn.right{right:8px}.thumbnails-scroll-btn:disabled{opacity:.3;cursor:not-allowed}.fullscreen-btn{position:absolute;bottom:16px;right:16px;background:#0009;border:none;color:#fff;width:40px;height:40px;border-radius:8px;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--transition-base);z-index:10}.fullscreen-btn:hover{background:#000c}.participant-tile:fullscreen{background:#000;display:flex;align-items:center;justify-content:center;cursor:none}.participant-tile:fullscreen.show-controls{cursor:default}.participant-tile:fullscreen .participant-video{max-width:100vw;max-height:100vh;object-fit:contain}.participant-tile:fullscreen .participant-info-overlay{position:absolute;bottom:20px;left:20px;opacity:0;transition:opacity var(--transition-base)}.participant-tile:fullscreen.show-controls .participant-info-overlay{opacity:1}.participant-tile:fullscreen .fullscreen-btn{bottom:20px;right:20px}.fullscreen-overlay-controls{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,rgba(0,0,0,.9) 0%,rgba(0,0,0,.7) 70%,transparent 100%);padding:32px 48px;display:flex;align-items:center;justify-content:center;gap:16px;opacity:0;transform:translateY(20px);transition:opacity var(--transition-base),transform var(--transition-base);pointer-events:none;z-index:1000}.participant-tile:fullscreen.show-controls .fullscreen-overlay-controls{opacity:1;transform:translateY(0);pointer-events:all}.fullscreen-overlay-controls .btn-icon{width:56px;height:56px;font-size:24px;background:#ffffff26;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:2px solid rgba(255,255,255,.2);box-shadow:0 8px 32px #0000004d}.fullscreen-overlay-controls .btn-icon:hover:not(:disabled){background:#ffffff40;border-color:#ffffff4d;transform:scale(1.1)}.fullscreen-overlay-controls .btn-icon.active{background:var(--primary);border-color:var(--primary-light)}.fullscreen-overlay-controls .btn-icon.danger{background:var(--error);border-color:#dc2626}.fullscreen-overlay-controls .btn-icon.danger:hover:not(:disabled){background:#dc2626;border-color:#b91c1c}.fullscreen-exit-btn{position:absolute;top:24px;right:24px;background:#000000b3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:2px solid rgba(255,255,255,.2);color:#fff;width:48px;height:48px;border-radius:50%;font-size:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-base);z-index:1001;opacity:0;transform:translateY(-10px);pointer-events:none}.participant-tile:fullscreen.show-controls .fullscreen-exit-btn{opacity:1;transform:translateY(0);pointer-events:all}.fullscreen-exit-btn:hover{background:#000000e6;border-color:#fff6;transform:scale(1.1)}.fullscreen-exit-btn:active{transform:scale(.95)}.fullscreen-volume-panel{position:absolute;top:0;left:0;bottom:0;width:320px;background:#000000f2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-right:1px solid rgba(255,255,255,.1);display:flex;flex-direction:column;transform:translate(-100%);transition:transform var(--transition-base);z-index:999;pointer-events:all}.fullscreen-volume-panel.open{transform:translate(0)}.fullscreen-volume-panel-header{padding:20px;border-bottom:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:space-between}.fullscreen-volume-panel-title{font-size:16px;font-weight:600;color:#fff;display:flex;align-items:center;gap:8px}.fullscreen-volume-panel-close{background:transparent;border:none;color:#fff9;font-size:24px;cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all var(--transition-fast)}.fullscreen-volume-panel-close:hover{background:#ffffff1a;color:#fff}.fullscreen-volume-panel-content{flex:1;overflow-y:auto;padding:16px}.fullscreen-volume-item{padding:12px;border-radius:8px;background:#ffffff0d;margin-bottom:12px;transition:background var(--transition-fast)}.fullscreen-volume-item:hover{background:#ffffff14}.fullscreen-volume-item-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.fullscreen-volume-item-name{font-size:14px;font-weight:500;color:#fff;display:flex;align-items:center;gap:8px}.fullscreen-volume-item-value{font-size:12px;color:#fff9;font-weight:600}.fullscreen-volume-item-slider{width:100%;height:4px;border-radius:2px;background:#fff3;outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;pointer-events:auto;touch-action:none;-webkit-user-select:none;user-select:none}.fullscreen-volume-item-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:#fff;cursor:pointer;box-shadow:0 2px 4px #0000004d;transition:transform var(--transition-fast)}.fullscreen-volume-item-slider::-webkit-slider-thumb:hover{transform:scale(1.2)}.fullscreen-volume-item-slider::-webkit-slider-thumb:active{transform:scale(1.3);box-shadow:0 4px 8px #0006}.fullscreen-volume-item-slider::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:#fff;cursor:pointer;border:none;box-shadow:0 2px 4px #0000004d;transition:transform var(--transition-fast)}.fullscreen-volume-item-slider::-moz-range-thumb:hover{transform:scale(1.2)}.fullscreen-volume-item-slider::-moz-range-thumb:active{transform:scale(1.3);box-shadow:0 4px 8px #0006}.fullscreen-volume-toggle{position:absolute;top:50%;left:24px;transform:translateY(-50%);background:#000000b3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:2px solid rgba(255,255,255,.2);color:#fff;width:48px;height:48px;border-radius:50%;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-base);z-index:998;opacity:0;pointer-events:none}.participant-tile:fullscreen.show-controls .fullscreen-volume-toggle{opacity:1;pointer-events:all}.fullscreen-volume-toggle:hover{background:#000000e6;border-color:#fff6;transform:translateY(-50%) scale(1.1)}.fullscreen-volume-toggle.active{background:var(--primary);border-color:var(--primary-light)}@media (max-width: 768px){.video-grid{grid-template-columns:1fr!important}}.audio-device-selector{background:var(--gray-800);border-radius:var(--radius-md);padding:var(--spacing-lg);margin-bottom:var(--spacing-md)}.device-selector-header{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-md);border-bottom:1px solid var(--gray-700)}.device-icon{font-size:24px}.device-title{font-size:16px;font-weight:700;color:#fff}.device-selector-controls{display:flex;flex-direction:column;gap:var(--spacing-md)}.device-label{display:flex;flex-direction:column;gap:var(--spacing-sm);font-size:14px;color:var(--gray-300)}.device-label>span{font-weight:600;color:var(--gray-200)}.device-select-wrapper{display:flex;gap:var(--spacing-sm);align-items:center}.device-select{flex:1;padding:var(--spacing-sm) var(--spacing-md);background:var(--gray-700);border:1px solid var(--gray-600);border-radius:var(--radius-sm);color:#fff;font-size:14px;cursor:pointer;transition:all var(--transition-base)}.device-select:hover{background:var(--gray-600);border-color:var(--gray-500)}.device-select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #667eea1a}.btn-refresh{width:36px;height:36px;padding:0;background:var(--gray-700);border:1px solid var(--gray-600);border-radius:var(--radius-sm);color:var(--gray-300);font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-base)}.btn-refresh:hover{background:var(--gray-600);color:#fff;transform:rotate(90deg)}.btn-refresh:disabled{opacity:.5;cursor:not-allowed;transform:none}.audio-level-meter{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--gray-700);border-radius:var(--radius-sm);transition:all var(--transition-base)}.audio-level-meter.clipping-warning{background:#ef44441a;border:1px solid var(--error)}.level-label{font-size:13px;color:var(--gray-300);white-space:nowrap;min-width:100px}.level-bar-container{flex:1;height:8px;background:var(--gray-600);border-radius:var(--radius-full);overflow:hidden;position:relative}.level-bar{height:100%;border-radius:var(--radius-full);transition:width 50ms linear,background-color var(--transition-base);position:relative}.level-bar.level-low{background:linear-gradient(90deg,var(--success),var(--success))}.level-bar.level-medium{background:linear-gradient(90deg,var(--success),var(--warning))}.level-bar.level-high{background:linear-gradient(90deg,var(--warning),var(--error))}.level-bar.level-clipping{background:var(--error);animation:pulse-error .5s infinite}@keyframes pulse-error{0%,to{opacity:1}50%{opacity:.7}}.level-value{min-width:45px;text-align:right;font-weight:700;font-size:13px;color:var(--gray-200)}.audio-level-meter.clipping-warning .level-value{color:var(--error)}.device-info{padding:var(--spacing-md);background:var(--gray-750);border-radius:var(--radius-sm);border-left:3px solid var(--info)}.info-text{font-size:13px;color:var(--gray-300);line-height:1.6;margin-bottom:var(--spacing-sm)}.info-text:last-child{margin-bottom:0}.info-text strong{color:var(--gray-100);font-weight:600}.btn-add-instrument{width:100%;padding:var(--spacing-md);background:var(--gray-700);border:2px dashed var(--gray-600);border-radius:var(--radius-md);color:var(--gray-300);font-size:14px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);transition:all var(--transition-base);margin-top:var(--spacing-md)}.btn-add-instrument:hover{background:var(--gray-600);border-color:var(--primary);color:#fff;transform:translateY(-2px)}.btn-add-instrument .btn-icon{font-size:20px;font-weight:700}.no-devices-message{width:100%;padding:var(--spacing-lg);background:var(--gray-750);border:2px solid var(--gray-700);border-radius:var(--radius-md);color:var(--gray-400);text-align:center;margin-top:var(--spacing-md);display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm)}.no-devices-icon{font-size:32px;opacity:.6}.no-devices-text{font-size:13px;line-height:1.5;color:var(--gray-400);margin-bottom:var(--spacing-xs)}.btn-refresh-devices{padding:var(--spacing-sm) var(--spacing-md);background:var(--gray-700);border:1px solid var(--gray-600);border-radius:var(--radius-sm);color:var(--gray-300);font-size:13px;font-weight:600;cursor:pointer;transition:all var(--transition-base);display:flex;align-items:center;gap:var(--spacing-xs)}.btn-refresh-devices:hover:not(:disabled){background:var(--gray-600);border-color:var(--primary);color:#fff;transform:translateY(-1px)}.btn-refresh-devices:disabled{opacity:.6;cursor:not-allowed}.instrument-item{background:var(--gray-750);border-radius:var(--radius-md);padding:var(--spacing-md);margin-bottom:var(--spacing-sm);border:1px solid var(--gray-700)}.instrument-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-md)}.instrument-name-input{flex:1;padding:var(--spacing-sm);background:var(--gray-700);border:1px solid var(--gray-600);border-radius:var(--radius-sm);color:#fff;font-size:14px;font-weight:600}.instrument-name-input:focus{outline:none;border-color:var(--primary)}.btn-remove-instrument{width:32px;height:32px;padding:0;background:transparent;border:1px solid var(--gray-600);border-radius:var(--radius-sm);color:var(--error);font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-base)}.btn-remove-instrument:hover{background:var(--error);color:#fff;border-color:var(--error)}.btn-confirm-device{width:100%;padding:var(--spacing-md);background:var(--primary);border:none;border-radius:var(--radius-md);color:#fff;font-size:14px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);transition:all var(--transition-base);margin-top:var(--spacing-md)}.btn-confirm-device:hover{background:var(--primary-dark);transform:translateY(-2px);box-shadow:var(--shadow-md)}.btn-confirm-device:active{transform:translateY(0)}.instrument-compact{background:var(--gray-750);border-radius:var(--radius-md);padding:var(--spacing-md);margin-bottom:var(--spacing-sm);border:1px solid var(--gray-700)}.instrument-compact-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-sm)}.instrument-compact-name{font-size:14px;font-weight:600;color:#fff;flex:1}.instrument-compact-actions{display:flex;gap:var(--spacing-xs)}.btn-edit-instrument,.btn-remove-instrument-compact{width:28px;height:28px;padding:0;background:transparent;border:1px solid var(--gray-600);border-radius:var(--radius-sm);color:var(--gray-400);font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-base)}.btn-edit-instrument:hover{background:var(--gray-600);color:#fff;border-color:var(--primary)}.btn-remove-instrument-compact:hover{background:var(--error);color:#fff;border-color:var(--error)}.instrument-volume-control{display:flex;align-items:center;gap:var(--spacing-md)}.instrument-volume-label{font-size:13px;color:var(--gray-400);min-width:60px}.instrument-volume-slider{flex:1}.instrument-volume-value{min-width:45px;text-align:right;font-weight:600;font-size:13px;color:var(--primary)}.audio-banner{position:fixed;top:80px;left:50%;transform:translate(-50%);z-index:9999;background:linear-gradient(135deg,var(--primary),var(--secondary));border-radius:var(--radius-lg);padding:var(--spacing-lg) var(--spacing-xl);box-shadow:var(--shadow-xl);cursor:pointer;transition:all var(--transition-base);animation:slideDown .3s ease}.audio-banner:hover{transform:translate(-50%) translateY(-2px);box-shadow:0 25px 35px #0003}.audio-banner.hidden{display:none}.audio-banner-content{display:flex;align-items:center;gap:var(--spacing-md)}.audio-banner-icon{font-size:32px;animation:pulse 2s infinite}.audio-banner-text{display:flex;flex-direction:column;gap:4px}.audio-banner-title{font-size:16px;font-weight:700;color:#fff}.audio-banner-subtitle{font-size:13px;color:#ffffffe6}@media (max-width: 768px){.audio-device-selector{padding:var(--spacing-md)}.device-select-wrapper{flex-direction:column}.btn-refresh{width:100%}.audio-level-meter{flex-direction:column;align-items:stretch}.level-label{min-width:auto}}.midi-instrument-item{background:linear-gradient(135deg,#667eea0d,#764ba20d);border:1px solid rgba(102,126,234,.2)}.midi-instrument-item .instrument-icon,.midi-instrument-item .instrument-compact-icon{font-size:24px;filter:drop-shadow(0 2px 4px rgba(102,126,234,.3))}.midi-device-selector{padding:var(--spacing-md)}.midi-device-selector .device-select-wrapper{display:flex;gap:var(--spacing-sm);align-items:center}.midi-device-selector .device-select{flex:1;padding:var(--spacing-sm) var(--spacing-md);background:var(--gray-800);border:1px solid var(--gray-700);border-radius:var(--radius-sm);color:#fff;font-size:14px}.midi-device-selector .device-select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #667eea1a}.midi-keyboard-visualizer{margin:var(--spacing-md) 0;padding:var(--spacing-md);background:var(--gray-900);border-radius:var(--radius-md);border:1px solid var(--gray-700)}.keyboard-label{font-size:12px;color:var(--gray-400);margin-bottom:var(--spacing-sm);font-weight:500}.keyboard-keys{display:flex;gap:2px;height:80px;position:relative;background:var(--gray-800);border-radius:var(--radius-sm);padding:var(--spacing-sm);overflow-x:auto}.key{position:relative;border-radius:2px;transition:all .1s ease;cursor:pointer;-webkit-user-select:none;user-select:none}.white-key{flex:1;min-width:24px;background:linear-gradient(180deg,#fff,#f0f0f0);border:1px solid var(--gray-400);box-shadow:0 2px 4px #0000001a}.white-key:hover{background:linear-gradient(180deg,#f8f8f8,#e8e8e8)}.white-key.active{background:linear-gradient(180deg,var(--primary-light) 0%,var(--primary) 100%);border-color:var(--primary-dark);box-shadow:0 0 12px #667eea99,inset 0 2px 4px #0003;transform:translateY(2px)}.black-key{position:absolute;width:16px;height:50px;background:linear-gradient(180deg,#2d2d2d,#1a1a1a);border:1px solid #000;box-shadow:0 2px 4px #0000004d;z-index:2;margin-left:-8px}.black-key:hover{background:linear-gradient(180deg,#3d3d3d,#2a2a2a)}.black-key.active{background:linear-gradient(180deg,var(--primary) 0%,var(--primary-dark) 100%);box-shadow:0 0 12px #667eeacc,inset 0 2px 4px #0000004d;transform:translateY(2px)}.midi-activity{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:var(--gray-800);border-radius:var(--radius-sm);margin:var(--spacing-sm) 0}.activity-label{font-size:12px;color:var(--gray-400);font-weight:500;min-width:80px}.activity-indicator{display:flex;gap:4px;flex:1}.activity-bar{flex:1;height:20px;background:var(--gray-700);border-radius:2px;transition:all .2s ease}.activity-bar.active{background:linear-gradient(135deg,var(--primary) 0%,var(--secondary) 100%);box-shadow:0 0 8px #667eea80;animation:pulse-midi .6s ease-in-out}@keyframes pulse-midi{0%,to{transform:scaleY(1)}50%{transform:scaleY(1.2)}}.activity-count{font-size:12px;color:var(--gray-300);font-weight:600;min-width:60px;text-align:right}.btn-add-midi-instrument{width:100%;padding:var(--spacing-md);background:linear-gradient(135deg,#667eea1a,#764ba21a);border:2px dashed rgba(102,126,234,.3);border-radius:var(--radius-md);color:var(--primary-light);font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);margin-top:var(--spacing-md)}.btn-add-midi-instrument:hover{background:linear-gradient(135deg,#667eea26,#764ba226);border-color:var(--primary);transform:translateY(-2px);box-shadow:0 4px 12px #667eea33}.btn-add-midi-instrument:active{transform:translateY(0)}.btn-add-midi-instrument .btn-icon{font-size:18px;font-weight:700}#host-midi-category,#participant-midi-category{border-left:3px solid var(--primary)}#host-midi-category .mixer-category-icon,#participant-midi-category .mixer-category-icon{filter:drop-shadow(0 2px 4px rgba(102,126,234,.4))}.midi-loading{display:flex;align-items:center;justify-content:center;padding:var(--spacing-xl);color:var(--gray-400);font-size:14px}.midi-loading:before{content:"🎹";font-size:32px;margin-right:var(--spacing-md);animation:bounce 1s ease-in-out infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.midi-error{padding:var(--spacing-md);background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-md);color:var(--error);font-size:13px;margin:var(--spacing-sm) 0}.midi-error:before{content:"⚠️ ";margin-right:var(--spacing-sm)}.mixer-midi-placeholder{padding:var(--spacing-lg) var(--spacing-md);text-align:center}.mixer-midi-icon{font-size:40px;margin-bottom:var(--spacing-sm);opacity:.4}.mixer-midi-text{font-size:12px;color:var(--gray-500);line-height:1.5;margin-bottom:var(--spacing-sm)}.mixer-midi-hint{font-size:11px;color:var(--gray-600);font-style:italic}@media (max-width: 768px){.keyboard-keys{height:60px}.white-key{min-width:18px}.black-key{width:12px;height:38px;margin-left:-6px}}.metronome-panel{padding:var(--spacing-md)}.metronome-header{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.metronome-icon{font-size:1.5rem}.metronome-title{font-size:1rem;font-weight:600;color:var(--gray-200)}.metronome-controls{display:flex;flex-direction:column;gap:var(--spacing-md)}.btn-metronome{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-md);background:linear-gradient(135deg,var(--primary),var(--secondary));color:#fff;border:none;border-radius:var(--radius-md);font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:var(--shadow-md)}.btn-metronome:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.btn-metronome:active{transform:translateY(0)}.btn-metronome.active{background:linear-gradient(135deg,var(--error),#dc2626)}.btn-metronome .icon{font-size:1.2rem}.metronome-settings{display:flex;flex-direction:column;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--gray-800);border-radius:var(--radius-md)}.metronome-label{display:flex;flex-direction:column;gap:var(--spacing-xs);color:var(--gray-300);font-size:.875rem}.metronome-label span:first-child{font-weight:600;color:var(--gray-200)}.metronome-label .value{display:inline-block;min-width:50px;text-align:right;font-weight:600;color:var(--primary-light)}.metronome-label .select{padding:var(--spacing-sm);background:var(--gray-700);color:var(--gray-200);border:1px solid var(--gray-600);border-radius:var(--radius-sm);font-size:.875rem;cursor:pointer;transition:all .2s ease}.metronome-label .select:hover{border-color:var(--primary)}.metronome-label .select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #667eea1a}.metronome-visual{margin-top:var(--spacing-md);padding:var(--spacing-md);background:var(--gray-800);border-radius:var(--radius-md)}.beat-indicators{display:flex;gap:var(--spacing-sm);justify-content:center}.beat-indicator{width:40px;height:40px;border-radius:var(--radius-full);background:var(--gray-700);border:2px solid var(--gray-600);transition:all .1s ease;display:flex;align-items:center;justify-content:center}.beat-indicator.active{background:var(--primary);border-color:var(--primary-light);box-shadow:0 0 20px #667eea99;transform:scale(1.2)}.beat-indicator.accent{background:var(--accent);border-color:#fbbf24;box-shadow:0 0 20px #f59e0b99}.metronome-indicator{padding:var(--spacing-md);text-align:center}.metronome-status{display:inline-block;padding:var(--spacing-sm) var(--spacing-md);background:var(--gray-800);color:var(--gray-400);border-radius:var(--radius-md);font-size:.875rem;transition:all .3s ease}.metronome-status.active{background:linear-gradient(135deg,var(--primary),var(--secondary));color:#fff;font-weight:600;box-shadow:var(--shadow-md)}.metronome-sync-status{display:flex;align-items:center;justify-content:center;gap:var(--spacing-md);padding:var(--spacing-md);margin-bottom:var(--spacing-md);background:linear-gradient(135deg,#667eea1a,#764ba21a);border:1px solid rgba(102,126,234,.3);border-radius:var(--radius-md);color:var(--primary-light);font-size:.875rem;font-weight:500;animation:pulse-border 2s ease-in-out infinite}@keyframes pulse-border{0%,to{border-color:#667eea4d;box-shadow:0 0 #667eea66}50%{border-color:#667eea99;box-shadow:0 0 0 4px #667eea1a}}.sync-spinner{width:20px;height:20px;border:2px solid rgba(102,126,234,.3);border-top-color:var(--primary);border-radius:50%;animation:spin 1s linear infinite}.sync-message{color:var(--gray-200);font-weight:500}@media (max-width: 768px){.beat-indicator{width:32px;height:32px}.metronome-settings{padding:var(--spacing-sm)}}.mp3-player-panel{width:360px;background:var(--gray-800);border-left:1px solid var(--gray-700);position:relative;z-index:50;transition:transform var(--transition-base)}.mp3-player-panel.hidden{transform:translate(100%)}.mp3-tracks-list{display:flex;flex-direction:column;gap:var(--spacing-md);max-height:calc(100vh - 280px);overflow-y:auto;overflow-x:hidden;padding-right:4px}.mp3-track-item{background:var(--gray-700);border-radius:var(--radius-md);padding:var(--spacing-md)}.mp3-track-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-sm);gap:var(--spacing-sm)}.mp3-track-name{font-size:14px;font-weight:600;color:var(--gray-100);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0}.mp3-track-controls{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-sm)}.mp3-track-time{font-size:12px;color:var(--gray-400);font-variant-numeric:tabular-nums;flex:1}.mp3-current-time{color:var(--primary);font-weight:600}.mp3-play-btn{background:var(--primary);color:#fff}.mp3-play-btn:hover{background:var(--primary-dark)}.mp3-delete-btn{color:var(--error)}.mp3-delete-btn:hover{background:#ef44441a;color:var(--error)}.mp3-track-progress{margin-bottom:var(--spacing-sm)}.mp3-progress-bar{width:100%;height:6px;border-radius:var(--radius-full);background:var(--gray-600);outline:none;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none}.mp3-progress-bar::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:14px;height:14px;border-radius:50%;background:var(--primary);cursor:pointer;transition:transform var(--transition-fast);margin-top:-4px}.mp3-progress-bar::-webkit-slider-thumb:hover{transform:scale(1.2)}.mp3-progress-bar::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:var(--primary);cursor:pointer;border:none;transition:transform var(--transition-fast);margin-top:-4px}.mp3-progress-bar::-moz-range-thumb:hover{transform:scale(1.2)}.mp3-progress-bar::-webkit-slider-runnable-track{width:100%;height:6px;border-radius:var(--radius-full);background:linear-gradient(to right,var(--primary) 0%,var(--primary) var(--progress, 0%),var(--gray-600) var(--progress, 0%),var(--gray-600) 100%)}.mp3-progress-bar::-moz-range-track{width:100%;height:6px;border-radius:var(--radius-full);background:var(--gray-600)}.mp3-track-progress-bar{height:4px;background:var(--primary);border-radius:var(--radius-full);transition:width .1s linear;position:relative}.mp3-track-progress-bar:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:var(--gray-600);border-radius:var(--radius-full);z-index:-1}.mp3-track-volume{display:flex;align-items:center;gap:var(--spacing-sm)}.mp3-track-volume>span:first-child{font-size:16px}.mp3-volume-slider{flex:1;height:4px;border-radius:var(--radius-full);background:var(--gray-600);outline:none;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none}.mp3-volume-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:12px;height:12px;border-radius:50%;background:var(--primary);cursor:pointer}.mp3-volume-slider::-moz-range-thumb{width:12px;height:12px;border-radius:50%;background:var(--primary);cursor:pointer;border:none}.mp3-volume-value{min-width:40px;text-align:right;font-size:12px;color:var(--gray-400);font-variant-numeric:tabular-nums}.mp3-sync-status{display:flex;align-items:center;justify-content:center;gap:var(--spacing-md);padding:var(--spacing-md);margin-bottom:var(--spacing-md);background:linear-gradient(135deg,#667eea1a,#764ba21a);border:1px solid rgba(102,126,234,.3);border-radius:var(--radius-md);color:var(--primary-light);font-size:.875rem;font-weight:500;animation:pulse-border 2s ease-in-out infinite}.mp3-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-2xl);text-align:center;color:var(--gray-400)}.mp3-empty-state.hidden{display:none}.mp3-empty-icon{font-size:48px;margin-bottom:var(--spacing-md);opacity:.5}.mp3-empty-text{font-size:14px;line-height:1.6}@media (max-width: 768px){.mp3-player-panel{width:100%;max-width:360px}}.network-quality{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:var(--gray-700);border-radius:var(--radius-md);font-size:12px}.network-bars{display:flex;gap:2px;align-items:flex-end}.network-bar{width:3px;background:var(--gray-500);border-radius:2px}.network-bar:nth-child(1){height:6px}.network-bar:nth-child(2){height:10px}.network-bar:nth-child(3){height:14px}.network-bar:nth-child(4){height:18px}.network-quality.excellent .network-bar{background:var(--success)}.network-quality.good .network-bar:nth-child(-n+3){background:var(--success)}.network-quality.fair .network-bar:nth-child(-n+2){background:var(--warning)}.network-quality.poor .network-bar:nth-child(1){background:var(--error)}.modal-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:10000;padding:20px;opacity:0;transition:opacity .3s ease}.modal-backdrop.modal-visible{opacity:1}.modal-container{background:#fff;border-radius:16px;max-width:500px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d;transform:scale(.9);transition:transform .3s ease}.modal-visible .modal-container{transform:scale(1)}.modal-header{display:flex;align-items:center;gap:12px;padding:24px 24px 16px;border-bottom:1px solid #e5e7eb;position:relative}.modal-icon{font-size:32px;line-height:1}.modal-title{flex:1;margin:0;font-size:24px;font-weight:600;color:#111827}.modal-close-btn{position:absolute;top:16px;right:16px;background:transparent;border:none;font-size:32px;line-height:1;color:#6b7280;cursor:pointer;padding:4px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:all .2s ease}.modal-close-btn:hover{background:#f3f4f6;color:#111827}.modal-close-btn:active{transform:scale(.95)}.modal-content{padding:24px}@media (max-width: 640px){.modal-backdrop{padding:0}.modal-container{max-width:100%;max-height:100vh;border-radius:0}.modal-header{padding:20px 20px 12px}.modal-title{font-size:20px}.modal-content{padding:20px}}@media (prefers-color-scheme: dark){.modal-container{background:#1f2937;color:#f9fafb}.modal-header{border-bottom-color:#374151}.modal-title{color:#f9fafb}.modal-close-btn{color:#9ca3af}.modal-close-btn:hover{background:#374151;color:#f9fafb}}.notifications-container{position:fixed;top:20px;right:20px;z-index:10000;display:flex;flex-direction:column;gap:12px;max-width:400px;pointer-events:none}.notification{display:flex;align-items:flex-start;gap:12px;padding:16px;background:#fff;border-radius:12px;box-shadow:0 4px 12px #00000026;pointer-events:auto;opacity:0;transform:translate(100%);transition:all .3s cubic-bezier(.4,0,.2,1);border-left:4px solid;min-width:300px}.notification-show{opacity:1;transform:translate(0)}.notification-info{border-left-color:#3b82f6;background:linear-gradient(to right,#eff6ff,#fff)}.notification-success{border-left-color:#10b981;background:linear-gradient(to right,#ecfdf5,#fff)}.notification-warning{border-left-color:#f59e0b;background:linear-gradient(to right,#fffbeb,#fff)}.notification-error{border-left-color:#ef4444;background:linear-gradient(to right,#fef2f2,#fff)}.notification-icon{font-size:24px;line-height:1;flex-shrink:0}.notification-content{flex:1;min-width:0}.notification-message{font-size:14px;line-height:1.5;color:#374151;word-wrap:break-word}.notification-close{background:none;border:none;color:#9ca3af;cursor:pointer;font-size:18px;line-height:1;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .2s;flex-shrink:0}.notification-close:hover{background:#0000000d;color:#374151}.notification-close:active{transform:scale(.95)}.notification-removing{opacity:0;transform:translate(100%)}@media (max-width: 640px){.notifications-container{top:10px;right:10px;left:10px;max-width:none}.notification{min-width:0}}@media (prefers-color-scheme: dark){.notification{background:#1f2937;box-shadow:0 4px 12px #0000004d}.notification-info{background:linear-gradient(to right,#1e3a8a,#1f2937)}.notification-success{background:linear-gradient(to right,#064e3b,#1f2937)}.notification-warning{background:linear-gradient(to right,#78350f,#1f2937)}.notification-error{background:linear-gradient(to right,#7f1d1d,#1f2937)}.notification-message{color:#e5e7eb}.notification-close{color:#6b7280}.notification-close:hover{background:#ffffff1a;color:#e5e7eb}}.global-loader{position:fixed;top:0;left:0;right:0;bottom:0;z-index:9999;display:flex;align-items:center;justify-content:center;opacity:1;transition:opacity .3s ease}.global-loader.hidden{opacity:0;pointer-events:none}.loader-backdrop{position:absolute;top:0;left:0;right:0;bottom:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.loader-content{position:relative;display:flex;flex-direction:column;align-items:center;gap:16px;padding:32px;background:#fff;border-radius:16px;box-shadow:0 8px 32px #0003}.loader-spinner{width:48px;height:48px;border:4px solid #e5e7eb;border-top-color:#3b82f6;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loader-message{font-size:14px;color:#374151;text-align:center;max-width:300px;line-height:1.5}@media (prefers-color-scheme: dark){.loader-content{background:#1f2937}.loader-spinner{border-color:#374151;border-top-color:#60a5fa}.loader-message{color:#e5e7eb}}@media (max-width: 640px){.loader-content{padding:24px}.loader-spinner{width:40px;height:40px}.loader-message{font-size:13px;max-width:250px}}
