*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--sb-blue:#0563C7;--sb-blue-soft:#0E8DD4;--sb-navy:#1B2155;--sb-blue-mid:#4A8FC0;--sb-blue-light:#E8F4FC;--sb-blue-dim:#D0E9F7;--sb-gradient:linear-gradient(90deg,#0563C7,#0E8DD4);--sb-gradient-bg:linear-gradient(135deg,#0d1b48 0%,#0e3580 55%,#0b5299 100%);--ok:#16a34a;--ok-dim:#f0fdf4;--warn:#d97706;--warn-dim:#fffbeb;--danger:#dc2626;--danger-dim:#fef2f2;--info:#0891b2;--info-dim:#ecfeff;--bg:#f1f5f9;--surface:#ffffff;--border:#e2e8f0;--border-strong:#cbd5e1;--text:#0f172a;--text-mid:#334155;--muted:#64748b;--faint:#94a3b8;--sidebar-bg:#1B2155;--sidebar-hover:#243070;--sidebar-active:#0563C7;--sidebar-border:#151a3e;--sidebar-text:#94a3b8;--sidebar-text-active:#ffffff;--shadow-sm:0 1px 3px rgba(0,0,0,.07);--shadow:0 2px 8px rgba(0,0,0,.1);--shadow-md:0 4px 16px rgba(0,0,0,.12);--shadow-lg:0 8px 32px rgba(0,0,0,.14);--shadow-btn:0 4px 12px rgba(5,99,199,.3);--radius-sm:6px;--radius:10px;--radius-lg:16px;--radius-xl:24px;--font-body:"Inter",system-ui,sans-serif;--font-head:"Plus Jakarta Sans","Inter",sans-serif;--transition:all .18s ease}body{font-family:var(--font-body);background:var(--bg);color:var(--text);font-size:14px;line-height:1.6;-webkit-font-smoothing:antialiased}.app-shell{display:flex;min-height:100vh}.sidebar{width:220px;flex-shrink:0;background:var(--sidebar-bg);display:flex;flex-direction:column}.main-area{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}.topbar{height:52px;background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 24px;flex-shrink:0}.page-content{flex:1;overflow-y:auto;padding:24px}.sidebar-logo{padding:20px 16px 12px;border-bottom:1px solid var(--sidebar-border)}.sidebar-logo-title{font-family:var(--font-head);font-size:15px;font-weight:800;color:#fff;line-height:1.2}.sidebar-logo-sub{font-size:10px;color:var(--sidebar-text);margin-top:2px}.sidebar-nav{flex:1;padding:12px 0;overflow-y:auto}.sidebar-section{font-size:10px;font-weight:700;color:var(--sidebar-text);letter-spacing:.08em;text-transform:uppercase;padding:12px 16px 4px}.sidebar-item{display:flex;align-items:center;gap:10px;padding:9px 16px;color:var(--sidebar-text);cursor:pointer;transition:var(--transition);font-size:13px;font-weight:500;border:none;background:none;width:100%;text-align:left;text-decoration:none}.sidebar-item:hover{background:var(--sidebar-hover);color:#fff}.sidebar-item.active{background:var(--sidebar-active);color:var(--sidebar-text-active)}.sidebar-item svg{width:16px;height:16px;flex-shrink:0}.sidebar-footer{padding:12px 16px;border-top:1px solid var(--sidebar-border)}.sidebar-user{font-size:12px;color:var(--sidebar-text)}.sidebar-user-name{color:#fff;font-weight:600}.sidebar-user-rol{font-size:11px;color:var(--faint)}.card{background:var(--surface);border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-sm);padding:20px}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.card-title{font-family:var(--font-head);font-size:15px;font-weight:700;color:var(--text)}.card-subtitle{font-size:12px;color:var(--muted);margin-top:2px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:24px}.stat-card{background:var(--surface);border-radius:var(--radius-lg);border:1px solid var(--border);padding:20px;box-shadow:var(--shadow-sm)}.stat-value{font-family:var(--font-head);font-size:32px;font-weight:800;color:var(--sb-blue);line-height:1}.stat-label{font-size:12px;color:var(--muted);margin-top:6px;font-weight:500}.stat-card.warn .stat-value{color:var(--warn)}.stat-card.ok .stat-value{color:var(--ok)}.stat-card.danger .stat-value{color:var(--danger)}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 18px;border-radius:var(--radius);font-size:13px;font-weight:600;cursor:pointer;border:none;transition:var(--transition)}.btn-primary{background:var(--sb-blue);color:#fff;box-shadow:var(--shadow-btn)}.btn-primary:hover{background:var(--sb-navy)}.btn-secondary{background:var(--surface);color:var(--text-mid);border:1px solid var(--border)}.btn-secondary:hover{background:var(--bg)}.btn-danger{background:var(--danger);color:#fff}.btn-success{background:var(--ok);color:#fff}.btn-sm{padding:5px 12px;font-size:12px}.btn:disabled{opacity:.5;cursor:not-allowed}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:700;white-space:nowrap}.badge-requerido{background:var(--warn-dim);color:var(--warn)}.badge-autorizado{background:var(--info-dim);color:var(--info)}.badge-gestionado{background:var(--sb-blue-light);color:var(--sb-blue)}.badge-completado{background:var(--ok-dim);color:var(--ok)}.table-wrap{overflow-x:auto;border-radius:var(--radius);border:1px solid var(--border)}table{width:100%;border-collapse:collapse;font-size:13px}thead th{background:var(--bg);color:var(--muted);font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.05em;padding:10px 14px;text-align:left;white-space:nowrap;border-bottom:1px solid var(--border)}tbody td{padding:11px 14px;border-bottom:1px solid var(--border);color:var(--text-mid)}tbody tr:last-child td{border-bottom:none}tbody tr:hover{background:var(--bg)}.form-group{margin-bottom:16px}.form-label{display:block;font-size:12px;font-weight:600;color:var(--text-mid);margin-bottom:6px}.form-control{width:100%;padding:9px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:13px;font-family:var(--font-body);color:var(--text);background:var(--surface);transition:var(--transition);outline:none}.form-control:focus{border-color:var(--sb-blue);box-shadow:0 0 0 3px #0563c71f}select.form-control{cursor:pointer}textarea.form-control{resize:vertical;min-height:80px}.upload-zone{border:2px dashed var(--border-strong);border-radius:var(--radius-lg);padding:40px;text-align:center;cursor:pointer;transition:var(--transition);background:var(--bg)}.upload-zone:hover,.upload-zone.drag{border-color:var(--sb-blue);background:var(--sb-blue-light)}.upload-zone svg{color:var(--sb-blue);margin-bottom:12px}.upload-zone p{color:var(--muted);font-size:13px}.upload-zone strong{color:var(--text)}.page-header{margin-bottom:24px}.page-header h1{font-family:var(--font-head);font-size:22px;font-weight:800;color:var(--text)}.page-header p{color:var(--muted);font-size:13px;margin-top:4px}.alert{padding:12px 16px;border-radius:var(--radius);font-size:13px;margin-bottom:16px;display:flex;align-items:flex-start;gap:10px}.alert-info{background:var(--info-dim);color:var(--info);border:1px solid rgba(8,145,178,.2)}.alert-warn{background:var(--warn-dim);color:var(--warn);border:1px solid rgba(217,119,6,.2)}.alert-ok{background:var(--ok-dim);color:var(--ok);border:1px solid rgba(22,163,74,.2)}.alert-danger{background:var(--danger-dim);color:var(--danger);border:1px solid rgba(220,38,38,.2)}.timeline{display:flex;gap:0;margin:20px 0}.timeline-step{flex:1;display:flex;flex-direction:column;align-items:center;position:relative}.timeline-step:not(:last-child):after{content:"";position:absolute;top:16px;left:50%;width:100%;height:2px;background:var(--border);z-index:0}.timeline-step.done:after{background:var(--sb-blue)}.timeline-dot{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;position:relative;z-index:1;border:2px solid var(--border);background:var(--surface);color:var(--muted)}.timeline-step.done .timeline-dot{background:var(--sb-blue);border-color:var(--sb-blue);color:#fff}.timeline-step.active .timeline-dot{background:var(--warn);border-color:var(--warn);color:#fff}.timeline-label{font-size:11px;color:var(--muted);margin-top:6px;text-align:center;font-weight:500}.timeline-step.done .timeline-label{color:var(--sb-blue)}.timeline-step.active .timeline-label{color:var(--warn);font-weight:700}.checkbox-item{display:flex;align-items:center;gap:8px;cursor:pointer;padding:6px 0}.checkbox-item input[type=checkbox]{width:16px;height:16px;accent-color:var(--sb-blue);cursor:pointer}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a80;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:540px;max-height:85vh;overflow-y:auto}.modal-header{padding:20px 24px 0;display:flex;align-items:center;justify-content:space-between}.modal-header h3{font-family:var(--font-head);font-size:16px;font-weight:800;color:var(--text)}.modal-body{padding:20px 24px}.modal-footer{padding:0 24px 20px;display:flex;gap:10px;justify-content:flex-end}.text-muted{color:var(--muted)}.text-sm{font-size:12px}.flex{display:flex}.flex-center{display:flex;align-items:center}.gap-2{gap:8px}.gap-3{gap:12px}.mt-1{margin-top:4px}.mt-2{margin-top:8px}.mt-3{margin-top:12px}.mb-3{margin-bottom:12px}.w-full{width:100%}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}.login-bg{min-height:100vh;background:var(--sb-gradient-bg);display:flex;align-items:center;justify-content:center;padding:20px}.login-card{background:var(--surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);width:100%;max-width:400px;padding:40px}.login-logo{text-align:center;margin-bottom:32px}.login-logo h1{font-family:var(--font-head);font-size:22px;font-weight:800;color:var(--sb-navy)}.login-logo p{font-size:12px;color:var(--muted);margin-top:4px}.spinner{display:inline-block;width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;padding:48px;color:var(--muted)}.empty-state svg{color:var(--faint);margin-bottom:12px}.empty-state p{font-size:14px}
