@import"https://fonts.googleapis.com/css2?family=DM+Sans:opsz,wght@9..40,400;9..40,500;9..40,600&family=Syne:wght@500;600;700;800&display=swap";:root{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;line-height:1.6;font-weight:400;color-scheme:dark;color:#f8fafc;background-color:#020617;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh}a{font-weight:500;color:#3b82f6;text-decoration:none;transition:color .2s}a:hover{color:#60a5fa}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.2}p{margin-bottom:1rem}button{font-family:inherit;cursor:pointer;-webkit-user-select:none;user-select:none}input,textarea{font-family:inherit}*:focus-visible{outline:2px solid #3b82f6;outline-offset:2px}::selection{background-color:#3b82f64d;color:#f8fafc}html{scroll-behavior:smooth}:root{--bg-base: #050B18;--bg-surface: #0a1120;--bg-surface-alt: #121c33;--accent-primary: #5B5FFF;--accent-hover: #4a4edf;--text-primary: #ffffff;--text-secondary: #8b98a9;--border-light: rgba(255, 255, 255, .08);--danger: #ef4444;--font-heading: "Syne", sans-serif;--font-body: "DM Sans", sans-serif}[data-theme=light]{--bg-base: #f1f5f9;--bg-surface: #ffffff;--bg-surface-alt: #e2e8f0;--accent-primary: #4f46e5;--accent-hover: #4338ca;--text-primary: #0f172a;--text-secondary: #475569;--border-light: rgba(0, 0, 0, .1);color-scheme:light}.theme-toggle-btn{background:var(--bg-surface-alt);color:var(--text-primary);border:1px solid var(--border-light);width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:999;font-size:1.2rem;transition:all .2s}.theme-toggle-btn:hover{transform:scale(1.05);background:var(--bg-surface)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-body);background-color:var(--bg-base);color:var(--text-primary);-webkit-font-smoothing:antialiased;min-height:100vh;margin:0;overflow-x:hidden}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);letter-spacing:-.02em}.btn{font-family:var(--font-body);font-weight:500;font-size:1rem;padding:.875rem 1.5rem;border-radius:8px;cursor:pointer;transition:all .2s cubic-bezier(.16,1,.3,1);display:inline-flex;align-items:center;justify-content:center;gap:.5rem;border:1px solid transparent;width:100%}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background-color:var(--accent-primary);color:#fff}.btn-primary:hover:not(:disabled){background-color:var(--accent-hover);box-shadow:0 4px 12px #5b5fff40}.btn-outline{background-color:transparent;border-color:var(--border-light);color:var(--text-primary)}.btn-outline:hover:not(:disabled){background-color:var(--bg-surface-alt)}.btn-google{background-color:#fff;color:#000}.btn-google:hover:not(:disabled){background-color:#e5e5e5}.input{width:100%;padding:.875rem 1.25rem;border-radius:8px;background-color:var(--bg-surface);border:1px solid var(--border-light);color:var(--text-primary);font-family:var(--font-body);font-size:1rem;transition:border-color .2s,box-shadow .2s}.input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 2px #5b5fff26}.input::placeholder{color:var(--text-secondary)}.login-container{display:flex;min-height:100vh;width:100%}.login-left{display:none;min-height:100%;height:100%}.login-right{flex:1;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:2rem;animation:fadeIn .4s ease-out}.login-form-wrapper{width:100%;max-width:400px}.login-form-wrapper h1{font-size:2.5rem;margin-bottom:.5rem;font-weight:700}.login-form-wrapper p{color:var(--text-secondary);font-size:1.1rem;margin-bottom:2.5rem}.divider{display:flex;align-items:center;text-align:center;margin:1.5rem 0;color:var(--text-secondary);font-size:.875rem;text-transform:uppercase;letter-spacing:.05em}.divider:before,.divider:after{content:"";flex:1;border-bottom:1px solid var(--border-light)}.divider:not(:empty):before{margin-right:1rem}.divider:not(:empty):after{margin-left:1rem}.room-selection-container{display:flex;justify-content:center;align-items:center;min-height:100vh;padding:1.5rem;animation:slideUp .4s ease-out}.room-card{background-color:var(--bg-surface);border:1px solid var(--border-light);border-radius:16px;width:100%;max-width:420px;padding:2.5rem;box-shadow:0 8px 32px #0006}.room-card h2{font-size:2rem;margin-bottom:.5rem}.room-card p{color:var(--text-secondary);margin-bottom:2rem}.tab-buttons{display:flex;gap:.5rem;background-color:var(--bg-surface-alt);padding:.35rem;border-radius:10px;margin-bottom:1.5rem}.tab-btn{flex:1;padding:.6rem;border:none;background:transparent;color:var(--text-secondary);font-family:var(--font-body);font-weight:600;font-size:.95rem;border-radius:6px;cursor:pointer;transition:all .2s}.tab-btn.active{background-color:var(--bg-surface);color:var(--text-primary);box-shadow:0 2px 8px #0003}.form-group{margin-bottom:1rem}.form-group:last-of-type{margin-bottom:2rem}.error-msg{color:var(--danger);font-size:.875rem;margin-top:.5rem}.app-layout{display:flex;height:100vh;height:100dvh;background-color:var(--bg-base);overflow:hidden;position:relative}.sidebar{width:320px;background-color:var(--bg-surface);border-right:1px solid var(--border-light);display:flex;flex-direction:column;transition:transform .3s cubic-bezier(.16,1,.3,1);z-index:50;position:absolute;top:0;bottom:0;left:0;transform:translate(-100%)}.sidebar.mobile-open{transform:translate(0)}.sidebar-overlay{position:fixed;inset:0;background:#0009;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:40;opacity:0;pointer-events:none;transition:opacity .3s}.sidebar-overlay.mobile-open{opacity:1;pointer-events:auto}.sidebar-header{padding:1.5rem;border-bottom:1px solid var(--border-light);display:flex;justify-content:space-between;align-items:center}.sidebar-header h2{font-size:1.25rem}.close-sidebar-btn{background:transparent;border:none;color:var(--text-secondary);cursor:pointer;padding:.25rem;display:flex;align-items:center;justify-content:center}.sidebar-content{flex:1;overflow-y:auto;padding:1.5rem}.info-section{margin-bottom:2rem}.info-section h3{font-family:var(--font-body);font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);margin-bottom:1rem}.room-code-display{background-color:var(--bg-base);border:1px solid var(--border-light);padding:1rem;border-radius:8px;display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.room-code-display span{font-family:var(--font-heading);font-weight:700;font-size:1.25rem;letter-spacing:.1em}.icon-btn{background:transparent;border:none;color:var(--text-secondary);cursor:pointer;transition:color .2s;display:flex;align-items:center;justify-content:center}.icon-btn:hover{color:var(--text-primary)}.qr-code-wrapper{background-color:#fff;padding:1rem;border-radius:12px;display:flex;justify-content:center;align-items:center}.user-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 0;border-bottom:1px solid rgba(255,255,255,.03)}.user-avatar{width:36px;height:36px;border-radius:50%;background-color:var(--bg-surface-alt);display:flex;align-items:center;justify-content:center;font-weight:600;color:var(--accent-primary);flex-shrink:0;overflow:hidden;border:1px solid var(--border-light)}.user-avatar img{width:100%;height:100%;object-fit:cover}.sidebar-footer{padding:1.5rem;border-top:1px solid var(--border-light)}.chat-main{flex:1;display:flex;flex-direction:column;height:100vh;height:100dvh;position:relative}.chat-header{height:64px;padding:0 1rem;display:flex;align-items:center;justify-content:space-between;background-color:var(--bg-surface);border-bottom:1px solid var(--border-light);flex-shrink:0}.chat-header-left{display:flex;align-items:center;gap:1rem}.hamburger-btn{background:transparent;border:none;color:var(--text-primary);cursor:pointer;display:flex;align-items:center;justify-content:center;padding:.25rem}.chat-title{display:flex;flex-direction:column}.chat-title h2{font-size:1.1rem;line-height:1.2}.chat-title span{font-size:.8rem;color:var(--text-secondary)}.chat-messages{flex:1;overflow-y:auto;padding:1.5rem 1rem;display:flex;flex-direction:column;gap:1rem;scroll-behavior:smooth;background-image:radial-gradient(circle at center,rgba(255,255,255,.01) 1px,transparent 1px);background-size:20px 20px}.message-wrapper{display:flex;flex-direction:column;max-width:85%;animation:popIn .3s cubic-bezier(.16,1,.3,1)}.message-wrapper.received{align-self:flex-start}.message-wrapper.sent{align-self:flex-end;align-items:flex-end}.message-sender{font-size:.75rem;color:var(--text-secondary);margin-bottom:.25rem;padding:0 .5rem}.message-bubble{padding:.6rem .8rem;border-radius:16px;position:relative;font-size:.95rem;line-height:1.4;word-wrap:break-word}.received .message-bubble{background-color:var(--bg-surface);border-bottom-left-radius:4px;border:1px solid var(--border-light)}.sent .message-bubble{background-color:var(--accent-primary);color:#fff;border-bottom-right-radius:4px}.message-footer{display:flex;align-items:center;gap:.4rem;margin-top:.25rem;font-size:.7rem;color:var(--text-secondary);padding:0 .5rem}.sent .message-footer{justify-content:flex-end}.message-status svg{color:var(--accent-primary)}.typing-wrapper{display:flex;align-items:center;gap:.5rem;align-self:flex-start;color:var(--text-secondary);font-size:.85rem;margin-bottom:1rem;animation:fadeIn .3s}.dots{display:flex;gap:.2rem}.dot{width:5px;height:5px;border-radius:50%;background-color:var(--text-secondary);animation:bounce 1.4s infinite ease-in-out both}.dot:nth-child(1){animation-delay:-.32s}.dot:nth-child(2){animation-delay:-.16s}@keyframes bounce{0%,80%,to{transform:scale(.6);opacity:.4}40%{transform:scale(1);opacity:1}}.system-message{align-self:center;background-color:#ffffff0d;padding:.35rem .8rem;border-radius:12px;font-size:.75rem;color:var(--text-secondary);margin:.5rem 0;text-align:center;max-width:90%;border:1px solid var(--border-light)}.chat-input-area{padding:.75rem 1rem;background-color:var(--bg-surface);border-top:1px solid var(--border-light);display:flex;align-items:flex-end;gap:.5rem;padding-bottom:max(.75rem,env(safe-area-inset-bottom))}.input-pill{flex:1;background-color:var(--bg-base);border:1px solid var(--border-light);border-radius:24px;display:flex;align-items:center;padding:.25rem .5rem;min-height:44px;transition:border-color .2s}.input-pill:focus-within{border-color:var(--accent-primary)}.emoji-btn{background:transparent;border:none;color:var(--text-secondary);padding:.5rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:color .2s}.emoji-btn:hover{color:var(--text-primary)}.chat-input{flex:1;background:transparent;border:none;color:var(--text-primary);font-family:var(--font-body);font-size:.95rem;padding:.5rem;outline:none;resize:none;max-height:120px;line-height:1.4}.chat-input::placeholder{color:var(--text-secondary)}.send-btn{background-color:var(--accent-primary);color:#fff;border:none;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;flex-shrink:0;margin-bottom:2px}.send-btn:hover:not(:disabled){background-color:var(--accent-hover);transform:scale(1.05)}.send-btn:disabled{opacity:.5;background-color:var(--bg-surface-alt);cursor:not-allowed}.send-btn:active:not(:disabled){transform:scale(.95)}.message-content h1,.message-content h2,.message-content h3{margin:.5rem 0;font-weight:600}.message-content p{margin-bottom:.25rem}.message-content p:last-child{margin-bottom:0}.message-content code{background:#0006;padding:.1rem .3rem;border-radius:4px;font-family:monospace;font-size:.85em;color:#93c5fd}.message-content pre{background:#0006;padding:.75rem;border-radius:8px;overflow-x:auto;margin:.5rem 0;border:1px solid rgba(255,255,255,.05)}.message-content pre code{background:transparent;padding:0;color:#f8fafc}.message-content a{text-decoration:underline;text-underline-offset:2px;color:inherit}.message-content ul,.message-content ol{margin-left:1.25rem;margin-bottom:.5rem}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes popIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.scroll-bottom{position:absolute;bottom:80px;right:1.5rem;width:40px;height:40px;border-radius:50%;background-color:var(--bg-surface-alt);border:1px solid var(--border-light);color:var(--text-primary);display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:10;box-shadow:0 4px 12px #0000004d;transition:all .2s}.scroll-bottom:hover{background-color:var(--bg-surface);transform:translateY(-2px)}@media(min-width:768px){.login-left{display:flex;flex:1;background-color:var(--bg-surface);border-right:1px solid var(--border-light);flex-direction:column;justify-content:center;align-items:center;padding:3rem;position:relative;overflow:hidden;height:100%;min-height:100vh}.sidebar{position:static;transform:none;height:100vh}.sidebar-overlay,.hamburger-btn{display:none}.chat-messages{padding:2rem 3rem}.chat-input-area{padding:1rem 3rem}}a,.link-hover{transition:color .22s ease,opacity .22s ease}a:hover{opacity:.85}.btn{position:relative;overflow:hidden}.btn:after{content:"";position:absolute;inset:0;background:#ffffff0f;opacity:0;transition:opacity .2s ease;border-radius:inherit;pointer-events:none}.btn:hover:not(:disabled):after{opacity:1}.btn-primary{background-color:var(--accent-primary);color:#fff;transition:background-color .22s ease,box-shadow .22s ease,transform .15s ease}.btn-primary:hover:not(:disabled){background-color:var(--accent-hover);box-shadow:0 4px 18px #5b5fff59;transform:translateY(-1px)}.message-content a{color:#93c5fd;text-decoration:underline;text-underline-offset:2px;transition:color .18s ease}.message-content a:hover{color:#60a5fa}.spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.2);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.message-info-btn{opacity:1}@media(hover:hover)and (pointer:fine){.message-info-btn{opacity:0;transition:opacity .2s}.message-wrapper:hover .message-info-btn{opacity:1}}
