*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-sans);background:var(--bg-primary);min-height:100vh;color:var(--text-primary)}.app{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-width);background:var(--bg-white);border-right:1px solid var(--border-light);display:flex;flex-direction:column;position:fixed;left:0;top:0;bottom:0;z-index:100}.sidebar-header{padding:var(--space-lg) var(--space-md)}.logo{display:flex;align-items:center;gap:var(--space-sm);overflow:hidden}.logo-icon{font-size:1.25rem}.logo-icon-img{width:36px;height:36px;border-radius:var(--radius-md);display:block;flex-shrink:0}.logo-brand{display:flex;flex-direction:column;line-height:1.2}.logo-text{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary)}.logo-sub{font-size:10px;color:var(--text-muted);font-weight:var(--font-normal)}.sidebar-nav{flex:1;padding:0 var(--space-sm);display:flex;flex-direction:column;gap:2px;overflow-y:auto}.nav-group{display:flex;flex-direction:column}.nav-group-header{display:flex;align-items:center;gap:var(--space-sm);padding:10px 12px;border-radius:var(--radius-md);color:var(--text-secondary);transition:all var(--transition-fast);cursor:pointer;font-weight:var(--font-medium);font-size:var(--text-sm);-webkit-user-select:none;user-select:none}.nav-group-header:hover{background:var(--bg-secondary);color:var(--text-primary)}.nav-group-header.active{color:var(--text-primary);background:var(--bg-secondary)}.nav-group-arrow{margin-left:auto;transition:transform var(--transition-fast);flex-shrink:0;color:var(--text-muted)}.nav-group-arrow.rotated{transform:rotate(180deg)}.nav-submenu{display:flex;flex-direction:column;gap:2px;max-height:0;overflow:hidden;transition:max-height .2s ease,opacity .15s ease;opacity:0;padding-left:10px}.nav-submenu.expanded{max-height:600px;opacity:1;margin:2px 0}.nav-subitem{display:flex;align-items:center;gap:8px;padding:8px 12px 8px 16px;border-radius:var(--radius-md);text-decoration:none;color:var(--text-tertiary);font-size:var(--text-sm);transition:all var(--transition-fast)}.nav-subitem:hover{background:var(--bg-secondary);color:var(--text-primary)}.nav-subitem.active{background:var(--primary-light);color:var(--text-primary);font-weight:var(--font-medium)}.nav-dot{width:5px;height:5px;border-radius:50%;background:currentColor;opacity:.4}.nav-subitem.active .nav-dot{opacity:1}.nav-item{display:flex;align-items:center;gap:var(--space-sm);padding:10px 12px;border-radius:var(--radius-md);text-decoration:none;color:var(--text-secondary);transition:all var(--transition-fast);cursor:pointer;font-weight:var(--font-medium);font-size:var(--text-sm)}.nav-item:hover{background:var(--bg-secondary);color:var(--text-primary)}.nav-item.active{background:var(--primary-light);color:var(--text-primary);font-weight:var(--font-medium)}.nav-icon{font-size:var(--text-lg);width:22px;text-align:center;flex-shrink:0;display:flex;align-items:center;justify-content:center;height:20px}.nav-icon svg{display:block}.nav-text,.nav-subtext{font-size:var(--text-sm);line-height:1.2}.nav-member-badge{font-size:10px;font-weight:var(--font-bold);padding:1px 6px;border-radius:var(--radius-full);margin-left:auto}.nav-member-badge.member{background:var(--color-warning-soft);color:var(--color-warning)}.nav-member-badge.trial{background:var(--color-primary-soft);color:var(--color-primary)}.sidebar-footer{padding:var(--space-sm);border-top:1px solid var(--border-light)}.user-card{display:flex;align-items:center;gap:var(--space-sm);padding:10px;background:var(--bg-white);cursor:pointer;border:1px solid var(--border-light);border-radius:var(--radius-md)}.user-avatar{width:34px;height:34px;border-radius:var(--radius-full);background:var(--primary);color:var(--text-white);display:flex;align-items:center;justify-content:center;font-weight:var(--font-semibold);font-size:var(--text-sm);flex-shrink:0}.user-info{flex:1;min-width:0}.user-name{font-weight:var(--font-medium);color:var(--text-primary);font-size:var(--text-xs);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-meta{margin-top:2px}.logout-btn{width:28px;height:28px;border:none;background:transparent;border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);flex-shrink:0}.logout-btn:hover{background:var(--error-bg);color:var(--error)}.theme-toggle-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;padding:10px 12px;margin-bottom:8px;border:1px solid var(--border-default);background:var(--bg-secondary);border-radius:var(--radius-md);color:var(--text-secondary);font-size:var(--text-sm);font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.theme-toggle-btn svg{display:block}.theme-toggle-btn:hover{background:var(--bg-hover);border-color:var(--border-hover);color:var(--text-primary)}.logout-btn-block{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;padding:12px;border:1px solid var(--color-error-soft);background:var(--color-error-soft);border-radius:var(--radius-md);color:var(--color-error);font-size:var(--text-sm);font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.logout-btn-block svg{display:block}.logout-btn-block:hover{filter:brightness(.85)}.sidebar-toggle-btn{position:absolute;right:-14px;top:72px;width:28px;height:28px;display:flex;align-items:center;justify-content:center;padding:0;border:1px solid var(--border-default);background:var(--bg-white);border-radius:50%;color:var(--text-secondary);font-size:var(--text-sm);cursor:pointer;transition:all var(--transition-fast);box-shadow:0 1px 4px var(--shadow);z-index:101}.sidebar-toggle-btn svg{display:block}.sidebar-toggle-btn:hover{background:var(--bg-hover);border-color:var(--border-hover);color:var(--text-primary);box-shadow:0 2px 8px var(--shadow)}.sidebar.collapsed{width:var(--sidebar-collapsed-width)}.sidebar.collapsed .sidebar-header{padding:16px 0;display:flex;justify-content:center}.sidebar.collapsed .logo{justify-content:center}.sidebar.collapsed .logo-brand,.sidebar.collapsed .nav-text,.sidebar.collapsed .nav-group-arrow,.sidebar.collapsed .nav-submenu,.sidebar.collapsed .nav-member-badge,.sidebar.collapsed .nav-subtext,.sidebar.collapsed .nav-dot,.sidebar.collapsed .btn-text{display:none}.sidebar.collapsed .nav-group-header,.sidebar.collapsed .nav-item{justify-content:center;padding:10px}.sidebar.collapsed .nav-icon{width:24px;height:24px}.sidebar.collapsed .nav-icon svg{width:20px;height:20px}.sidebar.collapsed .sidebar-footer{padding:12px 8px}.sidebar.collapsed .sidebar-toggle-btn,.sidebar.collapsed .theme-toggle-btn,.sidebar.collapsed .logout-btn-block{padding:10px}.nav-spacer{flex:1;min-height:16px}.main{flex:1;height:100vh;overflow-y:auto;display:flex;flex-direction:column;position:relative}.main.with-sidebar{margin-left:var(--sidebar-width)}.main-content{flex:1;padding:var(--space-xl);max-width:1120px;width:100%;margin:0 auto}.site-footer{padding:var(--space-lg) var(--space-xl);margin-top:auto;text-align:center}.footer-line{font-size:var(--text-xs);color:var(--text-muted);line-height:1.5;display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:0}.footer-item{display:inline-block}.footer-divider{margin:0 var(--space-sm);opacity:.5}.footer-beian{display:inline-flex;align-items:center;gap:4px;color:var(--text-muted);text-decoration:none;font-size:var(--text-xs)}.footer-beian:hover{color:var(--text-secondary)}.beian-icon{width:16px;height:16px}.mobile-header{display:none;position:fixed;top:0;left:0;right:0;height:var(--header-height);background:var(--bg-white);border-bottom:1px solid var(--border-light);z-index:100;padding:0 var(--space-md);align-items:center;justify-content:space-between}.mobile-logo{display:flex;align-items:center;gap:var(--space-sm)}.mobile-logo .logo-icon{font-size:1.25rem}.mobile-logo .logo-icon-img{width:32px;height:32px;border-radius:var(--radius-md);display:block}.mobile-logo .logo-brand{display:flex;flex-direction:column;line-height:1.2}.mobile-logo .logo-text{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--text-primary)}.mobile-logo .logo-sub{font-size:9px;color:var(--text-muted)}.menu-toggle{width:36px;height:36px;border:none;background:transparent;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.menu-toggle:hover{background:var(--bg-secondary);color:var(--text-primary)}.mobile-menu{display:none;position:fixed;top:var(--header-height);left:0;right:0;bottom:0;background:var(--bg-white);z-index:99;padding:var(--space-md);flex-direction:column;gap:2px;overflow-y:auto}.mobile-nav-item{display:flex;align-items:center;gap:var(--space-sm);padding:14px 16px;border-radius:var(--radius-md);text-decoration:none;color:var(--text-secondary);font-size:var(--text-base);font-weight:var(--font-medium);transition:all var(--transition-fast)}.mobile-nav-item.active{background:var(--primary-light);color:var(--text-primary)}.mobile-nav-group{display:flex;flex-direction:column}.mobile-nav-group-header{display:flex;align-items:center;gap:var(--space-sm);padding:14px 16px;border-radius:var(--radius-md);color:var(--text-secondary);font-size:var(--text-base);font-weight:var(--font-medium);transition:all var(--transition-fast);cursor:pointer;-webkit-user-select:none;user-select:none}.mobile-nav-group-header.active{color:var(--text-primary);background:var(--primary-light)}.mobile-nav-submenu{display:flex;flex-direction:column;gap:2px;max-height:0;overflow:hidden;transition:max-height .2s ease,opacity .15s ease;opacity:0;padding-left:12px}.mobile-nav-submenu.expanded{max-height:600px;opacity:1;margin:4px 0}.mobile-nav-subitem{display:flex;align-items:center;gap:10px;padding:12px 16px;border-radius:var(--radius-md);text-decoration:none;color:var(--text-tertiary);font-size:var(--text-sm);transition:all var(--transition-fast)}.mobile-nav-subitem:hover,.mobile-nav-subitem.active{background:var(--bg-secondary);color:var(--text-primary)}.mobile-user{margin-top:auto;padding-top:var(--space-md);border-top:1px solid var(--border-light);display:flex;justify-content:space-between;align-items:center;padding:var(--space-md) var(--space-sm)}.mobile-user span{color:var(--text-secondary);font-weight:var(--font-medium);font-size:var(--text-sm)}.mobile-user button{background:var(--color-error-soft);color:var(--color-error)}.mobile-user button:hover{background:var(--color-error);color:var(--text-white)}.mobile-overlay{display:none;position:fixed;top:var(--header-height);left:0;right:0;bottom:0;background:#0000004d;z-index:98}.note-fab{position:fixed;right:24px;top:50%;transform:translateY(-50%);width:52px;height:52px;border-radius:50%;background:var(--color-primary);color:var(--text-white);border:none;cursor:pointer;box-shadow:0 4px 14px #0000002e;z-index:150;display:flex;align-items:center;justify-content:center;transition:transform .2s,box-shadow .2s}.note-fab:hover{transform:translateY(calc(-50% - 2px));box-shadow:0 6px 20px #00000038}.note-fab[data-tooltip]:after,.feedback-fab[data-tooltip]:after{content:attr(data-tooltip);position:absolute;right:calc(100% + 10px);top:50%;transform:translateY(-50%) translate(4px);padding:4px 10px;font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--text-white);background:#000c;border-radius:var(--radius-sm);white-space:nowrap;opacity:0;pointer-events:none;transition:all .15s ease}.note-fab[data-tooltip]:hover:after,.feedback-fab[data-tooltip]:hover:after{opacity:1;transform:translateY(-50%) translate(0)}.feedback-fab{position:fixed;right:24px;bottom:24px;width:52px;height:52px;border-radius:50%;background:var(--primary);color:var(--text-white);border:none;font-size:1.4rem;cursor:pointer;box-shadow:0 4px 14px #0000002e;z-index:150;display:flex;align-items:center;justify-content:center;transition:transform .2s,box-shadow .2s}.feedback-fab:hover{transform:translateY(-2px);box-shadow:0 6px 20px #00000038}.feedback-fab.panel-open{bottom:210px}.feedback-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000038;z-index:139;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.feedback-panel{position:fixed;left:0;right:0;bottom:0;background:var(--bg-white);border-radius:20px 20px 0 0;box-shadow:0 -8px 32px #0000001a;z-index:140;transform:translateY(100%);transition:transform .3s cubic-bezier(.16,1,.3,1)}.feedback-panel.panel-visible{transform:translateY(0)}.feedback-panel-inner{max-width:560px;margin:0 auto;padding:20px 24px 28px}.feedback-panel-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.feedback-panel-title{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--text-primary);letter-spacing:-.2px}.feedback-panel-close{width:28px;height:28px;border-radius:50%;background:var(--bg-secondary);border:none;font-size:.95rem;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s,color .2s}.feedback-panel-close:hover{background:var(--border-light);color:var(--text-primary)}.feedback-textarea{width:100%;resize:none;min-height:90px;padding:12px 14px;border:1.5px solid var(--border-light);border-radius:12px;font-size:var(--text-sm);line-height:1.6;color:var(--text-primary);background:var(--bg-secondary);transition:border-color .2s;outline:none;margin-bottom:14px}.feedback-textarea::placeholder{color:var(--text-muted)}.feedback-textarea:focus{border-color:var(--primary)}.feedback-panel-actions{display:flex;justify-content:flex-end}.feedback-submit{padding:8px 22px;border-radius:10px;font-size:var(--text-sm);font-weight:var(--font-semibold)}@media (max-width: 768px){.sidebar{display:none}.main.with-sidebar{margin-left:0}.main.mobile{padding-top:var(--header-height)}.main-content{padding:var(--space-md)}.mobile-header,.mobile-menu,.mobile-overlay{display:flex}.feedback-fab{right:16px;bottom:16px;width:48px;height:48px;font-size:1.2rem}}.modal-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#00000059;z-index:200;display:flex;align-items:center;justify-content:center;animation:fadeIn .2s ease-out}.note-modal{background:var(--bg-white);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:90%;max-width:520px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;animation:slideUp .25s cubic-bezier(.16,1,.3,1)}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.note-modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border-light)}.note-modal-title{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--text-primary)}.note-modal-close{width:32px;height:32px;border-radius:50%;border:none;background:var(--bg-secondary);color:var(--text-secondary);font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.note-modal-close:hover{background:var(--border-default);color:var(--text-primary)}.note-modal-body{padding:20px;display:flex;flex-direction:column;gap:12px;overflow-y:auto}.note-input{width:100%;padding:10px 14px;border:1px solid var(--border-light);border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--text-primary);background:var(--bg-white);outline:none;transition:border-color var(--transition-fast)}.note-input:focus{border-color:var(--color-primary)}.note-textarea{width:100%;padding:10px 14px;border:1px solid var(--border-light);border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--text-primary);background:var(--bg-white);outline:none;resize:vertical;min-height:120px;transition:border-color var(--transition-fast);font-family:var(--font-sans);line-height:1.6}.note-textarea:focus{border-color:var(--color-primary)}.note-modal-footer{display:flex;justify-content:flex-end;gap:10px;padding:12px 20px 16px;border-top:1px solid var(--border-light)}@media (max-width: 640px){.note-fab{right:16px;top:50%;transform:translateY(-50%);width:48px;height:48px}.note-modal{width:95%;border-radius:var(--radius-lg)}.note-modal-body{padding:16px}}.toast-message{position:fixed;top:auto;bottom:40px;left:50%;transform:translate(-50%);padding:10px 20px;border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-white);z-index:9999;box-shadow:0 4px 12px #00000026;animation:fadeInUp .3s ease;width:max-content;max-width:90vw}.toast-message.success{background:var(--color-success)}.toast-message.error{background:var(--color-error)}@keyframes fadeInUp{0%{opacity:0;transform:translate(-50%,10px)}to{opacity:1;transform:translate(-50%)}}:root{--color-primary: #0d9488;--color-primary-hover: #0f766e;--color-primary-soft: rgba(13, 148, 136, .08);--color-success: #10b981;--color-success-soft: rgba(16, 185, 129, .08);--color-warning: #d97706;--color-warning-soft: rgba(217, 119, 6, .08);--color-error: #dc2626;--color-error-soft: rgba(220, 38, 38, .08);--text-primary: #171717;--text-secondary: #525252;--text-muted: #737373;--bg-primary: #fafafa;--bg-secondary: #f5f5f5;--bg-elevated: #ffffff;--border-default: #d4d4d4;--border-hover: #a3a3a3;--primary: var(--color-primary);--primary-hover: var(--color-primary-hover);--primary-light: var(--color-primary-soft);--success: var(--color-success);--success-bg: var(--color-success-soft);--warning: var(--color-warning);--warning-bg: var(--color-warning-soft);--error: var(--color-error);--error-bg: var(--color-error-soft);--info: var(--color-primary);--info-bg: var(--color-primary-soft);--text-tertiary: var(--text-muted);--text-white: #ffffff;--bg-white: var(--bg-elevated);--bg-card: var(--bg-elevated);--bg-hover: var(--bg-secondary);--bg-tertiary: var(--bg-secondary);--border-light: var(--border-default);--border-color: var(--border-default);--border-focus: var(--color-primary);--primary-color: var(--color-primary);--success-color: var(--color-success);--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--space-3xl: 64px;--radius-sm: 8px;--radius-md: 10px;--radius-lg: 12px;--radius-xl: 16px;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .06);--shadow-md: 0 4px 12px rgba(0, 0, 0, .08);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .1);--shadow-btn: 0 1px 2px rgba(0, 0, 0, .06);--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 1.875rem;--text-4xl: 2.25rem;--text-5xl: 3rem;--font-normal: 400;--font-medium: 500;--font-semibold: 600;--font-bold: 700;--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease;--sidebar-width: 240px;--sidebar-collapsed-width: 64px;--max-content-width: 1000px;--header-height: 60px}[data-theme=dark]{--color-primary: #2dd4bf;--color-primary-hover: #5eead4;--color-primary-soft: rgba(45, 212, 191, .12);--color-success: #34d399;--color-success-soft: rgba(52, 211, 153, .1);--color-warning: #fbbf24;--color-warning-soft: rgba(251, 191, 36, .1);--color-error: #f87171;--color-error-soft: rgba(248, 113, 113, .1);--text-primary: #f5f5f5;--text-secondary: #a3a3a3;--text-muted: #737373;--bg-primary: #0a0a0a;--bg-secondary: #141414;--bg-elevated: #1f1f1f;--border-default: #404040;--border-hover: #525252;--primary: var(--color-primary);--primary-hover: var(--color-primary-hover);--primary-light: var(--color-primary-soft);--success: var(--color-success);--success-bg: var(--color-success-soft);--warning: var(--color-warning);--warning-bg: var(--color-warning-soft);--error: var(--color-error);--error-bg: var(--color-error-soft);--info: var(--color-primary);--info-bg: var(--color-primary-soft);--text-tertiary: var(--text-muted);--bg-white: var(--bg-elevated);--bg-card: var(--bg-elevated);--bg-hover: var(--bg-secondary);--bg-tertiary: var(--bg-secondary);--border-light: var(--border-default);--border-color: var(--border-default);--border-focus: var(--color-primary);--primary-color: var(--color-primary);--success-color: var(--color-success)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-y:scroll}body{font-family:var(--font-sans);font-size:var(--text-base);line-height:1.6;color:var(--text-primary);background-color:var(--bg-primary);min-height:100vh;letter-spacing:-.01em}.card{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border-light);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition-base)}.card:hover{box-shadow:var(--shadow-md)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:10px 20px;font-size:var(--text-sm);font-weight:var(--font-medium);border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base);text-decoration:none;white-space:nowrap}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--primary);color:var(--text-white)}.btn-primary:hover:not(:disabled){background:var(--primary-hover)}.btn-secondary{background:var(--bg-white);color:var(--text-primary);border:1px solid var(--border-light)}.btn-secondary:hover:not(:disabled){background:var(--bg-secondary);border-color:var(--border-default);box-shadow:var(--shadow-sm)}.btn:active:not(:disabled){transform:translateY(1px)}.btn-sm{padding:6px 12px;font-size:var(--text-xs);border-radius:var(--radius-sm)}.btn-accent{background:var(--primary);color:var(--text-white)}.btn-accent:hover:not(:disabled){background:var(--primary-hover)}.btn-error{background:var(--error);color:var(--text-white)}.btn-error:hover:not(:disabled){filter:brightness(.9)}.btn-success{background:var(--color-primary);color:var(--text-white)}.btn-success:hover:not(:disabled){filter:brightness(.9)}.start-btn{width:100%;padding:14px;font-size:var(--text-lg)}.form-input,.form-textarea,.form-select{width:100%;padding:10px 14px;font-size:var(--text-sm);color:var(--text-primary);background:var(--bg-white);border:1px solid var(--border-light);border-radius:var(--radius-md);transition:all var(--transition-fast);font-family:inherit}.form-input:hover,.form-textarea:hover,.form-select:hover{border-color:var(--border-default)}.form-input:focus,.form-textarea:focus,.form-select:focus{outline:none;border-color:var(--border-focus);box-shadow:0 0 0 3px var(--color-primary-soft);background:var(--bg-elevated)}.form-input::placeholder,.form-textarea::placeholder{color:var(--text-muted)}.form-input:disabled,.form-textarea:disabled,.form-select:disabled{background:var(--bg-secondary);cursor:not-allowed}.form-label{display:block;margin-bottom:var(--space-sm);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-secondary)}.form-group{margin-bottom:var(--space-lg)}.page-header{margin-bottom:var(--space-lg);padding-bottom:var(--space-md);border-bottom:1px solid var(--border-light)}.page-title{font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--text-primary);letter-spacing:-.01em}.page-desc{font-size:var(--text-sm);color:var(--text-tertiary);line-height:1.5;margin-top:var(--space-xs)}.badge{display:inline-flex;align-items:center;padding:3px 10px;font-size:var(--text-xs);font-weight:var(--font-medium);border-radius:var(--radius-full);border:1px solid transparent}.badge-primary{background:var(--primary-light);color:var(--text-primary);border-color:var(--border-light)}.badge-success{background:var(--success-bg);color:var(--success);border-color:var(--color-success-soft)}.badge-warning{background:var(--warning-bg);color:var(--warning);border-color:var(--color-warning-soft)}.badge-error{background:var(--error-bg);color:var(--error);border-color:var(--color-error-soft)}.stat-value{font-size:var(--text-2xl);font-weight:var(--font-semibold);color:var(--text-primary)}.stat-label{font-size:var(--text-sm);color:var(--text-tertiary)}.loading-spinner{width:18px;height:18px;border:2px solid var(--border-default);border-top-color:var(--text-secondary);border-radius:50%;animation:spin .8s linear infinite}.loading-spinner-sm{width:14px;height:14px;border-width:1.5px}.loading-spinner-lg{width:28px;height:28px;border-width:2.5px}@keyframes spin{to{transform:rotate(360deg)}}.error-message{padding:10px 14px;background:var(--error-bg);border:1px solid var(--color-error-soft);border-radius:var(--radius-md);color:var(--error);font-size:var(--text-sm);display:flex;align-items:center;gap:var(--space-sm)}.success-message{padding:10px 14px;background:var(--success-bg);border:1px solid var(--color-success-soft);border-radius:var(--radius-md);color:var(--success);font-size:var(--text-sm);display:flex;align-items:center;gap:var(--space-sm)}.page-enter-active,.page-leave-active{transition:all .2s ease}.page-enter-from{opacity:0;transform:translateY(6px)}.page-leave-to{opacity:0;transform:translateY(-6px)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-hover);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.empty-icon{width:48px;height:48px;color:var(--text-muted);margin:0 auto 12px;display:flex;align-items:center;justify-content:center}::selection{background:color-mix(in srgb,var(--color-primary) 35%,transparent);color:var(--text-primary)}
