@import url("https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap");:root{--brand-primary:#0a1f5c;--brand-secondary:#1a3a8f;--brand-accent:#3b6ff0;--brand-light:#e8eefb;--color-success:#22c55e;--color-success-light:#dcfce7;--color-warning:#eab308;--color-warning-light:#fef9c3;--color-danger:#ef4444;--color-danger-light:#fee2e2;--color-info:#3b82f6;--color-info-light:#dbeafe;--gray-50:#f8fafc;--gray-100:#f1f5f9;--gray-200:#e2e8f0;--gray-300:#cbd5e1;--gray-400:#94a3b8;--gray-500:#64748b;--gray-600:#475569;--gray-700:#334155;--gray-800:#1e293b;--gray-900:#0f172a;--sidebar-width:260px;--sidebar-collapsed:72px;--header-height:64px;--bg-page:#f0f4fa;--bg-card:#ffffff;--bg-sidebar:#ffffff;--font-family:"Inter",-apple-system,sans-serif;--fs-xs:0.75rem;--fs-sm:0.8125rem;--fs-base:0.875rem;--fs-md:1rem;--fs-lg:1.125rem;--fs-xl:1.25rem;--fs-2xl:1.5rem;--fs-3xl:1.875rem;--sp-1:4px;--sp-2:8px;--sp-3:12px;--sp-4:16px;--sp-5:20px;--sp-6:24px;--sp-8:32px;--sp-10:40px;--sp-12:48px;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-xl:20px;--radius-full:9999px;--shadow-sm:0 1px 2px rgba(0,0,0,0.05);--shadow-md:0 4px 6px -1px rgba(0,0,0,0.07),0 2px 4px -2px rgba(0,0,0,0.05);--shadow-lg:0 10px 15px -3px rgba(0,0,0,0.08),0 4px 6px -4px rgba(0,0,0,0.04);--shadow-card:0 1px 3px rgba(0,0,0,0.06),0 1px 2px rgba(0,0,0,0.04);--transition-fast:150ms ease;--transition-base:200ms ease;--transition-slow:300ms ease}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased}body{font-family:var(--font-family);font-size:var(--fs-base);color:var(--gray-800);background:var(--bg-page);line-height:1.6;min-height:100vh}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:inherit}input,select,textarea{font-family:inherit;font-size:inherit}img{max-width:100%;display:block}ol,ul{list-style:none}.page-title{font-size:var(--fs-2xl);font-weight:700;color:var(--gray-900)}.section-title{font-size:var(--fs-lg);font-weight:600;color:var(--gray-800)}.text-muted{color:var(--gray-500)}.text-sm{font-size:var(--fs-sm)}.text-xs{font-size:var(--fs-xs)}.text-success{color:var(--color-success)}.text-warning{color:var(--color-warning)}.text-danger{color:var(--color-danger)}.fw-500{font-weight:500}.fw-600{font-weight:600}.fw-700{font-weight:700}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:var(--sp-2)}.gap-3{gap:var(--sp-3)}.gap-4{gap:var(--sp-4)}.gap-6{gap:var(--sp-6)}.card{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--gray-300);box-shadow:var(--shadow-md);padding:var(--sp-6);transition:all var(--transition-base);transform:translateY(-2px)}.card:hover{box-shadow:var(--shadow-lg);border-color:var(--brand-accent);transform:translateY(-5px)}.card-header{display:flex;justify-content:space-between;margin-bottom:var(--sp-4)}.btn,.card-header{align-items:center}.btn{display:inline-flex;justify-content:center;gap:var(--sp-2);padding:var(--sp-2) var(--sp-4);font-size:var(--fs-sm);font-weight:500;border:none;border-radius:var(--radius-sm);transition:all var(--transition-fast);white-space:nowrap;height:36px}.btn:active{transform:scale(.97)}.btn-primary{background:var(--brand-primary);color:white}.btn-primary:hover{background:var(--brand-secondary)}.btn-secondary{background:var(--gray-100);color:var(--gray-700);border:1px solid var(--gray-200)}.btn-secondary:hover{background:var(--gray-200)}.btn-success{background:var(--color-success);color:white}.btn-success:hover{background:#16a34a}.btn-danger{background:var(--color-danger);color:white}.btn-danger:hover{background:#dc2626}.btn-sm{height:30px;padding:var(--sp-1) var(--sp-3);font-size:var(--fs-xs)}.btn-lg{height:44px;padding:var(--sp-3) var(--sp-6);font-size:var(--fs-md)}.btn-icon{width:36px;height:36px;padding:0;border-radius:var(--radius-sm);background:transparent;color:var(--gray-500);border:none}.btn-icon:hover{background:var(--gray-100);color:var(--gray-700)}.badge{display:inline-flex;align-items:center;gap:4px;padding:2px 10px;font-size:var(--fs-xs);font-weight:600;border-radius:var(--radius-full);white-space:nowrap}.badge-green{background:var(--color-success-light);color:#166534}.badge-yellow{background:var(--color-warning-light);color:#854d0e}.badge-red{background:var(--color-danger-light);color:#991b1b}.badge-blue{background:var(--color-info-light);color:#1e40af}.badge-gray{background:var(--gray-100);color:var(--gray-600)}.semaforo-dot{width:12px;height:12px;border-radius:50%;display:inline-block;flex-shrink:0}.semaforo-dot.verde{background:var(--color-success);box-shadow:0 0 6px rgba(34,197,94,.5)}.semaforo-dot.amarillo{background:var(--color-warning);box-shadow:0 0 6px rgba(234,179,8,.5)}.semaforo-dot.naranja{background:transparent;border:3px solid #f97316;box-shadow:inset 0 0 4px rgba(249,115,22,.3),0 0 6px rgba(249,115,22,.5)}.semaforo-dot.rojo{background:var(--color-danger);box-shadow:0 0 6px rgba(239,68,68,.5);animation:pulse-red 2s infinite}@keyframes pulse-red{0%,to{box-shadow:0 0 6px rgba(239,68,68,.5)}50%{box-shadow:0 0 14px rgba(239,68,68,.8)}}.table-container{overflow-x:auto;border-radius:var(--radius-md)}.table{width:100%;border-collapse:collapse;font-size:var(--fs-sm)}.table th{text-align:left;padding:8px 12px;font-weight:600;color:var(--gray-600);background:var(--gray-50);border-bottom:1px solid var(--gray-200);font-size:var(--fs-xs);text-transform:uppercase;letter-spacing:.5px}.table td{padding:8px 12px;border-bottom:1px solid var(--gray-100);color:var(--gray-700)}.table tr{transition:background var(--transition-fast)}.table tbody tr:hover{background:var(--gray-50)}.table-compact td,.table-compact th{padding:6px 8px;font-size:11px}.form-group{margin-bottom:var(--sp-4)}.form-label{display:block;font-size:var(--fs-sm);font-weight:500;color:var(--gray-700);margin-bottom:var(--sp-1)}.form-input{width:100%;height:40px;padding:0 var(--sp-3);border:1px solid var(--gray-300);border-radius:var(--radius-sm);font-size:var(--fs-base);color:var(--gray-800);background:white;transition:border-color var(--transition-fast),box-shadow var(--transition-fast);outline:none}.form-input:focus{border-color:var(--brand-accent);box-shadow:0 0 0 3px rgba(59,111,240,.15)}.form-input::placeholder{color:var(--gray-400)}.form-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%2364748b' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10l-5 5z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px}textarea.form-input{height:auto;min-height:80px;padding:var(--sp-3);resize:vertical}.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.4);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.modal-content{background:white;border-radius:var(--radius-lg);padding:var(--sp-6);max-width:500px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:slideUp .2s ease}.modal-title{font-size:var(--fs-lg);font-weight:600;margin-bottom:var(--sp-4)}.modal-actions{display:flex;gap:var(--sp-3);justify-content:flex-end;margin-top:var(--sp-6)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:var(--sp-4);gap:var(--sp-4)}.stat-card{background:white;border-radius:var(--radius-lg);border:1px solid var(--gray-300);padding:var(--sp-5);box-shadow:var(--shadow-md);display:flex;align-items:center;gap:var(--sp-4);transition:all var(--transition-base);transform:translateY(-2px)}.stat-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);border-color:var(--brand-accent)}.stat-card .stat-icon{width:48px;height:48px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-card .stat-value{font-size:var(--fs-2xl);font-weight:700;color:var(--gray-900);line-height:1.2}.stat-card .stat-label{font-size:var(--fs-xs);color:var(--gray-500);font-weight:500}.dashboard-grid{grid-template-columns:1.2fr 1fr;grid-gap:var(--sp-4)}.dashboard-grid,.dashboard-grid-3{display:grid;gap:var(--sp-4);margin-top:var(--sp-4)}.dashboard-grid-3{grid-template-columns:1fr 1fr 1fr;grid-gap:var(--sp-4)}.pagination{display:flex;align-items:center;justify-content:center;gap:var(--sp-1);padding:var(--sp-4) 0}.pagination button{min-width:34px;height:34px;border:1px solid var(--gray-200);background:white;border-radius:var(--radius-sm);font-size:var(--fs-sm);color:var(--gray-600);transition:all var(--transition-fast)}.pagination button:hover{background:var(--gray-50);border-color:var(--gray-300)}.pagination button.active{background:var(--brand-primary);color:white;border-color:var(--brand-primary)}.spinner{width:24px;height:24px;border:3px solid var(--gray-200);border-top-color:var(--brand-accent);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.loading-overlay{display:flex;align-items:center;justify-content:center;padding:var(--sp-12);flex-direction:column;gap:var(--sp-3);color:var(--gray-500)}.empty-state{text-align:center;padding:var(--sp-12) var(--sp-6);color:var(--gray-400)}.empty-state svg{margin:0 auto var(--sp-4);opacity:.4}.empty-state p{font-size:var(--fs-sm)}@media (max-width:1280px){.stats-grid{grid-template-columns:repeat(2,1fr)}.dashboard-grid{grid-template-columns:1fr}.dashboard-grid-3{grid-template-columns:1fr 1fr}}@media (max-width:768px){.dashboard-grid-3,.stats-grid{grid-template-columns:1fr}}