.timesheet-page{max-width:100%;overflow-x:hidden}.timesheet-header{flex-wrap:wrap;gap:var(--spacing-md)}.timesheet-actions{display:flex;align-items:center;gap:var(--spacing-sm);flex-wrap:wrap}.week-nav{display:flex;align-items:center;gap:var(--spacing-xs)}.week-range{min-width:110px;text-align:center;font-weight:500;font-size:var(--font-size-sm)}.timesheet-tabs{display:flex;gap:var(--spacing-xs);margin-bottom:var(--spacing-md);overflow-x:auto;padding-bottom:var(--spacing-xs)}.timesheet-tab{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--radius-md);font-size:var(--font-size-sm);cursor:pointer;white-space:nowrap;transition:all var(--transition-fast)}.timesheet-tab:hover{border-color:var(--color-primary-500)}.timesheet-tab.active{background:var(--color-primary-50);border-color:var(--color-primary-500);color:var(--color-primary-700)}[data-theme=dark] .timesheet-tab.active{background:#0ea5e91a;color:var(--color-primary-400)}.timesheet-tab.add-tab{background:transparent;border-style:dashed;color:var(--text-tertiary)}.timesheet-tab.add-tab:hover{color:var(--color-primary-500);border-color:var(--color-primary-500)}.timesheet-status-bar{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--bg-secondary);border-radius:var(--radius-lg);margin-bottom:var(--spacing-md);flex-wrap:wrap}.status-info{display:flex;align-items:center;gap:var(--spacing-sm);flex-wrap:wrap}.status-detail{font-size:var(--font-size-sm);color:var(--text-tertiary)}.status-actions{display:flex;gap:var(--spacing-sm)}.selector-button{display:flex;align-items:center;gap:var(--spacing-xs);width:100%;padding:var(--spacing-sm);background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--radius-md);cursor:pointer;font-size:var(--font-size-sm);text-align:left;transition:all var(--transition-fast)}.selector-button:hover:not(:disabled){border-color:var(--color-primary-500);background:var(--bg-hover)}.selector-button.disabled,.selector-button:disabled{cursor:not-allowed;opacity:.7;background:var(--bg-secondary)}.selector-color{width:10px;height:10px;border-radius:50%;flex-shrink:0}.selector-text{color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.selector-placeholder{color:var(--text-tertiary)}.selection-modal{max-width:450px;width:100%;max-height:80vh;display:flex;flex-direction:column}.selection-search{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md);border-bottom:1px solid var(--border-primary)}.selection-search input{flex:1;border:none;background:transparent;font-size:var(--font-size-md);color:var(--text-primary);outline:none}.selection-search input::placeholder{color:var(--text-tertiary)}.selection-list{flex:1;overflow-y:auto;max-height:400px}.selection-empty{padding:var(--spacing-xl);text-align:center;color:var(--text-tertiary)}.selection-item{display:flex;align-items:center;gap:var(--spacing-md);width:100%;padding:var(--spacing-md);background:transparent;border:none;border-bottom:1px solid var(--border-primary);cursor:pointer;text-align:left;transition:background var(--transition-fast)}.selection-item:last-child{border-bottom:none}.selection-item:hover{background:var(--bg-hover)}.selection-item.selected{background:var(--color-primary-50)}[data-theme=dark] .selection-item.selected{background:#0ea5e91a}.selection-color{width:12px;height:12px;border-radius:50%;flex-shrink:0}.selection-content{flex:1;min-width:0}.selection-name{display:block;font-weight:500;color:var(--text-primary)}.selection-sub{display:block;font-size:var(--font-size-xs);color:var(--text-tertiary);margin-top:2px}.timesheet-table-wrapper{overflow-x:auto}.timesheet-table{min-width:1100px}.timesheet-table th{text-align:center;vertical-align:bottom;white-space:nowrap}.timesheet-table .col-project{width:160px;min-width:160px}.timesheet-table .col-category{width:130px;min-width:130px}.timesheet-table .col-description{width:auto;min-width:150px}.timesheet-table .col-hours{width:60px;min-width:60px;text-align:center}.timesheet-table .col-total{width:70px;min-width:70px;text-align:center;font-weight:600}.timesheet-table .col-status{width:110px;min-width:110px}.timesheet-table .col-actions{width:50px;min-width:50px}.date-label{font-weight:400;font-size:var(--font-size-xs);color:var(--text-tertiary)}.description-button{width:100%;padding:var(--spacing-sm);background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--radius-sm);font-size:var(--font-size-sm);color:var(--text-tertiary);text-align:left;cursor:pointer;transition:all var(--transition-fast);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}.description-button:hover:not(:disabled){border-color:var(--color-primary-500);background:var(--bg-hover)}.description-button.has-content{color:var(--text-primary)}.description-button:disabled{cursor:not-allowed;opacity:.7;background:var(--bg-secondary)}.description-modal{max-width:600px;width:100%}.description-textarea{width:100%;min-height:150px;padding:var(--spacing-md);border:1px solid var(--border-primary);border-radius:var(--radius-md);background:var(--bg-primary);font-size:var(--font-size-md);font-family:inherit;color:var(--text-primary);resize:vertical;line-height:1.5}.description-textarea:focus{outline:none;border-color:var(--color-primary-500);box-shadow:0 0 0 3px #0ea5e91a}.description-textarea::placeholder{color:var(--text-tertiary)}.description-textarea:disabled{background:var(--bg-secondary);cursor:not-allowed;opacity:.7}.description-hint{margin-top:var(--spacing-sm);font-size:var(--font-size-sm);color:var(--text-tertiary)}.hours-input{width:100%;padding:var(--spacing-sm);text-align:center;border:1px solid var(--border-primary);border-radius:var(--radius-sm);background:var(--bg-primary);font-size:var(--font-size-sm);color:var(--text-primary);-moz-appearance:textfield}.hours-input::-webkit-outer-spin-button,.hours-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.hours-input:focus{outline:none;border-color:var(--color-primary-500)}.hours-input::placeholder{color:var(--text-tertiary)}.hours-input:disabled{background:var(--bg-secondary);cursor:not-allowed;opacity:.7}.status-select{width:100%;padding:var(--spacing-sm);border:1px solid var(--border-primary);border-radius:var(--radius-sm);background:var(--bg-primary);font-size:var(--font-size-sm);color:var(--text-primary);cursor:pointer}.status-select:focus{outline:none;border-color:var(--color-primary-500)}.status-select:disabled{background:var(--bg-secondary);cursor:not-allowed;opacity:.7}.add-row td{padding:0!important}.add-row-btn{width:100%;justify-content:flex-start;padding:var(--spacing-md)!important;color:var(--text-tertiary)}.add-row-btn:hover{color:var(--color-primary-500)}.totals-row{background:var(--bg-secondary);font-weight:600}.totals-row td{border-bottom:none!important}.totals-label{text-align:right!important;padding-right:var(--spacing-md)!important}.week-total{color:var(--color-primary-600)}.hidden{display:none!important}.view-toggle{display:flex;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-md);overflow:hidden}.view-toggle-btn{padding:var(--spacing-xs) var(--spacing-md);font-size:var(--font-size-sm);font-weight:500;border:none;background:transparent;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.view-toggle-btn.active{background:var(--color-primary-500);color:#fff}.view-toggle-btn:hover:not(.active){background:var(--bg-hover)}.day-view{animation:fadeIn var(--transition-normal);max-width:100%;overflow-x:hidden}.day-nav{display:flex;align-items:center;justify-content:center;gap:var(--spacing-lg);margin-bottom:var(--spacing-md)}.day-nav-center{display:flex;flex-direction:column;align-items:center;min-width:200px}.day-nav-name{font-size:var(--font-size-xl);font-weight:700;color:var(--text-primary)}.day-nav-date{font-size:var(--font-size-sm);color:var(--text-tertiary)}.day-pills{display:flex;gap:var(--spacing-xs);justify-content:center;margin-bottom:var(--spacing-lg);max-width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}.day-pill{display:flex;flex-direction:column;align-items:center;gap:2px;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--border-primary);border-radius:var(--radius-lg);background:var(--bg-primary);cursor:pointer;transition:all var(--transition-fast);min-width:52px}.day-pill:hover{border-color:var(--color-primary-400);background:var(--bg-hover)}.day-pill.active{background:var(--color-primary-500);border-color:var(--color-primary-500);color:#fff;box-shadow:0 2px 8px #0ea5e94d}.day-pill.today:not(.active){border-color:var(--color-primary-300)}.day-pill.today:not(.active) .day-pill-name{color:var(--color-primary-500)}.day-pill.has-hours:not(.active){background:var(--color-primary-50)}[data-theme=dark] .day-pill.has-hours:not(.active){background:#0ea5e914}.day-pill-name{font-size:var(--font-size-xs);font-weight:600}.day-pill-hours{font-size:var(--font-size-sm);font-weight:700}.day-pill.active .day-pill-name,.day-pill.active .day-pill-hours{color:#fff}.day-total-header{text-align:center;padding:var(--spacing-lg) var(--spacing-md);margin-bottom:var(--spacing-lg);background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--radius-xl)}.day-total-value{font-size:3rem;font-weight:800;color:var(--color-primary-500);line-height:1;letter-spacing:-1px}.day-total-label{font-size:var(--font-size-sm);color:var(--text-tertiary);margin-top:var(--spacing-xs)}.day-entries{display:flex;flex-direction:column;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.day-entry-card{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);transition:all var(--transition-fast)}.day-entry-card.has-hours{border-left:3px solid var(--color-primary-500)}.day-entry-card.no-hours{opacity:.55}.day-entry-card:hover{box-shadow:0 2px 8px #0000000f}[data-theme=dark] .day-entry-card:hover{box-shadow:0 2px 8px #0003}.day-entry-left{display:flex;align-items:flex-start;gap:var(--spacing-md);flex:1;min-width:0}.day-entry-color{width:8px;height:8px;border-radius:50%;flex-shrink:0;margin-top:7px}.day-entry-info{flex:1;min-width:0}.day-entry-project{font-weight:600;font-size:var(--font-size-md);color:var(--text-primary);line-height:1.3}.day-entry-code{display:inline-block;background:var(--bg-secondary);padding:1px 6px;border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:700;color:var(--text-secondary);margin-right:var(--spacing-xs);letter-spacing:.5px}.day-entry-empty{color:var(--text-tertiary);font-style:italic}.day-entry-meta{display:flex;align-items:center;gap:var(--spacing-md);margin-top:4px;font-size:var(--font-size-sm)}.day-entry-category{display:flex;align-items:center;gap:4px;color:var(--text-secondary)}.day-entry-cat-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.day-entry-status{font-weight:500;font-size:var(--font-size-xs)}.day-entry-desc{margin-top:4px;font-size:var(--font-size-sm);color:var(--text-tertiary);line-height:1.4;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}.day-entry-right{display:flex;align-items:baseline;gap:4px;flex-shrink:0}.day-hours-input{width:72px;padding:var(--spacing-sm) var(--spacing-md);text-align:center;border:1px solid var(--border-primary);border-radius:var(--radius-md);background:var(--bg-primary);font-size:var(--font-size-xl);font-weight:700;color:var(--color-primary-600);-moz-appearance:textfield;transition:all var(--transition-fast)}.day-hours-input::-webkit-outer-spin-button,.day-hours-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.day-hours-input:focus{outline:none;border-color:var(--color-primary-500);box-shadow:0 0 0 3px #0ea5e926}.day-hours-input::placeholder{color:var(--color-gray-300);font-weight:400}.day-hours-display{font-size:var(--font-size-xl);font-weight:700;color:var(--color-primary-600)}.day-hours-display.zero{color:var(--text-tertiary);font-weight:400}.day-hours-unit{font-size:var(--font-size-sm);color:var(--text-tertiary);font-weight:500}.day-entry-selectors{display:flex;flex-direction:column;gap:var(--spacing-xs);margin-bottom:var(--spacing-xs)}.day-entry-selector-row{display:flex;gap:var(--spacing-xs)}.day-entry-selector-row .selector-button{flex:1}.day-status-select{flex:0 0 auto;width:auto;min-width:130px}.day-entry-desc-btn{display:block;width:100%;padding:4px 0;background:none;border:none;font-size:var(--font-size-sm);color:var(--text-tertiary);text-align:left;cursor:pointer;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%;transition:color var(--transition-fast)}.day-entry-desc-btn:hover:not(:disabled){color:var(--color-primary-500)}.day-entry-desc-btn.has-content{color:var(--text-secondary)}.day-entry-desc-btn:disabled{cursor:default}.day-entry-delete{color:var(--text-tertiary)!important;margin-left:var(--spacing-xs)}.day-entry-delete:hover{color:var(--color-error-500)!important}.day-add-entry{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);width:100%;padding:var(--spacing-md) var(--spacing-lg);background:transparent;border:2px dashed var(--border-primary);border-radius:var(--radius-lg);color:var(--text-tertiary);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.day-add-entry:hover{border-color:var(--color-primary-400);color:var(--color-primary-500);background:var(--color-primary-50)}[data-theme=dark] .day-add-entry:hover{background:#0ea5e90f}.day-empty{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-2xl);color:var(--text-tertiary)}.day-week-summary{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md) var(--spacing-lg);background:var(--bg-secondary);border-radius:var(--radius-lg)}.day-week-summary-label{font-size:var(--font-size-sm);color:var(--text-secondary);font-weight:500}.day-week-summary-value{font-size:var(--font-size-lg);font-weight:700;color:var(--color-primary-600)}.timesheet-mobile{display:none}.timesheet-card{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:var(--spacing-md);margin-bottom:var(--spacing-md)}.timesheet-card-header{display:flex;align-items:flex-start;gap:var(--spacing-sm);margin-bottom:var(--spacing-sm)}.timesheet-card-selectors{flex:1;display:flex;flex-direction:column;gap:var(--spacing-xs)}.timesheet-card-hours{display:grid;grid-template-columns:repeat(7,1fr);gap:var(--spacing-xs);margin-bottom:var(--spacing-sm)}.hour-cell{display:flex;flex-direction:column;align-items:center;gap:2px}.hour-cell label{font-size:var(--font-size-xs);font-weight:600;color:var(--text-secondary)}.hour-cell input{width:100%;padding:var(--spacing-sm);text-align:center;border:1px solid var(--border-primary);border-radius:var(--radius-sm);background:var(--bg-primary);font-size:var(--font-size-sm);color:var(--text-primary);-moz-appearance:textfield}.hour-cell input::-webkit-outer-spin-button,.hour-cell input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.hour-cell input:focus{outline:none;border-color:var(--color-primary-500)}.hour-cell input::placeholder{color:var(--text-tertiary)}.timesheet-card-footer{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md);padding-top:var(--spacing-sm);border-top:1px solid var(--border-primary)}.timesheet-card-footer .status-select{flex:1;max-width:150px}.entry-total{font-size:var(--font-size-sm);color:var(--text-secondary)}.entry-total strong{color:var(--color-primary-600)}.add-card-btn{width:100%;justify-content:center;margin-bottom:var(--spacing-md)}.mobile-totals{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md);background:var(--bg-secondary);border-radius:var(--radius-lg);font-size:var(--font-size-md)}.mobile-totals strong{font-size:var(--font-size-lg);color:var(--color-primary-600)}@media (max-width: 1024px){.timesheet-table-wrapper:not(.hidden){display:none}.timesheet-mobile:not(.hidden){display:block}}@media (max-width: 640px){.timesheet-header{flex-direction:column;align-items:flex-start}.timesheet-actions{width:100%;justify-content:space-between}.btn-text{display:none}.day-total-value{font-size:2.5rem}.day-pills{gap:4px}.day-pill{min-width:40px;padding:var(--spacing-xs) var(--spacing-sm)}.day-entry-card{padding:var(--spacing-md);flex-wrap:wrap}.day-entry-left{width:100%;min-width:0}.day-entry-right{width:100%;justify-content:flex-end;padding-top:var(--spacing-sm);border-top:1px solid var(--border-primary);margin-top:var(--spacing-sm)}.timesheet-card-hours .hour-cell:nth-child(n+5){grid-column:span 1}.timesheet-card-hours{grid-template-columns:repeat(4,1fr)}.selection-modal,.description-modal{max-width:100%;margin:var(--spacing-sm);max-height:90vh}}@media (max-width: 400px){.week-range{min-width:auto;font-size:var(--font-size-xs)}.timesheet-card-hours{grid-template-columns:repeat(3,1fr)}.hour-cell:last-child{grid-column:span 1}}.controlling-tabs{display:flex;gap:var(--spacing-xs);margin-bottom:var(--spacing-lg);border-bottom:1px solid var(--border-primary);padding-bottom:var(--spacing-xs)}.controlling-tab{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg);background:transparent;border:none;border-radius:var(--radius-md) var(--radius-md) 0 0;font-size:var(--font-size-sm);font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);position:relative}.controlling-tab:hover{color:var(--text-primary);background:var(--bg-hover)}.controlling-tab.active{color:var(--color-primary-600);background:var(--bg-primary)}.controlling-tab.active:after{content:"";position:absolute;bottom:-1px;left:0;right:0;height:2px;background:var(--color-primary-500)}.tab-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 var(--spacing-xs);background:var(--color-error-500);color:#fff;font-size:var(--font-size-xs);font-weight:600;border-radius:10px}.controlling-filters{padding:var(--spacing-md);margin-bottom:var(--spacing-md)}.filters-row{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);align-items:center}.filters-row+.filters-row{margin-top:var(--spacing-sm);padding-top:var(--spacing-sm);border-top:1px solid var(--border-primary)}.filter-search{display:flex;align-items:center;gap:var(--spacing-sm);flex:1;min-width:200px}.filter-search .input{flex:1;border:none;background:transparent}.filter-select{min-width:140px;max-width:180px}.sort-options{display:flex;align-items:center;gap:var(--spacing-sm);flex:1}.sort-options label{font-size:var(--font-size-sm);color:var(--text-secondary);white-space:nowrap}.controlling-stats{display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.stat-item{flex:1;display:flex;flex-direction:column;align-items:center;padding:var(--spacing-lg);background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--radius-lg)}.stat-value{font-size:var(--font-size-2xl);font-weight:700;color:var(--color-primary-600)}.stat-label{font-size:var(--font-size-sm);color:var(--text-tertiary);margin-top:var(--spacing-xs)}.pagination{display:flex;align-items:center;justify-content:center;gap:var(--spacing-md);margin-top:var(--spacing-lg);padding:var(--spacing-md)}.pagination-info{font-size:var(--font-size-sm);color:var(--text-secondary)}.controlling-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.controlling-card{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);overflow:hidden}.controlling-card-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md) var(--spacing-lg);cursor:pointer;transition:background var(--transition-fast)}.controlling-card-header:hover{background:var(--bg-hover)}.controlling-card-info{display:flex;align-items:center;gap:var(--spacing-xl);flex-wrap:wrap}.controlling-user{display:flex;align-items:center;gap:var(--spacing-sm)}.controlling-user strong{display:block}.controlling-meta{display:block;font-size:var(--font-size-sm);color:var(--text-tertiary)}.controlling-submitted{font-size:var(--font-size-sm);color:var(--text-tertiary)}.controlling-card-body{border-top:1px solid var(--border-primary);padding:var(--spacing-lg)}.controlling-entries{overflow-x:auto;margin-bottom:var(--spacing-md)}.controlling-entries .table{min-width:900px}.controlling-entries .table th,.controlling-entries .table td{padding:var(--spacing-sm);font-size:var(--font-size-sm)}.controlling-notes{padding:var(--spacing-md);background:var(--bg-secondary);border-radius:var(--radius-md);margin-bottom:var(--spacing-md);font-size:var(--font-size-sm)}.controlling-actions{display:flex;justify-content:flex-end;gap:var(--spacing-sm);padding-top:var(--spacing-md);border-top:1px solid var(--border-primary)}@media (max-width: 1024px){.filters-row{flex-direction:column;align-items:stretch}.filter-search{min-width:100%}.filter-select{max-width:100%}.sort-options,.controlling-stats{flex-wrap:wrap}.stat-item{flex:1 1 calc(50% - var(--spacing-sm));min-width:120px}}@media (max-width: 768px){.controlling-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch}.controlling-tab{padding:var(--spacing-sm) var(--spacing-md);white-space:nowrap}.controlling-card-info{flex-direction:column;align-items:flex-start;gap:var(--spacing-sm)}.controlling-actions{flex-direction:column}.controlling-actions .btn{width:100%}.stat-item{flex:1 1 100%}.pagination{flex-direction:column;gap:var(--spacing-sm)}}.edit-timesheet-modal{max-width:1100px;width:95%;max-height:90vh;display:flex;flex-direction:column}.edit-timesheet-modal .modal-body{flex:1;overflow:auto}.edit-timesheet-modal .table th,.edit-timesheet-modal .table td{padding:var(--spacing-xs) var(--spacing-sm);vertical-align:middle}.edit-timesheet-modal .table .input{padding:var(--spacing-xs) var(--spacing-sm);font-size:var(--font-size-sm)}@media (max-width: 1024px){.edit-timesheet-modal{width:100%;max-width:100%;height:100%;max-height:100%;border-radius:0}}.reports-page{padding:var(--spacing-lg);max-width:1400px;margin:0 auto}.page-header{margin-bottom:var(--spacing-lg)}.page-header h1{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--font-size-2xl);font-weight:700;color:var(--text-primary);margin:0}.page-subtitle{color:var(--text-secondary);margin-top:var(--spacing-xs);font-size:var(--font-size-sm)}.report-tabs{display:flex;gap:var(--spacing-xs);margin-bottom:var(--spacing-lg);border-bottom:1px solid var(--border-primary);padding-bottom:var(--spacing-xs)}.report-tab{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg);background:transparent;border:none;border-radius:var(--radius-md) var(--radius-md) 0 0;font-size:var(--font-size-sm);font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);position:relative}.report-tab:hover{color:var(--text-primary);background:var(--bg-hover)}.report-tab.active{color:var(--color-primary-600);background:var(--bg-primary)}.report-tab.active:after{content:"";position:absolute;bottom:-1px;left:0;right:0;height:2px;background:var(--color-primary-500)}.report-filters{padding:var(--spacing-lg);margin-bottom:var(--spacing-lg)}.filters-header{display:flex;align-items:center;gap:var(--spacing-sm);font-weight:600;color:var(--text-secondary);margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-sm);border-bottom:1px solid var(--border-primary)}.filters-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--spacing-md)}.filter-group{display:flex;flex-direction:column;gap:var(--spacing-xs)}.filter-group label{font-size:var(--font-size-sm);color:var(--text-secondary);font-weight:500}.filters-actions{display:flex;gap:var(--spacing-sm);margin-top:var(--spacing-lg);padding-top:var(--spacing-md);border-top:1px solid var(--border-primary);justify-content:flex-end}.summary-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.summary-card{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-lg);background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--radius-lg)}.summary-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;background:var(--bg-secondary);border-radius:var(--radius-md);color:var(--color-primary-500)}.summary-card.billable .summary-icon{background:var(--color-success-100);color:var(--color-success-600)}.summary-card.internal .summary-icon{background:var(--color-info-100);color:var(--color-info-600)}.summary-card.revenue .summary-icon{background:var(--color-warning-100);color:var(--color-warning-600)}.summary-content{flex:1;min-width:0}.summary-value{font-size:var(--font-size-xl);font-weight:700;color:var(--text-primary);white-space:nowrap}.summary-label{font-size:var(--font-size-sm);color:var(--text-tertiary);margin-top:var(--spacing-xs)}.charts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:var(--spacing-lg);margin-bottom:var(--spacing-lg)}.chart-card{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:var(--spacing-lg)}.chart-card.wide{grid-column:1 / -1}.chart-title{font-size:var(--font-size-base);font-weight:600;color:var(--text-primary);margin:0 0 var(--spacing-lg) 0;padding-bottom:var(--spacing-sm);border-bottom:1px solid var(--border-primary)}.bar-chart{display:flex;flex-direction:column;gap:var(--spacing-sm)}.bar-row{display:grid;grid-template-columns:minmax(120px,200px) 1fr auto;gap:var(--spacing-md);align-items:center}.bar-label{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--font-size-sm);color:var(--text-primary);min-width:0}.bar-color-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.bar-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.bar-container{height:24px;background:var(--bg-secondary);border-radius:var(--radius-sm);overflow:hidden}.bar-fill{height:100%;border-radius:var(--radius-sm);transition:width var(--transition-base)}.bar-value{font-size:var(--font-size-sm);font-weight:500;color:var(--text-primary);text-align:right;min-width:80px}.bar-percentage{color:var(--text-tertiary);font-weight:400;margin-left:var(--spacing-xs)}.weekly-chart{display:flex;gap:var(--spacing-xs);height:200px;align-items:flex-end;overflow-x:auto;padding-bottom:var(--spacing-md)}.weekly-bar{display:flex;flex-direction:column;align-items:center;flex:1;min-width:50px;max-width:80px}.weekly-bar-container{flex:1;width:100%;display:flex;align-items:flex-end;justify-content:center;position:relative}.weekly-bar-fill{width:70%;background:var(--color-primary-500);border-radius:var(--radius-sm) var(--radius-sm) 0 0;min-height:4px;display:flex;align-items:flex-start;justify-content:center;transition:height var(--transition-base)}.weekly-bar-value{font-size:var(--font-size-xs);color:#fff;font-weight:600;padding:var(--spacing-xs);white-space:nowrap}.weekly-bar-label{font-size:var(--font-size-xs);color:var(--text-tertiary);margin-top:var(--spacing-xs);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.daily-chart{display:flex;gap:var(--spacing-md);height:180px;align-items:flex-end;justify-content:space-around}.daily-bar{display:flex;flex-direction:column;align-items:center;flex:1}.daily-bar-container{flex:1;width:100%;display:flex;align-items:flex-end;justify-content:center;padding:0 var(--spacing-sm)}.daily-bar-fill{width:100%;max-width:40px;background:linear-gradient(180deg,var(--color-primary-400),var(--color-primary-600));border-radius:var(--radius-sm) var(--radius-sm) 0 0;min-height:4px;transition:height var(--transition-base)}.daily-bar-label{font-size:var(--font-size-sm);color:var(--text-secondary);font-weight:500;margin-top:var(--spacing-sm)}.daily-bar-value{font-size:var(--font-size-xs);color:var(--text-tertiary)}.user-table-wrapper{overflow-x:auto}.user-table{width:100%;border-collapse:collapse}.user-table th,.user-table td{padding:var(--spacing-sm) var(--spacing-md);text-align:left;border-bottom:1px solid var(--border-primary)}.user-table th{font-size:var(--font-size-xs);font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px}.user-table td{font-size:var(--font-size-sm);color:var(--text-primary)}.user-table tbody tr:hover{background:var(--bg-hover)}.user-table .text-right{text-align:right}.user-email{display:block;font-size:var(--font-size-xs);color:var(--text-tertiary)}.project-cell{display:flex;align-items:center;gap:var(--spacing-sm)}.project-color{width:12px;height:12px;border-radius:var(--radius-sm);flex-shrink:0}.project-color.large{width:24px;height:24px;border-radius:var(--radius-md)}.project-code{display:block;font-size:var(--font-size-xs);color:var(--text-tertiary)}.budget-card{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:var(--spacing-lg);margin-bottom:var(--spacing-lg)}.budget-header{margin-bottom:var(--spacing-lg)}.budget-project{display:flex;align-items:center;gap:var(--spacing-md)}.budget-project h3{margin:0;font-size:var(--font-size-lg);font-weight:600;color:var(--text-primary)}.budget-client{font-size:var(--font-size-sm);color:var(--text-tertiary)}.budget-progress{margin-bottom:var(--spacing-md)}.budget-progress-header{display:flex;justify-content:space-between;font-size:var(--font-size-sm);color:var(--text-secondary);margin-bottom:var(--spacing-sm)}.budget-progress-bar{height:12px;background:var(--bg-secondary);border-radius:var(--radius-full);overflow:hidden}.budget-progress-fill{height:100%;background:var(--color-primary-500);border-radius:var(--radius-full);transition:width var(--transition-base)}.budget-progress-fill.warning{background:var(--color-warning-500)}.budget-progress-fill.danger{background:var(--color-error-500)}.budget-progress-footer{display:flex;justify-content:space-between;font-size:var(--font-size-xs);color:var(--text-tertiary);margin-top:var(--spacing-sm)}.budget-revenue{display:flex;justify-content:space-between;padding-top:var(--spacing-md);border-top:1px solid var(--border-primary);font-size:var(--font-size-sm);color:var(--text-secondary)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-3xl);text-align:center;color:var(--text-tertiary)}.empty-state svg{opacity:.5;margin-bottom:var(--spacing-md)}.empty-state h3{margin:0 0 var(--spacing-sm) 0;color:var(--text-secondary);font-weight:600}.empty-state p{margin:0;max-width:300px}@media (max-width: 1024px){.charts-grid{grid-template-columns:1fr}.summary-cards{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.reports-page{padding:var(--spacing-md)}.report-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch}.report-tab{padding:var(--spacing-sm) var(--spacing-md);white-space:nowrap}.filters-grid{grid-template-columns:1fr}.filters-actions{flex-direction:column}.summary-cards{grid-template-columns:1fr}.bar-row{grid-template-columns:1fr;gap:var(--spacing-xs)}.bar-label{order:1}.bar-container{order:2;width:100%}.bar-value{order:3;text-align:left}.weekly-chart{height:150px}.weekly-bar{min-width:40px}.daily-chart{height:140px;gap:var(--spacing-sm)}.budget-revenue{flex-direction:column;gap:var(--spacing-sm)}}:root{--color-primary-50: #f0f9ff;--color-primary-100: #e0f2fe;--color-primary-200: #bae6fd;--color-primary-300: #7dd3fc;--color-primary-400: #38bdf8;--color-primary-500: #0ea5e9;--color-primary-600: #0284c7;--color-primary-700: #0369a1;--color-primary-800: #075985;--color-primary-900: #0c4a6e;--color-gray-50: #f9fafb;--color-gray-100: #f3f4f6;--color-gray-200: #e5e7eb;--color-gray-300: #d1d5db;--color-gray-400: #9ca3af;--color-gray-500: #6b7280;--color-gray-600: #4b5563;--color-gray-700: #374151;--color-gray-800: #1f2937;--color-gray-900: #111827;--color-gray-950: #030712;--color-success-50: #f0fdf4;--color-success-100: #dcfce7;--color-success-500: #22c55e;--color-success-600: #16a34a;--color-success-700: #15803d;--color-warning-50: #fffbeb;--color-warning-100: #fef3c7;--color-warning-500: #f59e0b;--color-warning-600: #d97706;--color-warning-700: #b45309;--color-error-50: #fef2f2;--color-error-100: #fee2e2;--color-error-500: #ef4444;--color-error-600: #dc2626;--color-error-700: #b91c1c;--color-info-50: #eff6ff;--color-info-100: #dbeafe;--color-info-500: #3b82f6;--color-info-600: #2563eb;--bg-primary: #ffffff;--bg-secondary: var(--color-gray-50);--bg-tertiary: var(--color-gray-100);--bg-hover: var(--color-gray-100);--bg-active: var(--color-gray-200);--bg-overlay: rgba(0, 0, 0, .5);--text-primary: var(--color-gray-900);--text-secondary: var(--color-gray-600);--text-tertiary: var(--color-gray-500);--text-disabled: var(--color-gray-400);--text-inverse: #ffffff;--border-primary: var(--color-gray-200);--border-secondary: var(--color-gray-300);--border-focus: var(--color-primary-500);--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -2px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -4px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 8px 10px -6px rgba(0, 0, 0, .1);--sidebar-bg: #ffffff;--sidebar-text: var(--color-gray-600);--sidebar-text-active: var(--color-gray-900);--sidebar-hover: var(--color-gray-100);--sidebar-active: var(--color-primary-500);--sidebar-border: var(--color-gray-200);--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--radius-sm: .25rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-full: 9999px;--font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--font-family-mono: "SF Mono", Monaco, "Cascadia Code", "Roboto Mono", monospace;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-md: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-size-4xl: 2.25rem;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--line-height-tight: 1.25;--line-height-normal: 1.5;--line-height-relaxed: 1.75;--transition-fast: .15s ease;--transition-normal: .2s ease;--transition-slow: .3s ease;--sidebar-width: 260px;--sidebar-collapsed-width: 70px;--header-height: 64px;--max-content-width: 1400px}[data-theme=dark]{--bg-primary: var(--color-gray-900);--bg-secondary: var(--color-gray-800);--bg-tertiary: var(--color-gray-700);--bg-hover: var(--color-gray-800);--bg-active: var(--color-gray-700);--bg-overlay: rgba(0, 0, 0, .7);--text-primary: var(--color-gray-50);--text-secondary: var(--color-gray-400);--text-tertiary: var(--color-gray-500);--text-disabled: var(--color-gray-600);--text-inverse: var(--color-gray-900);--border-primary: var(--color-gray-700);--border-secondary: var(--color-gray-600);--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .4), 0 2px 4px -2px rgba(0, 0, 0, .3);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .4), 0 4px 6px -4px rgba(0, 0, 0, .3);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .5), 0 8px 10px -6px rgba(0, 0, 0, .4);--sidebar-bg: #0f172a;--sidebar-text: #94a3b8;--sidebar-text-active: #ffffff;--sidebar-hover: #1e293b;--sidebar-border: #1e293b}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;overflow-x:hidden}body{font-family:var(--font-family);font-size:var(--font-size-md);font-weight:var(--font-weight-normal);line-height:var(--line-height-normal);color:var(--text-primary);background-color:var(--bg-secondary);min-height:100vh;overflow-x:hidden;position:relative;width:100%}#root{overflow-x:hidden;width:100%}a{color:var(--color-primary-500);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-primary-600)}img,svg{display:block;max-width:100%}ul,ol{list-style:none}button{font-family:inherit;font-size:inherit;cursor:pointer;border:none;background:none}button:disabled{cursor:not-allowed}input,textarea,select{font-family:inherit;font-size:inherit}table{border-collapse:collapse;width:100%}:focus-visible{outline:2px solid var(--color-primary-500);outline-offset:2px}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--color-gray-400);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-gray-500)}[data-theme=dark] ::-webkit-scrollbar-track{background:var(--color-gray-800)}[data-theme=dark] ::-webkit-scrollbar-thumb{background:var(--color-gray-600)}::selection{background-color:var(--color-primary-200);color:var(--color-primary-900)}[data-theme=dark] ::selection{background-color:var(--color-primary-800);color:var(--color-primary-100)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);line-height:1;border-radius:var(--radius-md);transition:all var(--transition-fast);white-space:nowrap}.btn:disabled{opacity:.5}.btn-primary{background-color:var(--color-primary-500);color:#fff}.btn-primary:hover:not(:disabled){background-color:var(--color-primary-600)}.btn-primary:active:not(:disabled){background-color:var(--color-primary-700)}.btn-secondary{background-color:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-primary)}.btn-secondary:hover:not(:disabled){background-color:var(--bg-hover);border-color:var(--border-secondary)}.btn-ghost{background-color:transparent;color:var(--text-secondary)}.btn-ghost:hover:not(:disabled){background-color:var(--bg-hover);color:var(--text-primary)}.btn-danger{background-color:var(--color-error-500);color:#fff}.btn-danger:hover:not(:disabled){background-color:var(--color-error-600)}.btn-warning{background-color:var(--color-warning-500);color:#fff}.btn-warning:hover:not(:disabled){background-color:var(--color-warning-600)}.btn-sm{padding:var(--spacing-xs) var(--spacing-sm);font-size:var(--font-size-xs)}.btn-lg{padding:var(--spacing-md) var(--spacing-lg);font-size:var(--font-size-md)}.btn-icon{padding:var(--spacing-sm);border-radius:var(--radius-md)}.input{width:100%;padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-sm);color:var(--text-primary);background-color:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--radius-md);transition:all var(--transition-fast)}.input:hover{border-color:var(--border-secondary)}.input:focus{outline:none;border-color:var(--color-primary-500);box-shadow:0 0 0 3px var(--color-primary-100)}[data-theme=dark] .input:focus{box-shadow:0 0 0 3px #0ea5e933}.input::placeholder{color:var(--text-tertiary)}.input:disabled{background-color:var(--bg-secondary);cursor:not-allowed}.input-error{border-color:var(--color-error-500)}.input-error:focus{box-shadow:0 0 0 3px var(--color-error-100)}.label{display:block;margin-bottom:var(--spacing-xs);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--text-primary)}.form-group{margin-bottom:var(--spacing-md)}.form-label{display:block;margin-bottom:var(--spacing-xs);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--text-primary)}.error-text{margin-top:var(--spacing-xs);font-size:var(--font-size-xs);color:var(--color-error-500)}.select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");background-position:right .5rem center;background-repeat:no-repeat;background-size:1.5em 1.5em;padding-right:2.5rem}.checkbox,.radio{width:1rem;height:1rem;accent-color:var(--color-primary-500);cursor:pointer}.card{background-color:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.card-header{padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--border-primary)}.card-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--text-primary)}.card-body{padding:var(--spacing-lg)}.card-footer{padding:var(--spacing-md) var(--spacing-lg);border-top:1px solid var(--border-primary);background-color:var(--bg-secondary);border-radius:0 0 var(--radius-lg) var(--radius-lg)}.badge{display:inline-flex;align-items:center;padding:.125rem .5rem;font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);border-radius:var(--radius-full)}.badge-primary{background-color:var(--color-primary-100);color:var(--color-primary-700)}.badge-success{background-color:var(--color-success-100);color:var(--color-success-700)}.badge-warning{background-color:var(--color-warning-100);color:var(--color-warning-700)}.badge-error{background-color:var(--color-error-100);color:var(--color-error-700)}.badge-gray{background-color:var(--color-gray-100);color:var(--color-gray-700)}.badge-info{background-color:var(--color-info-100);color:var(--color-info-700)}[data-theme=dark] .badge-primary{background-color:#0ea5e933;color:var(--color-primary-300)}[data-theme=dark] .badge-success{background-color:#22c55e33;color:var(--color-success-500)}[data-theme=dark] .badge-warning{background-color:#f59e0b33;color:var(--color-warning-500)}[data-theme=dark] .badge-error{background-color:#ef444433;color:var(--color-error-500)}[data-theme=dark] .badge-gray{background-color:var(--color-gray-700);color:var(--color-gray-300)}[data-theme=dark] .badge-info{background-color:#3b82f633;color:var(--color-info-400)}.table-container{overflow-x:auto;border:1px solid var(--border-primary);border-radius:var(--radius-lg)}.table{width:100%;border-collapse:collapse}.table th,.table td{padding:var(--spacing-sm) var(--spacing-md);text-align:left;border-bottom:1px solid var(--border-primary)}.table th{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;background-color:var(--bg-secondary)}.table td{font-size:var(--font-size-sm);color:var(--text-primary)}.table tbody tr{transition:background-color var(--transition-fast)}.table tbody tr:hover{background-color:var(--bg-hover)}.table tbody tr:last-child td{border-bottom:none}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background-color:var(--bg-overlay);display:flex;align-items:center;justify-content:center;padding:var(--spacing-md);z-index:50;animation:fadeIn var(--transition-fast)}.modal{background-color:var(--bg-primary);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:100%;max-width:500px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;animation:slideUp var(--transition-normal)}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--border-primary);flex-shrink:0}.modal-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold)}.modal-body{padding:var(--spacing-lg);flex:1;min-height:0;overflow-y:auto}.modal-footer{display:flex;justify-content:flex-end;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);border-top:1px solid var(--border-primary);background-color:var(--bg-secondary);flex-shrink:0}.modal>form{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}.spinner{width:1.5rem;height:1.5rem;border:2px solid var(--border-primary);border-top-color:var(--color-primary-500);border-radius:50%;animation:spin .8s linear infinite}.spinner-sm{width:1rem;height:1rem}.spinner-lg{width:2.5rem;height:2.5rem;border-width:3px}.alert{display:flex;align-items:flex-start;gap:var(--spacing-sm);padding:var(--spacing-md);border-radius:var(--radius-md);font-size:var(--font-size-sm)}.alert-success{background-color:var(--color-success-50);color:var(--color-success-700);border:1px solid var(--color-success-100)}.alert-warning{background-color:var(--color-warning-50);color:var(--color-warning-700);border:1px solid var(--color-warning-100)}.alert-error{background-color:var(--color-error-50);color:var(--color-error-700);border:1px solid var(--color-error-100)}.alert-info{background-color:var(--color-info-50);color:var(--color-info-600);border:1px solid var(--color-info-100)}[data-theme=dark] .alert-success{background-color:#22c55e1a;border-color:#22c55e33}[data-theme=dark] .alert-warning{background-color:#f59e0b1a;border-color:#f59e0b33}[data-theme=dark] .alert-error{background-color:#ef44441a;border-color:#ef444433}[data-theme=dark] .alert-info{background-color:#3b82f61a;border-color:#3b82f633}.avatar{display:flex;align-items:center;justify-content:center;width:2.5rem;height:2.5rem;border-radius:var(--radius-full);background-color:var(--color-primary-100);color:var(--color-primary-700);font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm)}.avatar-sm{width:2rem;height:2rem;font-size:var(--font-size-xs)}.avatar-lg{width:3rem;height:3rem;font-size:var(--font-size-md)}[data-theme=dark] .avatar{background-color:var(--color-primary-900);color:var(--color-primary-300)}.dropdown{position:relative}.dropdown-menu{position:absolute;top:100%;right:0;margin-top:var(--spacing-xs);min-width:200px;background-color:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:40;animation:slideDown var(--transition-fast)}.dropdown-item{display:flex;align-items:center;gap:var(--spacing-sm);width:100%;padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-sm);color:var(--text-primary);text-align:left;transition:background-color var(--transition-fast)}.dropdown-item:hover{background-color:var(--bg-hover)}.dropdown-item:first-child{border-radius:var(--radius-lg) var(--radius-lg) 0 0}.dropdown-item:last-child{border-radius:0 0 var(--radius-lg) var(--radius-lg)}.dropdown-divider{height:1px;margin:var(--spacing-xs) 0;background-color:var(--border-primary)}.skeleton{background:linear-gradient(90deg,var(--bg-tertiary) 25%,var(--bg-secondary) 50%,var(--bg-tertiary) 75%);background-size:200% 100%;animation:skeleton-loading 1.5s infinite;border-radius:var(--radius-sm)}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-text{height:1rem;margin-bottom:var(--spacing-sm)}.skeleton-text:last-child{width:80%}.skeleton-avatar{width:2.5rem;height:2.5rem;border-radius:var(--radius-full)}.skeleton-card{height:200px}.view-switcher{position:relative;width:220px}.view-switcher-btn{display:flex;align-items:center;gap:var(--spacing-sm);width:100%;padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--text-primary);cursor:pointer;transition:all var(--transition-fast)}.view-switcher-btn:hover{border-color:var(--color-primary-400);background:var(--bg-hover)}.view-switcher-label{flex:1;text-align:left}.view-switcher-chevron{color:var(--text-tertiary);transition:transform var(--transition-fast);flex-shrink:0}.view-switcher-chevron.open{transform:rotate(180deg)}.view-switcher-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;border-radius:var(--radius-full);background:var(--color-primary-500);color:#fff;font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);line-height:1}.view-switcher-menu{position:absolute;top:calc(100% + 4px);left:0;width:100%;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:50;animation:slideDown var(--transition-fast);overflow:hidden}.view-switcher-item{display:flex;align-items:center;gap:var(--spacing-sm);width:100%;padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-sm);color:var(--text-primary);text-align:left;cursor:pointer;transition:background var(--transition-fast);border-bottom:1px solid var(--border-primary)}.view-switcher-item:last-child{border-bottom:none}.view-switcher-item:hover{background:var(--bg-hover)}.view-switcher-item.active{background:var(--color-primary-50);color:var(--color-primary-700);font-weight:var(--font-weight-medium)}[data-theme=dark] .view-switcher-item.active{background:#0ea5e91a;color:var(--color-primary-400)}.row-actions{position:relative;display:flex;justify-content:center}.row-actions-trigger{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-md);cursor:pointer;background:none;border:none;padding:0;transition:background var(--transition-fast)}.row-actions-trigger:hover{background:var(--bg-hover)}.row-actions-trigger svg{display:block}.row-actions-menu{min-width:160px;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:9999;animation:slideDown var(--transition-fast);overflow:hidden}.row-actions-item{display:flex;align-items:center;gap:var(--spacing-sm);width:100%;padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-sm);color:var(--text-primary);text-align:left;cursor:pointer;transition:background var(--transition-fast);border-bottom:1px solid var(--border-primary)}.row-actions-item:last-child{border-bottom:none}.row-actions-item:hover{background:var(--bg-hover)}.row-actions-item.danger{color:var(--color-error-600)}.row-actions-item.danger:hover{background:var(--color-error-50)}[data-theme=dark] .row-actions-item.danger:hover{background:#ef44441a}.view-switcher-row{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-md)}.view-switcher-search{flex:1;display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--radius-md);transition:border-color var(--transition-fast)}.view-switcher-search:focus-within{border-color:var(--color-primary-500)}.view-switcher-search input{flex:1;border:none;background:transparent;font-size:var(--font-size-sm);color:var(--text-primary);outline:none;min-width:0}.view-switcher-search input::placeholder{color:var(--text-tertiary)}@media (max-width: 640px){.view-switcher-row{flex-direction:column;align-items:stretch}.view-switcher{width:100%}}.app-layout{display:flex;min-height:100vh;overflow-x:hidden;width:100%}.app-main{flex:1;margin-left:var(--sidebar-width);transition:margin-left var(--transition-normal);overflow-x:hidden;min-width:0}.app-layout.sidebar-collapsed .app-main{margin-left:var(--sidebar-collapsed-width)}.sidebar{position:fixed;top:0;left:0;bottom:0;width:var(--sidebar-width);height:100vh;height:100dvh;background-color:var(--sidebar-bg);color:var(--sidebar-text);display:flex;flex-direction:column;transition:width var(--transition-normal),transform var(--transition-normal);z-index:30;overflow:hidden;border-right:1px solid var(--border-primary)}[data-theme=dark] .sidebar{border-right-color:var(--sidebar-border)}.sidebar-collapsed .sidebar{width:var(--sidebar-collapsed-width)}.sidebar-header{display:flex;align-items:center;padding:0 var(--spacing-lg);height:var(--header-height);min-height:var(--header-height);border-bottom:1px solid var(--border-primary)}[data-theme=dark] .sidebar-header{border-bottom-color:var(--sidebar-border)}.sidebar-logo{display:flex;align-items:center;gap:var(--spacing-sm);overflow:hidden}.sidebar-logo-icon{width:36px;height:36px;background-color:var(--color-primary-500);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.sidebar-logo-initials{color:#fff;font-weight:700;font-size:14px}.sidebar-logo-image{height:36px;width:auto;object-fit:contain;flex-shrink:0}.sidebar-collapsed .sidebar-logo-image{height:32px}.sidebar-logo-text{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--text-primary);white-space:nowrap;transition:opacity var(--transition-normal)}[data-theme=dark] .sidebar-logo-text{color:#fff}.sidebar-collapsed .sidebar-logo-text{opacity:0;width:0}.sidebar-nav{flex:1;padding:var(--spacing-md) 0;overflow-y:auto}.sidebar-section{margin-bottom:var(--spacing-md)}.sidebar-section-title{padding:var(--spacing-sm) var(--spacing-md);margin:0 var(--spacing-sm);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:.05em;color:var(--text-tertiary);white-space:nowrap;overflow:hidden}[data-theme=dark] .sidebar-section-title{color:#64748b}.sidebar-collapsed .sidebar-section-title{opacity:0}.sidebar-link{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);margin:0 var(--spacing-sm);color:var(--text-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);transition:all var(--transition-fast);white-space:nowrap;overflow:hidden;border-radius:var(--radius-md)}.sidebar-link:hover{background-color:var(--bg-hover);color:var(--text-primary)}.sidebar-link.active{background-color:var(--color-primary-50);color:var(--color-primary-600)}[data-theme=dark] .sidebar-link{color:var(--sidebar-text)}[data-theme=dark] .sidebar-link:hover{background-color:var(--sidebar-hover);color:var(--sidebar-text-active)}[data-theme=dark] .sidebar-link.active{background-color:var(--sidebar-active);color:#fff}.sidebar-link-icon{width:20px;height:20px;flex-shrink:0}.sidebar-link-text{transition:opacity var(--transition-normal)}.sidebar-collapsed .sidebar-link-text{opacity:0;width:0}.sidebar-collapsed .sidebar-link{justify-content:center;padding:var(--spacing-sm);margin:0 var(--spacing-xs)}.sidebar-footer{padding:var(--spacing-md);border-top:1px solid var(--border-primary)}[data-theme=dark] .sidebar-footer{border-top-color:var(--sidebar-border)}.sidebar-toggle{display:flex;align-items:center;justify-content:center;width:100%;padding:var(--spacing-sm);color:var(--text-secondary);background-color:transparent;border-radius:var(--radius-md);transition:all var(--transition-fast)}.sidebar-toggle:hover{background-color:var(--bg-hover);color:var(--text-primary)}[data-theme=dark] .sidebar-toggle{color:var(--sidebar-text)}[data-theme=dark] .sidebar-toggle:hover{background-color:var(--sidebar-hover);color:var(--sidebar-text-active)}.header{position:sticky;top:0;height:var(--header-height);background-color:var(--bg-primary);border-bottom:1px solid var(--border-primary);display:flex;align-items:center;justify-content:space-between;padding:0 var(--spacing-lg);z-index:20;max-width:100%}.header-left{display:flex;align-items:center;gap:var(--spacing-md)}.header-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--text-primary)}.header-right{display:flex;align-items:center;gap:var(--spacing-md)}.header-search{position:relative;width:300px}.header-search-input{width:100%;padding:var(--spacing-sm) var(--spacing-md);padding-left:2.5rem;background-color:var(--bg-secondary);border:1px solid transparent;border-radius:var(--radius-full);font-size:var(--font-size-sm);color:var(--text-primary);transition:all var(--transition-fast)}.header-search-input:focus{background-color:var(--bg-primary);border-color:var(--border-primary);outline:none}.header-search-icon{position:absolute;left:var(--spacing-md);top:50%;transform:translateY(-50%);color:var(--text-tertiary)}.page-content{padding:var(--spacing-lg);max-width:var(--max-content-width);margin:0 auto}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-lg)}.page-title{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--text-primary);margin:0}.page-subtitle,.page-description{margin-top:var(--spacing-xs);font-size:var(--font-size-sm);color:var(--text-secondary)}.page-actions{display:flex;align-items:center;gap:var(--spacing-sm);flex:1;justify-content:flex-end;min-width:0}.page-actions .view-switcher-search{flex:1;max-width:320px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.stat-card{background-color:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:var(--spacing-lg);display:flex;align-items:flex-start;gap:var(--spacing-md)}.stat-icon{width:48px;height:48px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-icon-primary{background-color:var(--color-primary-100);color:var(--color-primary-600)}.stat-icon-success{background-color:var(--color-success-100);color:var(--color-success-600)}.stat-icon-warning{background-color:var(--color-warning-100);color:var(--color-warning-600)}.stat-icon-error{background-color:var(--color-error-100);color:var(--color-error-600)}[data-theme=dark] .stat-icon-primary{background-color:#0ea5e933}[data-theme=dark] .stat-icon-success{background-color:#22c55e33}[data-theme=dark] .stat-icon-warning{background-color:#f59e0b33}[data-theme=dark] .stat-icon-error{background-color:#ef444433}.stat-content{flex:1}.stat-value{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--text-primary)}.stat-label{font-size:var(--font-size-sm);color:var(--text-secondary)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-primary-600) 0%,var(--color-primary-800) 100%);padding:var(--spacing-md)}.login-card{width:100%;max-width:420px;background-color:var(--bg-primary);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);overflow:hidden}.login-header{padding:var(--spacing-xl) var(--spacing-xl) var(--spacing-lg);text-align:center}.login-logo{width:64px;height:64px;background-color:var(--color-primary-500);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;margin:0 auto var(--spacing-md)}.login-title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--text-primary);margin-bottom:var(--spacing-xs)}.login-subtitle{font-size:var(--font-size-sm);color:var(--text-secondary)}.login-form{padding:0 var(--spacing-xl) var(--spacing-xl)}.login-footer{padding:var(--spacing-md) var(--spacing-xl);background-color:var(--bg-secondary);text-align:center;font-size:var(--font-size-xs);color:var(--text-tertiary)}.page-container{padding:var(--spacing-lg);max-width:var(--max-content-width);margin:0 auto}@media (max-width: 1024px){.app-layout{overflow-x:hidden;width:100%;max-width:100vw}.sidebar{position:fixed;left:0;top:0;bottom:0;width:var(--sidebar-width);max-width:85vw;height:100vh;height:100dvh;transform:translate(-100%);box-shadow:none;z-index:30}.mobile-menu-open .sidebar{transform:translate(0);box-shadow:var(--shadow-xl)}.app-main{margin-left:0;width:100%;max-width:100vw;overflow-x:hidden}.mobile-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background-color:var(--bg-overlay);z-index:25}.header-search{display:none}}@media (max-width: 768px){.page-content{padding:var(--spacing-md)}.page-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-md)}.stats-grid{grid-template-columns:1fr}}@media (max-width: 480px){.login-card{border-radius:var(--radius-lg)}.login-header,.login-form{padding-left:var(--spacing-lg);padding-right:var(--spacing-lg)}}
