*{box-sizing:border-box}html,body,#app{height:100%;margin:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,PingFang SC,Microsoft YaHei,sans-serif}.layout[data-v-a0c35a0d]{--primary-color: #1890ff;--primary-light: #e6f7ff;--primary-hover: #40a9ff;--sidebar-bg: #001529;--sidebar-hover-bg: #1890ff20;--text-primary: #ffffff;--text-secondary: #b3bccc;--text-placeholder: #86909c;--border-color: #1f2d3d;--bg-main: #f5f5f5;--bg-card: #ffffff;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .06);display:flex;height:100vh;background:var(--bg-main)}[data-v-a0c35a0d]{margin:0;padding:0;box-sizing:border-box}.sidebar[data-v-a0c35a0d]{width:220px;background:var(--sidebar-bg);border-right:1px solid var(--border-color);display:flex;flex-direction:column;flex-shrink:0;transition:all .2s ease}.sidebar-title[data-v-a0c35a0d]{padding:20px 24px;font-size:18px;font-weight:600;color:var(--text-primary);border-bottom:1px solid var(--border-color);background:#000c17}.nav[data-v-a0c35a0d]{flex:1;padding:16px 0;overflow-y:auto}.nav[data-v-a0c35a0d]::-webkit-scrollbar{width:4px}.nav[data-v-a0c35a0d]::-webkit-scrollbar-track{background:#001020}.nav[data-v-a0c35a0d]::-webkit-scrollbar-thumb{background:#1f2d3d;border-radius:2px}.nav[data-v-a0c35a0d]::-webkit-scrollbar-thumb:hover{background:#345}.nav-group[data-v-a0c35a0d]{margin-bottom:12px;padding:0 8px}.nav-group-title[data-v-a0c35a0d]{padding:8px 16px;color:var(--text-placeholder);font-size:12px;font-weight:600;display:flex;align-items:center;cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:4px;margin-bottom:4px;text-transform:uppercase;letter-spacing:.5px}.nav-group-title[data-v-a0c35a0d]:hover{background:var(--sidebar-hover-bg);color:var(--text-secondary)}.nav-group-title .nav-text[data-v-a0c35a0d]{flex:1}.nav-group-arrow[data-v-a0c35a0d]{font-size:10px;color:var(--text-placeholder);transition:transform .2s ease}.nav-group-title.collapsed .nav-group-arrow[data-v-a0c35a0d]{transform:rotate(0)}.nav-group-arrow[data-v-a0c35a0d]{transform:rotate(90deg)}.nav-item[data-v-a0c35a0d]{display:flex;align-items:center;padding:12px 16px;margin:0 8px 4px;color:var(--text-secondary);text-decoration:none;border-radius:4px;transition:all .2s ease;font-size:15px;position:relative}.nav-item[data-v-a0c35a0d]:hover{color:var(--text-primary);background:var(--sidebar-hover-bg)}.nav-item.active[data-v-a0c35a0d]{color:var(--text-primary);background:var(--primary-light)!important;background:var(--sidebar-hover-bg)!important;font-weight:500}.nav-item.active[data-v-a0c35a0d]:before{content:"";position:absolute;left:0;top:0;height:100%;width:3px;background:var(--primary-color);border-radius:0 2px 2px 0}.nav-item.nav-sub[data-v-a0c35a0d]{padding-left:32px;font-size:14px;margin-left:8px;color:#a0a8b0}.nav-item.nav-sub[data-v-a0c35a0d]:hover{color:var(--text-primary)}.main[data-v-a0c35a0d]{flex:1;display:flex;flex-direction:column;min-width:0;background:var(--bg-main)}.header[data-v-a0c35a0d]{height:64px;padding:0 24px;background:var(--bg-card);border-bottom:1px solid #e8e8e8;display:flex;align-items:center;justify-content:space-between;box-shadow:var(--shadow-sm)}.page-title[data-v-a0c35a0d]{font-size:18px;font-weight:600;color:#262626}.header-right[data-v-a0c35a0d]{display:flex;align-items:center;gap:20px}.user[data-v-a0c35a0d]{font-size:14px;color:#555}.btn-logout[data-v-a0c35a0d]{padding:8px 16px;font-size:13px;color:#fff;background:var(--primary-color);border:none;border-radius:4px;cursor:pointer;transition:all .2s ease}.btn-logout[data-v-a0c35a0d]:hover{background:var(--primary-hover);box-shadow:0 2px 4px #1890ff33}.content[data-v-a0c35a0d]{flex:1;overflow:auto;padding:24px}.page-box{background:#fff;border-radius:12px;padding:24px}.page-title{margin:0 0 20px;font-size:18px;font-weight:600;color:#333}.toolbar{display:flex;gap:12px;margin-bottom:16px;flex-wrap:wrap}.search-inp{padding:8px 12px;font-size:14px;border:1px solid #ddd;border-radius:6px;width:200px}.btn{padding:8px 16px;font-size:14px;border-radius:6px;cursor:pointer;border:none}.btn-primary{background:#9b59b6;color:#fff}.btn-default{background:#f0f0f0;color:#333}.btn-sm{padding:6px 12px;font-size:13px}.table-wrap{overflow-x:auto}.data-table{width:100%;border-collapse:collapse;font-size:14px}.data-table th,.data-table td{padding:12px;text-align:left;border-bottom:1px solid #eee}.data-table th{background:#fafafa;font-weight:600;color:#333}.data-table tr:hover{background:#f9f9f9}.tag{display:inline-block;padding:2px 8px;font-size:12px;border-radius:4px}.tag-success{background:#e8f5e9;color:#2e7d32}.tag-warning{background:#fff3e0;color:#e65100}.tag-danger{background:#ffebee;color:#c62828}.tag-info{background:#e3f2fd;color:#1565c0}.empty-tip{padding:40px;text-align:center;color:#999;font-size:14px}.pagination{display:flex;align-items:center;gap:8px;margin-top:16px}.pagination button{padding:6px 12px;font-size:13px;border:1px solid #ddd;background:#fff;border-radius:4px;cursor:pointer}.pagination button:disabled{opacity:.5;cursor:not-allowed}.pagination span{font-size:13px;color:#666}.modal-mask{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a66;display:flex;align-items:center;justify-content:center;z-index:100;padding:24px;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal-dialog{background:#fff;border-radius:14px;box-shadow:0 25px 50px -12px #00000040;max-height:90vh;display:flex;flex-direction:column;min-width:580px;max-width:760px;width:92vw}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid #e5e7eb}.modal-header h2,.modal-header h3{margin:0;font-size:18px;font-weight:600;color:#1e293b}.modal-close{width:32px;height:32px;border:none;background:#f1f5f9;border-radius:6px;font-size:20px;line-height:1;color:#6b7280;cursor:pointer;flex-shrink:0}.modal-close:hover{background:#e2e8f0;color:#374151}.modal-body{padding:24px;overflow-y:auto;flex:1}.modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:16px 24px;border-top:1px solid #e5e7eb;background:#fafbfc}.modal-footer .btn{min-width:80px}.form-row{margin-bottom:16px}.form-row label{display:block;font-size:13px;font-weight:500;color:#374151;margin-bottom:6px}.form-row input,.form-row select,.form-row textarea{width:100%;max-width:100%;padding:8px 12px;border:1px solid #e5e7eb;border-radius:6px;font-size:14px;box-sizing:border-box}.form-row input:focus,.form-row select:focus,.form-row textarea:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1f}.form-actions{margin-top:20px;display:flex;gap:12px;justify-content:flex-end}.form-actions .btn-default{background:#f1f5f9;color:#475569;border:1px solid #e5e7eb}.form-actions .btn-default:hover{background:#e2e8f0}
