@import "https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700&family=Plus+Jakarta+Sans:wght@300;400;500;600;700&display=swap";:root{--bg-dark:#020617;--glass-bg:#0f172aa6;--glass-border:#ffffff14;--accent-primary:#a78bfa;--accent-secondary:#f472b6;--accent-glow:#a78bfa59;--text-primary:#f8fafc;--text-secondary:#94a3b8;--bubble-sent:linear-gradient(135deg, #7c3aed 0%, #db2777 100%);--bubble-received:#1e293bb3;--font-heading:"Plus Jakarta Sans", sans-serif;--font-body:"Outfit", sans-serif}body[data-theme=light]{--bg-dark:#f0f4ff;--glass-bg:#ffffffbf;--glass-border:#00000014;--accent-primary:#7c3aed;--accent-secondary:#db2777;--accent-glow:#7c3aed33;--text-primary:#0f172a;--text-secondary:#475569;--bubble-sent:linear-gradient(135deg, #7c3aed 0%, #db2777 100%);--bubble-received:#e2e8f0e6;background-color:var(--bg-dark);color:var(--text-primary);background-image:radial-gradient(at 0 0,#a78bfa26 0,#0000 40%),radial-gradient(at 100% 100%,#f472b626 0,#0000 40%),radial-gradient(#f0f4ff 0,#0000 100%)}*{box-sizing:border-box;font-family:var(--font-body);margin:0;padding:0;transition:background-color .3s,color .3s,border-color .3s}body{background-color:var(--bg-dark);color:var(--text-primary);background-image:radial-gradient(at 0 0,#8b5cf633 0,#0000 40%),radial-gradient(at 100% 100%,#ec489933 0,#0000 40%),radial-gradient(#0f172a 0,#0000 100%);justify-content:center;align-items:center;min-height:100vh;transition:background-color .4s,background-image .4s;display:flex;position:relative;overflow:hidden}body:before{content:"";opacity:.03;pointer-events:none;z-index:1;background:url(https://grainy-gradients.vercel.app/noise.svg);width:100%;height:100%;position:absolute;top:0;left:0}#root{justify-content:center;align-items:center;width:100%;height:100vh;padding:20px;display:flex}.glass-panel{background:var(--glass-bg);-webkit-backdrop-filter:blur(20px)saturate(180%);border:1px solid var(--glass-border);z-index:2;border-radius:32px;position:relative;box-shadow:0 25px 50px -12px #0009,0 0 40px #8b5cf60d}.btn-primary{background:linear-gradient(135deg, var(--accent-primary), var(--accent-secondary));color:#fff;font-weight:600;font-family:var(--font-heading);cursor:pointer;border:none;border-radius:16px;justify-content:center;align-items:center;gap:10px;padding:14px 28px;transition:all .4s cubic-bezier(.4,0,.2,1);display:flex;box-shadow:0 8px 20px -6px #a78bfa66}.btn-primary:hover{filter:brightness(1.1);transform:translateY(-3px)scale(1.02);box-shadow:0 12px 25px -8px #a78bfa99}.input-field{border:1px solid var(--glass-border);color:var(--text-primary);background:#0f172a99;border-radius:12px;outline:none;width:100%;padding:14px 20px;transition:border-color .3s}.input-field:focus{border-color:var(--accent-primary)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}.landing-container{width:100%;max-width:400px;padding:40px;animation:.5s fadeIn}.landing-header{text-align:center;margin-bottom:30px}.icon-wrapper{background:linear-gradient(135deg, var(--accent-primary), var(--accent-secondary));width:64px;height:64px;box-shadow:0 10px 20px -10px var(--accent-primary);border-radius:20px;justify-content:center;align-items:center;margin:0 auto 20px;display:flex}.landing-header h1{font-family:var(--font-heading);background:linear-gradient(#fff,#94a3b8);-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin-bottom:8px;font-size:32px;font-weight:800}.landing-header p{color:var(--text-secondary);font-size:14px}.landing-form{flex-direction:column;gap:20px;display:flex}.input-group{flex-direction:column;gap:8px;display:flex}.input-group label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-size:13px;font-weight:500}.chat-container{flex-direction:column;width:100%;max-width:1100px;height:88vh;animation:.5s fadeIn;display:flex;overflow:hidden}.chat-header{border-bottom:1px solid var(--glass-border);background:#1e293b66;justify-content:space-between;align-items:center;padding:20px 30px;display:flex}.room-info h2{align-items:center;gap:8px;font-size:18px;font-weight:600;display:flex}.room-users{color:var(--text-secondary);margin-top:4px;margin-left:16px;font-size:12px}.live-indicator{background:#10b981;border-radius:50%;width:8px;height:8px;animation:2s infinite pulse;box-shadow:0 0 10px #10b981}@keyframes pulse{0%{transform:scale(.95);box-shadow:0 0 #10b981b3}70%{transform:scale(1);box-shadow:0 0 0 6px #10b98100}to{transform:scale(.95);box-shadow:0 0 #10b98100}}.leave-btn{border:1px solid var(--glass-border);color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:8px;align-items:center;gap:6px;padding:8px 16px;font-size:14px;transition:all .2s;display:flex}.leave-btn:hover{color:#ef4444;background:#ef44441a;border-color:#ef44444d}.chat-tab:hover{color:var(--text-primary);background:#ffffff0d}.chat-body{flex-direction:column;flex:1;gap:16px;padding:30px;display:flex;overflow-y:auto}.chat-body::-webkit-scrollbar{width:6px}.chat-body::-webkit-scrollbar-track{background:0 0}.chat-body::-webkit-scrollbar-thumb{background:var(--glass-border);border-radius:10px}.message{flex-direction:column;max-width:70%;animation:.3s fadeIn;display:flex}.message.you{align-self:flex-end;animation:.3s slideInRight}.message.other{align-self:flex-start;animation:.3s slideInLeft}.mobile-menu-btn,.mobile-close-btn{color:var(--text-primary);cursor:pointer;background:0 0;border:none;display:none}@media (width<=1024px){.chat-container{border-radius:0;max-width:100%;height:100dvh}#root{padding:0}}@media (width<=768px){.mobile-menu-btn{margin-right:12px;display:flex}.mobile-close-btn{display:flex}.chat-main{position:relative}.chat-sidebar{z-index:1000;background:var(--bg-dark);border-right:1px solid var(--glass-border);width:280px;height:100%;transition:left .3s cubic-bezier(.4,0,.2,1);position:fixed;top:0;left:-100%;box-shadow:20px 0 50px #00000080}.chat-sidebar.open{left:0}.chat-sidebar .sidebar-header{justify-content:space-between}.chat-content{width:100%}.chat-header{padding:12px 15px}.chat-body{padding:15px 12px 10px}.message{max-width:90%}.chat-footer{padding:10px 12px;padding-bottom:calc(10px + env(safe-area-inset-bottom));gap:8px}.chat-input{border-radius:16px;flex:1;min-width:0;padding:11px 14px;font-size:16px}.action-btn,.image-upload-btn{flex-shrink:0;width:40px;height:40px}.send-btn{flex-shrink:0;width:44px;min-width:44px;height:44px}.input-row{align-items:center;gap:8px;width:100%;display:flex}.chat-tabs{-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--glass-border);z-index:50;scrollbar-width:none;background:#0a0f23f7;border-top:none;justify-content:space-around;align-items:center;gap:0;width:100%;padding:8px 0;display:flex;position:sticky;top:0;left:0;right:0;overflow-x:auto}.chat-tabs::-webkit-scrollbar{display:none}.chat-tab{text-transform:uppercase;letter-spacing:.4px;white-space:nowrap;color:var(--text-secondary);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:3px;padding:6px 8px;font-size:10px;font-weight:600;background:0 0!important;border:none!important;border-radius:10px!important}.chat-tab.active{color:var(--accent-primary);background:#a78bfa1a!important}}.message-image{object-fit:contain;max-height:300px}.message-sticker{width:100px;height:100px}.message.system{align-self:center;max-width:90%;margin:10px 0;animation:.3s fadeIn}.message-content{word-break:break-word;border-radius:18px;padding:12px 18px;font-size:15px;line-height:1.5;box-shadow:0 4px 15px #0000001a}.message.you .message-content{background:var(--bubble-sent);color:#fff;border-bottom-right-radius:6px;box-shadow:0 8px 20px -10px #8b5cf680}.message.other .message-content{background:var(--bubble-received);border:1px solid var(--glass-border);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom-left-radius:6px}.message.system .message-content{box-shadow:none;color:var(--text-secondary);border:1px solid var(--glass-border);background:#0f172a4d;border-radius:20px;padding:4px 12px;font-size:12px}.message-meta{color:var(--text-secondary);gap:8px;margin-top:4px;padding:0 4px;font-size:11px;display:flex}.message.you .message-meta{justify-content:flex-end;align-items:center}.message-status{align-items:center;margin-left:4px;display:flex}.tick-white{color:#fff9}.tick-blue{color:#38bdf8;filter:drop-shadow(0 0 2px #38bdf880)}.chat-footer{border-top:1px solid var(--glass-border);background:#1e293b66;gap:12px;padding:20px 30px;display:flex}.chat-input{border:1px solid var(--glass-border);color:var(--text-primary);background:#0f172a66;border-radius:20px;outline:none;flex:1;padding:14px 24px;font-size:15px;transition:all .3s cubic-bezier(.4,0,.2,1)}.chat-input:focus{border-color:var(--accent-primary);background:#0f172a99;box-shadow:0 0 20px #a78bfa26}.send-btn{background:linear-gradient(135deg, var(--accent-primary), var(--accent-secondary));color:#fff;cursor:pointer;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:50px;height:50px;transition:transform .2s,box-shadow .2s;display:flex}.send-btn:hover{transform:scale(1.05);box-shadow:0 5px 15px #8b5cf666}.send-btn:disabled{opacity:.5;cursor:not-allowed;box-shadow:none;transform:none}.message-image{cursor:pointer;border-radius:12px;max-width:100%;margin-top:8px;transition:transform .2s;box-shadow:0 4px 10px #0003}.message-image:hover{transform:scale(1.02)}.image-upload-btn{border:1px solid var(--glass-border);color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:50px;height:50px;transition:all .2s;display:flex}.image-upload-btn:hover{color:var(--text-primary);border-color:var(--text-primary);background:#ffffff1a}.member-tag{cursor:pointer;background:#ffffff0d;border-radius:12px;align-items:center;gap:4px;padding:2px 8px;transition:all .2s;display:inline-flex}.member-tag:hover{color:var(--accent-primary);background:#8b5cf633}.member-tag.active{background:var(--accent-primary);color:#fff;box-shadow:0 0 10px #8b5cf680}.private-badge{background:var(--accent-secondary);color:#fff;text-transform:uppercase;letter-spacing:.5px;border-radius:10px;margin-left:6px;padding:1px 6px;font-size:9px;font-weight:700}.image-lightbox-overlay{-webkit-backdrop-filter:blur(16px);z-index:9999;cursor:pointer;background:#000000eb;justify-content:center;align-items:center;width:100%;height:100%;animation:.2s fadeIn;display:flex;position:fixed;top:0;left:0}.image-lightbox-close{border:1px solid var(--glass-border);color:#fff;cursor:pointer;z-index:10000;background:#ffffff1a;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;transition:background .2s;display:flex;position:absolute;top:20px;right:20px}.image-lightbox-close:hover{background:#ef444466}.image-lightbox-img{object-fit:contain;cursor:default;border-radius:16px;max-width:95vw;max-height:90vh;box-shadow:0 30px 80px #0009}.chat-mode-indicator{color:var(--accent-primary);text-transform:uppercase;letter-spacing:1px;margin-bottom:2px;font-size:11px;font-weight:600}.sticker-picker{z-index:100;border:1px solid var(--glass-border);flex-direction:column;width:320px;height:350px;animation:.3s cubic-bezier(.4,0,.2,1) slideInUp;display:flex;position:absolute;bottom:80px;left:30px;overflow:hidden}@media (width<=768px){.sticker-picker{width:calc(100% - 40px);height:300px;bottom:70px;left:20px}}@keyframes slideInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.picker-tabs{border-bottom:1px solid var(--glass-border);background:#0f172a99;gap:8px;padding:8px;display:flex}.picker-tab{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:8px;flex:1;padding:8px;font-size:13px;font-weight:600;transition:all .2s}.picker-tab.active{background:var(--accent-primary);color:#fff;box-shadow:0 4px 12px #a78bfa4d}.picker-content{flex:1;padding:15px;overflow-y:auto}.emojis-grid{grid-template-columns:repeat(auto-fill,minmax(40px,1fr));gap:10px;display:grid}.emoji-item{cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:center;align-items:center;font-size:24px;transition:transform .2s;display:flex}.emoji-item:hover{transform:scale(1.3)}.stickers-grid{grid-template-columns:repeat(auto-fill,minmax(60px,1fr));gap:12px;display:grid}.sticker-item{aspect-ratio:1;object-fit:contain;cursor:pointer;width:100%;transition:transform .2s}.sticker-item:hover{transform:scale(1.1)}.picker-content::-webkit-scrollbar{width:4px}.picker-content::-webkit-scrollbar-thumb{background:var(--glass-border);border-radius:10px}.message.sticker .message-content{box-shadow:none!important;background:0 0!important;border:none!important;padding:0!important}.message-sticker{object-fit:contain;width:120px;height:120px;margin-top:5px}.location-card{border:1px solid var(--glass-border);background:#ffffff1a;border-radius:12px;flex-direction:column;gap:8px;min-width:200px;margin-top:8px;padding:12px;transition:all .2s;display:flex}.location-card:hover{border-color:var(--accent-primary);background:#ffffff26}.location-header{color:var(--accent-primary);align-items:center;gap:8px;font-size:14px;font-weight:600;display:flex}.location-btn{background:var(--accent-primary);color:#fff;cursor:pointer;text-align:center;border:none;border-radius:8px;padding:6px 12px;font-size:12px;font-weight:600;text-decoration:none;transition:all .2s}.location-btn:hover{filter:brightness(1.1);box-shadow:0 4px 12px #8b5cf64d}.message{position:relative}.delete-btn{color:#ef4444;cursor:pointer;opacity:0;z-index:10;background:#ef44441a;border:1px solid #ef444433;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;transition:all .2s;display:flex;position:absolute;top:0;right:-30px}.message.you .delete-btn{left:-30px;right:auto}.message:hover .delete-btn{opacity:1}.delete-btn:hover{color:#fff;background:#ef4444;transform:scale(1.1)}.map-modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:2000;background:#000c;justify-content:center;align-items:center;width:100vw;height:100vh;animation:.3s fadeIn;display:flex;position:fixed;top:0;left:0}.map-modal{flex-direction:column;gap:15px;width:90%;max-width:600px;height:500px;padding:20px;display:flex}#map-picker-container{border:1px solid var(--glass-border);border-radius:12px;flex:1;overflow:hidden}.map-modal-footer{justify-content:space-between;gap:10px;display:flex}.admin-container{flex-direction:column;width:100%;max-width:600px;max-height:90vh;padding:30px;animation:.5s fadeIn;display:flex}.admin-header{border-bottom:1px solid var(--glass-border);justify-content:space-between;align-items:center;margin-bottom:25px;padding-bottom:15px;display:flex}.admin-body{flex:1;padding-right:10px;overflow-y:auto}.admin-body::-webkit-scrollbar{width:4px}.admin-body::-webkit-scrollbar-thumb{background:var(--glass-border);border-radius:10px}.admin-form-row{gap:10px;margin-top:10px;display:flex}.admin-form-row input{flex:1}.user-row:hover{background:#ffffff0d;border-radius:12px}.maintenance-container{z-index:9999;background:radial-gradient(circle,#1e293b 0%,#0f172a 100%);justify-content:center;align-items:center;width:100vw;height:100vh;padding:20px;display:flex;position:fixed;top:0;left:0}.maintenance-card{text-align:center;width:100%;max-width:500px;padding:40px;animation:.8s ease-out fadeIn}.maintenance-header h1{background:linear-gradient(90deg,#f8fafc,#94a3b8);-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin:20px 0 10px;font-size:40px}.maintenance-header p{color:var(--text-secondary);line-height:1.6}.pulse-icon{background:#f59e0b1a;border-radius:50%;margin-bottom:10px;padding:20px;animation:2s infinite maintenancePulse;display:inline-flex}.status-badge{color:#94a3b8;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:20px;align-items:center;gap:8px;margin:20px 0;padding:8px 16px;font-size:.9rem;display:inline-flex}.maintenance-subtext{color:#94a3b899;font-size:.85rem}.maintenance-footer{border-top:1px solid #ffffff0d;margin-top:30px;padding-top:20px}.admin-link-subtle{color:#94a3b866;cursor:pointer;background:0 0;border:none;align-items:center;gap:5px;margin:0 auto;font-size:13px;transition:all .3s;display:flex}.admin-link-subtle:hover{color:var(--accent-primary);opacity:1}@keyframes maintenancePulse{0%{transform:scale(1);box-shadow:0 0 #f59e0b66}70%{transform:scale(1.05);box-shadow:0 0 0 15px #f59e0b00}to{transform:scale(1);box-shadow:0 0 #f59e0b00}}.admin-fab{color:#fff;cursor:pointer;z-index:10000;background:linear-gradient(135deg,#ef4444,#b91c1c);border-radius:50px;align-items:center;gap:10px;padding:12px 24px;font-weight:700;transition:all .3s;animation:.5s ease-out slideUp;display:flex;position:fixed;bottom:30px;right:30px;box-shadow:0 10px 25px #ef444480}.admin-fab:hover{transform:scale(1.05)translateY(-5px);box-shadow:0 15px 35px #ef444499}.admin-fab span{letter-spacing:1px;font-size:14px}@keyframes slideUp{0%{opacity:0;transform:translateY(100px)}to{opacity:1;transform:translateY(0)}}.location-gate-container{z-index:10000;background:radial-gradient(circle,#1e293b 0%,#0f172a 100%);justify-content:center;align-items:center;width:100vw;height:100vh;padding:20px;display:flex;position:fixed;top:0;left:0}.location-card{text-align:center;width:100%;max-width:450px;padding:40px;animation:.5s fadeIn}.location-icon-wrapper{background:#ef44441a;border:1px solid #ef444433;border-radius:50%;justify-content:center;align-items:center;width:80px;height:80px;margin:0 auto 20px;display:flex}.location-header h1{margin-bottom:10px;font-size:24px}.location-header p{color:var(--text-secondary);font-size:14px;line-height:1.5}.warning-box{color:#ef4444;background:#ef44441a;border:1px solid #ef444433;border-radius:12px;align-items:center;gap:10px;margin:20px 0;padding:12px;font-size:13px;font-weight:600;display:flex}.instruction-list{text-align:left;color:var(--text-secondary);margin-bottom:20px;padding-left:20px;font-size:13px}.instruction-list li{margin-bottom:8px}.chat-main{flex:1;display:flex;overflow:hidden}.chat-sidebar{border-right:1px solid var(--glass-border);background:#0f172a99;flex-direction:column;width:260px;padding:0;display:flex}.sidebar-header{border-bottom:1px solid var(--glass-border);color:var(--accent-primary);align-items:center;gap:10px;padding:20px;font-size:14px;font-weight:600;display:flex}.members-list{flex:1;padding:10px;overflow-y:auto}.member-item{z-index:5;border-radius:12px;align-items:center;gap:12px;margin-bottom:4px;padding:12px 15px;transition:all .2s;display:flex;position:relative;cursor:pointer!important;pointer-events:auto!important}.member-item:hover{background:#ffffff1a}.member-item.active{color:#60a5fa;background:#3b82f633;border:1px solid #3b82f64d}.status-dot{background:#10b981;border-radius:50%;width:8px;height:8px;box-shadow:0 0 5px #10b981}.kick-icon{opacity:0;color:#ef4444;transition:opacity .2s;position:absolute;right:15px}.member-item:hover .kick-icon{opacity:.7}.chat-content{background:var(--glass-bg);flex-direction:column;flex:1;display:flex;overflow:hidden}.chat-tabs{border-bottom:1px solid var(--glass-border);background:#0f172a66;gap:5px;padding:10px 20px 0;display:flex}.chat-tab{color:var(--text-secondary);cursor:pointer;background:0 0;border:1px solid #0000;border-bottom:none;border-radius:12px 12px 0 0;align-items:center;gap:8px;padding:10px 20px;font-size:13px;font-weight:500;transition:all .3s;display:flex}.chat-tab.active{background:var(--glass-bg);color:var(--accent-primary);border-color:var(--glass-border)}.chat-footer{border-top:1px solid var(--glass-border);background:#0f172a66;padding:20px}.input-row{align-items:center;gap:12px;display:flex}.action-btn{border:1px solid var(--glass-border);color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:10px;justify-content:center;align-items:center;width:40px;height:40px;transition:all .2s;display:flex}.action-btn.active{color:var(--accent-primary);border-color:var(--accent-primary);background:#a78bfa1a}.timer-badge{background:var(--accent-primary);color:#fff;border-radius:10px;padding:2px 4px;font-size:8px;font-weight:800;position:absolute;top:-5px;right:-5px;box-shadow:0 2px 5px #a78bfa80}.members-tab-content{padding:20px;animation:.4s fadeIn}.members-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:20px;display:grid}.member-card{cursor:pointer;border:1px solid #0000;border-radius:20px;align-items:center;gap:16px;padding:16px;transition:all .4s cubic-bezier(.4,0,.2,1);display:flex;position:relative;overflow:hidden}.member-card:before{content:"";opacity:0;pointer-events:none;background:linear-gradient(135deg,#0000,#a78bfa0d);width:100%;height:100%;transition:opacity .3s;position:absolute;top:0;left:0}.member-card:hover{border-color:var(--glass-border);background:#ffffff0d;transform:translateY(-5px)scale(1.02);box-shadow:0 10px 30px -10px #00000080,0 0 20px #a78bfa0d}.member-card:hover:before{opacity:1}.member-card.self{border-color:var(--accent-secondary);background:#ec48990d}.member-avatar{background:var(--bubble-sent);width:54px;height:54px;font-size:22px;font-weight:800;font-family:var(--font-heading);color:#fff;z-index:2;border-radius:18px;justify-content:center;align-items:center;display:flex;position:relative;box-shadow:0 8px 20px -5px #8b5cf680}.member-info{flex-direction:column;flex:1;gap:4px;display:flex}.member-name{font-family:var(--font-heading);color:var(--text-primary);font-size:16px;font-weight:700}.member-status{color:var(--text-secondary);align-items:center;gap:6px;font-size:12px;display:flex}.member-actions{z-index:10;gap:8px;display:flex;position:relative}.action-btn-small{border:1px solid var(--glass-border);height:32px;color:var(--text-secondary);cursor:pointer;background:#ffffff0d;border-radius:10px;justify-content:center;align-items:center;padding:0 12px;transition:all .2s;display:flex}.action-btn-small:hover{background:var(--accent-primary);color:#fff;border-color:var(--accent-primary)}.action-btn-small.delete:hover{background:#ef4444;border-color:#ef4444}@media (width<=600px){.members-grid{grid-template-columns:1fr}}.typing-indicator{color:var(--text-secondary);align-items:center;gap:10px;margin-top:5px;padding:5px 15px;font-size:12px;animation:.3s fadeIn;display:flex}.typing-dots{gap:3px;display:flex}.typing-dots span{background:var(--accent-primary);border-radius:50%;width:6px;height:6px;animation:1.4s ease-in-out infinite both typingBounce}.typing-dots span:first-child{animation-delay:-.32s}.typing-dots span:nth-child(2){animation-delay:-.16s}@keyframes typingBounce{0%,80%,to{transform:scale(0)}40%{transform:scale(1)}}.reply-preview-container{border:1px solid var(--glass-border);background:#0f172a99;border-bottom:none;border-radius:12px 12px 0 0;justify-content:space-between;align-items:center;padding:10px 15px;animation:.3s slideUp;display:flex}.reply-info{flex-direction:column;gap:2px;display:flex;overflow:hidden}.reply-label{color:var(--accent-primary);text-transform:uppercase;font-size:11px;font-weight:700}.reply-text{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;max-width:400px;font-size:13px;overflow:hidden}.cancel-reply{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;transition:color .2s}.cancel-reply:hover{color:#ef4444}.replied-message-preview{border-left:3px solid var(--accent-primary);background:#0003;border-radius:4px;margin-bottom:8px;padding:5px 10px;font-size:13px}.reply-author{color:var(--accent-primary);font-size:11px;font-weight:700;display:block}.message-actions-overlay{opacity:0;gap:5px;transition:all .2s;display:flex;position:absolute;top:0;right:-60px}.message.you .message-actions-overlay{left:-60px;right:auto}.message:hover .message-actions-overlay{opacity:1}.reply-btn-icon{color:var(--accent-primary);cursor:pointer;background:#8b5cf61a;border:1px solid #8b5cf633;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;transition:all .2s;display:flex}.reply-btn-icon:hover{background:var(--accent-primary);color:#fff}.message-wrapper{flex-direction:column;width:100%;margin-bottom:4px;display:flex;position:relative}.swipe-reply-indicator{color:var(--accent-primary);pointer-events:none;z-index:0;justify-content:center;align-items:center;display:flex;position:absolute;top:50%;left:-30px;transform:translateY(-50%)}.profile-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:3000;background:#000000b3;justify-content:center;align-items:center;width:100vw;height:100vh;animation:.3s fadeIn;display:flex;position:fixed;top:0;left:0}.profile-card{width:90%;max-width:400px;animation:.4s cubic-bezier(.18,.89,.32,1.28) slideInUp;position:relative;overflow:hidden}.profile-header{height:120px;position:relative}.profile-cover{background:linear-gradient(135deg, var(--accent-primary), var(--accent-secondary));opacity:.3;height:100%}.profile-close{color:#fff;cursor:pointer;background:#0000004d;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;transition:all .2s;display:flex;position:absolute;top:15px;right:15px}.profile-close:hover{background:#00000080;transform:scale(1.1)}.profile-avatar-wrapper{position:absolute;bottom:-40px;left:30px}.profile-avatar{background:var(--bubble-sent);color:#fff;border:4px solid var(--glass-bg);border-radius:24px;justify-content:center;align-items:center;width:80px;height:80px;font-size:32px;font-weight:800;display:flex;position:relative;box-shadow:0 10px 25px #0000004d}.profile-avatar.admin{background:linear-gradient(135deg,#ef4444,#b91c1c)}.admin-badge{color:#000;border:2px solid var(--glass-bg);background:#fbbf24;border-radius:50%;padding:4px;position:absolute;bottom:-5px;right:-5px}.profile-body{padding:50px 30px 30px}.profile-info h2{margin-bottom:5px;font-size:24px}.role-badge{color:var(--text-secondary);background:#ffffff1a;border-radius:20px;align-items:center;gap:6px;padding:4px 10px;font-size:12px;font-weight:600;display:inline-flex}.role-badge.admin{color:#ef4444;background:#ef44441a}.profile-section{margin-top:25px}.section-label{text-transform:uppercase;letter-spacing:1px;color:var(--text-secondary);justify-content:space-between;align-items:center;margin-bottom:10px;font-size:11px;font-weight:700;display:flex}.status-text{color:var(--text-primary);font-size:15px;font-style:italic}.status-edit{gap:10px;display:flex}.status-edit input{border:1px solid var(--glass-border);color:#fff;background:#ffffff0d;border-radius:8px;flex:1;padding:8px 12px}.status-edit button{background:var(--accent-primary);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:0 12px}.profile-stats{border-top:1px solid var(--glass-border);gap:20px;margin-top:30px;padding-top:25px;display:flex}.stat-item{color:var(--text-secondary);align-items:center;gap:12px;display:flex}.stat-info{flex-direction:column;display:flex}.stat-value{color:var(--text-primary);font-size:14px;font-weight:700}.stat-label{text-transform:uppercase;font-size:10px}.admin-notice{color:#ef4444;background:#ef44440d;border:1px solid #ef44441a;border-radius:12px;align-items:center;gap:10px;margin-top:25px;padding:12px;font-size:11px;display:flex}.edit-btn{color:var(--accent-primary);cursor:pointer;opacity:.6;background:0 0;border:none;transition:opacity .2s}.message-author-clickable{cursor:pointer;color:var(--accent-primary);font-weight:600;transition:opacity .2s}.message-author-clickable:hover{opacity:.8;text-decoration:underline}.profile-page{background:var(--bg-primary);justify-content:center;align-items:center;width:100vw;height:100vh;padding:20px;display:flex;overflow-y:auto}.profile-card.full{width:100%;max-width:500px}.back-to-chat-btn{background:var(--accent-primary);color:#fff;cursor:pointer;border:none;border-radius:12px;width:100%;margin-top:30px;padding:12px;font-weight:700;transition:all .2s;box-shadow:0 4px 15px #a78bfa4d}.back-to-chat-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #a78bfa66}.full-page-container{width:100%;height:100%}.profile-img-content{object-fit:cover;border-radius:inherit;width:100%;height:100%}.avatar-edit-overlay{color:#fff;opacity:0;cursor:pointer;border-radius:inherit;z-index:5;background:#0006;border:none;justify-content:center;align-items:center;width:100%;height:100%;transition:opacity .3s;display:flex;position:absolute;top:0;left:0}.profile-avatar:hover .avatar-edit-overlay{opacity:1}.member-item-avatar-small{flex-shrink:0;width:32px;height:32px;position:relative}.avatar-img-tiny{object-fit:cover;border:1px solid var(--glass-border);border-radius:50%;width:32px;height:32px}.avatar-letter-tiny{background:var(--accent-primary);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:12px;font-weight:700;display:flex}.avatar-img-small{object-fit:cover;border-radius:50%;width:100%;height:100%}.animate-spin{animation:1s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.profile-avatar.officer{background:linear-gradient(135deg,#0ea5e9,#2563eb)}.officer-badge{color:#000;border:2px solid var(--glass-bg);background:#38bdf8;border-radius:50%;padding:4px;position:absolute;bottom:-5px;right:-5px}.officer-notice{color:#0ea5e9;background:#0ea5e90d;border:1px solid #0ea5e91a;border-radius:12px;align-items:center;gap:10px;margin-top:15px;padding:12px;font-size:11px;display:flex}.promote-btn{background:linear-gradient(135deg,#0ea5e9,#2563eb)!important;box-shadow:0 4px 12px #0ea5e94d!important}.demote-btn:hover{color:#ef4444!important;background:#ef44441a!important;border-color:#ef44444d!important}.sidebar-badge{border:1px solid var(--glass-bg);z-index:10;border-radius:50%;padding:1px;position:absolute;bottom:-2px;right:-2px}.sidebar-badge.admin{color:#000;background:#fbbf24}.sidebar-badge.officer{color:#000;background:#38bdf8}.grid-badge{border:2px solid var(--glass-bg);z-index:10;border-radius:50%;padding:2px;position:absolute;bottom:-4px;right:-4px}.grid-badge.admin{color:#000;background:#fbbf24}.grid-badge.officer{color:#000;background:#38bdf8}.role-badge.officer{color:#0ea5e9;background:#0ea5e91a}.role-management-section{border-top:1px solid var(--glass-border);margin-top:25px;padding-top:20px}.message-with-avatar{align-items:flex-end;gap:8px;max-width:100%;display:flex}.message-with-avatar.you{flex-direction:row-reverse}.message-with-avatar.other{flex-direction:row}.message-bubble-col{flex-direction:column;gap:3px;max-width:70%;display:flex}.message-with-avatar.you .message-bubble-col{align-items:flex-end}.message-with-avatar.other .message-bubble-col{align-items:flex-start}.msg-author-name{color:var(--accent-primary);cursor:pointer;letter-spacing:.3px;white-space:nowrap;padding-left:4px;padding-right:4px;font-size:11px;font-weight:700;transition:opacity .2s}.msg-author-name.you{text-align:right;color:var(--accent-secondary)}.msg-author-name:hover{opacity:.7;text-decoration:underline}.chat-avatar-bubble{background:var(--bubble-sent);cursor:pointer;border:2px solid var(--glass-border);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;transition:transform .2s;display:flex;overflow:hidden;box-shadow:0 2px 8px #0000004d}.chat-avatar-bubble:hover{transform:scale(1.1)}.chat-avatar-bubble.self{background:linear-gradient(135deg, var(--accent-primary), var(--accent-secondary))}.chat-avatar-img{object-fit:cover;border-radius:50%;width:100%;height:100%}.chat-avatar-letter{color:#fff;font-size:14px;font-weight:800;font-family:var(--font-heading)}.message-with-avatar .message{max-width:100%}.rainbow-text{background:linear-gradient(45deg,red,#ff7f00,#ff0,#0f0,#00f,indigo,#9400d3) 0 0/400% 400%!important;-webkit-text-fill-color:transparent!important;color:#0000!important;-webkit-background-clip:text!important;background-clip:text!important;animation:3s infinite rainbow!important;display:inline-block!important}@keyframes rainbow{0%{background-position:0%}50%{background-position:100%}to{background-position:0%}}
