:root{--paper: #ffffff;--panel: #ffffff;--panel-2: #f8f8f8;--panel-hover: rgba(29, 28, 29, .04);--panel-active: rgba(18, 100, 163, .1);--ink: #1d1c1d;--muted: #616061;--line: #e2e2e2;--line-strong: #bbbabb;--phosphor: #007a5a;--phosphor-strong: #148567;--phosphor-soft: #e4f2ed;--link: #1264a3;--link-soft: #e8f5fa;--signal: #e8912d;--alert: #e01e5a;--alert-soft: #fde7ee;--focus-ring: rgba(18, 100, 163, .3);--sb-bg: #3f0e40;--sb-bg-2: #350d36;--sb-hover: rgba(255, 255, 255, .1);--sb-active: #1164a3;--sb-text: rgba(255, 255, 255, .78);--sb-text-strong: #ffffff;--sb-line: rgba(255, 255, 255, .14);--badge: #e01e5a;--mono: ui-monospace, "SF Mono", "JetBrains Mono", "Cascadia Code", Menlo, Consolas, monospace;--sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", "Lato", sans-serif;--radius: 8px;--shadow: 0 0 0 1px rgba(29, 28, 29, .08), 0 4px 12px rgba(0, 0, 0, .12);--shadow-sm: 0 1px 2px rgba(29, 28, 29, .08);--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px);--safe-left: env(safe-area-inset-left, 0px);--safe-right: env(safe-area-inset-right, 0px)}@media(prefers-color-scheme:dark){:root{--paper: #1a1d21;--panel: #1a1d21;--panel-2: #222529;--panel-hover: rgba(232, 232, 232, .06);--panel-active: rgba(29, 155, 209, .16);--ink: #d1d2d3;--muted: #ababad;--line: #35373b;--line-strong: #565856;--phosphor: #2eb67d;--phosphor-strong: #249c69;--phosphor-soft: #1b3129;--link: #1d9bd1;--link-soft: #17293300;--signal: #e8a33d;--alert: #e8547e;--alert-soft: #3a2029;--focus-ring: rgba(29, 155, 209, .35);--sb-bg: #19171d;--sb-bg-2: #121016;--sb-hover: rgba(255, 255, 255, .08);--sb-active: #1164a3;--sb-text: rgba(255, 255, 255, .7);--sb-text-strong: #ffffff;--sb-line: rgba(255, 255, 255, .1);--shadow: 0 0 0 1px rgba(0, 0, 0, .5), 0 6px 18px rgba(0, 0, 0, .5);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .4)}}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:var(--sans);font-size:15px;line-height:1.46;background:var(--paper);color:var(--ink);-webkit-font-smoothing:antialiased;-webkit-tap-highlight-color:transparent}button{font:inherit;cursor:pointer;touch-action:manipulation}input,textarea,select{font:inherit;color:inherit}a{color:var(--link)}:focus-visible{outline:2px solid var(--link);outline-offset:2px;border-radius:4px}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation:none!important;transition:none!important}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;min-height:36px;border:1px solid var(--line-strong);background:var(--panel);color:var(--ink);border-radius:6px;padding:7px 14px;font-weight:700;line-height:1.2;text-decoration:none;transition:background-color .12s ease,border-color .12s ease,box-shadow .12s ease}.btn:hover{background:var(--panel-2);box-shadow:var(--shadow-sm)}.btn:active{box-shadow:none}.btn.primary{background:var(--phosphor);border-color:var(--phosphor);color:#fff}.btn.primary:hover{background:var(--phosphor-strong);border-color:var(--phosphor-strong)}.btn.danger{color:var(--alert);border-color:color-mix(in srgb,var(--alert) 62%,var(--line));background:transparent}.btn.danger:hover{background:var(--alert-soft);border-color:var(--alert)}.btn.small{min-height:30px;padding:5px 10px;font-size:13px;border-radius:6px}.btn:disabled{opacity:.5;cursor:default;box-shadow:none}.btn.send-btn{min-width:62px}.btn.send-btn:after{content:"➤";font-size:11px;opacity:.9}.input{width:100%;border:1px solid var(--line-strong);background:var(--panel);border-radius:6px;padding:10px 12px;transition:border-color .12s ease,box-shadow .12s ease}.input::placeholder{color:color-mix(in srgb,var(--muted) 72%,transparent)}.input:focus{outline:none;border-color:var(--link);box-shadow:0 0 0 3px var(--focus-ring)}.mono{font-family:var(--mono)}.muted{color:var(--muted)}.chip{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:600;color:var(--muted);border:1px solid var(--line);border-radius:999px;padding:3px 10px;background:var(--panel);min-height:24px}.chip.on{color:var(--phosphor);border-color:var(--phosphor);background:var(--phosphor-soft)}.sidebar .chip{background:transparent;color:var(--sb-text);border-color:var(--sb-line)}.auth-wrap{min-height:100%;display:grid;place-items:center;padding:24px;background:var(--paper)}.auth-card{width:100%;max-width:400px;background:var(--panel);border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow);padding:32px}.auth-logo{font-size:26px;font-weight:900;letter-spacing:-.02em;margin:0 0 2px}.auth-logo .hash{color:var(--sb-bg)}@media(prefers-color-scheme:dark){.auth-logo .hash{color:var(--link)}}.auth-logo .cursor{display:inline-block;width:.5em;height:1em;background:var(--phosphor);vertical-align:text-bottom;margin-left:3px;animation:blink 1.4s steps(1) infinite}@keyframes blink{50%{opacity:0}}.auth-sub{margin:0 0 22px;color:var(--muted);font-size:14px}.auth-card label{display:block;font-size:13px;font-weight:700;color:var(--ink);margin:14px 0 5px}.captcha-box{display:flex;align-items:center;gap:8px;background:var(--panel-2);border:1px solid var(--line);border-radius:var(--radius);padding:5px 8px;margin-bottom:6px}.captcha-img{display:block;max-width:100%;height:56px}.auth-error{background:var(--alert-soft);color:var(--alert);border-radius:8px;padding:8px 12px;font-size:13px;margin-top:14px}.auth-card .btn.primary{width:100%;margin-top:20px;min-height:44px;font-size:16px}.auth-switch{margin-top:16px;font-size:13px;color:var(--muted);text-align:center}.app{display:grid;grid-template-columns:260px 1fr;height:100vh;height:100dvh;height:var(--app-h, 100dvh);overflow:hidden}.sidebar{background:var(--sb-bg);color:var(--sb-text);display:flex;flex-direction:column;min-height:0;padding-left:var(--safe-left)}.side-head{padding:calc(10px + var(--safe-top)) 12px 10px 16px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--sb-line);min-height:50px}.side-head .brand{font-weight:900;font-size:18px;color:var(--sb-text-strong);letter-spacing:-.01em}.side-head .brand .hash{opacity:.75}.side-actions{display:flex;gap:6px}.icon-btn{width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;flex:none;border:1px solid transparent;background:transparent;color:var(--muted);border-radius:6px;padding:0;line-height:1;text-decoration:none;transition:background-color .12s ease,color .12s ease}.icon-btn:hover{background:var(--panel-hover);color:var(--ink)}.sidebar .icon-btn{color:var(--sb-text)}.sidebar .icon-btn:hover{background:var(--sb-hover);color:var(--sb-text-strong)}.side-scroll{flex:1;overflow-y:auto;overscroll-behavior:contain;padding:8px 8px 12px;min-height:0}.side-section{font-size:13px;font-weight:600;text-transform:capitalize;color:var(--sb-text);padding:14px 10px 4px;display:flex;justify-content:space-between;align-items:center}.side-section button{font-size:15px;width:26px;height:26px}.chan-item{position:relative;display:flex;align-items:center;gap:8px;width:100%;border:none;background:transparent;color:var(--sb-text);padding:6px 10px;min-height:32px;border-radius:6px;font-family:var(--sans);font-size:15px;text-align:left;transition:background-color .12s ease,color .12s ease}.chan-item:hover{background:var(--sb-hover)}.chan-item.active{background:var(--sb-active);color:#fff;font-weight:700}.chan-item .glyph{color:currentColor;opacity:.72;width:1em;flex:none;text-align:center;font-size:14px}.chan-item.active .glyph{opacity:1}.chan-item .name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chan-item:has(.badge){color:var(--sb-text-strong);font-weight:800}.chan-item .badge{background:var(--badge);color:#fff;font-size:11.5px;border-radius:999px;min-width:19px;height:19px;display:grid;place-items:center;padding:0 6px;font-weight:700}.presence-dot{width:9px;height:9px;border-radius:50%;background:transparent;box-shadow:inset 0 0 0 1.5px currentColor;opacity:.65;flex:none}.presence-dot.on{background:#2bac76;box-shadow:none;opacity:1}.side-foot{border-top:1px solid var(--sb-line);background:var(--sb-bg-2);padding:10px 12px calc(10px + var(--safe-bottom));display:flex;align-items:center;flex-wrap:wrap;gap:8px;row-gap:8px}.side-foot .me{font-size:14px;font-weight:800;flex:1;min-width:72px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--sb-text-strong)}.side-foot .foot-actions{display:flex;align-items:center;gap:4px;margin-left:auto}.main{display:flex;flex-direction:column;min-width:0;min-height:0;background:var(--paper);padding-right:var(--safe-right)}.chan-head{display:flex;align-items:center;gap:10px;min-height:50px;padding:calc(8px + var(--safe-top)) 16px 8px;border-bottom:1px solid var(--line);background:var(--panel)}.chan-head .title{font-weight:900;font-size:17px;letter-spacing:-.01em}.chan-head .title .glyph{color:var(--muted);font-weight:700;margin-right:1px}.chan-head .topic{color:var(--muted);font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;border-left:1px solid var(--line);padding-left:10px}.chan-head .spacer{flex:1}.menu-btn{display:none}.msg-scroll{flex:1;overflow-y:auto;overscroll-behavior:contain;padding:12px 0 8px;min-height:0}.day-divider{display:flex;align-items:center;gap:0;margin:16px 20px 8px;color:var(--ink);font-size:12.5px;font-weight:700}.day-divider:before,.day-divider:after{content:"";flex:1;border-top:1px solid var(--line)}.day-divider:before{margin-right:12px}.day-divider:after{margin-left:12px}.msg-group{display:flex;align-items:flex-start;gap:8px;padding:3px 20px 2px;margin:2px 0 0}.mg-gutter{width:36px;flex:none;padding-top:2px}.mg-gutter .avatar,.mg-gutter .avatar-fallback{border-radius:4px}.mg-body{flex:1;min-width:0}.mg-head{font-size:15px;margin-bottom:1px;display:flex;align-items:baseline;gap:7px}.mg-head .nick{font-weight:900;color:var(--ink)}.mg-head .time{color:var(--muted);font-size:12px}.msg-row{position:relative;padding:2px 46px 2px 0;border-radius:6px;transition:background-color .1s ease}.msg-row:hover,.msg-row.tools-open{background:var(--panel-hover)}.msg-row .row-time{position:absolute;top:4px;right:6px;font-size:11px;color:var(--muted);opacity:0}.msg-row:hover .row-time{opacity:1}.msg-row .body{min-width:0;overflow-wrap:anywhere;white-space:pre-wrap}.msg-row .body .mention{color:var(--link);background:var(--panel-active);border-radius:4px;padding:0 3px;font-weight:600}.msg-row .edited{font-size:11.5px;color:var(--muted);margin-left:6px}.seen{font-size:11px;color:var(--muted);text-align:right;padding-right:4px}.msg-tools{position:absolute;top:-16px;right:8px;display:none;background:var(--panel);border:1px solid var(--line);border-radius:8px;box-shadow:var(--shadow);overflow:hidden;z-index:5}.msg-row:hover .msg-tools,.msg-row:focus-within .msg-tools,.msg-row.tools-open .msg-tools{display:flex}.msg-tools button{border:none;background:transparent;width:34px;height:32px;padding:0;font-size:14px;color:var(--muted);display:grid;place-items:center}.msg-tools button:hover{color:var(--ink);background:var(--panel-hover)}.reactions{display:flex;gap:4px;flex-wrap:wrap;margin-top:4px}.reaction{border:1px solid transparent;background:var(--panel-2);border-radius:999px;padding:2px 8px;font-size:13px;display:inline-flex;gap:5px;align-items:center;min-height:26px;transition:border-color .12s ease,background-color .12s ease}.reaction .n{font-size:11.5px;font-weight:700;color:var(--muted)}.reaction.mine{border-color:var(--link);background:var(--panel-active)}.reaction.mine .n{color:var(--link)}.reaction:hover{border-color:var(--line-strong);background:var(--panel)}.thread-link{border:none;background:transparent;color:var(--link);font-size:13px;font-weight:700;padding:3px 5px;margin-top:2px;border-radius:5px}.thread-link:hover{background:var(--panel-active);text-decoration:none}.file-card{display:flex;align-items:center;gap:10px;border:1px solid var(--line);background:var(--panel);border-radius:10px;padding:10px 12px;margin-top:6px;max-width:420px;text-decoration:none;color:var(--ink);transition:border-color .12s ease,box-shadow .12s ease}.file-card:hover{border-color:var(--line-strong);box-shadow:var(--shadow-sm)}.file-card .fname{font-weight:600;font-size:13.5px;word-break:break-all;color:var(--link)}.file-card .fsize{color:var(--muted);font-size:12px}.img-preview{display:block;max-width:min(420px,100%);max-height:320px;border-radius:10px;border:1px solid var(--line);margin-top:6px}.typing-row{height:20px;padding:0 20px 2px;font-size:12px;color:var(--muted)}.composer{position:relative;margin:0 20px calc(16px + var(--safe-bottom));border:1px solid var(--line-strong);border-radius:10px;background:var(--panel);display:flex;align-items:flex-end;gap:5px;padding:7px 8px;transition:border-color .12s ease,box-shadow .12s ease}.composer:focus-within{border-color:color-mix(in srgb,var(--ink) 45%,var(--line-strong));box-shadow:var(--shadow-sm)}.composer .prompt{display:none}.composer textarea{flex:1;border:none;background:transparent;resize:none;padding:7px 4px;max-height:180px;min-height:24px;line-height:1.4}.composer textarea:focus{outline:none}.composer .icon-btn{width:34px;height:34px;font-size:16px}.composer .send-btn{border-radius:6px}.emoji-suggest{position:absolute;bottom:calc(100% + 8px);left:0;display:flex;gap:4px;flex-wrap:wrap;background:var(--panel);border:1px solid var(--line);border-radius:10px;box-shadow:var(--shadow);padding:6px;z-index:30}.emoji-suggest button{border:none;background:transparent;border-radius:6px;padding:4px 8px;font-size:12.5px;color:var(--muted);display:inline-flex;align-items:center;gap:6px}.emoji-suggest button .ch{font-size:17px}.emoji-suggest button:hover,.emoji-suggest button[aria-selected=true]{background:var(--panel-active);color:var(--link)}.emoji-pop{position:absolute;bottom:calc(100% + 8px);right:0;display:grid;grid-template-columns:repeat(8,1fr);gap:2px;background:var(--panel);border:1px solid var(--line);border-radius:10px;box-shadow:var(--shadow);padding:8px;z-index:30;max-width:320px}.emoji-pop button{border:none;background:transparent;font-size:20px;line-height:1;border-radius:6px;padding:6px}.emoji-pop button:hover{background:var(--panel-hover)}.fx{position:fixed;inset:0;pointer-events:none;z-index:200;overflow:hidden}.fx span{position:absolute;will-change:transform,opacity}.fx .fx-rise{bottom:-70px;animation:fx-rise 3s linear forwards}@keyframes fx-rise{70%{opacity:1}to{transform:translateY(calc(-100vh - 140px)) translate(var(--sway, 0px));opacity:0}}.fx .fx-fall{top:-60px;animation:fx-fall 4s linear forwards}.fx .fx-paper{border-radius:2px;display:inline-block}@keyframes fx-fall{80%{opacity:1}to{transform:translateY(calc(100vh + 120px)) translate(var(--sway, 0px)) rotate(var(--spin, 360deg));opacity:0}}.fx .fx-burst{width:7px;height:7px;border-radius:50%;transform:scale(0);animation:fx-burst 1.1s ease-out forwards}@keyframes fx-burst{0%{transform:translate(0) scale(1);opacity:1}to{transform:translate(var(--dx),var(--dy)) scale(.3);opacity:0}}.fx .fx-across{left:-90px;top:var(--y, 60vh);animation:fx-across 1.6s ease-in forwards}@keyframes fx-across{to{transform:translate(calc(100vw + 220px),calc(-1 * var(--y, 60vh) - 20vh))}}.upload-row{margin:0 20px 8px;border:1px solid var(--line);border-radius:var(--radius);background:var(--panel-2);padding:8px 12px;display:flex;align-items:center;gap:10px;font-size:13px}.upload-bar{flex:1;height:6px;background:var(--line);border-radius:999px;overflow:hidden}.upload-bar>div{height:100%;background:var(--phosphor);transition:width .2s}.overlay-panel{position:fixed;inset:0 0 0 auto;width:min(440px,100vw);background:var(--panel);border-left:1px solid var(--line);box-shadow:var(--shadow);display:flex;flex-direction:column;z-index:40}.overlay-head{display:flex;align-items:center;justify-content:space-between;min-height:50px;padding:calc(10px + var(--safe-top)) 16px 10px;border-bottom:1px solid var(--line);font-weight:900;font-size:15px;background:var(--panel)}.overlay-body{flex:1;overflow-y:auto;overscroll-behavior:contain;min-height:0}.modal-back{position:fixed;inset:0;background:#1d1c1d80;display:grid;place-items:center;z-index:50;padding:16px}.modal{width:100%;max-width:440px;background:var(--panel);border-radius:12px;border:1px solid var(--line);box-shadow:var(--shadow);padding:22px;max-height:90vh;max-height:90dvh;overflow-y:auto;overscroll-behavior:contain}.modal h3{margin:0 0 4px;font-size:20px;font-weight:900;letter-spacing:-.01em}.modal .sub{color:var(--muted);font-size:13.5px;margin:0 0 16px}.modal label{display:block;font-size:13px;font-weight:700;color:var(--ink);margin:12px 0 5px}.modal .row{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end;margin-top:18px}.member-row{display:flex;align-items:center;gap:10px;padding:7px 2px;font-size:14px;min-height:40px}.member-row .grow{flex:1}.msg-row.flash{animation:flash-bg 2.4s ease-out}@keyframes flash-bg{0%,40%{background:color-mix(in srgb,#f2c744 22%,transparent)}to{background:transparent}}.fp-row{display:flex;align-items:center;gap:12px;padding:11px 16px;border-bottom:1px solid var(--line);transition:background-color .12s ease}.fp-row:hover{background:var(--panel-hover)}.fp-thumb{width:42px;height:42px;object-fit:cover;border-radius:8px;border:1px solid var(--line);flex:none}.fp-icon{font-size:26px;width:42px;text-align:center;flex:none}.fp-meta{flex:1;min-width:0;display:grid}.fp-name{font-size:13.5px;font-weight:600;color:var(--ink);text-decoration:none;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.fp-name:hover{color:var(--link);text-decoration:underline}.fp-sub{font-size:12px;color:var(--muted)}.search-hit{display:block;width:100%;text-align:left;border:none;border-bottom:1px solid var(--line);background:transparent;padding:11px 16px;color:var(--ink);transition:background-color .12s ease}.search-hit:hover{background:var(--panel-hover)}.search-hit .where{font-size:12.5px;font-weight:700;color:var(--link)}.search-hit .snippet{font-size:13.5px;margin-top:2px;overflow-wrap:anywhere}.search-hit .when{font-size:11.5px;color:var(--muted)}.admin-wrap{flex:1;overflow-y:auto;overscroll-behavior:contain;padding:20px;min-height:0}.admin-wrap h2{margin:4px 0 16px;font-weight:900;letter-spacing:-.01em}.admin-tabs{display:flex;gap:6px;margin-bottom:18px;flex-wrap:wrap}.admin-tabs button{border:1px solid var(--line-strong);background:var(--panel);border-radius:999px;padding:7px 14px;font-size:13.5px;font-weight:600;color:var(--muted);transition:border-color .12s ease,background-color .12s ease,color .12s ease}.admin-tabs button:hover{color:var(--ink);background:var(--panel-2)}.admin-tabs button.on{color:#fff;border-color:var(--sb-active);background:var(--sb-active)}.table{width:100%;border-collapse:collapse;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}.table th,.table td{text-align:left;padding:10px 12px;border-bottom:1px solid var(--line);font-size:13.5px}.table th{font-size:12px;letter-spacing:.03em;font-weight:700;color:var(--muted);background:var(--panel-2);text-transform:uppercase;font-family:var(--sans)}.table td.mono{font-size:12.5px}.table tr:last-child td{border-bottom:none}.pill{font-size:11.5px;font-weight:700;border-radius:999px;padding:2px 8px}.pill.active{background:var(--phosphor-soft);color:var(--phosphor)}.pill.paused{background:var(--alert-soft);color:var(--signal)}.pill.admin{background:var(--panel-2);color:var(--ink)}.settings-grid{display:grid;gap:14px;max-width:560px}.setting-row{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:14px 16px;display:flex;align-items:center;gap:14px}.setting-row .info{flex:1}.setting-row .info b{display:block;font-size:14px}.setting-row .info span{font-size:12.5px;color:var(--muted)}.toggle{position:relative;width:42px;height:24px;flex:none}.toggle input{position:absolute;opacity:0;inset:0;margin:0;cursor:pointer}.toggle .knob{position:absolute;inset:0;background:var(--line-strong);border-radius:999px;transition:background .15s}.toggle .knob:after{content:"";position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:50%;background:#fff;box-shadow:0 1px 3px #00000040;transition:transform .15s}.toggle input:checked+.knob{background:var(--phosphor)}.toggle input:checked+.knob:after{transform:translate(18px)}.toasts{position:fixed;bottom:calc(16px + var(--safe-bottom));left:50%;transform:translate(-50%);z-index:90;display:grid;gap:8px}.toast{background:#1d1c1d;color:#fff;border-radius:var(--radius);padding:10px 16px;font-size:13.5px;font-weight:600;box-shadow:var(--shadow)}.toast.error{background:var(--alert);color:#fff}.bot-badge{font-size:9.5px;font-weight:800;letter-spacing:.04em;color:var(--muted);background:var(--panel-2);border:1px solid var(--line);border-radius:3px;padding:1px 4px;vertical-align:middle}.token-reveal{background:var(--phosphor-soft);border:1px solid var(--phosphor);border-radius:var(--radius);padding:12px 14px;margin-bottom:16px;font-size:13px}.token-value{background:var(--panel);border:1px solid var(--line);border-radius:6px;padding:8px 10px;margin-top:6px;word-break:break-all;font-size:12.5px}.avatar{border-radius:4px;object-fit:cover;flex:none;display:inline-block;vertical-align:middle}.avatar-fallback{border-radius:4px;color:#fff;display:inline-grid;place-items:center;font-weight:800;flex:none;vertical-align:middle;user-select:none}.side-foot .avatar,.side-foot .avatar-fallback{border-radius:50%}.ic{font-family:var(--mono);font-size:.86em;color:var(--alert);background:var(--panel-2);border:1px solid var(--line);border-radius:4px;padding:0 4px}.codeblock{background:var(--panel-2);border:1px solid var(--line);border-radius:8px;padding:10px 12px;margin:6px 0;overflow-x:auto;font-family:var(--mono);font-size:12.5px;line-height:1.5;max-width:720px}.quote-card{display:block;width:fit-content;max-width:480px;text-align:left;background:transparent;border:none;border-left:4px solid var(--line-strong);border-radius:0;padding:2px 10px;margin:4px 0;color:var(--ink);cursor:pointer}.quote-card:hover{border-left-color:var(--link)}.quote-card .q-nick{font-size:13px;font-weight:800;display:block}.quote-card .q-text{font-size:13.5px;color:var(--muted);display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:440px}.pin-note{font-size:11.5px;color:var(--signal);font-weight:600;margin-bottom:2px}.lp-card{display:block;width:fit-content;max-width:480px;border:none;border-left:4px solid var(--line);border-radius:0;background:transparent;padding:2px 12px;margin-top:6px;text-decoration:none;color:var(--ink);transition:border-color .12s ease}.lp-card:hover{border-left-color:var(--link)}.lp-title{display:block;font-weight:700;font-size:13.5px;color:var(--link)}.lp-desc{display:block;font-size:12.5px;color:var(--muted);margin-top:2px}.lp-site{display:block;font-size:11.5px;color:var(--muted);margin-top:4px}.img-preview.clickable{cursor:zoom-in}.poll{display:grid;gap:6px;margin-top:8px;max-width:440px}.poll-opt{position:relative;border:1px solid var(--line);background:var(--panel);border-radius:8px;padding:8px 12px;text-align:left;display:flex;align-items:center;gap:8px;overflow:hidden;min-height:40px;transition:border-color .12s ease}.poll-opt:hover,.poll-opt.mine{border-color:var(--link)}.poll-bar{position:absolute;inset:0 auto 0 0;background:var(--panel-active);transition:width .25s ease}.poll-label{position:relative;flex:1;font-size:13.5px}.poll-count{position:relative;font-size:12.5px;font-weight:700;color:var(--muted)}.poll-foot{font-size:11.5px;color:var(--muted)}.lightbox{position:fixed;inset:0;background:#0a0a0ceb;z-index:120;display:grid;place-items:center}.lb-img{max-width:92vw;max-height:84vh;border-radius:8px;object-fit:contain}.lb-top{position:absolute;top:var(--safe-top);left:0;right:0;display:flex;justify-content:space-between;align-items:center;padding:12px 16px;color:#eee;font-size:13px}.lb-nav{position:absolute;top:50%;transform:translateY(-50%);background:#ffffff1f;border:1px solid rgba(255,255,255,.16);color:#fff;font-size:34px;width:52px;height:52px;border-radius:50%;line-height:0;display:grid;place-items:center;backdrop-filter:blur(6px)}.lb-nav:hover{background:#ffffff40}.lb-nav.prev{left:18px}.lb-nav.next{right:18px}.chan-item.muted-chan .name{opacity:.55}.install-banner{position:fixed;right:16px;bottom:calc(16px + var(--safe-bottom));z-index:80;display:flex;align-items:center;gap:10px;background:var(--panel);border:1px solid var(--line-strong);border-radius:10px;box-shadow:var(--shadow);padding:11px 12px;max-width:min(420px,calc(100vw - 32px))}.install-banner .ib-icon{color:var(--phosphor);font-size:18px}.install-banner .ib-text{display:grid;font-size:13px;line-height:1.35}.install-banner .ib-text b{font-weight:800}.install-banner .ib-text span{color:var(--muted);font-size:12.5px}.empty{flex:1;display:grid;place-items:center;color:var(--muted);font-size:14px;text-align:center;padding:24px}@media(hover:none){.msg-row .row-time{display:none}.btn:hover,.icon-btn:hover,.chan-item:hover{transform:none}}@media(max-width:760px){.app{grid-template-columns:1fr}.sidebar{position:fixed;inset:0 auto 0 0;width:min(83vw,330px);z-index:60;transform:translate(-105%);transition:transform .22s ease;box-shadow:none}.sidebar.open{transform:translate(0);box-shadow:0 0 40px #00000073}.side-back{position:fixed;inset:0;background:#00000080;z-index:55}.side-foot .foot-actions{flex-basis:100%;justify-content:space-between;margin-left:0}.menu-btn{display:inline-flex}.input,.composer textarea,.modal input,.modal select,.modal textarea,.auth-card input{font-size:16px}.icon-btn{width:38px;height:38px}.side-section button{width:32px;height:32px}.chan-item{min-height:42px;padding:8px 10px}.msg-tools button{width:42px;height:40px;font-size:16px}.btn{min-height:40px}.btn.small{min-height:34px}.reaction{min-height:30px;padding:3px 10px}.chan-head{min-height:50px;padding:calc(6px + var(--safe-top)) 8px 6px;gap:4px}.chan-head .topic{display:none}.chan-head .title{font-size:16px;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chan-head .chip{display:none}.msg-group{padding:3px 10px 2px;gap:8px}.mg-gutter{width:32px}.msg-row{padding-right:0}.day-divider{margin:14px 12px 6px}.typing-row{padding:0 12px 2px}.composer{margin:0 8px calc(8px + var(--safe-bottom));padding:6px;gap:4px}.composer .icon-btn{width:36px;height:36px}.composer .send-btn{min-width:44px;padding-inline:10px}.composer .send-btn:after{content:"➤"}.upload-row{margin:0 8px 8px}.emoji-pop{grid-template-columns:repeat(7,1fr);max-width:calc(100vw - 40px)}.modal-back{display:flex;align-items:flex-end;padding:0}.modal{max-width:100%;border-radius:16px 16px 0 0;border-left:none;border-right:none;border-bottom:none;max-height:88vh;max-height:88dvh;padding:20px 18px calc(20px + var(--safe-bottom))}.overlay-panel{width:100vw}.install-banner{bottom:calc(86px + var(--safe-bottom));right:10px}.lb-nav{width:44px;height:44px;font-size:26px}.lb-nav.prev{left:8px}.lb-nav.next{right:8px}.admin-wrap{padding:14px 10px}.table{display:block;overflow-x:auto}}
