.album-page{gap:22px;display:grid}.album-header{justify-content:space-between;align-items:center;gap:20px;display:flex}.album-header h2,.album-header p{margin:0}.album-header h2{color:#20283a;letter-spacing:0;font-size:24px}.album-header p{color:#818b9e;margin-top:7px;font-size:14px}.album-header-actions{align-items:center;gap:10px;display:flex}.album-upload-button,.album-manage-button{cursor:pointer;border-radius:6px;align-items:center;gap:8px;height:42px;padding:0 16px;font-size:14px;font-weight:700;display:flex}.album-upload-button{color:#fff;background:linear-gradient(135deg,#ff7ab6,#5b8cff);border:0;box-shadow:0 10px 22px #5b8cff38}.album-manage-button{color:#566178;background:#fff;border:1px solid #dfe5f1}.album-upload-button:hover{box-shadow:0 13px 26px #ff7ab640}.album-manage-button:hover{color:#5b6fd7;background:#f5f7ff;border-color:#cdd5f8}.album-upload-button:disabled{cursor:not-allowed;opacity:.6}.album-photo-input{display:none}.album-feedback{border-radius:7px;margin:0;padding:11px 14px;font-size:13px}.album-feedback--error{color:#bd4e5b;background:#fff3f5}.album-feedback--success{color:#47725e;background:#eef9f3}.album-empty{text-align:center;background:#fff;border:1px dashed #d7ddea;border-radius:8px;align-content:center;place-items:center;min-height:420px;padding:30px;display:grid}.album-empty-icon{color:#6577df;background:linear-gradient(135deg,#ff7ab624,#5b8cff26);border-radius:8px;place-items:center;width:64px;height:64px;margin-bottom:18px;display:grid}.album-empty h3{color:#30394d;letter-spacing:0;margin:0 0 8px;font-size:17px}.album-empty p{color:#929bad;margin:0;font-size:14px}.album-photo-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:18px;display:grid}.album-photo-card{background:#fff;border:1px solid #e5e9f2;border-radius:8px;min-width:0;overflow:hidden}.album-photo-meta{color:#8791a5;justify-content:space-between;align-items:center;gap:8px;min-width:0;padding:9px 11px;font-size:11px;display:flex}.album-photo-meta span{color:#616d83;text-overflow:ellipsis;white-space:nowrap;font-weight:700;overflow:hidden}.album-photo-meta time{white-space:nowrap;flex:none}.album-photo-card>button{aspect-ratio:4/3;cursor:zoom-in;background:#f2f4f8;border:0;width:100%;padding:0;display:block;overflow:hidden}.album-photo-card img{object-fit:cover;width:100%;height:100%;transition:transform .2s}.album-photo-card>button:hover img{transform:scale(1.025)}.album-pagination{color:#758096;justify-content:center;align-items:center;gap:12px;font-size:13px;display:flex}.album-pagination button{color:#5b6680;cursor:pointer;background:#fff;border:1px solid #dfe5f1;border-radius:6px;place-items:center;width:36px;height:36px;display:grid}.album-pagination button:disabled{cursor:not-allowed;opacity:.45}.album-preview-overlay,.album-dialog-overlay{z-index:100;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#151b28bd;place-items:center;padding:26px;display:grid;position:fixed;inset:0}.album-preview-overlay{z-index:120;cursor:zoom-out}.album-preview-close{color:#fff;cursor:pointer;background:#ffffff2e;border:0;border-radius:6px;place-items:center;width:42px;height:42px;display:grid;position:fixed;top:20px;right:22px}.album-preview-arrow{z-index:1;color:#fff;cursor:pointer;background:#ffffff2e;border:0;border-radius:50%;place-items:center;width:50px;height:50px;display:grid;position:fixed;top:50%;transform:translateY(-50%)}.album-preview-arrow:hover,.album-preview-close:hover{background:#ffffff4d}.album-preview-arrow--left{left:22px}.album-preview-arrow--right{right:22px}.album-preview-overlay>img{object-fit:contain;cursor:default;background:#fff;border-radius:8px;max-width:min(94vw,1280px);max-height:90vh;box-shadow:0 24px 70px #00000057}.album-management-dialog,.album-detail-dialog,.album-delete-dialog{background:#fff;border:1px solid #e1e6ef;border-radius:8px;box-shadow:0 24px 70px #0000003d}.album-management-dialog{grid-template-rows:auto auto minmax(0,1fr) auto;gap:16px;width:min(94vw,780px);max-height:88vh;padding:20px;display:grid}.album-management-dialog>header,.album-detail-dialog>header{justify-content:space-between;align-items:center;gap:14px;display:flex}.album-management-dialog h3,.album-detail-dialog h3,.album-delete-dialog h3{color:#293147;letter-spacing:0;margin:0;font-size:17px}.album-management-dialog header span{color:#929bad;margin-top:4px;font-size:12px;display:block}.album-management-dialog header button,.album-detail-dialog header button{color:#778299;cursor:pointer;background:0 0;border:0;border-radius:6px;place-items:center;width:36px;height:36px;display:grid}.album-management-list{overflow-y:auto}.album-management-toolbar{background:#f5f7fb;border-radius:7px;align-items:center;gap:10px;min-height:40px;padding:7px 9px;display:flex}.album-management-toolbar span{color:#788398;flex:1;font-size:12px}.album-management-toolbar button{color:#5b6680;cursor:pointer;background:#fff;border:1px solid #dfe5f1;border-radius:6px;justify-content:center;align-items:center;gap:6px;height:32px;padding:0 10px;font-weight:700;display:inline-flex}.album-management-toolbar .album-batch-delete-button{color:#c54f67;background:#fff7f8;border-color:#f0ccd4}.album-management-toolbar button:disabled{cursor:not-allowed;opacity:.45}.album-management-item{border-bottom:1px solid #edf0f5;grid-template-columns:26px 70px minmax(0,1fr) 36px 36px;align-items:center;gap:10px;min-width:0;padding:10px 0;display:grid}.album-management-checkbox{cursor:pointer;place-items:center;width:26px;height:36px;display:grid}.album-management-checkbox input{opacity:0;pointer-events:none;width:1px;height:1px;position:absolute}.album-management-checkbox span{background:#fff;border:1px solid #cbd3e2;border-radius:4px;width:17px;height:17px;display:block}.album-management-checkbox input:checked+span{background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m5 12 4 4L19 6'/%3E%3C/svg%3E") 50%/13px no-repeat,linear-gradient(135deg,#ff7ab6,#5b8cff);border-color:#6f82e8}.album-management-checkbox input:focus-visible+span{outline-offset:2px;outline:2px solid #9caaf2}.album-management-thumbnail{cursor:zoom-in;background:#f2f4f8;border:0;border-radius:6px;width:70px;height:54px;padding:0;overflow:hidden}.album-management-thumbnail img{object-fit:cover;width:100%;height:100%}.album-management-item>div{min-width:0}.album-management-item strong,.album-management-item time{text-overflow:ellipsis;white-space:nowrap;display:block;overflow:hidden}.album-management-item strong{color:#394257;font-size:13px}.album-management-item time{color:#929bad;margin-top:5px;font-size:11px}.album-management-item>button:not(.album-management-thumbnail){color:#778299;cursor:pointer;background:0 0;border:0;border-radius:6px;place-items:center;width:36px;height:36px;display:grid}.album-management-item>button:not(.album-management-thumbnail):hover{color:#5b6fd7;background:#f2f4fa}.album-dialog-state{color:#929bad;text-align:center;margin:60px 0}.album-detail-dialog{gap:16px;width:min(92vw,520px);padding:20px;display:grid}.album-detail-image{cursor:zoom-in;background:#f2f4f8;border:0;border-radius:7px;width:100%;max-height:300px;padding:0;overflow:hidden}.album-detail-image img{object-fit:contain;width:100%;max-height:300px;display:block}.album-detail-dialog dl{gap:10px;margin:0;display:grid}.album-detail-dialog dl div{grid-template-columns:90px minmax(0,1fr);gap:12px;display:grid}.album-detail-dialog dt{color:#8791a5;font-size:13px}.album-detail-dialog dd{overflow-wrap:anywhere;color:#394257;margin:0;font-size:13px}.album-detail-dialog footer,.album-delete-dialog footer{justify-content:flex-end;gap:10px;display:flex}.album-detail-dialog footer button,.album-delete-dialog footer button{color:#5b6680;cursor:pointer;background:#fff;border:1px solid #dfe5f1;border-radius:6px;justify-content:center;align-items:center;gap:6px;height:38px;padding:0 14px;font-weight:700;display:inline-flex}.album-detail-dialog footer button:last-child,.album-delete-dialog footer button:last-child{color:#fff;background:#d85a72;border-color:#d85a72}.album-delete-dialog{width:min(90vw,410px);padding:22px}.album-delete-dialog p{color:#667188;margin:12px 0 22px;line-height:1.65}.album-delete-dialog button:disabled{cursor:not-allowed;opacity:.55}@media (width<=620px){.album-header{flex-direction:column;align-items:stretch}.album-header-actions{grid-template-columns:1fr 1fr;display:grid}.album-upload-button,.album-manage-button{justify-content:center}.album-empty{min-height:340px}.album-photo-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.album-photo-meta{flex-direction:column;align-items:flex-start}.album-management-item{grid-template-columns:24px 58px minmax(0,1fr) 34px 34px;gap:7px}.album-management-toolbar{flex-wrap:wrap;align-items:stretch}.album-management-toolbar span{align-items:center;min-width:90px;display:flex}.album-management-thumbnail{width:58px;height:48px}.album-detail-dialog dl div{grid-template-columns:1fr;gap:3px}.album-preview-arrow{width:42px;height:42px}.album-preview-arrow--left{left:8px}.album-preview-arrow--right{right:8px}}.admin-users-page{gap:22px;display:grid}.admin-users-header{justify-content:space-between;align-items:center;gap:18px;display:flex}.admin-users-header h2,.admin-users-header p{margin:0}.admin-users-header h2{color:#20283a;letter-spacing:0;font-size:24px}.admin-users-header p{color:#8993a5;margin-top:7px;font-size:13px}.admin-users-header-actions{align-items:center;gap:9px;display:flex}.admin-users-count{color:#657086;background:#fff;border:1px solid #e2e7f0;border-radius:6px;align-items:center;gap:7px;min-height:38px;padding:0 13px;font-size:13px;font-weight:700;display:flex}.admin-feedback{border-radius:7px;margin:0;padding:11px 14px;font-size:13px}.admin-feedback--error{color:#bd4e5b;background:#fff3f5}.admin-feedback--success{color:#47725e;background:#eef9f3}.admin-users-state{color:#7f899c;background:#fff;border:1px dashed #d7ddea;border-radius:8px;align-content:center;place-items:center;gap:12px;min-height:360px;display:grid}.admin-users-state p{margin:0}.admin-loading-icon{animation:1s linear infinite admin-spin}.admin-user-list{background:#fff;border:1px solid #e3e8f1;border-radius:8px;overflow:hidden}.admin-user-row{border-bottom:1px solid #edf0f5;grid-template-columns:46px minmax(130px,1.2fr) minmax(180px,1.4fr) auto auto auto;align-items:center;gap:14px;min-width:0;padding:13px 16px;display:grid}.admin-user-row:last-child{border-bottom:0}.admin-user-row>img{object-fit:cover;border:2px solid #edf0f7;border-radius:50%;width:42px;height:42px}.admin-user-primary,.admin-user-meta{gap:4px;min-width:0;display:grid}.admin-user-primary strong,.admin-user-primary span,.admin-user-meta span,.admin-user-meta time{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.admin-users-header-actions>button{color:#fff;cursor:pointer;white-space:nowrap;background:linear-gradient(135deg,#ff7ab6,#5b8cff);border:0;border-radius:6px;justify-content:center;align-items:center;gap:7px;min-height:38px;padding:0 13px;font-weight:700;display:inline-flex}.admin-user-primary strong{color:#30394d;font-size:13px}.admin-user-primary span,.admin-user-meta{color:#8b95a8;font-size:11px}.admin-role-badge,.admin-status{white-space:nowrap;border-radius:5px;padding:5px 8px;font-size:11px;font-weight:700}.admin-role-badge{color:#687287;background:#f0f2f6;align-items:center;gap:4px;display:inline-flex}.admin-role-badge--administrator{color:#5268d5;background:#edf0ff}.admin-status{color:#47725e;background:#eef9f3}.admin-status--disabled{color:#b64f5e;background:#fff0f2}.admin-user-row>button{color:#59657b;cursor:pointer;background:#fff;border:1px solid #dfe5f1;border-radius:6px;justify-content:center;align-items:center;gap:6px;height:36px;padding:0 12px;font-weight:700;display:inline-flex}.admin-user-row>button:hover{color:#5367d9;background:#f5f7ff;border-color:#ccd5ed}.admin-pagination{color:#788296;justify-content:center;align-items:center;gap:13px;font-size:13px;display:flex}.admin-pagination button{color:#59657b;cursor:pointer;background:#fff;border:1px solid #e2e7f0;border-radius:6px;place-items:center;width:38px;height:38px;display:grid}.admin-pagination button:disabled{cursor:not-allowed;opacity:.45}.admin-dialog-overlay{z-index:100;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#151b28bd;place-items:center;padding:22px;display:grid;position:fixed;inset:0}.admin-user-editor{background:#fff;border:1px solid #e1e6ef;border-radius:8px;flex-direction:column;width:min(96vw,980px);max-height:92vh;display:flex;overflow:hidden;box-shadow:0 24px 70px #0000003d}.admin-user-editor>header,.admin-user-editor-actions{flex:none;justify-content:space-between;align-items:center;gap:12px;display:flex}.admin-user-editor>header{padding:20px 20px 14px}.admin-user-editor>.admin-feedback{flex:none;margin:0 20px 14px}.admin-user-editor>header h3{color:#293147;letter-spacing:0;margin:0;font-size:17px}.admin-user-editor>header span{color:#929bad;margin-top:4px;font-size:11px;display:block}.admin-user-editor>header button{color:#778299;cursor:pointer;background:0 0;border:0;border-radius:6px;place-items:center;width:36px;height:36px;display:grid}.admin-editor-body{flex:auto;grid-template-columns:180px minmax(0,1fr);gap:20px;min-height:0;padding:0 20px 18px;display:grid;overflow-y:auto}.admin-editor-profile{border-right:1px solid #edf0f5;flex-direction:column;align-items:center;gap:8px;padding:8px 20px 8px 0;display:flex}.admin-editor-profile img{object-fit:cover;border:3px solid #edf0f7;border-radius:50%;width:104px;height:104px}.admin-editor-profile strong{overflow-wrap:anywhere;color:#30394d;text-align:center;font-size:14px}.admin-editor-profile span{color:#8b95a8;font-size:12px}.admin-editor-profile button,.admin-reset-password-button{color:#59657b;cursor:pointer;background:#fff;border:1px solid #dfe5f1;border-radius:6px;justify-content:center;align-items:center;gap:6px;height:36px;padding:0 12px;font-weight:700;display:inline-flex}.admin-editor-profile input{display:none}.admin-editor-content{gap:16px;display:grid}.admin-editor-section{border-bottom:1px solid #edf0f5;gap:12px;padding-bottom:16px;display:grid}.admin-editor-section:last-child{border-bottom:0}.admin-editor-section h4{color:#354057;letter-spacing:0;margin:0;font-size:14px}.admin-editor-section>label,.admin-password-fields label{color:#677288;gap:7px;font-size:12px;font-weight:700;display:grid}.admin-editor-section input[type=text],.admin-editor-section input[type=password],.admin-editor-section textarea{color:#354057;width:100%;font:inherit;resize:vertical;background:#fff;border:1px solid #dfe5f1;border-radius:6px;outline:none;padding:10px 11px}.admin-editor-section input:focus,.admin-editor-section textarea:focus{border-color:#9aa9ef;box-shadow:0 0 0 3px #5b8cff1a}.admin-section-heading{justify-content:space-between;align-items:center;gap:10px;display:flex}.admin-section-heading span{color:#8a94a7;font-size:11px}.admin-permission-list{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;display:grid}.admin-setting-row{background:#fafbfc;border:1px solid #e8ebf2;border-radius:7px;justify-content:space-between;align-items:center;gap:12px;min-width:0;min-height:58px;padding:10px 11px;display:flex}.admin-setting-row>div{gap:4px;min-width:0;display:grid}.admin-setting-row strong{color:#414b60;font-size:12px}.admin-setting-row>div>span{color:#9099aa;font-size:10px;line-height:1.45}.admin-switch{cursor:pointer;flex:0 0 40px;width:40px;height:22px;display:block;position:relative}.admin-switch input{opacity:0;width:1px;height:1px;position:absolute}.admin-switch span{background:#cbd2df;border-radius:11px;transition:background .2s;position:absolute;inset:0}.admin-switch span:after{content:"";background:#fff;border-radius:50%;width:16px;height:16px;transition:transform .2s;position:absolute;top:3px;left:3px;box-shadow:0 1px 4px #25304633}.admin-switch input:checked+span{background:linear-gradient(135deg,#ff7ab6,#5b8cff)}.admin-switch input:checked+span:after{transform:translate(18px)}.admin-switch input:disabled+span{cursor:not-allowed;opacity:.48}.admin-password-fields{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.admin-reset-password-button{color:#b34d60;background:#fff7f8;border-color:#efccd3;justify-self:start}.admin-user-editor-actions{background:#fff;border-top:1px solid #edf0f5;justify-content:flex-end;padding:20px 20px 22px}.admin-user-editor-actions button{color:#5b6680;cursor:pointer;background:#fff;border:1px solid #dfe5f1;border-radius:6px;height:38px;padding:0 15px;font-weight:700}.admin-user-editor-actions button:last-child{color:#fff;background:linear-gradient(135deg,#ff7ab6,#5b8cff);border-color:#0000}.admin-user-editor button:disabled{cursor:not-allowed;opacity:.55}.admin-editor-state{color:#8791a5;text-align:center;flex:auto;margin:0;padding:70px 20px}.admin-create-user-dialog{background:#fff;border:1px solid #e1e6ef;border-radius:8px;gap:16px;width:min(92vw,520px);padding:20px;display:grid;box-shadow:0 24px 70px #0000003d}.admin-create-user-dialog>header,.admin-create-user-dialog>footer{justify-content:space-between;align-items:center;gap:12px;display:flex}.admin-create-user-dialog>header h3{color:#293147;letter-spacing:0;margin:0;font-size:17px}.admin-create-user-dialog>header span{color:#929bad;margin-top:4px;font-size:11px;display:block}.admin-create-user-dialog>header button{color:#778299;cursor:pointer;background:0 0;border:0;border-radius:6px;place-items:center;width:36px;height:36px;display:grid}.admin-create-user-fields{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.admin-create-user-fields label{color:#677288;gap:7px;font-size:12px;font-weight:700;display:grid}.admin-create-user-fields input{color:#354057;width:100%;font:inherit;background:#fff;border:1px solid #dfe5f1;border-radius:6px;outline:none;padding:10px 11px}.admin-create-user-fields input:focus{border-color:#9aa9ef;box-shadow:0 0 0 3px #5b8cff1a}.admin-create-user-dialog>footer{border-top:1px solid #edf0f5;justify-content:flex-end;padding-top:14px}.admin-create-user-dialog>footer button{color:#5b6680;cursor:pointer;background:#fff;border:1px solid #dfe5f1;border-radius:6px;justify-content:center;align-items:center;gap:6px;height:38px;padding:0 15px;font-weight:700;display:inline-flex}.admin-create-user-dialog>footer button:last-child{color:#fff;background:linear-gradient(135deg,#ff7ab6,#5b8cff);border-color:#0000}.admin-create-user-dialog button:disabled{cursor:not-allowed;opacity:.55}@keyframes admin-spin{to{transform:rotate(360deg)}}@media (width<=900px){.admin-user-row{grid-template-columns:46px minmax(120px,1fr) auto auto}.admin-user-meta,.admin-role-badge{display:none}.admin-permission-list{grid-template-columns:1fr}}@media (width<=680px){.admin-users-header{flex-direction:column;align-items:flex-start}.admin-users-header-actions{width:100%}.admin-users-header-actions>button{flex:1}.admin-user-row{grid-template-columns:42px minmax(0,1fr) auto;gap:9px;padding:11px}.admin-status{display:none}.admin-user-row>button{width:36px;padding:0;font-size:0}.admin-dialog-overlay{padding:8px}.admin-user-editor{max-height:96vh}.admin-editor-body{grid-template-columns:1fr;padding:0 14px 14px}.admin-user-editor>header{padding:14px 14px 12px}.admin-user-editor>.admin-feedback{margin:0 14px 12px}.admin-user-editor-actions{padding:16px 14px 18px}.admin-editor-profile{border-bottom:1px solid #edf0f5;border-right:0;padding:4px 0 16px}.admin-password-fields,.admin-create-user-fields{grid-template-columns:1fr}}.chat-page{background:#fff;border:1px solid #e5e9f2;border-radius:8px;grid-template-rows:auto minmax(0,1fr) auto auto;grid-template-areas:"toolbar""messages""error""composer";width:100%;height:100%;min-height:0;display:grid;position:relative;overflow:hidden}.chat-scroll-actions{z-index:15;gap:8px;display:grid;position:absolute;bottom:172px;left:50%;transform:translate(-50%)}.chat-scroll-actions button{color:#fff;cursor:pointer;background:linear-gradient(135deg,#f36fa8,#6489ef);border:1px solid #0000;border-radius:50%;place-items:center;width:42px;height:42px;display:grid;box-shadow:0 8px 22px #5b70d23d}.chat-scroll-actions button:hover{color:#fff;background:linear-gradient(135deg,#e95d9b,#557ae0)}.chat-toolbar{border-bottom:1px solid #edf0f5;grid-area:toolbar;justify-content:center;padding:8px;display:flex}.chat-history-button{color:#667188;cursor:pointer;background:#fff;border:1px solid #e2e7f0;border-radius:6px;align-items:center;gap:6px;height:36px;padding:0 12px;font-size:13px;font-weight:650;display:flex}.chat-message-list{background:#f8f9fc;grid-area:messages;min-height:0;padding:22px;overflow-y:auto}.chat-message-list--positioning{visibility:hidden}.chat-message{align-items:flex-start;gap:11px;width:fit-content;max-width:760px;margin-bottom:18px;display:flex}.chat-message--own{flex-direction:row-reverse;margin-left:auto}.chat-message--first-unread{position:relative}.chat-message--first-unread:before{content:"";background:linear-gradient(90deg,#0000,#f06a86,#0000);height:1px;position:absolute;top:-10px;left:0;right:0}.chat-message-avatar{object-fit:cover;border:2px solid #fff;border-radius:50%;flex:0 0 38px;width:38px;height:38px}.chat-message-body{flex-direction:column;align-items:flex-start;min-width:0;max-width:calc(100% - 49px);display:flex;position:relative}.chat-message-meta{align-items:center;gap:9px;margin-bottom:6px;display:flex}.chat-message--own .chat-message-meta{justify-content:flex-end}.chat-message--own .chat-message-body{align-items:flex-end}.chat-message-meta strong{color:#465066;font-size:13px}.chat-message-meta time{color:#9aa3b4;white-space:nowrap;font-size:11px}.chat-message-content,.chat-recalled{overflow-wrap:anywhere;color:#394257;white-space:pre-wrap;background:#fff;border:1px solid #e5e9f2;border-radius:7px;width:fit-content;max-width:100%;margin:0;padding:10px 13px;font-size:14px;line-height:1.65;display:inline-block}.chat-message-content{font-size:16px}.chat-message--own .chat-message-content{color:#fff;background:linear-gradient(135deg,#ff7ab6,#668cff);border-color:#0000}.chat-message-image-button{cursor:zoom-in;touch-action:manipulation;-webkit-touch-callout:none;background:0 0;border:0;margin:0 0 8px;padding:0;display:block}.chat-message-image{object-fit:contain;-webkit-user-select:none;user-select:none;-webkit-user-drag:none;background:#fff;border:1px solid #e5e9f2;border-radius:7px;width:min(360px,62vw);max-height:360px;display:block}.chat-message-image-button:hover .chat-message-image{border-color:#92a1ff;box-shadow:0 10px 28px #48568624}.chat-message-sticker-button{cursor:pointer;touch-action:manipulation;-webkit-touch-callout:none;background:0 0;border:0;margin:0;padding:0;display:block}.chat-message-sticker{object-fit:contain;-webkit-user-select:none;user-select:none;-webkit-user-drag:none;width:min(180px,42vw);max-height:180px;display:block}.chat-message-sticker-button:hover .chat-message-sticker{filter:drop-shadow(0 8px 14px #4856862e)}.chat-recalled{color:#929bad;font-style:italic}.chat-recall-button{color:#8a94a7;cursor:pointer;background:0 0;border:0;align-items:center;gap:4px;margin:5px 0 0 auto;padding:2px 0;font-size:11px;display:flex}.chat-error{color:#bd4e5b;background:#fff6f7;border-top:1px solid #f2dadd;grid-area:error;margin:0;padding:8px 18px;font-size:13px}.chat-composer{border-top:1px solid #edf0f5;grid-area:composer;grid-template-columns:minmax(0,1fr) auto;gap:12px;padding:16px;display:grid}.chat-composer-main{min-width:0;position:relative}.chat-composer-tools{align-items:center;gap:4px;margin-bottom:7px;display:flex}.chat-composer-tools>button,.chat-emoji-control>button,.chat-sticker-control>button{color:#69758b;cursor:pointer;background:0 0;border:0;border-radius:6px;place-items:center;width:34px;min-width:34px;height:34px;padding:0;display:grid}.chat-composer-tools>button:hover,.chat-emoji-control>button:hover,.chat-sticker-control>button:hover{color:#5b6fd7;background:#f0f3fa}.chat-emoji-control,.chat-sticker-control{position:relative}.chat-emoji-picker{z-index:20;background:#fff;border:1px solid #e1e6ef;border-radius:8px;grid-template-columns:repeat(5,1fr);gap:4px;width:248px;padding:10px;display:grid;position:absolute;bottom:42px;left:0;box-shadow:0 14px 34px #2d3c5b29}.chat-emoji-picker button{cursor:pointer;background:0 0;border:0;border-radius:6px;place-items:center;width:40px;min-width:40px;height:40px;padding:0;font-size:21px;display:grid}.chat-emoji-picker button:hover{background:#f2f4fa}.chat-sticker-picker{z-index:20;background:#fff;border:1px solid #e1e6ef;border-radius:8px;width:min(360px,100vw - 36px);padding:10px;position:absolute;bottom:42px;left:0;box-shadow:0 14px 34px #2d3c5b29}.chat-sticker-tabs{border-bottom:1px solid #edf0f5;grid-template-columns:1fr 1fr 42px;gap:4px;padding-bottom:8px;display:grid}.chat-sticker-tabs button{color:#778299;cursor:pointer;background:0 0;border:0;border-radius:6px;justify-content:center;align-items:center;gap:4px;min-width:0;padding:7px 8px;font-size:12px;display:flex}.chat-sticker-tabs button.active,.chat-sticker-tabs button:hover{color:#5b6fd7;background:#f0f3fa}.chat-sticker-tabs span{color:#9aa3b4;font-size:10px}.chat-sticker-grid{grid-template-columns:repeat(4,1fr);gap:6px;max-height:260px;padding-top:10px;display:grid;overflow-y:auto}.chat-sticker-item{aspect-ratio:1;min-width:0;position:relative}.chat-sticker-select-button{aspect-ratio:1;cursor:pointer;background:0 0;border:0;border-radius:7px;place-items:center;width:100%;height:100%;padding:5px;display:grid}.chat-sticker-select-button:hover{background:#f2f4fa}.chat-sticker-select-button img{object-fit:contain;width:100%;height:100%}.chat-sticker-delete-button{color:#fff;cursor:pointer;opacity:0;background:#2a3141b8;border:0;border-radius:50%;place-items:center;width:25px;height:25px;transition:opacity .15s,background .15s;display:grid;position:absolute;top:2px;right:2px}.chat-sticker-item:hover .chat-sticker-delete-button,.chat-sticker-delete-button:focus-visible{opacity:1}.chat-sticker-delete-button:hover{background:#d94f6d}.chat-sticker-picker-state{color:#929bad;text-align:center;grid-column:1/-1;margin:24px 0;font-size:12px}.chat-sticker-mobile-hint,.chat-image-input{display:none}.chat-selected-image{background:#fbfcff;border:1px solid #dfe5f1;border-radius:7px;grid-template-columns:58px minmax(0,1fr) 34px;align-items:center;gap:10px;margin-bottom:10px;padding:8px;display:grid}.chat-selected-image img{object-fit:cover;border-radius:6px;width:58px;height:58px}.chat-selected-image div{min-width:0}.chat-selected-image strong,.chat-selected-image span{text-overflow:ellipsis;white-space:nowrap;display:block;overflow:hidden}.chat-selected-image strong{color:#394257;font-size:13px}.chat-selected-image span{color:#8993a7;margin-top:3px;font-size:12px}.chat-selected-image button{color:#778299;cursor:pointer;background:0 0;border:0;border-radius:6px;place-items:center;width:34px;height:34px;display:grid}.chat-selected-image button:hover{color:#d64f73;background:#fff0f5}.chat-selected-sticker{background:#fbfcff;border:1px solid #dfe5f1;border-radius:7px;grid-template-columns:72px minmax(0,1fr) 34px;align-items:center;gap:10px;margin-bottom:10px;padding:8px;display:grid}.chat-selected-sticker img{object-fit:contain;width:72px;height:72px}.chat-selected-sticker strong,.chat-selected-sticker span{display:block}.chat-selected-sticker strong{color:#394257;font-size:13px}.chat-selected-sticker span{color:#8993a7;margin-top:3px;font-size:12px}.chat-selected-sticker button{color:#778299;cursor:pointer;background:0 0;border:0;border-radius:6px;place-items:center;width:34px;height:34px;display:grid}.chat-selected-sticker button:hover{color:#d64f73;background:#fff0f5}.chat-sticker-notice{z-index:120;color:#fff;background:#30394deb;border-radius:7px;margin:0;padding:9px 14px;font-size:13px;position:fixed;bottom:24px;left:50%;transform:translate(-50%);box-shadow:0 8px 26px #232b3c33}.chat-media-action-menu{z-index:130;background:#fff;border:1px solid #dfe5f0;border-radius:7px;min-width:150px;padding:5px;position:fixed;box-shadow:0 12px 30px #2d3c5b33}.chat-media-action-menu button{color:#4d5870;cursor:pointer;white-space:nowrap;background:0 0;border:0;border-radius:5px;align-items:center;gap:7px;width:100%;padding:8px 10px;font-size:13px;display:flex}.chat-media-action-menu button:hover{color:#5b6fd7;background:#f0f3fa}.chat-composer textarea{resize:none;color:#30394d;background:#fbfcfe;border:1px solid #dce2ed;border-radius:7px;outline:none;width:100%;padding:10px 12px;line-height:1.5}.chat-composer textarea:focus{border-color:#7b8cff;box-shadow:0 0 0 3px #7b8cff21}.chat-send-button{color:#fff;cursor:pointer;background:linear-gradient(135deg,#ff7ab6,#5b8cff);border:0;border-radius:6px;justify-content:center;align-self:end;align-items:center;gap:7px;min-width:94px;height:42px;font-weight:700;display:flex}.chat-send-button:disabled{cursor:not-allowed;opacity:.55}.chat-state{color:#929bad;text-align:center;margin:80px 0;font-size:14px}.chat-image-preview-overlay{z-index:100;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);cursor:zoom-out;background:#151b28bd;place-items:center;padding:28px;display:grid;position:fixed;inset:0}.chat-image-preview-overlay img{object-fit:contain;cursor:default;background:#fff;border-radius:8px;max-width:min(92vw,1120px);max-height:88vh;box-shadow:0 24px 70px #00000052}.chat-image-preview-close{color:#fff;cursor:pointer;background:#ffffff2e;border:0;border-radius:6px;place-items:center;width:42px;height:42px;display:grid;position:fixed;top:20px;right:22px}.chat-image-preview-close:hover{background:#ffffff47}@media (width<=640px){.chat-page{height:100%;min-height:0}.chat-message-list{padding:16px}.chat-composer{grid-template-columns:1fr}.chat-send-button{width:100%}.chat-scroll-actions{bottom:218px;left:50%}.chat-sticker-delete-button{opacity:1}.chat-sticker-mobile-hint{color:#8a94a7;border-top:1px solid #edf0f5;margin:8px 2px 0;padding-top:8px;font-size:11px;line-height:1.5;display:block}}.hall-page{gap:24px;display:grid}.hall-header{justify-content:space-between;align-items:center;gap:20px;display:flex}.hall-header h2{color:#20283a;letter-spacing:0;margin:0;font-size:24px}.hall-count{color:#657086;white-space:nowrap;background:#fff;border:1px solid #e2e7f0;border-radius:6px;align-items:center;gap:7px;min-height:38px;padding:0 13px;font-size:13px;font-weight:700;display:flex}.hall-user-grid{grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:16px;display:grid}.hall-user-card{cursor:pointer;background:#fff;border:1px solid #e5e9f2;border-radius:8px;align-items:center;gap:14px;min-width:0;min-height:112px;padding:18px;transition:border-color .2s,box-shadow .2s,transform .2s;display:flex}.hall-user-card:hover{border-color:#ccd5ed;transform:translateY(-2px);box-shadow:0 12px 28px #37496f1a}.hall-user-card:focus-visible{outline-offset:3px;outline:2px solid #8494ea}.hall-avatar-button{cursor:zoom-in;background:#eef1f7;border:0;border-radius:50%;flex:0 0 62px;width:62px;height:62px;padding:0;position:relative;overflow:hidden}.hall-user-avatar{object-fit:cover;border:2px solid #edf0f7;border-radius:50%;width:100%;height:100%;display:block}.hall-avatar-button span{color:#fff;opacity:0;background:#222a3d8c;place-items:center;transition:opacity .2s;display:grid;position:absolute;inset:0}.hall-avatar-button:hover span,.hall-avatar-button:focus-visible span{opacity:1}.hall-user-copy{min-width:0}.hall-user-heading{align-items:center;gap:8px;min-width:0;margin-bottom:7px;display:flex}.hall-user-copy h3{color:#293147;letter-spacing:0;text-overflow:ellipsis;white-space:nowrap;min-width:0;margin:0;font-size:15px;overflow:hidden}.hall-presence{color:#8993a5;white-space:nowrap;flex:none;align-items:center;gap:5px;font-size:11px;font-weight:700;display:inline-flex}.hall-presence:before{content:"";background:#b8bfcc;border-radius:50%;width:7px;height:7px}.hall-presence--online{color:#438267}.hall-presence--online:before{background:#48b785;box-shadow:0 0 0 3px #48b78524}.hall-user-copy p{color:#8993a5;-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0;font-size:13px;line-height:1.55;display:-webkit-box;overflow:hidden}.hall-state{color:#7f899c;text-align:center;background:#fff;border:1px dashed #d7ddea;border-radius:8px;align-content:center;place-items:center;gap:12px;min-height:360px;padding:28px;display:grid}.hall-state p{margin:0;font-size:14px}.hall-state button{color:#fff;cursor:pointer;background:linear-gradient(135deg,#ff7ab6,#5b8cff);border:0;border-radius:6px;height:38px;padding:0 16px;font-weight:700}.hall-state--error{color:#b84a58}.hall-loading-icon{animation:1s linear infinite hall-spin}.hall-pagination{color:#788296;justify-content:center;align-items:center;gap:14px;font-size:13px;font-weight:650;display:flex}.hall-pagination button{color:#59657b;cursor:pointer;background:#fff;border:1px solid #e2e7f0;border-radius:6px;place-items:center;width:38px;height:38px;display:grid}.hall-pagination button:disabled{cursor:not-allowed;opacity:.45}.hall-dialog-overlay,.hall-avatar-preview{z-index:100;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#151b28bd;place-items:center;padding:24px;display:grid;position:fixed;inset:0}.hall-user-detail{background:#fff;border:1px solid #e1e6ef;border-radius:8px;gap:18px;width:min(92vw,510px);padding:20px;display:grid;box-shadow:0 24px 70px #0000003d}.hall-user-detail>header{justify-content:space-between;align-items:center;gap:12px;display:flex}.hall-user-detail>header h3,.hall-detail-heading h4{color:#293147;letter-spacing:0;margin:0}.hall-user-detail>header h3{font-size:17px}.hall-user-detail>header button{color:#778299;cursor:pointer;background:0 0;border:0;border-radius:6px;place-items:center;width:36px;height:36px;display:grid}.hall-detail-avatar-button{cursor:zoom-in;background:#f2f4f8;border:3px solid #edf0f7;border-radius:50%;justify-self:center;width:112px;height:112px;padding:0;position:relative;overflow:hidden}.hall-detail-avatar-button img{object-fit:cover;width:100%;height:100%;display:block}.hall-detail-avatar-button span{color:#fff;opacity:0;background:#222a3d94;justify-content:center;align-items:center;gap:5px;font-size:12px;font-weight:700;transition:opacity .2s;display:flex;position:absolute;inset:0}.hall-detail-avatar-button:hover span,.hall-detail-avatar-button:focus-visible span{opacity:1}.hall-detail-heading{justify-content:center;align-items:center;gap:9px;display:flex}.hall-detail-heading h4{overflow-wrap:anywhere;text-align:center;font-size:19px}.hall-detail-heading span{color:#5a70d9;background:#eef1ff;border-radius:5px;padding:3px 7px;font-size:11px;font-weight:700}.hall-detail-heading .hall-presence{color:#8993a5;background:0 0}.hall-detail-heading .hall-presence--online{color:#438267}.hall-user-detail dl{gap:3px;margin:0;display:grid}.hall-user-detail dl div{border-bottom:1px solid #edf0f5;grid-template-columns:110px minmax(0,1fr);gap:12px;padding:13px 4px;display:grid}.hall-user-detail dt{color:#8791a5;align-items:flex-start;gap:7px;font-size:13px;display:flex}.hall-user-detail dd{overflow-wrap:anywhere;color:#394257;margin:0;font-size:13px;line-height:1.55}.hall-detail-state{color:#8791a5;text-align:center;margin:55px 0;font-size:13px}.hall-detail-state--error{color:#b84a58}.hall-avatar-preview{z-index:120;cursor:zoom-out;align-content:center;gap:16px}.hall-avatar-preview>button{color:#fff;cursor:pointer;background:#ffffff2e;border:0;border-radius:6px;place-items:center;width:42px;height:42px;display:grid;position:fixed;top:20px;right:22px}.hall-avatar-preview>img{object-fit:cover;object-position:center;cursor:default;background:#eef1f7;border-radius:50%;width:min(78vw,520px);max-width:70vh;height:min(78vw,520px);max-height:70vh;box-shadow:0 24px 70px #00000057}.hall-avatar-preview>strong{overflow-wrap:anywhere;color:#fff;text-align:center;max-width:min(80vw,520px);font-size:15px}@keyframes hall-spin{to{transform:rotate(360deg)}}@media (width<=560px){.hall-header{flex-direction:column;align-items:flex-start}.hall-user-grid{grid-template-columns:1fr}.hall-user-detail dl div{grid-template-columns:1fr;gap:5px}}.login-page{background:radial-gradient(circle at 0 0,#ff7dc53d,#0000 34%),linear-gradient(135deg,#ff7eb333,#5397ff2e),#f7f9ff;place-items:center;min-height:100vh;padding:32px;display:grid}.login-container{width:min(100%,720px)}.login-card{background:#fffffff5;border:1px solid #e4e8f4;border-radius:8px;width:min(100%,420px);margin:0 auto;padding:38px;box-shadow:0 24px 60px #3e5cad24}.login-morse{color:#6c7bea;letter-spacing:0;text-align:center;white-space:nowrap;scrollbar-width:none;min-height:48px;margin:0 0 16px;font-family:Consolas,Courier New,monospace;font-size:22px;font-weight:800;line-height:1.5;overflow:auto hidden}.login-morse span{color:#0000;background:linear-gradient(90deg,#ff6faf,#668cff);-webkit-background-clip:text;background-clip:text;display:inline-block}.login-morse::-webkit-scrollbar{display:none}.login-field{color:#29364a;gap:10px;margin-bottom:20px;font-size:14px;font-weight:700;display:grid}.login-field input{color:#172033;background:#f9fbfd;border:1px solid #d9e2ec;border-radius:8px;outline:none;width:100%;height:50px;padding:0 15px;transition:border-color .2s,box-shadow .2s,background .2s}.login-field input:focus{background:#fff;border-color:#7b8cff;box-shadow:0 0 0 4px #7b8cff29}.login-field input[type=password]::-ms-reveal{display:none}.login-field input[type=password]::-ms-clear{display:none}.password-field{position:relative}.password-field input{padding-right:76px}.password-toggle{color:#5b6ff0;cursor:pointer;background:0 0;border:0;border-radius:8px;min-width:52px;height:34px;position:absolute;top:50%;right:8px;transform:translateY(-50%)}.password-toggle:hover{background:#7b8cff1f}.login-submit{color:#fff;cursor:pointer;background:linear-gradient(135deg,#ff7ab6,#5b8cff);border:0;border-radius:8px;width:100%;height:52px;font-size:16px;font-weight:800;transition:opacity .2s,transform .2s,box-shadow .2s;position:relative;top:6px;box-shadow:0 14px 28px #5b8cff47}.login-submit:hover{transform:translateY(-1px);box-shadow:0 18px 34px #ff7ab647}.login-submit:disabled{cursor:wait;opacity:.65;transform:none}.login-error{color:#d14343;text-align:center;margin:0 0 8px;font-size:14px;line-height:1.5}@media (width<=560px){.login-page{padding:20px}.login-card{padding:28px 22px}}.app-sidebar{z-index:40;background:#fff;border-right:1px solid #e4e8f1;flex-direction:column;width:248px;height:100vh;padding:16px 12px;transition:width .22s,transform .22s;display:flex;position:fixed;box-shadow:8px 0 24px #2a38560a}.app-sidebar--collapsed{width:76px}.sidebar-header{justify-content:space-between;align-items:center;min-height:48px;padding:0 4px;display:flex}.sidebar-brand{align-items:center;gap:11px;min-width:0;display:flex}.sidebar-brand-mark{color:#fff;background:linear-gradient(135deg,#ff7ab6,#5b8cff);border-radius:7px;flex:0 0 38px;place-items:center;width:38px;height:38px;font-size:17px;font-weight:800;display:grid}.sidebar-brand-name{color:#20283a;text-overflow:ellipsis;white-space:nowrap;font-size:15px;font-weight:800;overflow:hidden}.sidebar-mobile-close{display:none}.sidebar-navigation{gap:6px;margin-top:28px;display:grid}.sidebar-nav-item,.sidebar-action{color:#667085;cursor:pointer;white-space:nowrap;background:0 0;border:0;border-radius:6px;align-items:center;gap:12px;width:100%;height:44px;padding:0 13px;font-size:14px;font-weight:650;text-decoration:none;display:flex}.sidebar-nav-item:hover,.sidebar-action:hover{color:#5367d9;background:#f3f5fb}.sidebar-nav-item.router-link-active{color:#4f61cf;background:linear-gradient(90deg,#ff7ab61f,#5b8cff1f)}.sidebar-nav-icon{flex:0 0 20px;place-items:center;display:grid;position:relative}.sidebar-unread-badge{color:#fff;background:#ed4f63;border:2px solid #fff;border-radius:11px;justify-content:center;align-items:center;min-width:22px;height:22px;margin-left:auto;padding:0 5px;font-size:10px;font-style:normal;font-weight:800;line-height:1;display:flex;box-shadow:0 2px 7px #ed4f6347}.sidebar-footer{border-top:1px solid #edf0f5;gap:6px;margin-top:auto;padding-top:14px;display:grid}.sidebar-user{align-items:center;gap:10px;min-width:0;margin-bottom:4px;padding:6px;display:flex}.sidebar-user img{object-fit:cover;border:2px solid #edf0f7;border-radius:50%;flex:0 0 36px;width:36px;height:36px}.sidebar-user-copy{gap:3px;min-width:0;display:grid}.sidebar-user-copy strong,.sidebar-user-copy span{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.sidebar-user-copy strong{color:#293147;font-size:13px}.sidebar-user-copy span{color:#8a94a7;font-size:12px}.app-sidebar--collapsed .sidebar-nav-item,.app-sidebar--collapsed .sidebar-action{justify-content:center;padding:0}.app-sidebar--collapsed .sidebar-user{justify-content:center;padding:6px 0}.app-sidebar--collapsed .sidebar-brand-name,.app-sidebar--collapsed .sidebar-nav-label,.app-sidebar--collapsed .sidebar-user-copy,.app-sidebar--collapsed .sidebar-action-label{display:none}.app-sidebar--collapsed .sidebar-nav-item{position:relative}.app-sidebar--collapsed .sidebar-unread-badge{border-radius:10px;min-width:19px;height:19px;padding:0 4px;font-size:9px;position:absolute;top:2px;right:1px}@media (width<=760px){.app-sidebar,.app-sidebar--collapsed{width:min(84vw,280px);transform:translate(-105%)}.app-sidebar--mobile-open{transform:translate(0)}.app-sidebar--collapsed .sidebar-nav-item,.app-sidebar--collapsed .sidebar-action{justify-content:flex-start;padding:0 13px}.app-sidebar--collapsed .sidebar-user{justify-content:flex-start;padding:6px}.app-sidebar--collapsed .sidebar-brand-name,.app-sidebar--collapsed .sidebar-nav-label,.app-sidebar--collapsed .sidebar-user-copy,.app-sidebar--collapsed .sidebar-action-label{display:initial}.app-sidebar--collapsed .sidebar-user-copy{display:grid}.sidebar-mobile-close{color:#687287;cursor:pointer;background:#f4f6fa;border:0;border-radius:6px;place-items:center;width:36px;height:36px;display:grid}.sidebar-collapse{display:none}}.lobby-layout{--sidebar-width:248px;background:#f5f7fb;min-height:100vh}.lobby-layout--collapsed{--sidebar-width:76px}.lobby-content{min-height:100vh;margin-left:var(--sidebar-width);transition:margin-left .22s}.lobby-topbar{z-index:10;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#ffffffeb;border-bottom:1px solid #e5e9f2;align-items:center;gap:12px;height:64px;padding:0 28px;display:flex;position:sticky;top:0}.lobby-topbar h1{color:#20283a;letter-spacing:0;margin:0;font-size:18px;font-weight:700}.lobby-menu-button{color:#49546a;cursor:pointer;background:#fff;border:1px solid #e2e7f0;border-radius:6px;place-items:center;width:38px;height:38px;display:none}.lobby-view{width:min(100%,1260px);margin:0 auto;padding:32px}.lobby-view--full{width:100%;max-width:none;height:calc(100vh - 64px);padding:12px}.sidebar-backdrop{display:none}@media (width<=760px){.lobby-content{margin-left:0}.lobby-topbar{padding:0 18px}.lobby-menu-button{display:grid}.lobby-view{padding:20px}.lobby-view--full{height:calc(100vh - 64px);padding:8px}.sidebar-backdrop{z-index:30;background:#1f283a5c;border:0;display:block;position:fixed;inset:0}}.profile-page{gap:24px;display:grid}.profile-header{background:linear-gradient(120deg,#ff7ab61a,#5b8cff1f),#fff;border:1px solid #e5e9f2;border-radius:8px;align-items:center;gap:26px;min-height:184px;padding:30px;display:flex}.profile-avatar-control{flex:0 0 112px;position:relative}.profile-avatar-button{cursor:pointer;background:0 0;border:0;border-radius:50%;padding:0;display:block}.profile-avatar{object-fit:cover;border:4px solid #ffffffeb;border-radius:50%;width:112px;height:112px;box-shadow:0 12px 28px #45588526}.profile-avatar-button:hover .profile-avatar{box-shadow:0 14px 32px #5b8cff40}.profile-avatar-menu{z-index:15;background:#fff;border:1px solid #e1e6ef;border-radius:8px;gap:4px;width:142px;padding:7px;display:grid;position:absolute;top:122px;left:0;box-shadow:0 14px 36px #2d3c5b29}.profile-avatar-menu button{color:#465066;cursor:pointer;background:0 0;border:0;border-radius:6px;align-items:center;gap:7px;height:36px;padding:0 9px;font-size:13px;display:flex}.profile-avatar-menu button:hover{color:#5b6fd7;background:#f2f4fa}.profile-avatar-input{display:none}.profile-heading{min-width:0}.profile-status{color:#47725e;align-items:center;gap:5px;margin-bottom:10px;font-size:13px;font-weight:700;display:inline-flex}.profile-heading h2{overflow-wrap:anywhere;color:#20283a;letter-spacing:0;margin:0 0 7px;font-size:28px}.profile-account{color:#6f798d;margin:0;font-size:14px}.profile-signature{overflow-wrap:anywhere;color:#626d82;max-width:620px;margin:15px 0 0;font-size:14px;line-height:1.7}.profile-feedback{border-radius:7px;margin:-6px 0 0;padding:11px 14px;font-size:13px}.profile-feedback--error{color:#bd4e5b;background:#fff3f5}.profile-feedback--success{color:#47725e;background:#eef9f3}.profile-section{background:#fff;border:1px solid #e5e9f2;border-radius:8px}.profile-section-heading{border-bottom:1px solid #edf0f5;justify-content:space-between;align-items:center;gap:16px;padding:20px 24px;display:flex}.profile-section-heading h3{color:#293147;letter-spacing:0;margin:0;font-size:16px}.profile-section-heading span{color:#929bad;font-size:13px}.profile-info-list{margin:0;padding:4px 24px}.profile-info-row{border-bottom:1px solid #f0f2f6;grid-template-columns:minmax(130px,.38fr) 1fr;align-items:center;min-height:62px;display:grid}.profile-info-row:last-child{border-bottom:0}.profile-info-row dt{color:#7b8598;align-items:center;gap:9px;font-size:14px;display:flex}.profile-info-row dd{overflow-wrap:anywhere;color:#30394d;margin:0;font-size:14px;font-weight:650}.profile-info-cell{gap:10px;display:grid}.profile-info-value{grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:12px;display:grid}.profile-info-value span{overflow-wrap:anywhere;min-width:0}.profile-signature-value{white-space:pre-wrap}.profile-info-value button{color:#5b6680;cursor:pointer;background:#fff;border:1px solid #dfe5f1;border-radius:6px;justify-content:center;align-items:center;gap:5px;height:34px;padding:0 11px;font-size:13px;font-weight:700;display:inline-flex}.profile-info-value button:hover{color:#5b6fd7;background:#f5f7ff;border-color:#cdd5f8}.profile-avatar-preview-overlay{z-index:100;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);cursor:zoom-out;background:#151b28bd;place-items:center;padding:28px;display:grid;position:fixed;inset:0}.profile-avatar-preview-overlay img{object-fit:contain;cursor:default;background:#fff;border-radius:8px;width:min(78vw,520px);max-height:78vh;box-shadow:0 24px 70px #00000052}.profile-avatar-preview-overlay button{color:#fff;cursor:pointer;background:#ffffff2e;border:0;border-radius:6px;place-items:center;width:42px;height:42px;display:grid;position:fixed;top:20px;right:22px}.profile-avatar-preview-overlay button:hover{background:#ffffff47}.profile-editor-overlay{z-index:90;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#1f283a57;place-items:center;padding:24px;display:grid;position:fixed;inset:0}.profile-editor-dialog{background:#fff;border:1px solid #e1e6ef;border-radius:8px;gap:18px;width:min(92vw,460px);padding:20px;display:grid;box-shadow:0 24px 70px #2a365233}.profile-editor-dialog header{justify-content:space-between;align-items:center;gap:12px;display:flex}.profile-editor-dialog h3{color:#293147;letter-spacing:0;margin:0;font-size:17px}.profile-editor-dialog header button{color:#778299;cursor:pointer;background:0 0;border:0;border-radius:6px;place-items:center;width:34px;height:34px;display:grid}.profile-editor-dialog header button:hover{color:#d64f73;background:#fff0f5}.profile-editor-dialog label{gap:8px;display:grid}.profile-editor-dialog label span{color:#6f798d;font-size:13px;font-weight:700}.profile-editor-dialog input,.profile-editor-dialog textarea{color:#30394d;width:100%;font:inherit;background:#fbfcfe;border:1px solid #dce2ed;border-radius:7px;outline:none;padding:11px 12px}.profile-editor-dialog textarea{resize:vertical;min-height:112px;line-height:1.6}.profile-editor-dialog input:focus,.profile-editor-dialog textarea:focus{border-color:#7b8cff;box-shadow:0 0 0 3px #7b8cff21}.profile-editor-error{color:#bd4e5b;background:#fff3f5;border-radius:6px;margin:-4px 0 0;padding:9px 11px;font-size:13px}.profile-editor-dialog footer{justify-content:flex-end;gap:10px;display:flex}.profile-editor-dialog footer button{color:#5b6680;cursor:pointer;background:#fff;border:1px solid #dfe5f1;border-radius:6px;justify-content:center;align-items:center;min-width:78px;height:38px;padding:0 14px;font-weight:700;display:inline-flex}.profile-editor-dialog footer button:last-child{color:#fff;background:linear-gradient(135deg,#ff7ab6,#5b8cff);border-color:#0000}.profile-editor-dialog footer button:hover{background:#f5f7ff;border-color:#cdd5f8}.profile-editor-dialog footer button:last-child:hover{background:linear-gradient(135deg,#f36aa8,#4f7fff)}.profile-editor-dialog footer button:disabled{cursor:not-allowed;opacity:.55}@media (width<=620px){.profile-header{flex-direction:column;align-items:flex-start;padding:24px}.profile-avatar-control{flex-basis:88px}.profile-avatar{width:88px;height:88px}.profile-avatar-menu{top:98px}.profile-heading h2{font-size:23px}.profile-section-heading{flex-direction:column;align-items:flex-start;gap:5px}.profile-info-row{grid-template-columns:1fr;align-items:start;gap:8px;padding:15px 0}.profile-info-value{grid-template-columns:1fr}.profile-info-value button{width:fit-content}.profile-editor-dialog footer{grid-template-columns:1fr;display:grid}}*{box-sizing:border-box}html,body,#app{min-width:320px;min-height:100vh;margin:0}body{color:#20283a;background:#f5f7fb;font-family:Inter,PingFang SC,Microsoft YaHei,system-ui,sans-serif}button,input{font:inherit}button{letter-spacing:0}
