:root{--bg:#f8f7f4;--bg-card:#fff;--bg-input:#fff;--border:#dddbd6;--border-focus:#ff5e00;--text-primary:#141414;--text-secondary:#6b6860;--text-muted:#a09d98;--accent:#ff5e00;--accent-hover:#e55400;--accent-active:#cc4a00;--accent-text:#fff;--link:#ff5e00;--shadow-card:0 4px 32px 0 #00000014, 0 1px 4px 0 #0000000a;--shadow-btn:0 4px 16px 0 #ff5e004d;--radius-card:22px;--radius-input:12px;--radius-btn:12px}[data-theme=dark]{--bg:#111;--bg-card:#1a1a1a;--bg-input:#242424;--border:#303030;--border-focus:#ff5e00;--text-primary:#f0ede8;--text-secondary:#9a9794;--text-muted:#585552;--accent:#ff5e00;--accent-hover:#ff7020;--accent-active:#ff8a40;--accent-text:#fff;--link:#ff7a28;--shadow-card:0 4px 40px 0 #00000080, 0 1px 4px 0 #0000004d;--shadow-btn:0 4px 20px 0 #ff5e0061}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;font-size:16px}body{background:var(--bg);color:var(--text-primary);min-height:100vh;font-family:Inter,system-ui,-apple-system,sans-serif;font-weight:400;transition:background .25s,color .25s}#root{flex-direction:column;min-height:100vh;display:flex}a{color:var(--link);font-weight:500;text-decoration:none;transition:opacity .15s}a:hover{opacity:.8;text-decoration:underline}button{cursor:pointer;background:0 0;border:none;font-family:inherit}input{font-family:inherit}.lobby{background:var(--bg);flex-direction:column;min-height:100vh;transition:background .25s;display:flex}.lobby-header{z-index:50;background:var(--bg-card);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;height:60px;padding:0 20px;transition:background .25s,border-color .25s;display:flex;position:sticky;top:0}.lobby-brand{align-items:center;gap:9px;display:flex}.lobby-logo-mark{background:var(--accent);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;display:flex}.lobby-logo-mark svg{width:18px;height:18px}.lobby-brand-name{letter-spacing:-.3px;color:var(--text-primary);font-size:15px;font-weight:600}.lobby-user{align-items:center;gap:8px;display:flex}.lobby-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.lobby-dot--ok{background:#1a7d3e}.lobby-dot--spin{background:var(--text-muted);animation:1.2s ease-in-out infinite pulse}[data-theme=dark] .lobby-dot--ok{background:#4cba72}@keyframes pulse{0%,to{opacity:1}50%{opacity:.35}}.lobby-requests-btn{border:1.5px solid var(--border);width:34px;height:34px;color:var(--text-muted);cursor:pointer;background:0 0;border-radius:50%;justify-content:center;align-items:center;transition:border-color .15s,color .15s;display:flex;position:relative}.lobby-requests-btn:hover{border-color:var(--accent);color:var(--accent)}.lobby-requests-badge{background:var(--accent);color:#fff;border-radius:8px;justify-content:center;align-items:center;min-width:16px;height:16px;padding:0 3px;font-size:9px;font-weight:700;line-height:1;display:flex;position:absolute;top:-4px;right:-4px}.requests-panel{background:var(--bg-card);border:1.5px solid var(--border);border-radius:14px;flex-direction:column;gap:10px;margin-bottom:16px;padding:14px 16px;display:flex}.requests-panel-title{letter-spacing:.07em;text-transform:uppercase;color:var(--text-muted);font-size:11px;font-weight:600}.request-row{justify-content:space-between;align-items:center;gap:8px;display:flex}.request-from{color:var(--text-primary);font-size:14px;font-weight:500}.request-actions{gap:6px;display:flex}.req-btn{cursor:pointer;border:1.5px solid #0000;border-radius:8px;height:32px;padding:0 12px;font-family:inherit;font-size:12.5px;font-weight:600;transition:background .15s,opacity .15s}.req-btn--accept{background:var(--accent);color:#fff}.req-btn--accept:hover{background:var(--accent-hover)}.req-btn--reject{border-color:var(--border);color:var(--text-secondary);background:0 0}.req-btn--reject:hover{border-color:var(--text-secondary)}.lobby-user-avatar{background:var(--accent);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:11px;font-weight:700;display:flex;box-shadow:0 2px 8px #ff5e004d}.lobby-username{color:var(--text-secondary);letter-spacing:.01em;font-size:13.5px;font-weight:500}.lobby-theme-btn,.lobby-logout{border:1.5px solid var(--border);width:34px;height:34px;color:var(--text-muted);cursor:pointer;background:0 0;border-radius:50%;justify-content:center;align-items:center;transition:border-color .15s,color .15s,background .15s;display:flex}.lobby-theme-btn:hover{border-color:var(--text-secondary);color:var(--text-primary)}.lobby-logout:hover{border-color:var(--accent);color:var(--accent);background:#ff5e000f}.lobby-main{flex-direction:column;flex:1;gap:6px;width:100%;max-width:560px;margin:0 auto;padding:28px 20px 120px;display:flex}.lobby-section-header{justify-content:space-between;align-items:center;margin-bottom:14px;display:flex}.lobby-section-title{letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);font-size:11px;font-weight:600}.lobby-add-btn{color:var(--accent);cursor:pointer;background:0 0;border:none;align-items:center;gap:5px;padding:4px 0;font-size:13px;font-weight:500;transition:opacity .15s;display:flex}.lobby-add-btn:hover{opacity:.75}.lobby-add-btn svg{width:15px;height:15px}.add-contact-form{background:var(--bg-card);border:1.5px solid var(--border);border-radius:14px;flex-direction:column;gap:10px;margin-bottom:16px;padding:14px 16px;transition:background .2s,border-color .2s;display:flex}.add-contact-row{gap:8px;display:flex}.add-contact-input{background:var(--bg-input);border:1.5px solid var(--border);height:42px;color:var(--text-primary);-webkit-appearance:none;border-radius:10px;outline:none;flex:1;padding:0 14px;font-family:inherit;font-size:14px;font-weight:400;transition:border-color .18s,box-shadow .18s}.add-contact-input::placeholder{color:var(--text-muted)}.add-contact-input:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px #ff5e001f}.add-contact-submit{background:var(--accent);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:10px;height:42px;padding:0 18px;font-family:inherit;font-size:13.5px;font-weight:600;transition:background .15s,opacity .15s,transform .1s}.add-contact-submit:hover:not(:disabled){background:var(--accent-hover)}.add-contact-submit:active:not(:disabled){transform:scale(.97)}.add-contact-submit:disabled{opacity:.5;cursor:not-allowed}.add-contact-msg{border-radius:8px;padding:8px 12px;font-size:13px;font-weight:400;line-height:1.4}.add-contact-error{color:#c0392b;background:#c0392b12;border:1px solid #c0392b29}[data-theme=dark] .add-contact-error{color:#e8614f;background:#c0392b21;border-color:#c0392b42}.add-contact-success{color:#1a7d3e;background:#1a7d3e12;border:1px solid #1a7d3e29}[data-theme=dark] .add-contact-success{color:#4cba72;background:#1a7d3e1f;border-color:#1a7d3e40}.lobby-empty{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:72px 24px 56px;display:flex}.lobby-empty-icon{background:linear-gradient(145deg, var(--bg-card) 0%, var(--bg) 100%);border:1.5px solid var(--border);border-radius:24px;justify-content:center;align-items:center;width:72px;height:72px;margin-bottom:8px;display:flex;box-shadow:0 4px 20px #0000000d,0 1px 4px #0000000a}.lobby-empty-icon svg{opacity:.5;width:36px;height:36px}.lobby-empty-title{color:var(--text-primary);letter-spacing:-.3px;font-size:17px;font-weight:700}.lobby-empty-sub{color:var(--text-secondary);max-width:260px;font-size:14px;font-weight:400;line-height:1.6}.contacts-list{flex-direction:column;gap:2px;list-style:none;display:flex}.contact-item{cursor:pointer;border-radius:14px;align-items:center;gap:12px;padding:12px 14px;transition:background .12s;display:flex}.contact-item:hover{background:var(--bg-card)}.contact-avatar{background:var(--accent);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:15px;font-weight:600;display:flex;position:relative}.contact-presence-dot{width:10px;height:10px;box-shadow:0 0 0 2px var(--bg);background:#22c55e;border-radius:50%;position:absolute;bottom:1px;right:1px}.contact-name{color:var(--text-primary);flex:1;font-size:14.5px;font-weight:500}.contact-chevron{color:var(--text-muted);align-items:center;transition:color .12s;display:flex}.contact-item:hover .contact-chevron{color:var(--accent)}.contact-item--offline .contact-avatar{background:var(--border);color:var(--text-muted)}.contact-item--offline .contact-name{color:var(--text-secondary)}.contact-item--offline .contact-chevron{opacity:.5}.contacts-separator{align-items:center;gap:10px;padding:8px 14px 4px;list-style:none;display:flex}.contacts-separator span{letter-spacing:.07em;text-transform:uppercase;color:var(--text-muted);font-size:10.5px;font-weight:600}.contacts-separator:before,.contacts-separator:after{content:"";background:var(--border);flex:1;height:1px}.incoming-call{z-index:200;background:var(--bg-card);border:1.5px solid var(--accent);border-radius:16px;justify-content:space-between;align-items:center;gap:12px;width:calc(100% - 32px);max-width:520px;padding:14px 16px;animation:.2s slideDown;display:flex;position:fixed;top:68px;left:50%;transform:translate(-50%);box-shadow:0 4px 24px #ff5e002e,0 1px 6px #00000014}@keyframes slideDown{0%{opacity:0;transform:translate(-50%)translateY(-8px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.incoming-call-text{color:var(--text-primary);align-items:center;gap:9px;min-width:0;font-size:14px;line-height:1.4;display:flex}.incoming-call-text strong{font-weight:600}.incoming-call-actions{flex-shrink:0;gap:7px;display:flex}.incoming-btn{cursor:pointer;white-space:nowrap;border:1.5px solid #0000;border-radius:9px;height:34px;padding:0 14px;font-family:inherit;font-size:13px;font-weight:600;transition:background .15s,opacity .15s,transform .1s}.incoming-btn--accept{background:var(--accent);color:#fff}.incoming-btn--accept:hover{background:var(--accent-hover)}.incoming-btn--accept:active{transform:scale(.97)}.incoming-btn--dismiss{border-color:var(--border);color:var(--text-secondary);background:0 0}.incoming-btn--dismiss:hover{border-color:var(--text-secondary)}.lobby-footer{background:linear-gradient(to top, var(--bg) 65%, transparent);pointer-events:none;justify-content:center;padding:12px 20px 24px;display:flex;position:fixed;bottom:0;left:0;right:0}.lobby-footer-inner{pointer-events:all;flex-direction:column;align-items:center;gap:10px;width:100%;max-width:520px;display:flex}.lobby-footer-btns{align-items:center;gap:8px;display:flex}.btn-anon-room{border:1.5px solid var(--border);background:var(--bg-card);height:46px;color:var(--text-primary);cursor:pointer;border-radius:23px;align-items:center;gap:8px;padding:0 24px;font-family:inherit;font-size:13.5px;font-weight:500;transition:border-color .15s,box-shadow .15s,transform .1s,background .2s;display:flex;box-shadow:0 2px 12px #00000012}.btn-anon-room svg{width:15px;height:15px;color:var(--accent)}.btn-anon-room:hover{border-color:var(--accent);transform:translateY(-1px);box-shadow:0 4px 18px #ff5e002e}.btn-anon-room:active{transform:translateY(0)}.btn-join-room{border:1.5px solid var(--border);height:46px;color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:23px;padding:0 20px;font-family:inherit;font-size:13.5px;font-weight:500;transition:border-color .15s,color .15s}.btn-join-room:hover{border-color:var(--text-secondary);color:var(--text-primary)}.join-room-form{background:var(--bg-card);border:1.5px solid var(--border);border-radius:14px;align-items:center;gap:6px;width:100%;max-width:420px;padding:10px 12px;transition:background .2s,border-color .2s;display:flex;box-shadow:0 2px 12px #00000012}.join-room-input{background:var(--bg-input);border:1.5px solid var(--border);letter-spacing:.12em;text-transform:uppercase;height:36px;color:var(--text-primary);-webkit-appearance:none;border-radius:8px;outline:none;flex:1;padding:0 12px;font-family:Courier New,monospace;font-size:15px;font-weight:600;transition:border-color .18s,box-shadow .18s}.join-room-input::placeholder{color:var(--text-muted);letter-spacing:0;font-family:inherit;font-size:13px;font-weight:400}.join-room-input:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px #ff5e001f}.join-room-submit{background:var(--accent);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:8px;height:36px;padding:0 16px;font-family:inherit;font-size:13px;font-weight:600;transition:background .15s,opacity .15s}.join-room-submit:hover:not(:disabled){background:var(--accent-hover)}.join-room-submit:disabled{opacity:.45;cursor:not-allowed}.join-room-cancel{border:1.5px solid var(--border);height:36px;color:var(--text-secondary);cursor:pointer;white-space:nowrap;background:0 0;border-radius:8px;padding:0 12px;font-family:inherit;font-size:13px;font-weight:500;transition:border-color .15s}.join-room-cancel:hover{border-color:var(--text-secondary)}.room-code-reveal{background:var(--surface-2,var(--surface));border:1.5px solid var(--border);border-radius:10px;flex-direction:column;gap:10px;margin-bottom:10px;padding:14px 16px;display:flex}.room-code-label{color:var(--text-secondary);margin:0;font-size:12px}.room-code-row{align-items:center;gap:10px;display:flex}.room-code-text{letter-spacing:.18em;font-variant-numeric:tabular-nums;color:var(--text-primary);flex:1;font-size:26px;font-weight:700}.room-code-copy{border:1.5px solid var(--border);height:34px;color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:7px;padding:0 14px;font-size:13px;transition:border-color .15s,color .15s}.room-code-copy:hover{border-color:var(--text-secondary);color:var(--text-primary)}.room-code-actions{justify-content:flex-end;gap:6px;display:flex}.lobby-toast{z-index:200;background:var(--bg-card);border:1.5px solid var(--border);color:var(--text-primary);white-space:nowrap;pointer-events:none;border-radius:12px;padding:10px 18px;font-size:13.5px;font-weight:500;animation:.2s toastIn;position:fixed;bottom:110px;left:50%;transform:translate(-50%);box-shadow:0 4px 20px #0000001a}@keyframes toastIn{0%{opacity:0;transform:translate(-50%)translateY(8px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.chat{background:var(--bg);flex-direction:column;height:100vh;display:flex}.chat-header{z-index:50;background:var(--bg-card);border-bottom:1px solid var(--border);align-items:center;gap:12px;height:60px;padding:0 16px;transition:background .25s,border-color .25s;display:flex;position:sticky;top:0}.chat-back{border:1.5px solid var(--border);width:36px;height:36px;color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;transition:border-color .15s,color .15s;display:flex}.chat-back:hover{border-color:var(--accent);color:var(--accent)}.chat-header-info{flex:1;align-items:center;gap:10px;min-width:0;display:flex}.chat-contact-avatar{background:var(--accent);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:13px;font-weight:600;display:flex}.chat-header-text{flex-direction:column;min-width:0;display:flex}.chat-contact-name{color:var(--text-primary);letter-spacing:-.2px;white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:600;overflow:hidden}.chat-status-label{margin-top:1px;font-size:11px;font-weight:400}.chat-status--ready{color:#1a7d3e}.chat-status--handshake,.chat-status--connecting{color:var(--text-muted)}.chat-status--error{color:#c0392b}[data-theme=dark] .chat-status--ready{color:#4cba72}[data-theme=dark] .chat-status--error{color:#e8614f}.chat-header-lock{color:var(--text-muted);flex-shrink:0;align-items:center;display:flex}.chat-messages{box-sizing:border-box;flex-direction:column;flex:1;align-self:stretch;gap:4px;width:100%;max-width:680px;margin:0 auto;padding:16px 16px 8px;display:flex;overflow-y:auto}.chat-empty{flex:1;justify-content:center;align-items:center;display:flex}.chat-empty-text{color:var(--text-muted);text-align:center;font-size:13px;line-height:1.5}.chat-handshake-spinner{color:var(--text-muted);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:14px;font-size:13px;display:flex}.chat-error-text{color:#c0392b}[data-theme=dark] .chat-error-text{color:#e8614f}.chat-spinner{border:2.5px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:24px;height:24px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.chat-bubble-row{max-width:72%;display:flex}.chat-bubble-row.mine{align-self:flex-end}.chat-bubble-row.sys{align-self:center;max-width:100%}.chat-bubble{word-break:break-word;white-space:pre-wrap;border-radius:18px;padding:9px 14px;font-size:14.5px;font-weight:400;line-height:1.5}.chat-bubble--mine{background:var(--accent);color:#fff;border-bottom-right-radius:5px}.chat-bubble--theirs{background:var(--bg-card);color:var(--text-primary);border:1px solid var(--border);border-bottom-left-radius:5px}.chat-sys-msg{color:var(--text-muted);text-align:center;background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:4px 10px;font-size:11.5px;line-height:1.4}.chat-input-bar{background:var(--bg-card);border-top:1px solid var(--border);box-sizing:border-box;align-self:stretch;align-items:flex-end;gap:10px;width:100%;max-width:680px;margin:0 auto;padding:12px 16px 20px;transition:background .25s,border-color .25s;display:flex}.chat-input{background:var(--bg-input);border:1.5px solid var(--border);min-height:44px;max-height:120px;color:var(--text-primary);resize:none;-webkit-appearance:none;border-radius:22px;outline:none;flex:1;padding:11px 14px;font-family:inherit;font-size:14.5px;font-weight:400;line-height:1.45;transition:border-color .18s,box-shadow .18s;overflow-y:auto}.chat-input::placeholder{color:var(--text-muted)}.chat-input:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px #ff5e001f}.chat-input:disabled{opacity:.5;cursor:not-allowed}.chat-send-btn{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;transition:background .15s,transform .1s,opacity .15s;display:flex;box-shadow:0 2px 10px #ff5e0059}.chat-send-btn:hover:not(:disabled){background:var(--accent-hover);transform:scale(1.06)}.chat-send-btn:active:not(:disabled){transform:scale(.96)}.chat-send-btn:disabled{opacity:.4;cursor:not-allowed;transform:none}.chat-bubble-wrap{flex-direction:column;gap:3px;display:flex}.chat-bubble-time{color:var(--text-muted);padding:0 4px;font-size:10.5px}.chat-bubble-time--mine{text-align:right}.chat-typing-bubble{background:var(--bg-card);border:1px solid var(--border);border-radius:18px 18px 18px 5px;align-items:center;gap:5px;padding:11px 16px;display:flex}.chat-typing-dot{background:var(--text-muted);border-radius:50%;width:7px;height:7px;animation:1.2s ease-in-out infinite typingBounce}.chat-typing-dot:nth-child(2){animation-delay:.2s}.chat-typing-dot:nth-child(3){animation-delay:.4s}@keyframes typingBounce{0%,60%,to{opacity:.4;transform:translateY(0)}30%{opacity:1;transform:translateY(-5px)}}.chat-anon-avatar{background:var(--bg);border:1.5px solid var(--border);color:var(--accent)}.chat-room-waiting{text-align:center;flex-direction:column;align-items:center;gap:12px;padding:16px 24px;display:flex}.chat-room-label{letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);margin:0;font-size:11px;font-weight:600}.chat-room-code{letter-spacing:.18em;color:var(--text-primary);font-variant-numeric:tabular-nums;font-family:Courier New,monospace;font-size:32px;font-weight:700}.chat-room-copy{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:18px;height:36px;padding:0 20px;font-family:inherit;font-size:13px;font-weight:600;transition:background .15s,transform .1s}.chat-room-copy:hover{background:var(--accent-hover)}.chat-room-copy:active{transform:scale(.97)}.chat-room-hint{color:var(--text-muted);max-width:220px;margin:0;font-size:12.5px;line-height:1.4}.chat-input-wrap{flex-shrink:0;align-items:flex-end;display:flex;position:relative}.chat-emoji-btn{width:40px;height:44px;color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:0;transition:color .15s,background .15s;display:flex}.chat-emoji-btn:hover:not(:disabled){color:var(--accent);background:#ff5e0014}.chat-emoji-btn:disabled{opacity:.35;cursor:not-allowed}.chat-emoji-picker{background:var(--bg-card);border:1px solid var(--border);z-index:200;border-radius:16px;width:284px;max-height:280px;padding:10px;animation:.15s cubic-bezier(.16,1,.3,1) emojiPickerIn;position:absolute;bottom:calc(100% + 8px);left:0;overflow-y:auto;box-shadow:0 8px 32px #00000029}@keyframes emojiPickerIn{0%{opacity:0;transform:translateY(8px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.chat-emoji-category{margin-bottom:8px}.chat-emoji-category-label{letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);margin-bottom:4px;padding:0 2px;font-size:10px;font-weight:600}.chat-emoji-grid{flex-wrap:wrap;gap:2px;display:flex}.chat-emoji-item{cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;padding:0;font-size:19px;line-height:1;transition:background .1s;display:flex}.chat-emoji-item:hover{background:var(--bg-input)}.chat-tick{letter-spacing:-1px;vertical-align:middle;margin-left:4px;font-size:10.5px;font-weight:600}.chat-tick--sent{color:var(--accent)}.chat-tick--delivered{color:var(--text-muted)}.chat-reply-quote{background:#0000000f;border-radius:10px;align-items:stretch;gap:7px;margin-bottom:5px;padding:5px 10px;display:flex;overflow:hidden}[data-theme=dark] .chat-reply-quote{background:#ffffff0f}.chat-reply-quote--mine{background:#ffffff26}.chat-reply-quote-bar{background:var(--accent);border-radius:2px;flex-shrink:0;align-self:stretch;width:3px;min-height:20px}.chat-reply-quote--mine .chat-reply-quote-bar{background:#ffffffb3}.chat-reply-quote-text{color:var(--text-secondary);word-break:break-word;-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:12px;line-height:1.4;display:-webkit-box;overflow:hidden}.chat-reply-quote--mine .chat-reply-quote-text{color:#fffc}.chat-reply-preview{background:var(--bg-card);border-top:1px solid var(--border);box-sizing:border-box;align-self:stretch;align-items:center;gap:10px;width:100%;max-width:680px;margin:0 auto;padding:8px 16px;transition:background .25s,border-color .25s;display:flex}.chat-reply-preview-bar{background:var(--accent);border-radius:2px;flex-shrink:0;width:3px;height:36px}.chat-reply-preview-content{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.chat-reply-preview-label{color:var(--accent);letter-spacing:.01em;font-size:11px;font-weight:600}.chat-reply-preview-text{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;font-size:12.5px;overflow:hidden}.chat-reply-cancel{background:var(--bg-input);width:28px;height:28px;color:var(--text-muted);cursor:pointer;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;transition:background .15s,color .15s;display:flex}.chat-reply-cancel:hover{background:var(--border);color:var(--text-secondary)}.chat-context-menu{z-index:300;background:var(--bg-card);border:1px solid var(--border);border-radius:10px;min-width:130px;animation:.12s cubic-bezier(.16,1,.3,1) contextMenuIn;position:fixed;overflow:hidden;box-shadow:0 4px 24px #00000029}@keyframes contextMenuIn{0%{opacity:0;transform:scale(.94)}to{opacity:1;transform:scale(1)}}.chat-context-item{text-align:left;width:100%;color:var(--text-primary);cursor:pointer;background:0 0;border:none;padding:10px 16px;font-family:inherit;font-size:14px;font-weight:500;transition:background .12s;display:block}.chat-context-item:hover{background:var(--bg-input)}.auth-page{background:linear-gradient(150deg,#fff9f5 0%,#f8f7f4 50%,#f2ede8 100%);flex-direction:column;flex:1;justify-content:center;align-items:center;min-height:100vh;padding:32px 16px 48px;transition:background .25s;display:flex}[data-theme=dark] .auth-page{background:linear-gradient(150deg,#181210 0%,#111 50%,#0e0c0b 100%)}.theme-toggle{z-index:100;background:var(--bg-card);border:1.5px solid var(--border);width:40px;height:40px;color:var(--text-secondary);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;font-size:18px;transition:background .2s,border-color .2s,color .2s,transform .12s;display:flex;position:fixed;top:20px;right:20px;box-shadow:0 1px 8px #00000012}.theme-toggle:hover{color:var(--text-primary);border-color:var(--accent);transform:scale(1.07)}@keyframes authFadeIn{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.auth-card{background:var(--bg-card);border-radius:var(--radius-card);width:100%;max-width:440px;box-shadow:var(--shadow-card);border:1px solid var(--border);flex-direction:column;align-items:stretch;padding:52px 48px 48px;transition:background .25s,border-color .25s,box-shadow .25s;animation:.45s cubic-bezier(.16,1,.3,1) both authFadeIn;display:flex}.auth-e2e{color:var(--text-muted);letter-spacing:.02em;justify-content:center;align-items:center;gap:6px;margin-top:20px;font-size:11.5px;font-weight:500;display:flex}.auth-e2e svg{opacity:.6;flex-shrink:0}@media (width<=480px){.auth-card{border-radius:16px;padding:40px 28px 36px}}.auth-logo{flex-direction:column;align-items:center;gap:18px;margin-bottom:44px;display:flex}.logo-mark{background:var(--accent);border-radius:22px;flex-shrink:0;justify-content:center;align-items:center;width:76px;height:76px;display:flex;box-shadow:0 8px 32px #ff5e0061,0 2px 8px #ff5e0038,0 0 0 1px #ff5e001f}.logo-mark svg{width:44px;height:44px}.logo-text{flex-direction:column;align-items:center;gap:4px;display:flex}.logo-wordmark{letter-spacing:-.8px;color:var(--text-primary);font-size:26px;font-weight:700;line-height:1}.logo-tagline{color:var(--text-muted);letter-spacing:.01em;font-size:12px;font-weight:400}.auth-header{text-align:center;margin-bottom:32px}.auth-title{letter-spacing:-.7px;color:var(--text-primary);margin-bottom:8px;font-size:28px;font-weight:700;line-height:1.15}.auth-subtitle{color:var(--text-secondary);font-size:15px;font-weight:400;line-height:1.55}.auth-form{flex-direction:column;gap:16px;display:flex}.form-field{flex-direction:column;gap:7px;display:flex}.form-label{color:var(--text-secondary);letter-spacing:.01em;font-size:13px;font-weight:500}.form-input{background:var(--bg-input);border:1.5px solid var(--border);border-radius:var(--radius-input);width:100%;height:52px;color:var(--text-primary);appearance:none;outline:none;padding:0 16px;font-size:15px;font-weight:400;transition:border-color .18s,box-shadow .18s,background .2s}.form-input::placeholder{color:var(--text-muted);font-weight:400}.form-input:focus{border-color:var(--border-focus);box-shadow:0 0 0 3.5px #ff5e0021}.input-wrapper{align-items:center;display:flex;position:relative}.input-wrapper .form-input{padding-right:50px}.input-eye{height:52px;color:var(--text-muted);cursor:pointer;background:0 0;border:none;outline:none;align-items:center;padding:0 2px;font-size:16px;transition:color .15s;display:flex;position:absolute;right:14px}.input-eye:hover{color:var(--text-secondary)}.btn-primary{background:var(--accent);width:100%;height:52px;color:var(--accent-text);border-radius:var(--radius-btn);letter-spacing:.01em;box-shadow:var(--shadow-btn);cursor:pointer;border:none;justify-content:center;align-items:center;margin-top:6px;font-size:15px;font-weight:600;transition:background .15s,box-shadow .15s,transform .1s;display:flex}.btn-primary:hover{background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 6px 24px #ff5e0061}.btn-primary:active{background:var(--accent-active);box-shadow:var(--shadow-btn);transform:translateY(0)}.btn-primary:disabled{opacity:.6;cursor:not-allowed;box-shadow:none;transform:none}.form-error{color:#c0392b;background:#c0392b12;border:1px solid #c0392b2e;border-radius:10px;padding:10px 14px;font-size:13.5px;font-weight:400;line-height:1.45}[data-theme=dark] .form-error{color:#e8614f;background:#c0392b21;border-color:#c0392b47}.auth-footer{text-align:center;color:var(--text-secondary);margin-top:26px;font-size:14px;line-height:1.5}.auth-footer a{color:var(--link);font-weight:500}.auth-footer a:hover{opacity:.8;text-decoration:underline}.page-footer{pointer-events:none;text-align:center;white-space:nowrap;flex-direction:column;align-items:center;gap:3px;width:100%;display:flex;position:fixed;bottom:16px}.version-badge{color:var(--text-secondary);letter-spacing:.02em;font-size:13px;font-weight:500}.impaxo-badge{color:var(--text-muted);letter-spacing:.02em;opacity:.7;font-size:10.5px;font-weight:400}
