:root{--bg-primary: #0f172a;--bg-secondary: #1e293b;--text-primary: #f8fafc;--text-secondary: #94a3b8;--accent-color: #3b82f6;--accent-hover: #2563eb;--accent-glow: rgba(59, 130, 246, .5);--error-color: #ef4444;--success-color: #22c55e;--card-radius: 16px;--btn-radius: 12px;--glass-bg: rgba(15, 23, 42, .85);--glass-border: rgba(255, 255, 255, .1);--chat-width: 350px;--network-badge-height: 26px}body{margin:0;font-family:Inter,system-ui,-apple-system,sans-serif;background-color:var(--bg-primary);color:var(--text-primary);overflow:hidden}#root{width:100vw;height:100vh;height:100dvh}.app-container{position:relative;width:100%;height:100%;overflow:hidden;background:#000}.error-banner{position:absolute;top:80px;left:50%;transform:translate(-50%);z-index:60;background:#ef4444eb;color:#fff;padding:.9rem 2rem;border-radius:12px;text-align:center;font-weight:500;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(239,68,68,.4);box-shadow:0 8px 24px #ef44444d;animation:fadeIn .3s ease;max-width:90vw}@keyframes fadeIn{0%{opacity:0;transform:translate(-50%) translateY(-6px)}to{opacity:1;transform:translate(-50%) translateY(0)}}header{position:absolute;top:0;left:0;right:0;z-index:50;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;pointer-events:none}header>*{pointer-events:auto}.logo{font-size:1.5rem;font-weight:800;background:linear-gradient(to right,#60a5fa,#a78bfa);-webkit-background-clip:text;background-clip:text;color:transparent;text-shadow:0 2px 10px rgba(0,0,0,.3)}.status-badge{padding:6px 16px;border-radius:50px;background:#0006;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);display:flex;align-items:center;gap:8px;font-size:.875rem;font-weight:500}.status-dot{width:8px;height:8px;border-radius:50%}.status-dot.idle{background-color:#94a3b8}.status-dot.waiting{background-color:#eab308;animation:pulse 1.5s infinite}.status-dot.connecting{background-color:#3b82f6;animation:blink 1s infinite}.status-dot.connected{background-color:#22c55e;box-shadow:0 0 10px #22c55e}.status-dot.error{background-color:#ef4444}.network-badge{height:var(--network-badge-height);padding:0 10px;border-radius:50px;background:#00000073;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid currentColor;display:flex;align-items:center;gap:5px;font-size:.72rem;font-weight:600;letter-spacing:.04em;cursor:default;transition:opacity .3s ease;animation:fadeIn .4s ease;white-space:nowrap}.network-badge .quality-label{opacity:.7;font-weight:400;margin-left:2px}@media (max-width: 480px){.network-badge .quality-label{display:none}}@keyframes pulse{0%{opacity:.6;transform:scale(.9)}50%{opacity:1;transform:scale(1.1)}to{opacity:.6;transform:scale(.9)}}@keyframes blink{50%{opacity:.4}}.video-grid{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;background:#000;display:flex;align-items:center;justify-content:center}.overlay-center{position:absolute;top:0;right:0;bottom:0;left:0;z-index:10;background:#1e293bd1;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;text-align:center;padding:2rem}.overlay-center h2{font-size:1.5rem;margin:.5rem 0 0;color:var(--text-primary)}.spinner-icon{animation:spin 1s linear infinite;color:var(--accent-color)}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.start-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#0f172ad1;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:10}.btn-start{padding:1.5rem 4rem;font-size:1.5rem;border-radius:50px;border:none;color:#fff;cursor:pointer;display:flex;align-items:center;gap:12px;box-shadow:0 0 60px #3b82f680;transition:transform .2s ease,box-shadow .2s ease;background:linear-gradient(135deg,#3b82f6,#6366f1);font-weight:700;letter-spacing:.02em}.btn-start:hover{transform:scale(1.05);box-shadow:0 0 80px #6366f199}.btn-start:active{transform:scale(.98)}.no-camera-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#111;color:#555}.msg-badge{position:absolute;top:2px;right:2px;width:10px;height:10px;background:var(--error-color);border-radius:50%;border:2px solid #1e293b;pointer-events:none}.video-wrapper.remote-wrapper{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;z-index:1;background:#0d0d0d}.video-wrapper.remote-wrapper video{width:100%;height:100%;object-fit:contain;display:block}.video-wrapper.local-wrapper{position:absolute;bottom:120px;right:20px;width:240px;aspect-ratio:16/9;z-index:20;border-radius:12px;overflow:hidden;box-shadow:0 10px 30px #00000080;border:2px solid rgba(255,255,255,.1);background:#000;transition:all .3s ease}.video-wrapper.local-wrapper:hover{transform:scale(1.05);border-color:#ffffff4d}.video-wrapper.local-wrapper video{width:100%;height:100%;object-fit:cover;transform:scaleX(-1)}@media (max-width: 768px){.logo{font-size:1.2rem}header{padding:1rem}.video-wrapper.local-wrapper{top:70px;bottom:auto;right:16px;width:30vw;max-width:120px;aspect-ratio:3/4;border-radius:12px}}.controls-container{position:absolute;bottom:0;left:0;right:0;z-index:50;display:flex;justify-content:center;gap:12px;padding:20px;padding-bottom:max(20px,env(safe-area-inset-bottom));background:linear-gradient(to top,rgba(0,0,0,.9),transparent)}@media (max-width: 768px){.controls-container{background:#0f172ad9;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-top:1px solid rgba(255,255,255,.1);padding:12px;padding-bottom:max(16px,env(safe-area-inset-bottom));gap:16px;display:flex;justify-content:space-around;align-items:center}}.btn-primary{background:linear-gradient(135deg,#3b82f6,#6366f1);border:none;color:#fff;border-radius:var(--btn-radius);cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem 1.5rem;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:8px}.btn-primary:hover{filter:brightness(1.1);transform:translateY(-1px)}.btn-control{width:50px;height:50px;border-radius:50%;border:none;background:#ffffff1a;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;position:relative;flex-shrink:0}@media (max-width: 768px){.btn-control{width:48px;height:48px;background:transparent}.btn-control:hover{background:#ffffff1a}.btn-control.active{background:#3b82f633;color:var(--accent-color)}}.btn-control:hover{background:#fff3;transform:translateY(-2px)}.btn-control.active{background:var(--accent-color);color:#fff}.btn-control.danger{background:#ef444433;color:var(--error-color)}.btn-control.danger:hover{background:#ef444466}.btn-next{padding:0 24px;border-radius:25px;width:auto;font-weight:600;background:var(--text-primary);color:var(--bg-primary)}@media (max-width: 768px){.btn-next{padding:0 16px;height:40px;font-size:.9rem}}.btn-next:hover{background:#fff;transform:scale(1.05)}.reaction-bar{position:absolute;bottom:100px;left:50%;transform:translate(-50%);z-index:45;display:flex;gap:12px;padding:8px 16px;background:#ffffff1a;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:50px;animation:fadeIn .3s ease-out}@media (max-width: 768px){.reaction-bar{bottom:90px;gap:8px;padding:6px 16px;background:#0009;border:1px solid rgba(255,255,255,.1)}}.btn-reaction{background:transparent;border:none;font-size:1.5rem;cursor:pointer;transition:transform .1s;padding:4px;border-radius:50%}.btn-reaction:hover{transform:scale(1.3);background:#ffffff1a}.btn-reaction:active{transform:scale(.9)}.chat-panel{position:absolute;top:80px;bottom:100px;right:20px;width:350px;background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:20px;border:1px solid var(--glass-border);z-index:40;display:flex;flex-direction:column;box-shadow:0 20px 50px #00000080;animation:slideIn .3s cubic-bezier(.16,1,.3,1);max-height:calc(100vh - 180px)}@keyframes slideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.chat-header{padding:1rem;border-bottom:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;align-items:center}.chat-header h3{margin:0;font-size:1.1rem}.btn-icon{background:none;border:none;color:var(--text-secondary);cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s}.btn-icon:hover{background:#ffffff1a;color:var(--text-primary)}.chat-messages{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:12px}.chat-empty{height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text-secondary);opacity:.7}.message{max-width:80%;display:flex;flex-direction:column}.message-local{align-self:flex-end;align-items:flex-end}.message-remote{align-self:flex-start;align-items:flex-start}.message-bubble{padding:10px 16px;border-radius:18px;font-size:.95rem;line-height:1.4;word-break:break-word}.message-local .message-bubble{background:var(--accent-color);color:#fff;border-bottom-right-radius:4px}.message-remote .message-bubble{background:#ffffff1a;color:var(--text-primary);border-bottom-left-radius:4px}.message-time{font-size:.7rem;color:#fff6;margin-top:4px;padding:0 4px}.chat-input-area{padding:1rem;border-top:1px solid rgba(255,255,255,.1);display:flex;gap:10px;align-items:flex-end}.chat-input-area textarea{flex:1;background:#0003;border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:12px 16px;color:#fff;resize:none;font-family:inherit;outline:none;max-height:100px}.chat-input-area textarea:focus{border-color:var(--accent-color);background:#0000004d}.btn-send{background:var(--accent-color);border:none;width:42px;height:42px;border-radius:50%;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.btn-send:disabled{opacity:.5;cursor:not-allowed;background:#ffffff1a}.btn-send:not(:disabled):hover{transform:scale(1.1)}@media (max-width: 768px){.chat-panel{top:auto;bottom:0;left:0;right:0;width:100%;height:60dvh;border-radius:24px 24px 0 0;border-bottom:none;border-left:none;border-right:none;max-height:none;animation:slideUp .3s cubic-bezier(.16,1,.3,1);z-index:60}@keyframes slideIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}}.age-gate-container{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at center,#1e293b,#0f172a);z-index:100;padding:20px}.age-gate-card{background:#1e293b99;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--glass-border);padding:3rem;border-radius:24px;text-align:center;max-width:450px;width:100%;box-shadow:0 20px 50px #00000080}.icon-wrapper{background:linear-gradient(135deg,#3b82f633,#8b5cf633);width:80px;height:80px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 1.5rem;box-shadow:0 0 20px #3b82f633}.shield-icon{color:#60a5fa;filter:drop-shadow(0 0 8px rgba(96,165,250,.5))}.age-gate-card h1{font-size:2rem;margin:0 0 .5rem;background:linear-gradient(to right,#60a5fa,#a78bfa);-webkit-background-clip:text;background-clip:text;color:transparent}.actions-row{display:flex;gap:16px;margin-top:2rem;flex-direction:column}@media (min-width: 480px){.actions-row{flex-direction:row}}.btn-secondary{background:transparent;border:1px solid rgba(255,255,255,.2);color:var(--text-secondary)}.btn-secondary:hover{border-color:var(--text-primary);color:var(--text-primary)}
