.app-header[data-v-c8e8f9fb]{position:sticky;top:0;z-index:100;background:#ffffffeb;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--color-divider)}.header-inner[data-v-c8e8f9fb]{max-width:var(--layout-max-width);height:var(--header-height);margin:0 auto;padding:0 var(--space-6);display:flex;align-items:center;gap:var(--space-10)}.brand[data-v-c8e8f9fb]{display:flex;align-items:center;gap:var(--space-3);flex-shrink:0}.brand-mark[data-v-c8e8f9fb]{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-sm);background:var(--color-primary);color:#fff}.brand-name[data-v-c8e8f9fb]{font-size:var(--text-lg);font-weight:600;letter-spacing:.5px}.nav[data-v-c8e8f9fb]{display:flex;gap:var(--space-2);flex:1}.nav-link[data-v-c8e8f9fb]{display:inline-flex;align-items:center;gap:var(--space-2);height:38px;padding:0 var(--space-4);border-radius:var(--radius-sm);font-size:var(--text-base);color:var(--color-text-secondary);transition:color var(--transition-fast),background var(--transition-fast)}.nav-link[data-v-c8e8f9fb]:hover{color:var(--color-primary);background:var(--color-primary-softer)}.nav-link.active[data-v-c8e8f9fb]{color:var(--color-primary);background:var(--color-primary-soft);font-weight:500}.user-area[data-v-c8e8f9fb]{flex-shrink:0}.user-chip[data-v-c8e8f9fb]{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-3) var(--space-1) var(--space-1);border-radius:var(--radius-full);transition:background var(--transition-fast)}.user-chip[data-v-c8e8f9fb]:hover{background:var(--color-divider)}.user-avatar[data-v-c8e8f9fb]{width:32px;height:32px;border-radius:50%;object-fit:cover}.user-avatar-fallback[data-v-c8e8f9fb]{display:flex;align-items:center;justify-content:center;background:var(--color-primary-soft);color:var(--color-primary)}.user-name[data-v-c8e8f9fb]{font-size:var(--text-base);max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.login-btn[data-v-c8e8f9fb]{height:36px}@media(max-width:768px){.header-inner[data-v-c8e8f9fb]{gap:var(--space-4);padding:0 var(--space-4)}.brand-name[data-v-c8e8f9fb],.user-name[data-v-c8e8f9fb]{display:none}}.app-main[data-v-66a0f465]{flex:1;display:flex;flex-direction:column}:root{--color-primary: #2456d9;--color-primary-hover: #1d47b8;--color-primary-soft: #eaf0fe;--color-primary-softer: #f5f8ff;--color-success: #16a34a;--color-success-soft: #e9f9ef;--color-warning: #d97706;--color-warning-soft: #fdf3e3;--color-danger: #dc2626;--color-danger-soft: #fdecec;--color-text: #1c2333;--color-text-secondary: #55617a;--color-text-muted: #8b96ab;--color-border: #e4e8f0;--color-divider: #eef1f6;--color-bg: #f6f8fb;--color-card: #ffffff;--font-family: "PingFang SC", "HarmonyOS Sans SC", "Microsoft YaHei", "Source Han Sans SC", system-ui, sans-serif;--font-family-num: "DIN Alternate", "Bahnschrift", "Segoe UI", var(--font-family);--text-xs: 12px;--text-sm: 13px;--text-base: 14px;--text-md: 15px;--text-lg: 17px;--text-xl: 20px;--text-2xl: 24px;--text-3xl: 32px;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-full: 999px;--shadow-card: 0 1px 2px rgba(28, 35, 51, .04), 0 4px 16px rgba(28, 35, 51, .06);--shadow-card-hover: 0 2px 4px rgba(28, 35, 51, .06), 0 10px 28px rgba(28, 35, 51, .1);--shadow-pop: 0 8px 32px rgba(28, 35, 51, .14);--transition-fast: .16s ease;--transition-base: .24s ease;--layout-max-width: 1200px;--header-height: 64px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%}body{font-family:var(--font-family);font-size:var(--text-base);color:var(--color-text);background:var(--color-bg);-webkit-font-smoothing:antialiased;line-height:1.6}#app{min-height:100vh;display:flex;flex-direction:column}a{color:inherit;text-decoration:none}button{font-family:inherit;border:none;background:none;cursor:pointer}img{display:block;max-width:100%}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}}.page-container{width:100%;max-width:var(--layout-max-width);margin:0 auto;padding:var(--space-6) var(--space-6) var(--space-12)}.card{background:var(--color-card);border-radius:var(--radius-md);box-shadow:var(--shadow-card)}.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);height:40px;padding:0 var(--space-6);border-radius:var(--radius-sm);background:var(--color-primary);color:#fff;font-size:var(--text-base);font-weight:500;transition:background var(--transition-fast),transform var(--transition-fast)}.btn-primary:hover{background:var(--color-primary-hover)}.btn-primary:active{transform:scale(.98)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-ghost{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);height:40px;padding:0 var(--space-5);border-radius:var(--radius-sm);border:1px solid var(--color-border);background:var(--color-card);color:var(--color-text-secondary);font-size:var(--text-base);transition:border-color var(--transition-fast),color var(--transition-fast)}.btn-ghost:hover{border-color:var(--color-primary);color:var(--color-primary)}.tag{display:inline-flex;align-items:center;gap:var(--space-1);height:24px;padding:0 var(--space-3);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:500}.tag-primary{background:var(--color-primary-soft);color:var(--color-primary)}.tag-success{background:var(--color-success-soft);color:var(--color-success)}.tag-warning{background:var(--color-warning-soft);color:var(--color-warning)}.tag-muted{background:var(--color-divider);color:var(--color-text-secondary)}.empty-state{display:flex;flex-direction:column;align-items:center;gap:var(--space-3);padding:var(--space-12) 0;color:var(--color-text-muted)}.skeleton{border-radius:var(--radius-sm);background:linear-gradient(90deg,#eef1f6 25%,#f6f8fb,#eef1f6 75%);background-size:200% 100%;animation:skeleton-wave 1.4s infinite}@keyframes skeleton-wave{0%{background-position:200% 0}to{background-position:-200% 0}}
