*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0a0a0f;--surface: #14141f;--surface-hover: #1e1e2e;--border: #2a2a3a;--text: #e4e4ef;--text-muted: #8888a0;--primary: #6366f1;--primary-hover: #818cf8;--danger: #ef4444;--danger-hover: #f87171;--success: #22c55e;--radius: 12px}html,body,#root{height:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased}button{cursor:pointer;border:none;font-family:inherit;font-size:inherit}input{font-family:inherit;font-size:inherit}.page{min-height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:32px;width:100%;max-width:480px}.card h1{font-size:28px;font-weight:700;margin-bottom:8px}.card p{color:var(--text-muted);margin-bottom:24px;line-height:1.5}.field{margin-bottom:16px}.field label{display:block;font-size:14px;font-weight:500;color:var(--text-muted);margin-bottom:6px}.field input{width:100%;padding:10px 14px;background:var(--bg);border:1px solid var(--border);border-radius:8px;color:var(--text);outline:none;transition:border-color .15s}.field input:focus{border-color:var(--primary)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;border-radius:8px;font-weight:600;font-size:15px;transition:background .15s}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-hover)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:var(--danger-hover)}.btn-ghost{background:transparent;color:var(--text);border:1px solid var(--border)}.btn-ghost:hover{background:var(--surface-hover)}.btn-icon{width:48px;height:48px;border-radius:50%;padding:0;display:flex;align-items:center;justify-content:center;font-size:20px}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-full{width:100%}.stream-layout{height:100%;display:flex;flex-direction:column;overflow:hidden}.stream-body{flex:1;display:flex;min-height:0}.stream-main{flex:1;display:flex;flex-direction:column;min-width:0}.stream-info{padding:8px 20px 12px}.stream-info-label{font-size:13px;color:var(--text-muted);margin-bottom:6px}.sidebar{width:320px;flex-shrink:0;display:flex;flex-direction:column;border-left:1px solid var(--border);background:var(--surface)}@media(max-width:768px){.stream-body{flex-direction:column}.sidebar{width:100%;max-height:50%;border-left:none;border-top:1px solid var(--border)}}.stream-header{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;background:var(--surface);border-bottom:1px solid var(--border)}.stream-header h2{font-size:16px;font-weight:600}.stream-status{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-muted)}.stream-status .dot{width:8px;height:8px;border-radius:50%;background:var(--success);animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.video-container{flex:1;display:flex;align-items:center;justify-content:center;background:#000;position:relative;overflow:hidden}.video-container video{width:100%;height:100%;object-fit:contain}.video-placeholder{display:flex;flex-direction:column;align-items:center;gap:12px;color:var(--text-muted);font-size:48px}.video-placeholder span{font-size:14px}.controls{display:flex;align-items:center;justify-content:center;gap:12px;padding:16px 20px;background:var(--surface);border-top:1px solid var(--border)}.controls-extra{position:absolute;bottom:0;left:0;right:0;display:flex;justify-content:center;padding:12px}.camera-select{padding:8px 12px;background:#000000b3;border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:13px;outline:none;max-width:200px}.share-box{display:flex;gap:8px;margin-top:16px}.share-box input{flex:1;padding:10px 14px;background:var(--bg);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:13px;outline:none}.viewer-count{font-size:13px;color:var(--text-muted)}.viewer-list{padding:12px 16px;border-bottom:1px solid var(--border)}.viewer-list-title{font-size:13px;font-weight:600;color:var(--text-muted);margin-bottom:8px}.viewer-list ul{list-style:none;display:flex;flex-wrap:wrap;gap:8px}.viewer-list li{display:flex;align-items:center;gap:6px;padding:4px 12px;background:var(--surface-hover);border:1px solid var(--border);border-radius:16px;font-size:13px}.viewer-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:140px}.viewer-dot{width:6px;height:6px;border-radius:50%;background:var(--success);flex-shrink:0}.btn-kick{background:none;color:var(--text-muted);font-size:16px;line-height:1;padding:0 2px;margin-left:2px;border-radius:4px;transition:color .15s}.btn-kick:hover{color:var(--danger)}.chat{display:flex;flex-direction:column;flex:1;min-height:0;background:var(--surface)}.chat-title{font-size:13px;font-weight:600;color:var(--text-muted);padding:10px 16px 0}.chat-messages{flex:1;overflow-y:auto;padding:8px 16px;display:flex;flex-direction:column;gap:4px;min-height:80px}.chat-empty{color:var(--text-muted);font-size:13px;text-align:center;padding:16px 0}.chat-msg{font-size:13px;line-height:1.4}.chat-name{font-weight:600;margin-right:6px;color:var(--primary)}.chat-name-streamer{color:var(--danger)}.chat-text{color:var(--text)}.chat-msg-own .chat-name{color:var(--success)}.chat-msg-system{color:var(--text-muted);font-style:italic;font-size:12px;padding:2px 0}.chat-input{display:flex;gap:8px;padding:8px 16px 12px}.chat-input input{flex:1;padding:8px 12px;background:var(--bg);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:13px;outline:none}.chat-input input:focus{border-color:var(--primary)}.chat-input .btn{padding:8px 14px;font-size:13px}.error-msg{color:var(--danger);font-size:14px;margin-top:8px}
