:root{--bg-color:#f0f2f5;--text-color:#303133;--sidebar-bg:#324157;--sidebar-hover:#263445;--sidebar-active:#1f2d3d;--primary:#409eff;--primary-hover:#66b1ff;--border:#dcdfe6}*,:after,:before{box-sizing:border-box}body{font-family:Microsoft YaHei,PingFang SC,Helvetica Neue,Arial,sans-serif;background-color:var(--bg-color);color:var(--text-color);font-size:14px}body,ul{margin:0}ul{list-style:none;padding:0}a{text-decoration:none;color:inherit}button{border:none;cursor:pointer}.content-area{padding:1rem}.flex{display:flex}.h-screen{height:100vh}.grid{display:grid}.relative{position:relative}.absolute{position:absolute}.w-64{width:16rem}.w-5{width:1.25rem}.h-5{height:1.25rem}.w-4{width:1rem}.h-4{height:1rem}.w-6{width:1.5rem}.h-6{height:1.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-5{padding:1.25rem}.p-6{padding:1.5rem}.px-4{padding-left:1rem;padding-right:1rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-4{padding-bottom:1rem}.pt-4,.py-4{padding-top:1rem}.pl-10{padding-left:2.5rem}.pr-4{padding-right:1rem}.m-0{margin:0}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mr-2{margin-right:.5rem}.mr-3{margin-right:.75rem}.mr-4{margin-right:1rem}.ml-2{margin-left:.5rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.gap-2{gap:.5rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.bg-white{background-color:#fff}.bg-blue-800{background-color:var(--sidebar-bg)}.bg-blue-600{background-color:var(--primary)}.bg-blue-50{background-color:#eff6ff}.bg-gray-100{background-color:#f3f4f6}.bg-gray-50{background-color:#f9fafb}.bg-green-100{background-color:#dcfce7}.bg-yellow-100{background-color:#fef9c3}.bg-red-100{background-color:#fee2e2}.text-white{color:white}.text-gray-900{color:#111827}.text-gray-800{color:#303133}.text-gray-700{color:#374151}.text-gray-600{color:#4b5563}.text-gray-500{color:#6b7280}.text-gray-400{color:#9ca3af}.text-blue-100{color:#dbeafe}.text-blue-600{color:var(--primary)}.text-blue-700{color:#1d4ed8}.text-red-500{color:#ef4444}.text-red-600{color:#dc2626}.text-yellow-500{color:#eab308}.text-green-500{color:#22c55e}.text-green-600{color:#16a34a}.text-green-800{color:#166534}.text-yellow-800{color:#854d0e}.text-red-800{color:#991b1b}.text-indigo-600{color:#4f46e5}.text-xs{font-size:.75rem}.text-sm{font-size:.875rem}.text-lg{font-size:1.125rem}.text-xl{font-size:1.25rem}.text-2xl{font-size:1.5rem}.text-3xl{font-size:1.875rem}.text-left{text-align:left}.flex-shrink-0{flex-shrink:0}.text-center{text-align:center}.border-b{border-bottom-width:1px}.border-t{border-top-width:1px}.border{border-width:1px}.border-blue-700{border-color:#1d4ed8}.border-gray-100{border-color:#f3f4f6}.border-gray-300{border-color:#d1d5db}.rounded{border-radius:4px}.rounded-lg{border-radius:6px}.rounded-full{border-radius:9999px}.font-bold{font-weight:700}.font-semibold{font-weight:600}.font-medium{font-weight:500}.uppercase{text-transform:uppercase}.tracking-wider{letter-spacing:.05em}.leading-5{line-height:1.25rem}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.flex-1{flex:1 1}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.min-w-full{min-width:100%}.whitespace-nowrap{white-space:nowrap}.overflow-hidden{overflow:hidden}.overflow-y-auto{overflow-y:auto}.shadow{box-shadow:0 1px 2px rgba(0,0,0,.08)}.shadow-md{box-shadow:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -2px rgba(0,0,0,.1)}.transition-shadow{transition:box-shadow .2s ease}.space-y-2>*+*{margin-top:.5rem}.left-3{left:.75rem}.top-2\.5{top:.625rem}.divide-y>*+*{border-top:1px solid #e5e7eb}.divide-gray-200>*+*{border-color:#e5e7eb}.hover\:bg-blue-700:hover{background-color:var(--primary-hover)}.hover\:bg-blue-100:hover{background-color:#dbeafe}.hover\:bg-blue-50:hover{background-color:#eff6ff}.hover\:shadow-lg:hover{box-shadow:0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -4px rgba(0,0,0,.1)}.hover\:shadow-md:hover{box-shadow:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -2px rgba(0,0,0,.1)}.hover\:text-red-700:hover{color:#f56c6c}.hover\:text-red-900:hover{color:#7f1d1d}.hover\:text-indigo-900:hover{color:#312e81}.focus\:outline-none:focus{outline:none}.focus\:ring-2:focus{box-shadow:0 0 0 2px rgba(59,130,246,.35)}.focus\:ring-blue-500:focus{border-color:#3b82f6}@media (min-width:768px){.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (min-width:1024px){.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}}.modal-overlay{position:fixed;inset:0;background:rgba(17,24,39,.45);display:flex;align-items:center;justify-content:center;padding:1rem;z-index:50}.modal-card{width:min(560px,100%);background:#fff;border-radius:6px;padding:1.25rem;box-shadow:0 8px 20px rgba(0,0,0,.16)}.form-grid{display:grid;grid-gap:.75rem;gap:.75rem}.form-label{display:grid;grid-gap:.35rem;gap:.35rem;font-size:.875rem;color:#374151}.form-input{border:1px solid var(--border);border-radius:4px;padding:.55rem .75rem;font-size:14px}.form-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px rgba(64,158,255,.2)}.modal-actions{margin-top:1rem;display:flex;justify-content:flex-end;gap:.5rem}.btn-danger,.btn-primary,.btn-secondary{padding:.55rem .9rem;border-radius:4px;font-size:.875rem;font-weight:600}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-hover)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{background:#fff;border:1px solid var(--border);color:#606266}.btn-danger{background:#f56c6c;color:#fff}.app-shell{background:var(--bg-color)}.sidebar{background:var(--sidebar-bg)}.sidebar-brand{border-bottom:1px solid rgba(255,255,255,.08)}.menu-link{color:#bfcbd9;transition:background-color .2s ease,color .2s ease}.menu-link:hover{background:var(--sidebar-hover);color:#fff}.menu-link-active{background:var(--sidebar-active);color:#fff;border-left:3px solid var(--primary);padding-left:calc(1.5rem - 3px)}.topbar{background:#fff;border-bottom:1px solid #ebeef5}.topbar-logout{color:#f56c6c;background:transparent}.topbar-logout:hover{color:#dd6161}.page-wrap{padding:16px}.page-title{font-size:20px;line-height:28px;font-weight:600;color:#303133;margin:0 0 16px}.panel{background:#fff;border:1px solid #ebeef5;border-radius:6px}.table-container{overflow-x:auto}.table{width:100%;border-collapse:collapse}.table td,.table th{padding:12px 16px;text-align:left;border-bottom:1px solid #ebeef5}.table th{color:#606266;font-weight:600}.table th,.table tr:hover{background-color:#f5f7fa}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2)}.login-card{background:#fff;padding:2.5rem;border-radius:8px;box-shadow:0 8px 32px rgba(0,0,0,.15);width:100%;max-width:400px}.login-title{text-align:center;color:#303133;margin-bottom:2rem;font-size:1.5rem}.form-group{margin-bottom:1.25rem}.form-group label{display:block;margin-bottom:.5rem;color:#606266;font-size:.875rem}.error-message{color:#f56c6c;background:#fef0f0;padding:.75rem;border-radius:4px;margin-bottom:1rem;font-size:.875rem}.login-btn{width:100%;margin-top:.5rem}