:root{--primary: #2563eb;--primary-dark: #1d4ed8;--primary-light: #60a5fa;--success: #22c55e;--danger: #ef4444;--warning: #f59e0b;--gray-50: #f8fafc;--gray-100: #f1f5f9;--gray-200: #e2e8f0;--gray-300: #cbd5e1;--gray-600: #475569;--gray-700: #334155;--gray-800: #1e293b;--gray-900: #0f172a;font-family:Inter,system-ui,-apple-system,sans-serif;line-height:1.5;font-weight:400;color:var(--gray-800);background-color:var(--gray-50);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{margin:0;padding:0;box-sizing:border-box}body{min-height:100vh}a{color:var(--primary);text-decoration:none;transition:color .2s}a:hover{color:var(--primary-dark)}button,.button{display:inline-flex;align-items:center;justify-content:center;padding:.5rem 1rem;font-size:.875rem;font-weight:500;border-radius:.375rem;border:none;background:var(--primary);color:#fff;cursor:pointer;transition:all .2s}button:hover,.button:hover{background:var(--primary-dark)}button.small{padding:.25rem .5rem;font-size:.75rem}button.secondary{background:#fff;border:1px solid var(--primary);color:var(--primary)}button.secondary:hover{background:var(--primary-50);border-color:var(--primary-dark);color:var(--primary-dark)}button.danger{background:var(--danger)}button.danger:hover{background:#dc2626}.button.ghost,button.ghost{background:transparent;color:var(--gray-700);border:1px solid var(--gray-300)}.button.ghost:hover,button.ghost:hover{background:var(--gray-100);color:var(--gray-900);border-color:var(--gray-400)}input,select,textarea{width:100%;padding:.5rem .75rem;font-size:.875rem;border:1px solid var(--gray-200);border-radius:.375rem;margin-bottom:1rem;background:#fff}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a}label{display:block;font-size:.875rem;font-weight:500;color:var(--gray-700);margin-bottom:.5rem}.card{background:#fff;border-radius:.5rem;padding:1.5rem;box-shadow:0 1px 3px #0000001a}.container{max-width:1200px;margin:0 auto;padding:1.5rem}.alert{padding:.75rem 1rem;border-radius:.375rem;margin-bottom:1rem}.alert-success{background:#f0fdf4;border:1px solid #bbf7d0;color:#15803d}.alert-error{background:#fef2f2;border:1px solid #fecaca;color:#b91c1c}.badge{display:inline-block;padding:.125rem .5rem;border-radius:9999px;font-size:.75rem;font-weight:500}.badge-blue{background:#dbeafe;color:#1e40af}.badge-green{background:#dcfce7;color:#15803d}h1,h2,h3,h4{color:var(--gray-900);font-weight:600;line-height:1.25;margin-bottom:1rem}h1{font-size:1.875rem}h2{font-size:1.5rem}h3{font-size:1.25rem}h4{font-size:1.125rem}.text-sm{font-size:.875rem}.text-xs{font-size:.75rem}.text-muted,.muted{color:var(--gray-600);opacity:.65}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:.5rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.grid{display:grid;gap:1.5rem}@media(min-width:640px){.grid-cols-2{grid-template-columns:repeat(2,1fr)}}@media(min-width:768px){.grid-cols-3{grid-template-columns:repeat(3,1fr)}}.loading{opacity:.7;pointer-events:none}.animate-spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}
