:root{font-family:SF Pro Text,Segoe UI,sans-serif;color:#111827}*{box-sizing:border-box}html,body,#root{margin:0;min-height:100%}body{background:#dfe6ec}.gate{min-height:100svh;display:grid;place-items:center;padding:24px;text-align:center;color:#1f2937;background:radial-gradient(circle at 20% 0%,rgba(120,185,255,.45),transparent 36%),radial-gradient(circle at 80% 0%,rgba(92,156,223,.28),transparent 28%),linear-gradient(180deg,#eaf3fb,#d7e6f5)}.auth-card{width:min(420px,100%);border-radius:20px;padding:24px 20px 18px;background:#ffffffeb;box-shadow:0 20px 40px #1e40af24;border:1px solid #d8e4f1;text-align:left}.auth-logo{display:inline-flex;padding:7px 12px;border-radius:999px;background:#e3f2ff;color:#1d4c73;font-size:12px;font-weight:600}.auth-card h1{margin:12px 0 6px;font-size:24px;line-height:1.2}.auth-sub{margin:0 0 14px;color:#64748b;font-size:14px}.auth-tabs{display:grid;grid-template-columns:1fr 1fr;background:#edf3f9;border-radius:12px;padding:4px;gap:4px;margin-bottom:12px}.auth-tabs button{border:0;border-radius:9px;background:transparent;color:#475569;min-height:38px;font-weight:600}.auth-tabs button.active{background:#fff;color:#0f172a;box-shadow:0 2px 6px #0f172a14}.auth-form{display:grid;gap:10px}.auth-form label{font-size:12px;color:#475569;display:grid;gap:6px}.auth-form input{width:100%;border:1px solid #cbd5e1;border-radius:12px;padding:12px 14px;font-size:15px;outline:none}.auth-form input:focus{border-color:#38bdf8;box-shadow:0 0 0 3px #38bdf833}.auth-submit{margin-top:4px;border:0;border-radius:12px;min-height:46px;background:linear-gradient(180deg,#3da9fc,#2f8be6);color:#fff;font-size:16px;font-weight:600}.auth-error{margin:10px 0 0;font-size:13px;color:#b91c1c;background:#fef2f2;border:1px solid #fecaca;border-radius:10px;padding:9px 10px}.app{width:min(960px,100vw);margin:0 auto;height:100svh;display:grid;grid-template-columns:270px 1fr;background:#e9eff5;position:relative;overflow:hidden}.backdrop{display:none}.sidebar{border-right:1px solid #d2dde8;padding:12px;display:flex;flex-direction:column;gap:12px;overflow-y:auto;background:linear-gradient(180deg,#f6fbff,#eef5fb);transition:transform .22s ease}.chat{display:grid;grid-template-rows:auto 1fr auto;min-width:0;min-height:0;position:relative;animation:fadeIn .18s ease}.chat-head{display:flex;align-items:center;gap:12px;min-height:56px;padding:calc(10px + env(safe-area-inset-top)) 12px 10px;border-bottom:1px solid #d2dde8;background:#5682a3;color:#fff}.chat-head-title{flex:1;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-align:left}.chat-head-title-wrap{min-width:0;display:grid;gap:2px}.chat-head-subtitle{font-size:12px;color:#ffffffd1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.menu-btn{border:1px solid rgba(255,255,255,.35);background:#ffffff1f;color:#fff;font-size:0;width:36px;min-width:36px;height:36px;min-height:36px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;padding:0}.btn-icon{font-size:16px;line-height:1}.primary-btn{display:inline-flex;gap:8px;align-items:center}.profile-card{display:grid;grid-template-columns:auto 1fr auto;gap:10px;align-items:center;background:#fff;border:1px solid #d7e5f2;border-radius:14px;padding:10px}.avatar{width:36px;height:36px;border-radius:50%;display:grid;place-items:center;background:#44a7ff;color:#fff;font-weight:700}.profile-meta{display:grid}.profile-meta strong{font-size:14px}.profile-meta span{font-size:12px;color:#64748b}.ghost-btn{border:0;background:transparent;color:#64748b;font-size:13px}.sidebar-actions{display:grid;gap:8px}.primary-btn,.secondary-btn{border:0;border-radius:12px;min-height:42px;padding:0 12px;font-weight:600;text-align:left}.primary-btn{background:linear-gradient(180deg,#3da9fc,#2f8be6);color:#fff}.secondary-btn{background:#fff;color:#1e3a5f;border:1px solid #cfe0f0}.secondary-btn:disabled{opacity:.6}.invite-card{background:#fff;border:1px dashed #9ec5eb;border-radius:12px;padding:10px;display:grid;gap:8px}.install-hint{background:#fff7ed;border:1px solid #fed7aa;border-radius:12px;padding:10px;display:grid;gap:8px}.install-hint strong{font-size:13px;color:#9a3412}.install-hint span{font-size:12px;color:#7c2d12}.invite-card span{font-size:12px;color:#64748b}.invite-card a{color:#0369a1;font-size:12px;word-break:break-all;text-decoration:none}.invite-card em{font-size:12px;color:#166534;font-style:normal}.flow-input{width:100%;border:1px solid #cbd5e1;border-radius:10px;min-height:40px;padding:0 10px;font-size:14px}.chat-list{display:grid;gap:6px}.chat-search{width:100%;border:1px solid #cbd5e1;border-radius:10px;min-height:38px;padding:0 10px;font-size:13px;background:#fff}.empty-list{font-size:12px;color:#64748b;background:#fff;border:1px dashed #c6daee;border-radius:10px;padding:10px}.chat-row{width:100%;border:1px solid transparent;border-radius:12px;min-height:44px;background:transparent;display:grid;grid-template-columns:auto 1fr;gap:8px;align-items:center;padding:0 10px;text-align:left;color:#1e293b;transition:background-color .12s ease,border-color .12s ease,transform .12s ease}.chat-avatar{width:28px;height:28px;border-radius:50%;display:grid;place-items:center;font-size:11px;font-weight:700;color:#fff;background:linear-gradient(180deg,#38bdf8,#0ea5e9)}.chat-row-main{min-width:0;display:grid}.unread-badge{margin-top:4px;justify-self:end;min-width:18px;height:18px;border-radius:999px;background:#0ea5e9;color:#fff;font-size:11px;display:inline-grid;place-items:center;padding:0 5px}.chat-row-title{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-row-meta{display:grid;grid-template-columns:1fr auto;gap:8px;align-items:center}.chat-row-preview{font-size:12px;color:#64748b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-row-time{font-size:11px;color:#94a3b8}.chat-row:hover{background:#e5f0fb;transform:translateY(-1px)}.chat-row.active{background:#d7eaff;border-color:#b8d6f4}.chat-dot{width:8px;height:8px;border-radius:50%;background:#6b7280}.chat-row.active .chat-dot{background:#0ea5e9}.topbar{padding:calc(10px + env(safe-area-inset-top)) 14px 10px;border-bottom:1px solid #d2dde8;display:flex;flex-direction:column;background:#5682a3;color:#fff}.topline{display:flex;justify-content:space-between;align-items:center}.topbar strong{font-size:18px;font-weight:600}.topbar span{font-size:12px;color:#dce9f5}.push-btn{border:0;border-radius:10px;padding:7px 10px;font-size:12px;color:#0f172a;background:#f8fafc}.push-btn:disabled{opacity:.75}.messages{overflow-y:auto;min-height:0;padding:14px;display:flex;flex-direction:column;gap:10px;background:radial-gradient(circle at 18% 22%,rgba(255,255,255,.6) 0,transparent 30%),radial-gradient(circle at 88% 8%,rgba(198,228,255,.8) 0,transparent 24%),linear-gradient(180deg,#dce6ef,#d5e3ee);transition:opacity .12s ease}.messages.loading{opacity:.85}.skeleton-list{display:grid;gap:6px}.skeleton-row{height:44px;border-radius:10px;background:linear-gradient(90deg,#e2e8f0,#f1f5f9,#e2e8f0);background-size:200% 100%;animation:shimmer 1.2s linear infinite}.skeleton-messages{display:grid;gap:10px;margin:6px 0}.skeleton-msg{height:48px;max-width:78%;border-radius:12px;background:linear-gradient(90deg,#d8e2ec,#eaf0f6,#d8e2ec);background-size:200% 100%;animation:shimmer 1.2s linear infinite}.skeleton-msg.short{max-width:55%}.empty-chat{margin:auto;background:#fffc;border:1px solid #d8e4ef;color:#64748b;font-size:13px;padding:10px 12px;border-radius:999px}.day-sep{display:flex;justify-content:center;margin:6px 0}.day-sep span{font-size:11px;color:#64748b;background:#ffffffd1;border:1px solid #d7e5f2;padding:4px 10px;border-radius:999px}.unread-sep{display:flex;justify-content:center;margin:6px 0}.unread-sep span{font-size:11px;color:#075985;background:#bae6fde6;border:1px solid #7dd3fc;padding:4px 10px;border-radius:999px}.bubble{max-width:82%;border-radius:16px;padding:10px 12px 8px;line-height:1.4;word-break:break-word;box-shadow:0 2px 8px #0f172a1a}.bubble-body{display:grid;gap:6px}.bubble.owner{align-self:flex-start;background:#fff;border-top-left-radius:8px}.bubble.peer{align-self:flex-end;background:#e7ffdb;color:#111827;border-top-right-radius:8px}.bubble.group-mid{margin-top:-4px}.bubble.group-start{margin-top:2px}.bubble small{display:inline-block;margin-top:5px;font-size:11px;color:#6b7280}.read-checks{display:inline-block}.read-checks.single{transform:translateY(.2px)}.read-checks.double{position:relative;width:12px;height:10px;vertical-align:-1px}.read-checks.double .check{position:absolute;font-size:10px;line-height:1}.read-checks.double .check-a{left:0;top:-1px}.read-checks.double .check-b{left:4px;top:2px}.bubble.status-sending{opacity:.84}.bubble.status-failed{border:1px solid #ef4444}.bubble.jump-highlight{animation:jumpFlash 1.2s ease}.pending-media{font-size:12px;color:#64748b}.reply-chip{display:grid;gap:2px;font-size:11px;color:#0f172a;background:#bfdbfe5c;border-left:3px solid #0ea5e9;border-radius:8px;padding:5px 7px;width:100%;text-align:left;border-top:0;border-right:0;border-bottom:0;cursor:pointer}.reply-chip strong{color:#0369a1;font-weight:700}.reply-chip span{color:#334155}.bubble-actions{display:flex;gap:6px;margin-top:6px;opacity:.72}.tiny-btn{border:0;border-radius:999px;background:#e2e8f0bf;color:#475569;font-size:11px;padding:3px 8px}.tiny-btn.danger{background:#fee2e2;color:#b91c1c}.retry-btn{margin-top:6px;border:0;border-radius:8px;min-height:26px;padding:0 10px;background:#fee2e2;color:#b91c1c;font-size:11px}.composer{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:8px;padding:8px 10px calc(10px + env(safe-area-inset-bottom));border-top:1px solid #d2dde8;background:#edf3f8}.reply-banner{grid-column:1 / -1;font-size:12px;color:#334155;background:#f8fbff;border:1px solid #cfe0f0;border-left:3px solid #38bdf8;border-radius:10px;padding:7px 8px;display:flex;align-items:center;justify-content:space-between;gap:8px}.reply-banner div{min-width:0;display:grid;gap:2px}.reply-banner strong{font-size:12px;color:#0f172a}.reply-banner span{font-size:11px;color:#64748b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.media-error{padding:6px 12px calc(6px + env(safe-area-inset-bottom));font-size:12px;color:#b91c1c;background:#fef2f2;border-top:1px solid #fecaca}.live-circle-wrap{position:absolute;right:12px;bottom:calc(62px + env(safe-area-inset-bottom));display:grid;gap:6px;justify-items:center;z-index:12}.live-circle-preview{width:116px;height:116px;border-radius:50%;object-fit:cover;background:#0f172a;border:2px solid #38bdf8;box-shadow:0 12px 24px #02061759}.live-circle-caption{font-size:11px;color:#0f172a;background:#ffffffe6;border:1px solid #cbd5e1;border-radius:999px;padding:4px 8px}.composer input{flex:1;border:1px solid #cbd5e1;border-radius:999px;padding:11px 14px;font-size:16px;min-height:44px}.composer button{border:none;border-radius:999px;background:#0284c7;color:#fff;padding:0 16px;font-size:15px;min-height:44px;font-weight:600;display:inline-flex;align-items:center;justify-content:center;line-height:1}.voice-btn{width:46px;min-width:46px;height:44px;border-radius:999px;background:#0ea5e9;transition:background-color .16s ease,transform .12s ease;font-size:16px;padding:0}.action-icon{width:20px;height:20px;fill:currentColor;display:block}.voice-btn.recording{background:#dc2626}.voice-btn.pressed{transform:scale(.96)}.voice-btn.send-mode{background:#0284c7}.voice-btn.mic-mode{background:#0ea5e9}.voice-btn.audio-mode{box-shadow:inset 0 0 0 1px #fff3}.voice-btn.video-mode{background:#0f766e;box-shadow:inset 0 0 0 2px #ffffff47}.icon-btn{width:44px;min-width:44px;height:44px;min-height:44px;padding:0;font-size:20px;display:inline-flex;align-items:center;justify-content:center}.icon-btn.recording{background:#dc2626}.media-img{width:min(240px,100%);border-radius:10px;display:block}.media-open-btn{border:0;padding:0;background:transparent;cursor:zoom-in}.media-circle{width:204px;height:204px;border-radius:50%;object-fit:cover;display:block;background:#0f172a;border:1px solid rgba(255,255,255,.5);box-shadow:inset 0 0 0 2px #ffffff2e;position:relative;z-index:1}.circle-card{--ring-color: #38bdf8;position:relative;width:fit-content;padding:10px;border-radius:26px;background:radial-gradient(circle at 18% 8%,rgba(255,255,255,.55),transparent 36%),radial-gradient(circle at 88% 92%,rgba(255,255,255,.18),transparent 44%),linear-gradient(165deg,#7dd3fc,#2563eb 58%,#1d4ed8);box-shadow:0 16px 30px #2563eb4d}.circle-card:before{content:"";position:absolute;top:6px;right:6px;bottom:6px;left:6px;border-radius:22px;border:1px solid rgba(255,255,255,.32);pointer-events:none}.circle-card.pending{filter:saturate(.9) brightness(.98)}.circle-card.outgoing{background:radial-gradient(circle at 18% 8%,rgba(255,255,255,.45),transparent 36%),radial-gradient(circle at 88% 92%,rgba(255,255,255,.18),transparent 44%),linear-gradient(165deg,#4ade80,#22c55e 58%,#16a34a)}.circle-ring-svg{position:absolute;top:2px;right:2px;bottom:2px;left:2px;width:calc(100% - 4px);height:calc(100% - 4px);pointer-events:none;z-index:2;transform:rotate(-90deg)}.circle-ring-svg .ring-track,.circle-ring-svg .ring-progress{fill:none;stroke-linecap:round}.circle-ring-svg .ring-track{stroke:#ffffff47;stroke-width:4}.circle-ring-svg .ring-progress{stroke-width:4;transition:stroke-dashoffset .18s linear}.circle-ring-svg .ring-progress.incoming{stroke:#38bdf8}.circle-ring-svg .ring-progress.outgoing{stroke:#22c55e}.circle-badge{position:absolute;right:16px;top:16px;font-size:10px;letter-spacing:.04em;text-transform:uppercase;color:#fff;background:#0206177a;border:1px solid rgba(255,255,255,.3);border-radius:999px;padding:4px 9px;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.circle-play{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:52px;height:52px;border-radius:999px;border:1px solid rgba(255,255,255,.55);background:#0206174d;color:#fff;font-size:17px;padding:0;display:grid;place-items:center;z-index:2;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);opacity:1;transition:opacity .18s ease,transform .18s ease,background-color .18s ease,box-shadow .18s ease;box-shadow:0 6px 16px #0206174d}.circle-play.playing{width:34px;height:34px;font-size:12px;left:auto;right:20px;top:20px;transform:none}.circle-play.hide{opacity:0;pointer-events:none}.circle-play.show{opacity:1}.circle-play.idle{animation:playPulse 1.6s ease-in-out infinite}.circle-progress{position:absolute;left:18px;right:18px;bottom:18px;height:5px;border-radius:999px;background:#ffffff47;overflow:hidden;opacity:1;transition:opacity .18s ease}.circle-progress span{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,#fff,#e0f2fe)}.circle-progress.hide{opacity:0}.circle-progress.show{opacity:1}.circle-badge{opacity:1;transition:opacity .18s ease}.circle-badge.hide{opacity:0}.circle-badge.show{opacity:1}.image-viewer{position:fixed;top:0;right:0;bottom:0;left:0;background:#020617e0;z-index:100;display:grid;place-items:center;padding:16px}.image-viewer-img{max-width:100%;max-height:100%;border-radius:12px;box-shadow:0 12px 36px #00000073}.image-viewer-close{position:absolute;top:calc(10px + env(safe-area-inset-top));right:10px;width:40px;height:40px;border:0;border-radius:999px;background:#ffffff26;color:#fff;font-size:28px;line-height:1}.voice-bubble{display:grid;grid-template-columns:auto 1fr auto auto;gap:8px;align-items:center;min-width:220px}.voice-play{width:34px;height:34px;border-radius:999px;border:0;font-size:12px;color:#fff;background:#0ea5e9}.voice-bubble.outgoing .voice-play{background:#22c55e}.voice-track{position:relative;height:24px;border:0;background:transparent;padding:0}.voice-track-bg,.voice-track-fill{position:absolute;left:0;top:10px;height:3px;border-radius:999px}.voice-track-bg{width:100%;background:#64748b47}.voice-track-fill{background:#0ea5e9}.voice-bubble.outgoing .voice-track-fill{background:#22c55e}.voice-time{font-size:11px;color:#475569;min-width:68px;text-align:right}.voice-rate{border:0;background:#0284c724;color:#075985;font-size:11px;min-width:38px;min-height:26px;border-radius:999px}.voice-wave{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;grid-auto-flow:column;grid-auto-columns:1fr;gap:2px;align-items:center;padding:1px 0}.voice-bar{width:100%;border-radius:999px;background:#64748b73;transform-origin:center}.voice-bar.active{background:#0ea5e9}.voice-bubble.outgoing .voice-bar.active{background:#22c55e}.voice-wave.playing .voice-bar{animation:voicePulse 1s ease-in-out infinite}.voice-wave.playing .voice-bar:nth-child(2n){animation-delay:.12s}.voice-wave.playing .voice-bar:nth-child(3n){animation-delay:.24s}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes fadeIn{0%{opacity:0;transform:translateY(2px)}to{opacity:1;transform:translateY(0)}}@keyframes voicePulse{0%{transform:scaleY(.7)}50%{transform:scaleY(1)}to{transform:scaleY(.7)}}@keyframes jumpFlash{0%{box-shadow:0 0 #38bdf88c}50%{box-shadow:0 0 0 6px #38bdf814}to{box-shadow:0 2px 8px #0f172a1a}}@keyframes playPulse{0%{transform:translate(-50%,-50%) scale(1);box-shadow:0 6px 16px #0206174d}50%{transform:translate(-50%,-50%) scale(1.05);box-shadow:0 10px 20px #02061761}to{transform:translate(-50%,-50%) scale(1);box-shadow:0 6px 16px #0206174d}}.typing{font-size:12px;color:#475569;padding:4px 8px}@media (max-width: 820px){.app{grid-template-columns:1fr;height:100svh}.sidebar{position:absolute;top:0;left:0;bottom:0;width:min(82vw,320px);transform:translate(-102%);transition:transform .22s ease;z-index:30;border-right:1px solid #d2dde8;border-bottom:0;max-height:none}.sidebar.open{transform:translate(0)}.backdrop{display:block;position:absolute;top:0;right:0;bottom:0;left:0;background:#0f172a5c;opacity:0;pointer-events:none;transition:opacity .18s ease;z-index:20}.backdrop.show{opacity:1;pointer-events:auto}.auth-card{padding:20px 16px 14px;border-radius:16px}.chat-head{padding-left:10px;padding-right:10px}.composer{gap:6px;padding-left:8px;padding-right:8px}.voice-btn,.icon-btn{width:42px;min-width:42px;height:42px;min-height:42px}.media-circle{width:176px;height:176px}.circle-card{padding:8px;border-radius:22px}}
