:root{--primary: #4f46e5;--primary-hover: #4338ca;--bg-color: #f9fafb;--card-bg: #ffffff;--text-main: #111827;--text-muted: #6b7280;--border-color: #e5e7eb;--danger: #ef4444;--success: #10b981;--font-sans: "Inter", system-ui, sans-serif;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--radius-md: 8px;--radius-lg: 12px}@media (prefers-color-scheme: dark){:root{--bg-color: #0f172a;--card-bg: #1e293b;--text-main: #f8fafc;--text-muted: #94a3b8;--border-color: #334155}}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-sans);background-color:var(--bg-color);color:var(--text-main);line-height:1.5;-webkit-font-smoothing:antialiased}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.5rem 1rem;font-size:.875rem;font-weight:500;border-radius:var(--radius-md);border:none;cursor:pointer;transition:all .2s ease-in-out;outline:none}.btn:focus-visible{box-shadow:0 0 0 2px var(--bg-color),0 0 0 4px var(--primary)}.btn-primary{background-color:var(--primary);color:#fff;box-shadow:var(--shadow-sm)}.btn-primary:hover{background-color:var(--primary-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-primary:active{transform:translateY(0)}.card{background:var(--card-bg);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:1.5rem;border:1px solid var(--border-color);transition:transform .2s ease}.card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.input-group{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.input-label{font-size:.875rem;font-weight:500;color:var(--text-main)}.input-field{padding:.625rem .875rem;border-radius:var(--radius-md);border:1px solid var(--border-color);background:var(--bg-color);color:var(--text-main);font-family:inherit;transition:border-color .2s,box-shadow .2s}.input-field:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #4f46e533}.layout-container{display:flex;height:100vh;overflow:hidden}.sidebar{width:260px;background-color:var(--card-bg);border-right:1px solid var(--border-color);display:flex;flex-direction:column;padding:1.5rem 1rem;z-index:10;overflow-y:auto;max-height:100vh}.sidebar-logo{font-size:1.25rem;font-weight:800;color:var(--primary);margin-bottom:2rem;display:flex;align-items:center;gap:.5rem;padding-left:.5rem}.nav-link{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border-radius:var(--radius-md);color:var(--text-muted);text-decoration:none;font-weight:500;transition:all .2s;margin-bottom:.25rem}.nav-link:hover{background-color:#4f46e50d;color:var(--primary)}.nav-link.active{background-color:#4f46e51a;color:var(--primary);font-weight:600}.main-content{flex:1;display:flex;flex-direction:column;overflow:hidden}.topbar{height:64px;background-color:var(--card-bg);border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between;padding:0 2rem;z-index:10}.page-content{flex:1;overflow-y:auto;padding:2rem}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--bg-color) 0%,rgba(79,70,229,.05) 100%);padding:1rem}.auth-card{width:100%;max-width:400px;animation:fadeIn .4s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.spinner{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.flex{display:flex}.flex-col{display:flex;flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.grid{display:grid}.grid-cols-2{grid-template-columns:repeat(2,1fr)}.grid-cols-3{grid-template-columns:repeat(3,1fr)}.grid-cols-4{grid-template-columns:repeat(4,1fr)}.w-full{width:100%}.h-full{height:100%}.text-sm{font-size:.875rem}.text-xs{font-size:.75rem}.text-lg{font-size:1.125rem}.text-xl{font-size:1.25rem}.text-2xl{font-size:1.5rem}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.text-center{text-align:center}.text-right{text-align:right}.text-primary{color:var(--primary)}.text-muted{color:var(--text-muted)}.text-danger{color:var(--danger)}.text-success{color:var(--success)}.mb-1{margin-bottom:.25rem}.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-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.p-2{padding:.5rem}.p-4{padding:1rem}.p-6{padding:1.5rem}.table-container{width:100%;overflow-x:auto;border-radius:var(--radius-md);border:1px solid var(--border-color)}.data-table{width:100%;border-collapse:collapse}.data-table th{background:var(--bg-color);padding:.75rem 1rem;text-align:left;font-size:.75rem;font-weight:600;text-transform:uppercase;color:var(--text-muted);border-bottom:1px solid var(--border-color)}.data-table td{padding:.875rem 1rem;border-bottom:1px solid var(--border-color);font-size:.875rem}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover{background-color:#4f46e505}.badge{display:inline-flex;padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:600;text-transform:capitalize}.badge-success{background:#d1fae5;color:#047857}.badge-danger{background:#fee2e2;color:#b91c1c}.badge-warning{background:#fef3c7;color:#b45309}.badge-info{background:#e0f2fe;color:#0369a1}.badge-neutral{background:#f3f4f6;color:#374151}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:100;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.header-actions{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.readonly-mode .btn.btn-primary,.readonly-mode button[title=Editar],.readonly-mode button[title=editar],.readonly-mode button[title="Editar registro"],.readonly-mode button[title=Modificar],.readonly-mode button[title=Eliminar],.readonly-mode button[title=eliminar],.readonly-mode button[title=Borrar],.readonly-mode button[title=borrar],.readonly-mode button[title="Eliminar registro"]{display:none!important}.readonly-mode th:last-child:has(~th),.readonly-mode td:last-child:empty{display:none!important}
