@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.login-bg{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 80% 60% at 20% 40%,rgba(108,99,255,.15) 0%,transparent 60%),radial-gradient(ellipse 60% 80% at 80% 80%,rgba(0,212,170,.08) 0%,transparent 60%),var(--color-bg);z-index:0}.login-card{position:relative;z-index:1;width:100%;max-width:420px;padding:48px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--r-xl);box-shadow:var(--shadow-lg);animation:slideUp .4s var(--t-slow) both}@keyframes slideUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.login-logo{text-align:center;margin-bottom:40px}.login-logo-icon{font-size:48px;display:block;margin-bottom:12px}.login-title{font-size:var(--fz-xl);font-weight:700;color:var(--color-text);margin-bottom:6px}.login-subtitle{font-size:var(--fz-sm);color:var(--color-text-2)}.login-form{display:flex;flex-direction:column;gap:20px}.login-error{padding:12px 16px;background:#ff5c7a1f;border:1px solid rgba(255,92,122,.3);border-radius:var(--r-md);color:var(--color-danger);font-size:var(--fz-sm)}.login-btn{width:100%;height:48px;font-size:var(--fz-md);margin-top:4px}.login-forgot{text-align:center;font-size:var(--fz-sm);color:var(--color-text-2);display:block}.login-forgot:hover{color:var(--color-primary)}.spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.chats-layout{display:flex;height:100%;overflow:hidden}.sidebar{width:var(--sidebar-w);min-width:var(--sidebar-w);background:var(--color-surface);border-right:1px solid var(--color-border);display:flex;flex-direction:column;overflow:hidden}.sidebar-header{padding:16px;border-bottom:1px solid var(--color-border)}.sidebar-logo{font-size:var(--fz-md);font-weight:700;color:var(--color-primary);display:block;margin-bottom:14px}.sidebar-user{display:flex;align-items:center;gap:10px}.sidebar-avatar{width:36px;height:36px;border-radius:50%;background:var(--color-primary);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:var(--fz-md);color:#fff;flex-shrink:0;overflow:hidden}.sidebar-avatar img{width:100%;height:100%;object-fit:cover}.sidebar-name{font-size:var(--fz-sm);font-weight:600;line-height:1.3}.sidebar-role{font-size:var(--fz-xs);color:var(--color-text-2)}.sidebar-search{padding:12px 16px;border-bottom:1px solid var(--color-border)}.sidebar-groups{flex:1;overflow-y:auto;padding:8px 0}.sidebar-empty{text-align:center;color:var(--color-text-2);font-size:var(--fz-sm);padding:32px 16px}.group-item{width:100%;display:flex;align-items:center;gap:12px;padding:12px 16px;background:none;border:none;cursor:pointer;text-align:left;color:var(--color-text);transition:background var(--t-fast)}.group-item:hover{background:var(--color-surface-2)}.group-item.active{background:#6c63ff1f}.group-item.active .group-name{color:var(--color-primary)}.group-avatar{width:44px;height:44px;border-radius:50%;background:var(--color-surface-2);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:var(--fz-md);flex-shrink:0;overflow:hidden}.group-avatar img{width:100%;height:100%;object-fit:cover}.group-info{flex:1;min-width:0}.group-name{font-size:var(--fz-sm);font-weight:600;margin-bottom:2px}.group-preview{font-size:var(--fz-xs)}.sidebar-admin{padding:12px 16px;border-top:1px solid var(--color-border)}.sidebar-admin .btn{width:100%}.chat-main{flex:1;display:flex;overflow:hidden}.chat-placeholder{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;text-align:center;color:var(--color-text-2)}.chat-placeholder-icon{font-size:64px;margin-bottom:8px}.chat-placeholder h2{font-size:var(--fz-lg);color:var(--color-text)}.chat-placeholder p{font-size:var(--fz-sm)}.chat-view{flex:1;display:flex;flex-direction:column;overflow:hidden}.chat-header{height:var(--header-h);padding:0 20px;border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between;background:var(--color-surface);flex-shrink:0}.chat-header-actions,.chat-header-info{display:flex;align-items:center;gap:12px}.chat-header-avatar{width:38px;height:38px;border-radius:50%;background:var(--color-primary);display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff;flex-shrink:0}.chat-header-name{font-size:var(--fz-md);font-weight:600}.chat-header-desc{font-size:var(--fz-xs)}.chat-messages{flex:1;overflow-y:auto;padding:20px}.typing-indicator-list{padding:10px 20px;font-size:12px;color:var(--color-text-2);font-style:italic;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.chat-input-bar{padding:16px 20px;background:var(--color-surface);border-top:1px solid var(--color-border);display:flex;gap:12px;align-items:flex-end;flex-shrink:0;position:relative;border-radius:0 0 calc(var(--radius-lg) - 1px) calc(var(--radius-lg) - 1px)}.input-actions-wrapper{display:flex;gap:12px;align-items:center;flex:1}.input-actions{display:flex;gap:8px;align-items:center;flex:1}.voice-btn{font-size:20px!important;transition:all .2s ease;-webkit-user-select:none;user-select:none}.voice-btn.recording{color:#ff4d4f;background:#ff4d4f1a;transform:scale(1.2)}.recording-indicator{display:flex;align-items:center;gap:8px;padding:0 12px;background:var(--color-surface-2);border-radius:20px;height:36px;animation:fadeIn .3s ease}.recording-dot{height:100px;width:10px;height:10px;background:#ff4d4f;border-radius:50%;animation:pulse 1s infinite}.recording-timer{font-family:monospace;font-size:14px;font-weight:600;color:#ff4d4f}@keyframes pulse{0%{transform:scale(1);opacity:1}50%{transform:scale(1.3);opacity:.5}to{transform:scale(1);opacity:1}}@keyframes fadeIn{0%{opacity:0;transform:translate(10px)}to{opacity:1;transform:translate(0)}}.message-media-container{margin-top:4px}.message-image{max-width:100%;max-height:300px;border-radius:8px;display:block}.message-media-caption{font-size:var(--fz-xs);margin-top:4px;opacity:.8}.message-file{display:flex;align-items:center;gap:12px;background:var(--color-surface);padding:10px 14px;border-radius:8px;border:1px solid var(--color-border);min-width:200px}.file-icon{font-size:24px}.file-info{flex:1;min-width:0}.file-name{display:block;font-size:var(--fz-sm);font-weight:600;color:var(--color-primary);text-decoration:none;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.file-name:hover{text-decoration:underline}.file-size{font-size:var(--fz-xs);color:var(--color-text-2);margin-top:2px}.file-download-btn{font-size:18px;text-decoration:none;opacity:.7;transition:opacity var(--t-fast)}.file-download-btn:hover{opacity:1}.upload-overlay{position:absolute;top:-40px;left:0;right:0;height:40px;background:var(--color-surface);border-top:1px solid var(--color-border);display:flex;align-items:center;padding:0 20px;z-index:10}.video-recording-container{position:absolute;bottom:80px;right:20px;z-index:100;animation:slideUp .3s ease}.video-preview-wrapper{width:200px;height:200px;border-radius:50%;overflow:hidden;border:4px solid var(--color-primary);background:#000;position:relative;box-shadow:0 4px 20px #0000004d}.video-preview-wrapper video{width:100%;height:100%;object-fit:cover;transform:scaleX(-1)}.video-recording-info{position:absolute;bottom:15px;left:50%;transform:translate(-50%);background:#00000080;padding:4px 10px;border-radius:12px;display:flex;align-items:center;gap:6px;color:#fff;font-size:12px;font-weight:600}.message-video-circle{width:250px;height:250px;border-radius:50%;overflow:hidden;background:#000;margin:10px 0;border:2px solid var(--color-primary);position:relative}.message-video-circle.processing{background:#2a2d37;display:flex;align-items:center;justify-content:center;border-style:dashed;opacity:.8}.video-processing-loader{display:flex;flex-direction:column;align-items:center;gap:8px;color:#fff;text-align:center}.message-video-circle video{width:100%;height:100%;object-fit:cover;cursor:pointer}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.upload-progress-container{flex:1;height:4px;background:var(--color-surface-2);border-radius:2px;overflow:hidden;position:relative}.upload-progress-bar{height:100%;background:var(--color-primary);transition:width .3s ease}.upload-progress-text{position:absolute;right:0;top:-20px;font-size:var(--fz-xs);color:var(--color-text-2)}.image-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000e6;display:flex;align-items:center;justify-content:center;z-index:1000;cursor:zoom-out;padding:40px}.image-modal-content{max-width:100%;max-height:100%;position:relative;display:flex;flex-direction:column;align-items:center}.image-modal-content img{max-width:100%;max-height:90vh;object-fit:contain;border-radius:4px;box-shadow:0 0 40px #00000080}.image-modal-close{position:absolute;top:-30px;right:-30px;background:none;border:none;color:#fff;font-size:32px;cursor:pointer;padding:10px}.image-modal-caption{color:#fff;margin-top:16px;font-size:var(--fz-md);text-align:center}.mobile-only{display:none!important}@media(max-width:768px){.mobile-only{display:flex!important}.sidebar{width:100%;min-width:100%;border-right:none}.sidebar.mobile-hidden{display:none}.chat-main{width:100%}.chat-view.mobile-hidden{display:none}.chat-header{padding:0 12px}.chat-header-left{display:flex;align-items:center;gap:8px;width:100%}.back-btn{padding:8px;font-size:20px;min-width:44px;justify-content:center}.chat-messages{padding:12px}.message-item{margin-bottom:12px!important;padding:0 10px!important}.message-video-circle{width:200px;height:200px}.chat-input-bar{padding:12px;gap:10px;flex-direction:column;align-items:stretch;flex-shrink:0;background:var(--color-surface)}.chat-input-bar input[type=text]{width:100%;margin-right:0}.input-actions-wrapper{display:flex;justify-content:space-between;align-items:center;width:100%;min-height:48px}.input-actions{gap:4px;flex:1;justify-content:flex-start}.btn-primary{padding:8px 12px;font-size:13px}.voice-btn{font-size:18px!important}}.unread-separator{text-align:center;margin:20px 0;position:relative;font-size:11px;color:var(--color-primary);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.unread-separator:before,.unread-separator:after{content:"";position:absolute;top:50%;width:calc(50% - 70px);height:1px;background:var(--color-primary);opacity:.3}.unread-separator:before{left:0}.unread-separator:after{right:0}.message-item{margin-bottom:20px;display:flex;flex-direction:column;padding:0 20px}.message-container{display:flex;gap:12px;max-width:85%}.message-item.own{align-items:flex-end}.message-item.own .message-container{flex-direction:row-reverse}.message-avatar{width:32px;height:32px;flex-shrink:0;font-size:12px}.message-content-wrapper{display:flex;flex-direction:column;gap:4px}.message-item.own .message-content-wrapper{align-items:flex-end}.message-item.other{align-items:flex-start}.message-sender{font-size:11px;font-weight:600;opacity:.7;margin-bottom:2px}.message-bubble{padding:10px 14px;border-radius:16px;font-size:14px;line-height:1.5;position:relative;word-wrap:break-word}.message-item.other .message-bubble{background:var(--color-surface-2);border-bottom-left-radius:4px;color:var(--color-text)}.message-item.own .message-bubble{background:var(--color-primary);color:#fff;border-bottom-right-radius:4px}.message-footer{display:flex;align-items:center;gap:8px;font-size:10px;opacity:.5}.message-item.own .message-footer{flex-direction:row-reverse}.btn-delete-msg{background:none;border:none;padding:0;cursor:pointer;font-size:12px;opacity:0;transition:opacity .2s}.message-item:hover .btn-delete-msg{opacity:.6}.chat-input-row{display:flex;gap:10px;width:100%;align-items:center}.mobile-send-btn{display:none;width:40px;height:40px;border-radius:50%;background:var(--color-primary);color:#fff;border:none;font-size:18px;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0}@media(max-width:768px){.mobile-send-btn{display:flex}}.chat-input-bar{padding:12px 16px;background:var(--color-surface);border-top:1px solid var(--color-border);display:flex;flex-direction:column;gap:8px}@media(max-width:768px){.chat-input-bar{padding:10px}}.admin-page{min-height:100vh;background:var(--color-bg);display:flex;flex-direction:column}.admin-header{height:var(--header-h);padding:0 24px;background:var(--color-surface);border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between}.admin-title{font-size:var(--fz-lg);font-weight:700;color:var(--color-text)}.admin-header-actions{display:flex;gap:12px}.admin-content{flex:1;padding:32px 24px;max-width:1200px;margin:0 auto;width:100%}.admin-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--r-lg);overflow:hidden}.admin-section-header{padding:24px;border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between}.admin-section-header h2{font-size:var(--fz-md);font-weight:600}.admin-loading{padding:48px;text-align:center;color:var(--color-text-2)}.admin-table-wrapper{overflow-x:auto}.admin-table{width:100%;border-collapse:collapse}.admin-table th,.admin-table td{padding:16px 24px;text-align:left;border-bottom:1px solid var(--color-border);font-size:var(--fz-sm)}.admin-table th{font-weight:600;color:var(--color-text-2);background:var(--color-surface-2)}.admin-table tr:last-child td{border-bottom:none}.admin-table tr:hover td{background:#ffffff05}.admin-user-name{display:flex;align-items:center;gap:12px;font-weight:500;color:var(--color-text)}.admin-avatar{width:32px;height:32px;border-radius:50%;background:var(--color-surface-2);display:flex;align-items:center;justify-content:center;font-weight:700;color:var(--color-primary);flex-shrink:0;overflow:hidden}.admin-avatar img{width:100%;height:100%;object-fit:cover}.role-badge{display:inline-flex;padding:4px 8px;border-radius:var(--r-sm);font-size:11px;font-weight:600;background:var(--color-surface-2);color:var(--color-text-2)}.role-badge.role-global_admin{background:#6c63ff26;color:var(--color-primary)}.status-badge{display:inline-flex;padding:4px 8px;border-radius:var(--r-sm);font-size:11px;font-weight:600}.status-badge.active{background:#00d4aa26;color:var(--color-accent)}.status-badge.inactive{background:#ff5c7a26;color:var(--color-danger)}.admin-avatar.group-avatar{border-radius:8px;width:48px;height:48px}.input{padding:12px 16px;background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--r-md);color:var(--color-text);font-family:var(--font);font-size:var(--fz-sm);transition:all var(--t-fast);outline:none}.input:focus{border-color:var(--color-primary);background:var(--color-surface)}.color-presets{display:flex;gap:8px;margin-top:8px;flex-wrap:wrap}.color-item{width:28px;height:28px;border-radius:6px;cursor:pointer;border:2px solid transparent;transition:transform .2s}.color-item:hover{transform:scale(1.1)}.color-item.active{border-color:#fff;box-shadow:0 0 0 1px var(--color-primary)}.color-picker-container{display:flex;align-items:center;gap:12px}.custom-color-input{width:40px;height:40px;padding:0;border:none;background:none;cursor:pointer}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:2000;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:20px}.modal{background:var(--color-surface);border:1px solid var(--color-border);border-radius:20px;width:100%;max-width:500px;padding:32px;box-shadow:0 25px 50px -12px #00000080;animation:modalEnter .3s ease-out}@keyframes modalEnter{0%{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-header{margin-bottom:24px}.modal-header h3{font-size:20px;font-weight:700;margin:0;color:var(--color-text)}.form-group{margin-bottom:20px}.form-group label{display:block;font-size:13px;font-weight:600;margin-bottom:8px;color:var(--color-text-2)}.modal-footer{margin-top:32px;display:flex;justify-content:flex-end;gap:12px}.admin-member-list{margin-top:12px;display:flex;flex-direction:column;gap:8px;max-height:250px;overflow-y:auto;border:1px solid var(--color-border);border-radius:12px;padding:8px;background:#0000001a}.admin-member-item{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:var(--color-surface);border-radius:8px;border:1px solid var(--color-border)}.admin-member-info{display:flex;align-items:center;gap:10px;font-size:13px}.admin-member-badge{font-size:10px;padding:2px 6px;border-radius:4px;background:var(--color-surface-2);color:var(--color-text-2)}:root{--color-bg: #0f1117;--color-surface: #1a1d27;--color-surface-2: #22263a;--color-border: rgba(255,255,255,.08);--color-primary: #6c63ff;--color-primary-h: #8b85ff;--color-accent: #00d4aa;--color-danger: #ff5c7a;--color-warning: #ffc95c;--color-text: #e8eaf0;--color-text-2: #9196b0;--color-text-3: #5c6080;--sidebar-w: 300px;--header-h: 60px;--font: "Inter", system-ui, sans-serif;--fz-xs: 11px;--fz-sm: 13px;--fz-md: 15px;--fz-lg: 18px;--fz-xl: 24px;--r-sm: 8px;--r-md: 12px;--r-lg: 18px;--r-xl: 24px;--r-full: 9999px;--shadow-sm: 0 2px 8px rgba(0,0,0,.24);--shadow-md: 0 8px 32px rgba(0,0,0,.32);--shadow-lg: 0 24px 64px rgba(0,0,0,.48);--t-fast: .12s ease;--t-base: .2s ease;--t-slow: .35s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;font-family:var(--font);font-size:var(--fz-md);background:var(--color-bg);color:var(--color-text);-webkit-font-smoothing:antialiased}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--r-full)}a{color:var(--color-primary);text-decoration:none}a:hover{color:var(--color-primary-h)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;border:none;border-radius:var(--r-md);font-family:var(--font);font-size:var(--fz-sm);font-weight:600;cursor:pointer;transition:all var(--t-base);outline:none}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover{background:var(--color-primary-h);transform:translateY(-1px);box-shadow:0 4px 16px #6c63ff66}.btn-ghost{background:transparent;color:var(--color-text-2);border:1px solid var(--color-border)}.btn-ghost:hover{background:var(--color-surface-2);color:var(--color-text)}.btn-danger{background:var(--color-danger);color:#fff}.btn:disabled{opacity:.4;cursor:not-allowed;pointer-events:none}.form-group{display:flex;flex-direction:column;gap:6px}.form-label{font-size:var(--fz-sm);font-weight:500;color:var(--color-text-2)}.form-input{padding:12px 16px;background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--r-md);color:var(--color-text);font-family:var(--font);font-size:var(--fz-sm);transition:border-color var(--t-fast);outline:none;width:100%}.form-input:focus{border-color:var(--color-primary)}.form-input::placeholder{color:var(--color-text-3)}.avatar{border-radius:var(--r-full);object-fit:cover;background:var(--color-surface-2);flex-shrink:0}.badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;border-radius:var(--r-full);background:var(--color-primary);color:#fff;font-size:var(--fz-xs);font-weight:700}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.gap-2{gap:8px}.gap-3{gap:12px}.text-muted{color:var(--color-text-2)}.text-xs{font-size:var(--fz-xs)}.text-sm{font-size:var(--fz-sm)}.font-medium{font-weight:500}.font-semibold{font-weight:600}
