*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;background:#f0f9ff;min-height:100vh;color:#1e293b}.app-layout{display:flex;min-height:100vh}.sidebar{width:220px;background:#fff;border-right:1px solid #e2e8f0;display:flex;flex-direction:column;position:fixed;height:100vh;z-index:100}.sidebar-logo{display:flex;align-items:center;gap:10px;padding:20px;border-bottom:1px solid #e2e8f0}.sidebar-logo span{font-size:1.2rem;font-weight:700;color:#1e40af}.sidebar-nav{flex:1;padding:16px 12px}.nav-item{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:8px;color:#64748b;text-decoration:none;margin-bottom:4px;transition:all .2s}.nav-item:hover{background:#f1f5f9;color:#1e40af}.nav-item.active{background:#eff6ff;color:#1e40af;font-weight:600}.sidebar-footer{padding:16px;border-top:1px solid #e2e8f0}.user-info{display:flex;align-items:center;gap:8px;margin-bottom:12px}.user-name{font-size:.9rem;color:#475569}.btn-logout-sidebar{width:100%;padding:10px;border:1px solid #e2e8f0;border-radius:8px;background:#fff;color:#64748b;font-size:.9rem;cursor:pointer;transition:all .2s}.btn-logout-sidebar:hover{background:#fef2f2;border-color:#fecaca;color:#dc2626}.main-content{flex:1;margin-left:220px;padding:24px;min-height:100vh}.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;padding:20px;background:linear-gradient(180deg,#e0f2fe,#f0f9ff,#fff)}.login-card{background:#fff;padding:40px 50px;border-radius:16px;width:100%;max-width:420px;box-shadow:0 4px 24px #00000014;text-align:center}.login-logo{display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:30px}.logo-text{font-size:1.5rem;font-weight:700;color:#1e40af}.login-card h1{font-size:1.5rem;color:#1e293b;margin-bottom:8px;font-weight:600}.login-subtitle{color:#64748b;font-size:.9rem;margin-bottom:28px;line-height:1.5}.form-group{margin-bottom:18px;text-align:left}.form-group label{display:block;margin-bottom:6px;font-weight:500;color:#334155;font-size:.9rem}.form-group input{width:100%;padding:12px 14px;border:1.5px solid #cbd5e1;border-radius:8px;background:#fff;color:#1e293b;font-size:1rem;transition:border-color .2s,box-shadow .2s}.form-group input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f626}.btn-login{width:auto;padding:12px 40px;margin-top:10px;border:none;border-radius:8px;background:#3b82f6;color:#fff;font-size:.95rem;font-weight:600;cursor:pointer;transition:background .2s}.btn-login:hover{background:#2563eb}.btn-login:disabled{opacity:.7;cursor:not-allowed}.error-message{background:#fef2f2;border:1px solid #fecaca;color:#dc2626;padding:10px 14px;border-radius:8px;margin-bottom:18px;font-size:.9rem}.dashboard-charts{max-width:1400px}.dashboard-header-row{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px;flex-wrap:wrap;gap:16px}.dashboard-charts h1{font-size:1.8rem;color:#1e40af;margin-bottom:8px}.dashboard-subtitle{color:#64748b;margin-bottom:0}.auto-refresh-container{display:flex;align-items:center;gap:16px;background:#fff;padding:12px 20px;border-radius:12px;box-shadow:0 2px 8px #0000000f}.refresh-info,.countdown-container{display:flex;flex-direction:column;align-items:center;gap:2px}.refresh-label,.countdown-label{font-size:.7rem;color:#64748b;text-transform:uppercase}.refresh-time{font-size:.9rem;font-weight:600;color:#1e40af}.countdown-timer{font-size:1.2rem;font-weight:700;color:#10b981;font-family:monospace}.btn-refresh{background:#3b82f6;color:#fff;border:none;padding:8px 16px;border-radius:8px;cursor:pointer;font-size:.85rem;font-weight:500;transition:background .2s}.btn-refresh:hover{background:#2563eb}.charts-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-bottom:24px}.chart-card{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 8px #0000000f}.chart-card.full-width{grid-column:1 / -1}.chart-card h3{font-size:1rem;color:#334155;margin-bottom:16px;font-weight:600}.stats-summary{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.stat-card{background:#fff;border-radius:12px;padding:20px;text-align:center;box-shadow:0 2px 8px #0000000f}.stat-number{display:block;font-size:2rem;font-weight:700;color:#1e40af}.stat-label{display:block;font-size:.85rem;color:#64748b;margin-top:4px}.listado-page{max-width:1600px}.listado-header{margin-bottom:20px}.listado-header h1{font-size:1.8rem;color:#1e40af}.active-filters{display:flex;align-items:center;gap:12px;flex-wrap:wrap;padding:12px 16px;background:#eff6ff;border-radius:8px;margin-bottom:16px}.filter-label{font-weight:600;color:#1e40af}.filter-tag{background:#3b82f6;color:#fff;padding:4px 12px;border-radius:16px;font-size:.85rem}.btn-clear-filters{padding:6px 12px;border:1px solid #3b82f6;border-radius:6px;background:#fff;color:#3b82f6;font-size:.85rem;cursor:pointer;transition:all .2s}.btn-clear-filters:hover{background:#3b82f6;color:#fff}.search-container{display:flex;align-items:center;gap:16px;margin-bottom:20px}.search-input{padding:12px 20px;border:1.5px solid #e2e8f0;border-radius:8px;background:#fff;color:#1e293b;font-size:1rem;width:320px;transition:border-color .2s}.search-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.result-count{color:#64748b;font-size:.9rem}.btn-export{margin-left:auto;padding:10px 20px;background:#10b981;color:#fff;border:none;border-radius:8px;font-size:.9rem;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:8px;transition:background .2s}.btn-export:hover{background:#059669}.table-container{overflow-x:auto;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000f}.activities-table{width:100%;border-collapse:collapse;font-size:.9rem}.activities-table th,.activities-table td{padding:14px 16px;text-align:left;border-bottom:1px solid #e2e8f0}.activities-table th{background:#1e40af;color:#fff;font-weight:600;text-transform:uppercase;font-size:.75rem;letter-spacing:.5px;white-space:nowrap}.activities-table th:first-child{border-top-left-radius:12px}.activities-table th:last-child{border-top-right-radius:12px}.activities-table tbody tr:hover{background:#f8fafc}.activities-table td{color:#334155;vertical-align:top}.activities-table td.desc-corta,.activities-table td.descripcion{white-space:normal;word-wrap:break-word;min-width:200px;max-width:300px;line-height:1.4}.cliente-nombre{max-width:180px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.semaforo{display:inline-block;width:14px;height:14px;border-radius:50%}.loading{display:flex;justify-content:center;align-items:center;height:60vh;font-size:1.2rem;color:#3b82f6}.error{display:flex;justify-content:center;align-items:center;height:60vh;color:#dc2626;font-size:1.2rem}@media (max-width: 1024px){.charts-grid{grid-template-columns:1fr}.stats-summary{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.sidebar{width:60px}.sidebar-logo span,.nav-item span,.user-name{display:none}.main-content{margin-left:60px}.stats-summary{grid-template-columns:1fr}}.reporte-horas-page{padding:24px}.reporte-horas-page h1{color:#1e40af;margin-bottom:24px}.filtros-container{display:flex;flex-wrap:wrap;gap:16px;align-items:flex-end;background:#fff;padding:20px;border-radius:12px;box-shadow:0 1px 3px #0000001a;margin-bottom:24px}.filtro-group{display:flex;flex-direction:column;gap:6px}.filtro-group label{font-size:.85rem;font-weight:500;color:#64748b}.filtro-select,.filtro-input{padding:10px 14px;border:1.5px solid #e2e8f0;border-radius:8px;background:#fff;font-size:.95rem;min-width:180px;transition:border-color .2s}.filtro-select:focus,.filtro-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.filtro-select.filtro-ticket{max-width:400px}.btn-generar{padding:10px 24px;background:#3b82f6;color:#fff;border:none;border-radius:8px;font-size:.95rem;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:8px;transition:background .2s}.btn-generar:hover{background:#2563eb}.btn-generar:disabled{background:#94a3b8;cursor:not-allowed}.filtros-secundarios{margin-top:-8px;padding:12px 20px;background:#f0f9ff;border:1px solid #bfdbfe}.btn-limpiar{padding:8px 16px;background:#ef4444;color:#fff;border:none;border-radius:8px;font-size:.85rem;font-weight:500;cursor:pointer;transition:background .2s}.btn-limpiar:hover{background:#dc2626}.reporte-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding:16px 20px;background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;flex-wrap:wrap;gap:16px}.search-export-container{display:flex;align-items:center;gap:16px;flex-wrap:wrap}.search-container-inline{display:flex;align-items:center;gap:12px}.search-container-inline .search-input{width:280px;padding:10px 14px;border:1px solid #e2e8f0;border-radius:8px;font-size:.9rem}.search-container-inline .search-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.search-container-inline .result-count{font-size:.85rem;color:#64748b;white-space:nowrap}.total-horas{display:flex;align-items:center;gap:12px}.totales-costos{display:flex;align-items:center;gap:24px}.total-item{display:flex;align-items:center;gap:8px}.total-item.total-costo .total-value{color:#10b981}.total-label{font-size:1.1rem;font-weight:500;color:#64748b}.total-value{font-size:1.8rem;font-weight:700;color:#3b82f6}.total-row{background:#f0f9ff}.total-row td{border-top:2px solid #3b82f6}.no-data{text-align:center;padding:40px;color:#64748b;font-size:1.1rem;background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a}.error-message{background:#fef2f2;color:#dc2626;padding:12px 16px;border-radius:8px;margin-bottom:16px}.success-message{background:#f0fdf4;color:#16a34a;padding:12px 16px;border-radius:8px;margin-bottom:16px;border:1px solid #bbf7d0}.admin-page{padding:24px}.admin-header{margin-bottom:24px}.admin-header h2{font-size:1.75rem;color:#1e293b;margin-bottom:8px}.admin-subtitle{color:#64748b;font-size:.95rem}.admin-actions{display:flex;gap:12px;margin-bottom:20px;flex-wrap:wrap}.btn-sync{padding:10px 20px;background:#8b5cf6;color:#fff;border:none;border-radius:8px;font-size:.95rem;font-weight:500;cursor:pointer;transition:background .2s}.btn-sync:hover{background:#7c3aed}.btn-sync:disabled{background:#a78bfa;cursor:not-allowed}.btn-add{padding:10px 20px;background:#10b981;color:#fff;border:none;border-radius:8px;font-size:.95rem;font-weight:500;cursor:pointer;transition:background .2s}.btn-add:hover{background:#059669}.btn-delete-multiple{padding:10px 20px;background:#ef4444;color:#fff;border:none;border-radius:8px;font-size:.95rem;font-weight:500;cursor:pointer;transition:background .2s}.btn-delete-multiple:hover{background:#dc2626}.btn-delete-multiple:disabled{background:#9ca3af;cursor:not-allowed}.row-selected{background:#dbeafe!important}.row-selected:hover{background:#bfdbfe!important}.add-form{background:#f8fafc;padding:20px;border-radius:12px;margin-bottom:20px;border:1px solid #e2e8f0}.add-form h3{margin-bottom:16px;color:#1e293b;font-size:1.1rem}.form-row{display:flex;gap:16px;flex-wrap:wrap;align-items:flex-end}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:.85rem;color:#64748b;font-weight:500}.form-group input,.form-group select{padding:10px 14px;border:1.5px solid #e2e8f0;border-radius:8px;font-size:.95rem;min-width:150px}.form-group input:focus,.form-group select:focus{outline:none;border-color:#3b82f6}.btn-save{padding:10px 24px;background:#3b82f6;color:#fff;border:none;border-radius:8px;font-weight:500;cursor:pointer;transition:background .2s}.btn-save:hover{background:#2563eb}.admin-table{width:100%;border-collapse:collapse;background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 1px 3px #0000001a}.admin-table th{background:#f8fafc;padding:14px 16px;text-align:left;font-weight:600;color:#64748b;font-size:.85rem;text-transform:uppercase;border-bottom:1px solid #e2e8f0}.admin-table td{padding:14px 16px;border-bottom:1px solid #f1f5f9;font-size:.95rem}.admin-table tr:hover{background:#f8fafc}.admin-table tr.row-inactive{opacity:.6;background:#fafafa}.number-cell{font-family:SF Mono,Monaco,monospace;text-align:right}.actions-cell{display:flex;gap:8px}.btn-action{width:32px;height:32px;border:none;border-radius:6px;cursor:pointer;font-size:1rem;display:flex;align-items:center;justify-content:center;transition:all .2s}.btn-edit{background:#eff6ff;color:#3b82f6}.btn-edit:hover{background:#dbeafe}.btn-delete{background:#fef2f2;color:#ef4444}.btn-delete:hover{background:#fee2e2}.btn-save-small{background:#f0fdf4;color:#16a34a}.btn-save-small:hover{background:#dcfce7}.btn-cancel{background:#f1f5f9;color:#64748b}.btn-cancel:hover{background:#e2e8f0}.edit-input{padding:8px 12px;border:1.5px solid #3b82f6;border-radius:6px;font-size:.9rem;width:100%}.edit-input.edit-number{width:100px;text-align:right}.edit-select{padding:8px 12px;border:1.5px solid #3b82f6;border-radius:6px;font-size:.9rem}.empty-state{text-align:center;padding:48px 24px;color:#64748b}.empty-state p{margin-bottom:8px}
