:root{--radius-sm:12px;--radius:16px;--radius-lg:22px;--glass-blur:18px;--accent:#6d28d9;--font-family:"Inter", system-ui, sans-serif;--font-scale:1;--accent-2:#6366f1;--accent-strong:color-mix(in oklab, var(--accent), black 14%);--accent-grad:linear-gradient(135deg, var(--accent), var(--accent-2));--accent-soft:color-mix(in srgb, var(--accent) 16%, transparent);--accent-ring:color-mix(in srgb, var(--accent) 38%, transparent);--on-accent:#fff;--fs-xs:calc(11px * var(--font-scale));--fs-sm:calc(12.5px * var(--font-scale));--fs-base:calc(14.5px * var(--font-scale));--fs-lg:calc(18px * var(--font-scale));--fs-xl:calc(20px * var(--font-scale))}:root[data-density=compact]{--gap:8px;--msg-pad:2px 8px;--row-pad:7px 10px;--col-w:248px}:root[data-density=comfortable]{--gap:12px;--msg-pad:4px 8px;--row-pad:9px 12px;--col-w:268px}:root[data-density=spacious]{--gap:16px;--msg-pad:8px 10px;--row-pad:12px 14px;--col-w:292px}:root[data-mode=light]{--text:#16182a;--text-muted:#5b6478;--glass-bg:#ffffff8c;--glass-bg-strong:#ffffffbd;--glass-hover:#ffffff80;--glass-border:#ffffffb3;--surface-2:#ffffff8c;--input-bg:#ffffff9e;--shadow:0 10px 34px #1f26871a;--shadow-lg:0 24px 60px #1f268733;--scrollbar:#14183238;--base-1:#eef1ff;--base-2:#f6f2ff;--base-3:#eaf6ff}:root[data-mode=dark]{--text:#e8ebf7;--text-muted:#9aa3bd;--glass-bg:#12182c85;--glass-bg-strong:#12182cbd;--glass-hover:#ffffff0f;--glass-border:#ffffff1a;--surface-2:#ffffff0f;--input-bg:#ffffff12;--shadow:0 10px 34px #00000052;--shadow-lg:0 24px 60px #00000080;--scrollbar:#fff3;--base-1:#0a0f1f;--base-2:#140f33;--base-3:#0b1430}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:var(--font-family);color:var(--text);font-size:var(--fs-base);-webkit-font-smoothing:antialiased;overflow:hidden}button{cursor:pointer;color:inherit;background:0 0;border:none;font-family:inherit}input,textarea{color:var(--text);font-family:inherit}:root[data-bg=solid] body{background:var(--base-1)}:root[data-bg=gradient] body{background:linear-gradient(140deg, color-mix(in srgb, var(--accent) 15%, var(--base-1)), var(--base-2) 50%, color-mix(in srgb, var(--accent-2) 15%, var(--base-3)))}:root[data-bg=mesh] body{background:radial-gradient(at 16% 18%, color-mix(in srgb, var(--accent) 32%, transparent), transparent 50%), radial-gradient(at 84% 14%, color-mix(in srgb, var(--accent-2) 30%, transparent), transparent 48%), radial-gradient(at 70% 84%, color-mix(in srgb, var(--accent) 20%, transparent), transparent 46%), var(--base-2)}:root[data-bg=aurora] body{background:var(--base-2)}:root[data-bg=aurora] body:before{content:"";z-index:-1;filter:blur(70px);opacity:.85;background:radial-gradient(38% 38% at 22% 30%, color-mix(in srgb, var(--accent) 62%, transparent), transparent), radial-gradient(36% 36% at 80% 22%, color-mix(in srgb, var(--accent-2) 55%, transparent), transparent), radial-gradient(44% 44% at 60% 82%, color-mix(in srgb, var(--accent) 42%, transparent), transparent);animation:20s ease-in-out infinite alternate aurora;position:fixed;inset:-25%}@keyframes aurora{0%{transform:translate(0,0)rotate(0)scale(1)}to{transform:translateY(-5%)rotate(8deg)scale(1.1)}}*{scrollbar-width:thin;scrollbar-color:var(--scrollbar) transparent}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-thumb{background:var(--scrollbar);background-clip:content-box;border:3px solid #0000;border-radius:8px}.shell{flex-direction:column;height:100vh;display:flex;overflow:hidden}.app{grid-template-columns:var(--col-w) 1fr 330px;background:0 0;flex:1;grid-template-rows:minmax(0,1fr);gap:10px;min-height:0;padding:10px;display:grid;overflow:hidden}.app.app-no-right{grid-template-columns:var(--col-w) 1fr}.main{flex-direction:column;min-width:0;min-height:0;display:flex;overflow:hidden}.sidebar{background:var(--glass-bg);min-height:0;-webkit-backdrop-filter:blur(var(--glass-blur)) saturate(150%);backdrop-filter:blur(var(--glass-blur)) saturate(150%);border:1px solid var(--glass-border);border-radius:var(--radius-lg);box-shadow:var(--shadow);flex-direction:column;display:flex}.brand{flex-direction:column;padding:18px 20px 12px;line-height:1;display:flex}.brand-logo{letter-spacing:.5px;background:var(--accent-grad);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;padding-top:2px;font-size:20px;font-weight:800;line-height:1.3}.brand-sub{letter-spacing:3px;color:var(--text-muted);margin-top:4px;font-size:10px;font-weight:700}.workspace-card{text-align:left;background:var(--surface-2);border:1px solid var(--glass-border);border-radius:12px;align-items:center;gap:9px;margin:2px 12px 8px;padding:7px 9px;transition:background .14s,border-color .14s;display:flex}.workspace-card:hover{background:var(--glass-hover);border-color:var(--accent)}.workspace-meta{flex:1;min-width:0}.workspace-chevron{color:var(--text-muted);flex-shrink:0}.workspace-name{font-weight:700;font-size:var(--fs-sm);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.workspace-id{font-size:var(--fs-xs);color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.nav{flex-direction:column;gap:2px;padding:4px 10px;display:flex}.nav-item{border-radius:var(--radius-sm);color:var(--text-muted);font-size:var(--fs-base);text-align:left;align-items:center;gap:12px;width:100%;padding:9px 12px;font-weight:500;transition:background .14s,color .14s,transform .14s;display:flex}.nav-item:hover{background:color-mix(in srgb, var(--accent) 14%, transparent);color:var(--text)}.nav-item-active{background:var(--accent-grad);color:var(--on-accent);box-shadow:0 8px 20px var(--accent-ring)}.nav-icon{flex-shrink:0}.nav-badge{background:var(--accent);min-width:20px;height:20px;color:var(--on-accent);font-size:var(--fs-xs);border-radius:10px;justify-content:center;align-items:center;margin-left:auto;padding:0 6px;font-weight:800;display:inline-flex}.nav-item-active .nav-badge{background:#ffffff47}.rooms{flex:1;min-height:0;padding:8px 10px 12px;overflow-y:auto}.rooms-head{justify-content:space-between;align-items:center;padding-right:4px;display:flex}.rooms-title{font-size:var(--fs-xs);letter-spacing:1.5px;text-transform:uppercase;color:var(--text-muted);padding:8px 8px 6px;font-weight:700}.rooms-add{width:26px;height:26px;color:var(--text-muted);border-radius:8px;justify-content:center;align-items:center;transition:background .14s,color .14s;display:flex}.rooms-add:hover{background:var(--glass-hover);color:var(--accent)}.rooms-empty{color:var(--text-muted);font-size:var(--fs-sm);padding:8px}.room-group{margin-bottom:8px}.room-group-title{font-size:var(--fs-xs);color:var(--text-muted);padding:6px 8px 4px;font-weight:600}.room-item{border-radius:var(--radius-sm);width:100%;color:var(--text);font-size:var(--fs-base);text-align:left;cursor:pointer;align-items:center;gap:10px;padding:8px 10px;transition:background .14s,transform .14s;display:flex}.room-more{width:24px;height:24px;color:var(--text-muted);opacity:0;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;font-size:18px;line-height:1;transition:opacity .12s,background .12s;display:flex}.room-item:hover .room-more{opacity:1}.room-more:hover{color:var(--text);background:#ffffff2e}.room-item-active .room-more{color:var(--on-accent)}.room-item:hover{background:color-mix(in srgb, var(--accent) 14%, transparent)}.room-item-active{background:var(--accent-grad);color:var(--on-accent);box-shadow:0 8px 20px var(--accent-ring)}.cat-icon{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;display:flex;box-shadow:0 4px 10px #0000002e}.room-name{white-space:nowrap;text-overflow:ellipsis;flex:1;overflow:hidden}.room-unread{background:var(--accent);color:var(--on-accent);font-size:var(--fs-xs);border-radius:9px;justify-content:center;align-items:center;min-width:18px;height:18px;padding:0 5px;font-weight:700;display:inline-flex}.room-item-active .room-unread{background:#ffffff4d}.user-footer{border-top:1px solid var(--glass-border);align-items:center;gap:8px;padding:12px;display:flex;position:relative}.user-footer-meta{flex:1;min-width:0}.user-footer-name{font-size:var(--fs-sm);white-space:nowrap;text-overflow:ellipsis;font-weight:700;overflow:hidden}.user-footer-status{font-size:var(--fs-xs);color:var(--text-muted);align-items:center;gap:6px;display:flex}.user-footer-icon{width:32px;height:32px;color:var(--text-muted);border-radius:9px;font-size:16px;transition:background .14s,color .14s}.user-footer-icon:hover{color:var(--text);background:var(--glass-hover)}.room{flex-direction:column;min-width:0;height:100%;min-height:0;display:flex}.room-header{background:var(--glass-bg);-webkit-backdrop-filter:blur(var(--glass-blur)) saturate(150%);backdrop-filter:blur(var(--glass-blur)) saturate(150%);border:1px solid var(--glass-border);box-shadow:var(--shadow);border-radius:14px;align-items:center;gap:11px;padding:9px 16px;display:flex}.room-header-icon{background:var(--accent-grad);width:42px;height:42px;box-shadow:0 8px 18px var(--accent-ring);border-radius:12px;justify-content:center;align-items:center;font-size:20px;display:flex}.room-header-main{flex:1;min-width:0}.room-header-name{font-weight:700;font-size:var(--fs-base)}.room-header-topic{font-size:var(--fs-sm);color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.room-header-actions{align-items:center;gap:10px;display:flex}.room-member-chip{background:var(--surface-2);color:var(--text-muted);font-size:var(--fs-xs);white-space:nowrap;border:1px solid var(--glass-border);border-radius:8px;padding:4px 9px;font-weight:700}.icon-btn{width:36px;height:36px;color:var(--text-muted);border-radius:10px;font-size:16px}.icon-btn:hover{background:var(--glass-hover);color:var(--text)}.messages{flex:1;min-height:0;padding:16px 18px 8px;overflow:hidden auto}.messages-empty{color:var(--text-muted);text-align:center;font-size:var(--fs-base);margin-top:40px}.date-sep{text-align:center;margin:18px 0 12px;position:relative}.date-sep:before{content:"";background:var(--glass-border);height:1px;position:absolute;top:50%;left:0;right:0}.date-sep span{background:var(--glass-bg-strong);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);font-size:var(--fs-xs);color:var(--text-muted);text-transform:capitalize;border-radius:999px;padding:3px 12px;font-weight:700;position:relative}.msg{padding:var(--msg-pad);border-radius:12px;gap:12px;transition:background .12s;display:flex;position:relative}.msg:hover{background:var(--glass-hover)}.msg:hover .msg-hide{opacity:1}.msg-gutter{flex-shrink:0;width:38px}.msg-body{flex:1;min-width:0}.msg-head{align-items:baseline;gap:8px;margin-bottom:2px;display:flex}.msg-author{font-weight:700;font-size:var(--fs-base)}.msg-time{font-size:var(--fs-xs);color:var(--text-muted)}.msg-content{font-size:var(--fs-base);color:var(--text);white-space:pre-wrap;word-break:break-word;padding-right:28px;line-height:1.5;position:relative}.msg-quote{border-left:2px solid var(--accent);background:var(--accent-soft);font-size:var(--fs-sm);color:var(--text-muted);border-radius:6px;align-items:center;gap:6px;width:fit-content;max-width:100%;margin-bottom:3px;padding:3px 10px;display:flex}.msg-quote-author{color:var(--accent-strong);font-weight:700}.msg-quote-body{white-space:nowrap;text-overflow:ellipsis;max-width:360px;overflow:hidden}.msg-media em{color:var(--text-muted);font-style:italic}.msg-hide{opacity:0;color:var(--text-muted);border-radius:6px;padding:2px 6px;font-size:16px;line-height:1;transition:opacity .12s;position:absolute;top:-2px;right:0}.msg-hide:hover{background:var(--surface-2);color:#ef4444}.avatar{color:#fff;-webkit-user-select:none;user-select:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-weight:700;display:flex;box-shadow:0 2px 8px #0000002e}.badge{letter-spacing:.4px;text-transform:uppercase;border-radius:6px;padding:2px 7px;font-size:10px;font-weight:800}.role-admin{background:var(--accent-soft);color:var(--accent-strong)}.role-merchant{color:#2563eb;background:#2563eb29}.role-verified{color:#16a34a;background:#16a34a2e}.role-member{background:var(--surface-2);color:var(--text-muted)}.presence{border:2px solid var(--glass-bg-strong);background:#94a3b8;border-radius:50%;width:10px;height:10px;display:inline-block}.presence-online{background:#22c55e}.presence-unavailable{background:#f59e0b}.presence-offline{background:#94a3b8}.composer-wrap{margin-top:8px;position:relative}.composer-reply{font-size:var(--fs-sm);color:var(--text-muted);background:var(--glass-bg);-webkit-backdrop-filter:blur(var(--glass-blur));backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);border-left:3px solid var(--accent);border-radius:12px;align-items:center;gap:8px;margin-bottom:6px;padding:8px 14px;display:flex}.composer-reply-text{white-space:nowrap;text-overflow:ellipsis;flex:1;overflow:hidden}.composer-reply b{color:var(--text)}.composer-reply button{width:26px;height:26px;color:var(--text-muted);border-radius:7px;justify-content:center;align-items:center;display:flex}.composer-reply button:hover{background:var(--glass-hover);color:var(--text)}.composer{background:var(--glass-bg);-webkit-backdrop-filter:blur(var(--glass-blur)) saturate(150%);backdrop-filter:blur(var(--glass-blur)) saturate(150%);border:1px solid var(--glass-border);border-radius:var(--radius-lg);box-shadow:var(--shadow);flex-direction:column;display:flex;overflow:hidden}.composer-row{align-items:flex-end;gap:8px;padding:8px 8px 8px 12px;display:flex}.composer-editwrap{flex:1;min-width:0;position:relative}.composer-ph{color:var(--text-muted);font-size:var(--fs-base);pointer-events:none;position:absolute;top:8px;left:4px}.composer-editable{min-height:24px;max-height:220px;font-size:var(--fs-base);white-space:pre-wrap;word-break:break-word;outline:none;padding:8px 4px;line-height:1.5;overflow-y:auto}.composer-editable code{background:var(--surface-2);border-radius:5px;padding:0 4px;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:.9em}.composer-editable blockquote{border-left:3px solid var(--accent);color:var(--text-muted);margin:2px 0;padding:0 10px}.composer-editable h1,.composer-editable h2,.composer-editable h3{margin:2px 0;font-size:1.15em;font-weight:800}.composer-editable ul{margin:2px 0;padding-left:20px}.composer-editable a{color:var(--accent)}.composer-btn{width:38px;height:38px;color:var(--text-muted);border-radius:10px;font-size:18px}.composer-btn:not(:disabled):hover{background:var(--glass-hover)}.composer-btn:disabled{opacity:.5;cursor:not-allowed}.composer-send{background:var(--accent-grad);width:40px;height:40px;color:var(--on-accent);box-shadow:0 8px 18px var(--accent-ring);border-radius:12px;justify-content:center;align-items:center;font-size:16px;display:flex}.composer-send:disabled{opacity:.45;box-shadow:none;cursor:not-allowed}.rightpanel{flex-direction:column;gap:10px;min-height:0;display:flex;overflow-y:auto}.panel-card{background:var(--glass-bg);-webkit-backdrop-filter:blur(var(--glass-blur)) saturate(150%);backdrop-filter:blur(var(--glass-blur)) saturate(150%);border:1px solid var(--glass-border);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:16px}.panel-card h3{font-size:var(--fs-sm);margin:0 0 10px;font-weight:800}.panel-topic{font-size:var(--fs-sm);color:var(--text-muted);margin:0;line-height:1.5}.member-list{flex-direction:column;gap:10px;margin:0;padding:0;list-style:none;display:flex}.member-item{align-items:center;gap:10px;display:flex}.member-avatar{position:relative}.member-avatar .presence{position:absolute;bottom:-1px;right:-1px}.member-meta{min-width:0}.member-name{font-size:var(--fs-sm);white-space:nowrap;text-overflow:ellipsis;font-weight:600;overflow:hidden}.member-role{font-size:var(--fs-xs);color:var(--text-muted)}.room-empty{justify-content:center;align-items:center}.empty-state{text-align:center;color:var(--text-muted);margin:auto}.empty-emoji{margin-bottom:8px;font-size:46px}.empty-state h2{color:var(--text);font-size:var(--fs-xl);margin:0 0 6px}.empty-state p{font-size:var(--fs-base);margin:0}.login-screen,.splash{justify-content:center;align-items:center;height:100vh;display:flex}.login-card{background:var(--glass-bg-strong);-webkit-backdrop-filter:blur(26px)saturate(160%);backdrop-filter:blur(26px)saturate(160%);border:1px solid var(--glass-border);border-radius:var(--radius-lg);width:380px;max-width:92vw;box-shadow:var(--shadow-lg);padding:30px 28px}.login-brand{flex-direction:column;align-items:center;margin-bottom:8px;line-height:1;display:flex}.login-logo{letter-spacing:.5px;background:var(--accent-grad);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:24px;font-weight:800}.login-sub{letter-spacing:4px;color:var(--text-muted);margin-top:4px;font-size:10px;font-weight:700}.login-title{font-size:var(--fs-xl);text-align:center;margin:6px 0 0}.login-hint{text-align:center;color:var(--text-muted);font-size:var(--fs-sm);margin:4px 0 10px}.field{flex-direction:column;gap:5px;margin-bottom:12px;display:flex}.field span{font-size:var(--fs-xs);color:var(--text-muted);font-weight:700}.field input,.text-input{background:var(--input-bg);border:1px solid var(--glass-border);font-size:var(--fs-base);border-radius:10px;outline:none;padding:10px 12px;transition:border .14s,box-shadow .14s}.field input:focus,.text-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}.btn-primary{background:var(--accent-grad);width:100%;color:var(--on-accent);font-weight:700;font-size:var(--fs-base);box-shadow:0 10px 22px var(--accent-ring);border-radius:12px;padding:12px;transition:opacity .14s,transform .14s}.btn-primary:hover:not(:disabled){transform:translateY(-1px)}.btn-primary:disabled{opacity:.55;cursor:not-allowed}.btn-sm{width:auto;padding:9px 16px}.login-error{color:#ef4444;font-size:var(--fs-sm);background:#ef44441f;border-radius:10px;margin-bottom:12px;padding:10px 12px}.login-switch{width:100%;font-size:var(--fs-sm);color:var(--accent);border-radius:10px;margin-top:10px;padding:8px;font-weight:700}.login-switch:hover{background:var(--glass-hover)}.splash{color:var(--text);flex-direction:column;gap:16px}.splash-logo{letter-spacing:2px;background:var(--accent-grad);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:26px;font-weight:800}.splash-spinner{border:3px solid var(--surface-2);border-top-color:var(--accent);border-radius:50%;width:34px;height:34px;animation:.8s linear infinite spin}.splash-label{color:var(--text-muted);font-size:var(--fs-base)}@keyframes spin{to{transform:rotate(360deg)}}.media-image{border:1px solid var(--glass-border);border-radius:14px;max-width:min(420px,100%);max-height:360px;margin-top:2px;display:block}.media-loading{background:var(--surface-2);width:240px;height:160px;animation:1.2s ease-in-out infinite pulse}@keyframes pulse{50%{opacity:.5}}.file-chip{background:var(--surface-2);border:1px solid var(--glass-border);font-size:var(--fs-sm);color:var(--text);border-radius:12px;align-items:center;gap:8px;max-width:320px;padding:8px 12px;display:inline-flex}.file-chip:hover{border-color:var(--accent)}.file-chip-name{white-space:nowrap;text-overflow:ellipsis;font-weight:600;overflow:hidden}.file-chip-action{color:var(--accent);margin-left:auto;font-weight:700}.toast-host{z-index:1000;flex-direction:column;gap:10px;max-width:340px;display:flex;position:fixed;top:18px;right:18px}.toast{text-align:left;background:var(--glass-bg-strong);-webkit-backdrop-filter:blur(20px)saturate(160%);backdrop-filter:blur(20px)saturate(160%);border:1px solid var(--glass-border);border-left:3px solid var(--accent);box-shadow:var(--shadow-lg);border-radius:14px;flex-direction:column;gap:3px;padding:12px 14px;animation:.18s ease-out toast-in;display:flex}.toast-title{font-size:var(--fs-sm);font-weight:800}.toast-body{font-size:var(--fs-xs);color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}@keyframes toast-in{0%{opacity:0;transform:translate(12px)}}.modal-overlay{z-index:1100;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#080a1673;justify-content:center;align-items:center;padding:20px;animation:.15s ease-out fade-in;display:flex;position:fixed;inset:0}@keyframes fade-in{0%{opacity:0}}.settings{background:var(--glass-bg-strong);-webkit-backdrop-filter:blur(28px)saturate(160%);backdrop-filter:blur(28px)saturate(160%);border:1px solid var(--glass-border);border-radius:var(--radius-lg);width:min(860px,96vw);height:min(620px,92vh);box-shadow:var(--shadow-lg);grid-template-columns:210px 1fr;display:grid;overflow:hidden}.settings-nav{border-right:1px solid var(--glass-border);flex-direction:column;gap:4px;padding:18px 12px;display:flex}.settings-nav-title{font-size:var(--fs-xs);letter-spacing:1.5px;text-transform:uppercase;color:var(--text-muted);padding:4px 10px 8px;font-weight:700}.settings-nav-item{text-align:left;font-size:var(--fs-base);color:var(--text-muted);border-radius:10px;padding:10px 12px;font-weight:600;transition:background .14s,color .14s}.settings-nav-item:hover{background:var(--glass-hover);color:var(--text)}.settings-nav-item.active{background:var(--accent-soft);color:var(--accent-strong)}.settings-body{padding:22px 26px;position:relative;overflow-y:auto}.settings-close{width:34px;height:34px;color:var(--text-muted);border-radius:9px;font-size:22px;position:absolute;top:16px;right:18px}.settings-close:hover{background:var(--glass-hover);color:var(--text)}.settings-page h2{font-size:var(--fs-xl);margin:0 0 18px}.settings-section{margin-bottom:22px}.settings-section-head{align-items:baseline;gap:10px;margin-bottom:10px;display:flex}.settings-section-head h3{font-size:var(--fs-base);margin:0;font-weight:700}.settings-section-head span{font-size:var(--fs-xs);color:var(--text-muted)}.preset-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:12px;display:grid}.preset-card{border:1px solid var(--glass-border);background:var(--surface-2);border-radius:14px;flex-direction:column;gap:8px;padding:8px;transition:transform .14s,border-color .14s,box-shadow .14s;display:flex}.preset-card:hover{border-color:var(--accent);transform:translateY(-2px)}.preset-card.active{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-ring)}.preset-preview{border:1px solid var(--glass-border);border-radius:10px;justify-content:center;align-items:center;height:64px;display:flex;position:relative;overflow:hidden}.preset-preview[data-mode=dark]{color:#e8ebf7}.preset-aa{font-size:20px;font-weight:800}.preset-dot{border-radius:50%;width:14px;height:14px;position:absolute;bottom:8px;right:8px;box-shadow:0 0 0 2px #ffffff80}.preset-name{font-size:var(--fs-xs);text-align:center;font-weight:700}.segmented{background:var(--surface-2);border:1px solid var(--glass-border);border-radius:12px;flex-wrap:wrap;gap:4px;padding:4px;display:inline-flex}.segmented button{font-size:var(--fs-sm);color:var(--text-muted);border-radius:9px;padding:8px 14px;font-weight:600;transition:background .14s,color .14s}.segmented button:hover{color:var(--text)}.segmented button.active{background:var(--accent-grad);color:var(--on-accent);box-shadow:0 6px 14px var(--accent-ring)}.swatch-row{flex-wrap:wrap;gap:10px;display:flex}.swatch{border:2px solid #0000;border-radius:10px;width:32px;height:32px;transition:transform .12s;position:relative;box-shadow:0 4px 10px #0000002e}.swatch:hover{transform:scale(1.08)}.swatch.active{border-color:var(--text)}.swatch-custom{cursor:pointer;background:conic-gradient(red,#ff0,#0f0,#0ff,#00f,#f0f,red);justify-content:center;align-items:center;display:flex;overflow:hidden}.swatch-custom input{opacity:0;cursor:pointer;width:100%;height:100%}.profile-head{align-items:center;gap:14px;margin-bottom:20px;display:flex}.profile-display{font-size:var(--fs-lg);font-weight:800}.profile-id{font-size:var(--fs-sm);color:var(--text-muted)}.profile-name-row{gap:8px;display:flex}.profile-name-row .text-input{flex:1}.profile-saved{font-size:var(--fs-sm);color:#16a34a;margin-top:8px;font-weight:600}.about-text{font-size:var(--fs-base);color:var(--text-muted);margin:0 0 12px;line-height:1.6}.topbar{background:var(--glass-bg);-webkit-backdrop-filter:blur(var(--glass-blur)) saturate(150%);backdrop-filter:blur(var(--glass-blur)) saturate(150%);border:1px solid var(--glass-border);border-radius:var(--radius-lg);box-shadow:var(--shadow);align-items:center;gap:16px;margin:10px 10px 0;padding:10px 16px;display:flex}.topbar-search{background:var(--surface-2);border:1px solid var(--glass-border);max-width:520px;color:var(--text-muted);font-size:var(--fs-sm);border-radius:12px;flex:1;align-items:center;gap:10px;padding:9px 14px;transition:border-color .14s,background .14s;display:flex}.topbar-search:hover{border-color:var(--accent)}.topbar-search span{text-align:left;flex:1}.topbar-kbd{font-size:var(--fs-xs);background:var(--glass-bg-strong);border:1px solid var(--glass-border);border-radius:6px;padding:2px 7px;font-weight:700}.topbar-actions{align-items:center;gap:6px;margin-left:auto;display:flex}.topbar-icon{width:38px;height:38px;color:var(--text-muted);border-radius:11px;justify-content:center;align-items:center;transition:background .14s,color .14s;display:flex;position:relative}.topbar-icon:hover{background:var(--glass-hover);color:var(--text)}.topbar-badge{background:var(--accent);min-width:16px;height:16px;color:var(--on-accent);border-radius:8px;justify-content:center;align-items:center;padding:0 4px;font-size:10px;font-weight:800;display:flex;position:absolute;top:4px;right:4px}.topbar-brand{letter-spacing:.5px;background:var(--accent-grad);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-left:8px;font-weight:800}.reactions{flex-wrap:wrap;gap:6px;margin-top:5px;display:flex}.reaction{background:var(--surface-2);border:1px solid var(--glass-border);font-size:var(--fs-sm);border-radius:999px;align-items:center;gap:5px;padding:3px 9px;line-height:1;transition:background .12s,border-color .12s,transform .12s;display:inline-flex}.reaction:hover{transform:translateY(-1px)}.reaction.mine{background:var(--accent-soft);border-color:var(--accent)}.reaction-count{color:var(--text-muted);font-weight:700}.reaction.mine .reaction-count{color:var(--accent-strong)}.reaction-add{color:var(--text-muted);padding:4px 8px}.msg-toolbar{background:var(--glass-bg-strong);-webkit-backdrop-filter:blur(14px)saturate(150%);backdrop-filter:blur(14px)saturate(150%);border:1px solid var(--glass-border);box-shadow:var(--shadow);opacity:0;pointer-events:none;border-radius:10px;gap:2px;padding:3px;transition:opacity .12s;display:flex;position:absolute;top:-12px;right:10px}.msg:hover .msg-toolbar{opacity:1;pointer-events:auto}.msg-toolbar button{width:30px;height:30px;color:var(--text-muted);border-radius:7px;justify-content:center;align-items:center;display:flex}.msg-toolbar button:hover{background:var(--glass-hover);color:var(--text)}.msg-picker{z-index:60;position:absolute;top:26px;left:50px}.emoji-picker{background:var(--glass-bg-strong);-webkit-backdrop-filter:blur(22px)saturate(160%);backdrop-filter:blur(22px)saturate(160%);border:1px solid var(--glass-border);width:300px;box-shadow:var(--shadow-lg);border-radius:14px;flex-direction:column;gap:8px;padding:8px;display:flex}.emoji-search{background:var(--input-bg);border:1px solid var(--glass-border);font-size:var(--fs-sm);border-radius:9px;outline:none;padding:8px 10px}.emoji-cats{gap:2px;display:flex}.emoji-cat{border-radius:8px;justify-content:center;align-items:center;width:30px;height:30px;font-size:16px;display:flex}.emoji-cat:hover{background:var(--glass-hover)}.emoji-cat.active{background:var(--accent-soft)}.emoji-grid{grid-template-columns:repeat(7,1fr);gap:2px;max-height:220px;display:grid;overflow-y:auto}.emoji-empty{text-align:center;color:var(--text-muted);font-size:var(--fs-sm);grid-column:1/-1;padding:20px}.emoji-pick{aspect-ratio:1;border-radius:8px;justify-content:center;align-items:center;width:100%;font-size:20px;transition:background .12s,transform .12s;display:flex}.emoji-pick:hover{background:var(--glass-hover);transform:scale(1.15)}.float-emoji{pointer-events:none;z-index:2000;font-size:26px;animation:1s ease-out forwards float-up;position:fixed}@keyframes float-up{0%{opacity:0;transform:translateY(0)scale(.6)}20%{opacity:1;transform:translateY(-10px)scale(1.2)}to{opacity:0;transform:translateY(-90px)scale(1)}}.palette-overlay{align-items:flex-start;padding-top:12vh}.palette{background:var(--glass-bg-strong);-webkit-backdrop-filter:blur(28px)saturate(160%);backdrop-filter:blur(28px)saturate(160%);border:1px solid var(--glass-border);border-radius:var(--radius-lg);width:min(600px,94vw);max-height:60vh;box-shadow:var(--shadow-lg);flex-direction:column;animation:.16s ease-out palette-in;display:flex;overflow:hidden}@keyframes palette-in{0%{opacity:0;transform:translateY(-8px)}}.palette-input{font-size:var(--fs-lg);border:none;border-bottom:1px solid var(--glass-border);background:0 0;outline:none;padding:16px 18px}.palette-list{padding:6px;overflow-y:auto}.palette-empty{text-align:center;color:var(--text-muted);font-size:var(--fs-sm);padding:18px}.palette-item{text-align:left;border-radius:10px;align-items:center;gap:12px;width:100%;padding:10px 12px;display:flex}.palette-item.active{background:var(--accent-soft)}.palette-item-icon{justify-content:center;align-items:center;width:26px;font-size:16px;display:flex}.palette-item-label{font-size:var(--fs-base);flex:1;font-weight:600}.palette-item.active .palette-item-label{color:var(--accent-strong)}.palette-item-hint{font-size:var(--fs-xs);color:var(--text-muted)}.room-av{color:#fff;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;font-weight:700;display:flex;overflow:hidden;box-shadow:0 4px 10px #0000002e}.room-av-img{object-fit:cover}.md-code{background:var(--surface-2);border:1px solid var(--glass-border);border-radius:6px;padding:1px 5px;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:.9em}.md-pre{background:var(--surface-2);border:1px solid var(--glass-border);border-radius:10px;margin:4px 0;padding:10px 12px;overflow-x:auto}.md-pre code{white-space:pre;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:.88em}.md-link{color:var(--accent);text-decoration:none}.md-link:hover{text-decoration:underline}.mention{color:var(--accent-strong);background:var(--accent-soft);border-radius:5px;padding:0 4px;font-weight:600}.msg-edited{font-size:var(--fs-xs);color:var(--text-muted);margin-left:6px}.msg-edit{margin-top:2px}.msg-edit-input{resize:vertical;width:100%;min-height:52px;font-size:var(--fs-base);background:var(--input-bg);border:1px solid var(--accent);border-radius:10px;outline:none;padding:8px 10px}.msg-edit-actions{justify-content:flex-end;gap:8px;margin-top:6px;display:flex}.msg-edit-actions button:first-child{font-size:var(--fs-sm);color:var(--text-muted);border-radius:9px;padding:7px 12px}.msg-edit-actions button:first-child:hover{background:var(--glass-hover);color:var(--text)}.typing{height:22px;font-size:var(--fs-sm);color:var(--text-muted);align-items:center;gap:8px;padding:0 24px;display:flex}.typing-empty{visibility:hidden}.typing-dots{gap:3px;display:inline-flex}.typing-dots i{background:var(--accent);border-radius:50%;width:5px;height:5px;animation:1.1s ease-in-out infinite typing-bounce}.typing-dots i:nth-child(2){animation-delay:.15s}.typing-dots i:nth-child(3){animation-delay:.3s}@keyframes typing-bounce{0%,80%,to{opacity:.5;transform:translateY(0)}40%{opacity:1;transform:translateY(-4px)}}.mention-pop{background:var(--glass-bg-strong);-webkit-backdrop-filter:blur(20px)saturate(160%);backdrop-filter:blur(20px)saturate(160%);border:1px solid var(--glass-border);min-width:240px;max-height:240px;box-shadow:var(--shadow-lg);z-index:50;border-radius:14px;padding:6px;position:absolute;bottom:calc(100% + 6px);left:0;overflow-y:auto}.mention-item{text-align:left;width:100%;font-size:var(--fs-base);border-radius:9px;align-items:center;gap:8px;padding:8px 10px;font-weight:500;display:flex}.mention-item.active{background:var(--accent-soft)}.mention-trigger{color:var(--accent-strong);font-weight:800}.view{height:100%;padding:24px 28px;overflow-y:auto}.view-header{margin-bottom:18px}.view-header h1{font-size:var(--fs-xl);margin:0}.view-header p{color:var(--text-muted);font-size:var(--fs-sm);margin:4px 0 0}.view-empty{text-align:center;color:var(--text-muted);padding:60px 0}.view-empty-emoji{margin-bottom:8px;font-size:40px}.row-list{flex-direction:column;gap:6px;margin:0;padding:0;list-style:none;display:flex}.row{text-align:left;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:14px;align-items:center;gap:12px;width:100%;padding:10px 12px;transition:border-color .14s;display:flex}.row:hover{border-color:var(--accent)}.row-static{cursor:default}.row-main{flex:1;min-width:0}.row-title{font-weight:700;font-size:var(--fs-base);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.row-room{color:var(--text-muted);font-weight:500}.row-sub{font-size:var(--fs-sm);color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.row-badge{background:var(--accent);color:var(--on-accent);font-size:var(--fs-xs);border-radius:10px;justify-content:center;align-items:center;min-width:20px;height:20px;padding:0 6px;font-weight:800;display:inline-flex}.row-time{font-size:var(--fs-xs);color:var(--text-muted)}.row-fav{color:var(--warn)}.row-actions{gap:8px;display:flex}.home{padding:24px 28px}.home-head{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.home-head h1{margin:0;font-size:26px}.home-head p{color:var(--text-muted);font-size:var(--fs-sm);margin:4px 0 0}.home-actions{flex-wrap:wrap;gap:10px;display:flex}.home-chips{flex-wrap:wrap;gap:10px;margin:16px 0 20px;display:flex}.home-chip{background:var(--surface-2);border:1px solid var(--glass-border);font-size:var(--fs-sm);color:var(--text-muted);border-radius:999px;padding:8px 14px}.home-chip b{color:var(--text);font-size:var(--fs-base);margin-right:4px}button.home-chip:hover{border-color:var(--accent)}.home-section{font-size:var(--fs-base);margin:0 0 12px}.home-cols{grid-template-columns:1fr 300px;align-items:start;gap:20px;display:grid}.home-feed{min-width:0}.feed-list{flex-direction:column;gap:4px;margin:0;padding:0;list-style:none;display:flex}.feed-item{text-align:left;border-radius:12px;gap:12px;width:100%;padding:10px 12px;transition:background .12s;display:flex}.feed-item:hover{background:color-mix(in srgb, var(--accent) 12%, transparent)}.feed-main{flex:1;min-width:0}.feed-meta{font-size:var(--fs-sm);align-items:baseline;gap:6px;display:flex}.feed-room{color:var(--accent-strong);font-weight:600}.feed-time{color:var(--text-muted);font-size:var(--fs-xs);margin-left:auto}.feed-body{font-size:var(--fs-sm);color:var(--text);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.home-aside{flex-direction:column;gap:16px;display:flex}.home-block{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:14px}.mini-room{text-align:left;width:100%;font-size:var(--fs-sm);border-radius:10px;align-items:center;gap:8px;padding:7px 8px;font-weight:500;display:flex}.mini-room:hover{background:color-mix(in srgb, var(--accent) 12%, transparent)}.mini-room span{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.mini-mention{text-align:left;border-radius:10px;flex-direction:column;gap:2px;width:100%;padding:7px 8px;display:flex}.mini-mention:hover{background:color-mix(in srgb, var(--accent) 12%, transparent)}.mini-mention b{font-size:var(--fs-sm)}.mini-mention span{font-size:var(--fs-xs);color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}@media (width<=900px){.home-cols{grid-template-columns:1fr}}.btn-ghost{background:var(--surface-2);border:1px solid var(--glass-border);color:var(--text);font-weight:600;font-size:var(--fs-base);border-radius:12px;padding:11px 16px}.btn-ghost:hover{border-color:var(--accent)}.dialog{background:var(--glass-bg-strong);-webkit-backdrop-filter:blur(28px)saturate(160%);backdrop-filter:blur(28px)saturate(160%);border:1px solid var(--glass-border);border-radius:var(--radius-lg);width:420px;max-width:94vw;box-shadow:var(--shadow-lg);padding:24px}.dialog h2{font-size:var(--fs-xl);margin:0 0 16px}.dialog-actions{justify-content:flex-end;gap:10px;margin-top:8px;display:flex}.toggle-row{font-size:var(--fs-sm);color:var(--text-muted);cursor:pointer;align-items:center;gap:10px;margin:4px 0 12px;display:flex}.toggle-row input{width:16px;height:16px;accent-color:var(--accent)}.ctx-menu{z-index:1200;background:var(--glass-bg-strong);-webkit-backdrop-filter:blur(22px)saturate(160%);backdrop-filter:blur(22px)saturate(160%);border:1px solid var(--glass-border);min-width:190px;box-shadow:var(--shadow-lg);border-radius:12px;padding:6px;position:fixed}.ctx-item{text-align:left;width:100%;font-size:var(--fs-sm);border-radius:8px;align-items:center;gap:8px;padding:9px 10px;font-weight:500;display:flex}.ctx-item:hover{background:color-mix(in srgb, var(--accent) 14%, transparent)}.ctx-item.danger{color:#ef4444}.ctx-item.danger:hover{background:#ef444424}.status-menu{background:var(--glass-bg-strong);-webkit-backdrop-filter:blur(22px)saturate(160%);backdrop-filter:blur(22px)saturate(160%);border:1px solid var(--glass-border);width:230px;box-shadow:var(--shadow-lg);z-index:60;border-radius:14px;padding:8px;position:absolute;bottom:calc(100% + 8px);left:12px}.status-opt{text-align:left;width:100%;font-size:var(--fs-sm);border-radius:9px;align-items:center;gap:10px;padding:9px 10px;font-weight:500;display:flex}.status-opt:hover{background:var(--glass-hover)}.status-opt.active{background:var(--accent-soft);color:var(--accent-strong)}.status-custom{border-top:1px solid var(--glass-border);gap:6px;margin-top:6px;padding-top:6px;display:flex}.status-custom input{background:var(--input-bg);border:1px solid var(--glass-border);min-width:0;font-size:var(--fs-sm);border-radius:9px;outline:none;flex:1;padding:7px 9px}.user-footer-statusbtn{text-align:left;flex:1;min-width:0}.user-footer-statusbtn:hover .user-footer-name{color:var(--accent)}.link-preview{border:1px solid var(--glass-border);border-left:3px solid var(--accent);background:var(--surface-2);max-width:460px;color:inherit;border-radius:12px;gap:10px;margin-top:6px;padding:10px;text-decoration:none;display:flex}.link-preview:hover{border-color:var(--accent)}.link-preview-img{object-fit:cover;border-radius:8px;flex-shrink:0;width:64px;height:64px}.link-preview-body{min-width:0}.link-preview-site{font-size:var(--fs-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.link-preview-title{font-weight:700;font-size:var(--fs-sm);margin:2px 0}.link-preview-desc{font-size:var(--fs-xs);color:var(--text-muted);-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.format-bar{border-bottom:1px solid var(--glass-border);align-items:center;gap:2px;padding:5px 10px;display:flex}.format-bar button{width:28px;height:28px;color:var(--text-muted);border-radius:7px;justify-content:center;align-items:center;transition:background .12s,color .12s;display:flex}.format-bar button:hover{background:color-mix(in srgb, var(--accent) 16%, transparent);color:var(--accent-strong)}.format-sep{background:var(--glass-border);width:1px;height:16px;margin:0 4px}.md-h{margin:2px 0;font-weight:800;line-height:1.3}.md-h1{font-size:1.35em}.md-h2{font-size:1.2em}.md-h3{font-size:1.08em}.md-ul{margin:2px 0;padding-left:20px}.md-ul li{margin:1px 0}.md-quote{border-left:3px solid var(--accent);color:var(--text-muted);margin:3px 0;padding:2px 10px}del{opacity:.75}.feed-head{justify-content:space-between;align-items:center;gap:12px;display:flex}.feed-markread{font-size:var(--fs-sm);color:var(--accent);border-radius:9px;align-items:center;gap:6px;padding:6px 10px;font-weight:600;display:inline-flex}.feed-markread:hover{background:color-mix(in srgb, var(--accent) 12%, transparent)}.feed-filters{flex-wrap:wrap;gap:6px;margin:10px 0 12px;display:flex}.feed-filter{font-size:var(--fs-sm);color:var(--text-muted);border:1px solid var(--glass-border);background:var(--surface-2);border-radius:10px;padding:6px 12px;font-weight:600}.feed-filter:hover{border-color:var(--accent)}.feed-filter.active{background:var(--accent-grad);color:var(--on-accent);border-color:#0000}.feed-item{cursor:pointer}.feed-item .reactions{margin-top:4px}.member-card{background:var(--glass-bg-strong);-webkit-backdrop-filter:blur(28px)saturate(160%);backdrop-filter:blur(28px)saturate(160%);border:1px solid var(--glass-border);border-radius:var(--radius-lg);width:380px;max-width:94vw;box-shadow:var(--shadow-lg);overflow:hidden}.member-card-banner{background:var(--accent-grad);height:84px}.member-card-head{align-items:flex-end;gap:14px;margin-top:-40px;margin-bottom:14px;padding:0 22px;display:flex}.member-card-avatar{position:relative}.member-card-avatar .avatar{border:3px solid var(--glass-bg-strong)}.member-card-dot{width:16px;height:16px;position:absolute;bottom:3px;right:3px}.member-card-info{min-width:0;padding-bottom:4px}.member-card-bio{font-size:var(--fs-sm);color:var(--text);margin:0 0 14px;padding:0 22px;line-height:1.5}.member-card-name{font-size:var(--fs-lg);align-items:center;gap:8px;font-weight:800;display:flex}.member-card-id{font-size:var(--fs-sm);color:var(--text-muted);word-break:break-all}.member-card-presence{font-size:var(--fs-sm);color:var(--text-muted);align-items:center;gap:6px;margin-top:4px;display:flex}.member-card-section{border-top:1px solid var(--glass-border);padding:14px 22px 0}.member-card-section h4{font-size:var(--fs-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;margin:0 0 8px}.member-field{font-size:var(--fs-sm);justify-content:space-between;align-items:center;padding:8px 0;display:flex}.member-field+.member-field{border-top:1px solid color-mix(in srgb, var(--glass-border) 40%, transparent)}.member-field span{color:var(--text-muted)}.member-card-actions{gap:8px}.msg-caption{font-size:var(--fs-base);color:var(--text);white-space:pre-wrap;word-break:break-word;margin-top:4px;line-height:1.5}.msg-text{display:block}.member-card-note{font-size:var(--fs-xs);color:var(--text-muted);margin:10px 0 0;font-style:italic}.member-card-actions{justify-content:flex-end;padding:14px 22px 18px;display:flex}.profile-bio{resize:vertical;width:100%;min-height:64px}.msg-avatar-btn{border-radius:50%;padding:0;display:block}.msg-avatar-btn:hover{opacity:.85}.msg-author{padding:0}.msg-author:hover{text-decoration:underline}.member-item{text-align:left;border-radius:10px;width:100%;padding:6px;transition:background .12s}.member-item:hover{background:color-mix(in srgb, var(--accent) 12%, transparent)}.presence-dnd{background:#ef4444}.status-dnd.active{color:#ef4444;background:#ef444424}.status-dnd-state{font-size:var(--fs-xs);color:#ef4444;margin-left:auto;font-weight:700}.composer-attach{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:14px;align-items:center;gap:12px;margin-bottom:6px;padding:8px;display:flex}.composer-attach-thumb{object-fit:cover;border-radius:10px;flex-shrink:0;width:56px;height:56px}.composer-attach-file{background:var(--surface-2);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:56px;height:56px;font-size:24px;display:flex}.composer-attach-meta{flex:1;min-width:0}.composer-attach-name{font-weight:600;font-size:var(--fs-sm);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.composer-attach-hint{font-size:var(--fs-xs);color:var(--text-muted)}.composer-attach-remove{width:30px;height:30px;color:var(--text-muted);border-radius:8px;justify-content:center;align-items:center;display:flex}.composer-attach-remove:hover{background:var(--glass-hover);color:var(--text)}.panel-card-head{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.panel-card-head h3{margin:0}.panel-link{font-size:var(--fs-xs);color:var(--accent);font-weight:700}.panel-link:hover{text-decoration:underline}.panel-media{grid-template-columns:repeat(3,1fr);gap:6px;display:grid}.panel-media-cell{aspect-ratio:1;border-radius:8px;overflow:hidden}.panel-media-img{object-fit:cover;width:100%;height:100%;display:block}.panel-media-cell:hover .panel-media-img{opacity:.85}.gallery{background:var(--glass-bg-strong);-webkit-backdrop-filter:blur(28px)saturate(160%);backdrop-filter:blur(28px)saturate(160%);border:1px solid var(--glass-border);border-radius:var(--radius-lg);width:min(880px,96vw);height:min(640px,92vh);box-shadow:var(--shadow-lg);flex-direction:column;display:flex;overflow:hidden}.gallery-head{border-bottom:1px solid var(--glass-border);justify-content:space-between;align-items:center;padding:18px 22px;display:flex;position:relative}.gallery-head h2{font-size:var(--fs-xl);margin:0}.gallery-body{flex:1;padding:18px 22px;overflow-y:auto}.gallery-section{font-size:var(--fs-sm);color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;margin:4px 0 10px}.gallery-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:8px;margin-bottom:18px;display:grid}.gallery-cell{aspect-ratio:1;border-radius:12px;overflow:hidden}.gallery-img{object-fit:cover;width:100%;height:100%;transition:transform .14s;display:block}.gallery-cell:hover .gallery-img{transform:scale(1.05)}.gallery-files{flex-direction:column;gap:6px;margin:0;padding:0;list-style:none;display:flex}.room-group-title{text-align:left;cursor:pointer;align-items:center;gap:4px;width:100%;display:flex}.room-group-title:hover{color:var(--text)}.group-chev{flex-shrink:0;transition:transform .15s}.group-chev.open{transform:rotate(90deg)}.composer-readonly{text-align:center;color:var(--text-muted);font-size:var(--fs-sm);padding:14px 18px}.discover-search{width:100%;margin-bottom:14px}.discover-avatar{object-fit:cover;border-radius:10px;flex-shrink:0;width:40px;height:40px}.discover-avatar-ph{background:var(--surface-2);color:var(--text-muted);justify-content:center;align-items:center;font-weight:700;display:flex}.stat-row{font-size:var(--fs-sm);justify-content:space-between;align-items:center;padding:5px 0;display:flex}.stat-row b{font-weight:700}.stat-note{font-size:var(--fs-xs);color:var(--text-muted);margin:6px 0 0;font-style:italic}@media (width<=1100px){.app{grid-template-columns:var(--col-w) 1fr}.rightpanel{display:none}}@media (width<=720px){.app,.app.app-no-right{grid-template-columns:1fr;padding:6px}.sidebar{display:none}.settings{grid-template-columns:1fr}.settings-nav{border-right:none;border-bottom:1px solid var(--glass-border);flex-direction:row;overflow-x:auto}}
