:root{--bg-void: #010409;--bg-base: #040c1a;--bg-panel: #060f22;--bg-card: #08132e;--bg-elevated: #0d1c3f;--bg-hover: #112247;--bg-input: #070e1f;--blue-900: #0f2460;--blue-700: #1446b0;--blue-500: #1d6ef5;--blue-400: #3b82f6;--blue-300: #60a5fa;--blue-200: #93c5fd;--cyan-400: #22d3ee;--cyan-300: #67e8f9;--border-dim: rgba(59,130,246,.08);--border: rgba(59,130,246,.18);--border-bright: rgba(59,130,246,.38);--text-primary: #ccd9f0;--text-secondary: #6e90c0;--text-muted: #2d4470;--success: #10b981;--error: #ef4444;--warning: #f59e0b}*{margin:0;padding:0;box-sizing:border-box}html,body{height:100%;width:100%;overflow:hidden}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg-void);color:var(--text-primary);-webkit-font-smoothing:antialiased}::-webkit-scrollbar{width:3px;height:3px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:linear-gradient(180deg,var(--blue-500),var(--cyan-400));border-radius:3px}*{scrollbar-width:thin;scrollbar-color:var(--blue-500) transparent}.auth-container{display:flex;justify-content:center;align-items:center;height:100vh;background:radial-gradient(ellipse 100% 70% at 50% -10%,rgba(29,110,245,.22) 0%,rgba(34,211,238,.06) 40%,transparent 70%),radial-gradient(ellipse 60% 40% at 85% 90%,rgba(29,110,245,.1) 0%,transparent 60%),radial-gradient(ellipse 40% 30% at 15% 80%,rgba(34,211,238,.05) 0%,transparent 50%),var(--bg-void)}.auth-card{background:linear-gradient(145deg,#0d1c3ff2,#08132efa,#060f22);border:1px solid var(--border);border-radius:20px;padding:48px 44px;width:420px;position:relative;overflow:hidden;box-shadow:0 0 0 1px #1d6ef50f,0 32px 80px #000000b3,0 0 60px #1d6ef51a,inset 0 1px #ffffff0a}.auth-card:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent 0%,var(--blue-500) 30%,var(--cyan-400) 60%,transparent 100%);opacity:.9}.auth-card:after{content:"";position:absolute;top:-100px;left:50%;transform:translate(-50%);width:280px;height:200px;background:radial-gradient(ellipse,rgba(29,110,245,.14) 0%,transparent 70%);pointer-events:none}.auth-header{text-align:center;margin-bottom:38px;position:relative;z-index:1}.auth-logo{width:58px;height:58px;background:linear-gradient(135deg,var(--blue-700) 0%,var(--blue-500) 50%,var(--cyan-400) 100%);border-radius:16px;display:flex;align-items:center;justify-content:center;margin:0 auto 18px;font-size:26px;color:#fff;box-shadow:0 0 0 1px #1d6ef54d,0 0 30px #1d6ef580,0 8px 20px #0006;font-family:JetBrains Mono,monospace}.auth-title{font-size:23px;font-weight:700;color:var(--text-primary);letter-spacing:-.5px;margin-bottom:7px}.auth-subtitle{color:var(--text-secondary);font-size:13px;font-family:JetBrains Mono,monospace;opacity:.8}.form-group{margin-bottom:16px;position:relative;z-index:1}.form-label{display:block;margin-bottom:7px;color:var(--text-secondary);font-weight:500;font-size:10px;letter-spacing:1.2px;text-transform:uppercase;font-family:JetBrains Mono,monospace}.form-input{width:100%;padding:12px 16px;border:1px solid var(--border-dim);border-radius:10px;font-size:14px;font-family:inherit;transition:all .2s;background:linear-gradient(135deg,#070e1ff2,#040c1afa);color:var(--text-primary)}.form-input::placeholder{color:var(--text-muted);font-size:13px}.form-input:focus{outline:none;border-color:var(--blue-400);box-shadow:0 0 0 3px #3b82f61a,0 0 12px #1d6ef526;background:linear-gradient(135deg,#0a1228fa,#070e1f)}.btn{width:100%;padding:13px;border:none;border-radius:10px;font-size:14px;font-weight:600;font-family:inherit;cursor:pointer;transition:all .2s;margin-bottom:10px;letter-spacing:.2px;position:relative;z-index:1}.btn-primary{background:linear-gradient(135deg,var(--blue-500) 0%,var(--blue-700) 60%,#0f2460 100%);color:#fff;box-shadow:0 4px 20px #1d6ef573,0 0 0 1px #3b82f633,inset 0 1px #ffffff14}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 8px 28px #1d6ef599,0 0 0 1px #3b82f659,inset 0 1px #ffffff1a;filter:brightness(1.1)}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:linear-gradient(135deg,#1d6ef50f,#22d3ee08);color:var(--blue-300);border:1px solid var(--border)}.btn-secondary:hover{background:linear-gradient(135deg,#1d6ef51f,#22d3ee0f);border-color:var(--border-bright)}.app-container{display:none;height:100vh;width:100%;background:var(--bg-base);flex-direction:column;overflow:hidden}.app-header{height:56px;background:linear-gradient(90deg,var(--bg-panel) 0%,rgba(8,19,46,.95) 50%,var(--bg-panel) 100%);border-bottom:1px solid var(--border-dim);padding:0 20px;display:flex;justify-content:space-between;align-items:center;flex-shrink:0;position:relative}.app-header:after{content:"";position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent 0%,var(--blue-700) 20%,var(--blue-500) 40%,var(--cyan-400) 60%,var(--blue-500) 80%,transparent 100%);opacity:.7}.app-title{font-size:16px;font-weight:700;letter-spacing:-.2px;display:flex;align-items:center;gap:9px;background:linear-gradient(90deg,var(--blue-300) 0%,var(--cyan-400) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.app-title:before{content:"⚛";font-size:16px;background:linear-gradient(135deg,var(--blue-500),var(--cyan-400));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.user-info{display:flex;align-items:center;gap:10px}.user-details{display:flex;flex-direction:column;align-items:flex-end}.user-name{font-weight:600;font-size:13px;color:var(--text-primary)}.user-id{font-size:10px;color:var(--blue-300);font-family:JetBrains Mono,monospace;background:#1d6ef514;border:1px solid var(--border-dim);padding:2px 6px;border-radius:4px;cursor:pointer;transition:all .2s;margin-top:2px;letter-spacing:.5px}.user-id:hover{background:#1d6ef526;border-color:var(--border);box-shadow:0 0 8px #1d6ef533}.avatar{width:34px;height:34px;border-radius:9px;background:linear-gradient(135deg,var(--blue-700) 0%,var(--blue-500) 50%,var(--cyan-400) 100%);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;color:#fff;box-shadow:0 0 12px #1d6ef566,0 0 0 1px #3b82f633}.logout-btn{background:linear-gradient(135deg,#ef444412,#ef44440a);border:1px solid rgba(239,68,68,.15);color:#f87171;padding:6px 13px;border-radius:7px;cursor:pointer;font-size:12px;font-family:inherit;font-weight:500;transition:all .2s}.logout-btn:hover{background:#ef444421;border-color:#ef44444d}.app-content{display:flex;flex:1;min-height:0;overflow:hidden}.sidebar{width:286px;background:linear-gradient(180deg,var(--bg-panel) 0%,rgba(6,12,28,.97) 100%);border-right:1px solid var(--border-dim);display:flex;flex-direction:column;flex-shrink:0;min-height:0;overflow:hidden}.sidebar-tabs{display:flex;border-bottom:1px solid var(--border-dim);flex-shrink:0;background:#040c1a99}.tab{flex:1;padding:13px;text-align:center;cursor:pointer;font-weight:600;font-size:10px;color:var(--text-muted);border-bottom:2px solid transparent;transition:all .2s;letter-spacing:1px;text-transform:uppercase;font-family:JetBrains Mono,monospace}.tab.active{color:var(--blue-300);border-bottom-color:var(--blue-500);background:linear-gradient(180deg,rgba(29,110,245,.06) 0%,transparent 100%);text-shadow:0 0 8px rgba(59,130,246,.4)}.tab:hover:not(.active){color:var(--text-secondary);background:#ffffff05}.sidebar-content{flex:1;overflow-y:auto;padding:10px;min-height:0}.chat-item{display:flex;align-items:center;padding:10px 11px;border-radius:10px;cursor:pointer;transition:all .18s;margin-bottom:3px;border:1px solid transparent}.chat-item:hover{background:linear-gradient(135deg,#1d6ef512,#22d3ee08);border-color:var(--border-dim)}.chat-item.active{background:linear-gradient(135deg,#1d6ef524,#22d3ee0d);border-color:var(--border)}.chat-avatar{width:40px;height:40px;border-radius:11px;background:linear-gradient(135deg,var(--blue-700) 0%,var(--blue-500) 60%,var(--cyan-400) 100%);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;margin-right:10px;flex-shrink:0;box-shadow:0 0 12px #1d6ef540,0 2px 6px #0000004d}.chat-info{flex:1;min-width:0}.chat-name{font-weight:600;font-size:13px;color:var(--text-primary);margin-bottom:3px;display:flex;align-items:center;gap:5px}.chat-preview{color:var(--text-muted);font-size:11px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-family:JetBrains Mono,monospace}.add-friend-form{display:flex;gap:7px;margin-bottom:14px}.add-friend-input{flex:1;padding:9px 12px;border:1px solid var(--border-dim);border-radius:8px;font-size:12px;font-family:JetBrains Mono,monospace;background:var(--bg-input);color:var(--text-primary);transition:all .2s;letter-spacing:.5px}.add-friend-input::placeholder{color:var(--text-muted);font-size:11px}.add-friend-input:focus{outline:none;border-color:var(--blue-400);box-shadow:0 0 0 3px #3b82f61a}.add-friend-btn{padding:9px 13px;background:linear-gradient(135deg,var(--blue-500) 0%,var(--blue-700) 100%);color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:600;font-size:12px;font-family:inherit;transition:all .2s;white-space:nowrap;box-shadow:0 2px 10px #1d6ef54d}.add-friend-btn:hover{filter:brightness(1.15);transform:translateY(-1px)}.friend-item{display:flex;align-items:center;padding:10px 11px;border-radius:10px;margin-bottom:5px;background:linear-gradient(135deg,#0d1c3f99,#08132ecc);border:1px solid var(--border-dim);transition:all .18s}.friend-item:hover{border-color:var(--border);box-shadow:0 0 12px #1d6ef514}.friend-info{flex:1;margin-left:10px}.friend-name{font-weight:600;font-size:13px;color:var(--text-primary);margin-bottom:2px}.friend-status{color:var(--success);font-size:10px;font-weight:500;font-family:JetBrains Mono,monospace}.friend-actions{display:flex;gap:5px}.btn-small{padding:5px 10px;border:none;border-radius:6px;font-size:11px;cursor:pointer;font-weight:600;font-family:inherit;transition:all .18s}.btn-chat{background:linear-gradient(135deg,#1d6ef51f,#22d3ee0d);color:var(--blue-300);border:1px solid var(--border-dim)}.btn-chat:hover{background:linear-gradient(135deg,var(--blue-500) 0%,var(--blue-700) 100%);color:#fff;border-color:var(--blue-500);box-shadow:0 2px 8px #1d6ef559}.btn-remove{background:#ef444412;color:#f87171;border:1px solid rgba(239,68,68,.12)}.btn-remove:hover{background:var(--error);color:#fff;border-color:var(--error)}.chat-area{flex:1;display:flex;flex-direction:column;min-height:0;min-width:0;overflow:hidden;background:radial-gradient(ellipse 80% 40% at 50% 0%,rgba(29,110,245,.05) 0%,transparent 60%),linear-gradient(180deg,var(--bg-base) 0%,var(--bg-void) 100%)}#chatContent{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}.chat-header{background:linear-gradient(90deg,#060f22fa,#08132ef2,#060f22fa);border-bottom:1px solid var(--border-dim);flex-shrink:0}.chat-header-content{display:flex;align-items:center;padding:13px 18px;width:100%;justify-content:space-between}.chat-header-avatar{width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,var(--blue-700) 0%,var(--blue-500) 60%,var(--cyan-400) 100%);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;margin-right:12px;flex-shrink:0;box-shadow:0 0 10px #1d6ef54d}.chat-header-info{flex:1}.chat-header-info h3{color:var(--text-primary);font-size:14px;font-weight:600;display:flex;align-items:center;gap:8px;margin-bottom:2px}.chat-header-info p{color:var(--text-muted);font-size:11px;font-family:JetBrains Mono,monospace}.messages-container{flex:1;overflow-y:auto;overflow-x:hidden;min-height:0;padding:18px 20px;display:flex;flex-direction:column;gap:3px}.message{display:flex;margin-bottom:3px;animation:fadeUp .18s ease}.message.own{justify-content:flex-end}.message-bubble{max-width:60%;padding:9px 14px;border-radius:16px;word-wrap:break-word;word-break:break-word}.message.own .message-bubble{background:linear-gradient(135deg,var(--blue-500) 0%,var(--blue-700) 60%,#0f2460 100%);color:#fff;border-bottom-right-radius:3px;box-shadow:0 2px 12px #1d6ef559,0 0 0 1px #3b82f626,inset 0 1px #ffffff14}.message:not(.own) .message-bubble{background:linear-gradient(135deg,#0d1c3fe6,#08132ef2);color:var(--text-primary);border:1px solid var(--border-dim);border-bottom-left-radius:3px;box-shadow:inset 0 1px #ffffff08}.message.pending .message-bubble{opacity:.5}.message-content{font-size:14px;line-height:1.55;margin-bottom:3px}.message-time{font-size:10px;opacity:.5;display:flex;align-items:center;gap:4px;font-family:JetBrains Mono,monospace}.message.own .message-time{justify-content:flex-end}.temp-indicator{color:var(--warning);font-size:10px}.permanent-indicator{color:var(--success);font-size:10px}.message-input-container{padding:14px 18px;background:linear-gradient(90deg,#060f22fa,#08132ef2,#060f22fa);border-top:1px solid var(--border-dim);flex-shrink:0}.message-input-form{display:flex;gap:9px;align-items:center}.message-input{flex:1;padding:10px 15px;border:1px solid var(--border-dim);border-radius:12px;font-size:14px;font-family:inherit;outline:none;transition:all .2s;background:linear-gradient(135deg,#070e1ff2,#040c1afa);color:var(--text-primary)}.message-input::placeholder{color:var(--text-muted);font-size:13px}.message-input:focus{border-color:var(--blue-500);box-shadow:0 0 0 3px #1d6ef51a,0 0 14px #1d6ef51f}.send-btn{width:42px;height:42px;border:none;border-radius:11px;background:linear-gradient(135deg,var(--blue-500) 0%,var(--blue-700) 60%,#0f2460 100%);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:15px;transition:all .2s;flex-shrink:0;box-shadow:0 2px 12px #1d6ef566,0 0 0 1px #3b82f626}.send-btn:hover{transform:scale(1.07);box-shadow:0 4px 18px #1d6ef58c;filter:brightness(1.1)}.save-chat-btn{display:flex;align-items:center;gap:5px;padding:6px 12px;background:linear-gradient(135deg,#1d6ef512,#22d3ee08);border:1px solid var(--border-dim);color:var(--blue-300);border-radius:7px;cursor:pointer;font-size:11px;font-weight:600;font-family:inherit;transition:all .2s}.save-chat-btn:hover{background:linear-gradient(135deg,#1d6ef524,#22d3ee12);border-color:var(--border);transform:translateY(-1px)}.save-chat-btn.has-messages{background:#10b98112;border-color:#10b9812e;color:var(--success)}.save-chat-btn.saved{background:transparent;border-color:var(--border-dim);color:var(--text-muted)}.realtime-status{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:500;padding:2px 7px;border-radius:20px;background:#10b98112;color:var(--success);border:1px solid rgba(16,185,129,.15);font-family:JetBrains Mono,monospace}.realtime-status.disconnected{background:#ef444412;color:var(--error);border-color:#ef444426}.status-dot{width:5px;height:5px;border-radius:50%;background:currentColor;animation:pulse 2s infinite;box-shadow:0 0 4px currentColor}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--text-muted);text-align:center;padding:30px 20px;gap:8px}.empty-icon{font-size:36px;margin-bottom:8px;opacity:.3;filter:drop-shadow(0 0 8px rgba(29,110,245,.4))}.empty-state h3,.empty-state h4{color:var(--text-secondary);font-size:15px;font-weight:600}.empty-state p{color:var(--text-muted);font-size:12px;font-family:JetBrains Mono,monospace}.notification{position:fixed;top:20px;right:20px;background:linear-gradient(135deg,#0d1c3ff7,#08132efc);padding:13px 17px;border-radius:12px;box-shadow:0 8px 32px #0009,0 0 0 1px var(--border-dim);border-left:3px solid;z-index:9999;animation:slideInRight .25s ease;font-size:13px;color:var(--text-primary);max-width:340px;line-height:1.45}.notification.success{border-left-color:var(--success);box-shadow:0 8px 32px #0009,0 0 16px #10b9811a,0 0 0 1px var(--border-dim)}.notification.error{border-left-color:var(--error);box-shadow:0 8px 32px #0009,0 0 16px #ef44441a,0 0 0 1px var(--border-dim)}@keyframes fadeUp{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(50px)}to{opacity:1;transform:translate(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}.hidden{display:none!important}@media (max-width: 775px){.auth-card{width:93%;max-width:420px;padding:36px 26px}.app-content{position:relative;overflow:hidden}.sidebar{width:100%;height:100%;position:absolute;top:0;left:0;z-index:10;transform:translate(0);transition:transform .28s ease}.chat-area{width:100%;height:100%;position:absolute;top:0;left:0;z-index:20;transform:translate(100%);transition:transform .28s ease}.chat-open .sidebar{transform:translate(-100%)}.chat-open .chat-area{transform:translate(0)}.app-header{padding:0 14px}.user-name{font-size:12px}.back-to-chats{display:flex;align-items:center;gap:8px;padding:10px 15px;background:var(--bg-panel);border-bottom:1px solid var(--border-dim);cursor:pointer;font-weight:600;font-size:12px;color:var(--blue-300);font-family:JetBrains Mono,monospace}.back-to-chats:before{content:"←";font-size:14px}.messages-container{padding:12px 14px}.message-bubble{max-width:84%}.save-text{display:none}.realtime-status{font-size:9px}.chat-header-content{padding:10px 13px}html,body,.app-container,.app-content,.sidebar,.chat-area,.messages-container{overflow-x:hidden;max-width:100%}}@media (min-width: 776px){.back-to-chats{display:none}.sidebar{width:286px;position:static;transform:none!important}.chat-area{flex:1;position:static;transform:none!important}.user-details{max-width:200px}}@media (max-width: 775px){html,body{overflow-x:hidden;width:100%}.app-container,.app-content{width:100%;overflow-x:hidden}}
