*{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-a1643f9f]{display:flex;height:100vh;background:#f0f2f5}.sidebar[data-v-a1643f9f]{width:240px;background:linear-gradient(180deg,#1e1b2e,#16213e,#0f0f23);color:#e8e6f0;display:flex;flex-direction:column;box-shadow:4px 0 24px #0000001f;flex-shrink:0}.sidebar-title[data-v-a1643f9f]{padding:24px 20px;font-size:20px;font-weight:700;letter-spacing:.5px;color:#fff;border-bottom:1px solid rgba(255,255,255,.08);background:#ffffff08}.nav[data-v-a1643f9f]{flex:1;padding:12px 12px 24px;overflow-y:auto}.nav[data-v-a1643f9f]::-webkit-scrollbar{width:6px}.nav[data-v-a1643f9f]::-webkit-scrollbar-track{background:#ffffff0a;border-radius:3px}.nav[data-v-a1643f9f]::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:3px}.nav-item[data-v-a1643f9f]{display:flex;align-items:center;padding:12px 16px;margin-bottom:4px;color:#b8b5c4;text-decoration:none;border-radius:10px;transition:all .2s ease;font-size:14px}.nav-item[data-v-a1643f9f]:hover{color:#fff;background:#9b59b640}.nav-item.active[data-v-a1643f9f]{color:#fff;background:linear-gradient(135deg,#9b59b680,#7d3c9866);box-shadow:0 2px 12px #9b59b64d}.nav-item.nav-sub[data-v-a1643f9f]{padding-left:20px;margin-left:12px;border-left:2px solid rgba(255,255,255,.1);font-size:13px}.nav-item.nav-sub.active[data-v-a1643f9f]{border-left-color:#9b59b6}.nav-group[data-v-a1643f9f]{margin-bottom:8px}.nav-group-title[data-v-a1643f9f]{padding:14px 16px 8px;color:#7a7690;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.8px;display:flex;align-items:center}.nav-group-title .nav-icon[data-v-a1643f9f]{margin-right:10px;font-size:15px;opacity:.9}.nav-group-title .nav-text[data-v-a1643f9f]{font-size:12px}.nav-icon[data-v-a1643f9f]{margin-right:12px;font-size:18px;line-height:1;opacity:.95}.nav-text[data-v-a1643f9f]{font-size:14px;font-weight:500}.main[data-v-a1643f9f]{flex:1;display:flex;flex-direction:column;min-width:0;background:#f0f2f5}.header[data-v-a1643f9f]{height:60px;padding:0 28px;background:#fff;box-shadow:0 1px 8px #0000000f;display:flex;align-items:center;justify-content:space-between}.page-title[data-v-a1643f9f]{font-size:18px;font-weight:600;color:#1a1a2e}.header-right[data-v-a1643f9f]{display:flex;align-items:center;gap:16px}.user[data-v-a1643f9f]{font-size:14px;color:#555}.btn-logout[data-v-a1643f9f]{padding:8px 16px;font-size:13px;color:#555;background:#f5f5f5;border:none;border-radius:8px;cursor:pointer;transition:background .2s}.btn-logout[data-v-a1643f9f]:hover{background:#e8e8e8;color:#333}.content[data-v-a1643f9f]{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}
