*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth;font-size:16px}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6;color:#0f172a;background-color:#f8fafc;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@import url("https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap");.min-h-screen{min-height:100vh}.flex{display:flex}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.flex-1{flex:1 1}.flex-col{flex-direction:column}.space-y-8>*+*{margin-top:2rem}.space-y-6>*+*{margin-top:1.5rem}.space-y-4>*+*{margin-top:1rem}.space-y-2>*+*{margin-top:.5rem}.space-x-4>*+*{margin-left:1rem}.space-x-3>*+*{margin-left:.75rem}.space-x-2>*+*{margin-left:.5rem}.table{width:100%;border-collapse:collapse}.table-header{background-color:#f9fafb}.table-header-cell{padding:.75rem 1rem;text-align:left;font-size:.875rem;font-weight:600;color:#374151;border-bottom:1px solid #e5e7eb}.table-body{background-color:#ffffff}.table-row{border-bottom:1px solid #f3f4f6;transition:background-color .15s}.table-row:hover{background-color:#f9fafb}.table-cell{padding:.75rem 1rem;font-size:.875rem;color:#374151;border-bottom:1px solid #f3f4f6}.form-select{display:block;width:100%;border-radius:.5rem;border:1px solid #d1d5db;background-color:#ffffff;padding:.5rem .75rem;font-size:.875rem;color:#111827;transition:all .15s}.form-select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 1px #3b82f6}.page-header{margin-bottom:1.5rem}.grid{display:grid}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.gap-6{gap:1.5rem}.gap-4{gap:1rem}.p-8{padding:2rem}.p-6{padding:1.5rem}.p-4{padding:1rem}.p-2{padding:.5rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.px-4{padding-left:1rem;padding-right:1rem}.px-3{padding-left:.75rem;padding-right:.75rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-12{padding-top:3rem;padding-bottom:3rem}.mb-8{margin-bottom:2rem}.mb-6{margin-bottom:1.5rem}.mb-4{margin-bottom:1rem}.mb-2{margin-bottom:.5rem}.mt-6{margin-top:1.5rem}.mt-2{margin-top:.5rem}.mr-2{margin-right:.5rem}.mr-3{margin-right:.75rem}.w-full{width:100%}.w-64{width:16rem}.h-16{height:4rem}.h-12{height:3rem}.h-8{height:2rem}.h-5{height:1.25rem}.h-4{height:1rem}.max-w-md{max-width:28rem}.max-w-7xl{max-width:80rem}.bg-white{background-color:#ffffff}.bg-gray-50{background-color:#f9fafb}.bg-gray-100{background-color:#f3f4f6}.bg-gray-200{background-color:#e5e7eb}.bg-blue-50{background-color:#eff6ff}.bg-blue-100{background-color:#dbeafe}.bg-blue-600{background-color:#2563eb}.bg-blue-700{background-color:#1d4ed8}.bg-green-100{background-color:#dcfce7}.bg-green-600{background-color:#16a34a}.bg-red-100{background-color:#fee2e2}.bg-red-600{background-color:#dc2626}.bg-yellow-100{background-color:#fef3c7}.bg-yellow-600{background-color:#d97706}.bg-purple-100{background-color:#e9d5ff}.bg-purple-600{background-color:#9333ea}.text-white{color:#ffffff}.text-gray-500{color:#6b7280}.text-gray-600{color:#4b5563}.text-gray-700{color:#374151}.text-gray-800{color:#1f2937}.text-gray-900{color:#111827}.text-blue-600{color:#2563eb}.text-blue-700{color:#1d4ed8}.text-green-600{color:#16a34a}.text-green-800{color:#166534}.text-red-600{color:#dc2626}.text-red-800{color:#991b1b}.text-yellow-600{color:#d97706}.text-yellow-800{color:#92400e}.text-purple-600{color:#9333ea}.border-gray-200{border-color:#e5e7eb}.border-gray-300{border-color:#d1d5db}.border-red-200{border-color:#fecaca}.border-blue-500{border-color:#3b82f6}.text-xs{font-size:.75rem;line-height:1rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-base{font-size:1rem;line-height:1.5rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-2xl{font-size:1.5rem;line-height:2rem}.text-3xl{font-size:1.875rem;line-height:2.25rem}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.font-mono{font-family:ui-monospace,SFMono-Regular,monospace}.border{border-width:1px}.rounded-lg{border-radius:.5rem}.rounded-xl{border-radius:.75rem}.rounded-2xl{border-radius:1rem}.rounded-full{border-radius:9999px}.shadow-sm{box-shadow:0 1px 2px 0 rgb(0 0 0/.05)}.shadow-lg{box-shadow:0 10px 15px -3px rgb(0 0 0/.1),0 4px 6px -4px rgb(0 0 0/.1)}.shadow-xl{box-shadow:0 20px 25px -5px rgb(0 0 0/.1),0 8px 10px -6px rgb(0 0 0/.1)}.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-colors{transition-property:color,background-color,border-color,fill,stroke,-webkit-text-decoration-color;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,-webkit-text-decoration-color;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-transform{transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.duration-200{transition-duration:.2s}.duration-300{transition-duration:.3s}.hover\:bg-gray-50:hover{background-color:#f9fafb}.hover\:bg-gray-100:hover{background-color:#f3f4f6}.hover\:bg-blue-700:hover{background-color:#1d4ed8}.hover\:text-gray-900:hover{color:#111827}.hover\:shadow-md:hover{box-shadow:0 4px 6px -1px rgb(0 0 0/.1),0 2px 4px -2px rgb(0 0 0/.1)}.hover\:shadow-lg:hover{box-shadow:0 10px 15px -3px rgb(0 0 0/.1),0 4px 6px -4px rgb(0 0 0/.1)}.hover\:scale-110:hover{transform:scale(1.1)}.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}.focus\:ring-1:focus{box-shadow:0 0 0 1px #3b82f6}.focus\:ring-2:focus{box-shadow:0 0 0 2px #3b82f6}.focus\:ring-blue-500:focus{box-shadow:0 0 0 1px #3b82f6}.focus\:border-blue-500:focus{border-color:#3b82f6}.disabled\:opacity-50:disabled{opacity:.5}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.animate-spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.bg-gradient-to-br{background-image:linear-gradient(to bottom right,var(--tw-gradient-stops))}.bg-gradient-to-r{background-image:linear-gradient(to right,var(--tw-gradient-stops))}.from-blue-50{--tw-gradient-from:#eff6ff;--tw-gradient-to:rgb(239 246 255/0);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.to-indigo-50{--tw-gradient-to:#eef2ff}.from-blue-600{--tw-gradient-from:#2563eb;--tw-gradient-to:rgb(37 98 235/0);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.to-blue-700{--tw-gradient-to:#1d4ed8}.sidebar{background-color:#ffffff;border-right:1px solid #e5e7eb;width:16rem;height:100vh;position:fixed;left:0;top:0;z-index:40}.main-content{margin-left:16rem;min-height:100vh;display:flex;flex-direction:column}.main-header{background-color:#ffffff;border-bottom:1px solid #e5e7eb;padding:1rem 1.5rem;display:flex;align-items:center;justify-content:space-between}.main-body{flex:1 1;padding:1.5rem;overflow-y:auto}.btn{display:inline-flex;align-items:center;justify-content:center;border-radius:.5rem;font-weight:500;transition:all .2s;border:none;cursor:pointer}.btn:focus{outline:2px solid transparent;outline-offset:2px;box-shadow:0 0 0 2px #3b82f6}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-sm{padding:.25rem .5rem;font-size:.75rem;border-radius:.375rem}.btn-primary{background-color:#2563eb;color:#ffffff;padding:.5rem 1rem;font-size:.875rem}.btn-primary:hover{background-color:#1d4ed8}.btn-secondary{background-color:#ffffff;color:#374151;border:1px solid #d1d5db;padding:.5rem 1rem;font-size:.875rem}.btn-secondary:hover{background-color:#f9fafb}.btn-ghost{color:#4b5563;padding:.5rem 1rem;font-size:.875rem}.btn-ghost:hover{color:#111827;background-color:#f3f4f6}.card{background-color:#ffffff;border-radius:.75rem;box-shadow:0 1px 2px 0 rgb(0 0 0/.05);border:1px solid rgba(229,231,235,.6)}.card-hover{transition:all .3s}.card-hover:hover{box-shadow:0 10px 15px -3px rgb(0 0 0/.1),0 4px 6px -4px rgb(0 0 0/.1);border-color:rgba(209,213,219,.6)}.badge{display:inline-flex;align-items:center;border-radius:9999px;padding:.125rem .625rem;font-size:.75rem;font-weight:500}.badge-success{background-color:#dcfce7;color:#166534}.badge-warning{background-color:#fef3c7;color:#92400e}.badge-danger{background-color:#fee2e2;color:#991b1b}.badge-info{background-color:#dbeafe;color:#1e40af}.badge-gray{background-color:#f3f4f6;color:#1f2937}.nav-link{display:flex;align-items:center;border-radius:.5rem;padding:.5rem .75rem;font-size:.875rem;font-weight:500;transition:all .2s;text-decoration:none}.nav-link-active{background-color:#dbeafe;color:#1d4ed8}.nav-link-inactive{color:#4b5563}.nav-link-inactive:hover{background-color:#f3f4f6;color:#111827}.form-input{display:block;width:100%;border-radius:.5rem;border:1px solid #d1d5db;background-color:#ffffff;padding:.5rem .75rem;font-size:.875rem;color:#111827;transition:all .15s}.form-input::placeholder{color:#9ca3af}.form-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 1px #3b82f6}.form-label{display:block;font-size:.875rem;font-weight:500;color:#374151;margin-bottom:.5rem}.alert{border-radius:.5rem;border:1px solid;padding:1rem}.alert-danger{background-color:#fef2f2;border-color:#fecaca;color:#991b1b}.alert-success{background-color:#f0fdf4;border-color:#bbf7d0;color:#166534}.alert-warning{background-color:#fffbeb;border-color:#fed7aa;color:#92400e}.alert-info{background-color:#eff6ff;border-color:#bfdbfe;color:#1e40af}.page-title{font-size:1.875rem;font-weight:700;color:#111827}.page-subtitle{color:#6b7280;margin-top:.5rem}.stat-card{background-color:#ffffff;border-radius:.75rem;box-shadow:0 1px 2px 0 rgb(0 0 0/.05);border:1px solid rgba(229,231,235,.6);padding:1.5rem;transition:all .3s}.stat-card:hover{box-shadow:0 10px 15px -3px rgb(0 0 0/.1),0 4px 6px -4px rgb(0 0 0/.1);border-color:rgba(209,213,219,.6)}.stat-icon{height:3rem;width:3rem;border-radius:.75rem;display:flex;align-items:center;justify-content:center;transition:transform .2s}.stat-value{font-size:1.5rem;font-weight:700;color:#111827}.stat-label{font-size:.875rem;font-weight:500;color:#6b7280}.stat-change-positive{color:#16a34a;font-size:.875rem;font-weight:600}.stat-change-negative{color:#dc2626;font-size:.875rem;font-weight:600}@media (min-width:768px){.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (min-width:1024px){.lg\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.lg\:px-8{padding-left:2rem;padding-right:2rem}.lg\:hidden{display:none}}@media (max-width:1023px){.lg\:block{display:none}.main-content{margin-left:0}.sidebar{transform:translateX(-100%)}.sidebar.open{transform:translateX(0)}}@media (min-width:640px){.sm\:px-6{padding-left:1.5rem;padding-right:1.5rem}}.mobile-menu-overlay{position:fixed;inset:0;z-index:40;background-color:rgba(0,0,0,.5)}.mobile-sidebar{position:fixed;inset-y:0;left:0;z-index:50;width:16rem;background-color:#ffffff;box-shadow:0 20px 25px -5px rgb(0 0 0/.1);transform:translateX(-100%);transition:transform .3s ease-in-out}.mobile-sidebar.open{transform:translateX(0)}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.relative{position:relative}.absolute{position:absolute}.fixed{position:fixed}.inset-0{right:0;left:0}.inset-0,.inset-y-0{top:0;bottom:0}.left-0{left:0}.top-0{top:0}.z-40{z-index:40}.z-50{z-index:50}.overflow-hidden{overflow:hidden}.overflow-y-auto{overflow-y:auto}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.uppercase{text-transform:uppercase}.tracking-wider{letter-spacing:.05em}.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}