.dashboard-layout[data-v-dbda04ba]{display:flex;min-height:100vh}.sidebar[data-v-dbda04ba]{width:var(--sidebar-width);background-color:var(--color-primary-dark);color:#fff;display:flex;flex-direction:column;transition:width .2s;position:fixed;top:0;left:0;bottom:0;z-index:100}.sidebar.collapsed[data-v-dbda04ba]{width:60px}.sidebar-header[data-v-dbda04ba]{height:var(--header-height);display:flex;align-items:center;padding:0 16px;border-bottom:1px solid rgba(255,255,255,.1)}.logo[data-v-dbda04ba]{font-size:20px;font-weight:700;color:#fff}.logo-text[data-v-dbda04ba]{margin-left:8px;font-size:14px;white-space:nowrap}.sidebar-nav[data-v-dbda04ba]{flex:1;padding:16px 0;overflow-y:auto}.nav-item[data-v-dbda04ba]{display:flex;align-items:center;padding:12px 16px;color:#ffffffb3;transition:all .2s;text-decoration:none}.nav-item[data-v-dbda04ba]:hover{background-color:#ffffff1a;color:#fff}.nav-item.active[data-v-dbda04ba]{background-color:#ffffff26;color:#fff;border-left:3px solid #fff}.nav-icon[data-v-dbda04ba]{font-size:18px;width:28px;text-align:center}.nav-text[data-v-dbda04ba]{margin-left:8px;white-space:nowrap}.sidebar-footer[data-v-dbda04ba]{padding:16px;border-top:1px solid rgba(255,255,255,.1)}.collapse-btn[data-v-dbda04ba]{width:100%;padding:8px;background:#ffffff1a;border:none;color:#fff;cursor:pointer;border-radius:var(--border-radius)}.collapse-btn[data-v-dbda04ba]:hover{background:#fff3}.main-wrapper[data-v-dbda04ba]{flex:1;margin-left:var(--sidebar-width);transition:margin-left .2s;min-height:100vh;display:flex;flex-direction:column}.sidebar.collapsed+.main-wrapper[data-v-dbda04ba]{margin-left:60px}.header[data-v-dbda04ba]{height:var(--header-height);background-color:var(--color-bg-white);border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between;padding:0 24px;position:sticky;top:0;z-index:50}.page-title[data-v-dbda04ba]{font-size:18px;font-weight:500;color:var(--color-text)}.header-right[data-v-dbda04ba]{display:flex;align-items:center;gap:16px}.user-info[data-v-dbda04ba]{display:flex;align-items:center;gap:8px}.user-avatar[data-v-dbda04ba]{width:32px;height:32px;border-radius:50%;object-fit:cover}.user-name[data-v-dbda04ba]{font-weight:500}.main-content[data-v-dbda04ba]{flex:1;padding:24px}*{margin:0;padding:0;box-sizing:border-box}:root{--color-primary: #333333;--color-primary-light: #555555;--color-primary-dark: #1a1a1a;--color-bg: #f5f5f5;--color-bg-white: #ffffff;--color-bg-dark: #e8e8e8;--color-text: #333333;--color-text-light: #666666;--color-text-muted: #999999;--color-border: #e0e0e0;--color-border-light: #f0f0f0;--color-success: #52c41a;--color-warning: #faad14;--color-danger: #ff4d4f;--color-info: #666666;--sidebar-width: 220px;--header-height: 56px;--border-radius: 4px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 2px 4px rgba(0, 0, 0, .08)}html,body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif;font-size:14px;line-height:1.5;color:var(--color-text);background-color:var(--color-bg);-webkit-font-smoothing:antialiased}a{color:var(--color-primary);text-decoration:none}a:hover{color:var(--color-primary-light)}.btn{display:inline-flex;align-items:center;justify-content:center;padding:8px 16px;font-size:14px;font-weight:500;border:1px solid transparent;border-radius:var(--border-radius);cursor:pointer;transition:all .2s;white-space:nowrap}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background-color:var(--color-primary);color:#fff}.btn-primary:hover:not(:disabled){background-color:var(--color-primary-light)}.btn-secondary{background-color:var(--color-bg-white);color:var(--color-text);border-color:var(--color-border)}.btn-secondary:hover:not(:disabled){background-color:var(--color-bg-dark)}.btn-danger{background-color:var(--color-danger);color:#fff}.btn-danger:hover:not(:disabled){background-color:#ff7875}.btn-sm{padding:4px 12px;font-size:13px}.btn-lg{padding:12px 24px;font-size:16px}.form-group{margin-bottom:16px}.form-label{display:block;margin-bottom:6px;font-weight:500;color:var(--color-text)}.form-input,.form-select,.form-textarea{width:100%;padding:8px 12px;font-size:14px;border:1px solid var(--color-border);border-radius:var(--border-radius);background-color:var(--color-bg-white);transition:border-color .2s}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--color-primary)}.form-input::placeholder{color:var(--color-text-muted)}.form-textarea{min-height:100px;resize:vertical}.table{width:100%;border-collapse:collapse;background-color:var(--color-bg-white)}.table th,.table td{padding:12px 16px;text-align:left;border-bottom:1px solid var(--color-border-light)}.table th{font-weight:500;color:var(--color-text-light);background-color:var(--color-bg)}.table tr:hover td{background-color:var(--color-bg)}.card{background-color:var(--color-bg-white);border-radius:var(--border-radius);box-shadow:var(--shadow-sm)}.card-header{padding:16px 20px;border-bottom:1px solid var(--color-border-light);font-weight:500}.card-body{padding:20px}.tag{display:inline-flex;align-items:center;padding:2px 8px;font-size:12px;border-radius:2px;background-color:var(--color-bg);color:var(--color-text-light)}.tag-primary{background-color:var(--color-primary);color:#fff}.tag-success{background-color:#f6ffed;color:var(--color-success)}.tag-warning{background-color:#fffbe6;color:var(--color-warning)}.tag-danger{background-color:#fff2f0;color:var(--color-danger)}.status{display:inline-flex;align-items:center;gap:6px;font-size:13px}.status:before{content:"";width:6px;height:6px;border-radius:50%;background-color:currentColor}.status-success{color:var(--color-success)}.status-warning{color:var(--color-warning)}.status-danger{color:var(--color-danger)}.status-default{color:var(--color-text-muted)}.pagination{display:flex;align-items:center;gap:8px;margin-top:16px}.pagination-btn{padding:6px 12px;border:1px solid var(--color-border);border-radius:var(--border-radius);background-color:var(--color-bg-white);cursor:pointer;transition:all .2s}.pagination-btn:hover:not(:disabled){border-color:var(--color-primary)}.pagination-btn.active{background-color:var(--color-primary);border-color:var(--color-primary);color:#fff}.pagination-info{color:var(--color-text-muted);font-size:13px}.empty{padding:60px 20px;text-align:center;color:var(--color-text-muted)}.empty-icon{font-size:48px;margin-bottom:16px;opacity:.3}.loading{display:flex;align-items:center;justify-content:center;padding:40px}.loading-spinner{width:24px;height:24px;border:2px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.message{padding:12px 16px;border-radius:var(--border-radius);margin-bottom:16px}.message-success{background-color:#f6ffed;border:1px solid #b7eb8f;color:var(--color-success)}.message-warning{background-color:#fffbe6;border:1px solid #ffe58f;color:var(--color-warning)}.message-error{background-color:#fff2f0;border:1px solid #ffccc7;color:var(--color-danger)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background-color:#0006;display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background-color:var(--color-bg-white);border-radius:var(--border-radius);box-shadow:var(--shadow-md);max-width:500px;width:90%;max-height:90vh;overflow:auto}.modal-header{padding:16px 20px;border-bottom:1px solid var(--color-border-light);display:flex;align-items:center;justify-content:space-between}.modal-title{font-size:16px;font-weight:500}.modal-close{background:none;border:none;font-size:20px;cursor:pointer;color:var(--color-text-muted);padding:0;line-height:1}.modal-close:hover{color:var(--color-text)}.modal-body{padding:20px}.modal-footer{padding:16px 20px;border-top:1px solid var(--color-border-light);display:flex;justify-content:flex-end;gap:12px}.text-center{text-align:center}.text-right{text-align:right}.text-muted{color:var(--color-text-muted)}.text-success{color:var(--color-success)}.text-warning{color:var(--color-warning)}.text-danger{color:var(--color-danger)}.mt-1{margin-top:8px}.mt-2{margin-top:16px}.mt-3{margin-top:24px}.mb-1{margin-bottom:8px}.mb-2{margin-bottom:16px}.mb-3{margin-bottom:24px}.flex{display:flex}.flex-1{flex:1}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-1{gap:8px}.gap-2{gap:16px}
