.login-page{min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0f172a,#1e3a5f);padding:1rem}.login-card{background:#fff;border-radius:16px;padding:2.5rem 2rem;width:100%;max-width:400px;box-shadow:0 20px 60px #0000004d;animation:cardIn .4s cubic-bezier(.4,0,.2,1)}@keyframes cardIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.login-header{text-align:center;margin-bottom:2rem}.login-logo{width:64px;height:64px;border-radius:12px;object-fit:cover;margin-bottom:.75rem}.login-title{margin:0 0 .25rem;font-size:1.75rem;font-weight:700;color:#0f172a;letter-spacing:1px}.login-subtitle{margin:0;font-size:.875rem;color:#64748b}.login-form{display:flex;flex-direction:column;gap:1.25rem}.login-field{display:flex;flex-direction:column;gap:.375rem}.login-field label{font-size:.8125rem;font-weight:600;color:#334155}.login-field input{padding:.625rem .875rem;border:1.5px solid #E2E8F0;border-radius:8px;font-size:.875rem;color:#0f172a;background:#f8fafc;transition:border-color .2s ease,box-shadow .2s ease;outline:none}.login-field input:focus{border-color:#1e3a5f;background:#fff;box-shadow:0 0 0 3px #1e3a5f1a}.login-field input:disabled{opacity:.6;cursor:not-allowed}.login-error{padding:.625rem .875rem;background:#fef2f2;border:1px solid #FECACA;border-radius:8px;color:#dc2626;font-size:.8125rem}.login-submit{padding:.75rem 1rem;background:linear-gradient(135deg,#0f172a,#1e3a5f);color:#fff;border:none;border-radius:8px;font-size:.9375rem;font-weight:600;cursor:pointer;transition:opacity .2s ease,transform .15s ease;margin-top:.25rem}.login-submit:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.login-submit:active:not(:disabled){transform:translateY(0)}.login-submit:disabled{opacity:.5;cursor:not-allowed}.login-divider{display:flex;align-items:center;gap:.75rem;margin:1.25rem 0 0;color:#94a3b8;font-size:.8125rem}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:#e2e8f0}.login-google{display:flex;align-items:center;justify-content:center;gap:.625rem;width:100%;padding:.75rem 1rem;background:#fff;color:#334155;border:1.5px solid #E2E8F0;border-radius:8px;font-size:.9375rem;font-weight:500;cursor:pointer;transition:border-color .2s ease,box-shadow .2s ease;margin-top:.5rem}.login-google:hover:not(:disabled){border-color:#cbd5e1;box-shadow:0 1px 4px #00000014}.login-google:disabled{opacity:.5;cursor:not-allowed}.space-selector{position:relative;width:auto;max-width:380px}.space-selector-trigger{width:auto;min-width:220px;max-width:100%;padding:5px 10px;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:6px;color:#fff;font-size:12px;font-weight:500;display:flex;align-items:center;justify-content:space-between;cursor:pointer;transition:all .2s ease;gap:8px}.space-selector-trigger:hover{background:#ffffff26;border-color:#ffffff4d}.space-selector-current{flex:1;text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.space-selector-arrow{font-size:9px;opacity:.7}.space-selector-dropdown{position:absolute;top:calc(100% + 8px);left:0;width:320px;background:#fff;border-radius:12px;box-shadow:0 8px 24px #00000026;z-index:1000;max-height:420px;display:flex;flex-direction:column;animation:slideDown .2s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.space-selector-header{padding:14px 16px 10px;border-bottom:1px solid #E2E8F0}.space-selector-header h3{margin:0 0 10px;font-size:13px;font-weight:600;color:#0f172a}.space-selector-search{width:100%;padding:7px 10px;border:1px solid #CBD5E1;border-radius:6px;font-size:13px;color:#0f172a;outline:none;transition:border-color .2s ease,box-shadow .2s ease;box-sizing:border-box}.space-selector-search:focus{border-color:#1e3a5f;box-shadow:0 0 0 3px #1e3a5f1a}.space-selector-search::placeholder{color:#94a3b8}.space-selector-list{flex:1;overflow-y:auto;max-height:300px;padding:6px}.space-selector-list::-webkit-scrollbar{width:6px}.space-selector-list::-webkit-scrollbar-track{background:#f1f5f9;border-radius:3px}.space-selector-list::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.space-selector-item{width:100%;padding:9px 10px;border:none;background:transparent;color:#334155;font-size:13px;text-align:left;display:flex;align-items:center;gap:8px;cursor:pointer;border-radius:6px;transition:background .15s ease;margin-bottom:2px;min-width:0}.space-selector-item:hover{background:#f1f5f9}.space-selector-item.active{background:#eff6ff;color:#1e3a5f;font-weight:500}.space-selector-item-icon{font-size:14px;flex-shrink:0;width:18px;text-align:center}.space-selector-item-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.space-selector-item-count{flex-shrink:0;padding:2px 6px;background:#e2e8f0;color:#64748b;font-size:11px;font-weight:500;border-radius:10px}.space-selector-item.active .space-selector-item-count{background:#bfdbfe;color:#1e3a5f}.space-selector-footer{padding:10px 14px;border-top:1px solid #E2E8F0;background:#f8fafc;border-radius:0 0 12px 12px}.space-selector-count{font-size:11px;color:#64748b;font-weight:500}.main-layout{display:flex;flex-direction:column;height:100vh;height:100dvh;background:#f8fafc;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.main-header{background:linear-gradient(135deg,#0f172a,#1e3a5f);color:#fff;padding:0 1.25rem;height:64px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0;box-shadow:0 2px 8px #0003;position:sticky;top:0;z-index:100}.main-header-left{display:flex;align-items:center;gap:12px;min-width:0}.main-header-logo-wrap{width:40px;height:40px;border-radius:8px;overflow:hidden;flex-shrink:0}.main-header-logo{width:40px;height:40px;object-fit:cover}.main-header-title-block{display:flex;flex-direction:column;gap:3px;min-width:0}.main-header-title-row{display:flex;align-items:center;gap:8px}.main-header-title-row h1{margin:0;font-size:16px;font-weight:700;letter-spacing:.5px;line-height:1}.main-header-status-dot{width:6px;height:6px;border-radius:50%;background:#22c55e;animation:statusPulse 2s ease-in-out infinite;flex-shrink:0}.main-header-refresh{font-size:10px;opacity:.45;white-space:nowrap}.main-header-right{display:flex;align-items:center;gap:12px;flex-shrink:0}.main-header-user{font-size:13px;opacity:.85;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.main-header-logout{padding:5px 12px;background:#ffffff1f;border:1px solid rgba(255,255,255,.2);border-radius:6px;color:#fff;font-size:12px;font-weight:500;cursor:pointer;transition:background .2s ease;white-space:nowrap}.main-header-logout:hover{background:#fff3}.main-tabs{display:flex;flex-wrap:wrap;gap:4px;padding:8px 12px;background:linear-gradient(135deg,#0f172a,#1e3a5f);border-bottom:1px solid rgba(255,255,255,.1);flex-shrink:0}@media (max-width: 768px){.main-tabs{flex-wrap:nowrap;overflow-x:auto;overflow-y:hidden;gap:3px;padding:6px 10px;-webkit-overflow-scrolling:touch;scrollbar-width:none}.main-tabs::-webkit-scrollbar{display:none}}.main-tab{background:#ffffff0f;border:none;color:#fff;padding:6px 14px;border-radius:6px;cursor:pointer;display:flex;align-items:center;gap:6px;font-size:13px;font-weight:500;transition:all .15s ease;opacity:.65;white-space:nowrap}.main-tab:hover{opacity:1;background:#ffffff1f}.main-tab.active{background:#ffffff2e;opacity:1;font-weight:700}.main-tab-icon{font-size:15px;line-height:1}.main-tab-label{font-size:12px;line-height:1}.main-content{flex:1;overflow-y:auto;padding:16px 20px;background:#f8fafc;animation:contentFadeIn .2s ease-out;max-width:1400px;width:100%;margin:0 auto;box-sizing:border-box}.main-content::-webkit-scrollbar{width:6px}.main-content::-webkit-scrollbar-track{background:transparent}.main-content::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.main-content::-webkit-scrollbar-thumb:hover{background:#94a3b8}@keyframes contentFadeIn{0%{opacity:0}to{opacity:1}}@keyframes statusPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.85)}}@keyframes itemSlideIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes skeletonShimmer{0%{background-position:-200px 0}to{background-position:calc(200px + 100%) 0}}.skeleton-bar{background:linear-gradient(90deg,#e2e8f0 25%,#f1f5f9,#e2e8f0 75%);background-size:200px 100%;animation:skeletonShimmer 1.5s ease-in-out infinite;border-radius:4px}.unified-panel-content{flex:1;overflow-y:auto;background:#f8fafc}.unified-panel-loading{display:flex;align-items:center;justify-content:center;padding:20px;color:#64748b}.unified-panel-error{padding:10px 12px;background:#fef2f2;border:1px solid #FECACA;border-radius:6px;color:#dc2626;margin:10px 0;font-size:.78rem}.unified-panel-empty{text-align:center;padding:24px;color:#94a3b8}@media (max-width: 768px){.main-header{padding:0 .75rem}.main-header-user{display:none}.main-content{padding:12px}.main-tab{padding:6px 10px;flex-shrink:0}.main-tab-label{display:none}}*,*:before,*:after{box-sizing:border-box}html,body,#root{margin:0;padding:0;height:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f8fafc;color:#0f172a}button,input,textarea,select{font-family:inherit}
