:root{--bg-main:#0b0e14;--bg-card:#151a23;--bg-card-hover:#1a202c;--bg-input:#1c2331;--text-primary:#f1f5f9;--text-secondary:#94a3b8;--text-muted:#64748b;--accent-primary:#8b5cf6;--accent-secondary:#3b82f6;--success:#10b981;--success-bg:#10b9811a;--danger:#ef4444;--danger-bg:#ef44441a;--warning:#f59e0b;--warning-bg:#f59e0b1a;--border-color:#2a3441;--border-focus:#8b5cf6;--font-family:"Inter", system-ui, Avenir, Helvetica, Arial, sans-serif;--space-xs:.25rem;--space-sm:.5rem;--space-md:1rem;--space-lg:1.5rem;--space-xl:2rem;--radius-sm:.25rem;--radius-md:.5rem;--radius-lg:1rem;--radius-xl:1.5rem;--shadow-sm:0 1px 2px 0 #0003;--shadow-md:0 4px 6px -1px #0000004d, 0 2px 4px -1px #00000026;--shadow-lg:0 10px 15px -3px #0006, 0 4px 6px -2px #0003;--shadow-glow:0 0 15px #8b5cf64d}body{font-family:var(--font-family);background-color:var(--bg-main);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0}*{box-sizing:border-box}.card{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-lg);box-shadow:var(--shadow-md);transition:transform .2s,box-shadow .2s}.card:hover{box-shadow:var(--shadow-lg)}.input{background-color:var(--bg-input);border:1px solid var(--border-color);color:var(--text-primary);border-radius:var(--radius-md);padding:var(--space-sm) var(--space-md);font-family:var(--font-family);outline:none;transition:border-color .2s,box-shadow .2s}.input:focus{border-color:var(--border-focus);box-shadow:0 0 0 2px #8b5cf633}.select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%2394A3B8'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M19 9l-7 7-7-7'%3E%3C/path%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--space-sm) center;padding-right:var(--space-xl);background-size:1rem}.badge{text-transform:uppercase;letter-spacing:.05em;border-radius:9999px;padding:.25rem .75rem;font-size:.75rem;font-weight:600;display:inline-block}.badge-success{background:var(--success-bg);color:var(--success);border:1px solid #10b98133}.badge-danger{background:var(--danger-bg);color:var(--danger);border:1px solid #ef444433}.badge-warning{background:var(--warning-bg);color:var(--warning);border:1px solid #f59e0b33}.table-container{width:100%;overflow-x:auto}table{border-collapse:collapse;text-align:left;width:100%}th{background-color:var(--bg-card);color:var(--text-secondary);padding:var(--space-md);border-bottom:1px solid var(--border-color);white-space:nowrap;font-weight:600}td{padding:var(--space-md);border-bottom:1px solid var(--border-color);color:var(--text-primary)}.worker-name{color:var(--text-primary);font-size:.875rem;font-weight:600}tbody tr{transition:background-color .2s}tbody tr:hover{background-color:var(--bg-card-hover)}tr.obra-group-header td{color:var(--accent-primary)!important;border-bottom:1px solid var(--border-color)!important;background-color:#8b5cf614!important}tr.obra-group-subtotal td{color:var(--text-secondary)!important;border-bottom:1px dashed var(--border-color)!important;background-color:#ffffff03!important}tr.obra-group-header:hover,tr.obra-group-subtotal:hover{background-color:#0000!important}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.animate-fade-in{animation:.4s forwards fadeIn}.dashboard-grid{gap:var(--space-lg);padding:var(--space-lg);grid-template-columns:repeat(1,1fr);max-width:1600px;margin:0 auto;display:grid}@media (width>=768px){.dashboard-grid{grid-template-columns:repeat(2,1fr)}}@media (width>=1024px){.dashboard-grid{grid-template-columns:repeat(4,1fr)}}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-main)}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.print-only,.print-only-inline,.print-header-table,.print-summary-box{display:none!important}@media print{@page{size:portrait;margin:.8cm}body,html{color:#000!important;-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important;background:#fff!important;margin:0!important;padding:0!important}header,div[style*="position: sticky"],div[style*="position: fixed"],.no-print,button.no-print,td button.no-print,td button.attendance-btn.no-print,.chat-widget-trigger,.chat-widget,select,input[type=text],form,.zona-desarrollo,div[style*="border: 1px dashed var(--danger)"]{display:none!important}main{margin:0!important;padding:0!important}.card{box-shadow:none!important;background-color:#fff!important;border:none!important;margin:0!important;padding:0!important}.print-only{display:block!important}.print-only-inline{display:inline-block!important}.print-header-table{border-collapse:collapse!important;border:none!important;width:100%!important;margin-bottom:1.25rem!important;display:table!important}.print-header-table tr,.print-header-table td{background:0 0!important;border:none!important;padding:0!important}.print-header-logo{text-align:left!important;vertical-align:middle!important;width:40%!important}.print-header-logo .brand{color:#6d28d9!important;letter-spacing:-.02em!important;font-size:1.6rem!important;font-weight:900!important}.print-header-logo .subtitle{color:#64748b!important;letter-spacing:.15em!important;text-transform:uppercase!important;margin-top:-2px!important;font-size:.65rem!important;font-weight:700!important}.print-header-title{text-align:center!important;vertical-align:middle!important;color:#1e293b!important;text-transform:uppercase!important;border-left:1px solid #e2e8f0!important;border-right:1px solid #e2e8f0!important;width:30%!important;padding:0 10px!important;font-size:.95rem!important;font-weight:800!important}.print-header-meta{text-align:right!important;vertical-align:middle!important;color:#334155!important;width:30%!important;font-size:.75rem!important;line-height:1.3!important}.print-summary-box{grid-template-columns:repeat(4,1fr)!important;gap:.75rem!important;width:100%!important;margin-bottom:1.25rem!important;display:grid!important}.print-summary-card{text-align:left!important;box-sizing:border-box!important;background-color:#fcfbff!important;border:1px solid #ddd6fe!important;border-radius:6px!important;padding:8px 12px!important}.print-summary-card-label{color:#64748b!important;text-transform:uppercase!important;margin-bottom:2px!important;font-size:.6rem!important;font-weight:600!important}.print-summary-card-value{color:#1e293b!important;font-family:monospace!important;font-size:1.1rem!important;font-weight:800!important}.print-summary-card-value.success{color:#047857!important}.print-summary-card-value.danger{color:#b91c1c!important}.table-container{overflow:visible!important}table{border-collapse:collapse!important;border:1px solid #ddd6fe!important;width:100%!important}tbody tr:nth-child(2n){background-color:#f8f6ff!important}th,td{border:1px solid #ddd6fe!important;padding:6px 8px!important;font-size:.75rem!important}th{color:#fff!important;background-color:#6d28d9!important;font-weight:700!important}.worker-name{color:#1e293b!important;font-weight:600!important}td{color:#334155!important}input[type=number]{color:#1e293b!important;text-align:right!important;background-color:#0000!important;border:none!important;width:60px!important;padding:0!important;font-family:monospace!important;font-size:.75rem!important}.badge{-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important;border-radius:9999px!important;padding:2px 6px!important;font-size:.75rem!important;font-weight:600!important;display:inline-block!important}.badge-present{color:#065f46!important;background-color:#d1fae5!important;border:1px solid #a7f3d0!important}.badge-partial{color:#92400e!important;background-color:#fef3c7!important;border:1px solid #fde68a!important}.badge-absent{color:#991b1b!important;background-color:#fee2e2!important;border:1px solid #fecaca!important}.weekly-pay{color:#047857!important;font-family:monospace!important;font-weight:700!important}tfoot tr{background-color:#f5f3ff!important;border-top:2px solid #8b5cf6!important}tfoot td{color:#1e293b!important;font-weight:700!important}.footer-payroll{color:#047857!important;font-weight:800!important}tbody tr.obra-group-header td{color:#6d28d9!important;background-color:#f3e8ff!important;font-weight:700!important}tbody tr.obra-group-subtotal td{color:#1e293b!important;background-color:#faf5ff!important;font-weight:700!important}.print-signatures{page-break-inside:avoid;grid-template-columns:1fr 1fr;gap:3rem;margin-top:2rem!important;display:grid!important}.signature-line{text-align:center;padding-top:.5rem;font-size:.75rem;color:#475569!important;border-top:1px solid #8b5cf6!important}}.app-layout-container{flex-direction:row;flex:1;min-height:calc(100vh - 64px);display:flex}.sidebar-menu{background-color:var(--bg-card);border-right:1px solid var(--border-color);flex-direction:column;flex-shrink:0;gap:.5rem;width:260px;padding:1.5rem 1rem;display:flex}.sidebar-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem;padding-left:.5rem;font-size:.75rem;font-weight:700}.sidebar-btn{color:var(--text-secondary);border-radius:var(--radius-md);cursor:pointer;text-align:left;background-color:#0000;border:none;align-items:center;gap:.75rem;width:100%;padding:.75rem 1rem;font-size:.9rem;font-weight:600;transition:all .2s;display:flex}.sidebar-btn:hover{background-color:var(--bg-card-hover);color:var(--text-primary)}.sidebar-btn.active{color:var(--accent-primary);background-color:#8b5cf61a}.sidebar-btn-settings{margin-top:auto}@media screen and (width<=768px){.main-header{gap:var(--space-sm)!important;padding:var(--space-md)!important;flex-direction:column!important;align-items:stretch!important;position:static!important}.header-info{text-align:center}.header-info h1{flex-direction:column;gap:.25rem!important;font-size:1.1rem!important}.header-info h1 span[style*="font-size: 1.1rem"]{font-size:.95rem!important}.header-info p{display:none!important}.header-actions{width:100%;gap:var(--space-xs)!important;flex-direction:column!important;align-items:stretch!important}.header-payroll,.header-clock{justify-content:center!important;width:100%!important;font-size:.75rem!important}.app-layout-container{flex-direction:column!important}.sidebar-menu{-webkit-overflow-scrolling:touch;white-space:nowrap!important;border-right:none!important;border-bottom:1px solid var(--border-color)!important;z-index:50!important;scrollbar-width:none!important;flex-direction:row!important;gap:.75rem!important;width:100%!important;height:auto!important;padding:.5rem 1rem!important;position:sticky!important;top:0!important;overflow-x:auto!important}.sidebar-menu::-webkit-scrollbar{display:none!important}.sidebar-title{display:none!important}.sidebar-btn{flex-shrink:0!important;justify-content:center!important;width:auto!important;padding:.5rem .75rem!important;font-size:.8rem!important}.sidebar-btn-settings{margin-top:0!important}.filters-card{padding:var(--space-sm)!important;gap:var(--space-sm)!important}.filters-header-row{align-items:stretch!important;gap:var(--space-sm)!important;flex-direction:column!important}.filters-header-row>div{justify-content:center!important;width:100%!important}.table-container th:first-child,.table-container td:first-child{background-color:var(--bg-card)!important;z-index:10!important;position:sticky!important;left:0!important;box-shadow:2px 0 5px #0000004d!important}.table-container th:first-child{z-index:11!important}.main-content-col{grid-column:span 1!important}.sticky-sidebar{position:static!important;top:auto!important}}.report-viewer-overlay{z-index:9999;background-color:#000000d9;flex-direction:column;align-items:center;padding:20px 0;display:flex;position:fixed;inset:0;overflow-y:auto}@media print{.report-viewer-overlay{z-index:99999!important;background-color:#fff!important;width:215.9mm!important;margin:0!important;padding:0!important;display:block!important;position:absolute!important;top:0!important;left:0!important;overflow:visible!important}@page letter-page{size:letter portrait;margin:0}.print-page{page:letter-page;width:215.9mm!important;height:279.4mm!important;min-height:279.4mm!important;max-height:279.4mm!important;box-shadow:none!important;page-break-after:always!important;page-break-inside:avoid!important;box-sizing:border-box!important;flex-direction:column!important;margin:0!important;display:flex!important;position:relative!important;overflow:hidden!important}.print-page:last-child{page-break-after:auto!important}.photo-cell.empty{background:0 0!important;border:none!important}.photo-cell.empty .empty-content,body.printing-credential #root>div>:not(main),body.printing-credential main>:not(.employee-layout),body.printing-credential .employee-layout>:not(#credential-print-layout),body.printing-credential .no-print{display:none!important}body.printing-credential #credential-print-layout{background:#fff!important;flex-direction:row!important;justify-content:center!important;align-items:center!important;gap:15mm!important;width:100%!important;margin:30mm auto 0!important;display:flex!important}.credential-card-print{color:#000!important;box-sizing:border-box!important;page-break-inside:avoid!important;background-color:#fff!important;border:1.2mm solid #0056b3!important;border-radius:3mm!important;outline:.1mm solid #d1d5db!important;flex-direction:column!important;align-items:center!important;width:54mm!important;height:85.6mm!important;padding:2mm 1mm!important;display:flex!important;position:relative!important;overflow:hidden!important}}
