*{box-sizing:border-box;margin:0;padding:0}:root{--primary-color:#2563eb;--primary-dark:#1e40af;--success-color:#10b981;--danger-color:#ef4444;--warning-color:#f59e0b;--text-primary:#111827;--text-secondary:#6b7280;--border-color:#e5e7eb;--bg-primary:#fff;--bg-secondary:#f9fafb;--bg-hover:#f3f4f6}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif,Microsoft YaHei,微软雅黑;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--bg-secondary);color:var(--text-primary);line-height:1.6}a{color:inherit;text-decoration:none}button{cursor:pointer;border:none}button,input,select,textarea{font-family:inherit;outline:none}.container{max-width:1400px;margin:0 auto;padding:20px}.btn{display:inline-flex;align-items:center;justify-content:center;padding:10px 20px;font-size:14px;font-weight:500;border-radius:6px;transition:all .2s;gap:8px}.btn-primary{background-color:var(--primary-color);color:#fff}.btn-primary:hover{background-color:var(--primary-dark)}.btn-success{background-color:var(--success-color);color:#fff}.btn-success:hover{opacity:.9}.btn-danger{background-color:var(--danger-color);color:#fff}.btn-danger:hover{opacity:.9}.btn-secondary{background-color:var(--bg-hover);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover{background-color:#e5e7eb}.btn-sm{padding:6px 12px;font-size:13px}.form-group{margin-bottom:20px}.form-label{display:block;margin-bottom:8px;font-weight:500;font-size:14px;color:var(--text-primary)}.form-input,.form-select{width:100%;padding:10px 12px;font-size:14px;border:1px solid var(--border-color);border-radius:6px;background-color:#fff;transition:border-color .2s}.form-input:focus,.form-select:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px rgba(37,99,235,.1)}.card{padding:24px}.card,.table-container{background-color:#fff;border-radius:8px;box-shadow:0 1px 3px rgba(0,0,0,.1)}.table-container{overflow-x:auto}table{width:100%;border-collapse:collapse}thead{background-color:var(--bg-secondary)}td,th{padding:12px 16px;text-align:left;border-bottom:1px solid var(--border-color);font-size:14px}th{font-weight:600;color:var(--text-secondary);text-transform:uppercase;font-size:12px;letter-spacing:.5px}tbody tr:hover{background-color:var(--bg-hover)}.badge{display:inline-block;padding:4px 10px;font-size:12px;font-weight:500;border-radius:12px;line-height:1}.badge-success{background-color:#d1fae5;color:#065f46}.badge-danger{background-color:#fee2e2;color:#991b1b}.badge-warning{background-color:#fef3c7;color:#92400e}.badge-info{background-color:#dbeafe;color:#1e40af}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal{background-color:#fff;border-radius:12px;padding:24px;max-width:500px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 25px -5px rgba(0,0,0,.1)}.modal-header{margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--border-color)}.modal-title{font-size:20px;font-weight:600}.modal-footer{margin-top:24px;padding-top:16px;border-top:1px solid var(--border-color);display:flex;gap:12px;justify-content:flex-end}.spinner{border-top:3px solid var(--border-color);border:3px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;width:24px;height:24px;animation:spin .8s linear infinite}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:8px}.gap-4{gap:16px}.mb-4{margin-bottom:16px}.text-center{text-align:center}.text-sm{font-size:14px}.text-danger{color:var(--danger-color)}.text-success{color:var(--success-color)}