@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap";@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";:root{--bg-main: #05070f;--bg-card: #0b1020;--bg-input: #0f172a;--border-soft: rgba(255, 255, 255, .06);--text-main: #f8fafc;--text-muted: #94a3b8;--accent: #7c7cff;--accent-soft: rgba(124, 124, 255, .35);--danger: #fb7185;--success: #4ade80}.auth-wrapper{min-height:98vh;background:radial-gradient(60% 40% at 50% 0%,rgba(124,124,255,.15),transparent),var(--bg-main);display:flex;align-items:center;justify-content:center;padding:20px}.auth-card{width:100%;max-width:430px;background:linear-gradient(180deg,#ffffff0a,#ffffff03),var(--bg-card);border:1px solid var(--border-soft);border-radius:22px;padding:44px;box-shadow:0 30px 90px #000000d9,inset 0 1px #ffffff0a;color:var(--text-main);animation:premiumIn .6s cubic-bezier(.2,.8,.2,1);transition:transform .25s ease}@media(hover:hover){.auth-card:hover{transform:translateY(-2px)}}.auth-card h1{font-size:30px;font-weight:800;text-align:center;letter-spacing:-.6px;margin-bottom:6px}.auth-subtitle{text-align:center;font-size:14px;color:var(--text-muted);margin-bottom:34px}.field{margin-bottom:18px}.field input{width:100%;padding:15px 18px;border-radius:14px;border:1px solid var(--border-soft);background:var(--bg-input);color:var(--text-main);font-size:14px;outline:none;transition:border-color .2s ease,box-shadow .2s ease}.field input::placeholder{color:#64748b}.field input:focus-visible{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}input:-webkit-autofill{-webkit-box-shadow:0 0 0 1000px var(--bg-input) inset;-webkit-text-fill-color:var(--text-main)}.auth-btn{width:100%;padding:15px;border-radius:16px;border:none;background:linear-gradient(135deg,var(--accent),#5b5bff);color:#fff;font-size:16px;font-weight:700;cursor:pointer;margin-top:16px;transition:transform .25s ease,box-shadow .25s ease,opacity .2s}.auth-btn:hover{transform:translateY(-2px);box-shadow:0 18px 55px var(--accent-soft)}.auth-btn:active{transform:scale(.97)}.auth-logo{width:90px;height:90px;margin:0 auto 16px;border-radius:50%;background:linear-gradient(145deg,#0f172a,#020617);display:flex;align-items:center;justify-content:center;box-shadow:0 0 0 2px #ffffff14,0 10px 30px #0009}.auth-logo img{width:75%;height:75%;object-fit:contain;border-radius:50%}.auth-btn.loading{opacity:.7;pointer-events:none}.alert{padding:12px;border-radius:12px;font-size:14px;text-align:center;margin-bottom:18px}.alert.error{background:#fb718526;color:#fecdd3}.alert.success{background:#4ade8026;color:#bbf7d0}.switch-auth{text-align:center;font-size:14px;margin-top:26px;color:var(--text-muted)}.switch-auth a{color:#b4b4ff;font-weight:600;text-decoration:none}.switch-auth a:hover{text-decoration:underline}@keyframes premiumIn{0%{opacity:0;transform:translateY(18px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}@media(max-width:480px){.auth-card{padding:34px 24px;border-radius:18px}}:root{--bg-main: #05070f;--bg-sidebar: #0b1020;--bg-chat: #0f172a;--bg-hover: rgba(255,255,255,.06);--border-soft: rgba(255,255,255,.08);--text-main: #f8fafc;--text-muted: #94a3b8;--accent: #7c7cff;--success: #4ade80;--danger: #fb7185}*{box-sizing:border-box;font-family:Inter,sans-serif}.app{display:flex;height:98vh;background:var(--bg-main);color:var(--text-main)}.chat-input-row{width:100%;display:flex;align-items:center;gap:10px;padding:10px}.input-wrapper{position:relative;flex:1}.input.typing{padding-right:16px}.mic-icon.hide,.plus-icon.hide{opacity:0;pointer-events:none}.recording-ui{display:flex;align-items:center;gap:8px;font-size:14px;color:red;margin-bottom:4px}.record-dot{width:10px;height:10px;background:red;border-radius:50%;animation:blink 1s infinite}@keyframes blink{0%{opacity:1}50%{opacity:.3}to{opacity:1}}.mic-icon.recording{color:red;transform:scale(1.2)}.input{width:100%;height:44px;padding:0 45px 0 16px;border-radius:22px;border:1px solid #2a2a2a;background:#0f172a;color:#fff;font-size:14px}.plus-icon{position:absolute;right:14px;top:50%;transform:translateY(-50%);font-size:22px;cursor:pointer;color:#9ca3af}.plus-icon:hover{color:#fff}.send-outside{width:44px;height:44px;border-radius:50%;border:none;background:#6366f1;color:#fff;font-size:18px;cursor:pointer}.chat-image{max-width:190px;border-radius:10px;margin-top:6px}.chat-video{max-width:260px;border-radius:10px;margin-top:6px}.chat-doc{display:inline-block;margin-top:6px;color:#fff;text-decoration:none}.sidebar{width:28%;background-color:#020617;border-right:1px solid rgba(255,255,255,.06);box-shadow:2px 0 12px #0009;padding:20px;display:flex;flex-direction:column}.profile{font-size:20px;font-weight:700}.username{font-size:12px;color:var(--text-muted)}.heading{font-size:11px;color:var(--text-muted);margin:18px 0 8px;text-transform:uppercase}.user-header{display:flex;justify-content:space-between;align-items:center}.search{width:120px;padding:6px 10px;border-radius:12px;background:#ffffff0d;border:1px solid rgba(255,255,255,.08);color:var(--text-main)}.user-card{transition:background .25s ease,transform .25s ease;display:flex;align-items:center;gap:10px;padding:12px;border-radius:16px;cursor:pointer}.user-card:hover{background:#ffffff0f;transform:translate(4px)}.status{width:9px;height:9px;border-radius:50%;background:#64748b}.status.online{background:var(--success);box-shadow:0 0 8px #4ade80e6}.user-info{flex:1}.uname{font-weight:600}.name{font-size:12px;color:var(--text-muted)}.follow{border:1px solid var(--accent);background:transparent;color:var(--accent);padding:4px 10px;border-radius:20px}.badge{background:var(--danger);color:#fff;font-size:11px;padding:2px 7px;border-radius:50%}.logout{margin-top:auto;padding:12px;border-radius:16px;border:1px solid var(--border-soft);background:#ffffff0a;color:var(--text-main)}.logout:hover{background:#ffffff14}.unread-badge{background:linear-gradient(135deg,#ff4d4d,#ff1f1f);color:#fff;font-size:11px;font-weight:600;padding:4px 7px;border-radius:999px;min-width:20px;text-align:center;margin-left:auto;box-shadow:0 4px 10px #ff3b3b8c}.chat{flex:1;display:flex;flex-direction:column;background:radial-gradient(circle at 80% 20%,rgba(56,189,248,.08),transparent 40%),linear-gradient(180deg,#020617,#020617)}.chat-user{display:flex;align-items:center;gap:10px}.chat-username{font-size:16px;font-weight:600}.chat-header{padding:16px;border-bottom:1px solid var(--border-soft);display:flex;align-items:center;gap:10px;font-weight:600}.back-btn{display:none;background:none;border:none;color:#fff;font-size:22px;cursor:pointer}.chat-online-dot{position:absolute;bottom:0;right:0;width:10px;height:10px;background:#22c55e;border-radius:50%;border:2px solid #0b1020}.messages{background:linear-gradient(180deg,#02061799,#020617e6);flex:1;padding:20px;overflow-y:auto;display:flex;flex-direction:column;gap:10px;scrollbar-width:none;-ms-overflow-style:none}.messages::-webkit-scrollbar{display:none}.bubble{display:inline-block;width:fit-content;max-width:75%;padding:10px 14px;border-radius:16px;background:#0f172ad9;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);color:#e5e7eb;font-size:14px;line-height:1.45}.bubble.me{align-self:flex-end;background:linear-gradient(135deg,var(--accent),#5b5bff);color:#fff}.seen{font-size:9.5px;margin-left:9px;opacity:.6;padding-left:2px;-webkit-user-select:none;user-select:none;vertical-align:-2px;transform:scale(.001);transform-origin:left center}.seen.seen{color:#ff0;opacity:1}.seen.sent{color:#000}.input-box{width:100%;display:flex;gap:10px;padding:14px;border-top:1px solid var(--border-soft);background:#0f172a99}.input{flex:1;padding:12px 16px;border-radius:22px;border:1px solid var(--border-soft);background:#0f172a;color:var(--text-main);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.send{background:var(--accent);color:#fff;border-radius:50%;border:none;width:44px;height:44px}.empty{margin:auto;color:var(--text-muted)}.request{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;border-radius:14px;background:#ffffff0a;margin-bottom:8px}.request-user{font-size:14px;font-weight:500;color:var(--text-main)}.req-btn{width:30px;height:30px;border-radius:50%;border:none;cursor:pointer;font-size:14px;font-weight:700;display:flex;align-items:center;justify-content:center;transition:transform .15s ease,box-shadow .15s ease}.req-btn.accept:hover{transform:scale(1.15);box-shadow:0 0 10px #4ade8099}.req-btn.reject:hover{transform:scale(1.15);box-shadow:0 0 10px #fb718599}.notification{position:fixed;top:18px;right:18px;display:flex;align-items:center;gap:10px;background:linear-gradient(135deg,#22c55e,#16a34a);color:#ecfdf5;padding:14px 20px;min-width:220px;border-radius:14px;font-size:14px;font-weight:500;letter-spacing:.2px;box-shadow:0 10px 25px #22c55e59,inset 0 0 0 1px #ffffff26;z-index:9999;animation:toastIn .45s cubic-bezier(.22,1,.36,1)}.notification:before{content:"✔";display:grid;place-items:center;width:26px;height:26px;border-radius:50%;background:#ffffff40;font-weight:700}@keyframes toastIn{0%{opacity:0;transform:translateY(-12px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.disconnect-btn{margin-left:auto;background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;border:none;padding:6px 14px;border-radius:999px;font-size:13px;font-weight:500;cursor:pointer;box-shadow:0 6px 18px #ef444459;transition:all .25s ease}.disconnect-btn:hover{transform:translateY(-1px);box-shadow:0 10px 24px #ef444473}.open-side-btn{margin:12px 0;padding:10px;border-radius:12px;background:#ffffff0d;cursor:pointer;text-align:center;font-size:14px}.side-panel{width:100%;height:100%}.side-header{display:flex;align-items:center;gap:12px;padding:14px 4px;font-weight:600}.side-header button{background:none;border:none;color:#fff;font-size:20px;cursor:pointer}.side-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#6366f1,#8b5cf6);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:15px;flex-shrink:0}.chat-avatar-wrapper{position:relative}.chat-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#6366f1,#8b5cf6);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:16px}.chat-online-dot{position:absolute;bottom:0;right:0;width:10px;height:10px;background:#22c55e;border-radius:50%;border:2px solid #020617}.request-actions{display:flex;gap:8px}.req-btn{width:30px;height:30px;border-radius:50%;border:none;cursor:pointer;font-size:14px;font-weight:700}.req-btn.accept{background:#4ade8026;color:#4ade80}.req-btn.reject{background:#fb718526;color:#fb7185}.request{display:flex;align-items:center;gap:12px;padding:12px;border-radius:16px;background:#ffffff0a;transition:background .25s ease,transform .25s ease}.request:hover{background:#ffffff12;transform:translate(4px)}.request .side-avatar{width:38px;height:38px;font-size:15px}.request-user{flex:1;display:flex;flex-direction:column}.request-user .uname{font-weight:600;font-size:14px}.request-user .name{font-size:12px;color:var(--text-muted)}.request-actions{display:flex;gap:10px}.request-actions button{width:34px;height:34px;border-radius:50%;border:none;cursor:pointer;font-size:15px;font-weight:700;display:flex;align-items:center;justify-content:center;transition:all .25s ease}.request-actions button:first-child{background:linear-gradient(135deg,#22c55e,#16a34a);color:#ecfdf5;box-shadow:0 6px 16px #22c55e73}.request-actions button:first-child:hover{transform:scale(1.15);box-shadow:0 10px 26px #22c55ea6}.request-actions button:last-child{background:linear-gradient(135deg,#fb7185,#e11d48);color:#fff1f2;box-shadow:0 6px 16px #e11d4873}.request-actions button:last-child:hover{transform:scale(1.15);box-shadow:0 10px 26px #e11d48a6}.chat-disabled{width:100%;padding:14px;text-align:center;border-radius:14px;background:#ef444414;border:1px dashed rgba(239,68,68,.4);color:#fca5a5;font-size:14px;font-weight:500}.requested-btn{background:#facc151f;color:#facc15;border:1px solid rgba(250,204,21,.4);padding:6px 14px;border-radius:999px;font-size:12px;font-weight:500;cursor:not-allowed;white-space:nowrap;box-shadow:0 4px 14px #facc1540}.requested-btn:hover{box-shadow:0 6px 18px #facc1559}.follow{background:linear-gradient(135deg,#6366f1,#4f46e5);color:#fff;border:none;padding:6px 14px;border-radius:999px;font-size:13px;cursor:pointer;transition:all .25s ease}.follow:hover{transform:translateY(-1px);box-shadow:0 6px 20px #6366f173}.requested{font-size:12px;color:#facc15;font-weight:500}.chat-header{display:flex;align-items:center;gap:10px}@media(max-width:640px){.disconnect-btn{padding:5px 10px;font-size:12px}.chat-disabled{font-size:13px}}@media(max-width:600px){.notification{left:50%;right:auto;transform:translate(-50%);top:14px;min-width:auto}}@media(max-width:600px){.sidebar{width:100%;display:none}.sidebar.show{display:flex}.chat{display:none}.chat.show{display:flex}.back-btn{display:inline-block}.bubble{max-width:75%}}.bubble{max-width:90%}.chat-image,.chat-video{width:100%;max-width:100%;height:auto}.chat,.input-box{overflow-x:hidden}.image-preview{position:relative;padding:10px;background:#0f172ad9;border-top:1px solid rgba(255,255,255,.1)}.image-preview img{max-width:120px;max-height:120px;border-radius:10px;object-fit:cover}.preview-cancel{position:absolute;top:6px;right:6px;width:22px;height:22px;border-radius:50%;border:none;background:#000000b3;color:#fff;font-size:14px;cursor:pointer;line-height:1}.image-preview-list{display:flex;gap:10px;padding:10px;width:100%;max-width:100vw;overflow-x:auto;overflow-y:hidden;background:#0f172ad9;border-top:1px solid rgba(255,255,255,.1);white-space:nowrap;scroll-behavior:smooth;scrollbar-width:none;-ms-overflow-style:none}.image-preview-list::-webkit-scrollbar{height:8px}.image-preview-list::-webkit-scrollbar-thumb{background:#fff6;border-radius:10px}.image-preview-list::-webkit-scrollbar-track{background:transparent}.image-preview-item{position:relative;flex-shrink:0}.image-preview-item img{width:90px;height:90px;border-radius:10px;object-fit:cover}.image-preview-item .preview-cancel{position:absolute;top:4px;right:4px;width:20px;height:20px;border-radius:50%;border:none;background:#000000b3;color:#fff;font-size:12px;cursor:pointer}.mic-icon{position:absolute;right:60px;top:50%;transform:translateY(-50%);cursor:pointer;font-size:18px;color:#9ca3af}.mic-icon.recording{color:red;animation:pulse 1s infinite}@keyframes pulse{0%{transform:translateY(-50%) scale(1)}50%{transform:translateY(-50%) scale(1.2)}to{transform:translateY(-50%) scale(1)}}.audio-preview{display:flex;align-items:center;gap:10px;padding:10px;background:#0f172ad9;border-top:1px solid rgba(255,255,255,.1)}.audio-preview{position:relative;background:#0f172ad9;padding:10px;border-radius:14px;max-width:260px}.audio-cut{position:absolute;top:6px;right:6px;width:20px;height:20px;border-radius:50%;background:#000000b3;color:#fff;font-size:12px;display:flex;align-items:center;justify-content:center;cursor:pointer}.bubble:has(.audio-bubble){background:transparent!important;padding:0;box-shadow:none}.bubble:has(.audio-bubble) .seen{position:absolute;right:8px;bottom:6px;font-size:10px;opacity:.9}.bubble .chat-image{width:auto!important;max-width:260px!important;height:auto!important;display:block}.bubble .chat-video{width:auto!important;max-width:300px!important;max-height:270px!important;height:auto!important;display:block}@media(max-width:600px){.bubble .chat-image,.bubble .chat-video{max-width:100%!important}}.bubble.me .chat-image{max-width:170px!important}.bubble:not(.me) .chat-image{max-width:265px!important}.image-viewer{position:fixed;inset:0;background:#000000e6;display:flex;align-items:center;justify-content:center;z-index:9999}.image-viewer img{max-width:90%;max-height:90%;border-radius:12px}.close-btn{position:absolute;top:20px;right:20px;font-size:22px;background:#0009;color:#fff;border:none;width:38px;height:38px;border-radius:50%;cursor:pointer}.download-btn{position:absolute;top:20px;right:70px;font-size:20px;background:#0009;color:#fff;width:38px;height:38px;border-radius:50%;text-decoration:none;display:flex;align-items:center;justify-content:center}@media(max-width:600px){.bubble{max-width:100%}.chat-image{max-width:100%;max-height:45vh}}.download-btn{position:absolute;top:20px;right:70px;width:38px;height:38px;border-radius:50%;background:#0009;color:#fff;border:none;font-size:18px;cursor:pointer}.audio-bubble{background:#0f172a!important;border-radius:999px;padding:6px 10px}.custom-audio{display:flex;align-items:center;gap:10px;background:#010102;padding:10px 14px;border-radius:999px;color:#ff0;max-width:300px}.custom-audio button{background:none;border:none;color:#fff;font-size:18px;cursor:pointer}.audio-bar{flex:1;height:4px;background:#fff3;border-radius:4px;overflow:hidden}.audio-progress{height:100%;background:#7c7cff}.audio-time{font-size:11px;opacity:.8}.custom-audio audio{display:none}@media(max-width:600px){.bubble .chat-video{max-width:200px!important;width:auto!important;height:auto!important;max-height:25vh;object-fit:contain}}
