:root,[data-theme=sky]{--bg-0: #eaf2ff;--bg-1: #f3f0ff;--bg-2: #e6fbff;--cyan: #22d3ee;--blue: #3b82f6;--violet: #8b5cf6;--pink: #f472b6;--ink: #0b1733;--ink-soft: #51618a;--glass: rgba(255, 255, 255, .55);--glass-strong: rgba(255, 255, 255, .78);--stroke: rgba(255, 255, 255, .7);--neon: 0 0 0 1px rgba(139, 92, 246, .18), 0 18px 50px rgba(59, 130, 246, .18);--accent-grad: linear-gradient(90deg, var(--cyan), var(--blue) 55%, var(--violet));font-family:Inter,PingFang SC,Microsoft YaHei,system-ui,sans-serif;color:var(--ink)}[data-theme=lavender]{--bg-0: #f5f0ff;--bg-1: #ede9fe;--bg-2: #faf5ff;--cyan: #c4b5fd;--blue: #8b5cf6;--violet: #a855f7;--pink: #e879f9;--accent-grad: linear-gradient(90deg, #c4b5fd, #8b5cf6 55%, #a855f7)}[data-theme=mint]{--bg-0: #ecfdf5;--bg-1: #d1fae5;--bg-2: #f0fdf4;--cyan: #6ee7b7;--blue: #10b981;--violet: #14b8a6;--pink: #34d399;--accent-grad: linear-gradient(90deg, #6ee7b7, #10b981 55%, #14b8a6)}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;min-height:100vh;background:radial-gradient(1200px 800px at 12% -8%,var(--bg-2),transparent 60%),radial-gradient(1000px 700px at 100% 0%,var(--bg-1),transparent 55%),linear-gradient(160deg,var(--bg-0) 0%,#ffffff 55%,var(--bg-1) 100%);overflow-x:hidden}.app-bg{position:relative;min-height:100vh;overflow:hidden}.orb{position:fixed;border-radius:50%;filter:blur(60px);opacity:.55;z-index:0;pointer-events:none;animation:float 18s ease-in-out infinite}.orb-1{width:460px;height:460px;left:-120px;top:-100px;background:radial-gradient(circle at 30% 30%,var(--cyan),transparent 70%)}.orb-2{width:520px;height:520px;right:-160px;top:8%;background:radial-gradient(circle at 60% 40%,var(--violet),transparent 70%);animation-delay:-6s}.orb-3{width:420px;height:420px;left:30%;bottom:-180px;background:radial-gradient(circle at 50% 50%,var(--pink),transparent 70%);animation-delay:-10s}@keyframes float{0%,to{transform:translate(0) scale(1)}33%{transform:translate(40px,30px) scale(1.08)}66%{transform:translate(-30px,20px) scale(.96)}}.grid-overlay{position:fixed;inset:0;z-index:0;pointer-events:none;background-image:linear-gradient(rgba(59,130,246,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(139,92,246,.06) 1px,transparent 1px);background-size:44px 44px;mask-image:radial-gradient(circle at 50% 30%,#000 30%,transparent 80%)}.glass-card{position:relative;z-index:1;background:var(--glass);border:1px solid var(--stroke);backdrop-filter:blur(22px) saturate(140%);-webkit-backdrop-filter:blur(22px) saturate(140%);box-shadow:var(--neon);border-radius:26px}.auth-page{display:grid;place-items:center;padding:24px;min-height:100vh;min-height:100dvh}.auth-card{width:min(420px,92vw);padding:30px 26px;display:grid;gap:16px}.brand{display:flex;align-items:center;gap:14px;margin-bottom:4px}.brand-logo{width:54px;height:54px;border-radius:18px;display:grid;place-items:center;font-weight:800;font-size:26px;color:#fff;background:linear-gradient(135deg,var(--cyan),var(--blue) 50%,var(--violet));box-shadow:0 10px 30px #3b82f680}.brand-text h1{margin:0;font-size:30px;letter-spacing:1px;background:linear-gradient(90deg,var(--blue),var(--violet));-webkit-background-clip:text;background-clip:text;color:transparent}.tagline{margin:2px 0 0;font-size:12px;letter-spacing:3px;color:var(--ink-soft)}.field{display:grid;gap:6px}.field-label{font-size:12px;color:var(--ink-soft);letter-spacing:1px}input{width:100%;border:1px solid rgba(148,163,184,.35);background:var(--glass-strong);padding:13px 15px;border-radius:14px;outline:none;color:var(--ink);font-size:15px;transition:border-color .2s,box-shadow .2s}input::placeholder{color:#9aa6c2}input:focus{border-color:var(--violet);box-shadow:0 0 0 4px #8b5cf629}.auth-actions{margin-top:4px}.auth-actions .pill{flex:1;justify-content:center}.row{display:flex;gap:10px}.pill{border:none;border-radius:999px;padding:12px 20px;color:#fff;font-weight:600;font-size:14px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:6px;background:var(--accent-grad);box-shadow:0 8px 22px #3b82f659;transition:transform .15s,box-shadow .2s,opacity .2s}.pill:hover{transform:translateY(-1px);box-shadow:0 12px 28px #3b82f680}.pill:active{transform:translateY(0)}.pill:disabled{opacity:.45;cursor:not-allowed;box-shadow:none}.pill.sm{padding:8px 14px;font-size:13px}.pill.ghost{background:#fff9;color:var(--blue);border:1px solid rgba(59,130,246,.35);box-shadow:none}.pill.ghost:hover{background:#ffffffd9;box-shadow:0 6px 18px #3b82f62e}.pill.danger{background:linear-gradient(90deg,#fb7185,#ef4444);box-shadow:0 8px 22px #ef444459}.pill.accept{background:linear-gradient(90deg,#34d399,#10b981);box-shadow:0 8px 22px #10b98159}.layout{min-height:100vh;min-height:100dvh;display:grid;grid-template-columns:340px 1fr;gap:16px;padding:16px}.sidebar{padding:0;display:flex;flex-direction:column;min-height:0;overflow:hidden}.app-topbar{display:flex;align-items:center;justify-content:space-between;padding:18px 18px 12px;border-bottom:1px solid rgba(148,163,184,.2)}.topbar-title{font-size:22px;font-weight:800;letter-spacing:1px;background:linear-gradient(90deg,var(--blue),var(--violet));-webkit-background-clip:text;background-clip:text;color:transparent}.topbar-badge{min-width:22px;height:22px;padding:0 7px;border-radius:999px;background:linear-gradient(90deg,#fb7185,#ef4444);color:#fff;font-size:12px;font-weight:700;display:inline-flex;align-items:center;justify-content:center}.sidebar .search-row,.sidebar .search-result,.sidebar .pending-block,.sidebar .section-title,.sidebar .friends{margin-left:16px;margin-right:16px}.sidebar .search-row{margin-top:14px}.sidebar .section-title{margin-top:14px;margin-bottom:6px}.sidebar .friends{flex:1;overflow:auto;margin-bottom:16px;max-height:none}.pending-block{display:grid;gap:8px}.pending-item{align-items:center}.pending-text{display:grid;gap:2px;font-size:13px}.pending-text span{color:var(--ink-soft);font-size:12px}.friend-meta{flex:1;display:grid;gap:2px;text-align:left}.friend-sub{font-size:12px;color:var(--ink-soft)}.search-row{display:grid;grid-template-columns:1fr auto;gap:8px}.section-title{font-size:12px;letter-spacing:2px;color:var(--ink-soft);text-transform:uppercase}.search-result{display:grid;gap:8px;margin-bottom:8px}.friends{display:grid;gap:6px;align-content:start}.empty-tip,.empty-chat{color:var(--ink-soft);font-size:13px;text-align:center;padding:18px 8px}.empty-chat{margin:auto}.item,.friend-item{background:var(--glass-strong);border:1px solid rgba(148,163,184,.22);border-radius:16px;padding:10px 12px;display:flex;align-items:center;gap:10px;width:100%}.item{justify-content:space-between}.item-id{display:flex;align-items:center;gap:8px}.friend-item{cursor:pointer;transition:transform .12s,box-shadow .2s,border-color .2s;text-align:left}.friend-item:hover{transform:translate(2px);box-shadow:0 8px 20px #3b82f629}.friend-item.active{border-color:#8b5cf68c;box-shadow:0 0 0 1px #8b5cf666,0 10px 24px #8b5cf638;background:linear-gradient(90deg,#22d3ee1f,#8b5cf61f)}.friend-name{flex:1;font-weight:600}.avatar{width:38px;height:38px;border-radius:12px;display:grid;place-items:center;font-weight:700;font-size:14px;color:#fff;background:linear-gradient(135deg,var(--cyan),var(--violet));flex:0 0 auto}.sm-avatar{width:30px;height:30px;border-radius:10px;font-size:12px}.dot{font-style:normal;min-width:22px;height:22px;padding:0 6px;border-radius:999px;background:linear-gradient(90deg,#fb7185,#ef4444);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;box-shadow:0 4px 10px #ef444473}.chat{display:flex;flex-direction:column;padding:0;gap:0;min-height:0;overflow:hidden}.chat-head{display:flex;align-items:center;gap:10px;padding:14px 16px;border-bottom:1px solid rgba(148,163,184,.22);flex-shrink:0}.back-btn{display:none;width:36px;height:36px;border:none;border-radius:12px;background:#ffffffb3;color:var(--blue);font-size:18px;cursor:pointer;flex-shrink:0}.chat-peer{display:flex;align-items:center;gap:10px;flex:1;min-width:0}.chat-actions{flex-shrink:0;flex-wrap:wrap;justify-content:flex-end}.peer-text h3{margin:0;font-size:17px}.peer-sub{font-size:12px;color:var(--ink-soft)}.messages{flex:1;overflow:auto;display:flex;flex-direction:column;gap:10px;padding:14px 16px;min-height:0}.bubble{width:fit-content;max-width:100%;padding:10px 14px;border-radius:18px;line-height:1.45;font-size:15px;overflow-wrap:anywhere;word-break:normal;white-space:pre-wrap;background:var(--glass-strong);border:1px solid rgba(255,255,255,.7);box-shadow:0 6px 16px #0f172a0f;animation:pop .18s ease}@keyframes pop{0%{transform:scale(.97);opacity:0}to{transform:scale(1);opacity:1}}.bubble.mine{color:#fff;background:linear-gradient(120deg,var(--cyan),var(--blue) 60%,var(--violet));border:none;border-bottom-right-radius:6px;box-shadow:0 8px 20px #3b82f666}.bubble.theirs{border-bottom-left-radius:6px}.composer{display:flex;align-items:center;gap:10px;padding:12px 14px calc(12px + env(safe-area-inset-bottom));border-top:1px solid rgba(148,163,184,.2);background:#ffffff73;flex-shrink:0}.composer input{flex:1;min-width:0}.composer .send{flex:0 0 auto;white-space:nowrap;padding:10px 18px}.call-panel{margin:10px 16px 0;flex-shrink:0;background:linear-gradient(120deg,#22d3ee1a,#8b5cf61f);border:1px solid rgba(139,92,246,.25);border-radius:18px;padding:12px}.call-status{display:flex;align-items:center;gap:10px;font-weight:600;margin-bottom:10px}.pulse{width:10px;height:10px;border-radius:50%;background:var(--violet);box-shadow:0 0 #8b5cf699;animation:pulse 1.5s infinite}@keyframes pulse{0%{box-shadow:0 0 #8b5cf699}70%{box-shadow:0 0 0 12px #8b5cf600}to{box-shadow:0 0 #8b5cf600}}.call-status .accept{margin-left:auto}.videos{display:grid;grid-template-columns:1fr 160px;gap:10px}.videos video{width:100%;height:200px;border-radius:14px;background:#0b1733;object-fit:cover;border:1px solid rgba(139,92,246,.3)}.videos video:last-child{height:120px;align-self:end}.error{color:#ef4444;font-weight:600;padding:0 16px 8px}.hint{color:var(--ink-soft);font-size:12px}.success-msg{color:#059669;font-weight:600}.list-notice{display:block;margin:8px 16px 0;font-size:13px}.tab-panel{display:none;flex-direction:column;flex:1;min-height:0;overflow:hidden}.pad{padding:0 16px}.block-gap{display:grid;gap:10px;margin-bottom:12px}.member-pick{display:flex;flex-wrap:wrap;gap:8px}.member-chip{border:1px solid rgba(148,163,184,.3);background:#ffffffbf;border-radius:999px;padding:6px 12px;font-size:13px;cursor:pointer}.member-chip.active{background:var(--accent-grad);color:#fff;border:none}.group-avatar{background:linear-gradient(135deg,var(--violet),var(--pink))}.online-dot.sm{width:10px;height:10px;border-radius:50%;background:#22c55e;flex-shrink:0}.online-label{color:#16a34a;font-weight:600}.friend-item.static{cursor:default}.settings-hero{display:flex;align-items:center;gap:14px;padding:16px;margin:8px 16px;border-radius:18px;background:var(--glass-strong);border:1px solid rgba(148,163,184,.18)}.settings-menu{padding:0 16px;display:grid;gap:8px}.menu-row{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;border-radius:14px;border:1px solid rgba(148,163,184,.2);background:#ffffffa6;cursor:pointer;font-size:15px;font-weight:600;width:100%}.menu-row i{color:var(--ink-soft);font-style:normal}.row-value{font-size:13px;font-weight:500}.settings-form{padding:0 16px 16px;display:grid;gap:12px}.about-box{place-items:center;text-align:center;padding-top:24px;gap:10px}.about-logo{width:64px;height:64px;border-radius:20px;display:grid;place-items:center;font-weight:800;font-size:32px;color:#fff;background:linear-gradient(135deg,var(--cyan),var(--blue) 50%,var(--violet));box-shadow:0 10px 30px #3b82f673}.about-name{font-size:22px;font-weight:800;background:linear-gradient(90deg,var(--blue),var(--violet));-webkit-background-clip:text;background-clip:text;color:transparent}.about-ver{color:var(--ink-soft);font-size:14px}.update-card{width:100%;display:grid;gap:8px;padding:16px;border-radius:16px;background:var(--glass-strong);border:1px solid rgba(59,130,246,.25)}.update-card strong{color:var(--blue)}.hint.center,.error.center{text-align:center;width:100%}.block-msg{display:block;padding:0 16px 8px}.theme-grid.wide{padding:0 16px 16px}.back-btn.show{display:inline-flex;align-items:center;justify-content:center}.bubble-wrap{display:flex;flex-direction:column;max-width:min(78%,560px)}.bubble-wrap.mine{align-self:flex-end;align-items:flex-end}.bubble-wrap.theirs{align-self:flex-start;align-items:flex-start}.bubble-meta{display:flex;gap:6px;justify-content:flex-end;margin-top:4px;opacity:.75}.read-tick{color:#93c5fd}.msg-image{max-width:220px;border-radius:12px;display:block}.msg-audio{width:200px;height:36px}.msg-file{color:inherit;text-decoration:none}.msg-menu{display:grid;gap:4px;margin-top:6px;background:#fffffff2;border-radius:12px;padding:6px;box-shadow:0 8px 24px #0f172a26}.msg-menu button{border:none;background:transparent;padding:8px 12px;text-align:left;border-radius:8px;cursor:pointer}.rec-on{background:#ef4444!important;color:#fff!important}@media (max-width: 900px){body{overflow:hidden}.layout{display:flex;flex-direction:column;grid-template-columns:1fr;gap:0;padding:0;height:100dvh;min-height:100dvh;max-height:100dvh}.app-main{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden}.glass-card{border-radius:0;box-shadow:none;border:none}.tab-panel,.settings-panel,.chat{width:100%;flex:1;min-height:0}.layout.mode-messages .messages-tab,.layout.mode-contacts .contacts-tab,.layout.mode-settings .settings-panel{display:flex}.layout.mode-messages .contacts-tab,.layout.mode-messages .settings-panel,.layout.mode-messages .chat,.layout.mode-contacts .messages-tab,.layout.mode-contacts .settings-panel,.layout.mode-contacts .chat,.layout.mode-settings .messages-tab,.layout.mode-settings .contacts-tab,.layout.mode-settings .chat,.layout.mode-chat .app-main .messages-tab,.layout.mode-chat .app-main .contacts-tab,.layout.mode-chat .app-main .settings-panel{display:none!important}.layout.mode-chat .chat{display:flex;flex:1}.layout.mode-chat .bottom-nav{display:none!important}.layout.mode-messages .bottom-nav,.layout.mode-contacts .bottom-nav,.layout.mode-settings .bottom-nav{display:flex!important}.friends,.settings-panel,.contacts-tab{padding-bottom:8px}}@media (min-width: 901px){.layout{grid-template-columns:340px 1fr}.app-main{display:contents}.layout.mode-messages .messages-tab,.layout.mode-contacts .contacts-tab,.layout.mode-settings .settings-panel{display:flex;grid-column:1;height:calc(100vh - 32px)}.layout.mode-messages .contacts-tab,.layout.mode-messages .settings-panel,.layout.mode-contacts .messages-tab,.layout.mode-contacts .settings-panel,.layout.mode-settings .messages-tab,.layout.mode-settings .contacts-tab{display:none}.layout.mode-chat .messages-tab{display:flex}.layout.mode-chat .contacts-tab,.layout.mode-chat .settings-panel{display:none}.layout.mode-chat .chat{display:flex;grid-column:2;height:calc(100vh - 32px)}.layout:not(.mode-chat) .chat{display:none}.bottom-nav{display:none}}.pill.capsule{position:relative;overflow:hidden}.pill.capsule:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(255,255,255,.35),transparent 55%);pointer-events:none;border-radius:inherit}.glass-bubble.theirs{backdrop-filter:blur(12px);background:#ffffffb8;border:1px solid rgba(255,255,255,.85)}.avatar-img{width:38px;height:38px;border-radius:12px;object-fit:cover;flex:0 0 auto}.avatar.emoji{font-size:20px;background:#ffffffd9}.avatar.lg,.avatar-img.lg{width:56px;height:56px;border-radius:16px;font-size:28px}.avatar.sm-avatar,.avatar-img.sm-avatar{width:30px;height:30px;border-radius:10px;font-size:12px}.settings-panel{flex-direction:column;padding:16px;gap:14px;overflow:auto;display:none;z-index:2}.settings-head{display:flex;align-items:center;gap:10px}.settings-head h2{margin:0;font-size:20px;background:linear-gradient(90deg,var(--blue),var(--violet));-webkit-background-clip:text;background-clip:text;color:transparent}.settings-profile{display:flex;align-items:center;gap:14px;padding:12px;border-radius:16px;background:var(--glass-strong);border:1px solid rgba(148,163,184,.2)}.settings-block{display:grid;gap:10px;padding:14px;border-radius:18px;background:#ffffff73;border:1px solid rgba(148,163,184,.18)}.emoji-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:8px}.emoji-btn{border:1px solid rgba(148,163,184,.25);background:#fffc;border-radius:12px;font-size:22px;padding:8px;cursor:pointer}.emoji-btn.active{border-color:var(--violet);box-shadow:0 0 0 2px #8b5cf640}.theme-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.theme-card{border:1px solid rgba(148,163,184,.25);background:#fffc;border-radius:14px;padding:10px;display:grid;gap:8px;cursor:pointer;font-size:13px;text-align:center}.theme-card.active{border-color:var(--violet);box-shadow:0 0 0 2px #8b5cf640}.theme-swatch{height:36px;border-radius:10px}.pill.full{width:100%}.logout-btn{margin-top:4px}.bottom-nav{flex-shrink:0;display:none;position:relative;z-index:100;padding:8px 12px calc(10px + env(safe-area-inset-bottom));gap:8px;background:#ffffffeb;backdrop-filter:blur(20px);border-top:1px solid rgba(148,163,184,.25)}.nav-item{flex:1;border:none;border-radius:999px;padding:10px 12px;background:#fff9;color:var(--ink-soft);font-weight:600;font-size:13px;display:flex;align-items:center;justify-content:center;gap:6px;cursor:pointer;position:relative}.nav-item.active{background:var(--accent-grad);color:#fff;box-shadow:0 6px 18px #3b82f659}.nav-dot{font-style:normal;min-width:18px;height:18px;padding:0 5px;border-radius:999px;background:#ef4444;color:#fff;font-size:11px;display:inline-flex;align-items:center;justify-content:center}.topbar-actions{display:flex;align-items:center;gap:8px}.icon-btn{border:none;width:36px;height:36px;border-radius:12px;background:#ffffffb3;cursor:pointer;font-size:18px}.videos.audio-only{grid-template-columns:1fr}.switch-cam{margin-left:auto}.chat-error{padding:0 16px}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-thumb{background:#8b5cf64d;border-radius:999px}
