:root{--fib-1: .25rem;--fib-2: .5rem;--fib-3: .75rem;--fib-5: 1rem;--fib-8: 1.5rem;--fib-13: 2rem;--fib-21: 3rem;--fib-34: 4rem;--fib-55: 5rem;--fib-89: 8rem;--fib-144: 13rem;--fib-233: 21rem;--fib-377: 34rem;--fs-caption: .7rem;--fs-sm: .85rem;--fs-body: 1rem;--fs-h3: 1.25rem;--fs-h2: 1.5rem;--fs-h1: 2rem;--lh-tight: 1.2;--lh-normal: 1.5;--fw-regular: 400;--fw-medium: 500;--fw-semibold: 600;--fw-bold: 700;--c-bg: #eae6df;--c-bg-chat: #efeae2;--c-panel: #ffffff;--c-panel-2: #f7f8fa;--c-rail: #1f2c33;--c-rail-2: #111b21;--c-rail-hover: #2a3942;--c-rail-active: #2f3b43;--c-primary: #2a9d8f;--c-primary-dark: #21867a;--c-primary-soft: #e7f5f2;--c-accent: #128c7e;--c-unread: #25d366;--c-text: #111b21;--c-text-soft: #667781;--c-text-mute: #8696a0;--c-text-invert: #e9edef;--c-danger: #e63946;--c-danger-soft: #fdecee;--c-warning: #f4a261;--c-success: #25d366;--c-info: #3a86ff;--c-border: #e4e6e9;--c-border-soft: #f0f1f3;--c-divider: #f2f3f5;--c-out: #d9fdd3;--c-out-2: #d1f4cc;--c-in: #ffffff;--r-xs: var(--fib-1);--r-sm: var(--fib-2);--r-md: var(--fib-3);--r-lg: var(--fib-5);--r-xl: var(--fib-8);--r-pill: var(--fib-89);--r-circle: 50%;--shadow-1: 0 1px 2px rgba(11, 27, 33, .08);--shadow-2: 0 2px 8px rgba(11, 27, 33, .1);--shadow-3: 0 6px 20px rgba(11, 27, 33, .14);--shadow-4: 0 12px 40px rgba(11, 27, 33, .22);--shadow-inset: inset 0 1px 0 rgba(255, 255, 255, .25);--ring: 0 0 0 var(--fib-1) rgba(42, 157, 143, .45);--t-fast: .12s;--t-base: .2s;--t-slow: .32s;--ease: cubic-bezier(.4, 0, .2, 1);--ease-out: cubic-bezier(.16, 1, .3, 1);--ease-spring: cubic-bezier(.34, 1.56, .64, 1);--z-base: 1;--z-sticky: 10;--z-rail: 20;--z-modal-bg: 50;--z-modal: 51;--z-toast: 60;--z-tooltip: 70;--w-rail: var(--fib-89);--w-chatlist: var(--fib-233)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}html{-webkit-text-size-adjust:100%;text-size-adjust:100%}body{font-family:Segoe UI,system-ui,-apple-system,BlinkMacSystemFont,Roboto,Helvetica,Arial,sans-serif;font-size:var(--fs-body);line-height:var(--lh-normal);color:var(--c-text);background:var(--c-bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;overflow:hidden}h1,h2,h3,h4{line-height:var(--lh-tight);font-weight:var(--fw-semibold)}button{font-family:inherit;font-size:inherit;color:inherit;cursor:pointer;border:none;background:none}input,textarea,select{font-family:inherit;font-size:var(--fs-body);color:var(--c-text)}a{color:var(--c-accent);text-decoration:none}a:hover{text-decoration:underline}img{max-width:100%;display:block}:focus{outline:none}:focus-visible{outline:none;box-shadow:var(--ring);border-radius:var(--r-sm)}::selection{background:#2a9d8f40}*{scrollbar-width:thin;scrollbar-color:rgba(102,119,129,.4) transparent}*::-webkit-scrollbar{width:var(--fib-2);height:var(--fib-2)}*::-webkit-scrollbar-track{background:transparent}*::-webkit-scrollbar-thumb{background:#66778159;border-radius:var(--r-pill)}*::-webkit-scrollbar-thumb:hover{background:#66778199}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes fade-in-up{0%{opacity:0;transform:translateY(var(--fib-3))}to{opacity:1;transform:translateY(0)}}@keyframes fade-in-down{0%{opacity:0;transform:translateY(calc(var(--fib-3) * -1))}to{opacity:1;transform:translateY(0)}}@keyframes slide-in-right{0%{opacity:0;transform:translate(var(--fib-8))}to{opacity:1;transform:translate(0)}}@keyframes slide-in-left{0%{opacity:0;transform:translate(calc(var(--fib-8) * -1))}to{opacity:1;transform:translate(0)}}@keyframes pop-in{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes bubble-in{0%{opacity:0;transform:translateY(var(--fib-2)) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes pulse-unread{0%{box-shadow:0 0 #25d36680}70%{box-shadow:0 0 0 var(--fib-2) #25d36600}to{box-shadow:0 0 #25d36600}}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.4}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes typing-bounce{0%,60%,to{transform:translateY(0);opacity:.4}30%{transform:translateY(calc(var(--fib-1) * -1));opacity:1}}@keyframes gradient-shift{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}@keyframes toast-in{0%{opacity:0;transform:translateY(var(--fib-8)) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes modal-in{0%{opacity:0;transform:translateY(var(--fib-5)) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes backdrop-in{0%{opacity:0}to{opacity:1}}.login-wrap{display:flex;align-items:center;justify-content:center;height:100%;padding:var(--fib-5);background:linear-gradient(135deg,#264653,#2a9d8f 60%,#21867a);background-size:200% 200%;animation:gradient-shift 18s var(--ease) infinite}.login-card{position:relative;width:100%;max-width:var(--fib-233);display:flex;flex-direction:column;gap:var(--fib-5);padding:var(--fib-13);background:var(--c-panel);border-radius:var(--r-xl);box-shadow:var(--shadow-4);animation:fade-in-up var(--t-slow) var(--ease-out) both}.login-card:before{content:"";position:absolute;inset:0 0 auto 0;height:var(--fib-1);border-radius:var(--r-xl) var(--r-xl) 0 0;background:linear-gradient(90deg,var(--c-primary),var(--c-unread))}.login-card h1{font-size:var(--fs-h2);color:var(--c-rail);text-align:center;display:flex;align-items:center;justify-content:center;gap:var(--fib-2)}.login-card p.sub{margin-top:calc(var(--fib-3) * -1);font-size:var(--fs-sm);color:var(--c-text-soft);text-align:center}.field{display:flex;flex-direction:column;gap:var(--fib-2)}.field label{font-size:var(--fs-sm);font-weight:var(--fw-medium);color:var(--c-text-soft)}.field input{height:var(--fib-21);padding:0 var(--fib-3);background:var(--c-panel-2);border:var(--fib-1) solid var(--c-border);border-radius:var(--r-md);transition:border-color var(--t-base) var(--ease),box-shadow var(--t-base) var(--ease),background var(--t-base) var(--ease)}.field input::placeholder{color:var(--c-text-mute)}.field input:hover{border-color:var(--c-text-mute)}.field input:focus{background:var(--c-panel);border-color:var(--c-primary);box-shadow:var(--ring)}.btn{position:relative;display:inline-flex;align-items:center;justify-content:center;gap:var(--fib-2);height:var(--fib-21);padding:0 var(--fib-5);font-size:var(--fs-body);font-weight:var(--fw-semibold);color:#fff;background:var(--c-primary);border-radius:var(--r-md);box-shadow:var(--shadow-1);transition:background var(--t-base) var(--ease),transform var(--t-fast) var(--ease),box-shadow var(--t-base) var(--ease),opacity var(--t-base) var(--ease);-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.btn:hover{background:var(--c-primary-dark);box-shadow:var(--shadow-2)}.btn:active{transform:translateY(1px) scale(.99)}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn.ghost{color:var(--c-primary);background:transparent;border:var(--fib-1) solid var(--c-primary);box-shadow:none}.btn.ghost:hover{background:var(--c-primary-soft)}.btn.danger{background:var(--c-danger)}.btn.danger:hover{background:#c92f3c}.btn.block{width:100%}.btn.sm{height:var(--fib-13);padding:0 var(--fib-3);font-size:var(--fs-sm)}.btn.loading{color:transparent;pointer-events:none}.btn.loading:after{content:"";position:absolute;width:var(--fib-5);height:var(--fib-5);border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:var(--r-circle);animation:spin .7s linear infinite}.err{color:var(--c-danger);background:var(--c-danger-soft);font-size:var(--fs-sm);text-align:center;padding:var(--fib-2) var(--fib-3);border-radius:var(--r-sm);animation:fade-in-down var(--t-base) var(--ease-out) both}.app{display:grid;grid-template-columns:var(--w-rail) var(--w-chatlist) 1fr;height:100%;animation:fade-in var(--t-base) var(--ease) both}.rail{position:relative;z-index:var(--z-rail);display:flex;flex-direction:column;gap:var(--fib-1);padding:var(--fib-3) 0;background:linear-gradient(180deg,var(--c-rail) 0%,var(--c-rail-2) 100%);color:var(--c-text-invert);min-height:0;overflow-y:auto;overflow-x:hidden}.rail-title{padding:var(--fib-2) var(--fib-3);font-size:var(--fs-caption);font-weight:var(--fw-semibold);text-transform:uppercase;letter-spacing:.08em;color:var(--c-text-mute)}.doc-tab{position:relative;display:flex;align-items:center;gap:var(--fib-2);width:100%;padding:var(--fib-3);text-align:left;color:var(--c-text-invert);border-left:var(--fib-1) solid transparent;transition:background var(--t-fast) var(--ease),border-color var(--t-fast) var(--ease)}.doc-tab:hover{background:var(--c-rail-hover)}.doc-tab.active{background:var(--c-rail-active);border-left-color:var(--c-primary)}.doc-tab.active:after{content:"";position:absolute;right:var(--fib-2);top:50%;transform:translateY(-50%);width:var(--fib-1);height:60%;border-radius:var(--r-pill);background:var(--c-primary);opacity:.6}.doc-dot{flex:0 0 auto;width:var(--fib-3);height:var(--fib-3);border-radius:var(--r-circle);box-shadow:0 0 0 var(--fib-1) #ffffff1f;position:relative}.doc-info{display:flex;flex-direction:column;min-width:0;flex:1}.doc-name{font-size:var(--fs-sm);font-weight:var(--fw-semibold);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.doc-state{display:flex;align-items:center;gap:var(--fib-1);font-size:var(--fs-caption);color:var(--c-text-mute)}.doc-state:before{content:"";width:var(--fib-2);height:var(--fib-2);border-radius:var(--r-circle);background:currentColor;flex:0 0 auto}.doc-state.open{color:var(--c-unread)}.doc-state.open:before{animation:pulse-dot 2s var(--ease) infinite}.doc-state.close{color:var(--c-warning)}.badge{display:inline-flex;align-items:center;justify-content:center;min-width:var(--fib-5);height:var(--fib-5);padding:0 var(--fib-1);font-size:var(--fs-caption);font-weight:var(--fw-bold);color:#04160c;background:var(--c-unread);border-radius:var(--r-pill);animation:pulse-unread 2.4s var(--ease) 2}.rail-add{margin:var(--fib-3)}.rail-add.logout{margin-top:auto}.chatlist{display:flex;flex-direction:column;min-width:0;min-height:0;background:var(--c-panel);border-right:var(--fib-1) solid var(--c-border)}.chatlist-head{position:sticky;top:0;z-index:var(--z-sticky);display:flex;flex-direction:column;gap:var(--fib-2);padding:var(--fib-3);background:var(--c-panel);border-bottom:var(--fib-1) solid var(--c-border)}.chatlist-title{display:flex;align-items:center;justify-content:space-between;gap:var(--fib-2)}.chatlist-head h2{display:flex;align-items:center;gap:var(--fib-2);font-size:var(--fs-h3);color:var(--c-text);min-width:0}.chatlist-head h2{overflow:hidden}.chatlist-head h2>:last-child{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.disc-btn{flex:0 0 auto;display:inline-flex;align-items:center;gap:var(--fib-1);padding:var(--fib-1) var(--fib-2);font-size:var(--fs-caption);font-weight:var(--fw-semibold);color:var(--c-danger);background:var(--c-danger-soft);border:var(--fib-1) solid transparent;border-radius:var(--r-pill);transition:background var(--t-fast) var(--ease),opacity var(--t-fast) var(--ease)}.disc-btn:hover{background:#fbd9dd}.disc-btn:disabled{color:var(--c-text-mute);background:var(--c-panel-2);cursor:default;opacity:.7}.load-more{width:100%;padding:var(--fib-3);font-size:var(--fs-sm);font-weight:var(--fw-medium);color:var(--c-primary-dark);background:var(--c-panel-2);border-top:var(--fib-1) solid var(--c-divider);transition:background var(--t-fast) var(--ease)}.load-more:hover{background:var(--c-primary-soft)}.media-loading{display:inline-flex;align-items:center;gap:var(--fib-1);padding:var(--fib-2) var(--fib-3);font-size:var(--fs-sm);color:var(--c-text-soft);background:#0000000a;border-radius:var(--r-sm);align-self:flex-start}.search{height:var(--fib-13);padding:0 var(--fib-3);background:var(--c-panel-2);border:var(--fib-1) solid transparent;border-radius:var(--r-pill);transition:border-color var(--t-base) var(--ease),box-shadow var(--t-base) var(--ease),background var(--t-base) var(--ease)}.search::placeholder{color:var(--c-text-mute)}.search:focus{background:var(--c-panel);border-color:var(--c-primary);box-shadow:var(--ring)}.chats{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden}.chat-item{display:flex;align-items:center;gap:var(--fib-3);width:100%;padding:var(--fib-3);text-align:left;border-bottom:var(--fib-1) solid var(--c-divider);transition:background var(--t-fast) var(--ease);animation:fade-in var(--t-base) var(--ease) both}.chat-item:hover{background:var(--c-panel-2)}.chat-item.active{background:var(--c-primary-soft)}.chat-item.active .chat-name{color:var(--c-primary-dark)}.avatar{flex:0 0 auto;display:flex;align-items:center;justify-content:center;width:var(--fib-13);height:var(--fib-13);border-radius:var(--r-circle);background:linear-gradient(135deg,#b0bec5,#90a4ae);color:#fff;font-weight:var(--fw-bold);font-size:var(--fs-sm);object-fit:cover;overflow:hidden;-webkit-user-select:none;user-select:none}.chat-meta{display:flex;flex-direction:column;gap:var(--fib-1);min-width:0;flex:1}.chat-top{display:flex;justify-content:space-between;align-items:baseline;gap:var(--fib-2)}.chat-name{font-weight:var(--fw-semibold);color:var(--c-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-time{flex:0 0 auto;font-size:var(--fs-caption);color:var(--c-text-soft)}.chat-last{display:flex;justify-content:space-between;align-items:center;gap:var(--fib-2)}.chat-preview{font-size:var(--fs-sm);color:var(--c-text-soft);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.skeleton{background:linear-gradient(90deg,#eceff1 25%,#f5f6f7 37%,#eceff1 63%);background-size:200% 100%;animation:shimmer 1.4s linear infinite;border-radius:var(--r-sm)}.chat-skeleton{display:flex;gap:var(--fib-3);padding:var(--fib-3);align-items:center}.chat-skeleton .sk-avatar{width:var(--fib-13);height:var(--fib-13);border-radius:var(--r-circle)}.chat-skeleton .sk-lines{flex:1;display:flex;flex-direction:column;gap:var(--fib-2)}.chat-skeleton .sk-line{height:var(--fib-2)}.chat-skeleton .sk-line.short{width:40%}.thread{display:flex;flex-direction:column;min-width:0;min-height:0;overflow:hidden;background-color:var(--c-bg-chat);background-image:radial-gradient(rgba(0,0,0,.02) 1px,transparent 1px);background-size:var(--fib-8) var(--fib-8)}.thread-head{display:flex;align-items:center;gap:var(--fib-3);padding:var(--fib-3);background:var(--c-panel);border-bottom:var(--fib-1) solid var(--c-border);box-shadow:var(--shadow-1);z-index:var(--z-sticky)}.thread-head .chat-name{font-size:var(--fs-h3)}.thread-head .sub{font-size:var(--fs-caption);color:var(--c-text-soft)}.messages{flex:1;min-height:0;display:flex;flex-direction:column;gap:var(--fib-2);padding:var(--fib-5) var(--fib-8);overflow-y:auto;overflow-x:hidden}.bubble{position:relative;max-width:65%;padding:var(--fib-2) var(--fib-3);font-size:var(--fs-sm);line-height:var(--lh-normal);border-radius:var(--r-md);box-shadow:var(--shadow-1);word-wrap:break-word;overflow-wrap:anywhere;white-space:pre-wrap;animation:bubble-in var(--t-base) var(--ease-out) both}.bubble.in{align-self:flex-start;background:var(--c-in);border-top-left-radius:var(--r-xs)}.bubble.out{align-self:flex-end;background:var(--c-out);border-top-right-radius:var(--r-xs)}.bubble.in:before,.bubble.out:before{content:"";position:absolute;top:0;width:0;height:0;border:var(--fib-2) solid transparent}.bubble.in:before{left:calc(var(--fib-2) * -1 + 1px);border-top-color:var(--c-in);border-right-color:var(--c-in)}.bubble.out:before{right:calc(var(--fib-2) * -1 + 1px);border-top-color:var(--c-out);border-left-color:var(--c-out)}.bubble .sender{display:block;margin-bottom:var(--fib-1);font-size:var(--fs-caption);font-weight:var(--fw-bold);line-height:1.1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.bubble .time{display:block;margin-top:var(--fib-1);font-size:var(--fs-caption);color:var(--c-text-soft);text-align:right}.bubble.out .time{color:#4a7c59}.bubble img.media{display:block;max-width:100%;margin-bottom:var(--fib-1);border-radius:var(--r-sm)}.bubble audio{width:100%;margin-top:var(--fib-1)}.bubble a{color:var(--c-accent);text-decoration:underline;word-break:break-all}.bubble.has-media{max-width:min(var(--fib-233),80%)}.media-msg{display:flex;flex-direction:column;gap:var(--fib-2)}.media-msg.audio audio{width:var(--fib-233);max-width:100%;height:var(--fib-13)}.media-btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--fib-1);padding:var(--fib-2) var(--fib-3);font-size:var(--fs-sm);font-weight:var(--fw-medium);color:var(--c-primary-dark);background:#2a9d8f1a;border:var(--fib-1) solid rgba(42,157,143,.3);border-radius:var(--r-md);transition:background var(--t-fast) var(--ease);align-self:flex-start;max-width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.media-btn:hover{background:#2a9d8f2e}.media-btn:disabled{opacity:.6;cursor:progress}.media-btn.ghost{color:var(--c-text-soft);background:transparent;border-color:var(--c-border)}.media-btn.ghost:hover{background:var(--c-panel-2);color:var(--c-text)}.media-img{display:block;max-width:var(--fib-233);width:100%;max-height:var(--fib-233);object-fit:cover;border-radius:var(--r-sm);cursor:zoom-in;background:#0000000a}.media-img.sticker{max-width:var(--fib-89);background:transparent;object-fit:contain}video.media-img{cursor:default;object-fit:contain;max-height:var(--fib-377)}.transcript{padding:var(--fib-2) var(--fib-3);font-size:var(--fs-sm);font-style:italic;color:var(--c-text);background:#0000000a;border-left:var(--fib-1) solid var(--c-primary);border-radius:var(--r-sm);white-space:pre-wrap;line-height:var(--lh-normal)}.media-err{font-size:var(--fs-caption);color:var(--c-danger)}.lightbox{position:fixed;top:0;right:0;bottom:0;left:0;z-index:var(--z-modal);display:flex;align-items:center;justify-content:center;padding:var(--fib-8);background:#000000d9;cursor:zoom-out;animation:backdrop-in var(--t-base) var(--ease) both}.lightbox img{max-width:100%;max-height:100%;border-radius:var(--r-sm);box-shadow:var(--shadow-4);cursor:default;animation:pop-in var(--t-base) var(--ease-spring) both}.lightbox-close{position:absolute;top:var(--fib-5);right:var(--fib-5);width:var(--fib-13);height:var(--fib-13);font-size:var(--fs-h3);color:#fff;background:#ffffff26;border-radius:var(--r-circle)}.lightbox-close:hover{background:#ffffff47}.day-sep{align-self:center;margin:var(--fib-2) 0;padding:var(--fib-1) var(--fib-3);font-size:var(--fs-caption);font-weight:var(--fw-medium);color:var(--c-text-soft);background:#ffffffd9;border-radius:var(--r-pill);box-shadow:var(--shadow-1);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.typing{align-self:flex-start;display:inline-flex;gap:var(--fib-1);padding:var(--fib-3);background:var(--c-in);border-radius:var(--r-md);box-shadow:var(--shadow-1)}.typing span{width:var(--fib-2);height:var(--fib-2);border-radius:var(--r-circle);background:var(--c-text-mute);animation:typing-bounce 1.2s var(--ease) infinite}.typing span:nth-child(2){animation-delay:.15s}.typing span:nth-child(3){animation-delay:.3s}.composer{display:flex;align-items:flex-end;gap:var(--fib-2);padding:var(--fib-3);background:var(--c-panel);border-top:var(--fib-1) solid var(--c-border)}.composer textarea{flex:1;min-height:var(--fib-13);max-height:var(--fib-89);padding:var(--fib-2) var(--fib-3);background:var(--c-panel-2);border:var(--fib-1) solid transparent;border-radius:var(--r-xl);resize:none;line-height:var(--lh-normal);transition:border-color var(--t-base) var(--ease),box-shadow var(--t-base) var(--ease),background var(--t-base) var(--ease)}.composer textarea::placeholder{color:var(--c-text-mute)}.composer textarea:focus{background:var(--c-panel);border-color:var(--c-primary);box-shadow:var(--ring)}.icon-btn{flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;width:var(--fib-21);height:var(--fib-21);font-size:var(--fs-h3);color:#fff;background:var(--c-primary);border-radius:var(--r-circle);box-shadow:var(--shadow-1);transition:background var(--t-base) var(--ease),transform var(--t-fast) var(--ease),box-shadow var(--t-base) var(--ease)}.icon-btn:hover{background:var(--c-primary-dark);box-shadow:var(--shadow-2)}.icon-btn:active{transform:scale(.92)}.icon-btn:disabled{opacity:.55;cursor:not-allowed;transform:none}.icon-btn.attach{color:var(--c-text-soft);background:var(--c-panel-2);box-shadow:none}.icon-btn.attach:hover{background:var(--c-border);color:var(--c-text)}.empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:var(--fib-3);padding:var(--fib-13);text-align:center;color:var(--c-text-soft);animation:fade-in var(--t-slow) var(--ease) both}.empty .big{font-size:var(--fs-h1);filter:grayscale(.1);animation:pop-in var(--t-slow) var(--ease-spring) both}.modal-bg{position:fixed;top:0;right:0;bottom:0;left:0;z-index:var(--z-modal-bg);display:flex;align-items:center;justify-content:center;padding:var(--fib-5);background:#0b1b218c;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);animation:backdrop-in var(--t-base) var(--ease) both}.modal{position:relative;z-index:var(--z-modal);width:100%;max-width:var(--fib-233);max-height:90vh;overflow-y:auto;display:flex;flex-direction:column;gap:var(--fib-5);padding:var(--fib-8);background:var(--c-panel);border-radius:var(--r-xl);box-shadow:var(--shadow-4);animation:modal-in var(--t-slow) var(--ease-out) both}.modal h2{font-size:var(--fs-h2);color:var(--c-rail)}.modal .qr{display:flex;flex-direction:column;align-items:center;gap:var(--fib-3)}.modal .qr img{width:var(--fib-144);height:var(--fib-144);padding:var(--fib-2);background:#fff;border:var(--fib-2) solid var(--c-border);border-radius:var(--r-md);box-shadow:var(--shadow-2);animation:pop-in var(--t-base) var(--ease-spring) both}.modal .steps{font-size:var(--fs-sm);line-height:var(--lh-normal);color:var(--c-text-soft)}.modal-actions{display:flex;justify-content:flex-end;gap:var(--fib-3)}.row{display:flex;gap:var(--fib-3)}.row>*{flex:1}.toast{position:fixed;bottom:var(--fib-5);right:var(--fib-5);z-index:var(--z-toast);max-width:var(--fib-233);padding:var(--fib-3) var(--fib-5);font-size:var(--fs-sm);color:#fff;background:var(--c-rail);border-radius:var(--r-md);box-shadow:var(--shadow-3);animation:toast-in var(--t-slow) var(--ease-spring) both}.toast.success{background:var(--c-accent)}.toast.error{background:var(--c-danger)}.toast.info{background:var(--c-info)}[data-tip]{position:relative}[data-tip]:after{content:attr(data-tip);position:absolute;left:100%;top:50%;transform:translate(var(--fib-2),-50%) scale(.95);white-space:nowrap;padding:var(--fib-1) var(--fib-2);font-size:var(--fs-caption);color:#fff;background:var(--c-rail-2);border-radius:var(--r-sm);box-shadow:var(--shadow-2);opacity:0;pointer-events:none;z-index:var(--z-tooltip);transition:opacity var(--t-fast) var(--ease),transform var(--t-fast) var(--ease)}[data-tip]:hover:after{opacity:1;transform:translate(var(--fib-2),-50%) scale(1)}.mobile-back{display:none;font-size:var(--fs-h3);color:var(--c-text);width:var(--fib-13);height:var(--fib-13);border-radius:var(--r-circle);align-items:center;justify-content:center;transition:background var(--t-fast) var(--ease)}.mobile-back:hover{background:var(--c-panel-2)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-1{gap:var(--fib-1)}.gap-2{gap:var(--fib-2)}.gap-3{gap:var(--fib-3)}.mt-auto{margin-top:auto}.text-soft{color:var(--c-text-soft)}.text-mute{color:var(--c-text-mute)}.text-center{text-align:center}.full{width:100%}.hidden{display:none!important}.pill{display:inline-flex;align-items:center;gap:var(--fib-1);padding:var(--fib-1) var(--fib-2);font-size:var(--fs-caption);font-weight:var(--fw-medium);border-radius:var(--r-pill)}.pill.online{color:#0b6b3a;background:#25d36626}.pill.offline{color:#9a5b1e;background:#f4a2612e}@media(max-width:1024px){:root{--w-rail: var(--fib-55);--w-chatlist: var(--fib-144)}.doc-info,.rail-title{display:none}.doc-tab{justify-content:center;padding:var(--fib-2)}.doc-tab.active:after{display:none}.rail-add .btn-label{display:none}.messages{padding:var(--fib-3) var(--fib-5)}}@media(max-width:600px){.app{grid-template-columns:var(--w-rail) 1fr}.chatlist{grid-column:2}.thread,.app.show-thread .chatlist{display:none}.app.show-thread .thread{display:flex;grid-column:2}.mobile-back{display:inline-flex}.messages{padding:var(--fib-3) var(--fib-3)}.bubble{max-width:82%}.toast{left:var(--fib-3);right:var(--fib-3);max-width:none}}@media(max-width:480px){:root{--w-rail: var(--fib-34)}.login-card{padding:var(--fib-8)}.modal{padding:var(--fib-5)}.modal .qr img{width:var(--fib-89);height:var(--fib-89)}.bubble{max-width:85%}.composer{padding:var(--fib-2)}.icon-btn{width:var(--fib-13);height:var(--fib-13);font-size:var(--fs-body)}}@media(max-width:360px){:root{--w-rail: var(--fib-21)}.doc-dot{width:var(--fib-2);height:var(--fib-2)}.chatlist-head h2{font-size:var(--fs-body)}.avatar{width:var(--fib-8);height:var(--fib-8);font-size:var(--fs-caption)}}@media(prefers-color-scheme:dark){:root{--c-bg: #0b141a;--c-bg-chat: #0b141a;--c-panel: #111b21;--c-panel-2: #1c272e;--c-rail: #0a1014;--c-rail-2: #060c10;--c-rail-hover: #1c272e;--c-rail-active: #233138;--c-text: #e9edef;--c-text-soft: #aebac1;--c-text-mute: #8696a0;--c-border: #2a3942;--c-border-soft: #202c33;--c-divider: #1c272e;--c-in: #202c33;--c-out: #005c4b;--c-out-2: #015042;--c-primary-soft: #15302c}body{background:var(--c-bg)}.bubble.in{color:var(--c-text)}.bubble.in:before{border-top-color:var(--c-in);border-right-color:var(--c-in)}.bubble.out{color:#e9edef}.bubble.out:before{border-top-color:var(--c-out);border-left-color:var(--c-out)}.bubble.out .time{color:#9fe0c7}.day-sep{background:#202c33e6;color:var(--c-text-soft)}.avatar{background:linear-gradient(135deg,#2a3942,#233138)}.skeleton{background:linear-gradient(90deg,#1c272e 25%,#233138 37%,#1c272e 63%);background-size:200% 100%}.thread{background-image:radial-gradient(rgba(255,255,255,.02) 1px,transparent 1px)}.err{background:#e6394626}}
