.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-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}.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}}.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;overflow:hidden}.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{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-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;background:0 0;border:0;margin:0 0 8px;padding:0;display:block}.chat-message-image{object-fit:contain;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-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{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{color:#5b6fd7;background:#f0f3fa}.chat-emoji-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-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-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%}}.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-copy h3{color:#293147;letter-spacing:0;text-overflow:ellipsis;white-space:nowrap;margin:0 0 7px;font-size:15px;overflow:hidden}.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-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-dot{background:#ed4f63;border:2px solid #fff;border-radius:50%;width:8px;height:8px;position:absolute;top:-4px;right:-5px}.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}@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}
