*{box-sizing:border-box}body{margin:0;font-family:Avenir Next,Segoe UI,sans-serif;background:radial-gradient(circle at top left,#eff6ff,#f8fafc 45%,#eef2ff);color:#0f172a}.container{max-width:1040px;margin:0 auto;padding:24px}.container.user-mode{max-width:1280px;padding:16px 20px}.topbar{background:#fff;border:1px solid #dbe4ef;border-radius:14px;padding:10px 12px;display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:12px;box-shadow:0 8px 20px #0f172a0d}.topbar-main{display:flex;align-items:baseline;gap:12px;min-width:0}.topbar-main h1{margin:0;white-space:nowrap}.container:not(.user-mode) .topbar-main h1{font-size:26px}.container.user-mode .topbar-main h1{font-size:24px}.topbar-main .sub{margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.topbar-actions{display:flex;align-items:center;gap:10px;flex-shrink:0}.topbar-actions .sub{margin:0;white-space:nowrap}.topbar-lang{display:inline-flex;align-items:center;gap:6px;white-space:nowrap;color:#475569;font-size:14px}.topbar-lang select{padding:6px 8px;border-radius:8px;border:1px solid #cbd5e1;background:#fff}.topbar-btn{margin-top:0;white-space:nowrap}.topbar .topbar-btn{padding:6px 10px;font-size:14px;border-radius:8px;line-height:1.2;background:#dc2626}.topbar .topbar-btn:hover{background:#b91c1c}.topbar-admin{flex-wrap:nowrap}.row{display:grid;grid-template-columns:1fr auto;gap:8px}.auth{display:grid;gap:8px;max-width:420px;background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:14px}input,button{padding:10px;font-size:16px}input{border:1px solid #cbd5e1;border-radius:10px;background:#fff}button{cursor:pointer;background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;border:none;border-radius:10px;font-weight:600}button[disabled]{opacity:.6;cursor:not-allowed}.link{margin-top:10px;background:#111827}.topbar .topbar-btn{margin-top:0}.sub{color:#555;margin:4px 0}.status-line{display:inline-flex;align-items:center;gap:6px}.status-dot{width:9px;height:9px;border-radius:50%;display:inline-block}.status-dot.on{background:#16a34a}.status-dot.off{background:#94a3b8}.lang-row{display:flex;align-items:center;gap:8px;margin:8px 0 4px}.lang-row select{padding:8px 10px;border-radius:8px;border:1px solid #cbd5e1;background:#fff}.error{color:#b91c1c;margin:8px 0}.messages{margin:12px 0;background:#fff;border:1px solid #dbe4ef;border-radius:14px;padding:14px;min-height:320px;max-height:460px;overflow:auto;display:flex;flex-direction:column;gap:10px;box-shadow:0 10px 24px #0f172a0f}.older-loading{text-align:center;color:#64748b;font-size:12px;padding:4px 0}.user-mode .messages{min-height:calc(100vh - 290px);max-height:calc(100vh - 290px);border-radius:16px;padding:12px 14px}.message{max-width:95%;border-radius:14px;padding:10px 12px;display:grid;gap:6px;line-height:1.35;word-break:break-word;align-self:flex-start;background:#f8fafc;border:1px solid #e2e8f0}.message-own,.message-other{align-self:flex-start}.message-meta{font-size:12px;font-weight:600}.message-head{display:flex;align-items:center;justify-content:space-between;gap:10px}.message-own .message-meta{color:#1d4ed8}.message-other .message-meta{color:#b45309}.message-time{font-size:11px;color:#64748b;margin-left:auto;white-space:nowrap}.msg-recalled-time{font-size:12px;color:#92400e;font-weight:400;justify-self:center;background:#fef9c3;border:1px solid #fde68a;border-radius:999px;padding:2px 8px}.msg-recall-link{justify-self:center;padding:0;font-size:12px;border:none;background:transparent;color:#dc2626;font-weight:400;cursor:pointer;text-decoration:none}.msg-attachment{margin-top:4px;border-radius:10px;max-width:320px}.msg-image{width:min(320px,100%);border:1px solid #dbe4ef}.msg-image-btn{border:none;padding:0;margin:0;background:transparent;cursor:zoom-in;width:fit-content}.msg-video{width:min(360px,100%);border:1px solid #dbe4ef;background:#000}.msg-audio{width:min(320px,100%)}.msg-audio-wrap{display:grid;gap:6px}.msg-audio-fallback{width:min(320px,100%);background:#0f172a}.msg-link{color:#1d4ed8;text-decoration:none;font-weight:600}.msg-link:hover{text-decoration:underline}.image-lightbox{position:fixed;top:0;right:0;bottom:0;left:0;background:#020617c7;display:grid;place-items:center;padding:24px;z-index:1200}.image-lightbox-content{position:relative;max-width:min(1200px,96vw);max-height:92vh}.image-lightbox-img{display:block;max-width:100%;max-height:92vh;border-radius:12px;box-shadow:0 20px 40px #0006}.image-lightbox-close{position:absolute;top:-12px;right:-12px;width:34px;height:34px;border-radius:999px;background:#111827;color:#fff;border:1px solid #1f2937;padding:0;line-height:1;font-size:24px;cursor:pointer}.admin-grid{display:grid;grid-template-columns:320px 1fr;gap:14px;margin-top:14px}.admin-empty{display:flex;align-items:center;justify-content:center}.admin-empty-card{width:100%;min-height:320px;border:1px dashed #bfdbfe;border-radius:16px;background:linear-gradient(140deg,#f8fbff,#eef6ff);display:grid;place-content:center;text-align:center;padding:24px;color:#334155}.admin-empty-card h3{margin:0 0 8px;color:#1e3a8a}.admin-empty-card p{margin:0}.user-chat-shell{display:grid;grid-template-rows:auto auto 1fr auto;gap:8px}.user-chat-shell h3{margin:4px 0}.user-mode .row input{padding:12px}.user-mode .row button:not(.mic-btn){min-width:110px}.users{background:#fff;border:1px solid #dbe4ef;border-radius:12px;padding:12px;max-height:560px;overflow:auto;box-shadow:0 10px 24px #0f172a0d}.user-item{width:100%;text-align:left;display:block;align-items:center;gap:8px;margin-bottom:8px;background:#eff6ff;color:#0f172a}.user-item.active{outline:2px solid #2563eb;background:#dbeafe}.user-item-label{display:inline-flex;align-items:center;gap:8px}.user-item-text{display:grid;gap:1px}.user-item-name{font-size:14px;color:#0f172a}.user-item-email{font-size:12px;color:#64748b;font-weight:400}.unread-badge{min-width:20px;height:20px;padding:0 6px;border-radius:999px;background:#dc2626;color:#fff;font-size:12px;font-weight:700;display:inline-flex;align-items:center;justify-content:center}.user-presence-dot{width:9px;height:9px;border-radius:50%;display:inline-block;flex:0 0 auto}.user-presence-dot.on{background:#16a34a}.user-presence-dot.off{background:#94a3b8}.file-btn{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;padding:0;border-radius:10px;background:#0f766e;color:#fff;font-weight:600;cursor:pointer}.file-icon{font-size:20px;line-height:1}.mic-btn{width:42px;height:42px;border-radius:10px;border:none;background:#0f172a;color:#fff;font-size:18px;cursor:pointer}.mic-btn.recording{background:#b91c1c;animation:pulse 1s ease-in-out infinite}@keyframes pulse{0%{box-shadow:0 0 #b91c1c59}70%{box-shadow:0 0 0 10px #b91c1c00}to{box-shadow:0 0 #b91c1c00}}.file-btn.disabled{opacity:.6;cursor:not-allowed;pointer-events:none}.composer-row{display:flex;align-items:center;gap:8px;flex-wrap:nowrap}.composer-row input{flex:1;min-width:0}.composer-row .mic-btn{flex:0 0 auto;min-width:42px}.composer-row button[type=submit]{flex:0 0 auto}.attach-pending{margin:8px 0;padding:8px 10px;border:1px solid #cbd5e1;border-radius:10px;background:#f8fafc;display:inline-flex;align-items:center;gap:8px;max-width:100%}.pending-image-btn{border:none;background:transparent;padding:0;margin:0;cursor:zoom-in;line-height:0}.pending-image-thumb{width:44px;height:44px;border-radius:8px;object-fit:cover;border:1px solid #cbd5e1;display:block}.attach-name{max-width:280px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:13px}.attach-remove{background:#ef4444;color:#fff;border:none;border-radius:999px;width:22px;height:22px;line-height:1;padding:0;margin:0;cursor:pointer}@media (max-width: 900px){.admin-grid{grid-template-columns:1fr}.topbar{flex-wrap:wrap}.topbar-main{width:100%}.topbar-actions{width:100%;justify-content:space-between}.topbar-lang{margin-left:auto}.user-mode .messages{min-height:calc(100vh - 340px);max-height:calc(100vh - 340px)}}
