*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-primary: #0f1117;--bg-secondary: #181b24;--bg-tertiary: #1f2330;--bg-hover: #272b3a;--bg-glass: rgba(24, 27, 36, .75);--border: #2a2f3e;--border-light: #353a4d;--text-primary: #eaecf0;--text-secondary: #8b92a5;--text-muted: #5c6275;--accent: #6366f1;--accent-hover: #818cf8;--accent-glow: rgba(99, 102, 241, .25);--accent-subtle: rgba(99, 102, 241, .1);--danger: #ef4444;--danger-hover: #f87171;--danger-subtle: rgba(239, 68, 68, .1);--success: #22c55e;--success-subtle: rgba(34, 197, 94, .1);--warning: #f59e0b;--warning-subtle: rgba(245, 158, 11, .1);--live-red: #ef4444;--banner-bg: rgba(15, 17, 23, .85);--sidebar-width: 300px;--control-height: 72px;--radius: 12px;--radius-sm: 8px;--radius-xs: 6px;--shadow-sm: 0 1px 2px rgba(0,0,0,.3);--shadow-md: 0 4px 12px rgba(0,0,0,.4);--shadow-lg: 0 8px 32px rgba(0,0,0,.5);--shadow-glow: 0 0 20px var(--accent-glow);--gradient-accent: linear-gradient(135deg, #6366f1, #a855f7);--gradient-bg: linear-gradient(135deg, #0f1117, #1a1d2e);--transition-fast: .15s ease;--transition-base: .25s ease;--transition-slow: .4s ease}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg-primary);color:var(--text-primary);min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}button{cursor:pointer;font-family:inherit;border:none;background:none;color:inherit}input,select,textarea{font-family:inherit;color:var(--text-primary);background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 16px;font-size:14px;outline:none;width:100%;transition:border-color var(--transition-base),box-shadow var(--transition-base)}input:focus,select:focus,textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}input::placeholder,textarea::placeholder{color:var(--text-muted)}.home-page{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:32px;background:var(--gradient-bg);position:relative;overflow:hidden}.home-page:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle at 30% 40%,rgba(99,102,241,.08) 0%,transparent 50%),radial-gradient(circle at 70% 60%,rgba(168,85,247,.06) 0%,transparent 50%);pointer-events:none}.home-page>*{position:relative;z-index:1}.home-page h1{font-size:48px;font-weight:800;background:var(--gradient-accent);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.02em}.home-page p{color:var(--text-secondary);font-size:17px;max-width:520px;text-align:center;line-height:1.7}.home-user-bar{position:absolute;top:24px;right:24px;display:flex;align-items:center;gap:12px;z-index:10}.home-user-name{color:var(--text-secondary);font-size:14px;font-weight:500}.btn-primary{background:var(--gradient-accent);color:#fff;padding:14px 32px;border-radius:var(--radius-sm);font-size:15px;font-weight:600;transition:all var(--transition-base);box-shadow:0 2px 8px #6366f14d;letter-spacing:.01em}.btn-primary:hover{box-shadow:0 4px 16px #6366f173;transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-danger{background:var(--danger);color:#fff;padding:14px 32px;border-radius:var(--radius-sm);font-size:15px;font-weight:600;transition:all var(--transition-base)}.btn-danger:hover{background:var(--danger-hover)}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);padding:14px 32px;border-radius:var(--radius-sm);font-size:15px;font-weight:600;border:1px solid var(--border);transition:all var(--transition-base)}.btn-secondary:hover{background:var(--bg-hover);border-color:var(--border-light)}.setup-page{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:40px;overflow-y:auto;background:var(--gradient-bg)}.setup-container{max-width:560px;width:100%}.setup-container h1{font-size:28px;text-align:center;margin-bottom:8px;font-weight:700}.setup-container .subtitle{text-align:center;color:var(--text-secondary);margin-bottom:32px;font-size:14px}.preview-area{background:#000;border-radius:var(--radius);overflow:hidden;aspect-ratio:16/9;position:relative;margin-bottom:24px;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-lg)}.preview-area video{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;transform:scaleX(-1);display:block}.preview-controls{display:flex;gap:4px;justify-content:center;margin-bottom:24px;background:var(--bg-secondary);border-radius:var(--radius-sm);padding:4px;width:fit-content;margin-left:auto;margin-right:auto;border:1px solid var(--border)}.preview-ctrl-btn{display:flex;align-items:center;gap:8px;padding:10px 20px;border-radius:var(--radius-xs);font-size:13px;color:var(--text-secondary);transition:all var(--transition-fast)}.preview-ctrl-btn:hover,.preview-ctrl-btn.active{background:var(--bg-tertiary);color:var(--text-primary)}.preview-ctrl-btn.muted{color:var(--danger)}.device-selector{margin-bottom:16px}.device-selector label{display:block;font-size:13px;color:var(--text-secondary);margin-bottom:6px;font-weight:500}.setup-form{display:flex;flex-direction:column;gap:16px;margin-top:24px}.mic-level{height:4px;background:var(--bg-tertiary);border-radius:2px;margin-top:8px;overflow:hidden}.mic-level-bar{height:100%;background:var(--success);border-radius:2px;transition:width .1s}.studio-layout{display:grid;grid-template-columns:1fr 300px;grid-template-rows:48px 1fr;height:100vh;overflow:hidden}.studio-header{grid-column:1 / -1;display:flex;align-items:center;justify-content:space-between;padding:8px 16px;background:var(--bg-secondary);border-bottom:1px solid var(--border);height:48px}.studio-header .brand{font-weight:700;font-size:15px;display:flex;align-items:center;gap:10px}.studio-header .brand-icon{width:28px;height:28px;background:var(--gradient-accent);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;color:#fff}.studio-header .live-badge{display:flex;align-items:center;gap:6px;background:var(--live-red);color:#fff;padding:4px 14px;border-radius:20px;font-size:12px;font-weight:700;animation:pulse-live 2s infinite;box-shadow:0 0 12px #ef444466}@keyframes pulse-live{0%,to{opacity:1;box-shadow:0 0 12px #ef444466}50%{opacity:.8;box-shadow:0 0 20px #ef444499}}.studio-header .header-actions{display:flex;gap:8px;align-items:center}.btn-go-live{background:var(--gradient-accent);color:#fff;padding:8px 20px;border-radius:var(--radius-sm);font-size:16px;font-weight:600;display:flex;align-items:center;gap:6px;transition:all var(--transition-base);box-shadow:0 2px 8px #6366f14d}.btn-go-live:hover{box-shadow:0 4px 16px #6366f173}.btn-go-live.is-live{background:var(--danger);box-shadow:0 2px 8px #ef44444d}.studio-main{display:flex;flex-direction:column;background:var(--bg-primary);overflow:hidden;grid-row:2;grid-column:1}.video-preview-container{flex:1;display:flex;align-items:center;justify-content:center;padding:8px 12px;position:relative;min-height:0;overflow:hidden}.video-canvas-wrapper{position:relative;width:100%;height:100%;max-height:100%;background:#000;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-lg);display:flex;align-items:center;justify-content:center}.video-canvas-wrapper canvas{max-width:100%;max-height:100%;width:auto;height:auto;aspect-ratio:16/9}.resolution-badge{position:absolute;top:12px;left:12px;background:#0009;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fff;padding:3px 10px;border-radius:6px;font-size:11px;font-weight:600;border:1px solid rgba(255,255,255,.1)}.banner-overlay{position:absolute;bottom:0;left:0;right:0;background:var(--banner-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);color:#fff;text-align:center;padding:10px 20px;font-size:16px;font-weight:600}.layout-selector{display:flex;align-items:center;justify-content:center;gap:4px;padding:4px 8px;background:var(--bg-secondary);border-top:1px solid var(--border)}.layout-btn{width:40px;height:30px;border:2px solid var(--border);border-radius:6px;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);padding:3px}.layout-btn:hover{border-color:var(--text-secondary)}.layout-btn.active{border-color:var(--accent);background:var(--accent-subtle)}.layout-btn svg{width:100%;height:100%}.participants-strip{display:flex;gap:6px;padding:4px 8px;background:var(--bg-secondary);border-top:1px solid var(--border);overflow-x:auto;flex-shrink:0}.participant-thumb{width:120px;min-width:120px;border-radius:var(--radius-sm);overflow:hidden;position:relative;cursor:pointer;border:2px solid transparent;background:var(--bg-tertiary);transition:border-color var(--transition-fast)}.participant-thumb.active{border-color:var(--accent);box-shadow:0 0 12px var(--accent-glow)}.participant-thumb.disconnected{opacity:.4;filter:grayscale(1);border-color:#ffffff0d}.participant-thumb.disconnected:after{content:"Deconnecte";position:absolute;bottom:24px;left:50%;transform:translate(-50%);background:#ef4444cc;color:#fff;font-size:9px;padding:2px 6px;border-radius:3px;white-space:nowrap}.participant-thumb video{width:100%;aspect-ratio:16/9;object-fit:cover;transform:scaleX(-1)}.participant-thumb .name{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,#000c);color:#fff;padding:12px 8px 4px;font-size:11px;display:flex;align-items:center;gap:4px}.invite-placeholder{width:120px;min-width:120px;aspect-ratio:16/9;border:2px dashed var(--border);border-radius:var(--radius-sm);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;color:var(--text-muted);font-size:11px;cursor:pointer;transition:all var(--transition-base)}.invite-placeholder:hover{border-color:var(--accent);color:var(--accent)}.control-bar{display:flex;align-items:center;justify-content:center;gap:12px;padding:16px 32px;background:var(--bg-secondary);border-top:1px solid var(--border);min-height:80px}.ctrl-btn{display:flex;flex-direction:column;align-items:center;gap:6px;padding:12px 22px;border-radius:var(--radius);font-size:12px;color:var(--text-secondary);transition:all var(--transition-fast);position:relative;min-width:64px}.ctrl-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.ctrl-btn.active{color:var(--accent)}.ctrl-btn.muted{color:var(--danger)}.ctrl-btn .icon{font-size:28px}.ctrl-btn svg{width:28px;height:28px}.ctrl-btn-chevron{position:absolute;top:2px;right:2px;font-size:10px}.ctrl-btn-group{position:relative;display:flex;flex-direction:column;align-items:center}.ctrl-btn-chevron-btn{position:absolute;top:0;right:0;background:#ffffff1a;border:none;border-radius:4px;color:var(--text-secondary);padding:2px 4px;cursor:pointer;z-index:2;transition:all var(--transition-fast)}.ctrl-btn-chevron-btn:hover{background:#ffffff40;color:var(--text-primary)}.device-picker-dropdown{position:absolute;bottom:100%;left:50%;transform:translate(-50%);background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);min-width:260px;max-width:360px;padding:8px 0;z-index:1000;box-shadow:0 8px 32px #00000080;margin-bottom:8px}.device-picker-title{padding:8px 16px 6px;font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);font-weight:600}.device-picker-item{display:block;width:100%;text-align:left;padding:10px 16px;font-size:13px;color:var(--text-secondary);background:none;border:none;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.device-picker-item:hover{background:var(--bg-tertiary);color:var(--text-primary)}.device-picker-item.active{color:var(--accent);background:#7c3aed1a}.device-picker-item.active:before{content:"✓ "}.device-picker-empty{padding:12px 16px;font-size:12px;color:var(--text-muted);font-style:italic}.ctrl-divider{width:1px;height:48px;background:var(--border);margin:0 8px}.btn-end-stream{background:var(--danger);color:#fff;padding:14px 28px;border-radius:var(--radius);font-size:15px;font-weight:600;display:flex;align-items:center;gap:8px;margin-left:16px;transition:all var(--transition-base)}.btn-end-stream:hover{background:var(--danger-hover)}.studio-sidebar{background:var(--bg-secondary);border-left:1px solid var(--border);display:flex;flex-direction:column;grid-row:2;grid-column:2;overflow:hidden}.sidebar-tabs{display:flex;flex-direction:row;flex-wrap:wrap;gap:2px;padding:6px 8px;border-bottom:1px solid var(--border);justify-content:center}.sidebar-tab{display:flex;flex-direction:column;align-items:center;gap:2px;padding:6px 8px;border-radius:var(--radius-xs);font-size:9px;color:var(--text-secondary);transition:all var(--transition-fast);min-width:46px}.sidebar-tab:hover{background:var(--bg-tertiary);color:var(--text-primary)}.sidebar-tab.active{color:var(--accent);background:var(--accent-subtle)}.sidebar-content{flex:1;overflow-y:auto;padding:16px}.sidebar-panel h3{font-size:13px;margin-bottom:10px;color:var(--text-primary);border-bottom:1px solid var(--border);padding-bottom:6px;font-weight:600}.sidebar-panel h3:first-child{border-bottom:none;padding-bottom:0}.rtmp-target{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--bg-tertiary);border-radius:var(--radius-sm);margin-bottom:8px;border:1px solid var(--border);transition:border-color var(--transition-fast)}.rtmp-target:hover{border-color:var(--border-light)}.rtmp-target .platform-icon{width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:#fff;flex-shrink:0}.rtmp-target .platform-icon.youtube{background:red}.rtmp-target .platform-icon.twitch{background:#9146ff}.rtmp-target .platform-icon.tiktok{background:#000;border:1px solid #333}.rtmp-target .platform-icon.instagram{background:linear-gradient(45deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888)}.rtmp-target .platform-icon.x{background:#000;border:1px solid #333}.rtmp-target .platform-icon.linkedin{background:#0077b5}.rtmp-target .platform-icon.facebook{background:#1877f2}.rtmp-target .platform-icon.discord{background:#5865f2}.rtmp-target .platform-icon.custom{background:var(--accent)}.rtmp-target .info{flex:1;min-width:0}.rtmp-target .info .name{font-size:13px;font-weight:600}.rtmp-target .info .status{font-size:11px;color:var(--text-secondary)}.rtmp-target .remove-btn{color:var(--text-muted);font-size:18px;padding:4px;transition:color var(--transition-fast)}.rtmp-target .remove-btn:hover{color:var(--danger)}.add-target-form{display:flex;flex-direction:column;gap:10px;padding:12px;background:var(--bg-tertiary);border-radius:var(--radius-sm);margin-top:12px;border:1px solid var(--border)}.add-target-form select,.add-target-form input{font-size:13px;padding:10px 12px}.add-target-form .btn-add{background:var(--gradient-accent);color:#fff;padding:10px;border-radius:var(--radius-sm);font-size:13px;font-weight:600;transition:all var(--transition-base)}.banner-panel textarea{width:100%;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);padding:10px 12px;font-size:14px;resize:vertical;min-height:60px;font-family:inherit}.banner-panel textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow);outline:none}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.modal{background:var(--bg-secondary);border:1px solid var(--border);border-radius:16px;padding:32px;width:480px;max-width:90vw;box-shadow:var(--shadow-lg);animation:slideUp .3s ease}.modal h2{font-size:20px;margin-bottom:20px;font-weight:700}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.invite-link-box{display:flex;gap:8px;margin-top:12px}.invite-link-box input{flex:1;font-size:13px}.invite-link-box button{background:var(--gradient-accent);color:#fff;padding:10px 20px;border-radius:var(--radius-sm);font-size:13px;font-weight:600;white-space:nowrap}.scene-active{border:2px solid var(--accent)!important;background:var(--accent-subtle)}.countdown-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#000000d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:10;color:#fff}.countdown-overlay .countdown-number{font-size:120px;font-weight:800;line-height:1;background:var(--gradient-accent);-webkit-background-clip:text;-webkit-text-fill-color:transparent;animation:countdown-pulse 1s ease-in-out infinite}.countdown-overlay .countdown-label{font-size:20px;margin-top:16px;color:#fff9}@keyframes countdown-pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.08);opacity:.85}}.btn-add{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:13px;font-weight:500;display:flex;align-items:center;gap:6px;transition:all var(--transition-base)}.btn-add:hover{background:var(--bg-hover);border-color:var(--accent)}input[type=range]{-webkit-appearance:none;-moz-appearance:none;appearance:none;height:4px;background:var(--border);border-radius:2px;outline:none;margin-top:6px;border:none;padding:0}input[type=range]:focus{box-shadow:none}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:var(--accent);cursor:pointer;box-shadow:0 0 6px var(--accent-glow)}input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent);cursor:pointer;border-radius:4px}input[type=color]{-webkit-appearance:none;border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;padding:2px}input[type=color]::-webkit-color-swatch-wrapper{padding:0}input[type=color]::-webkit-color-swatch{border:none;border-radius:calc(var(--radius-sm) - 2px)}.green-room-badge{position:absolute;top:2px;right:6px;background:var(--warning);color:#fff;border-radius:50%;width:16px;height:16px;font-size:10px;display:flex;align-items:center;justify-content:center;font-weight:700}.auth-page{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:24px;background:var(--gradient-bg);position:relative;overflow:hidden}.auth-page:before{content:"";position:absolute;top:-30%;right:-20%;width:600px;height:600px;background:radial-gradient(circle,rgba(99,102,241,.12) 0%,transparent 70%);pointer-events:none}.auth-page:after{content:"";position:absolute;bottom:-30%;left:-20%;width:500px;height:500px;background:radial-gradient(circle,rgba(168,85,247,.08) 0%,transparent 70%);pointer-events:none}.auth-card{position:relative;z-index:1;background:var(--bg-glass);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border);border-radius:20px;padding:40px;width:440px;max-width:100%;box-shadow:var(--shadow-lg),0 0 60px #6366f10d;animation:slideUp .4s ease}.auth-brand{text-align:center;margin-bottom:32px}.brand-icon-lg{width:56px;height:56px;background:var(--gradient-accent);border-radius:16px;display:inline-flex;align-items:center;justify-content:center;font-size:20px;font-weight:800;color:#fff;margin-bottom:16px;box-shadow:0 4px 16px #6366f159}.auth-brand h1{font-size:24px;font-weight:700;color:var(--text-primary);letter-spacing:-.01em}.auth-card>h2{font-size:18px;font-weight:600;color:var(--text-secondary);text-align:center;margin-bottom:28px}.auth-error{background:var(--danger-subtle);border:1px solid rgba(239,68,68,.2);color:var(--danger-hover);padding:12px 16px;border-radius:var(--radius-sm);font-size:13px;margin-bottom:20px;text-align:center;animation:shake .3s ease}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-6px)}75%{transform:translate(6px)}}.auth-form{display:flex;flex-direction:column;gap:18px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:13px;font-weight:600;color:var(--text-secondary);letter-spacing:.02em}.form-hint{font-size:12px;color:var(--text-muted);margin-top:4px}.auth-btn{width:100%;padding:14px;font-size:15px;margin-top:4px}.auth-links{display:flex;justify-content:center;gap:24px;margin-top:24px;padding-top:20px;border-top:1px solid var(--border)}.auth-links a{color:var(--accent);text-decoration:none;font-size:13px;font-weight:500;transition:color var(--transition-fast)}.auth-links a:hover{color:var(--accent-hover)}.auth-success{background:var(--success-subtle);border:1px solid rgba(34,197,94,.2);color:var(--success);padding:12px 16px;border-radius:var(--radius-sm);font-size:13px;margin-bottom:20px;text-align:center}.admin-page{min-height:100vh;background:var(--gradient-bg)}.admin-header{display:flex;align-items:center;justify-content:space-between;padding:12px 24px;background:var(--bg-glass);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100}.admin-brand{display:flex;align-items:center;gap:12px;font-size:16px;font-weight:700}.admin-header-right{display:flex;align-items:center;gap:12px}.admin-user{color:var(--text-secondary);font-size:13px}.admin-msg{padding:12px 24px;background:var(--accent-subtle);border-bottom:1px solid rgba(99,102,241,.15);color:var(--accent-hover);font-size:14px;font-weight:500;text-align:center;animation:slideDown .3s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.admin-tabs{display:flex;gap:4px;padding:16px 24px 0;border-bottom:1px solid var(--border)}.admin-tab{padding:10px 20px;font-size:14px;font-weight:500;color:var(--text-secondary);border-bottom:2px solid transparent;transition:all var(--transition-base);margin-bottom:-1px}.admin-tab:hover{color:var(--text-primary)}.admin-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.admin-content{padding:24px;max-width:1200px;margin:0 auto}.admin-content h2{font-size:20px;font-weight:700;margin-bottom:16px;color:var(--text-primary)}.admin-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);padding:24px;transition:border-color var(--transition-base)}.admin-card:hover{border-color:var(--border-light)}.admin-card h3{font-size:15px;font-weight:600;margin-bottom:12px;color:var(--text-primary)}.admin-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.admin-form-grid input,.admin-form-grid select{font-size:13px;padding:10px 14px}.admin-table-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-secondary)}.admin-table{width:100%;border-collapse:collapse;font-size:13px}.admin-table thead{background:var(--bg-tertiary)}.admin-table th{padding:12px 16px;text-align:left;font-weight:600;color:var(--text-secondary);font-size:12px;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border)}.admin-table td{padding:12px 16px;border-bottom:1px solid var(--border);color:var(--text-primary)}.admin-table tbody tr{transition:background var(--transition-fast)}.admin-table tbody tr:hover{background:var(--bg-tertiary)}.admin-table tbody tr:last-child td{border-bottom:none}.role-badge{display:inline-block;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600;text-transform:capitalize}.role-admin{background:var(--accent-subtle);color:var(--accent-hover);border:1px solid rgba(99,102,241,.2)}.role-moderator{background:var(--warning-subtle);color:var(--warning);border:1px solid rgba(245,158,11,.2)}.role-guest{background:#8b92a51a;color:var(--text-secondary);border:1px solid rgba(139,146,165,.15)}.action-badge{display:inline-block;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600}.action-login{background:var(--success-subtle);color:var(--success)}.action-logout,.action-failed_login{background:var(--danger-subtle);color:var(--danger)}.action-register,.action-create_user{background:var(--accent-subtle);color:var(--accent-hover)}.action-update_user,.action-update_permissions,.action-change_password{background:var(--warning-subtle);color:var(--warning)}.action-delete_user{background:var(--danger-subtle);color:var(--danger)}.btn-sm{padding:5px 12px;font-size:12px;font-weight:500;border-radius:var(--radius-xs);background:var(--bg-tertiary);border:1px solid var(--border);color:var(--text-primary);transition:all var(--transition-fast);cursor:pointer}.btn-sm:hover{background:var(--bg-hover);border-color:var(--border-light)}.btn-sm-danger{color:var(--danger);border-color:#ef444433}.btn-sm-danger:hover{background:var(--danger-subtle);border-color:var(--danger)}.perms-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:12px}.perm-toggle{display:flex;align-items:center;gap:10px;padding:8px 12px;background:var(--bg-tertiary);border-radius:var(--radius-sm);font-size:13px;cursor:pointer;border:1px solid var(--border);transition:all var(--transition-fast)}.perm-toggle:hover{border-color:var(--border-light);background:var(--bg-hover)}.chat-messages{display:flex;flex-direction:column;gap:8px;max-height:400px;overflow-y:auto;padding-right:4px}.chat-message{padding:8px 12px;background:var(--bg-tertiary);border-radius:var(--radius-sm);font-size:13px;border:1px solid var(--border)}.chat-message .chat-author{font-weight:600;color:var(--accent);font-size:12px;margin-bottom:2px}.chat-message .chat-platform{font-size:10px;color:var(--text-muted);margin-left:6px;font-weight:400}.chat-message .chat-text{color:var(--text-primary);line-height:1.4}.chat-input-area{display:flex;gap:8px;margin-top:12px}.chat-input-area input{flex:1;font-size:13px;padding:10px 14px}.chat-input-area button{background:var(--gradient-accent);color:#fff;padding:10px 16px;border-radius:var(--radius-sm);font-size:13px;font-weight:600;flex-shrink:0}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--border-light)}@media (max-width: 1100px){.studio-layout{grid-template-columns:1fr}.studio-sidebar{display:none}}@media (max-width: 640px){.auth-card{padding:28px 24px;border-radius:16px}.admin-tabs{overflow-x:auto;padding:12px 16px 0}.admin-content{padding:16px}.admin-form-grid,.perms-grid{grid-template-columns:1fr}.home-page h1{font-size:36px}}.home-page{background:var(--bg-primary);min-height:100vh}.home-topbar{display:flex;align-items:center;justify-content:space-between;padding:16px 0;border-bottom:1px solid rgba(255,255,255,.06);margin-bottom:32px}.home-topbar-left{display:flex;align-items:center;gap:16px}.home-topbar-right{display:flex;align-items:center;gap:12px}.home-logo{display:flex;align-items:center;gap:10px;font-size:18px;font-weight:700;color:var(--text-primary)}.home-logo svg{color:var(--accent)}.home-user-name{color:var(--text-secondary);font-size:14px}.btn-icon{background:#ffffff0f;border:1px solid rgba(255,255,255,.1);color:var(--text-secondary);width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.btn-icon:hover{background:#ffffff1a;color:var(--text-primary)}.home-content{max-width:1100px;margin:0 auto}.home-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:32px}.home-header h1{font-size:28px;font-weight:700;color:var(--text-primary);margin:0 0 6px}.home-header p{color:var(--text-secondary);font-size:15px;margin:0}.home-header .btn-primary{display:flex;align-items:center;gap:8px;white-space:nowrap}.studios-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px}.studio-card{background:var(--bg-card);border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:20px;cursor:pointer;transition:all .25s;display:flex;flex-direction:column}.studio-card:hover{border-color:#6366f14d;transform:translateY(-2px);box-shadow:0 8px 30px #0000004d}.studio-card-live{border-color:#ef44444d;background:linear-gradient(135deg,rgba(239,68,68,.05) 0%,var(--bg-card) 100%)}.studio-card-live:hover{border-color:#ef444480}.studio-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.studio-card-actions{display:flex;gap:6px;opacity:0;transition:opacity .2s}.studio-card:hover .studio-card-actions{opacity:1}.btn-icon-sm{background:#ffffff0f;border:1px solid rgba(255,255,255,.1);color:var(--text-secondary);width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;padding:0}.btn-icon-sm:hover{background:#ffffff1f;color:var(--text-primary)}.btn-icon-sm.btn-danger:hover{background:#ef444433;color:#ef4444;border-color:#ef44444d}.status-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;border-radius:20px;font-size:11px;font-weight:700;letter-spacing:.5px}.status-live{background:#ef444426;color:#ef4444}.live-dot{width:6px;height:6px;background:#ef4444;border-radius:50%;animation:pulse-dot 1.5s ease-in-out infinite}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.3}}.status-offline{background:#ffffff0f;color:var(--text-muted)}.studio-card-body{flex:1;margin-bottom:16px}.studio-card-body h3{font-size:18px;font-weight:600;color:var(--text-primary);margin:0 0 6px}.studio-card-desc{color:var(--text-secondary);font-size:13px;margin:0;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.studio-card-footer{display:flex;justify-content:space-between;align-items:center;padding-top:16px;border-top:1px solid rgba(255,255,255,.06)}.studio-card-meta{display:flex;gap:16px;color:var(--text-muted);font-size:12px}.studio-card-meta span{display:flex;align-items:center;gap:4px}.btn-sm{padding:6px 16px!important;font-size:13px!important;display:flex;align-items:center;gap:6px}.studio-card-new{border:2px dashed rgba(255,255,255,.1);background:transparent;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;min-height:200px;color:var(--text-muted);transition:all .25s}.studio-card-new:hover{border-color:#6366f166;color:var(--accent);background:#6366f10d}.studio-card-new p{font-size:14px;margin:0}.home-empty{text-align:center;padding:80px 20px}.home-empty-icon{width:80px;height:80px;border-radius:20px;background:#6366f11a;display:flex;align-items:center;justify-content:center;margin:0 auto 24px;color:var(--accent)}.home-empty h2{font-size:22px;color:var(--text-primary);margin:0 0 8px}.home-empty p{color:var(--text-secondary);font-size:15px;max-width:400px;margin:0 auto 24px;line-height:1.5}.home-empty .btn-primary{display:inline-flex;align-items:center;gap:8px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-card{background:var(--bg-card);border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:32px;width:100%;max-width:480px;box-shadow:0 20px 60px #00000080}.modal-card h2{font-size:22px;font-weight:700;color:var(--text-primary);margin:0 0 8px}.modal-card label{display:block;font-size:13px;color:var(--text-secondary);margin-bottom:6px;font-weight:500}.modal-card input{width:100%}.guest-badge{background:#f59e0b26;color:#f59e0b;padding:4px 12px;border-radius:20px;font-size:12px;font-weight:600}.setup-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.setup-logo{display:flex;align-items:center;gap:8px;font-size:15px;font-weight:600;color:var(--text-primary)}.setup-logo svg{color:var(--accent)}.preview-cam-off{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;background:#000c;color:var(--text-muted);border-radius:12px}.preview-cam-off p{font-size:14px;margin:0}.preview-area{position:relative}@media (min-width: 1200px){.ctrl-btn{padding:14px 26px;font-size:13px;min-width:72px}.ctrl-btn svg{width:32px;height:32px}.control-bar{gap:14px;min-height:90px}.btn-end-stream{padding:16px 32px;font-size:16px}}@media (max-width: 768px){.ctrl-btn{padding:8px 12px;font-size:10px;min-width:48px}.ctrl-btn svg{width:22px;height:22px}.control-bar{gap:6px;padding:10px 12px;min-height:60px}}.system-stats-overlay{position:absolute;top:12px;right:12px;background:#000000bf;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:10px;padding:10px 14px;display:flex;flex-direction:column;gap:6px;cursor:pointer;z-index:10;min-width:160px;border:1px solid rgba(255,255,255,.1)}.system-stats-overlay:hover{background:#000000d9}.stat-item{display:flex;align-items:center;gap:8px}.stat-label{font-size:11px;font-weight:600;color:#ffffffb3;width:30px;text-transform:uppercase}.stat-bar{flex:1;height:6px;background:#ffffff26;border-radius:3px;overflow:hidden}.stat-fill{height:100%;border-radius:3px;transition:width .5s ease,background .5s ease}.stat-value{font-size:11px;font-weight:600;color:#ffffffe6;width:60px;text-align:right;font-variant-numeric:tabular-nums}.video-canvas-wrapper{position:relative}.waiting-screens-bar{position:relative;bottom:auto;left:0;right:0;background:#000000d9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-top:1px solid rgba(255,255,255,.1);padding:8px 16px;z-index:20}.waiting-screens-header{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--text-secondary);margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}.waiting-screens-list{display:flex;gap:12px;overflow-x:auto;padding-bottom:4px}.waiting-screen-item{position:relative;flex-shrink:0;width:160px;border-radius:8px;overflow:hidden;background:var(--bg-elevated);border:2px solid rgba(255,255,255,.1);transition:border-color .2s}.waiting-screen-item:hover{border-color:#ffffff4d}.waiting-screen-item.is-live{border-color:#ef4444;box-shadow:0 0 12px #ef44444d}.waiting-screen-preview{width:100%;height:90px;object-fit:cover;display:block;background:#000}.waiting-screen-label{padding:4px 8px 0;font-size:11px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.waiting-screen-sublabel{padding:0 8px 4px;font-size:10px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.waiting-screen-actions{padding:0 6px 6px;display:flex;gap:4px}.ws-btn{display:flex;align-items:center;gap:4px;padding:4px 8px;border:none;bord}
