:root{--bg-primary: #0f0a0d;--bg-secondary: #1a1215;--bg-tertiary: #251a1f;--bg-card: rgba(255, 182, 193, .03);--bg-card-hover: rgba(255, 182, 193, .06);--text-primary: #fff5f7;--text-secondary: rgba(255, 245, 247, .75);--text-muted: rgba(255, 245, 247, .45);--accent-gradient: linear-gradient(135deg, #ff6b9d 0%, #c44569 50%, #ff8a5c 100%);--accent-primary: #ff6b9d;--accent-secondary: #c44569;--accent-hover: #ff85ad;--success: #10b981;--warning: #f59e0b;--error: #ef4444;--border-subtle: rgba(255, 182, 193, .08);--border-active: rgba(255, 182, 193, .15);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .3);--shadow-md: 0 4px 20px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 40px rgba(0, 0, 0, .5);--shadow-glow: 0 0 60px rgba(255, 107, 157, .25);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .4s ease;font-family:Inter,system-ui,-apple-system,sans-serif;line-height:1.5;font-weight:400;color-scheme:dark;color:var(--text-primary);background-color:var(--bg-primary);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{margin:0;min-height:100vh;background:var(--bg-primary);background-image:radial-gradient(ellipse 80% 60% at 20% -10%,rgba(255,107,157,.12),transparent),radial-gradient(ellipse 60% 50% at 80% 10%,rgba(196,69,105,.1),transparent),radial-gradient(ellipse 50% 40% at 90% 90%,rgba(255,138,92,.08),transparent)}#root{min-height:100vh;display:flex;flex-direction:column}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#ffb6c126;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#ffb6c140}:focus-visible{outline:2px solid var(--accent-primary);outline-offset:2px}::selection{background:#ff6b9d4d}.landing-page:before{content:"";position:fixed;inset:0;pointer-events:none;background-image:radial-gradient(2px 2px at 10% 20%,rgba(255,107,157,.3),transparent),radial-gradient(2px 2px at 90% 80%,rgba(255,138,92,.3),transparent),radial-gradient(1px 1px at 30% 70%,rgba(255,182,193,.4),transparent),radial-gradient(2px 2px at 70% 30%,rgba(196,69,105,.3),transparent),radial-gradient(1px 1px at 50% 50%,rgba(255,107,157,.2),transparent);animation:twinkle 8s ease-in-out infinite;z-index:0}@keyframes twinkle{0%,to{opacity:.5}50%{opacity:1}}.landing-page{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px;min-height:100vh}.landing-hero{text-align:center;max-width:600px;animation:fadeInUp .6s ease-out}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.landing-logo{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:16px}.landing-logo-icon{width:56px;height:56px;background:var(--accent-gradient);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-glow);animation:heartbeat 2s ease-in-out infinite}@keyframes heartbeat{0%,to{transform:scale(1)}14%{transform:scale(1.1)}28%{transform:scale(1)}42%{transform:scale(1.1)}70%{transform:scale(1)}}.landing-logo-icon svg{width:32px;height:32px;color:#fff}.landing-title{font-size:3rem;font-weight:800;margin:0;background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.02em}.landing-subtitle{font-size:1.25rem;color:var(--text-secondary);margin:16px 0 48px;line-height:1.6}.landing-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);padding:40px;width:100%;max-width:420px;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);box-shadow:var(--shadow-lg)}.landing-input-group{display:flex;flex-direction:column;gap:16px}.input-wrapper{position:relative}.input-icon{position:absolute;left:16px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}.landing-input{width:100%;padding:16px 16px 16px 48px;font-size:1rem;border:1px solid var(--border-subtle);border-radius:var(--radius-md);background:var(--bg-secondary);color:var(--text-primary);transition:all var(--transition-fast)}.landing-input::placeholder{color:var(--text-muted)}.landing-input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #ff6b9d26}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:16px 32px;font-size:1rem;font-weight:600;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);text-decoration:none}.btn-primary{background:var(--accent-gradient);color:#fff;box-shadow:var(--shadow-sm),0 0 25px #ff6b9d59}.btn-primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-md),0 0 40px #ff6b9d80}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-subtle)}.btn-secondary:hover{background:var(--bg-card-hover);border-color:var(--border-active)}.btn-icon{padding:12px;border-radius:var(--radius-md);background:var(--bg-card);border:1px solid var(--border-subtle);color:var(--text-secondary)}.btn-icon:hover{background:var(--bg-card-hover);color:var(--text-primary)}.btn-sm{padding:10px 20px;font-size:.875rem}.landing-divider{display:flex;align-items:center;gap:16px;margin:24px 0;color:var(--text-muted);font-size:.875rem}.landing-divider:before,.landing-divider:after{content:"";flex:1;height:1px;background:var(--border-subtle)}.landing-features{display:flex;justify-content:center;gap:48px;margin-top:64px}.landing-feature{display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--text-muted);font-size:.875rem}.landing-feature-icon{width:48px;height:48px;border-radius:var(--radius-md);background:var(--bg-card);border:1px solid var(--border-subtle);display:flex;align-items:center;justify-content:center;color:var(--accent-primary)}.room-page{display:flex;flex-direction:column;min-height:100vh}.room-header{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;background:var(--bg-secondary);border-bottom:1px solid var(--border-subtle);position:sticky;top:0;z-index:100;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.room-header-left{display:flex;align-items:center;gap:16px}.room-logo{display:flex;align-items:center;gap:8px;font-weight:700;font-size:1.125rem;color:var(--text-primary);text-decoration:none}.room-logo-icon{width:32px;height:32px;background:var(--accent-gradient);border-radius:6px;display:flex;align-items:center;justify-content:center}.room-logo-icon svg{width:18px;height:18px;color:#fff}.room-id-badge{display:flex;align-items:center;gap:8px;padding:6px 12px;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:20px;font-size:.875rem;color:var(--text-secondary)}.room-id-badge code{font-family:SF Mono,Monaco,monospace;color:var(--accent-primary)}.room-header-right{display:flex;align-items:center;gap:12px}.connection-status{display:flex;align-items:center;gap:6px;font-size:.75rem;color:var(--text-muted)}.status-dot{width:8px;height:8px;border-radius:50%;background:var(--text-muted)}.status-dot.connected{background:var(--success);box-shadow:0 0 8px var(--success)}.status-dot.connecting{background:var(--warning);animation:pulse 1.5s infinite}.status-dot.disconnected{background:var(--error)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.room-main{flex:1;display:flex;gap:0}.room-content{flex:1;display:flex;flex-direction:column;background:var(--bg-primary)}.video-container{position:relative;width:100%;aspect-ratio:16 / 9;background:#000;overflow:hidden}.video-player{width:100%;height:100%;object-fit:contain;background:#000}.video-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.video-placeholder{text-align:center;color:var(--text-secondary)}.video-placeholder-icon{width:80px;height:80px;margin:0 auto 16px;background:var(--bg-card);border:2px dashed var(--border-active);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;color:var(--text-muted)}.room-controls{padding:24px;background:var(--bg-secondary);border-top:1px solid var(--border-subtle)}.now-playing{display:flex;align-items:center;gap:16px;margin-bottom:20px}.now-playing-info{flex:1}.now-playing-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:4px}.now-playing-title{font-size:1.25rem;font-weight:600;color:var(--text-primary)}.movie-selector{display:flex;align-items:center;gap:12px}.movie-selector label{font-size:.875rem;color:var(--text-secondary)}.movie-select{padding:10px 36px 10px 16px;font-size:.875rem;border:1px solid var(--border-subtle);border-radius:var(--radius-md);background:var(--bg-tertiary);color:var(--text-primary);cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='rgba(255,255,255,0.5)' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;transition:all var(--transition-fast);min-width:200px}.movie-select:hover{border-color:var(--border-active)}.movie-select:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #ff6b9d26}.room-sidebar{width:320px;background:var(--bg-secondary);border-left:1px solid var(--border-subtle);display:flex;flex-direction:column}.sidebar-header{padding:20px;border-bottom:1px solid var(--border-subtle)}.sidebar-title{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0 0 4px}.sidebar-subtitle{font-size:.875rem;color:var(--text-muted)}.members-list{flex:1;padding:16px;overflow-y:auto}.member-item{display:flex;align-items:center;gap:12px;padding:12px;border-radius:var(--radius-md);transition:background var(--transition-fast)}.member-item:hover{background:var(--bg-card)}.member-avatar{width:40px;height:40px;border-radius:50%;background:var(--accent-gradient);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:1rem;color:#fff;text-transform:uppercase}.member-name{flex:1;font-weight:500;color:var(--text-primary)}.member-badge{font-size:.75rem;padding:2px 8px;border-radius:10px;background:var(--bg-card);color:var(--text-muted)}.sidebar-footer{padding:16px;border-top:1px solid var(--border-subtle)}@media(max-width:1024px){.room-sidebar{display:none}}@media(max-width:768px){.landing-title{font-size:2rem}.landing-subtitle{font-size:1rem}.landing-card{padding:24px}.landing-features{gap:24px;flex-wrap:wrap}.room-header{padding:12px 16px;flex-wrap:wrap;gap:12px}.room-controls{padding:16px}.movie-selector{flex-direction:column;align-items:stretch}.movie-select{width:100%}}.toast{position:fixed;bottom:24px;right:24px;padding:16px 24px;background:var(--bg-tertiary);border:1px solid var(--border-subtle);border-radius:var(--radius-md);color:var(--text-primary);font-size:.875rem;box-shadow:var(--shadow-lg);animation:slideIn .3s ease-out;z-index:1000;display:flex;align-items:center;gap:12px}.toast.success{border-color:var(--success);background:#10b9811a}.toast.error{border-color:var(--error);background:#ef44441a}@keyframes slideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none!important}.input-icon svg{width:20px;height:20px}.landing-feature-icon svg{width:24px;height:24px}.video-overlay{animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.movie-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:20px;padding:20px}.movie-card{position:relative;border-radius:var(--radius-md);overflow:hidden;background:var(--bg-card);border:1px solid var(--border-subtle);transition:all var(--transition-normal);cursor:pointer}.movie-card:hover{transform:translateY(-4px);border-color:var(--accent-primary);box-shadow:var(--shadow-md),0 0 20px #ff6b9d40}.movie-card-poster{aspect-ratio:16 / 9;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;color:var(--text-muted)}.movie-card-info{padding:16px}.movie-card-title{font-weight:600;color:var(--text-primary);margin:0 0 4px}.movie-card-meta{font-size:.875rem;color:var(--text-muted)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px;text-align:center;color:var(--text-secondary)}.empty-state-icon{width:64px;height:64px;margin-bottom:16px;color:var(--text-muted)}.skeleton{background:linear-gradient(90deg,var(--bg-card) 25%,var(--bg-card-hover) 50%,var(--bg-card) 75%);background-size:200% 100%;animation:skeleton-loading 1.5s infinite;border-radius:var(--radius-sm)}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}.tooltip{position:relative}.tooltip:after{content:attr(data-tooltip);position:absolute;bottom:100%;left:50%;transform:translate(-50%);padding:8px 12px;background:var(--bg-tertiary);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);font-size:.75rem;color:var(--text-primary);white-space:nowrap;opacity:0;visibility:hidden;transition:all var(--transition-fast);z-index:100}.tooltip:hover:after{opacity:1;visibility:visible}
