*{margin:0;padding:0;box-sizing:border-box}body{font-family:system-ui,-apple-system,sans-serif;line-height:1.5;color:#111827;background-color:#f9fafb}.btn-primary{background-color:#2563eb;color:#fff;font-weight:500;padding:.5rem 1rem;border-radius:.5rem;border:none;cursor:pointer;transition:background-color .2s}.btn-primary:hover{background-color:#1d4ed8}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background-color:#e5e7eb;color:#374151;font-weight:500;padding:.5rem 1rem;border-radius:.5rem;border:none;cursor:pointer;transition:background-color .2s}.btn-secondary:hover{background-color:#d1d5db}.btn-secondary:disabled{opacity:.5;cursor:not-allowed}.btn-danger{background-color:#dc2626;color:#fff;font-weight:500;padding:.5rem 1rem;border-radius:.5rem;border:none;cursor:pointer;transition:background-color .2s}.btn-danger:hover{background-color:#b91c1c}.btn-danger:disabled{opacity:.5;cursor:not-allowed}.input-field{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:.5rem;font-size:1rem;transition:border-color .2s,box-shadow .2s}.input-field:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.card{background-color:#fff;border-radius:.75rem;box-shadow:0 1px 3px #0000001a;border:1px solid #e5e7eb;padding:1.5rem}.status-indicator{display:inline-flex;align-items:center;padding:.25rem .625rem;border-radius:9999px;font-size:.75rem;font-weight:500}.status-online{background-color:#dcfce7;color:#166534}.status-offline{background-color:#fee2e2;color:#991b1b}.sidebar-link{display:flex;align-items:center;padding:.5rem 1rem;color:#374151;text-decoration:none;border-radius:.5rem;transition:background-color .2s,color .2s;cursor:pointer;border:none;background:none;width:100%;text-align:left}.sidebar-link:hover{background-color:#f3f4f6;color:#111827}.sidebar-link.active{background-color:#dbeafe;color:#1e40af;font-weight:500}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.font-bold{font-weight:700}.font-semibold{font-weight:600}.font-medium{font-weight:500}.text-xs{font-size:.75rem}.text-sm{font-size:.875rem}.text-base{font-size:1rem}.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-gray-400{color:#9ca3af}.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-red-600{color:#dc2626}.text-red-700{color:#b91c1c}.text-green-800{color:#166534}.bg-white{background-color:#fff}.bg-gray-100{background-color:#f3f4f6}.bg-gray-200{background-color:#e5e7eb}.bg-red-50{background-color:#fef2f2}.bg-green-100{background-color:#dcfce7}.bg-blue-100{background-color:#dbeafe}.bg-purple-100{background-color:#ede9fe}.bg-yellow-100{background-color:#fef3c7}.bg-green-500{background-color:#22c55e}.bg-primary-600{background-color:#2563eb}.bg-primary-700{background-color:#1d4ed8}.bg-primary-100{background-color:#dbeafe}.border{border-width:1px}.border-red-200{border-color:#fecaca}.rounded{border-radius:.25rem}.rounded-sm{border-radius:.125rem}.rounded-lg{border-radius:.5rem}.rounded-xl{border-radius:.75rem}.rounded-full{border-radius:9999px}.shadow-sm{box-shadow:0 1px 2px #0000000d}.shadow-lg{box-shadow:0 10px 15px -3px #0000001a}.p-2{padding:.5rem}.p-4{padding:1rem}.p-6{padding:1.5rem}.px-3{padding-left:.75rem;padding-right:.75rem}.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-top:1rem;padding-bottom:1rem}.py-12{padding-top:3rem;padding-bottom:3rem}.m-2{margin:.5rem}.m-4{margin:1rem}.mb-2{margin-bottom:.5rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.mt-8{margin-top:2rem}.mr-2{margin-right:.5rem}.mr-3{margin-right:.75rem}.ml-4{margin-left:1rem}.w-2{width:.5rem}.w-8{width:2rem}.w-10{width:2.5rem}.w-12{width:3rem}.w-64{width:16rem}.w-full{width:100%}.h-2{height:.5rem}.h-4{height:1rem}.h-8{height:2rem}.h-10{height:2.5rem}.h-12{height:3rem}.h-full{height:100%}.h-screen{height:100vh}.min-h-screen{min-height:100vh}.min-w-0{min-width:0}.max-w-md{max-width:28rem}.aspect-square{aspect-ratio:1 / 1}.w-3{width:.75rem}.h-3{height:.75rem}.flex{display:flex}.flex-1{flex:1 1 0%}.flex-shrink-0{flex-shrink:0}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.space-y-1>*+*{margin-top:.25rem}.space-y-2>*+*{margin-top:.5rem}.space-y-3>*+*{margin-top:.75rem}.space-y-4>*+*{margin-top:1rem}.space-y-6>*+*{margin-top:1.5rem}.space-y-8>*+*{margin-top:2rem}.space-x-3>*+*{margin-left:.75rem}.space-x-4>*+*{margin-left:1rem}.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))}.grid-cols-12{grid-template-columns:repeat(12,minmax(0,1fr))}.gap-1{gap:.25rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.overflow-hidden{overflow:hidden}.overflow-y-auto{overflow-y:auto}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.uppercase{text-transform:uppercase}.capitalize{text-transform:capitalize}.block{display:block}.inline-flex{display:inline-flex}.relative{position:relative}.transition-colors{transition-property:color,background-color,border-color}.transition-all{transition-property:all}.duration-200{transition-duration:.2s}.hover\:bg-gray-50:hover{background-color:#f9fafb}.hover\:bg-blue-50:hover{background-color:#eff6ff}.hover\:shadow-sm:hover{box-shadow:0 1px 2px #0000000d}.hover\:text-gray-900:hover{color:#111827}.cursor-pointer{cursor:pointer}.animate-spin{animation:spin 1s linear infinite}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes data-update{0%{background-color:#dbeafe}to{background-color:transparent}}.animate-data-update{animation:data-update .5s ease-out}.mobile-nav{display:block}.desktop-nav{display:none}.mobile-only{display:block}.desktop-only{display:none}.touch-target{min-height:44px;min-width:44px}.mobile-padding{padding:1rem}.mobile-margin{margin:.5rem}.mobile-full{width:100vw}.mobile-stack{flex-direction:column}.mobile-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}.mobile-fixed{position:fixed;top:0;left:0;right:0;z-index:1000}.mobile-text-sm{font-size:.875rem}.mobile-text-base{font-size:1rem}.mobile-text-lg{font-size:1.125rem}.mobile-p-2{padding:.5rem}.mobile-p-4{padding:1rem}.mobile-px-4{padding-left:1rem;padding-right:1rem}.mobile-py-2{padding-top:.5rem;padding-bottom:.5rem}.mobile-py-4{padding-top:1rem;padding-bottom:1rem}.mobile-m-2{margin:.5rem}.mobile-mx-4{margin-left:1rem;margin-right:1rem}.mobile-mt-4{margin-top:1rem}.mobile-mb-4{margin-bottom:1rem}.mobile-overlay{position:fixed;inset:0;background-color:#00000080;z-index:999}.mobile-sidebar{position:fixed;top:0;left:0;height:100vh;width:280px;background-color:#fff;z-index:1000;transform:translate(-100%);transition:transform .3s ease-in-out;box-shadow:2px 0 4px #0000001a}.mobile-sidebar.open{transform:translate(0)}.hamburger{display:flex;flex-direction:column;justify-content:space-around;width:24px;height:24px;background:transparent;border:none;cursor:pointer;padding:0}.hamburger span{width:24px;height:2px;background:currentColor;border-radius:1px;transition:all .3s linear;position:relative;transform-origin:1px}.hamburger.open span:first-child{transform:rotate(45deg)}.hamburger.open span:nth-child(2){opacity:0}.hamburger.open span:nth-child(3){transform:rotate(-45deg)}@media (min-width: 640px){.sm\:px-6{padding-left:1.5rem;padding-right:1.5rem}.sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.sm\:text-sm{font-size:.875rem}.sm\:text-base{font-size:1rem}.sm\:p-6{padding:1.5rem}.sm\:space-x-4>*+*{margin-left:1rem}.sm\:flex-row{flex-direction:row}.sm\:justify-between{justify-content:space-between}}@media (min-width: 768px){.mobile-nav{display:none}.desktop-nav{display:block}.mobile-only{display:none}.desktop-only{display:block}.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.md\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.md\:flex{display:flex}.md\:flex-row{flex-direction:row}.md\:items-center{align-items:center}.md\:justify-between{justify-content:space-between}.md\:p-6{padding:1.5rem}.md\:px-6{padding-left:1.5rem;padding-right:1.5rem}.md\:py-4{padding-top:1rem;padding-bottom:1rem}.md\:space-x-6>*+*{margin-left:1.5rem}.md\:space-y-0>*+*{margin-top:0}.md\:w-auto{width:auto}.md\:text-left{text-align:left}}@media (min-width: 1024px){.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.lg\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.lg\:px-8{padding-left:2rem;padding-right:2rem}.lg\:py-6{padding-top:1.5rem;padding-bottom:1.5rem}.lg\:space-x-8>*+*{margin-left:2rem}}@media (min-width: 1280px){.xl\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.xl\:grid-cols-5{grid-template-columns:repeat(5,minmax(0,1fr))}.xl\:px-10{padding-left:2.5rem;padding-right:2.5rem}}.bg-blue-50{background-color:#eff6ff}.bg-purple-50{background-color:#faf5ff}.bg-orange-50{background-color:#fff7ed}.bg-green-50{background-color:#f0fdf4}.bg-gray-50{background-color:#f9fafb}.border-blue-200{border-color:#bfdbfe}.border-purple-200{border-color:#e9d5ff}.border-orange-200{border-color:#fed7aa}.border-green-200{border-color:#bbf7d0}.border-gray-200{border-color:#e5e7eb}.text-blue-600{color:#2563eb}.text-blue-700{color:#1d4ed8}.text-blue-500{color:#3b82f6}.text-purple-600{color:#9333ea}.text-purple-700{color:#7c3aed}.text-purple-500{color:#8b5cf6}.text-orange-600{color:#ea580c}.text-orange-700{color:#c2410c}.text-orange-500{color:#f97316}.text-green-600{color:#16a34a}.text-green-700{color:#15803d}.text-green-500{color:#22c55e}
