*{box-sizing:border-box;margin:0;padding:0}:root{--sidebar-w:260px;--sidebar-collapsed-w:80px;--bg-color:#f8fafc;--sidebar-bg:#3b82f6;--primary:#3b82f6;--text-main:#0f172a;--text-muted:#64748b;--white:#ffffff;--border:#f1f5f9}body{background-color:var(--bg-color);color:var(--text-main);font-family:Outfit,Inter,sans-serif;min-height:100vh;-webkit-tap-highlight-color:transparent;overflow:hidden}.app-container{flex-direction:column;width:100%;min-height:100vh}.top-navbar{background-color:var(--white);padding:0 1.5rem;height:70px;justify-content:space-between;position:sticky;top:0;z-index:1000;box-shadow:0 1px 3px rgba(0,0,0,.05);border-bottom:1px solid var(--border)}.nav-brand,.top-navbar{display:flex;align-items:center}.nav-brand{color:var(--text-main);font-size:1.25rem;font-weight:800;gap:.75rem;white-space:nowrap}.nav-links{height:100%}.nav-links,.top-nav-item{display:flex;align-items:center;gap:.5rem}.top-nav-item{padding:.5rem .75rem;color:var(--text-muted);background:transparent;border:none;border-radius:.5rem;cursor:pointer;font-size:.85rem;font-weight:600;transition:all .2s;white-space:nowrap;text-decoration:none;height:40px}.top-nav-item:hover{background:#f1f5f9;color:var(--text-main)}.top-nav-item.active{background:var(--primary);color:var(--white)}.user-menu{display:flex;align-items:center}.main-content{margin-left:0!important;width:100%;padding:2rem 1.5rem;flex:1 1}.content-container{max-width:1400px;margin:0 auto}.card{background:var(--white);border-radius:1rem;border:1px solid var(--border);padding:2rem;margin-bottom:2rem;box-shadow:0 1px 3px rgba(0,0,0,.05)}.chart-container{height:320px;width:100%}.page-header{margin-bottom:2rem}.page-title{font-size:1.5rem;font-weight:700;color:#0f172a;margin-bottom:.25rem}.page-subtitle{color:var(--text-muted);font-size:.875rem}.tabs{display:flex;gap:2rem;border-bottom:1px solid var(--border);margin-bottom:2rem}.tab{padding:.75rem .25rem;color:var(--text-muted);font-size:.875rem;font-weight:600;background:none;border:none;cursor:pointer;position:relative}.tab.active{color:var(--primary)}.tab.active:after{content:"";position:absolute;bottom:-1px;left:0;right:0;height:2px;background-color:var(--primary)}.controls-row{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.5rem;background:var(--white);padding:1.25rem;border-radius:1rem;border:1px solid var(--border)}.search-wrapper{position:relative;flex:1 1;min-width:250px;max-width:400px}.date-filters{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.search-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:#94a3b8}.input-field{width:100%;padding:.75rem 1rem .75rem 2.5rem;border-radius:.75rem;border:1px solid var(--border);background:#f8fafc;font-size:.875rem;outline:none;transition:all .2s}.input-field:focus{border-color:var(--primary);background:var(--white);box-shadow:0 0 0 3px rgba(59,130,246,.1)}.select-field{padding:.75rem 2.5rem .75rem 1rem;border-radius:.75rem;border:1px solid var(--border);background:#f8fafc;appearance:none;min-width:150px}.btn-pdf,.select-field{font-size:.875rem;cursor:pointer}.btn-pdf{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;border:none;border-radius:.75rem;font-weight:700;color:var(--white);background:var(--sidebar-bg);transition:all .2s;white-space:nowrap}.btn-pdf:hover{background:#1e293b;transform:translateY(-1px);box-shadow:0 4px 6px -1px rgba(0,0,0,.1)}.data-table-wrapper{overflow-x:auto;border:1px solid var(--border);border-radius:.75rem}.data-table{width:100%;border-collapse:collapse}.data-table th{background:#f8fafc;padding:.6rem 1rem;text-align:left;font-size:.7rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.data-table td,.data-table th{border-bottom:1px solid var(--border)}.data-table td{padding:.5rem 1rem;font-size:.85rem}.text-bold{font-weight:700;color:#0f172a}.badge{padding:.25rem .5rem;border-radius:.375rem;font-size:.7rem;font-weight:700;background:#f1f5f9}.success-text{color:#10b981;font-weight:600}.error-text{color:#ef4444;font-weight:600}.results-count{font-size:.75rem;font-weight:700;color:#94a3b8;text-transform:uppercase;margin-bottom:1rem}.hidden{display:none!important}@keyframes spin{to{transform:rotate(1turn)}}.animate-spin{animation:spin 1s linear infinite}.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:75px;background:white;box-shadow:0 -4px 20px rgba(0,0,0,.04);justify-content:space-around;padding:0 1rem 12px;z-index:2000;border-top:1px solid #f1f5f9}.bottom-nav,.bottom-nav-item{display:flex;align-items:center}.bottom-nav-item{flex-direction:column;gap:.35rem;color:#94a3b8;background:none;border:none;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.025em;cursor:pointer;transition:all .2s;flex:1 1}.bottom-nav-item.active{color:#3b82f6}.bottom-nav-item svg{width:24px;height:24px}.mobile-directory{display:flex;flex-direction:column;gap:1.25rem;padding-bottom:20px;animation:slideUp .5s cubic-bezier(.16,1,.3,1)}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.directory-header-row{display:flex;align-items:center;justify-content:space-between;padding:.5rem 0}.back-btn-mobile{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:none;border:none;color:#1e293b;cursor:pointer}.directory-title-mobile{font-size:1.35rem;font-weight:700;color:#0f172a;flex:1 1;text-align:center}.mobile-search-section{display:flex;gap:.75rem;align-items:center}.search-field-mobile{flex:1 1;position:relative;background:#f8fafc;border-radius:1rem;border:1px solid #f1f5f9;padding:.875rem 1rem .875rem 3rem;font-size:1rem;outline:none}.search-field-mobile::placeholder{color:#94a3b8}.search-icon-mobile{position:absolute;left:1.125rem;top:50%;transform:translateY(-50%);color:#94a3b8}.filter-btn-mobile{width:52px;height:52px;background:white;border:1px solid #f1f5f9;border-radius:1rem;display:flex;align-items:center;justify-content:center;color:#3b82f6;box-shadow:0 1px 2px rgba(0,0,0,.05)}.category-chips-container{display:flex;gap:.75rem;overflow-x:auto;margin:0 -1.5rem;padding:.25rem 1.5rem 1rem;scrollbar-width:none}.category-chips-container::-webkit-scrollbar{display:none}.category-chip{padding:.75rem 1.5rem;background:white;border:1px solid #f1f5f9;border-radius:2rem;font-size:.9375rem;font-weight:400;color:#64748b;white-space:nowrap;cursor:pointer;transition:all .2s;box-shadow:0 1px 2px rgba(0,0,0,.03)}.category-chip.active{background:#3b82f6;color:white;border-color:#3b82f6;font-weight:500}.employees-list-mobile{display:flex;flex-direction:column;gap:1rem}.employee-card-mobile{background:white;border-radius:1.25rem;padding:1.125rem;display:flex;align-items:center;gap:1rem;box-shadow:0 4px 12px rgba(0,0,0,.03);border:1px solid #f1f5f9;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1)}.employee-card-mobile:active{background-color:#f8fafc;transform:scale(.98)}.avatar-container-mobile{position:relative;width:64px;height:64px;flex-shrink:0}.avatar-image-mobile{width:100%;height:100%;border-radius:50%;object-fit:cover;background:#f1f5f9;border:2px solid white}.status-dot-mobile{position:absolute;bottom:2px;right:2px;width:14px;height:14px;background:#10b981;border:2.5px solid white;border-radius:50%}.status-dot-mobile.inactive{background:#cbd5e1}.employee-details-mobile{flex:1 1}.employee-name-mobile{font-size:1.15rem;font-weight:600;color:#0f172a;margin-bottom:.25rem}.employee-role-mobile{font-size:.8125rem;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.25rem}.employee-dept-mobile{font-size:.9375rem;color:#3b82f6;font-weight:600}.chevron-icon-mobile{color:#cbd5e1}.fab-button-mobile{position:fixed;bottom:100px;right:20px;width:64px;height:64px;background:#3b82f6;color:white;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 10px 20px rgba(59,130,246,.35);border:none;z-index:1000}@media (max-width:768px){.top-navbar{display:none!important}.main-content{padding:1.25rem!important;background-color:#f8fafc}.controls-row,.data-table-wrapper,.page-header{display:none!important}}@media (min-width:769px){.bottom-nav,.fab-button-mobile,.mobile-directory{display:none!important}}.income-registration-mobile{position:fixed;top:0;left:0;right:0;bottom:0;background:#f8fafc;z-index:3000;display:flex;flex-direction:column;overflow-y:auto;padding-bottom:110px;animation:slideUp .4s cubic-bezier(.16,1,.3,1)}.income-reg-header{background:white;padding:1rem 1.25rem;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:10;border-bottom:1px solid #f1f5f9}.income-reg-title{font-size:1.15rem;font-weight:700;color:#0f172a}.income-reg-employee-card-mobile{background:white;margin:1.25rem;padding:1.25rem;border-radius:1.25rem;display:flex;align-items:center;gap:1rem;box-shadow:0 4px 12px rgba(0,0,0,.03);border:1px solid #f1f5f9}.income-reg-avatar-mobile{width:52px;height:52px;background:#eff6ff;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#3b82f6}.income-reg-section-mobile{padding:0 1.25rem;margin-bottom:2.25rem}.income-reg-section-header-mobile{display:flex;align-items:center;gap:.75rem;margin-bottom:1.25rem;color:#1e293b;font-size:.875rem;font-weight:800;text-transform:uppercase;letter-spacing:.05em}.income-reg-field-group-mobile{display:flex;flex-direction:column;gap:1.25rem}.income-reg-input-wrapper-mobile{display:flex;flex-direction:column;gap:.5rem}.income-reg-label-mobile{font-size:.875rem;font-weight:600;color:#64748b}.income-reg-input-mobile{background:#f8fafc;border:1px solid #f1f5f9;border-radius:.875rem;padding:1rem 1.125rem;font-size:1rem;color:#0f172a;outline:none;transition:all .2s}.income-reg-input-mobile:focus{background:white;border-color:#3b82f6;box-shadow:0 0 0 4px rgba(59,130,246,.08)}.income-reg-grid-mobile{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.income-reg-footer-mobile{position:fixed;bottom:0;left:0;right:0;background:white;padding:1.25rem 1.5rem;border-top:1px solid #f1f5f9;z-index:10;box-shadow:0 -10px 20px rgba(0,0,0,.02)}.income-reg-total-row-mobile{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem}.income-reg-total-label-mobile{font-size:1rem;color:#64748b;font-weight:500}.income-reg-total-value-mobile{font-size:1.5rem;font-weight:800;color:#3b82f6}.income-reg-btn-save-mobile{width:100%;background:#3b82f6;color:white;padding:1.125rem;border-radius:1rem;font-size:1.1rem;font-weight:700;border:none;display:flex;align-items:center;justify-content:center;gap:.75rem;box-shadow:0 8px 24px rgba(59,130,246,.25);transition:transform .2s}.income-reg-btn-save-mobile:active{transform:scale(.98)}.home-dashboard-mobile{padding:1.5rem 1.25rem 100px;background-color:#f8fafc;min-height:100vh;animation:fadeIn .4s ease-out}@media (min-width:769px){.home-dashboard-mobile{display:none!important}}.home-header{justify-content:space-between;margin-bottom:2rem}.home-header,.home-user-info{display:flex;align-items:center}.home-user-info{gap:.75rem}.home-user-avatar{width:48px;height:48px;border-radius:50%;object-fit:cover}.home-greeting-sub{font-size:.75rem;color:#64748b;font-weight:500}.home-greeting-name{font-size:1.1rem;font-weight:700;color:#0f172a;line-height:1.2}.home-notification-btn{width:44px;height:44px;background:white;border-radius:12px;display:flex;align-items:center;justify-content:center;color:#1e293b;box-shadow:0 4px 12px rgba(0,0,0,.05);border:none}.home-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.home-section-title{font-size:1.25rem;font-weight:700;color:#0f172a}.home-month-selector{padding:.4rem .75rem;background:#eff6ff;color:#1e40af;border-radius:20px;font-size:.8rem;font-weight:600;display:flex;align-items:center;gap:.25rem;border:none}.home-card-main{background:white;border-radius:1.25rem;padding:1.5rem;box-shadow:0 8px 20px rgba(0,0,0,.04);margin-bottom:1rem}.home-card-label{font-size:.85rem;color:#64748b;font-weight:500;margin-bottom:.25rem}.home-card-value-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.home-card-value{font-size:2rem;font-weight:800;color:#1d4ed8;letter-spacing:-.5px}.home-badge-green{background:#dcfce7;color:#166534;padding:.2rem .5rem;border-radius:6px;font-size:.75rem;font-weight:600;display:flex;align-items:center;gap:.2rem}.home-card-icon-wrapper{width:48px;height:48px;background:#f1f5f9;border-radius:14px;display:flex;align-items:center;justify-content:center;color:#94a3b8}.home-progress-container{display:flex;align-items:center;gap:.75rem}.home-progress-bar-bg{flex:1 1;height:8px;background:#f1f5f9;border-radius:4px;overflow:hidden}.home-progress-bar-fill{height:100%;background:#1d4ed8;width:75%;border-radius:4px}.home-progress-text{font-size:.75rem;color:#94a3b8;font-weight:500}.home-cards-row{display:flex;gap:1rem;margin-bottom:2rem}.home-card-small{flex:1 1;background:white;border-radius:1.25rem;padding:1.25rem;box-shadow:0 8px 20px rgba(0,0,0,.04)}.home-icon-green,.home-icon-red{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;margin-bottom:1rem}.home-icon-green{background:#dcfce7;color:#16a34a}.home-icon-red{background:#fee2e2;color:#dc2626}.home-small-label{font-size:.8rem;color:#64748b;font-weight:500;margin-bottom:.25rem}.home-small-value{font-size:1.5rem;font-weight:700;color:#0f172a;margin-bottom:.5rem}.home-small-trend-green{font-size:.7rem;color:#16a34a;font-weight:600}.home-small-trend-red{font-size:.7rem;color:#dc2626;font-weight:600}.home-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.home-grid-item{background:white;border-radius:1.25rem;padding:1.25rem .5rem;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;box-shadow:0 4px 12px rgba(0,0,0,.03);border:1px solid transparent;cursor:pointer;transition:all .2s}.home-grid-item:active{transform:scale(.95);border-color:#e2e8f0;background:#f8fafc}.home-grid-icon{width:48px;height:48px;background:#f8fafc;border-radius:16px;display:flex;align-items:center;justify-content:center;color:#334155}.home-grid-label{font-size:.75rem;font-weight:600;color:#1e293b;text-align:center}.bottom-nav-fab-container{flex:1 1;display:flex;justify-content:center;position:relative;top:-20px}.bottom-nav-fab{width:60px;height:60px;background:#1d4ed8;border-radius:50%;display:flex;align-items:center;justify-content:center;color:white;box-shadow:0 8px 20px rgba(29,78,216,.4);border:none;cursor:pointer;transition:transform .2s}.bottom-nav-fab:active{transform:scale(.95)}.mobile-income-consult{display:flex;flex-direction:column;gap:1.25rem;padding-bottom:20px;animation:slideUp .5s cubic-bezier(.16,1,.3,1)}.results-info-mobile{display:flex;justify-content:space-between;align-items:center;padding:0 .25rem}.results-title-mobile{font-size:1.25rem;font-weight:700;color:#0f172a}.results-count-mobile{font-size:.875rem;color:#94a3b8;font-weight:500}.income-list-mobile{display:flex;flex-direction:column;gap:1rem}.income-card-mobile{background:white;border-radius:1.25rem;padding:1.25rem;display:flex;align-items:center;gap:1rem;box-shadow:0 4px 12px rgba(0,0,0,.03);border:1px solid #f1f5f9;transition:all .2s}.income-card-mobile:active{transform:scale(.98);background-color:#f8fafc}.income-avatar{width:48px;height:48px;background:#f1f5f9;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;color:#3b82f6;font-size:1.2rem;flex-shrink:0;overflow:hidden}.income-avatar img{width:100%;height:100%;object-fit:cover}.income-info{flex:1 1;display:flex;flex-direction:column;gap:.25rem}.income-bottom-row,.income-top-row{display:flex;justify-content:space-between;align-items:center}.income-emp-name{font-size:1.1rem;font-weight:600;color:#0f172a}.income-amount{font-size:1.1rem;font-weight:700;color:#10b981}.income-rubro{font-size:.875rem;color:#64748b;font-weight:500}.income-date{font-size:.8125rem;color:#94a3b8}@media (min-width:769px){.mobile-income-consult{display:none!important}}.income-card-expanded{grid-column:span 2}.income-details-expanded{width:100%;animation:fadeIn .2s ease-out}