*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--primary:#1e40af;--primary-light:#3b82f6;--primary-dark:#1e3a8a;--success:#16a34a;--danger:#dc2626;--warning:#d97706;--bg:#f1f5f9;--surface:#fff;--border:#e2e8f0;--text:#0f172a;--text-muted:#64748b;--radius:8px;--shadow:0 1px 3px #0000001a, 0 1px 2px #0000000f;--shadow-md:0 4px 6px #00000012, 0 2px 4px #0000000f}body{background-color:var(--bg);color:var(--text);background-image:url(/images/fondo.jpg);background-position:50%;background-repeat:no-repeat;background-size:cover;background-attachment:fixed;font-family:Inter,system-ui,-apple-system,sans-serif;font-size:14px;line-height:1.6}a{color:inherit;text-decoration:none}#app{min-height:100vh}.btn{border-radius:var(--radius);cursor:pointer;white-space:nowrap;border:none;align-items:center;gap:6px;padding:8px 16px;font-size:14px;font-weight:500;transition:all .15s;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-dark)}.btn-secondary{background:var(--surface);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:var(--bg)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){background:#b91c1c}.btn-success{background:var(--success);color:#fff}.btn-sm{padding:5px 10px;font-size:12px}.btn-icon{border-radius:var(--radius);border:1px solid var(--border);background:var(--surface);cursor:pointer;justify-content:center;align-items:center;padding:6px;display:inline-flex}.btn-icon:hover{background:var(--bg)}.form-group{flex-direction:column;gap:4px;display:flex}.form-label{color:var(--text);font-size:13px;font-weight:500}.form-control{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text);width:100%;padding:9px 12px;font-size:14px;transition:border-color .15s}.form-control:focus{border-color:var(--primary-light);outline:none;box-shadow:0 0 0 3px #3b82f626}.form-error{color:var(--danger);font-size:12px}.form-hint{color:var(--text-muted);font-size:12px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}.card-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:12px;padding:16px 20px;display:flex}.card-body{padding:20px}.card-title{font-size:15px;font-weight:600}.table-wrap{overflow-x:auto}table{border-collapse:collapse;width:100%;font-size:14px}th{background:var(--bg);text-align:left;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);border-bottom:1px solid var(--border);white-space:nowrap;padding:10px 14px;font-size:12px;font-weight:600}td{border-bottom:1px solid var(--border);vertical-align:middle;padding:12px 14px}tr:last-child td{border-bottom:none}tr:hover td{background:#f8fafc}.badge{border-radius:999px;align-items:center;padding:2px 8px;font-size:11px;font-weight:600;display:inline-flex}.badge-green{color:#15803d;background:#dcfce7}.badge-red{color:#b91c1c;background:#fee2e2}.badge-yellow{color:#854d0e;background:#fef9c3}.badge-blue{color:#1d4ed8;background:#dbeafe}.badge-gray{color:#475569;background:#f1f5f9}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:24px;display:flex}.page-title{font-size:20px;font-weight:700}.page-subtitle{color:var(--text-muted);margin-top:2px;font-size:13px}.empty-state{text-align:center;color:var(--text-muted);padding:48px 24px}.alert{border-radius:var(--radius);margin-bottom:16px;padding:12px 16px;font-size:13px}.alert-error{color:var(--danger);background:#fee2e2;border:1px solid #fecaca}.alert-success{color:var(--success);background:#dcfce7;border:1px solid #bbf7d0}.pagination{justify-content:center;align-items:center;gap:4px;margin-top:20px;display:flex}.page-btn{border-radius:var(--radius);border:1px solid var(--border);background:var(--surface);cursor:pointer;justify-content:center;align-items:center;min-width:32px;height:32px;padding:0 8px;font-size:13px;display:inline-flex}.page-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.page-btn:hover:not(.active):not(:disabled){background:var(--bg)}.page-btn:disabled{opacity:.4;cursor:not-allowed}.modal-overlay{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:200;background:#0f172a8c;justify-content:center;align-items:center;padding:16px;animation:.2s overlay-in;display:flex;position:fixed;inset:0}.modal{background:var(--surface);border-radius:16px;width:100%;max-width:480px;max-height:90vh;animation:.24s cubic-bezier(.16,1,.3,1) modal-in;overflow-y:auto;box-shadow:0 32px 80px #0f172a38,0 4px 16px #0f172a1a}.modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:12px;padding:18px 22px;display:flex}.modal-title{color:var(--text);font-size:16px;font-weight:700}.modal-close{cursor:pointer;color:var(--text-muted);background:#f1f5f9;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:15px;transition:all .15s;display:inline-flex}.modal-close:hover{color:var(--text);background:#e2e8f0}.modal-body{flex-direction:column;gap:16px;padding:22px;display:flex}.modal-footer{border-top:1px solid var(--border);background:#f8fafc;border-radius:0 0 16px 16px;justify-content:flex-end;gap:10px;padding:14px 22px;display:flex}@keyframes overlay-in{0%{opacity:0}to{opacity:1}}@keyframes modal-in{0%{opacity:0;transform:scale(.95)translateY(12px)}to{opacity:1;transform:scale(1)translateY(0)}}.stats-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;margin-bottom:24px;display:grid}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px}.stat-value{color:var(--primary);font-size:28px;font-weight:700}.stat-label{color:var(--text-muted);margin-top:4px;font-size:12px}.filter-bar{flex-wrap:wrap;align-items:flex-end;gap:10px;margin-bottom:16px;display:flex}.filter-bar .form-control{min-width:160px}.spinner{border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;width:24px;height:24px;animation:.6s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.loading-center{justify-content:center;padding:48px;display:flex}
