*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--beige-50:#faf7f2;--beige-100:#f2ede3;--beige-200:#e8e0d0;--beige-300:#d5c9b2;--sand:#c9a96e;--sand-dark:#9a7535;--sand-hover:#b8923a;--warm-dark:#3d3328;--text-secondary:#7a6e5f;--text-muted:#a89d8f;--bubble-in:#ede8de;--red:#c0392b;--red-light:#fdf0ee}html,body{background:var(--beige-100);height:100%;font-family:DM Sans,sans-serif}#root{justify-content:center;align-items:center;width:100%;height:100%;display:flex}.login-wrap{flex-direction:column;align-items:center;gap:28px;width:100%;max-width:520px;padding:0 24px;display:flex}.logo{flex-direction:column;align-items:center;gap:10px;display:flex}.logo-icon{background:var(--sand);border-radius:16px;justify-content:center;align-items:center;width:52px;height:52px;display:flex}.logo-name{color:var(--warm-dark);letter-spacing:-.3px;font-family:Lora,serif;font-size:22px;font-weight:500}.logo-tagline{color:var(--text-muted);margin-top:-6px;font-size:13px}.login-card{background:var(--beige-50);border:.5px solid var(--beige-300);border-radius:18px;width:100%;padding:32px 28px 28px;box-shadow:0 4px 28px #3d332814}.card-title{color:var(--warm-dark);margin-bottom:6px;font-family:Lora,serif;font-size:20px;font-weight:500}.card-sub{color:var(--text-muted);margin-bottom:24px;font-size:13px}.field{flex-direction:column;gap:6px;margin-bottom:16px;display:flex}.field label{color:var(--text-secondary);font-size:12px;font-weight:500}.field-wrap{background:var(--beige-100);border:.5px solid var(--beige-300);border-radius:10px;align-items:center;transition:border-color .15s,background .15s;display:flex;position:relative}.field-wrap.error{border-color:var(--red);background:var(--red-light)}.field-wrap:focus-within{border-color:var(--sand);background:var(--beige-50)}.field-icon{color:var(--text-muted);pointer-events:none;flex-shrink:0;align-items:center;display:flex;position:absolute;left:12px}.field input{color:var(--warm-dark);background:0 0;border:none;border-radius:10px;outline:none;flex:1;min-width:0;padding:10px 12px 10px 38px;font-family:DM Sans,sans-serif;font-size:13px}.field input::placeholder{color:var(--text-muted)}.toggle-pw{cursor:pointer;color:var(--text-muted);background:0 0;border:none;border-radius:0 10px 10px 0;flex-shrink:0;justify-content:center;align-items:center;height:100%;padding:0 12px 0 4px;transition:color .15s;display:flex}.toggle-pw:hover{color:var(--text-secondary)}.btn-login{background:var(--sand);color:#fff;cursor:pointer;letter-spacing:.2px;border:none;border-radius:10px;width:100%;padding:11px;font-family:DM Sans,sans-serif;font-size:14px;font-weight:500;transition:background .15s,transform .1s,opacity .15s}.btn-login:hover:not(:disabled){background:var(--sand-hover)}.btn-login:active:not(:disabled){transform:scale(.985)}.btn-login.error{background:var(--red)}.divider-or{align-items:center;gap:10px;margin:20px 0;display:flex}.divider-or span{color:var(--text-muted);white-space:nowrap;font-size:11px}.divider-or:before,.divider-or:after{content:"";background:var(--beige-300);flex:1;height:.5px}.register-row{text-align:center;color:var(--text-secondary);font-size:13px}.register-row a{color:var(--sand-dark);font-weight:500;text-decoration:none}.register-row a:hover{text-decoration:underline}.success-msg{color:var(--sand-dark);text-align:center;background:#f4faf5;border:.5px solid #a8d5ad;border-radius:8px;margin-bottom:12px;padding:8px 12px;font-size:12px}.byline{color:var(--text-muted);align-items:center;gap:5px;font-size:12px;display:flex}.byline .heart{color:#e07070;font-size:13px;line-height:1}.byline strong{color:var(--text-secondary);font-weight:500}.app{background:var(--beige-50);border:.5px solid var(--beige-300);border-radius:18px;width:860px;height:620px;display:flex;overflow:hidden;box-shadow:0 8px 40px #3d33281f}.nav-rail{background:var(--beige-200);border-right:.5px solid var(--beige-300);flex-direction:column;flex-shrink:0;align-items:center;gap:4px;width:54px;padding:16px 0 12px;display:flex}.nav-btn{cursor:pointer;width:36px;height:36px;color:var(--text-secondary);background:0 0;border:none;border-radius:10px;justify-content:center;align-items:center;transition:background .15s,color .15s;display:flex;position:relative}.nav-btn:hover{background:var(--beige-300)}.nav-btn.active{background:var(--sand);color:#fff}.nav-spacer{flex:1}.logout-btn{cursor:pointer;width:36px;height:36px;color:var(--text-secondary);background:0 0;border:none;border-radius:10px;justify-content:center;align-items:center;transition:background .15s,color .15s;display:flex}.logout-btn:hover{background:var(--red-light);color:var(--red)}.badge{background:var(--red);border:1.5px solid var(--beige-200);border-radius:50%;width:7px;height:7px;position:absolute;top:5px;right:5px}@keyframes pulse{0%{box-shadow:0 0 #c0392b80}70%{box-shadow:0 0 0 5px #c0392b00}to{box-shadow:0 0 #c0392b00}}.badge.pulse{animation:.7s 2 pulse}.sidebar{background:var(--beige-100);border-right:.5px solid var(--beige-200);flex-direction:column;flex-shrink:0;width:210px;display:flex;overflow-x:hidden}.panel{flex-direction:column;flex:1;display:none;overflow:hidden}.panel.active{display:flex}.panel-head{color:var(--warm-dark);padding:16px 14px 10px;font-family:Lora,serif;font-size:15px;font-weight:500}.divider{background:var(--beige-200);height:.5px;margin:0 14px}.contact-list{flex:1;padding:8px;overflow-y:auto}.contact-list::-webkit-scrollbar{width:4px}.contact-list::-webkit-scrollbar-thumb{background:var(--beige-300);border-radius:4px}.contact{cursor:pointer;border-radius:10px;align-items:center;gap:9px;padding:9px 10px;transition:background .12s;display:flex}.contact.active{background:var(--beige-200)}.contact:hover:not(.active){background:#00000008}.avatar{background:var(--sand);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:11px;font-weight:500;display:flex}.avatar.gray{background:var(--beige-300);color:var(--text-secondary)}.contact-name{color:var(--warm-dark);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:500;overflow:hidden}.contact-preview{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;margin-top:1px;font-size:11px;overflow:hidden}.pending-empty{color:var(--text-muted);text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:10px;padding:20px;font-size:13px;display:flex}.search-box{background:var(--beige-50);border:.5px solid var(--beige-300);border-radius:9px;align-items:center;gap:7px;margin:10px 10px 8px;padding:8px 10px;display:flex}.search-box input{color:var(--warm-dark);background:0 0;border:none;outline:none;flex:1;font-family:DM Sans,sans-serif;font-size:12px}.search-box input::placeholder{color:var(--text-muted)}.search-results{flex:1;padding:4px 8px;overflow-y:auto}.search-hint{color:var(--text-muted);text-align:center;padding:16px 10px;font-size:12px}.search-user-card{border-radius:10px;align-items:center;gap:9px;width:100%;padding:9px 10px;transition:background .12s;display:flex;overflow:hidden}.search-user-card:hover{background:#00000008}.search-user-info{flex:1;min-width:0}.search-user-info .contact-name,.search-user-info .contact-preview{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.search-action-btn{cursor:pointer;border:1.5px solid #0000;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-family:DM Sans,sans-serif;font-weight:500;transition:background .15s,color .15s,border-color .15s;display:inline-flex}.btn-new-chat{background:var(--sand);color:#fff;border-color:var(--sand)}.btn-new-chat:hover{background:var(--sand-hover);border-color:var(--sand-hover)}.btn-add-friend{color:var(--sand-dark);border-color:var(--sand);background:0 0;font-size:18px;line-height:1}.btn-add-friend:hover{background:var(--sand);color:#fff;border-color:var(--sand)}.btn-add-friend:disabled{opacity:.55;cursor:default;pointer-events:none}.user-bar{border-top:.5px solid var(--beige-200);background:var(--beige-100);flex-shrink:0;align-items:center;gap:9px;padding:10px 12px;display:flex}.user-bar-avatar{background:var(--warm-dark);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:10px;font-weight:500;display:flex}.user-bar .uname{color:var(--warm-dark);white-space:nowrap;text-overflow:ellipsis;max-width:130px;font-size:13px;font-weight:500;overflow:hidden}.user-bar .uid{color:var(--text-muted);letter-spacing:.3px;white-space:nowrap;text-overflow:ellipsis;max-width:130px;font-size:10px;overflow:hidden}@keyframes slideIn{0%{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}.request-card{background:var(--beige-50);border:.5px solid var(--beige-300);border-radius:12px;padding:11px 12px;animation:.4s cubic-bezier(.22,1,.36,1) forwards slideIn}.request-top{align-items:center;gap:9px;margin-bottom:10px;display:flex}.request-avatar{background:var(--sand);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:11px;font-weight:500;display:flex}.request-name{color:var(--warm-dark);font-size:13px;font-weight:500}.request-uid{color:var(--text-muted);margin-top:1px;font-size:10px}.request-actions{gap:6px;display:flex}.req-btn{cursor:pointer;border:1.5px solid #0000;border-radius:7px;flex:1;padding:6px 0;font-family:DM Sans,sans-serif;font-size:11px;font-weight:500;transition:background .15s,color .15s,border-color .15s}.req-accept{background:var(--sand);color:#fff;border-color:var(--sand)}.req-accept:hover{background:var(--sand-hover);border-color:var(--sand-hover)}.req-decline{color:var(--text-secondary);border-color:var(--beige-300);background:0 0}.req-decline:hover{background:var(--red-light);color:var(--red);border-color:var(--red)}.accepted-card{background:#f4faf5;border:.5px solid #a8d5ad;border-radius:12px;padding:11px 12px;animation:.4s cubic-bezier(.22,1,.36,1) forwards slideIn}.accepted-top{align-items:center;gap:9px;margin-bottom:10px;display:flex}.accepted-avatar{color:#2e6e38;background:#c5e8c9;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:11px;font-weight:500;display:flex}.accepted-label{color:#3a8a47;align-items:center;gap:3px;margin-bottom:2px;font-size:10px;font-weight:500;display:flex}.accepted-name{color:var(--warm-dark);font-size:13px;font-weight:500}.accepted-uid{color:var(--text-muted);margin-top:1px;font-size:10px}.btn-start-convo{cursor:pointer;background:var(--sand);color:#fff;border:1.5px solid var(--sand);letter-spacing:.2px;border-radius:7px;justify-content:center;align-items:center;gap:5px;width:100%;padding:7px 0;font-family:DM Sans,sans-serif;font-size:11px;font-weight:500;transition:background .15s,border-color .15s;display:flex}.btn-start-convo:hover{background:var(--sand-hover);border-color:var(--sand-hover)}.chat-area{flex-direction:column;flex:1;min-width:0;display:flex}.chat-header{border-bottom:.5px solid var(--beige-200);flex-shrink:0;align-items:center;gap:10px;padding:14px 20px;display:flex}.chat-header-avatar{background:var(--sand);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:11px;font-weight:500;display:flex}.chat-header .hname{color:var(--warm-dark);font-family:Lora,serif;font-size:15px;font-weight:500}.chat-header .hstatus{color:var(--text-muted);font-size:11px}.messages{flex-direction:column;flex:1;gap:12px;padding:20px 20px 10px;display:flex;overflow-y:auto}.messages::-webkit-scrollbar{width:4px}.messages::-webkit-scrollbar-thumb{background:var(--beige-200);border-radius:4px}.msg-row{display:flex}.msg-row.out{justify-content:flex-end}.msg-wrap{align-items:flex-end;gap:6px;display:flex}.msg-wrap.out{flex-direction:row-reverse}.msg-rel{flex-direction:column;display:flex;position:relative}.msg-rel.out{align-items:flex-end}.dot-menu-btn{opacity:0;background:var(--beige-200);cursor:pointer;width:22px;height:22px;color:var(--text-secondary);border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;transition:opacity .15s,background .12s;display:flex}.msg-row.out:hover .dot-menu-btn{opacity:1}.dot-menu-btn:hover{background:var(--beige-300)}.bubble{word-break:break-word;border-radius:16px;max-width:260px;padding:9px 14px;font-size:13px;line-height:1.55}.bubble.in{background:var(--bubble-in);color:var(--warm-dark);border-bottom-left-radius:4px}.bubble.out{background:var(--sand);color:#fff;border-bottom-right-radius:4px}.bubble-deleted{color:var(--text-muted);border:.5px dashed var(--beige-300);border-radius:16px 16px 4px;align-items:center;gap:6px;padding:8px 14px;font-size:12px;display:flex}.ts{color:var(--text-muted);margin-top:3px;font-size:10px}.ts.r{text-align:right}.file-bubble{background:var(--beige-200);border:.5px solid var(--beige-300);border-radius:14px 14px 4px;max-width:240px;padding:11px 13px}.file-top{align-items:center;gap:8px;margin-bottom:10px;display:flex}.file-icon{background:var(--sand);border-radius:7px;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;display:flex}.ftitle{color:var(--warm-dark);word-break:break-word;font-size:11px;font-weight:500;line-height:1.4}.fsize{color:var(--text-muted);margin-top:1px;font-size:10px}.file-dl{color:var(--sand-dark);border:1.5px solid var(--sand);cursor:pointer;letter-spacing:.2px;background:0 0;border-radius:8px;justify-content:center;align-items:center;gap:6px;width:100%;padding:7px 12px;font-family:DM Sans,sans-serif;font-size:11px;font-weight:500;transition:background .15s,color .15s,border-color .15s;display:flex}.file-dl:hover{background:var(--sand-hover);color:#fff;border-color:var(--sand-hover)}.file-dl:hover svg{stroke:#fff}.dropdown{background:var(--beige-50);border:.5px solid var(--beige-300);z-index:100;border-radius:10px;min-width:110px;padding:4px;display:none;position:absolute;box-shadow:0 4px 16px #3d332821}.dropdown.open{display:block}.dd-item{cursor:pointer;color:var(--warm-dark);text-align:left;background:0 0;border:none;border-radius:7px;align-items:center;gap:8px;width:100%;padding:8px 10px;font-family:DM Sans,sans-serif;font-size:13px;transition:background .1s;display:flex}.dd-item:hover{background:var(--beige-100)}.dd-item.danger{color:var(--red)}.dd-item.danger:hover{background:var(--red-light)}.compose{border-top:.5px solid var(--beige-200);flex-shrink:0;align-items:center;gap:8px;padding:10px 16px 14px;display:flex}.attach-btn{border:.5px solid var(--beige-300);background:var(--beige-100);cursor:pointer;width:36px;height:36px;color:var(--text-secondary);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;transition:background .12s;display:flex}.attach-btn:hover{background:var(--beige-200)}.compose-input{background:var(--beige-100);border:.5px solid var(--beige-200);color:var(--warm-dark);border-radius:22px;outline:none;flex:1;padding:9px 16px;font-family:DM Sans,sans-serif;font-size:13px;transition:border-color .15s,background .15s}.compose-input::placeholder{color:var(--text-muted)}.compose-input:focus{border-color:var(--beige-300);background:var(--beige-50)}.send-btn{background:var(--sand);cursor:pointer;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;transition:background .15s;display:flex}.send-btn:hover{background:var(--sand-hover)}.chat-empty-state{color:var(--text-muted);text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:8px;padding:20px;font-size:13px;display:flex}.chat-empty-state .ename{color:var(--warm-dark);margin-top:4px;font-family:Lora,serif;font-size:16px}.chat-empty-state .esub{color:var(--text-muted);font-size:12px}.upload-container{width:100%;margin-top:6px}.progress-bg{background:#0000001a;border-radius:2px;height:4px;margin-bottom:4px;overflow:hidden}.progress-fill{background:var(--sand-dark);height:100%;transition:width .2s}.upload-actions{color:var(--text-muted);justify-content:space-between;font-size:10px;display:flex}.cancel-btn{color:var(--red);cursor:pointer;background:0 0;border:none;font-family:DM Sans,sans-serif;font-size:10px}.edit-form{background:var(--sand);border-radius:16px 16px 4px;flex-direction:column;gap:4px;padding:9px 14px;display:flex}.edit-input{color:#fff;background:#fff3;border:1px solid #ffffff80;border-radius:8px;outline:none;width:100%;padding:4px 8px;font-family:DM Sans,sans-serif;font-size:13px}.edit-hint{color:#ffffffbf;font-size:10px}.pending-list{flex-direction:column;flex:1;gap:6px;padding:8px;display:flex;overflow-y:auto}.pending-list::-webkit-scrollbar{width:4px}.pending-list::-webkit-scrollbar-thumb{background:var(--beige-300);border-radius:4px}
