*{box-sizing:border-box;scrollbar-width:thin;scrollbar-color:#bcbcbc transparent}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#bcbcbc padding-box padding-box;border:2px solid #0000;border-radius:999px}::-webkit-scrollbar-thumb:hover{background:#d6d6d6}:root{color:#fff;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;font-weight:400;line-height:1.5}html{background:#000;max-width:100%;overflow-x:hidden}body{color:#fff;background:#000;max-width:100%;min-height:100vh;margin:0;overflow-x:hidden}#root{background:#111;width:100%;min-height:100vh}.app-shell{background:#111;place-items:center;min-height:100vh;padding:24px;display:grid}.app-shell:has(.login-page-card){background:#111}.app-shell:has(.chat-page){place-items:stretch stretch;padding:0}.page-card{color:#fff;background:#111;border:1px solid #333;border-radius:8px;width:min(960px,100%);padding:24px}.page-card.wide{width:min(1100px,100%)}.login-page-card{background:#111;border:none;border-radius:0;flex-direction:column;align-items:center;gap:16px;width:min(460px,92vw);padding:24px 20px;display:flex}.login-art{width:min(240px,70vw);height:auto;display:block}.login-form{width:100%;max-width:240px}.login-form button{align-self:center;width:auto;margin-top:10px;padding:4px 24px}.login-page-card .sub{color:#e5e7eb;margin:0}.login-page-card .sub a{color:#fff}.login-page-card .error-text{color:#fca5a5;margin:0}.field-error{color:#fca5a5;text-align:left;margin:-8px 0 0;font-size:.78rem}h1,h2{color:#fff;margin:0}h1{margin-bottom:8px;font-size:1.5rem}h2{margin-bottom:8px;font-size:1.125rem}.sub{color:#aaa;margin:0 0 16px}.error-text{color:#b91c1c}.status{color:#1f2937}.form-col{flex-direction:column;gap:12px;display:flex}label{flex-direction:column;gap:6px;font-size:.95rem;display:flex}input,button,textarea,select{font:inherit}input,textarea,select{color:#e4e4e4;background:#1a1a1a;border:1px solid #444;border-radius:2px;padding:2px 12px}button{color:#e4e4e4;cursor:pointer;background:#111;border:.5px solid #e4e4e4;border-radius:2px;width:30%;padding:2px 14px}button:disabled{opacity:.6;cursor:not-allowed}button.ghost{color:#fff;background:#111;border-color:#666}.header-row{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:16px;display:flex}.split-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;display:grid}.room-list{gap:12px;margin-top:16px;display:grid}.room-item,.panel-box{background:#111;border:1px solid #333;border-radius:8px;padding:12px}.room-item{justify-content:space-between;align-items:center;gap:12px;display:flex}.actions{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.header-user-name{color:#d7d7d7;letter-spacing:.04em;white-space:nowrap;text-overflow:ellipsis;text-align:right;max-width:180px;margin:0;font-size:.95rem;line-height:1;overflow:hidden}.panel-box{flex-direction:column;gap:10px;display:flex}.chat-page{flex-direction:column;width:100%;height:auto;min-height:100vh;display:flex}.chat-header{background:#111;flex-shrink:0;justify-content:space-between;align-items:center;padding:8px 20px;display:flex}.chat-header h1{color:#fff;margin:0;font-size:1.1rem}.chat-header-info{flex-direction:column;gap:2px;display:flex}.chat-header-logo{flex:1;justify-content:center;align-items:center;display:flex}.header-logo-img{object-fit:contain;width:auto;height:40px}.chat-header-sub{color:#fffc;font-size:.8rem}.chat-header .ghost{color:#fff;border-color:#ffffff80}.chat-body{flex:1;grid-template-columns:minmax(0,1fr) 320px;min-height:0;padding-right:12px;display:grid}.chat-main{background:#111;flex-direction:column;gap:10px;min-height:0;padding:0 12px 12px;display:flex}.chat-input-row{flex-shrink:0;align-items:center;gap:8px;display:flex}.chat-input-row input{flex:1}.chat-input-row textarea{resize:vertical;flex:1;min-height:30px;max-height:40px}.chat-input-row button{width:auto}.chat-sidebar{--sidebar-divider-length:100%;background:#111;border:1px solid #333;border-radius:8px;flex-direction:column;gap:0;min-height:0;margin-bottom:12px;padding:0;display:flex;overflow:hidden}.chat-info-panel{text-align:center;background:#111;border:none;border-radius:0;flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;gap:8px;padding:12px;display:flex}.chat-info-logo-img{object-fit:contain;width:auto;height:200px}.chat-info-panel h2{color:#fff;margin-bottom:4px}.chat-info-panel .sub{color:#fffc;text-align:center;margin:0;font-size:.875rem;font-style:italic}.info-stanza-gap{height:.45rem;display:block}.info-line-small{font-size:.75rem}.chat-members-panel{background:#111;border:none;border-radius:0;flex:1;min-height:0;padding:18px 12px 12px;position:relative;overflow-y:auto}.chat-members-panel:before{content:"";width:min(var(--sidebar-divider-length), 100%);border-top:1px solid #333;position:absolute;top:0;left:50%;transform:translate(-50%)}.chat-members-panel h2{color:#fff;margin-bottom:8px;font-size:.95rem;font-weight:400}.chat-members-panel .members li{background:0 0;border:none;border-radius:0;align-items:center;padding:3px 0}.chat-members-panel .members{gap:4px}.chat-members-panel .members span{color:#ffffffb3}.chat-members-panel .members strong{color:#fff;font-weight:200}.chat-members-panel .member-info{gap:0}.conn-dot{background:#555;border:none;border-radius:50%;flex-shrink:0;width:10px;height:10px;padding:0;display:inline-block}.conn-dot.ok{cursor:default;background:#22c55e;box-shadow:0 0 6px #22c55e88}.conn-dot.off{cursor:pointer;background:#555}.conn-status{align-items:center;gap:12px;display:flex}.mute-btn{color:#fff;cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;width:auto;padding:0;line-height:1;display:inline-flex}.mute-btn:hover{opacity:.8}.mute-icon{fill:none;stroke:currentColor;stroke-width:2px;stroke-linecap:round;stroke-linejoin:round;width:16px;height:16px;display:block}.logout-btn{color:#fff;cursor:pointer;background:0 0;border:none;padding:0;font-size:.9rem;font-weight:500;transition:color .2s,-webkit-text-decoration .2s,text-decoration .2s}.logout-btn:hover{color:#fca5a5;text-decoration:underline}.logout-btn:active{color:#dc2626}.status-badge{color:#ccc;background:#1a1a1a;border:1px solid #444;border-radius:9999px;padding:2px 8px;font-size:.85rem;display:inline-block}.status-badge.ok{color:#166534;background:#dcfce7;border-color:#86efac}.status-badge.off{color:#991b1b;background:#fee2e2;border-color:#fca5a5}.members{gap:8px;margin:0;padding:0;list-style:none;display:grid}.members li{border:1px solid #333;border-radius:6px;align-items:flex-start;gap:8px;padding:8px;display:flex}.member-avatar{object-fit:cover;border-radius:50%;flex-shrink:0;width:24px;height:24px}.member-info{flex-direction:column;gap:2px;min-width:0;font-size:.875rem;display:flex}.members strong{font-weight:600}.members span{color:#aaa;word-break:break-all;font-size:.875rem}.message-row{justify-content:flex-start;align-items:center;gap:24px;margin-bottom:24px;display:flex}.message-row.mine{justify-content:flex-end}.message-system-row{justify-content:center;margin:6px 0;display:flex}.message-system-text{color:#aaa;letter-spacing:.04em;text-align:center;margin:0;font-size:.82rem}.message-bubble-stack{flex-direction:column;align-items:flex-start;min-width:0;max-width:calc(100% - 88px);display:flex;position:relative}.message-bubble-stack.mine{align-items:flex-end}.message-side{flex-shrink:0;order:-1;justify-content:center;align-items:center;width:56px;height:44px;display:flex;position:relative}.message-side.mine{order:0}.message-name{white-space:nowrap;color:#d7d7d7;letter-spacing:.08em;text-align:center;min-width:max-content;max-width:min(240px,100vw - 140px);margin:0;font-size:.9rem;line-height:1;position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%)}.message-name.long{text-align:left;left:0;transform:none}.message-side.mine .message-name.long{text-align:right;left:auto;right:0}.bubble-avatar{object-fit:cover;border-radius:50%;flex-shrink:0;width:44px;height:44px}.bubble-avatar-placeholder{background:#7f86e8;display:inline-block}.messages{scrollbar-gutter:auto;background-color:#111;background-image:url(/assets/chatroomBG-DSWM7Dz0.png);background-position:50%;background-repeat:no-repeat;background-size:60%;border:1px solid #333;border-radius:8px;flex-direction:column;flex:1;gap:10px;min-height:0;padding:24px 12px 12px;display:flex;overflow:auto}.bubble{z-index:0;color:#fff;background:#4a4a4a;border:1px solid #606060;border-radius:12px;width:max-content;max-width:min(100%,520px);padding:8px 20px;position:relative}.bubble:before{content:"";clip-path:polygon(100% 0,100% 100%,0 50%);z-index:-2;background:#606060;width:18px;height:18px;position:absolute;top:50%;left:-18px;transform:translateY(-50%)}.bubble:after{content:"";clip-path:polygon(100% 0,100% 100%,0 50%);z-index:-1;background:#4a4a4a;width:16px;height:16px;position:absolute;top:50%;left:-15px;transform:translateY(-50%)}.bubble.mine{background:#212121;border-color:#313131;border-radius:12px;margin-right:0}.bubble.mine:before{clip-path:polygon(0 0,100% 50%,0 100%);background:#313131;left:auto;right:-18px}.bubble.mine:after{clip-path:polygon(0 0,100% 50%,0 100%);background:#212121;left:auto;right:-15px}.bubble p{white-space:pre-wrap;overflow-wrap:anywhere;margin:0}.message-time{color:#cbcbcb;margin:0;font-size:.65rem;line-height:1;position:absolute;top:calc(100% + 2px);left:6px}.message-time.mine{left:auto;right:6px}.logs{margin-top:16px}.logs pre{color:#ccc;background:#111;border:1px solid #333;border-radius:6px;max-height:220px;margin:8px 0 0;padding:10px;overflow:auto}.avatar-btn{cursor:pointer;background:0 0;border:1px solid #555;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;padding:0;display:flex;overflow:hidden}.avatar-btn img{object-fit:cover;border-radius:50%;width:100%;height:100%}.avatar-placeholder{font-size:1.2rem}.modal-overlay{z-index:1000;background:#000000b3;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-dialog{text-align:center;background:#111;border:1px solid #333;border-radius:8px;width:min(400px,90vw);padding:20px;position:relative;box-shadow:0 4px 12px #00000080}.modal-close-btn{color:#888;cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;width:24px;height:24px;padding:2px;font-size:1rem;line-height:1;transition:color .15s;display:flex;position:absolute;top:10px;right:12px}.modal-dialog h2{text-align:center;margin-top:0;margin-bottom:16px}.modal-dialog input[type=file]{width:100%;margin-bottom:16px}.modal-actions{justify-content:center;gap:8px;margin-top:16px;display:flex}.modal-actions button{width:auto;padding:6px 16px}.profile-avatar-preview{flex-direction:column;align-items:center;gap:8px;margin-bottom:20px;display:flex}.profile-avatar-preview img{object-fit:cover;border:2px solid #444;border-radius:50%;width:80px;height:80px}.profile-current-name{color:#ddd;text-align:center;margin:0;font-size:.95rem}.profile-current-username{color:#8f8f8f;text-align:center;margin:0;font-size:.82rem}.register-avatar-picker{cursor:pointer;flex-direction:column;align-items:center;gap:6px;margin-bottom:16px;display:flex}.register-avatar-picker img{object-fit:cover;border:2px solid #444;border-radius:50%;width:80px;height:80px;transition:border-color .15s}.register-avatar-picker:hover img{border-color:#888}.register-avatar-hint{color:#666;font-size:.78rem}.register-avatar-picker:hover .register-avatar-hint{color:#aaa}.profile-section{text-align:center;border-top:1px solid #2a2a2a;margin-bottom:14px;padding-top:14px}.profile-section h3{text-transform:uppercase;letter-spacing:.05em;color:#777;margin:0 0 10px;font-size:.85rem}.profile-text-input{color:#eee;box-sizing:border-box;text-align:center;background:#1a1a1a;border:1px solid #333;border-radius:5px;width:100%;margin-bottom:8px;padding:7px 10px;font-size:.9rem}.profile-text-input:focus{border-color:#555;outline:none}.profile-save-btn{color:#ddd;cursor:pointer;background:#2a2a2a;border:1px solid #444;border-radius:5px;width:100%;padding:7px 0;font-size:.85rem;transition:background .15s}.profile-save-btn:hover:not(:disabled){background:#333}.profile-save-btn:disabled{opacity:.45;cursor:not-allowed}@media (width<=960px){.split-grid,.chat-body{grid-template-columns:1fr}.room-item{flex-direction:column;align-items:flex-start}}@media (width<=640px){.app-shell:has(.chat-page){width:100%;max-width:100%;display:block;overflow:hidden}.chat-page{width:100%;max-width:100%;padding:0 0 calc(12px + env(safe-area-inset-bottom)) 0;overflow-x:clip}.chat-header{gap:8px;padding:8px 12px}.chat-header-logo{flex:none}.header-logo-img{height:28px}.actions{flex-wrap:nowrap;flex:1;justify-content:flex-end;gap:6px;min-width:0}.header-user-name{min-width:0;max-width:96px;font-size:.8rem}.avatar-btn{width:28px;height:28px}.conn-status{gap:6px;min-width:0}.logout-btn{white-space:nowrap;font-size:.8rem}.chat-body{flex-direction:column;width:100%;min-width:0;padding:0;display:flex}.chat-main{width:100%;min-width:0;padding:0 12px 12px}.chat-sidebar{width:100%;min-width:0;margin:0}.messages{scrollbar-gutter:auto;width:100%;min-width:0;height:60vh;min-height:60vh;max-height:80vh;padding:24px 8px 12px;overflow-x:hidden}.message-row{gap:12px;width:100%;margin-bottom:16px}.message-row.mine{padding-right:4px}.message-row:not(.mine){padding-left:4px}.message-bubble-stack{max-width:calc(100% - 64px)}.message-side{justify-content:center;align-items:center;width:44px;height:44px;display:flex}.bubble-avatar{width:36px;height:36px}.message-name,.message-name.long{white-space:nowrap;text-overflow:ellipsis;text-align:center;width:8ch;min-width:0;max-width:12ch;font-size:.8rem;line-height:1;display:block;position:absolute;bottom:calc(100% + 8px);left:50%;right:auto;overflow:hidden;transform:translate(-50%)}.message-side.mine .message-name.long{text-align:center;left:50%;right:auto;transform:translate(-50%)}.chat-input-row{flex-shrink:0;gap:6px;width:100%;margin-top:8px}.chat-input-row textarea{min-width:0}.chat-input-row button{flex:none;width:56px;min-width:56px;padding:2px 6px;font-size:.8rem}.bubble{max-width:min(100%,230px)}.bubble:before{width:12px;height:14px;left:-12px}.bubble:after{width:10px;height:12px;left:-10px}.bubble.mine:before{left:auto;right:-12px}.bubble.mine:after{left:auto;right:-10px}}
