:root{--bg:#121816;--bg2:#18201d;--sidebar:#222c28;--sidebar2:#1d2623;--panel:#f6f8f3;--panel2:#edf1e8;--line:#d8ddd4;--text:#1f2521;--muted:#77817a;--green:#a9c34a;--green2:#8faa33;--green-soft:#d8e3a0;--bubble-out:#d4e27b;--bubble-in:#ffffff;--danger:#cb6b6b}*{box-sizing:border-box}html,body,#root{margin:0;height:100%;font-family:Inter,system-ui,sans-serif;background:linear-gradient(180deg,#141917,#0f1312);color:var(--text)}body{overflow:hidden}button,input,select{font:inherit}button:disabled{opacity:.55;cursor:not-allowed}.auth-wrap{min-height:100%;display:grid;place-items:center;padding:24px;background:radial-gradient(circle at top,#242d2a,#161d1a 48%,#101413)}.auth-card{width:min(520px,100%);background:#131917eb;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(169,195,74,.16);border-radius:28px;padding:32px;color:#eef2eb;box-shadow:0 24px 60px #00000047}.pill{display:inline-flex;align-items:center;padding:10px 16px;border-radius:999px;background:#a9c34a24;color:#d8e59f;font-weight:700;margin-bottom:12px;border:1px solid rgba(169,195,74,.2)}.muted{color:var(--muted)}.center{text-align:center}.auth-card h1{font-size:56px;line-height:1;margin:16px 0}.auth-form{display:flex;flex-direction:column;gap:14px;margin-top:18px}.auth-form input,.composer-input,.searchbox input{width:100%;padding:16px 18px;border-radius:18px;border:1px solid rgba(169,195,74,.12);background:#121816;color:#eef2eb;outline:none}.auth-form input::placeholder,.composer-input::placeholder,.searchbox input::placeholder{color:#8a968f}.auth-form button,.send-btn,.small{border:none;cursor:pointer}.auth-form button,.send-btn{padding:16px 20px;border-radius:18px;background:linear-gradient(180deg,var(--green) 0%,var(--green2) 100%);color:#1a2014;font-weight:800}.switcher{margin-top:16px;color:#d6ddd0;cursor:pointer;text-align:center}.error,.ok{padding:12px 14px;border-radius:14px;margin-top:12px}.error{background:#432523;color:#ffd5d5}.ok{background:#253725;color:#cdf5d2}.inline-error{margin:0 0 10px}.layout{display:flex;height:100dvh;min-height:100dvh;background:#131816;overflow:hidden}.sidebar{width:360px;max-width:100%;background:linear-gradient(180deg,var(--sidebar) 0%,var(--sidebar2) 100%);border-right:1px solid rgba(255,255,255,.06);padding:18px;display:flex;flex-direction:column;gap:14px;color:#eef2eb;overflow:auto}.brand-row{display:flex;align-items:center;gap:12px;margin-bottom:2px}.brand-lock{width:42px;height:42px;border-radius:12px;background:linear-gradient(180deg,#bfd86a,#96b238);display:grid;place-items:center;border:1px solid rgba(255,255,255,.18);box-shadow:inset 0 1px #ffffff47}.brand-knot{color:#1e2519;font-size:18px;font-weight:900;line-height:1}.brand{font-size:24px;font-weight:900;color:#eef2eb;letter-spacing:.2px}.mebox,.notif-row,.search-results .user-item,.chat-item,.attach-bar{background:#ffffff09;border:1px solid rgba(255,255,255,.06);border-radius:18px;padding:14px}.mebox,.notif-row,.searchbox,.attach-bar{display:flex;align-items:center;justify-content:space-between;gap:10px}.user-meta{display:flex;align-items:center;gap:12px;min-width:0}.user-meta.stretch{align-items:flex-start;width:100%}.avatar{width:44px;height:44px;border-radius:12px;background:linear-gradient(180deg,#b7cf5b,#8faa33);display:grid;place-items:center;color:#172011;font-weight:900;box-shadow:inset 0 1px #ffffff52}.avatar.header,.avatar.me{width:48px;height:48px}.chat-copy{min-width:0;flex:1}.small{padding:10px 14px;border-radius:14px;background:#a9c34a29;color:#eef2eb}.danger{background:#cb6b6b2e;color:#ffdede}.searchbox{display:flex;gap:8px}.search-results,.chat-list{display:flex;flex-direction:column;gap:10px;overflow:auto}.chat-list{min-height:0;flex:1}.chat-item{cursor:pointer;transition:.15s ease}.chat-item:hover{background:#ffffff0d}.chat-item.active{background:#a9c34a1a;border-color:#a9c34a57}.chat-top{display:flex;justify-content:space-between;align-items:center;gap:8px}.badge{min-width:24px;height:24px;padding:0 8px;border-radius:999px;background:var(--green);color:#172011;display:grid;place-items:center;font-weight:800;font-size:13px}.status{font-size:13px}.green{color:#d8f08a}.gray{color:#a8b1ab}.preview,.chat-sub{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:13px;color:#b6c0b9;margin-top:4px}.main{flex:1;display:flex;flex-direction:column;min-width:0;background:linear-gradient(180deg,var(--panel) 0%,var(--panel2) 100%);height:100dvh;min-height:0}.chat-header{padding:18px 22px;border-bottom:1px solid var(--line);background:#ffffffb8;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:space-between;gap:16px;box-shadow:0 1px #ffffff73}.chat-header h2{margin:0 0 4px;color:var(--text);font-size:26px}.mobile-nav-btn{width:42px;height:42px;border-radius:14px;border:1px solid rgba(143,170,51,.28);background:#fff;color:#324126;display:grid;place-items:center;cursor:pointer;font-size:22px;font-weight:800;flex-shrink:0}.messages{flex:1;overflow:auto;padding:22px 24px;display:flex;flex-direction:column;gap:14px;background-color:#e5e9df;background-image:radial-gradient(circle at 25px 25px,rgba(169,195,74,.1) 2px,transparent 2px),radial-gradient(circle at 75px 75px,rgba(169,195,74,.08) 1.5px,transparent 1.5px),linear-gradient(180deg,#ffffff8c,#dfe5da40);background-size:100px 100px,120px 120px,100% 100%;background-position:0 0,20px 10px,0 0;min-height:0}.msg-row{display:flex}.msg-row.mine{justify-content:flex-end}.bubble{max-width:min(72%,760px);padding:12px 14px 10px;border-radius:12px 18px 18px;background:var(--bubble-in);border:1px solid rgba(0,0,0,.06);box-shadow:0 2px 8px #0000000a;position:relative}.bubble.mine{background:var(--bubble-out);border-radius:18px 12px 18px 18px}.msg-text{white-space:pre-wrap;word-break:break-word;font-size:16px;line-height:1.38;color:var(--text)}.msg-text.caption{font-size:14px;margin-top:10px;color:#3d473f}.meta{margin-top:7px;font-size:12px;color:#6d766f;text-align:right}.composer-wrap{padding:14px 18px;border-top:1px solid var(--line);background:#f8faf6f5;padding-bottom:max(14px,env(safe-area-inset-bottom))}.composer{display:grid;grid-template-columns:auto auto minmax(0,1fr) auto;gap:12px;align-items:center}.icon-btn{width:50px;height:50px;border-radius:14px;border:1px solid var(--line);background:#fff;color:#47514a;cursor:pointer;display:grid;place-items:center}.icon-btn.bomb{background:linear-gradient(180deg,#2d3529,#1d2419);color:#ecf6bf;border-color:#9bb63c}.glyph{font-size:22px;line-height:1;font-weight:700}.composer-input{min-width:0}.file-link{color:#45631a}.button-link{background:none;border:none;padding:0;cursor:pointer;text-align:left}.media-thumb{max-width:100%;max-height:360px;border-radius:16px;display:block;margin-top:8px;cursor:pointer;-webkit-user-select:none;user-select:none}.progress{height:10px;border-radius:999px;background:#d6dccf;overflow:hidden;margin-bottom:10px}.progress-bar{height:100%;background:linear-gradient(90deg,#b4cb58,#8faa33)}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0d0f0ead;display:grid;place-items:center;padding:28px}.overlay-card{max-width:min(1100px,100%);max-height:100%;background:#f7f8f5;border:1px solid var(--line);border-radius:24px;padding:16px;box-shadow:0 20px 60px #00000038}.overlay-media{max-width:100%;max-height:80vh;border-radius:16px;display:block}.overlay-caption{margin-top:14px;padding:14px 16px;border-radius:18px;background:#eef1e9;border:1px solid var(--line);color:#29312c;white-space:pre-wrap}.empty{display:grid;place-items:center;height:100%;font-size:28px;color:#68716a;padding:24px}.empty-card{display:flex;flex-direction:column;gap:16px;align-items:center;text-align:center}.empty-mobile-btn{padding-inline:18px}.view-once-card{position:relative;width:min(360px,70vw);height:210px;border:1px solid rgba(0,0,0,.06);border-radius:22px;background:linear-gradient(135deg,#dce7ab,#c2d57b 40%,#a7c044);overflow:hidden;cursor:pointer;color:#1f2521;padding:0}.view-once-blur{position:absolute;top:-12px;right:-12px;bottom:-12px;left:-12px;background:radial-gradient(circle at 20% 20%,rgba(255,255,255,.55),transparent 35%),radial-gradient(circle at 70% 50%,rgba(171,195,74,.42),transparent 25%),linear-gradient(135deg,#cadb88,#a7c044 45%,#8faa33);filter:blur(18px) saturate(1.15);transform:scale(1.2)}.view-once-inner{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;padding:18px;text-align:center;background:linear-gradient(180deg,#ffffff24,#ffffff47)}.view-once-icon{font-size:30px;margin-bottom:10px}.view-once-title{font-size:18px;font-weight:800}.view-once-sub{margin-top:6px;font-size:14px;color:#43503e}.attach-bar strong{display:block;max-width:500px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-thumb{background:#c3cac0;border-radius:999px}::-webkit-scrollbar-track{background:transparent}.msg-row.other .bubble:before{content:"";position:absolute;left:-6px;bottom:10px;width:12px;height:12px;background:var(--bubble-in);border-left:1px solid rgba(0,0,0,.06);border-bottom:1px solid rgba(0,0,0,.06);transform:rotate(45deg);border-bottom-left-radius:3px}.msg-row.mine .bubble:after{content:"";position:absolute;right:-6px;bottom:10px;width:12px;height:12px;background:var(--bubble-out);border-right:1px solid rgba(0,0,0,.05);border-bottom:1px solid rgba(0,0,0,.05);transform:rotate(45deg);border-bottom-right-radius:3px}.bubble.editing{outline:2px solid rgba(143,170,51,.45)}.bubble-actions{position:absolute;top:8px;right:10px;display:flex;gap:6px;opacity:0;transform:translateY(-4px);transition:.15s ease}.msg-row.mine:hover .bubble-actions,.bubble.editing .bubble-actions{opacity:1;transform:translateY(0)}.tiny-action{width:28px;height:28px;border-radius:999px;border:1px solid rgba(0,0,0,.08);background:#ffffffd1;color:#33412a;cursor:pointer;display:grid;place-items:center;font-size:13px}.tiny-action.danger{color:#8e3e3e}.editing-bar{border-color:#8faa3352;background:#a9c34a1a}.header-actions{margin-left:auto;display:flex;align-items:center;justify-content:flex-end;gap:10px;flex-shrink:0}.call-btn{width:50px;height:50px;border-radius:16px;border:1px solid rgba(143,170,51,.42);background:linear-gradient(180deg,#eef6c8,#b8cf5e);color:#213018;cursor:pointer;font-size:22px;box-shadow:inset 0 1px #ffffff8c,0 6px 18px #78922b2e}.call-btn:disabled{opacity:.45;cursor:not-allowed}.call-hint{margin:0 0 10px;padding:11px 13px;border-radius:14px;background:#a9c34a1f;color:#44513b;border:1px solid rgba(143,170,51,.2)}.call-overlay{position:fixed;right:22px;bottom:22px;z-index:50}.call-card{width:min(360px,calc(100vw - 28px));background:#161d1af5;color:#edf3ea;border:1px solid rgba(169,195,74,.18);border-radius:26px;padding:22px;box-shadow:0 24px 60px #0000004d;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.call-avatar{width:68px;height:68px;border-radius:18px;display:grid;place-items:center;background:linear-gradient(180deg,#bfd86a,#96b238);color:#182213;font-size:26px;font-weight:900;margin-bottom:14px}.call-title{font-size:24px;font-weight:800}.call-subtitle{margin-top:6px;color:#c2cec6}.call-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px}.call-action{flex:1;border:none;border-radius:16px;padding:14px 16px;font-weight:800;cursor:pointer}.call-action.accept{background:linear-gradient(180deg,#bfd86a,#96b238);color:#172011}.call-action.decline{background:linear-gradient(180deg,#5a2a2a,#3a1d1d);color:#ffdede}.call-action.mute{background:#ffffff14;color:#edf3ea;border:1px solid rgba(255,255,255,.08)}.call-action.mute.on{background:#a9c34a24;color:#eef7bf;border:1px solid rgba(169,195,74,.25)}.call-note{margin-top:12px;color:#93a097;font-size:13px}.calls-box{background:#ffffff09;border:1px solid rgba(255,255,255,.06);border-radius:18px;padding:14px;display:flex;flex-direction:column;gap:10px}.calls-box-head{display:flex;align-items:center;justify-content:space-between;gap:8px;color:#eef2eb}.danger-badge{background:#d08b8b;color:#2b1414}.call-history-list{display:flex;flex-direction:column;gap:8px;max-height:180px;overflow:auto}.call-history-item{padding:10px 12px;border-radius:14px;background:#ffffff0a;border:1px solid rgba(255,255,255,.05)}.call-history-item.missed{background:#cb6b6b24;border-color:#cb6b6b2e}.call-history-main{display:flex;align-items:center;gap:8px;color:#eef2eb;font-weight:700}.call-dir{display:inline-grid;place-items:center;width:22px;height:22px;border-radius:999px;background:#a9c34a26;color:#dff09a;font-size:13px}.call-peer{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.call-history-meta{margin-top:4px;font-size:12px;color:#b6c0b9}.call-device-row{display:flex;flex-direction:column;gap:8px;margin-top:14px}.call-device-row label{font-size:13px;color:#cbd6cf}.call-device-row select{width:100%;padding:12px 14px;border-radius:14px;border:1px solid rgba(255,255,255,.08);background:#ffffff0f;color:#edf3ea;outline:none}.call-device-row option{color:#111}.mic-meter-wrap{display:flex;align-items:center;gap:10px;margin-top:12px;color:#cbd6cf;font-size:13px}.mic-meter{flex:1;height:10px;border-radius:999px;background:#ffffff14;overflow:hidden;border:1px solid rgba(255,255,255,.06)}.mic-meter-bar{height:100%;background:linear-gradient(90deg,#c8dc74,#8faa33);transition:width .08s linear}@media (max-width: 900px){html,body,#root{height:100dvh}.auth-wrap{padding:12px}.auth-card{padding:22px 18px;border-radius:22px;min-height:auto}.auth-card h1{font-size:34px}.layout{display:block;position:relative;height:100dvh;min-height:100dvh}.sidebar,.main{width:100%;height:100dvh;min-height:100dvh}.sidebar{padding:14px 12px 18px;border-right:none}.brand-row{position:sticky;top:0;z-index:5;padding-bottom:6px;background:linear-gradient(180deg,var(--sidebar) 80%,rgba(34,44,40,0))}.mebox,.notif-row,.calls-box,.searchbox,.search-results .user-item,.chat-item,.attach-bar{border-radius:16px}.main{background:linear-gradient(180deg,var(--panel) 0%,var(--panel2) 100%)}.chat-header{padding:12px 14px;gap:10px;position:sticky;top:0;z-index:5}.chat-header h2{font-size:20px;margin-bottom:2px}.avatar.header,.avatar.me,.avatar{width:40px;height:40px;border-radius:12px}.header-actions{gap:8px}.call-btn,.mobile-nav-btn{width:42px;height:42px;border-radius:14px;font-size:20px}.messages{padding:12px 10px 10px;gap:10px}.bubble{max-width:84%;padding:10px 12px 9px;border-radius:14px 16px 16px}.bubble.mine{border-radius:16px 14px 16px 16px}.msg-row.other .bubble:before,.msg-row.mine .bubble:after{display:none}.msg-text{font-size:15px;line-height:1.34}.msg-text.caption{font-size:13px;margin-top:8px}.meta{font-size:11px}.media-thumb{max-height:260px;border-radius:14px}.composer-wrap{padding:10px 10px calc(10px + env(safe-area-inset-bottom));position:sticky;bottom:0}.composer{grid-template-columns:auto auto minmax(0,1fr) auto;gap:8px}.icon-btn{width:44px;height:44px;border-radius:14px}.glyph{font-size:20px}.composer-input{padding:13px 14px;border-radius:16px;min-width:0}.send-btn{padding:13px 14px;border-radius:16px;min-width:94px}.attach-bar{padding:12px}.attach-bar strong{max-width:100%}.call-overlay{left:12px;right:12px;bottom:12px}.call-card{width:auto;padding:18px;border-radius:22px}.call-avatar{width:58px;height:58px;border-radius:16px;font-size:22px}.call-title{font-size:21px}.empty{padding:20px;font-size:22px}.view-once-card{width:100%;height:170px}}
