.chat-page{--chat-bg: #e8f4fc;--chat-bubble-mine: #fff9c4;--chat-bubble-others: #fff;--chat-system-bg: #e0e0e0;--chat-system-bg-dark: #d2e4f0;--chat-line: var(--line, #d3dde4);--chat-accent: var(--brand, #62aa9e);font-family:inherit;height:100dvh;padding-top:41px;padding-bottom:77px;box-sizing:border-box;display:flex;flex-direction:column;background:var(--chat-bg);color:#1f2b2d}.chat-page--nickname{align-items:center;justify-content:center;padding:1rem}.chat-nickname-card{background:var(--chat-bubble-others);padding:2rem;border-radius:12px;box-shadow:0 2px 12px #00000014;width:100%;max-width:320px}.chat-nickname-title{margin:0 0 1.25rem;font-size:1.1rem;font-weight:600;text-align:center}.chat-nickname-leave-notice{margin:0 0 1rem;padding:.6rem .75rem;font-size:.9rem;color:#5c6d74;background:var(--chat-system-bg-dark);border-radius:8px;text-align:center}.chat-nickname-form{display:flex;flex-direction:column;gap:.75rem}.chat-nickname-input{padding:.6rem .75rem;border:1px solid var(--chat-line);border-radius:8px;font-size:1rem}.chat-nickname-submit{padding:.6rem 1rem;font-size:1rem;font-weight:500;color:#fff;background:var(--chat-accent);border:none;border-radius:8px;cursor:pointer}.chat-nickname-submit:hover:not(:disabled){filter:brightness(1.08)}.chat-nickname-submit:disabled{opacity:.6;cursor:not-allowed}.chat-change-nickname-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;display:flex;align-items:center;justify-content:center;padding:1rem;background:#00000059}.chat-change-nickname-card{background:var(--chat-bubble-others);padding:1.5rem;border-radius:12px;box-shadow:0 4px 20px #00000026;width:100%;max-width:300px}.chat-change-nickname-title{margin:0 0 1rem;font-size:1rem;font-weight:600;text-align:center}.chat-change-nickname-form{display:flex;flex-direction:column;gap:.75rem}.chat-change-nickname-form .chat-nickname-input{width:100%;box-sizing:border-box}.chat-change-nickname-buttons{display:flex;gap:.5rem;justify-content:flex-end}.chat-change-nickname-cancel{padding:.5rem .9rem;font-size:.9rem;color:#5c6d74;background:transparent;border:1px solid var(--chat-line);border-radius:8px;cursor:pointer}.chat-change-nickname-cancel:hover{background:#f0f6f8;color:#1f2b2d}.chat-change-nickname-buttons .chat-nickname-submit{padding:.5rem .9rem;font-size:.9rem}.chat-header{position:fixed;top:0;left:0;right:0;flex:0 0 auto;display:flex;align-items:center;justify-content:space-between;padding:.25rem .8rem;background:var(--chat-bubble-others);border-bottom:1px solid var(--chat-line)}.chat-header-title{margin:0;font-size:.95rem;font-weight:600}.chat-header-actions{flex-shrink:0;display:flex;align-items:center;gap:.25rem}.chat-header-nickname-btn{display:inline-flex;align-items:center;padding:.15rem .5rem;font-size:.8rem;color:#5c6d74;background:transparent;border:1px solid var(--chat-line);border-radius:6px;cursor:pointer}.chat-header-nickname-btn:hover{background:#f0f6f8;color:#1f2b2d}.chat-header-nickname-label{max-width:72px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-header-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;padding:0;font-size:1.1rem;color:#5c6d74;background:transparent;border:none;border-radius:8px;cursor:pointer}.chat-header-close:hover{background:#f0f6f8;color:#1f2b2d}.chat-body{flex:1;min-height:0;display:flex;flex-direction:column}.chat-participant-notice{flex-shrink:0;position:relative;padding:.2em 1rem;background:#bcd6e7;border-bottom:1px solid var(--chat-line);font-size:.85rem;color:#555}.chat-participant-trigger{display:flex;align-items:center;justify-content:center;gap:.35rem;width:100%;padding:.25rem 0;font-size:.85rem;color:inherit;background:transparent;border:none;border-radius:6px;cursor:pointer;transition:background .15s ease}.chat-participant-trigger:hover{background:#0000000f;color:#1f2b2d}.chat-participant-trigger:focus{outline:none;box-shadow:0 0 0 2px var(--chat-accent)}.chat-participant-trigger-text strong{color:#1f2b2d}.chat-participant-trigger-icon{font-size:.65rem;opacity:.8}.chat-participant-popup{position:absolute;top:100%;left:.5rem;right:.5rem;margin-top:.25rem;padding:0;background:var(--chat-bubble-others);border:1px solid var(--chat-line);border-radius:10px;box-shadow:0 4px 16px #0000001f;z-index:10;max-height:220px;display:flex;flex-direction:column}.chat-participant-popup-header{display:flex;align-items:center;justify-content:space-between;padding:.5rem .75rem;border-bottom:1px solid var(--chat-line);flex-shrink:0}.chat-participant-popup-title{font-size:.8rem;font-weight:600;color:#1f2b2d}.chat-participant-popup-close{width:28px;height:28px;padding:0;display:flex;align-items:center;justify-content:center;font-size:.9rem;color:#666;background:transparent;border:none;border-radius:6px;cursor:pointer}.chat-participant-popup-close:hover{background:#0000000f;color:#1f2b2d}.chat-participant-popup-list{margin:0;padding:.35rem 0;list-style:none;overflow-y:auto;flex:1;min-height:0}.chat-participant-popup-item{padding:.4rem 1rem;font-size:.9rem;color:#1f2b2d;border-bottom:1px solid transparent}.chat-participant-popup-item:last-child{border-bottom:none}.chat-messages{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:.75rem}.chat-messages-empty{margin:0;font-size:.9rem;color:var(--text-subtle, #5c6d74);text-align:center;padding:1.5rem}.chat-message{max-width:85%;display:flex;flex-direction:column;gap:.25rem}.chat-message-meta{display:flex;align-items:center;gap:.35rem;font-size:.75rem;color:var(--text-subtle, #5c6d74)}.chat-message-name{font-weight:600;color:#1f2b2d}.chat-message-time{font-size:.7rem;color:var(--text-subtle, #5c6d74)}.chat-message-body{width:fit-content;padding:.5rem .75rem;border-radius:10px;font-size:.9rem;line-height:1.4;word-break:break-word;white-space:pre-wrap}.chat-message-body-link{color:var(--chat-accent);text-decoration:underline;word-break:break-all;overflow-wrap:break-word}.chat-message-body-link:hover{text-decoration:underline;opacity:.9}.chat-message--system{align-self:center;max-width:90%}.chat-message-body--system{background:#d2e4f0;color:#343434;text-align:center;word-break:keep-all}.chat-message--mine{align-self:flex-end;align-items:flex-end}.chat-message--mine .chat-message-body{background:var(--chat-bubble-mine)}.chat-message--mine .chat-message-meta{flex-direction:row-reverse}.chat-message--others{align-self:flex-start}.chat-message--others .chat-message-body{background:var(--chat-bubble-others);box-shadow:0 1px 2px #0000000d}.chat-message-image-wrap{display:block;border-radius:8px;overflow:hidden;max-width:240px}.chat-message-image{display:block;max-width:100%;height:auto}.chat-input-wrap{position:fixed;left:0;right:0;bottom:0;padding:.75rem 1rem;background:var(--chat-bubble-others);border-top:1px solid var(--chat-line)}.chat-send-error{margin:0 0 .5rem;font-size:.8rem;color:var(--danger, #c62828)}.chat-input-row{display:flex;gap:.5rem;align-items:center}.chat-file-input{position:absolute;width:0;height:0;opacity:0;pointer-events:none}.chat-add-btn{flex-shrink:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;padding:0;font-size:1.5rem;line-height:1;color:#fff;background:#5c6d74;border:none;border-radius:50%;cursor:pointer}.chat-add-btn:hover:not(:disabled){filter:brightness(1.1)}.chat-add-btn:disabled{opacity:.6;cursor:not-allowed}.chat-input{flex:1;min-width:0;padding:.5rem .75rem;border:1px solid var(--chat-line);border-radius:10px;font-size:.9rem}.chat-input:focus{outline:none;border-color:var(--chat-accent)}textarea.chat-input{resize:none;min-height:auto;vertical-align:middle}.chat-send-btn{flex-shrink:0;padding:.5rem 1rem;font-size:.9rem;font-weight:500;color:#fff;background:var(--chat-accent);border:none;border-radius:10px;cursor:pointer}.chat-send-btn:hover:not(:disabled){filter:brightness(1.08)}.chat-send-btn:disabled{opacity:.6;cursor:not-allowed}
