:root{--color-primary: #6366f1;--color-primary-hover: #4f46e5;--color-secondary: #64748b;--color-secondary-hover: #475569;--color-danger: #ef4444;--color-danger-hover: #dc2626;--color-success: #22c55e;--color-bg: #0f172a;--color-surface: #1e293b;--color-surface-hover: #334155;--color-text: #f8fafc;--color-text-muted: #94a3b8;--color-border: #334155;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-full: 9999px;--shadow: 0 4px 6px -1px rgba(0, 0, 0, .3), 0 2px 4px -2px rgba(0, 0, 0, .2);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .3), 0 4px 6px -4px rgba(0, 0, 0, .2);--transition: .15s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left)}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:var(--color-bg);color:var(--color-text);line-height:1.5;-webkit-font-smoothing:antialiased}#app{height:100vh;height:100dvh;display:flex;flex-direction:column;overflow:hidden}.screen{display:none;flex:1;min-height:0;padding:24px;overflow:hidden}.screen.active{display:flex;flex-direction:column;align-items:center;justify-content:center}.container{width:100%;max-width:420px;display:flex;flex-direction:column;align-items:center;gap:24px}.logo{font-size:3rem;font-weight:700;background:linear-gradient(135deg,var(--color-primary),#a855f7);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.02em}.tagline{color:var(--color-text-muted);font-size:1.1rem;margin-top:-16px}.card{width:100%;background:var(--color-surface);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;font-size:1rem;font-weight:500;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition);text-decoration:none}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--color-primary-hover);transform:translateY(-1px);box-shadow:var(--shadow-lg)}.btn-secondary{background:var(--color-secondary);color:#fff}.btn-secondary:hover:not(:disabled){background:var(--color-secondary-hover)}.btn-danger{background:var(--color-danger);color:#fff}.btn-danger:hover:not(:disabled){background:var(--color-danger-hover)}.btn-large{width:100%;padding:16px 24px;font-size:1.1rem}.btn-icon{font-size:1.5rem;font-weight:300;line-height:1}.btn-icon-only{width:40px;height:40px;padding:8px;background:var(--color-surface-hover);border:none;border-radius:var(--radius-sm);color:var(--color-text);cursor:pointer;transition:all var(--transition)}.btn-icon-only:hover{background:var(--color-primary)}.btn-text{background:transparent;color:var(--color-text-muted);padding:8px 12px}.btn-text:hover{color:var(--color-text);background:var(--color-surface-hover)}.btn-google{width:100%;background:#fff;color:#1f1f1f;font-weight:500;padding:12px 24px;border:1px solid #dadce0}.btn-google:hover:not(:disabled){background:#f8f9fa;box-shadow:0 1px 3px #0000001a}.btn-google .google-icon{flex-shrink:0}.login-card{text-align:center}.login-prompt{color:var(--color-text-muted);margin-bottom:20px}.user-header{position:absolute;top:0;left:0;right:0;display:flex;align-items:center;justify-content:space-between;padding:16px 24px;background:transparent}.user-info{display:flex;align-items:center;gap:12px}.avatar{width:36px;height:36px;border-radius:var(--radius-full);object-fit:cover;background:var(--color-surface)}#user-name{font-size:.95rem;color:var(--color-text);font-weight:500}.input-group{display:flex;gap:12px}.input-group input{flex:1;padding:12px 16px;font-size:1rem;background:var(--color-bg);border:2px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);transition:border-color var(--transition)}.input-group input:focus{outline:none;border-color:var(--color-primary)}.input-group input::placeholder{color:var(--color-text-muted)}.divider{width:100%;display:flex;align-items:center;gap:16px;color:var(--color-text-muted);font-size:.9rem}.divider:before,.divider:after{content:"";flex:1;height:1px;background:var(--color-border)}.error-message{width:100%;padding:12px 16px;background:#ef44441a;border:1px solid var(--color-danger);border-radius:var(--radius-md);color:var(--color-danger);text-align:center}.room-info{text-align:center}.room-info p{color:var(--color-text-muted);margin-bottom:12px}.room-id-box{display:flex;flex-direction:column;align-items:center;gap:12px;padding:16px;background:var(--color-surface);border-radius:var(--radius-md)}.room-id-box span{font-family:SF Mono,Monaco,Inconsolata,monospace;font-size:.9rem;font-weight:500;color:var(--color-primary);letter-spacing:.02em;word-break:break-all;text-align:center}.room-actions{display:flex;gap:8px}.video-preview{width:100%;max-width:320px;aspect-ratio:4/3;position:relative;border-radius:var(--radius-lg);overflow:hidden;background:var(--color-surface);box-shadow:var(--shadow)}.video-preview video{width:100%;height:100%;object-fit:cover;transform:scaleX(-1)}.video-label{position:absolute;bottom:12px;left:50%;transform:translate(-50%);padding:6px 12px;background:#0009;border-radius:var(--radius-full);font-size:.85rem;color:#fff}.status-message{padding:12px 20px;background:var(--color-surface);border-radius:var(--radius-full);color:var(--color-text-muted);font-size:.95rem}#call-screen.active{padding:0}.call-container{width:100%;height:100%;display:flex;flex-direction:column;background:#000}.videos{flex:1;min-height:0;position:relative;background:#000;overflow:hidden}#remote-video{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:contain;background:#000}.video-placeholder{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;background:var(--color-surface);color:var(--color-text-muted)}.video-placeholder.hidden{display:none}.placeholder-icon{opacity:.5}.local-video-wrapper{position:absolute;right:20px;bottom:20px;width:160px;aspect-ratio:4/3;border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-lg);border:3px solid var(--color-bg)}.local-video-wrapper video{width:100%;height:100%;object-fit:cover;transform:scaleX(-1);background:var(--color-surface)}.call-controls{display:flex;align-items:center;justify-content:center;gap:16px;padding:24px;background:var(--color-bg)}.btn-control{width:56px;height:56px;border-radius:var(--radius-full);background:var(--color-surface);border:none;color:var(--color-text);cursor:pointer;transition:all var(--transition);display:flex;align-items:center;justify-content:center}.btn-control:hover{background:var(--color-surface-hover);transform:scale(1.05)}.btn-control.active,.btn-control.btn-close{background:var(--color-danger)}.btn-control.btn-close:hover{background:var(--color-danger-hover)}.btn-control svg{width:24px;height:24px}.call-status{position:absolute;top:20px;left:50%;transform:translate(-50%);padding:10px 20px;border-radius:var(--radius-full);font-size:.9rem;font-weight:500;z-index:10}.call-status.info{background:var(--color-surface);color:var(--color-text)}.call-status.error{background:var(--color-danger);color:#fff}.quality-indicator{position:absolute;top:20px;right:20px;background:var(--color-surface);border-radius:var(--radius-md);font-size:.85rem;z-index:10;cursor:pointer;transition:all var(--transition);overflow:hidden}.quality-indicator:hover{background:var(--color-surface-hover)}.quality-header{display:flex;align-items:center;gap:8px;padding:10px 14px}.quality-dot{width:10px;height:10px;border-radius:var(--radius-full);background:var(--color-text-muted);transition:background var(--transition)}.quality-indicator.excellent .quality-dot{background:var(--color-success)}.quality-indicator.good .quality-dot{background:var(--color-primary)}.quality-indicator.fair .quality-dot{background:#f59e0b}.quality-indicator.poor .quality-dot{background:var(--color-danger)}.quality-level{font-weight:500;color:var(--color-text)}.quality-details{padding:0 14px 12px;border-top:1px solid var(--color-border);margin-top:0}.quality-details:not(.hidden){padding-top:10px}.quality-row{display:flex;justify-content:space-between;gap:16px;padding:4px 0;color:var(--color-text-muted);font-size:.8rem}.quality-row span:last-child{color:var(--color-text);font-weight:500;font-family:SF Mono,Monaco,Inconsolata,monospace}.peer-left-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#000000e6;z-index:20}.peer-left-content{display:flex;flex-direction:column;align-items:center;gap:24px;padding:32px;max-width:400px;width:100%}.peer-left-video-container{width:100%;max-width:320px;aspect-ratio:4/3;border-radius:var(--radius-lg);overflow:hidden;background:var(--color-surface);box-shadow:var(--shadow-lg)}.peer-left-video-container video{width:100%;height:100%;object-fit:cover;transform:scaleX(-1)}.peer-left-message{text-align:center}.peer-left-message p{font-size:1.25rem;color:var(--color-text);margin:0}.peer-left-message span{font-weight:600;color:var(--color-primary)}.call-type-selector{display:flex;gap:12px;width:100%}.btn-call-type{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px;padding:20px 16px;font-size:.95rem}.btn-call-type svg{width:32px;height:32px}.audio-preview{width:100%;max-width:320px;aspect-ratio:4/3;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;border-radius:var(--radius-lg);background:var(--color-surface);box-shadow:var(--shadow)}.audio-avatar{width:100px;height:100px;border-radius:var(--radius-full);background:var(--color-surface-hover);display:flex;align-items:center;justify-content:center;color:var(--color-primary)}.audio-label{font-size:.95rem;color:var(--color-text-muted)}.audio-call-placeholder{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px;background:var(--color-surface)}.audio-call-avatar{width:140px;height:140px;border-radius:var(--radius-full);background:var(--color-surface-hover);display:flex;align-items:center;justify-content:center;color:var(--color-primary);animation:audio-pulse 2s ease-in-out infinite}.audio-call-label{font-size:1.25rem;color:var(--color-text-muted);margin:0}@keyframes audio-pulse{0%,to{transform:scale(1);box-shadow:0 0 #6366f166}50%{transform:scale(1.02);box-shadow:0 0 0 20px #6366f100}}.local-audio-indicator{position:absolute;right:20px;bottom:20px;width:60px;height:60px;border-radius:var(--radius-full);background:var(--color-surface);display:flex;align-items:center;justify-content:center;color:var(--color-primary);box-shadow:var(--shadow-lg);border:3px solid var(--color-bg)}.hidden{display:none!important}@media (max-width: 480px){.container{padding:16px}.logo{font-size:2.5rem}.card{padding:20px}.input-group{flex-direction:column}.input-group .btn{width:100%}.local-video-wrapper{width:120px;right:12px;bottom:12px}.call-controls{gap:12px;padding:16px}.btn-control{width:48px;height:48px}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.status-message{animation:pulse 2s ease-in-out infinite}.legal-agreement{font-size:.75rem;color:var(--color-text-muted);text-align:center;margin-top:16px;line-height:1.5}.legal-agreement a{color:var(--color-primary);text-decoration:none}.legal-agreement a:hover{text-decoration:underline}.cookie-banner{position:fixed;bottom:0;left:0;right:0;background:var(--color-surface);border-top:1px solid var(--color-border);padding:16px 20px;z-index:1000;box-shadow:0 -4px 20px #0000004d}.cookie-content{max-width:800px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}.cookie-content p{margin:0;font-size:.875rem;color:var(--color-text-muted);flex:1;min-width:200px}.cookie-content a{color:var(--color-primary);text-decoration:none}.cookie-content a:hover{text-decoration:underline}.btn-cookie{background:var(--color-primary);color:#fff;padding:8px 24px;border-radius:var(--radius-md);font-size:.875rem;font-weight:500;border:none;cursor:pointer;white-space:nowrap}.btn-cookie:hover{background:var(--color-primary-hover)}@media (max-width: 480px){.cookie-content{flex-direction:column;text-align:center}.cookie-content p{min-width:100%}.btn-cookie{width:100%}}.site-footer{position:fixed;bottom:0;left:0;right:0;padding:.75rem 1rem;text-align:center;font-size:.75rem;color:var(--color-text-muted);background:linear-gradient(transparent,var(--color-bg) 50%);z-index:10}.site-footer a{color:var(--color-text-muted);text-decoration:none;transition:color var(--transition)}.site-footer a:hover{color:var(--color-primary)}.footer-divider{margin:0 .5rem;opacity:.5}
