.album-page{gap:24px;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-upload-button{color:#fff;cursor:pointer;background:linear-gradient(135deg,#ff7ab6,#5b8cff);border:0;border-radius:6px;align-items:center;gap:8px;height:42px;padding:0 17px;font-size:14px;font-weight:700;display:flex;box-shadow:0 10px 22px #5b8cff38}.album-upload-button:hover{box-shadow:0 13px 26px #ff7ab640}.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}@media (width<=560px){.album-header{flex-direction:column;align-items:stretch}.album-upload-button{justify-content:center}.album-empty{min-height:340px}}.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{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-avatar{object-fit:cover;border:2px solid #edf0f7;border-radius:50%;flex:0 0 62px;width:62px;height:62px}.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}@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}}.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-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-item span,.app-sidebar--collapsed .sidebar-user-copy,.app-sidebar--collapsed .sidebar-action span{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-item span,.app-sidebar--collapsed .sidebar-user-copy,.app-sidebar--collapsed .sidebar-action span{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}.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}.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{object-fit:cover;border:4px solid #ffffffeb;border-radius:50%;flex:0 0 112px;width:112px;height:112px;box-shadow:0 12px 28px #45588526}.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-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}@media (width<=620px){.profile-header{flex-direction:column;align-items:flex-start;padding:24px}.profile-avatar{flex-basis:88px;width:88px;height:88px}.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}}*{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}
