@import"https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,300..700;1,9..40,300..700&family=JetBrains+Mono:wght@400;500&display=swap";:root{--surface-base: #f8fafc;--surface-elevated: #fff;--surface-sunken: #f1f5f9;--text-primary: #0f172a;--text-secondary: #475569;--text-tertiary: #94a3b8;--accent: #2563eb;--accent-hover: #1d4ed8;--accent-subtle: #eff6ff;--accent-text: #1e40af;--success: #16a34a;--success-bg: #f0fdf4;--success-text: #166534;--warning: #d97706;--warning-bg: #fffbeb;--warning-text: #92400e;--error: #dc2626;--error-bg: #fef2f2;--error-text: #991b1b;--info: #0284c7;--info-bg: #f0f9ff;--info-text: #075985;--border: #e2e8f0;--border-hover: #cbd5e1;--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: 4px;--radius-md: 6px;--radius-lg: 10px;--shadow-xs: 0 1px 2px rgba(0,0,0,.05);--shadow-sm: 0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 4px 6px -1px rgba(0,0,0,.08), 0 2px 4px -2px rgba(0,0,0,.04);--shadow-lg: 0 10px 15px -3px rgba(0,0,0,.08), 0 4px 6px -4px rgba(0,0,0,.04);--font-sans: "DM Sans", system-ui, -apple-system, sans-serif;--font-mono: "JetBrains Mono", ui-monospace, monospace;--text-xs: 11px;--text-sm: 12px;--text-base: 13px;--text-md: 14px;--text-lg: 16px;--text-xl: 18px;--text-2xl: 22px}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-sans);font-size:var(--text-base);color:var(--text-primary);background:var(--surface-base);line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app-shell{min-height:100vh;display:flex;flex-direction:column}.app-header{position:sticky;top:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:0 var(--sp-5);height:48px;background:var(--surface-elevated);border-bottom:1px solid var(--border);box-shadow:var(--shadow-xs)}.app-title{font-size:var(--text-lg);font-weight:700;color:var(--accent);letter-spacing:-.02em}.tab-nav{display:flex;align-items:center;gap:var(--sp-1);height:100%}.tab-btn{display:inline-flex;align-items:center;gap:var(--sp-1);padding:var(--sp-2) var(--sp-3);height:36px;font-family:var(--font-sans);font-size:var(--text-sm);font-weight:500;color:var(--text-secondary);background:transparent;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease;white-space:nowrap}.tab-btn:hover{background:var(--surface-sunken);color:var(--text-primary)}.tab-btn.active{background:var(--accent-subtle);color:var(--accent-text)}.header-user{display:flex;align-items:center;gap:var(--sp-2);font-size:var(--text-sm);color:var(--text-secondary)}.header-avatar{width:28px;height:28px;border-radius:50%;background:var(--accent-subtle);color:var(--accent);display:flex;align-items:center;justify-content:center;font-size:var(--text-xs);font-weight:600}.page{padding:var(--sp-5);max-width:1400px;width:100%;margin:0 auto}.card{background:var(--surface-elevated);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xs)}.card-header{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-4);border-bottom:1px solid var(--border)}.card-title{font-size:var(--text-md);font-weight:600;color:var(--text-primary)}.card-body{padding:var(--sp-4)}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--sp-4)}.kpi-card{background:var(--surface-elevated);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--sp-4);box-shadow:var(--shadow-xs)}.kpi-label{font-size:var(--text-xs);font-weight:500;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--sp-1)}.kpi-value{font-size:var(--text-2xl);font-weight:700;color:var(--text-primary);line-height:1.2}.kpi-sub{font-size:var(--text-xs);color:var(--text-tertiary);margin-top:var(--sp-1)}.table-wrap{border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}table{width:100%;border-collapse:collapse}thead{background:var(--surface-sunken)}th{padding:var(--sp-2) var(--sp-3);font-size:var(--text-xs);font-weight:600;color:var(--text-secondary);text-align:left;text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--border)}td{padding:var(--sp-2) var(--sp-3);font-size:var(--text-sm);color:var(--text-primary);border-bottom:1px solid var(--border);vertical-align:middle}tr:last-child td{border-bottom:none}tbody tr:hover{background:var(--surface-sunken)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--sp-1);padding:var(--sp-2) var(--sp-3);height:34px;font-family:var(--font-sans);font-size:var(--text-sm);font-weight:500;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface-elevated);color:var(--text-primary);cursor:pointer;transition:all .15s ease;white-space:nowrap}.btn:hover{border-color:var(--border-hover);box-shadow:var(--shadow-xs)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}.btn-primary:hover{background:var(--accent-hover);border-color:var(--accent-hover)}.btn-success{background:var(--success);color:#fff;border-color:var(--success)}.btn-success:hover{background:#15803d;border-color:#15803d}.btn-error{background:var(--error);color:#fff;border-color:var(--error)}.btn-error:hover{background:#b91c1c;border-color:#b91c1c}.btn-sm{height:28px;padding:var(--sp-1) var(--sp-2);font-size:var(--text-xs)}.btn-ghost{background:transparent;border-color:transparent;color:var(--text-secondary)}.btn-ghost:hover{background:var(--surface-sunken);color:var(--text-primary);border-color:transparent}.badge{display:inline-flex;align-items:center;padding:2px var(--sp-2);font-size:var(--text-xs);font-weight:500;border-radius:9999px;line-height:1.4}.badge-pendiente{background:var(--warning-bg);color:var(--warning-text)}.badge-aprobada{background:var(--success-bg);color:var(--success-text)}.badge-rechazada{background:var(--error-bg);color:var(--error-text)}.badge-abierto{background:var(--info-bg);color:var(--info-text)}.badge-cerrado{background:var(--surface-sunken);color:var(--text-tertiary)}.form-group{display:flex;flex-direction:column;gap:var(--sp-1)}.form-label{font-size:var(--text-xs);font-weight:500;color:var(--text-secondary)}.form-input,.form-select,.form-textarea{width:100%;padding:var(--sp-2) var(--sp-3);font-family:var(--font-sans);font-size:var(--text-sm);color:var(--text-primary);background:var(--surface-elevated);border:1px solid var(--border);border-radius:var(--radius-md);transition:border-color .15s ease,box-shadow .15s ease;outline:none}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px #2563eb1f}.form-textarea{min-height:80px;resize:vertical}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-4)}.employee-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--sp-3)}.employee-card{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-3);background:var(--surface-elevated);border:1px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;transition:all .15s ease}.employee-card:hover{border-color:var(--accent);box-shadow:var(--shadow-sm)}.emp-avatar{width:44px;height:44px;min-width:44px;border-radius:50%;background:var(--accent-subtle);color:var(--accent);display:flex;align-items:center;justify-content:center;font-size:var(--text-md);font-weight:600;overflow:hidden}.emp-avatar img{width:100%;height:100%;object-fit:cover}.emp-info{flex:1;min-width:0}.emp-name{font-size:var(--text-sm);font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.emp-position{font-size:var(--text-xs);color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.emp-dept{font-size:var(--text-xs);color:var(--text-tertiary)}.emp-meta{font-size:10px;color:var(--text-tertiary);margin-top:var(--sp-1)}.toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:var(--sp-2);margin-bottom:var(--sp-4)}.search-input{width:260px;padding:var(--sp-2) var(--sp-3);font-family:var(--font-sans);font-size:var(--text-sm);color:var(--text-primary);background:var(--surface-elevated);border:1px solid var(--border);border-radius:var(--radius-md);outline:none;transition:border-color .15s ease,box-shadow .15s ease}.search-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #2563eb1f}.side-sheet-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:#0f172a4d;animation:fadeIn .2s ease}.side-sheet{position:fixed;top:0;right:0;bottom:0;z-index:201;width:500px;max-width:100vw;background:var(--surface-elevated);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;animation:slideIn .25s ease}.side-sheet-header{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-4) var(--sp-5);border-bottom:1px solid var(--border)}.side-sheet-header h3{font-size:var(--text-md);font-weight:600}.side-sheet-body{flex:1;overflow-y:auto;padding:var(--sp-5);display:flex;flex-direction:column;gap:var(--sp-4)}.side-sheet-footer{display:flex;align-items:center;justify-content:flex-end;gap:var(--sp-2);padding:var(--sp-3) var(--sp-5);border-top:1px solid var(--border)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.employee-header{display:flex;align-items:center;gap:var(--sp-4);padding:var(--sp-5);background:linear-gradient(135deg,var(--accent-subtle),var(--surface-elevated));border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:var(--sp-4)}.employee-header-avatar{width:64px;height:64px;min-width:64px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:var(--text-xl);font-weight:700;overflow:hidden}.employee-header-avatar img{width:100%;height:100%;object-fit:cover}.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-4)}.detail-field{display:flex;flex-direction:column;gap:2px}.detail-label{font-size:var(--text-xs);font-weight:500;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em}.detail-value{font-size:var(--text-sm);color:var(--text-primary)}.loading{display:flex;align-items:center;justify-content:center;padding:var(--sp-12);color:var(--text-tertiary);font-size:var(--text-sm)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--sp-12);text-align:center}.empty-state-title{font-size:var(--text-md);font-weight:600;color:var(--text-secondary);margin-bottom:var(--sp-1)}.empty-state-text{font-size:var(--text-sm);color:var(--text-tertiary)}.error-banner{padding:var(--sp-3) var(--sp-4);background:var(--error-bg);color:var(--error-text);border:1px solid #fecaca;border-radius:var(--radius-md);font-size:var(--text-sm);margin-bottom:var(--sp-4)}.flex{display:flex}.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)}.mt-4{margin-top:var(--sp-4)}.mt-6{margin-top:var(--sp-6)}.mb-4{margin-bottom:var(--sp-4)}.mb-6{margin-bottom:var(--sp-6)}.ml-auto{margin-left:auto}.text-sm{font-size:var(--text-sm)}.text-secondary{color:var(--text-secondary)}.text-mono{font-family:var(--font-mono)}@media (max-width: 768px){.app-header{flex-wrap:wrap;height:auto;padding:var(--sp-2) var(--sp-3);gap:var(--sp-2)}.tab-nav{order:3;width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}.page{padding:var(--sp-3)}.kpi-grid{grid-template-columns:repeat(2,1fr)}.employee-grid,.detail-grid,.form-row{grid-template-columns:1fr}.side-sheet{width:100vw}.toolbar{flex-direction:column;align-items:stretch}.search-input{width:100%}}.construction-overlay{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0f172a,#1e293b,#0f172a);z-index:9999}.construction-modal{text-align:center;padding:var(--sp-12) var(--sp-8);max-width:480px;width:90%;background:var(--surface-elevated);border-radius:var(--radius-lg);box-shadow:0 25px 60px #00000059;animation:constructionFadeIn .6s ease-out}@keyframes constructionFadeIn{0%{opacity:0;transform:translateY(24px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.construction-icon{display:inline-flex;align-items:center;justify-content:center;width:96px;height:96px;border-radius:50%;background:var(--accent-subtle);color:var(--accent);margin-bottom:var(--sp-6)}.construction-title{font-size:1.625rem;font-weight:700;color:var(--text-primary);margin:0 0 var(--sp-3);letter-spacing:-.025em}.construction-text{font-size:var(--text-md);color:var(--text-secondary);margin:0 0 var(--sp-6);line-height:1.6}.construction-divider{width:48px;height:2px;background:var(--accent);margin:0 auto var(--sp-6);border-radius:1px}.construction-signature{font-size:var(--text-sm);color:var(--text-secondary);line-height:1.8;margin:0;font-weight:500}
