*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.6;color:#333;background-color:#f8fafc}:root{--primary-50: #fef2f2;--primary-100: #fee2e2;--primary-200: #fecaca;--primary-300: #fca5a5;--primary-400: #f87171;--primary-500: #ef4444;--primary-600: #dc2626;--primary-700: #b91c1c;--primary-800: #991b1b;--primary-900: #7f1d1d;--secondary-50: #f9fafb;--secondary-100: #f3f4f6;--secondary-200: #e5e7eb;--secondary-300: #d1d5db;--secondary-400: #9ca3af;--secondary-500: #6b7280;--secondary-600: #4b5563;--secondary-700: #374151;--secondary-800: #1f2937;--secondary-900: #111827;--header-bg: #ffffff;--header-border: #e5e7eb;--header-text: #1f2937;--header-text-secondary: #6b7280}.container{max-width:1200px;margin:0 auto;padding:0 1rem}.min-h-screen{min-height:100vh}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.grid{display:grid}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.gap-6{gap:1.5rem}.gap-4{gap:1rem}.cursor-pointer{cursor:pointer}.text-right{text-align:right}.bg-gray-50{background-color:#f8fafc}.bg-white{background-color:#fff}.bg-primary-600{background-color:var(--primary-600)}.bg-primary-700{background-color:var(--primary-700)}.bg-primary-500{background-color:var(--primary-500)}.bg-header{background-color:var(--header-bg);border-bottom:1px solid var(--header-border);box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f}.text-header{color:var(--header-text)}.text-header-secondary{color:var(--header-text-secondary)}.bg-red-100{background-color:#fee2e2}.text-red-800{color:#991b1b}.bg-blue-100{background-color:#dbeafe}.text-blue-800{color:#1e40af}.bg-green-100{background-color:#dcfce7}.text-green-800{color:#166534}.bg-purple-100{background-color:#f3e8ff}.text-purple-800{color:#6b21a8}.bg-gray-100{background-color:#f3f4f6}.text-gray-800{color:#1f2937}.bg-red-50{background-color:#fef2f2}.border-red-200{border-color:#fecaca}.text-red-600{color:#dc2626}.text-white{color:#fff}.text-primary-700{color:var(--primary-700)}.text-primary-600{color:var(--primary-600)}.text-gray-600{color:#6b7280}.text-gray-700{color:#374151}.text-gray-900{color:#111827}.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}.font-bold{font-weight:700}.font-semibold{font-weight:600}.font-medium{font-weight:500}.capitalize{text-transform:capitalize}.opacity-75{opacity:.75}.py-6{padding-top:1.5rem;padding-bottom:1.5rem}.py-8{padding-top:2rem;padding-bottom:2rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.px-4{padding-left:1rem;padding-right:1rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.px-2{padding-left:.5rem;padding-right:.5rem}.p-6{padding:1.5rem}.p-8{padding:2rem}.p-4{padding:1rem}.p-3{padding:.75rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mb-2{margin-bottom:.5rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.mt-1{margin-top:.25rem}.mx-auto{margin-left:auto;margin-right:auto}.w-full{width:100%}.w-2{width:.5rem}.h-2{height:.5rem}.max-w-md{max-width:28rem}.max-w-2xl{max-width:42rem}.max-h-90vh{max-height:90vh}.line-clamp-2{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.min-w-full{min-width:100%}.divide-y>*+*{border-top-width:1px}.divide-gray-200>*+*{border-color:#e5e7eb}.overflow-x-auto{overflow-x:auto}table{border-collapse:collapse}th{background-color:#f9fafb;font-weight:500;text-transform:uppercase;letter-spacing:.05em}th,td{padding:.75rem 1.5rem;text-align:left;border-bottom:1px solid #e5e7eb}tbody tr:hover{background-color:#f9fafb}.action-btn{padding:.25rem .75rem;font-size:.875rem;border-radius:.375rem;border:1px solid transparent;cursor:pointer;transition:all .15s ease-in-out;text-decoration:none;display:inline-block;margin-right:.5rem}.action-btn-view{color:#dc2626;border-color:#dc2626}.action-btn-view:hover{background-color:#dc2626;color:#fff}.action-btn-edit{color:#2563eb;border-color:#2563eb}.action-btn-edit:hover{background-color:#2563eb;color:#fff}.action-btn-delete{color:#dc2626;border-color:#dc2626}.action-btn-delete:hover{background-color:#dc2626;color:#fff}.modal-overlay{z-index:1000}.btn-with-icon{display:flex;align-items:center;gap:.5rem}.rounded-lg{border-radius:.5rem}.rounded-md{border-radius:.375rem}.rounded-full{border-radius:9999px}.shadow-md{box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.shadow-lg{box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}.border{border-width:1px}.border-gray-300{border-color:#d1d5db}.border-primary-600{border-color:var(--primary-600)}.form-input{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:1rem;transition:border-color .15s ease-in-out,box-shadow .15s ease-in-out}.form-input:focus{outline:none;border-color:var(--primary-600);box-shadow:0 0 0 3px #dc26261a}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.75rem 1.5rem;border:none;border-radius:.375rem;font-size:1rem;font-weight:500;cursor:pointer;transition:background-color .15s ease-in-out,transform .15s ease-in-out}.btn-primary{background-color:var(--primary-600);color:#fff}.btn-primary:hover{background-color:var(--primary-700);transform:translateY(-1px)}.btn-secondary{background-color:var(--secondary-600);color:#fff}.btn-secondary:hover{background-color:var(--secondary-700)}.link{color:var(--primary-600);text-decoration:none;transition:color .15s ease-in-out}.link:hover{color:var(--primary-700);text-decoration:underline}.text-center{text-align:center}.space-y-4>*+*{margin-top:1rem}.space-y-6>*+*{margin-top:1.5rem}.space-y-3>*+*{margin-top:.75rem}.space-x-4>*+*{margin-left:1rem}.space-x-2>*+*{margin-left:.5rem}@media (min-width: 768px){.md\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}}#root{max-width:1280px;margin:0 auto;padding:2rem;text-align:center}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (prefers-reduced-motion: no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}
