.home-container{max-width:1400px;margin:0 auto;padding:2rem;background:#ecf0f5}.welcome-section{background:linear-gradient(135deg,#3498db,#2980b9);color:#fff;padding:3rem;border-radius:4px;margin-bottom:2rem;box-shadow:0 2px 4px #0000001a}.welcome-header h1{margin:0 0 .5rem;font-size:2.5rem;font-weight:700}.welcome-subtitle{margin:0;font-size:1.2rem;opacity:.9}.clock-widget{margin-top:2rem;padding-top:2rem;border-top:1px solid rgba(255,255,255,.2)}.current-time{font-size:3.5rem;font-weight:700;font-variant-numeric:tabular-nums;margin-bottom:.5rem}.current-date{font-size:1.1rem;opacity:.9}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card{background:#fff;padding:2rem;border-radius:4px;box-shadow:0 1px 3px #0000001f;border-top:3px solid #3498db;display:flex;gap:1.5rem;align-items:flex-start;transition:all .3s ease}.stat-card:hover{box-shadow:0 2px 8px #00000026;transform:translateY(-2px)}.stat-icon{font-size:3rem;line-height:1}.stat-content{flex:1}.stat-content h3{margin:0 0 .5rem;font-size:.95rem;font-weight:600;color:#666;text-transform:uppercase;letter-spacing:.5px}.stat-value{margin:0 0 .5rem;font-size:2rem;font-weight:700;color:#333}.stat-label{font-size:.9rem;color:#999}.quick-actions{background:#fff;padding:2rem;border-radius:4px;box-shadow:0 1px 3px #0000001f;margin-bottom:2rem}.quick-actions h2{margin:0 0 1.5rem;font-size:1.5rem;color:#333}.action-buttons{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.action-btn{display:flex;align-items:center;gap:.75rem;padding:1.25rem 1.5rem;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;font-family:inherit}.action-btn.primary{background:#3498db;color:#fff}.action-btn.primary:hover{background:#2980b9;transform:translateY(-2px);box-shadow:0 4px 12px #3498db4d}.action-btn.secondary{background:#f5f5f5;color:#333}.action-btn.secondary:hover{background:#e8e8e8;transform:translateY(-2px)}.btn-icon{font-size:1.5rem;line-height:1}.btn-text{flex:1;text-align:left}.recent-activity{background:#fff;padding:2rem;border-radius:4px;box-shadow:0 1px 3px #0000001f}.recent-activity h2{margin:0 0 1.5rem;font-size:1.5rem;color:#333}.activity-list{min-height:200px}.empty-state{text-align:center;padding:3rem 1rem}.empty-icon{font-size:4rem;margin-bottom:1rem}.empty-state h3{margin:0 0 .5rem;font-size:1.25rem;color:#333}.empty-state p{margin:0;color:#999;font-size:1rem}@media(max-width:768px){.home-container{padding:1rem}.welcome-section{padding:2rem}.welcome-header h1{font-size:1.75rem}.current-time{font-size:2.5rem}.stats-grid,.action-buttons{grid-template-columns:1fr}}.pie-chart-legend-container{width:100%;margin-top:16px;padding:0 4px;display:flex;justify-content:center}.pie-chart-legend-scrollable{overflow-y:auto;overflow-x:hidden;padding-right:8px;max-height:200px;display:flex;flex-direction:column;align-items:center}.pie-chart-legend-scrollable::-webkit-scrollbar{width:6px}.pie-chart-legend-scrollable::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.pie-chart-legend-scrollable::-webkit-scrollbar-thumb{background:#888;border-radius:3px}.pie-chart-legend-scrollable::-webkit-scrollbar-thumb:hover{background:#555}.pie-chart-legend-item{display:flex;align-items:center;justify-content:center;gap:8px;padding:4px 0;font-size:13px;color:#666;transition:color .2s;width:100%}.pie-chart-legend-item:hover{color:#000}.pie-chart-legend-color{width:12px;height:12px;border-radius:50%;flex-shrink:0;border:1px solid rgba(0,0,0,.1)}.pie-chart-legend-label{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.timesheet-summary-table{width:100%;border-collapse:collapse;font-size:.9rem;background:#fff;border-radius:8px;border:none;overflow:hidden;box-shadow:0 2px 8px #0000001a;margin:8px 0;box-sizing:border-box;max-width:100%}.timesheet-summary-table thead{background:var(--color-primary)!important;color:#fff!important}.timesheet-summary-table th{padding:6px 8px;text-align:left;font-weight:600;border-bottom:1px solid rgba(255,255,255,.2);white-space:nowrap;color:#fff!important;background:var(--color-primary)!important;font-size:13px}.timesheet-summary-table .project-task-header{min-width:320px;position:sticky;left:0;background:var(--color-primary)!important;z-index:10;padding:6px 8px 6px 16px!important}.timesheet-summary-table .day-header{text-align:center;min-width:50px}.timesheet-summary-table .total-header{text-align:center;min-width:60px;font-weight:700}.header-two-line,.header-three-line{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;line-height:1.2}.header-line-1{font-weight:600;font-size:13px}.header-line-2{font-weight:400;font-size:11px;opacity:.95}.header-line-3{font-weight:400;font-size:10px;opacity:.9}.timesheet-summary-table .day-header .header-two-line{text-align:center}.timesheet-summary-table .project-task-header .header-two-line,.timesheet-summary-table .project-task-header .header-three-line{text-align:left;align-items:flex-start}.timesheet-summary-table tbody tr{border-bottom:1px solid var(--color-gray-200);transition:background .2s}.timesheet-summary-table tbody tr:hover{background-color:var(--color-gray-50)}.timesheet-summary-table tbody tr:nth-child(2n){background-color:var(--color-gray-50)}.timesheet-summary-table tbody tr:nth-child(2n):hover{background-color:var(--color-gray-100)}.timesheet-summary-table tbody tr:last-child td{border-bottom:1px solid var(--color-gray-200)}.timesheet-summary-table td{padding:4px 8px;border-bottom:1px solid #e5e7eb;vertical-align:middle}.timesheet-summary-table .project-task-cell{font-weight:500;position:sticky;left:0;background-color:#fff;z-index:5;border:none!important;border-bottom:none!important;border-right:none!important;border-left:none!important;border-top:none!important;padding:4px 8px 4px 16px!important}.timesheet-summary-table tbody tr:hover .project-task-cell{background-color:var(--color-gray-50)}.timesheet-summary-table tbody tr:nth-child(2n) .project-task-cell{background-color:var(--color-gray-50)}.timesheet-summary-table tbody tr:nth-child(2n):hover .project-task-cell{background-color:var(--color-gray-100)}.cell-three-line{display:flex;flex-direction:column;gap:2px;line-height:1.3}.cell-line-1{font-weight:700;font-size:13px;color:#3857be}.cell-line-2{font-weight:600;font-size:12px;color:#567af1}.cell-line-3{font-weight:400;font-size:11px;color:#9ca3af;font-style:italic}.timesheet-summary-table .hours-cell{text-align:center;color:#374151;min-width:50px}.timesheet-summary-table .row-total-cell{text-align:center;font-weight:600;background-color:#f3f4f6;color:#059669;min-width:60px}.timesheet-summary-table tfoot{background-color:#f3f4f6;border-top:2px solid #3498db}.timesheet-summary-table tfoot .total-row{border-top:2px solid #3498db}.timesheet-summary-table .total-label{font-weight:700;text-align:left;padding:12px 8px 12px 16px;background-color:#f3f4f6;position:sticky;left:0;z-index:5}.timesheet-summary-table .day-total-cell{text-align:center;font-weight:700;padding:12px 8px;background-color:#f3f4f6;color:#059669;min-width:50px}.timesheet-summary-table .grand-total-cell{text-align:center;font-weight:700;padding:12px 8px;background-color:#dbeafe;color:#1e40af;min-width:60px}.timesheet-summary-table .no-entries{text-align:center;padding:24px;color:#6b7280;font-style:italic}.timesheet-summary-no-data{padding:24px;text-align:center;color:#6b7280;font-style:italic}@media(max-width:768px){.timesheet-summary-table{font-size:.85rem}.timesheet-summary-table th,.timesheet-summary-table td{padding:8px 6px}.timesheet-summary-table .project-task-header,.timesheet-summary-table .project-task-cell{min-width:150px}.timesheet-summary-table .day-header,.timesheet-summary-table .hours-cell,.timesheet-summary-table .day-total-cell{min-width:80px}}.modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.timesheet-detail-modal{background:#fff;border-radius:12px;width:90%;max-width:1000px;max-height:75vh;display:flex;flex-direction:column;box-shadow:0 10px 40px #0003}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e5e7eb}.modal-header h2{margin:0;font-size:1.5rem;color:#111827}.close-btn{background:none;border:none;font-size:28px;color:#6b7280;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.close-btn:hover{background:#f3f4f6;color:#111827}.modal-content{flex:1;overflow-y:auto;overflow-x:hidden;padding:20px 24px;min-height:0;max-height:calc(75vh - 140px)}.modal-loading{padding:60px 24px;text-align:center}.modal-error{padding:24px;color:#dc2626;background:#fee;border-radius:6px;margin:24px}.detail-section{margin-top:16px;margin-bottom:4px}.detail-section:last-child{margin-bottom:0}.detail-section h3{margin:0 0 16px;font-size:1.125rem;color:#111827;font-weight:600}.detail-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:12px}.detail-row-full{grid-template-columns:1fr}.detail-item{display:flex;flex-direction:row;align-items:center;gap:8px}.detail-item label{font-size:.8125rem;color:#6b7280;font-weight:500;white-space:nowrap}.detail-item span{font-size:.875rem;color:#111827;font-weight:500}.entries-table-wrapper{overflow-x:auto;overflow-y:auto;max-height:450px;border:1px solid #e5e7eb;border-radius:8px}.entries-table{width:100%;border-collapse:collapse;font-size:.875rem}.entries-table thead{background:#f9fafb;border-bottom:2px solid #e5e7eb;position:sticky;top:0;z-index:10}.entries-table th{padding:12px;text-align:left;font-weight:600;color:#374151;font-size:.8125rem;text-transform:uppercase;letter-spacing:.5px}.entries-table td{padding:12px;border-bottom:1px solid #f3f4f6;color:#111827}.entries-table tbody tr:hover{background:#f9fafb}.entries-table tfoot{background:#f9fafb;font-weight:600}.entries-table tfoot td{border-top:2px solid #e5e7eb;border-bottom:none}.day-cell{display:flex;flex-direction:row;align-items:center;gap:6px;white-space:nowrap}.day-name{font-weight:600;color:#374151}.day-date{font-size:.75rem;color:#6b7280}.hours-cell{text-align:right;font-weight:500}.total-label{text-align:right}.total-hours{text-align:right;color:#3498db;font-size:1rem}.no-entries{padding:40px;text-align:center;color:#6b7280}.rejection-input-wrapper,.return-input-wrapper{flex:1;margin-right:12px}.rejection-reason-input,.return-reason-input{width:100%;padding:10px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:.875rem;font-family:inherit;transition:all .2s}.rejection-reason-input:focus,.return-reason-input:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 3px #3498db1a}.rejection-reason-input::placeholder,.return-reason-input::placeholder{color:#9ca3af}.modal-footer{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:16px 24px;border-top:1px solid #e5e7eb;background:#f9fafb;flex-wrap:nowrap}.modal-footer .footer-left,.modal-footer .footer-right{display:flex;align-items:center;gap:12px}.btn-primary,.btn-secondary,.btn-danger,.btn-warning{display:inline-flex!important;align-items:center!important;justify-content:center!important;padding:10px 20px!important;border:none;border-radius:6px;font-size:.875rem!important;font-weight:600;cursor:pointer;transition:background .2s,color .2s,box-shadow .2s;line-height:1.2!important;box-sizing:border-box!important;height:41px!important;min-height:41px!important;max-height:41px!important;margin:0!important;vertical-align:middle!important;white-space:nowrap!important;overflow:hidden;transform:none!important}.btn-primary{background:#3498db;color:#fff}.btn-primary:hover{background:#2980b9}.btn-secondary{background:#6b7280;color:#fff}.btn-secondary:hover{background:#4b5563}.btn-danger{background:#ef4444;color:#fff}.btn-danger:hover{background:#dc2626}.btn-warning{background:#f59e0b;color:#fff}.btn-warning:hover{background:#d97706}.unlocked-badge,.returned-badge{padding:8px 16px;background:#dbeafe;color:#1e40af;border-radius:6px;font-weight:600;font-size:.875rem}.go-to-timesheets-btn-modal{display:inline-flex!important;align-items:center!important;justify-content:center!important;gap:6px;padding:10px 20px!important;background:#3498db;color:#fff;border:none;border-radius:6px;font-size:.875rem!important;font-weight:600;cursor:pointer;transition:background .2s;line-height:1.2!important;box-sizing:border-box!important;height:41px!important;min-height:41px!important;max-height:41px!important;margin:0!important;vertical-align:middle!important;white-space:nowrap!important}.go-to-timesheets-btn-modal:hover{background:#2980b9}.go-to-timesheets-btn-modal .btn-icon{font-size:14px;line-height:1;display:inline-flex;align-items:center}.go-to-timesheets-btn-modal .btn-text{font-size:.875rem;line-height:1.2;display:inline-flex;align-items:center}@media(max-width:768px){.timesheet-detail-modal{width:95%;max-height:95vh}.detail-row{grid-template-columns:1fr}.modal-footer{flex-direction:column;gap:12px}.rejection-input-wrapper,.return-input-wrapper{width:100%;margin-right:0;margin-bottom:0}.modal-footer button{width:100%}}.breakdown-chart-container{background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 8px #0000001a;margin-bottom:24px;width:100%;max-width:100%;overflow-x:hidden;box-sizing:border-box;min-height:500px}.breakdown-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;flex-wrap:wrap;gap:16px}.breakdown-header h2{margin:0;font-size:24px;font-weight:600;color:#1f2937}.breakdown-controls{display:flex;gap:12px;align-items:center}.period-selector{display:flex;background:#f3f4f6;border-radius:8px;padding:4px;gap:4px}.period-selector button{padding:8px 16px;border:none;background:transparent;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;color:#6b7280;transition:all .2s}.period-selector button:hover{background:#e5e7eb;color:#374151}.period-selector button.active{background:#3498db;color:#fff}.period-combobox{padding:8px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;font-weight:500;color:#374151;background:#fff;cursor:pointer;transition:all .2s;min-width:100px}.period-combobox:hover:not(:disabled){border-color:#9ca3af;background:#f9fafb}.period-combobox:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 3px #3498db1a}.period-combobox:disabled{opacity:.6;cursor:not-allowed;background:#f3f4f6}.date-picker{padding:8px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;cursor:pointer;transition:border-color .2s}.date-picker:hover{border-color:#9ca3af}.date-picker:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 3px #3498db1a}.date-range-inputs{display:flex;align-items:center;gap:8px}.date-separator{color:#6b7280;font-size:14px;font-weight:500}.breakdown-content{display:flex;flex-direction:column;gap:24px}.charts-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;width:100%}.pie-charts-row{display:grid;grid-template-columns:1fr 1fr;gap:24px;width:100%;margin-bottom:24px}.bar-chart-row{width:100%}.breakdown-summary{text-align:center;padding:16px;background:#f9fafb;border-radius:8px}.total-hours{display:flex;flex-direction:column;gap:4px;margin-bottom:8px}.total-label{font-size:14px;color:#6b7280;font-weight:500}.total-value{font-size:32px;font-weight:700;color:#1f2937}.period-label{font-size:14px;color:#6b7280;font-style:italic}.chart-section{background:#f9fafb;border-radius:8px;padding:20px;overflow:hidden;display:flex;flex-direction:column;min-height:0}.chart-title{margin:0 0 16px;font-size:18px;font-weight:600;color:#1f2937;text-align:center}.chart-wrapper{width:100%;max-width:100%;height:400px;display:flex;justify-content:center;align-items:center;overflow:hidden;position:relative}.pie-chart-wrapper{height:280px;max-height:280px;min-height:280px;flex-shrink:0}.bar-chart-wrapper{height:400px;max-height:400px;width:100%;overflow-x:auto;overflow-y:hidden;position:relative}.bar-chart-container{height:100%;min-width:100%;max-width:1200px;position:relative}.chart-wrapper>div{width:100%!important;height:100%!important;max-width:100%;max-height:100%}.bar-chart-wrapper .bar-chart-container>div{width:100%!important;height:100%!important}.bar-chart-wrapper::-webkit-scrollbar{height:8px}.bar-chart-wrapper::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.bar-chart-wrapper::-webkit-scrollbar-thumb{background:#888;border-radius:4px}.bar-chart-wrapper::-webkit-scrollbar-thumb:hover{background:#555}.project-task-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.project-task-modal-container{background:#fff;border-radius:12px;padding:24px;max-width:700px;width:100%;max-height:90vh;overflow-y:auto;position:relative;box-shadow:0 10px 40px #0003}.project-task-modal-close{position:absolute;top:16px;right:16px;background:transparent;border:none;font-size:28px;color:#6b7280;cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .2s}.project-task-modal-close:hover{background:#f3f4f6;color:#1f2937}.project-task-modal-header{margin-bottom:24px;padding-bottom:16px;border-bottom:2px solid #e5e7eb}.project-task-modal-header h2{margin:0 0 8px;font-size:24px;font-weight:600;color:#1f2937}.project-task-modal-info{display:flex;align-items:center;gap:16px}.project-code{color:#6b7280;font-size:14px}.project-total-hours{font-size:16px;font-weight:600;color:#3498db}.project-task-modal-subtitle{margin:0 0 16px;font-size:18px;font-weight:600;color:#1f2937;text-align:center}.project-task-modal-content{display:flex;flex-direction:column;align-items:center}.project-task-chart-wrapper{width:100%;height:400px;max-height:400px;display:flex;justify-content:center;align-items:center;overflow:hidden;position:relative}.project-task-chart-wrapper>div{width:100%!important;height:100%!important;max-width:100%;max-height:100%}.project-task-modal-empty{text-align:center;padding:48px 24px;color:#6b7280}.breakdown-download-section{margin-top:16px;padding-top:0;display:flex;justify-content:flex-start;align-items:center;gap:12px}.download-csv-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;background:#3498db;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s,transform .1s}.download-csv-btn:hover:not(:disabled){background:#2980b9;transform:translateY(-1px)}.download-csv-btn:active:not(:disabled){transform:translateY(0)}.download-csv-btn:disabled{background:#9ca3af;cursor:not-allowed;opacity:.6}.download-icon{font-size:16px}.download-text{font-size:14px}.download-pdf-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;background:#3498db;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s,transform .1s}.download-pdf-btn:hover:not(:disabled){background:#2980b9;transform:translateY(-1px)}.download-pdf-btn:active:not(:disabled){transform:translateY(0)}.download-pdf-btn:disabled{background:#9ca3af;cursor:not-allowed;opacity:.6}.breakdown-table-section{margin-top:16px;padding-top:0}.table-toggle-btn{display:flex;align-items:center;gap:8px;padding:10px 16px;background:#f3f4f6;border:1px solid #d1d5db;border-radius:6px;font-size:14px;font-weight:500;color:#374151;cursor:pointer;transition:all .2s;width:100%;justify-content:flex-start}.table-toggle-btn:hover:not(:disabled){background:#e5e7eb;border-color:#9ca3af}.table-toggle-btn:disabled{background:#f9fafb;color:#9ca3af;cursor:not-allowed;opacity:.6}.table-toggle-icon{font-size:12px;transition:transform .2s}.table-toggle-text{font-size:14px}.table-container{overflow:hidden;transition:max-height .3s ease-out,opacity .3s ease-out}.table-container.collapsed{max-height:0;opacity:0;margin-top:0}.table-container.expanded{max-height:5000px;opacity:1;margin-top:16px}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.table-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px;gap:16px;min-height:200px}.table-loading .loading-spinner{width:32px;height:32px;border:3px solid #f3f4f6;border-top:3px solid #3498db;border-radius:50%;animation:spin 1s linear infinite}.table-pagination{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:16px;padding:12px;background:#f9fafb;border-radius:6px}.pagination-btn{padding:8px 16px;background:#fff;border:1px solid #d1d5db;border-radius:6px;font-size:14px;font-weight:500;color:#374151;cursor:pointer;transition:all .2s}.pagination-btn:hover:not(:disabled){background:#f3f4f6;border-color:#9ca3af}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}.table-view-mode-selector{display:flex;gap:24px;margin-bottom:16px;padding:12px;background:#f9fafb;border-radius:6px;transition:all .2s ease-in-out}.radio-option{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:14px;font-weight:500;color:#374151;transition:color .2s ease-in-out}.radio-option:hover{color:#3498db}.radio-option input[type=radio]{width:18px;height:18px;cursor:pointer;accent-color:#3498db;transition:all .2s ease-in-out}.radio-option span{-webkit-user-select:none;user-select:none}.table-row-clickable{cursor:pointer;transition:background-color .2s}.table-row-clickable:hover{background-color:#f3f4f6}.status-badge{display:inline-block;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.status-approved{background-color:#d1fae5;color:#065f46}.status-pending{background-color:#fef3c7;color:#92400e}.status-rejected{background-color:#fee2e2;color:#991b1b}.status-unlocked{background-color:#dbeafe;color:#1e40af}.status-draft{background-color:#f3f4f6;color:#4b5563}.table-loading p{color:#6b7280;font-size:14px}.table-wrapper{overflow-x:hidden;border:1px solid #e5e7eb;border-radius:8px;background:#fff;transition:opacity .2s ease-in-out}.table-content-wrapper{transition:opacity .2s ease-in-out;min-height:200px}.timesheet-detail-table,.entries-table{width:100%;border-collapse:collapse;font-size:14px}.timesheet-detail-table{table-layout:fixed}.timesheet-detail-table thead,.entries-table thead{background:var(--color-primary)!important;color:#fff!important}.timesheet-detail-table th,.entries-table th{padding:12px!important;text-align:left;font-weight:600;font-size:13px;white-space:nowrap;color:#fff!important;background:var(--color-primary)!important;border:none!important}.timesheet-detail-table tbody tr,.entries-table tbody tr{border-bottom:1px solid var(--color-gray-200);transition:background .2s}.timesheet-detail-table tbody tr:hover,.entries-table tbody tr:hover{background:var(--color-gray-50)}.timesheet-detail-table tbody tr:nth-child(2n),.entries-table tbody tr:nth-child(2n):not(.add-entry-row){background:var(--color-gray-50)}.timesheet-detail-table tbody tr:nth-child(2n):hover,.entries-table tbody tr:nth-child(2n):not(.add-entry-row):hover{background:var(--color-gray-100)}.timesheet-detail-table td,.entries-table td,.entries-table .entry-row td,.entries-table .add-entry-row td{padding:10px 6px!important;color:var(--color-gray-700);font-size:14px;vertical-align:middle}.timesheet-detail-table th:nth-child(1),.timesheet-detail-table td:nth-child(1){width:10%}.timesheet-detail-table th:nth-child(2),.timesheet-detail-table td:nth-child(2){width:30%}.timesheet-detail-table th:nth-child(3),.timesheet-detail-table td:nth-child(3){width:30%}.timesheet-detail-table th:nth-child(4),.timesheet-detail-table td:nth-child(4){width:10%;text-align:left}.timesheet-detail-table th:nth-child(5),.timesheet-detail-table td:nth-child(5){width:20%}.hours-cell{text-align:left;font-weight:500;color:#1f2937}.timesheet-detail-table tfoot{background:#e8f4f8;border-top:2px solid #3498db}.table-total-row{font-weight:700}.total-label{text-align:right;padding-right:12px;color:#1f2937}.total-hours-cell{text-align:left;font-size:15px;color:#1f2937;padding-left:12px}.table-empty{padding:40px;text-align:center;color:#6b7280;font-size:14px;background:#f9fafb;border-radius:8px;border:1px solid #e5e7eb;min-height:100px}.table-container.expanded .table-content-wrapper,.table-container.expanded .table-wrapper,.table-container.expanded .table-empty,.table-container.expanded .table-view-mode-selector{animation:fadeInContent .2s ease-in-out}@keyframes fadeInContent{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.table-wrapper{font-size:12px}.timesheet-detail-table th,.timesheet-detail-table td{padding:8px}}@media(max-width:768px){.project-task-modal-container{max-width:95%;padding:16px;max-height:95vh}.project-task-chart-wrapper{height:300px;max-height:300px}}.breakdown-tooltip{background:#fff;border:1px solid #e5e7eb;border-radius:6px;padding:8px 12px;box-shadow:0 4px 6px #0000001a}.tooltip-label{margin:0 0 4px;font-weight:600;color:#1f2937;font-size:14px}.tooltip-value{margin:0;color:#6b7280;font-size:13px}.breakdown-legend{margin-top:24px}.breakdown-legend h3{margin:0 0 16px;font-size:18px;font-weight:600;color:#1f2937}.project-list{display:flex;flex-direction:column;gap:8px}.project-item{border:1px solid #e5e7eb;border-radius:8px;overflow:hidden;transition:box-shadow .2s}.project-item:hover{box-shadow:0 2px 4px #0000001a}.project-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;cursor:pointer;background:#f9fafb;transition:background .2s}.project-header:hover{background:#f3f4f6}.project-info{display:flex;align-items:center;gap:12px;flex:1}.project-color-dot{width:16px;height:16px;border-radius:50%;flex-shrink:0}.project-name{font-weight:600;color:#1f2937;font-size:15px}.project-code{color:#6b7280;font-size:13px}.project-stats{display:flex;align-items:center;gap:16px}.project-hours{font-weight:600;color:#1f2937;font-size:15px;min-width:60px;text-align:right}.project-percentage{color:#6b7280;font-size:14px;min-width:50px;text-align:right}.expand-icon{color:#9ca3af;font-size:12px;min-width:20px;text-align:center}.task-list{background:#fff;border-top:1px solid #e5e7eb;padding:8px 16px 12px 48px}.task-item{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid #f3f4f6}.task-item:last-child{border-bottom:none}.task-name{color:#4b5563;font-size:14px}.task-stats{display:flex;align-items:center;gap:16px}.task-hours{font-weight:500;color:#1f2937;font-size:14px;min-width:60px;text-align:right}.task-percentage{color:#6b7280;font-size:13px;min-width:50px;text-align:right}.empty-state{text-align:center;padding:48px 24px;color:#6b7280}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px;gap:16px}.loading-spinner{width:40px;height:40px;border:4px solid #f3f4f6;border-top-color:#3498db;border-radius:50%;animation:spin 1s linear infinite}.error-banner{background:#fee2e2;color:#dc2626;padding:12px 16px;border-radius:6px;border:1px solid #fca5a5;text-align:center}.nivo-tooltip{background:#fff;border:1px solid #e5e7eb;border-radius:6px;padding:8px 12px;box-shadow:0 4px 6px #0000001a;font-size:13px;color:#1f2937}.nivo-tooltip strong{color:#1f2937;font-weight:600}@media(max-width:1024px){.charts-grid,.pie-charts-row{grid-template-columns:1fr;gap:24px}}@media(max-width:768px){.breakdown-chart-container{padding:16px}.breakdown-header{flex-direction:column;align-items:flex-start}.breakdown-controls{width:100%;flex-wrap:wrap}.charts-grid{grid-template-columns:1fr;gap:16px}.chart-wrapper{height:300px!important;max-height:300px!important}.pie-chart-wrapper{height:250px!important;max-height:250px!important;min-height:250px!important}.bar-chart-wrapper{height:300px!important;max-height:300px!important}.bar-chart-container{max-width:800px}.chart-section{padding:12px}.project-header{flex-wrap:wrap;gap:8px}.project-stats{width:100%;justify-content:space-between}.task-list{padding-left:16px}}.dashboard-page{padding:60px 24px 24px;max-width:1400px;margin:0 auto}.dashboard-header{margin-bottom:16px;display:flex;justify-content:space-between;align-items:flex-start}.dashboard-header-left{flex:0 0 auto}.dashboard-header-left h1{margin:0;font-size:32px;color:#111827;font-weight:700}.dashboard-header-right{flex:0 0 auto;text-align:right;display:flex;flex-direction:column;align-items:flex-end;gap:8px}.company-name{font-size:24px;color:#3498db;font-weight:600;letter-spacing:.5px;margin:0}.dashboard-subtitle{margin:0;font-size:16px;color:#4b5563;font-weight:500}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px}.loading-spinner{border:3px solid #f3f4f6;border-top:3px solid #3498db;border-radius:50%;width:40px;height:40px;animation:spin 1s linear infinite;margin-bottom:16px}.error-banner{padding:16px;background:#fee;color:#c33;border-radius:8px;margin-bottom:20px}.metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px;margin-bottom:32px}.metric-card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 8px #0000001a;display:flex;gap:16px;transition:transform .2s,box-shadow .2s}.metric-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.metric-icon{width:56px;height:56px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.metric-content{flex:1}.metric-content h3{margin:0 0 12px;font-size:14px;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.5px}.metric-value{font-size:32px;font-weight:700;color:#111827;margin-bottom:8px}.metric-details{display:flex;align-items:center;gap:12px;font-size:14px;color:#6b7280;margin-bottom:8px}.metric-subtext{font-size:12px;color:#9ca3af;margin-top:8px}.status-badge{padding:4px 8px;border-radius:6px;font-size:11px;font-weight:600;text-transform:uppercase}.change-indicator{font-weight:600;font-size:12px}.change-indicator.positive{color:#10b981}.change-indicator.negative{color:#ef4444}.progress-bar{width:100%;height:8px;background:#e5e7eb;border-radius:4px;overflow:hidden;margin-top:12px}.progress-fill{height:100%;border-radius:4px;transition:width .3s ease}.status-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-top:12px}.status-item{text-align:center}.status-value{font-size:24px;font-weight:700;color:#111827;margin-bottom:4px}.status-label{font-size:12px;color:#6b7280;text-transform:uppercase;letter-spacing:.5px}.action-list{margin-top:12px;display:flex;flex-direction:column;gap:8px}.action-item{display:flex;justify-content:space-between;align-items:center;padding:8px;background:#f9fafb;border-radius:6px;font-size:12px}.action-week{color:#374151;font-weight:500}.action-status{color:#ef4444;font-weight:600;font-size:11px}.charts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:24px;margin-bottom:32px}.chart-card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 8px #0000001a}.chart-card h2{margin:0 0 20px;font-size:18px;font-weight:600;color:#111827}.chart-container{min-height:200px}.bar-chart{display:flex;align-items:flex-end;justify-content:space-between;height:200px;gap:8px}.bar-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px}.bar-wrapper{width:100%;height:160px;display:flex;align-items:flex-end;justify-content:center}.bar{width:100%;min-height:4px;border-radius:4px 4px 0 0;transition:all .3s ease;cursor:pointer}.bar:hover{opacity:.8}.bar-label{font-size:10px;color:#6b7280;text-align:center;writing-mode:horizontal-tb;transform:none}.project-list{display:flex;flex-direction:column;gap:12px}.project-item{padding:12px;background:#f9fafb;border-radius:8px}.project-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.project-name{font-weight:600;color:#111827;font-size:14px}.project-hours{font-size:12px;color:#6b7280;font-weight:500}.project-bar{width:100%;height:8px;background:#e5e7eb;border-radius:4px;overflow:hidden}.project-bar-fill{height:100%;border-radius:4px;transition:width .3s ease}.empty-chart{display:flex;align-items:center;justify-content:center;height:200px;color:#9ca3af;font-size:14px}.dashboard-actions{margin-bottom:20px}.go-to-timesheets-btn{display:flex;align-items:center;justify-content:center;gap:6px;padding:6px 16px;background:#3498db;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s;white-space:nowrap;min-width:190px;box-sizing:border-box}.go-to-timesheets-btn:hover{background:#2980b9}.go-to-timesheets-btn .btn-icon,.go-to-timesheets-btn .btn-text{font-size:14px}.empty-state{text-align:center;padding:60px 20px;color:#9ca3af}@media(max-width:768px){.metrics-grid,.charts-grid{grid-template-columns:1fr}.action-buttons{flex-direction:column}.action-btn{width:100%;justify-content:center}}.admin-dashboard-page{padding:60px 24px 24px;max-width:1400px;margin:0 auto}.dashboard-toggle-container{margin-bottom:24px;display:flex;justify-content:flex-start}.toggle-switch-wrapper{display:flex;background:#e5e7eb;border-radius:8px;padding:4px;gap:4px;box-shadow:0 1px 3px #0000001a;border:1px solid #d1d5db}.toggle-option{padding:6px 32px;border:none;background:transparent;color:#6b7280;font-size:14px;font-weight:500;cursor:pointer;border-radius:6px;transition:all .2s ease;white-space:nowrap;font-family:inherit}.toggle-option:hover{color:#374151;background:#0000000d}.toggle-option.active{background:#3498db;color:#fff;font-weight:600;box-shadow:0 2px 4px #3498db4d}.dashboard-content{width:100%;position:relative;min-height:500px}.admin-dashboard-page .home-container{padding:0;background:transparent}.admin-dashboard-page .dashboard-page{padding:0}.user-detail-view{padding:20px}.reset-password-container{display:flex;flex-direction:column;align-items:flex-start;gap:.5rem}.btn-action{display:flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;border:none;border-radius:6px!important;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s;font-family:inherit;box-shadow:0 1px 3px #0000001f}.btn-reset-password{background:#e67e22;color:#fff}.btn-reset-password:hover:not(:disabled){background:#d35400;box-shadow:0 2px 6px #00000026;transform:translateY(-1px)}.btn-reset-password:disabled{background:#bdc3c7;cursor:not-allowed;opacity:.6;transform:none}.reset-password-label{font-size:.75rem;color:#6c757d;text-align:left;white-space:nowrap}.error-banner{background-color:#fee;color:#c33;padding:12px 16px;border-radius:6px;border-left:4px solid #c33}.success-banner{background-color:#d4edda;color:#155724;padding:12px 16px;border-radius:6px;border-left:4px solid #28a745}.role-badge{display:inline-block;padding:4px 10px;border-radius:4px;font-size:12px;font-weight:500;white-space:nowrap;text-transform:capitalize}.role-badge.administrator{background-color:#e3f2fd;color:#1976d2}.role-badge.employee{background-color:#f1f8e9;color:#558b2f}.role-badge.super_admin{background-color:#fce4ec;color:#c2185b}.status-badge{display:inline-block;padding:4px 10px;border-radius:4px;font-size:12px;font-weight:500;white-space:nowrap;text-transform:capitalize}.user-edit-input{padding:.375rem .75rem;border:1px solid #ddd;border-radius:4px;font-size:.95rem;font-family:inherit;width:150px;max-width:100%}.user-edit-input:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 2px #3498db33}.user-edit-input:disabled{background-color:#f5f5f5;cursor:not-allowed}@media(max-width:768px){.detail-footer-actions{justify-content:flex-start!important}.footer-actions-right{flex-direction:column;width:100%}.reset-password-container{width:100%;align-items:stretch}.reset-password-label{text-align:left}.btn-action{width:100%;justify-content:center}.small-panels-row{grid-template-columns:1fr}}.users-container{padding:60px 20px 20px}.add-user-btn{display:flex;align-items:center;gap:.5rem;padding:.875rem 1.5rem;background:#3498db;color:#fff;border:none;border-radius:4px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;font-family:inherit}.add-user-btn:hover{background:#2980b9;transform:translateY(-2px);box-shadow:0 4px 12px #3498db4d}.btn-icon{font-size:1.2rem;line-height:1}.users-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin-bottom:1.5rem}.stat-item{background:#fff;padding:.75rem 1rem;border-radius:4px;box-shadow:0 1px 3px #0000001f;border-top:3px solid #3498db;text-align:center}.stat-number{display:block;font-size:1.5rem;font-weight:700;color:#3498db;margin-bottom:.25rem}.stat-text{display:block;font-size:.75rem;color:#666;text-transform:uppercase;letter-spacing:.5px;font-weight:600}.users-table-container{background:#fff;border-radius:8px;border:1px solid #e5e7eb;overflow:hidden;box-shadow:0 2px 8px #0000001a}.users-table{width:100%;border-collapse:collapse;font-size:14px;min-width:600px}.users-table thead{background:#3498db!important;color:#fff!important}.users-table th{padding:12px!important;text-align:left;font-weight:600;font-size:13px;white-space:nowrap;color:#fff!important;background:#3498db!important}.users-table tbody tr{border-bottom:1px solid #e5e7eb;transition:background .2s}.users-table tbody tr:hover{background:#f9fafb}.users-table tbody tr:nth-child(2n){background:#f9fafb}.users-table tbody tr:nth-child(2n):hover{background:#f3f4f6}.users-table tbody tr:last-child td{border-bottom:1px solid #e5e7eb}.user-row-clickable{cursor:pointer}.user-row-clickable:hover{background-color:#f9fafb!important}.user-row-clickable:nth-child(2n):hover{background-color:#f3f4f6!important}.user-name-cell{font-weight:500}.users-table td{padding:10px 12px!important;color:#374151;font-size:14px;vertical-align:middle;border-bottom:1px solid #e5e7eb}.user-id{color:#999;font-weight:600;font-size:.9rem}.user-info{display:flex;align-items:center;gap:.75rem}.user-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#3498db,#2980b9);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.9rem}.user-name{font-weight:600;color:#374151}.user-email{color:#374151}.role-badge{display:inline-block;padding:.375rem .875rem;border-radius:20px;font-size:.85rem;font-weight:600;text-transform:capitalize}.role-badge.administrator{background:#fff3e0;color:#e65100}.role-badge.employee{background:#e3f2fd;color:#1565c0}.status-badge{display:inline-block;padding:.375rem .875rem;border-radius:20px;font-size:.85rem;font-weight:600;text-transform:capitalize}.status-badge.active{background:#d4edda;color:#155724}.status-badge.disabled{background:#f8d7da;color:#721c24}.user-disabled{opacity:.6;color:#999!important}.user-disabled td{color:#999!important}.user-date{color:#374151;font-size:14px}.users-table th:last-child{text-align:center}.loading-state,.error-state,.empty-state{background:#fff;border-radius:4px;box-shadow:0 1px 3px #0000001f;padding:4rem 2rem;text-align:center}.spinner{width:48px;height:48px;border:4px solid #f3f3f3;border-top:4px solid #3498db;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 1rem}.loading-state p{margin:0;color:#666;font-size:1.1rem}.error-icon,.empty-icon{font-size:4rem;margin-bottom:1rem}.error-state h3,.empty-state h3{margin:0 0 .5rem;font-size:1.5rem;color:#333}.error-state p,.empty-state p{margin:0 0 1.5rem;color:#666;font-size:1rem}.retry-btn{padding:.875rem 1.5rem;background:#3498db;color:#fff;border:none;border-radius:4px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease}.retry-btn:hover{background:#2980b9;transform:translateY(-2px)}.user-username-badge{display:inline-block;background-color:#ecf0f5;color:#3498db;padding:4px 10px;border-radius:12px;font-size:12px;font-weight:600}.user-mobile{color:#374151}.role-edit{display:flex;gap:.5rem;align-items:center}.role-edit select{padding:.375rem .75rem;border:1px solid #ddd;border-radius:4px;font-size:.85rem;cursor:pointer;background:#fff}.role-edit select:disabled{opacity:.6;cursor:not-allowed}.inline-edit-input{padding:.375rem .5rem;border:1px solid #ddd;border-radius:4px;font-size:.85rem;background:#fff;width:80px}.inline-edit-input:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 2px #3498db33}.inline-edit-input:disabled{opacity:.6;cursor:not-allowed}.save-btn,.cancel-btn{border:none;cursor:pointer;font-size:18px;padding:6px 8px;border-radius:4px;transition:all .2s;display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;flex-shrink:0}.table-actions .save-btn,.table-actions .cancel-btn{margin-left:.25rem}.save-btn{background:#27ae60;color:#fff}.save-btn:hover:not(:disabled){background:#229954}.cancel-btn{background:#e74c3c;color:#fff}.cancel-btn:hover:not(:disabled){background:#c0392b}.save-btn:disabled,.cancel-btn:disabled{opacity:.6;cursor:not-allowed}@media(max-width:768px){.users-container{padding:1rem}.users-header{flex-direction:column;align-items:stretch}.add-user-btn{width:100%;justify-content:center}.users-table-container{overflow-x:auto}.users-table{min-width:800px}}.project-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:projectModalFadeIn .2s}@keyframes projectModalFadeIn{0%{opacity:0}to{opacity:1}}.project-modal-container{background:#fff;border-radius:8px;box-shadow:0 4px 20px #00000026;max-width:550px;width:90%;min-width:0;max-height:90vh;overflow-y:auto;overflow-x:hidden;padding:1rem 1.5rem;box-sizing:border-box;position:relative;margin:0 auto;flex-shrink:0}.project-modal-container .project-form{width:100%;max-width:100%;box-sizing:border-box}.project-modal-container .modal-close{position:absolute;top:1rem;right:1rem;background:none;border:none;font-size:2rem;color:#999;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s;z-index:10}.project-modal-container .modal-close:hover{background:#f8f9fa;color:#333}.project-modal-container .modal-header{margin-bottom:.5rem;padding-bottom:.5rem;border-bottom:1px solid #eee}.project-modal-container .modal-header h2{margin:0;color:#2c3e50;font-size:1.5rem;font-weight:600}.project-modal-container .modal-subtitle{margin:0;color:#666;font-size:.875rem}.project-form{display:flex;flex-direction:column;gap:.35rem}.form-group-inline{display:grid;grid-template-columns:140px 1fr;gap:.35rem;align-items:center;margin-bottom:.35rem}.form-group-inline label{color:#555;font-weight:500;font-size:.875rem;text-align:right;padding-right:.5rem}.form-group-inline input,.form-group-inline textarea,.form-group-inline select{width:100%;padding:.5rem .75rem;border:1.5px solid #ddd;border-radius:6px;font-size:.95rem;box-sizing:border-box;transition:all .2s;font-family:inherit;background:#fff;height:36px}.form-group-inline select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23333' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;padding-right:2.5rem}.form-group-inline textarea{height:auto;min-height:60px;resize:vertical;padding:.5rem .75rem}.form-group-inline input:focus,.form-group-inline textarea:focus,.form-group-inline select:focus{outline:none;border-color:#4caf50;box-shadow:0 0 0 3px #4caf501a}.date-inputs-inline{display:flex;gap:.5rem;align-items:center}.date-inputs-inline input[type=date]{flex:0 0 calc(50% - .25rem);padding:.5rem .75rem;border:1.5px solid #ddd;border-radius:6px;font-size:.95rem;box-sizing:border-box;transition:all .2s;font-family:inherit;background:#fff;height:36px;min-width:0}.form-group-inline input::placeholder,.form-group-inline textarea::placeholder{color:#aaa}.form-group-inline .selected-users-container{grid-column:2}.input-with-icon{position:relative;width:100%}.input-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:#666;font-weight:600;font-size:.95rem;z-index:1}.input-with-icon input{padding-left:28px;width:100%}.selected-users-container{display:flex;flex-direction:column;gap:.5rem}.selected-users{display:flex;flex-wrap:wrap;gap:.5rem;padding:.5rem;background:#fff;border-radius:6px;border:1.5px solid #e8eaed;min-height:40px;align-items:center}.selected-users-text{padding:.5rem .75rem;margin:0 0 .5rem;color:#495057;font-size:.95rem;background:#f8f9fa;border:1.5px solid #dee2e6;border-radius:6px}.user-chip{display:flex;align-items:center;gap:.4rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:.3rem .6rem;border-radius:16px;font-size:.8rem;font-weight:500}.user-chip-avatar{width:20px;height:20px;border-radius:50%;background:#ffffff4d;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.7rem}.user-chip-name{font-weight:500}.user-chip-role{font-size:.7rem;opacity:.9;background:#fff3;padding:.1rem .4rem;border-radius:8px}.user-chip-remove{background:#ffffff4d;border:none;color:#fff;width:20px;height:20px;border-radius:50%;cursor:pointer;font-size:1rem;line-height:1;display:flex;align-items:center;justify-content:center;transition:all .2s;padding:0;margin-left:.25rem}.user-chip-remove:hover{background:#ffffff80;transform:scale(1.1)}.user-select-container{position:relative}.user-select-dropdown{max-height:180px;overflow-y:auto;background:#fff;border:1.5px solid #e8eaed;border-radius:6px;padding:.25rem}.user-select-item{display:flex;align-items:center;gap:.5rem;padding:.4rem .5rem;border-radius:4px;cursor:pointer;transition:all .2s;margin-bottom:.15rem}.user-select-item:hover{background:#f5f7fa}.user-select-item.selected{background:#e3f2fd;border:1px solid #3498db}.user-select-checkbox{width:18px;height:18px;border:2px solid #ddd;border-radius:3px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .2s;background:#fff}.user-select-item.selected .user-select-checkbox{background:#3498db;border-color:#3498db}.checkmark{color:#fff;font-weight:700;font-size:.7rem;line-height:1}.user-select-info{flex:1;min-width:0}.user-select-name{font-weight:500;color:#2c3e50;font-size:.85rem;margin-bottom:.1rem;line-height:1.2}.user-select-name-inline{font-weight:500;color:#2c3e50;font-size:.85rem;line-height:1.2}.user-select-username{font-size:.75rem;color:#666;line-height:1.2}.no-users-message{color:#999;font-style:italic;margin:.5rem;text-align:center;padding:.75rem;font-size:.8rem}.loading-state{padding:2rem;text-align:center;color:#666;display:flex;flex-direction:column;align-items:center;gap:.75rem;font-size:.9rem}.loading-spinner-small{width:32px;height:32px;border:3px solid #f3f3f3;border-top:3px solid #3498db;border-radius:50%;animation:spin 1s linear infinite}.error-message{color:#d32f2f;margin-bottom:.75rem;padding:.5rem .75rem;background:#ffebee;border-radius:6px;font-size:.85rem;border-left:3px solid #d32f2f;grid-column:1 / -1}.project-modal-container .modal-actions{display:flex;gap:.75rem;justify-content:flex-end;align-items:center;padding-top:.5rem;border-top:1px solid #eee;margin-top:.5rem;margin-bottom:0}.project-modal-container .btn-secondary{padding:.5rem 1.25rem;background:#e9ecef;color:#495057;border:none;border-radius:8px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s;font-family:inherit;display:flex;align-items:center;justify-content:center;margin:0;box-sizing:border-box;min-height:36px;line-height:1.5}.project-modal-container .btn-secondary:hover:not(:disabled){background:#dee2e6}.project-modal-container .btn-secondary:disabled{opacity:.5;cursor:not-allowed}.project-modal-container .btn-primary{padding:.5rem 1.25rem;background:#3498db;color:#fff;border:none;border-radius:8px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s;font-family:inherit;display:flex;align-items:center;justify-content:center;gap:.5rem;margin:0;box-sizing:border-box;min-height:36px;line-height:1.5}.project-modal-container .btn-primary:hover{background:#2980b9}.project-modal-container .btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top:2px solid white;border-radius:50%;animation:spin .8s linear infinite}.user-select-dropdown::-webkit-scrollbar{width:8px}.user-select-dropdown::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.user-select-dropdown::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:4px}.user-select-dropdown::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.project-modal-container::-webkit-scrollbar{width:10px}.project-modal-container::-webkit-scrollbar-track{background:#f1f1f1}.project-modal-container::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:5px}.project-modal-container::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.form-group-inline.tasks-section{display:flex;flex-direction:column;gap:.5rem;align-items:stretch}.form-group-inline.tasks-section>*{width:100%}.section-header-with-action{display:flex;justify-content:space-between;align-items:center;width:100%;margin-bottom:.5rem;padding-bottom:.5rem;border-bottom:1px solid #e8eaed}.section-header-with-action label{text-align:left;margin:0;font-weight:500;font-size:.875rem;color:#555}.btn-add-task{padding:.4rem .8rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:6px;font-size:.8rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-add-task:hover{transform:translateY(-1px);box-shadow:0 2px 8px #667eea4d}.loading-tasks{padding:1rem;text-align:center;color:#666;display:flex;flex-direction:column;align-items:center;gap:.75rem;font-size:.85rem}.task-form-container{background:#fff;padding:.75rem;border-radius:6px;border:1.5px solid #e8eaed;margin-bottom:.75rem}.task-form-row{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin-bottom:.75rem}.task-form-group{display:flex;flex-direction:column;gap:.35rem}.task-form-group label{font-size:.8rem;font-weight:500;color:#555}.task-form-group input,.task-form-group select,.task-form-group textarea{padding:.5rem .75rem;border:1.5px solid #ddd;border-radius:6px;font-size:.85rem;font-family:inherit;transition:all .2s;height:36px}.task-form-group textarea{height:auto;min-height:50px}.task-form-group input:focus,.task-form-group select:focus,.task-form-group textarea:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 3px #3498db1a}.task-form-actions{display:flex;gap:.5rem;justify-content:flex-end;margin-top:.75rem}.btn-task-cancel{padding:.4rem 1rem;background:#fff;color:#666;border:1.5px solid #ddd;border-radius:6px;font-size:.8rem;font-weight:500;cursor:pointer;transition:all .2s;height:32px}.btn-task-cancel:hover{background:#f5f5f5;border-color:#bbb}.btn-task-save{padding:.4rem 1rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:6px;font-size:.8rem;font-weight:500;cursor:pointer;transition:all .2s;height:32px}.btn-task-save:hover{transform:translateY(-1px);box-shadow:0 2px 8px #667eea4d}.tasks-list{display:flex;flex-direction:column;gap:.5rem}.task-item{display:flex;justify-content:space-between;align-items:flex-start;background:#fff;padding:.75rem;border-radius:6px;border:1.5px solid #e8eaed;transition:all .2s}.task-item:hover{border-color:#3498db;box-shadow:0 2px 8px #3498db1a}.task-main-info{flex:1;min-width:0}.task-name-row{display:flex;align-items:center;gap:.5rem;margin-bottom:.35rem;flex-wrap:wrap}.task-name{font-weight:600;color:#2c3e50;font-size:.85rem}.task-badges{display:flex;gap:.5rem;flex-wrap:wrap}.task-status-badge,.task-priority-badge{padding:.2rem .6rem;border-radius:10px;font-size:.7rem;font-weight:500;color:#fff;text-transform:capitalize}.task-description{margin:.35rem 0;color:#666;font-size:.8rem;line-height:1.4}.task-meta{display:flex;gap:.75rem;margin-top:.35rem;flex-wrap:wrap}.task-meta-item{font-size:.75rem;color:#999}.task-actions{display:flex;gap:.5rem;margin-left:1rem}.btn-task-edit,.btn-task-delete{background:none;border:none;cursor:pointer;font-size:1rem;padding:.5rem;border-radius:4px;transition:all .2s}.btn-task-delete:hover{background:#fee}.no-tasks-message{text-align:center;color:#999;font-style:italic;padding:1rem;background:#fff;border-radius:6px;border:1.5px dashed #e8eaed;font-size:.85rem}@media(max-width:768px){.project-modal-container{padding:1.5rem;max-width:95%;width:95%}.form-row,.task-form-row{grid-template-columns:1fr}.project-modal-container .modal-actions{flex-direction:column}.project-modal-container .btn-secondary,.project-modal-container .btn-primary{width:100%}.section-header-with-action{flex-direction:column;align-items:flex-start;gap:.75rem}.task-item{flex-direction:column}.task-actions{margin-left:0;margin-top:.75rem;align-self:flex-end}}.delete-confirm-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:deleteModalFadeIn .2s}@keyframes deleteModalFadeIn{0%{opacity:0}to{opacity:1}}.delete-confirm-modal-container{background:#fff;border-radius:8px;box-shadow:0 4px 20px #00000026;padding:1.5rem;max-width:450px;width:90%;max-height:90vh;overflow-y:auto;position:relative;box-sizing:border-box}.delete-confirm-modal-close{position:absolute;top:1rem;right:1rem;background:none;border:none;font-size:2rem;cursor:pointer;color:#999;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s;z-index:10}.delete-confirm-modal-close:hover{background:#f8f9fa;color:#333}.delete-confirm-modal-container .delete-warning{display:flex;gap:16px;margin-bottom:0}.delete-warning-icon{font-size:48px;flex-shrink:0}.delete-warning-title{margin:0 0 12px;color:#2c3e50;font-size:1.5rem;font-weight:600}.delete-confirm-modal-container .delete-confirm-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:1rem;padding-top:1rem;border-top:1px solid #eee}.btn-secondary:hover{background:#e8e8e8;border-color:#bbb}.btn-secondary:disabled{opacity:.5;cursor:not-allowed}.member-management-modal{background:#fff;border-radius:8px;width:90%;max-width:600px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 4px 20px #00000026;margin:0 auto;overflow:hidden;align-items:stretch}.member-management-modal>*{width:100%;box-sizing:border-box;min-width:0}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e9ecef;width:100%;box-sizing:border-box;flex-shrink:0}.modal-header h2{margin:0;font-size:1.5rem;color:#2c3e50;font-weight:600}.modal-close{background:none;border:none;font-size:2rem;color:#999;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.modal-close:hover{background:#f8f9fa;color:#333}.modal-content{flex:1;overflow-y:auto;overflow-x:hidden;padding:0 1.5rem;display:flex;flex-direction:column;gap:1rem;width:100%;min-width:100%;max-width:100%;box-sizing:border-box;margin:0;align-self:stretch;flex-shrink:0;scrollbar-gutter:stable}.modal-content::-webkit-scrollbar{width:8px}.modal-content::-webkit-scrollbar-track{background:transparent}.modal-content::-webkit-scrollbar-thumb{background:#ccc;border-radius:4px}.modal-content::-webkit-scrollbar-thumb:hover{background:#999}.member-search-container{margin-bottom:.5rem;width:100%;box-sizing:border-box}.member-search-input{width:100%;padding:.75rem 1rem;border:1.5px solid #e0e0e0;border-radius:4px;font-size:.95rem;font-family:inherit;transition:border-color .2s;box-sizing:border-box}.member-search-input:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 3px #3498db1a}.member-actions-bar{display:flex;justify-content:space-between;align-items:center;padding:.75rem 0;border-bottom:1px solid #e9ecef;width:100%;box-sizing:border-box}.selection-info{font-size:.9rem;color:#666;font-weight:500}.selection-buttons{display:flex;align-items:center;gap:.5rem}.btn-link{background:none;border:none;color:#3498db;font-size:.9rem;cursor:pointer;padding:.25rem .5rem;border-radius:4px;transition:background .2s}.btn-link:hover:not(:disabled){background:#e3f2fd}.btn-link:disabled{color:#ccc;cursor:not-allowed}.separator{color:#ddd;margin:0 .25rem}.error-message{background:#fee;color:#c33;padding:.75rem 1rem;border-radius:4px;border-left:3px solid #c33;font-size:.9rem}.member-list-container{flex:1;overflow-y:auto;min-height:200px;max-height:450px;border:1px solid #e9ecef;border-radius:4px;background:#f8f9fa;width:100%;box-sizing:border-box}.member-list{display:flex;flex-direction:column}.member-item{padding:.2rem 1rem;border-bottom:1px solid #e9ecef;transition:background .2s;background:#fff;min-height:auto}.member-item-header{display:grid;grid-template-columns:1fr minmax(90px,auto) minmax(90px,auto);gap:1rem;align-items:center;padding:.5rem 1rem;background:#f8f9fa;border-bottom:2px solid #dee2e6;font-weight:600;font-size:.85rem;color:#495057}.member-item-row{display:grid;grid-template-columns:1fr minmax(90px,auto) minmax(90px,auto);gap:1rem;align-items:center}.member-item:last-child{border-bottom:none}.member-item:hover{background:#f8f9fa}.member-item.is-selected{background:#e3f2fd;border-left:3px solid #3498db}.member-item.is-manager{background:#fff9e6;border-left:3px solid #ffc107}.member-checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;padding:.25rem}.member-name-col{display:flex;flex-direction:column;gap:.1rem;min-width:200px}.member-checkbox-col{display:flex;align-items:center;justify-content:flex-start;min-width:90px}.header-label-text{font-size:.85rem;color:#495057;font-weight:600;-webkit-user-select:none;user-select:none}.member-checkbox{width:18px;height:18px;cursor:pointer;flex-shrink:0}.member-checkbox:disabled{cursor:not-allowed;opacity:.5}.member-radio{width:18px;height:18px;cursor:pointer;flex-shrink:0}.member-avatar-small{display:none}.member-details{flex:1;min-width:200px;display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.member-name-row{display:flex;align-items:center;gap:.5rem;margin:0}.member-name{font-weight:500;color:#2c3e50;font-size:.9rem}.member-badge{display:inline-block;padding:2px 8px;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.manager-badge{background:#ffc107;color:#856404}.member-badge-active{background:#28a745;color:#fff}.member-meta{font-size:.85rem;color:#666;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.no-users-message{padding:2rem;text-align:center;color:#999;font-style:italic}.modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1.5rem;border-top:1px solid #e9ecef;background:#f8f9fa;width:100%;box-sizing:border-box;flex-shrink:0}.modal-footer .btn-primary,.modal-footer .btn-secondary{padding:.625rem 1.25rem;border:none;border-radius:4px;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s;margin:0;display:flex;align-items:center;justify-content:center;box-sizing:border-box;min-height:44px;line-height:1.5}.modal-footer .btn-primary{background:#3498db;color:#fff}.modal-footer .btn-primary:hover:not(:disabled){background:#2980b9}.modal-footer .btn-primary:disabled{background:#ccc;cursor:not-allowed}.modal-footer .btn-secondary{background:#fff;color:#495057;border:1px solid #dee2e6}.modal-footer .btn-secondary:hover:not(:disabled){background:#f8f9fa;border-color:#adb5bd}.modal-footer .btn-secondary:disabled{opacity:.6;cursor:not-allowed}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@media(max-width:768px){.member-management-modal{width:95%;max-height:95vh}.member-actions-bar{flex-direction:column;align-items:flex-start;gap:.5rem}.member-meta{white-space:normal}}.detail-footer-actions{display:flex;justify-content:flex-start!important;margin-top:.5rem!important;padding-top:.5rem!important;border-top:1px solid #eee}.footer-actions-right{display:flex;gap:.75rem;align-items:flex-start}.btn-delete:hover{background:#c0392b}.small-panels-row{display:grid;grid-template-columns:300px 260px 1fr;gap:1.25rem;width:100%;align-items:start}.detail-section.information-panel,.detail-section.member-panel{background:#fff;padding:1.5rem;border-radius:0;box-shadow:0 1px 3px #0000001f;border-top:3px solid #3498db}.detail-section.project-task-panel{background:#fff;padding:1.5rem;border-radius:0;box-shadow:0 1px 3px #0000001f;border-top:3px solid #3498db;min-width:0;width:100%}.detail-section{padding-bottom:0;border-bottom:none}.detail-section:last-child{border-bottom:none}.section-title{margin:0 0 1.25rem;padding-bottom:.75rem;border-bottom:1px solid #e0e0e0;color:#2c3e50;font-size:1.25rem;font-weight:600}.project-edit-input{padding:.375rem .75rem;border:1px solid #ddd;border-radius:4px;font-size:.95rem;font-family:inherit;width:150px;max-width:100%}.project-edit-input:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 2px #3498db33}.project-edit-input:disabled{background-color:#f5f5f5;cursor:not-allowed}.message-banner{padding:.75rem 1rem;border-radius:4px;margin-bottom:1rem;font-size:.9rem}.message-banner.error{background-color:#fee;color:#c33;border:1px solid #fcc}.message-banner.success{background-color:#efe;color:#3c3;border:1px solid #cfc}.btn-cancel{background:#95a5a6;color:#fff}.btn-cancel:hover:not(:disabled){background:#7f8c8d;box-shadow:0 2px 6px #00000026;transform:translateY(-1px)}.btn-cancel:disabled{opacity:.6;cursor:not-allowed}.managers-inline{color:#2c3e50}.text-muted{color:#999;font-style:italic}.team-list{display:flex;flex-direction:column;gap:.75rem}.team-section-label{font-size:.875rem;font-weight:600;color:#666;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.5rem;padding-bottom:.5rem;border-bottom:1px solid #e0e0e0}.team-section-label:not(:first-child){margin-top:1.5rem}.team-list:first-child .team-section-label{margin-top:0}.team-member{display:flex;align-items:center;gap:.5rem;padding:.4rem .75rem;background:#f8f9fa;border-radius:0;transition:background .2s;border-left:2px solid #3498db;position:relative;min-height:auto}.team-member:hover{background:#e9ecef}.team-member .btn-delete{position:absolute;right:.5rem;top:50%;transform:translateY(-50%);opacity:.7}.team-member:hover .btn-delete{opacity:1}.member-avatar{display:none}.member-info{flex:1;display:flex;align-items:center;gap:.5rem}.member-number{font-weight:600;color:#666;font-size:.85rem;min-width:1.5rem}.member-name{font-weight:500;color:#2c3e50;font-size:.9rem;margin:0}.member-username{font-size:.85rem;color:#666;margin:0}.project-tasks-table-container{width:100%;overflow-x:auto;margin-bottom:1rem}.project-tasks-table{width:100%;border-collapse:collapse;background:#fff}.project-tasks-table thead{background:#f8f9fa}.project-tasks-table th{padding:.25rem 1rem;text-align:left;font-weight:600;font-size:.875rem;color:#495057;border-bottom:2px solid #dee2e6}.project-tasks-table th:last-child{text-align:center}.project-tasks-table td{padding:.25rem 1rem;border-bottom:1px solid #e9ecef;font-size:.95rem}.project-tasks-table tbody tr:hover{background:#f8f9fa}.project-tasks-table .task-name-cell{font-weight:400;color:#2c3e50}.project-tasks-table .actions-cell{text-align:right;width:80px}.project-tasks-table .btn-icon{background:none;border:none;cursor:pointer;padding:.25rem .5rem;display:inline-flex;align-items:center;justify-content:center;transition:all .2s}.project-tasks-table .btn-delete{color:#e74c3c}.project-tasks-table .btn-delete:hover{background:#ffebee;color:#c0392b}.project-tasks-table .delete-icon{color:#e74c3c;font-size:1.2rem;font-weight:700}.loading-tasks{display:flex;align-items:center;gap:.75rem;padding:1rem;color:#666}.project-code-badge{display:inline-block;background-color:#ecf0f5;color:#3498db;padding:4px 10px;border-radius:0;font-size:12px;font-weight:600}.status-badge{display:inline-block;padding:4px 10px;border-radius:0;font-size:12px;font-weight:500;white-space:nowrap}.status-badge.disabled{background-color:#f8d7da;color:#721c24}.chargeable-badge{display:inline-block;padding:4px 10px;border-radius:0;font-size:12px;font-weight:500;white-space:nowrap}.section-header-with-action{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem}.btn-add-task{padding:.5rem 1rem;background:#3498db;color:#fff;border:none;border-radius:8px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s;width:250px;min-width:200px;max-width:100%;box-sizing:border-box;margin-top:0}.btn-add-task:hover{background:#2980b9}.add-task-button-container{margin-top:0;padding-top:0;border-top:1px solid #e9ecef;display:flex;justify-content:flex-end}.add-task-form{margin:0!important;padding-top:1rem;border-top:1px solid #e9ecef}.add-task-form-row,.import-tasks-row{display:flex;gap:.75rem;align-items:center;width:100%}.import-tasks-row{margin-top:.75rem}.add-task-form-row .task-combobox-container,.import-tasks-row .task-combobox-container{flex:1;min-width:0}.add-task-form-row .btn-primary,.import-tasks-row .btn-primary{flex-shrink:0;padding:.625rem 1rem;border:none;border-radius:6px;background:#3498db;color:#fff;font-size:.9rem;font-weight:500;cursor:pointer;transition:background-color .2s;white-space:nowrap;min-width:80px;width:80px;text-align:center}.add-task-form-row .btn-primary:hover,.import-tasks-row .btn-primary:hover:not(:disabled){background:#2980b9}.import-tasks-row .btn-primary:disabled{opacity:.6;cursor:not-allowed}.add-task-form,.edit-task-form{background:#f8f9fa;padding:1rem 1.25rem;border-radius:0;margin-bottom:1.5rem;margin-top:0!important;border-left:3px solid #3498db;width:100%;box-sizing:border-box;margin-left:0;margin-right:0;max-width:100%}.add-task-grid{display:grid;grid-template-columns:120px 1fr;grid-template-rows:auto auto;gap:.75rem;align-items:center;margin:0}.add-task-label{grid-column:1;grid-row:1;font-weight:500;color:#495057;font-size:.9rem;margin:0}.add-task-grid .task-combobox-container{grid-column:2;grid-row:1;width:100%;min-width:0;max-width:100%;flex:none}.add-task-grid .btn-secondary{grid-column:1;grid-row:2;justify-self:start}.add-task-grid .btn-primary{grid-column:2;grid-row:2;justify-self:end;background:#3498db;color:#fff;border:none;border-radius:8px;padding:.75rem 1.5rem;font-size:1rem;font-weight:500;margin:0!important}.add-task-grid .btn-primary:hover{background:#2980b9}.add-task-grid .btn-secondary{grid-column:1;grid-row:2;justify-self:start;background:#e9ecef;color:#495057;border:none;border-radius:8px;padding:.75rem 1.5rem;font-size:1rem;font-weight:500;margin:0!important}.add-task-grid .btn-secondary:hover{background:#dee2e6}.form-row{margin-bottom:1rem;display:flex;align-items:center;gap:.5rem;width:100%;margin-left:0;margin-right:0;max-width:100%;box-sizing:border-box;justify-content:flex-end}.form-row .task-combobox-container{width:250px;min-width:200px;max-width:100%;flex:0 0 auto}.form-row label{display:inline-block;margin:0;font-weight:500;color:#495057;font-size:.9rem;flex-shrink:0;white-space:nowrap;width:60px;min-width:60px;max-width:60px}.form-row-inline{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin-bottom:1rem}.form-field{display:flex;flex-direction:column;gap:.5rem}.form-field label{font-weight:500;color:#495057;font-size:.9rem}.task-select,.task-input{width:100%;padding:.625rem;border:1.5px solid #e0e0e0;border-radius:0;font-size:.95rem;font-family:inherit;transition:border-color .2s}.task-select:focus,.task-input:focus{outline:none;border-color:#3498db}.task-select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23333' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;background-size:12px;padding-right:2.5rem;appearance:none;-webkit-appearance:none;-moz-appearance:none}.task-combobox-container{position:relative;flex:1 1 auto;min-width:350px;max-width:none;width:auto;flex-grow:1;flex-shrink:0;box-sizing:border-box}.task-combobox-input,.task-select-input{width:100%;padding:.5rem;border:1.5px solid #e0e0e0;border-radius:0;font-size:.875rem;font-family:inherit;transition:border-color .2s;box-sizing:border-box;line-height:1.4;background-color:#fff;cursor:pointer}.task-combobox-input:focus,.task-select-input:focus{outline:none;border-color:#3498db}.task-select-input option{padding:.25rem .5rem;font-size:.875rem;line-height:1.3}.form-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1rem}.form-actions .btn-primary,.form-actions .btn-secondary{padding:.625rem 1.25rem;border:none;border-radius:0;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s;margin:0;display:flex;align-items:center;justify-content:center;box-sizing:border-box;min-height:44px;line-height:1.5}.form-actions .btn-primary{background:#3498db;color:#fff}.form-actions .btn-primary:hover{background:#2980b9}.form-actions .btn-secondary{background:#e9ecef;color:#495057}.form-actions .btn-secondary:hover{background:#dee2e6}.task-item{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.task-actions{display:flex;gap:.5rem;flex-shrink:0}.btn-task-edit,.btn-task-remove{background:none;border:none;font-size:1.1rem;cursor:pointer;padding:.25rem .5rem;border-radius:0;transition:background .2s}.btn-task-edit:hover{background:#e3f2fd}.btn-task-remove:hover{background:#ffebee}.manage-members-button-container{margin-top:1rem;padding-top:1rem;border-top:1px solid #e9ecef;display:flex;justify-content:flex-end}.btn-manage-members{padding:.625rem 1.5rem;background:#3498db;color:#fff;border:none;border-radius:8px;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s;box-shadow:0 1px 3px #0000001f}.btn-manage-members:hover{background:#2980b9;box-shadow:0 2px 6px #00000026;transform:translateY(-1px)}@media(max-width:768px){.info-grid{grid-template-columns:1fr}.detail-footer-actions{flex-direction:column;width:100%}.btn-action{width:100%;justify-content:center}.section-header-with-action{flex-direction:column;align-items:flex-start;gap:1rem}.form-row-inline{grid-template-columns:1fr}.btn-add-task{width:100%;max-width:100%}.form-row .task-combobox-container{width:100%;max-width:100%;flex:1 1 auto}}.project-statistics-container{width:100%;background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 8px #0000001a}.project-statistics-chart-wrapper{height:600px;width:100%;min-height:400px;margin-bottom:24px}.project-statistics-tooltip{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:12px;box-shadow:0 4px 12px #00000026;min-width:200px}.tooltip-header{font-weight:600;font-size:14px;color:#2c3e50;margin-bottom:8px;border-bottom:1px solid #e5e7eb;padding-bottom:6px}.tooltip-content{display:flex;flex-direction:column;gap:4px}.tooltip-employee{font-size:13px;color:#374151;font-weight:500}.tooltip-hours{font-size:12px;color:#6b7280}.project-statistics-pagination{display:flex;justify-content:center;align-items:center;gap:16px;margin-top:24px;padding-top:20px;border-top:1px solid #e5e7eb}.pagination-btn{padding:8px 16px;background:#3498db;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.pagination-btn:hover:not(:disabled){background:#2980b9;transform:translateY(-1px);box-shadow:0 2px 8px #3498db4d}.pagination-btn:disabled{background:#ccc;cursor:not-allowed;transform:none;opacity:.6}.pagination-info{font-size:14px;color:#6b7280;font-weight:500}.project-statistics-container .empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center}.project-statistics-container .empty-icon{margin-bottom:20px}.project-statistics-container .empty-state h3{font-size:20px;color:#374151;margin-bottom:8px}.project-statistics-container .empty-state p{font-size:14px;color:#6b7280}@media(max-width:768px){.project-statistics-chart-wrapper{height:500px}.project-statistics-pagination{flex-direction:column;gap:12px}}.page-header-standard{margin-bottom:16px;display:flex;justify-content:space-between;align-items:flex-start;gap:16px;min-height:0;height:auto;max-height:none;flex-shrink:0}.page-header-container{flex:0 0 auto;display:flex;flex-direction:column;gap:6px;min-width:0;min-height:0;height:auto;max-height:none;width:100%}.page-header-row{display:flex;justify-content:space-between;align-items:flex-start!important;gap:16px;min-width:0;min-height:0!important;height:auto!important;max-height:none!important;flex-shrink:0;flex-grow:0}.page-header-title{margin:0;padding:0;font-size:32px;color:#111827;font-weight:700;display:flex;align-items:center;gap:.5rem;line-height:1.2;height:auto;min-height:0;max-height:none;flex:0 0 auto;flex-shrink:0}.page-subtitle{margin:0;padding:0;color:#666;font-size:14px;line-height:1.4;height:auto;min-height:0;max-height:none;flex:0 0 auto;flex-shrink:0;display:block}.page-subtitle-placeholder{margin:0;padding:0;height:0;min-height:0;max-height:0;flex:0 0 auto;flex-shrink:0;width:0}.header-with-back{display:flex;align-items:center;gap:1rem;flex:0 0 auto}.back-button{background:#f5f5f5;border:1px solid #ddd;color:#333;padding:.5rem 1rem;border-radius:6px;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s;margin:0;font-family:inherit;flex-shrink:0;height:auto}.company-name{font-size:20px;color:#3498db;font-weight:600;letter-spacing:.5px;margin:0;padding:0;line-height:1.1;height:auto;min-height:0;max-height:none;white-space:nowrap;flex:0 0 auto;flex-shrink:0;text-align:right;display:block}.page-header-standard .welcome-message,.page-header-row .welcome-message,.welcome-message{margin:0!important;padding:0!important;font-size:15px;color:#4b5563;font-weight:500;line-height:1.2;height:auto!important;min-height:0!important;max-height:none!important;white-space:nowrap;flex:0 0 auto;flex-shrink:0;text-align:right;display:block!important;justify-content:flex-start!important}.page-header-actions{display:flex;align-items:center;gap:12px;flex:0 0 auto;justify-content:flex-end;height:auto}@media(max-width:768px){.page-header-standard{flex-direction:column;align-items:stretch;gap:12px}.page-header-row{flex-direction:column;align-items:flex-start;gap:8px}.company-name,.welcome-message{text-align:left}.page-header-actions{width:100%;justify-content:flex-start}}.projects-page{padding:60px 20px 20px}.projects-tabs{display:flex;gap:8px;margin-top:20px;margin-bottom:20px;border-bottom:2px solid #e5e7eb;padding-bottom:0}.tab-button{padding:12px 24px;background:transparent;border:none;border-bottom:3px solid transparent;color:#6b7280;font-size:15px;font-weight:500;cursor:pointer;transition:all .2s;position:relative;bottom:-2px;margin-bottom:-2px}.tab-button:hover{color:#3498db;background:#f9fafb}.tab-button.active{color:#3498db;border-bottom-color:#3498db;background:transparent}.tab-button.active:hover{background:transparent}.projects-table-container{background-color:#fff;border-radius:12px;border:1px solid #e5e7eb;overflow:hidden;box-shadow:0 2px 8px #0000001a;overflow-x:auto}.projects-table{width:100%;border-collapse:collapse;min-width:1000px;font-size:14px}.projects-table thead{background:#3498db!important;color:#fff!important}.projects-table th{padding:12px!important;text-align:left;font-weight:600;font-size:13px;white-space:nowrap;color:#fff!important;background:#3498db!important}.projects-table th:last-child{text-align:center}.projects-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color .2s}.projects-table th.sortable:hover{background-color:#2980b9!important}.sort-indicator{color:#fff;font-weight:700;margin-left:4px}.projects-table td{padding:10px 12px!important;border-bottom:1px solid #e5e7eb;color:#374151;font-size:14px;vertical-align:middle}.projects-table tbody tr{border-bottom:1px solid #e5e7eb;transition:background .2s}.projects-table tbody tr:hover{background:#f9fafb}.projects-table tbody tr:nth-child(2n){background:#f9fafb}.projects-table tbody tr:nth-child(2n):hover{background:#f3f4f6}.projects-table tbody tr:last-child td{border-bottom:1px solid #e5e7eb}.project-row-clickable{cursor:pointer}.project-row-clickable:hover{background-color:#f9fafb!important}.project-row-clickable:nth-child(2n):hover{background-color:#f3f4f6!important}.project-disabled{opacity:.6;color:#999!important}.project-disabled td{color:#999!important}.project-name-cell{font-weight:500;color:#374151}.text-muted{color:#6b7280;font-style:italic}.team-cell{min-width:150px}.team-list{display:flex;flex-wrap:wrap;gap:6px}.team-member-badge{display:inline-block;background-color:#e3f2fd;color:#1976d2;padding:4px 8px;border-radius:4px;font-size:12px;white-space:nowrap}.status-badge{display:inline-block;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:500;white-space:nowrap;color:#fff}.status-badge.disabled,.status-badge.inactive{background-color:#6c757d;color:#fff}.actions-cell{position:relative;min-width:120px}.btn-view:hover{background:none;color:#2980b9}.delete-confirm-inline{margin-top:12px;padding:16px;background-color:#fff5f5;border:2px solid #e74c3c;border-radius:8px;font-size:13px}.delete-warning{display:flex;gap:12px;margin-bottom:16px}.delete-warning-icon{font-size:24px;flex-shrink:0}.delete-warning-title{margin:0 0 8px;color:#c0392b;font-size:14px;font-weight:600}.delete-warning-message{margin:0 0 12px;color:#666;font-size:13px;line-height:1.5}.delete-warning-instruction{margin:0 0 8px;color:#555;font-size:12px;font-weight:500}.delete-confirm-input{width:100%;padding:10px 12px;border:2px solid #e74c3c;border-radius:6px;font-size:13px;font-family:inherit;box-sizing:border-box;transition:all .2s}.delete-confirm-input::placeholder{color:#aaa}.delete-error-message{margin:8px 0 0;color:#c0392b;font-size:12px;font-weight:500}.delete-confirm-actions{display:flex;gap:8px;justify-content:flex-end}.btn-secondary-small{background-color:#6c757d;color:#fff;border:none;padding:4px 12px;border-radius:4px;cursor:pointer;font-size:12px;transition:background-color .2s}.btn-secondary-small:hover{background-color:#5a6268}.btn-danger-small{background-color:#e74c3c;color:#fff;border:none;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:13px;font-weight:500;transition:all .2s}.btn-danger-small:hover:not(:disabled){background-color:#c0392b;transform:translateY(-1px);box-shadow:0 2px 8px #e74c3c4d}.btn-danger-small:disabled{background-color:#ccc;cursor:not-allowed;opacity:.6;transform:none}.btn-danger{background-color:#e74c3c;color:#fff;border:none;padding:8px 16px;border-radius:4px;cursor:pointer;font-size:14px;transition:background-color .2s}.btn-danger:hover{background-color:#c0392b}@media(max-width:768px){.projects-table-container{overflow-x:scroll}.page-header{flex-direction:column;align-items:flex-start;gap:15px}}.companies-page{padding:20px}.companies-table-container{background-color:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;overflow-x:auto}.companies-table{width:100%;border-collapse:collapse;min-width:1000px}.companies-table thead{background-color:#f8f9fa;border-bottom:2px solid #dee2e6}.companies-table th{padding:12px 16px;text-align:left;font-weight:600;color:#2c3e50;font-size:14px}.companies-table td{padding:12px 16px;border-bottom:1px solid #ecf0f5;color:#2c3e50;font-size:14px}.companies-table tbody tr:hover{background-color:#f8f9fa}.company-code-badge{display:inline-block;background-color:#ecf0f5;color:#3498db;padding:4px 10px;border-radius:12px;font-size:12px;font-weight:600}.plan-badge{display:inline-block;background-color:#e3f2fd;color:#1976d2;padding:4px 10px;border-radius:12px;font-size:12px;font-weight:500;text-transform:capitalize}.status-badge{display:inline-block;padding:4px 10px;border-radius:12px;font-size:12px;font-weight:500}.status-badge.active{background-color:#d4edda;color:#155724}.status-badge.inactive{background-color:#f8d7da;color:#721c24}.admin-badge{display:inline-block;background-color:#fff3cd;color:#856404;padding:4px 10px;border-radius:12px;font-size:12px;font-weight:500}.text-muted{color:#6c757d;font-style:italic}.loading-small{padding:8px;text-align:center;color:#6c757d;font-size:12px}.company-modal{max-width:600px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.company-modal .form-group{margin-bottom:.75rem}.company-modal .form-group label{display:block;margin-bottom:.35rem;color:#555;font-weight:500;font-size:.875rem}.company-modal .form-group input,.company-modal .form-group select{width:100%;padding:.5rem .75rem;border:1.5px solid #ddd;border-radius:6px;font-size:.95rem;box-sizing:border-box;transition:all .2s;font-family:inherit;height:36px;background-color:#fff;color:#333}.company-modal .form-group select{appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23333' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;background-size:12px;padding-right:2.5rem}.company-modal .form-group input:focus,.company-modal .form-group select:focus{outline:none;border-color:#4caf50;box-shadow:0 0 0 3px #4caf501a}.company-modal .form-group input::placeholder{color:#aaa}.company-modal .form-hint{display:block;margin-top:.2rem;font-size:.75rem;color:#999;font-style:italic;line-height:1.2}.delete-confirm-modal{max-width:500px}.delete-warning{display:flex;gap:12px;margin-bottom:20px}.delete-warning-icon{font-size:32px;flex-shrink:0}.delete-warning-content{flex:1}.delete-warning-title{margin:0 0 12px;color:#c0392b;font-size:1.5rem;font-weight:600}.delete-warning-message{margin:0 0 16px;color:#666;font-size:.95rem;line-height:1.6}.delete-warning-message strong{color:#2c3e50;font-weight:600}.delete-warning-instruction{margin:0 0 12px;color:#555;font-size:.9rem;font-weight:500}.delete-warning-instruction strong{color:#c0392b;font-weight:600}.delete-confirm-input{width:100%;padding:10px 12px;border:2px solid #e74c3c;border-radius:6px;font-size:.95rem;font-family:inherit;box-sizing:border-box;transition:all .2s}.delete-confirm-input:focus{outline:none;border-color:#c0392b;box-shadow:0 0 0 3px #e74c3c1a}.delete-error-message{margin:8px 0 0;color:#c0392b;font-size:.85rem;font-weight:500}.delete-confirm-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:20px;padding-top:20px;border-top:1px solid #eee}.btn-danger{padding:.5rem 1.25rem;background:#e74c3c;color:#fff;border:none;border-radius:6px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s;font-family:inherit;display:flex;align-items:center;justify-content:center;box-sizing:border-box;min-height:36px;line-height:1.5}.btn-danger:hover:not(:disabled){background:#c0392b;transform:translateY(-1px);box-shadow:0 4px 8px #e74c3c4d}.btn-danger:active:not(:disabled){transform:translateY(0)}.btn-danger:disabled{background:#ccc;cursor:not-allowed;transform:none}.btn-secondary{padding:.5rem 1.25rem;background:#f5f5f5;color:#333;border:1px solid #ddd;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s;font-family:inherit;display:flex;align-items:center;justify-content:center;box-sizing:border-box;min-height:36px;line-height:1.5}.btn-secondary:hover{background:#e8e8e8;border-color:#ccc}.btn-primary{padding:.5rem 1.25rem;background:#3498db;color:#fff;border:none;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s;font-family:inherit;display:flex;align-items:center;justify-content:center;box-sizing:border-box;min-height:36px;line-height:1.5}.btn-primary:hover:not(:disabled){background:#2980b9}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.modal-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:20px;padding-top:20px;border-top:1px solid #eee}.error-message{color:#d32f2f;margin-bottom:.75rem;padding:.5rem .75rem;background:#ffebee;border-radius:6px;font-size:.85rem;border-left:3px solid #d32f2f}.clients-page{padding:60px 20px 20px}.clients-table-container{background:#fff;border-radius:8px;border:1px solid #e5e7eb;overflow:hidden;box-shadow:0 2px 8px #0000001a;overflow-x:auto}.clients-table{width:100%;border-collapse:collapse;font-size:14px;min-width:800px}.clients-table thead{background:#3498db!important;color:#fff!important}.clients-table th{padding:12px!important;text-align:left;font-weight:600;font-size:13px;white-space:nowrap;color:#fff!important;background:#3498db!important}.clients-table td{padding:10px 12px!important;border-bottom:1px solid #e5e7eb;color:#374151;font-size:14px;vertical-align:middle}.clients-table tbody tr{border-bottom:1px solid #e5e7eb;transition:background .2s}.clients-table tbody tr:hover{background:#f9fafb}.clients-table tbody tr:nth-child(2n){background:#f9fafb}.clients-table tbody tr:nth-child(2n):hover{background:#f3f4f6}.clients-table tbody tr:last-child td{border-bottom:1px solid #e5e7eb}.client-row-clickable{cursor:pointer}.client-row-clickable:hover{background-color:#f9fafb!important}.client-row-clickable:nth-child(2n):hover{background-color:#f3f4f6!important}.client-name-cell{font-weight:500}.client-code-badge{display:inline-block;background-color:#ecf0f5;color:#3498db;padding:4px 10px;border-radius:12px;font-size:12px;font-weight:600}.clients-table .no-data{text-align:center;padding:2rem;color:#6c757d}.clients-table th:last-child{text-align:center}.client-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:clientModalFadeIn .2s}@keyframes clientModalFadeIn{0%{opacity:0}to{opacity:1}}.client-modal-container{background:#fff;border-radius:8px;box-shadow:0 4px 20px #00000026;padding:1.5rem;max-width:500px;width:90%;max-height:90vh;overflow-y:auto;position:relative;box-sizing:border-box}.client-modal-close{position:absolute;top:1rem;right:1rem;background:none;border:none;font-size:2rem;cursor:pointer;color:#999;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s;z-index:10}.client-modal-close:hover{background:#f8f9fa;color:#333}.client-modal-container h2{margin:0 0 1.5rem;color:#2c3e50;font-size:1.5rem;font-weight:600}.client-modal-container .form-group{margin-bottom:1.25rem}.client-modal-container .form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#495057;font-size:.95rem}.client-modal-container .form-group input,.client-modal-container .form-group textarea{width:100%;padding:.75rem;border:1.5px solid #e0e0e0;border-radius:8px;font-size:1rem;transition:border-color .2s;font-family:inherit;box-sizing:border-box}.client-modal-container .form-group input:focus,.client-modal-container .form-group textarea:focus{outline:none;border-color:#3498db}.client-modal-container .form-group textarea{resize:vertical}.client-modal-container .modal-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:1.5rem;padding-top:1rem;border-top:1px solid #eee}.client-modal-container .btn-primary,.client-modal-container .btn-secondary{padding:.5rem 1.25rem;border:none;border-radius:8px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s;font-family:inherit;display:flex;align-items:center;justify-content:center;box-sizing:border-box;min-height:36px;line-height:1.5;margin:0}.client-modal-container .btn-primary{background:#3498db;color:#fff}.client-modal-container .btn-primary:hover{background:#2980b9}.client-modal-container .btn-secondary{background:#e9ecef;color:#495057}.client-modal-container .btn-secondary:hover{background:#dee2e6}.client-modal-container .error-message{background:#fee;color:#c33;padding:1rem;border-radius:8px;margin-bottom:1rem}.detail-footer-actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:2rem;padding-top:1.5rem;border-top:1px solid #eee}.btn-action{display:flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;border:none;border-radius:0;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s;font-family:inherit;box-shadow:0 1px 3px #0000001f}.btn-update{background:#3498db;color:#fff}.btn-update:hover{background:#2980b9;box-shadow:0 2px 6px #00000026;transform:translateY(-1px)}.btn-delete{background:#e74c3c;color:#fff}.btn-delete:hover:not(:disabled){background:#c0392b;box-shadow:0 2px 6px #00000026;transform:translateY(-1px)}.btn-delete:disabled{background:#ccc;cursor:not-allowed;opacity:.6;transform:none}.detail-content{display:flex;flex-direction:column;gap:1.5rem}.small-panels-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem}.detail-section.small-panel{background:#fff;padding:1.5rem;border-radius:0;box-shadow:0 1px 3px #0000001f;border-top:3px solid #3498db}.section-title{margin:0 0 1.25rem;color:#2c3e50;font-size:1.25rem;font-weight:600}.info-list-inline{display:flex;flex-direction:column;gap:.75rem}.info-row{display:flex;align-items:flex-start;gap:.5rem;line-height:1.5}.info-label{font-size:.9rem;color:#666;font-weight:500;min-width:120px;flex-shrink:0}.info-value{font-size:.95rem;color:#2c3e50;font-weight:500;flex:1}.description-inline{white-space:pre-wrap;word-wrap:break-word}.projects-list{display:flex;flex-direction:column;gap:.75rem}.project-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:#f8f9fa;border-radius:0;border-left:2px solid #3498db}.project-name{font-weight:500;color:#2c3e50;font-size:.95rem}.project-code-badge{display:inline-block;background-color:#ecf0f5;color:#3498db;padding:4px 10px;border-radius:12px;font-size:12px;font-weight:600}.loading-projects{display:flex;align-items:center;gap:.75rem;padding:1rem;color:#666}.loading-spinner-small{width:20px;height:20px;border:2px solid #f3f3f3;border-top:2px solid #3498db;border-radius:50%;animation:spin 1s linear infinite}.no-data{color:#999;font-style:italic;padding:1rem;text-align:center;background:#f8f9fa;border-radius:0}@media(max-width:768px){.detail-footer-actions{flex-direction:column;width:100%}.btn-action{width:100%;justify-content:center}.small-panels-row{grid-template-columns:1fr}}.tasks-page{padding:60px 20px 20px}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px}.header-with-back{display:flex;align-items:center;gap:1rem}.page-header h1{margin:0;font-size:28px;color:#2c3e50;display:flex;align-items:center;gap:.5rem}.back-button{background:#f5f5f5;border:1px solid #ddd;color:#333;padding:.5rem 1rem;border-radius:6px;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s;margin-right:0;font-family:inherit;flex-shrink:0}.back-button:hover{background:#e8e8e8;border-color:#bbb}.breadcrumb-link{color:#3498db;cursor:pointer;text-decoration:none;transition:color .2s}.breadcrumb-link:hover{color:#2980b9;text-decoration:underline}.page-actions{margin-bottom:20px;display:flex;justify-content:flex-start;align-items:center;gap:12px}.btn-create{display:flex;align-items:center;gap:8px;background-color:#3498db;color:#fff;border:none;padding:8px 24px;border-radius:6px;font-size:16px;font-weight:500;cursor:pointer;transition:background-color .2s}.btn-create:hover{background-color:#2980b9}.btn-create .icon{font-size:20px;font-weight:700}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:#666}.loading-spinner{width:40px;height:40px;border:4px solid #f3f3f3;border-top:4px solid #3498db;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:15px}.empty-state{text-align:center;padding:60px 20px;background-color:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a}.empty-icon{font-size:64px;margin-bottom:20px}.empty-state h3{margin:0 0 10px;color:#2c3e50;font-size:24px}.empty-state p{color:#666;margin-bottom:20px}.tasks-table-container{background:#fff;border-radius:8px;border:1px solid #e5e7eb;overflow:hidden;box-shadow:0 2px 8px #0000001a;overflow-x:auto}.tasks-table{width:100%;border-collapse:collapse;font-size:14px;min-width:900px}.tasks-table thead{background:#3498db!important;color:#fff!important}.tasks-table th{padding:12px!important;text-align:left;font-weight:600;font-size:13px;white-space:nowrap;color:#fff!important;background:#3498db!important}.tasks-table td{padding:10px 12px!important;border-bottom:1px solid #e5e7eb;color:#374151;font-size:14px;vertical-align:middle}.tasks-table tbody tr{border-bottom:1px solid #e5e7eb;transition:background .2s}.tasks-table tbody tr:hover{background:#f9fafb}.tasks-table tbody tr:nth-child(2n){background:#f9fafb}.tasks-table tbody tr:nth-child(2n):hover{background:#f3f4f6}.tasks-table tbody tr:last-child td{border-bottom:1px solid #e5e7eb}.task-row-clickable{cursor:pointer}.task-row-clickable:hover{background-color:#f9fafb!important}.task-row-clickable:nth-child(2n):hover{background-color:#f3f4f6!important}.task-name-cell{font-weight:500}.tasks-table .no-data{text-align:center;padding:2rem;color:#6c757d}.actions-cell{position:relative;min-width:120px;text-align:center}.tasks-table th:last-child{text-align:center}.table-actions{display:flex;gap:8px;align-items:center}.btn-icon{background:none;border:none;cursor:pointer;font-size:18px;padding:6px 8px;border-radius:4px;transition:all .2s;display:flex;align-items:center;justify-content:center;width:32px;height:32px}.btn-icon:hover{background:none;opacity:.7}.btn-edit{color:#3498db}.btn-edit:hover{color:#2980b9}.btn-delete{color:#e74c3c}.btn-delete:hover{background:none;color:#c0392b}.btn-view{color:#3498db}.btn-view:hover{background-color:#e3f2fd;color:#2980b9}.btn-up,.btn-down{color:#6b7280;font-size:16px;font-weight:700;line-height:1;margin:0 -2px}.btn-up:hover:not(:disabled),.btn-down:hover:not(:disabled){color:#3498db;background:#e3f2fd}.btn-up:disabled,.btn-down:disabled{opacity:.3;cursor:not-allowed}.delete-icon{font-size:24px;font-weight:700;line-height:1;color:#e74c3c}.status-badge{display:inline-block;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:500;white-space:nowrap}.status-badge.active{background-color:#28a745;color:#fff}.status-badge.disabled{background-color:#6c757d;color:#fff}.chargeable-badge{display:inline-block;padding:4px 10px;border-radius:4px;font-size:12px;font-weight:500;white-space:nowrap}.chargeable-badge.yes{background-color:#d4edda;color:#155724}.chargeable-badge.no{background-color:#f8d7da;color:#721c24}.task-disabled{opacity:.6;color:#999!important}.task-disabled td{color:#999!important}.task-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:taskModalFadeIn .2s}@keyframes taskModalFadeIn{0%{opacity:0}to{opacity:1}}.task-modal-container{background:#fff;border-radius:8px;box-shadow:0 4px 20px #00000026;padding:1.5rem;max-width:500px;width:90%;max-height:90vh;overflow-y:auto;position:relative;box-sizing:border-box}.task-modal-close{position:absolute;top:1rem;right:1rem;background:none;border:none;font-size:2rem;cursor:pointer;color:#999;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s;z-index:10}.task-modal-close:hover{background:#f8f9fa;color:#333}.task-modal-container h2{margin:0 0 1.5rem;color:#2c3e50;font-size:1.5rem;font-weight:600}.task-modal-container .form-group{margin-bottom:1.25rem}.task-modal-container .form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#495057;font-size:.95rem}.task-modal-container .form-group input,.task-modal-container .form-group textarea,.task-modal-container .form-group select{width:100%;padding:.75rem;border:1.5px solid #e0e0e0;border-radius:8px;font-size:1rem;transition:border-color .2s;font-family:inherit;box-sizing:border-box}.task-modal-container .form-group input:focus,.task-modal-container .form-group textarea:focus,.task-modal-container .form-group select:focus{outline:none;border-color:#3498db}.task-modal-container .form-group textarea{resize:vertical}.task-modal-container .form-group select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23333' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;background-size:12px;padding-right:2.5rem;appearance:none;-webkit-appearance:none;-moz-appearance:none}.task-modal-container .estimation-radio-group{display:flex;gap:1rem;margin-bottom:.75rem}.task-modal-container .radio-label{display:flex;align-items:center;font-size:.875rem;font-weight:400;color:#2c3e50;cursor:pointer}.task-modal-container .radio-label input[type=radio]{cursor:pointer;width:16px;height:16px;accent-color:#3498db}.task-modal-container .radio-label span{margin-left:.5rem}.task-modal-container .estimation-input{width:100%;padding:.625rem;border:1.5px solid #e0e0e0;border-radius:0;font-size:.95rem;font-family:inherit;transition:border-color .2s;box-sizing:border-box}.task-modal-container .estimation-input:focus{outline:none;border-color:#3498db}.task-modal-container .modal-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:1.5rem;padding-top:1rem;border-top:1px solid #eee}.task-modal-container .btn-primary,.task-modal-container .btn-secondary{padding:.5rem 1.25rem;border:none;border-radius:8px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s;font-family:inherit;display:flex;align-items:center;justify-content:center;box-sizing:border-box;min-height:36px;line-height:1.5;margin:0}.task-modal-container .btn-primary{background:#3498db;color:#fff}.task-modal-container .btn-primary:hover{background:#2980b9}.task-modal-container .btn-secondary{background:#e9ecef;color:#495057}.task-modal-container .btn-secondary:hover{background:#dee2e6}.task-modal-container .error-message{background:#fee;color:#c33;padding:1rem;border-radius:8px;margin-bottom:1rem}.profile-container{padding:20px;max-width:800px;margin:0 auto}.profile-header{margin-bottom:30px}.profile-header h1{margin:0;font-size:28px;color:#2c3e50}.profile-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:1rem}.loading-spinner{width:40px;height:40px;border:4px solid #f3f3f3;border-top:4px solid #3498db;border-radius:50%;animation:spin 1s linear infinite}.profile-content{display:flex;flex-direction:column;gap:2rem}.profile-section{background:#fff;border-radius:8px;padding:2rem;box-shadow:0 1px 3px #0000001f}.section-title{margin:0 0 1.5rem;font-size:20px;color:#2c3e50;font-weight:600;border-bottom:2px solid #3498db;padding-bottom:.5rem}.profile-form{display:flex;flex-direction:column;gap:1.25rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-weight:600;color:#2c3e50;font-size:14px}.form-input{padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:14px;font-family:inherit;transition:border-color .2s ease}.form-input:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 3px #3498db1a}.form-input.disabled{background-color:#f5f5f5;color:#666;cursor:not-allowed}.form-help{font-size:12px;color:#666;margin-top:-.25rem}.error-message{background-color:#fee;color:#c33;padding:.75rem 1rem;border-radius:4px;margin-bottom:1rem;border-left:4px solid #c33;font-size:14px}.success-message{background-color:#efe;color:#3c3;padding:.75rem 1rem;border-radius:4px;margin-bottom:1rem;border-left:4px solid #3c3;font-size:14px}.form-actions{display:flex;gap:1rem;margin-top:.5rem;padding-top:1rem;border-top:1px solid #eee}.btn-primary{padding:.875rem 1.5rem;background:#3498db;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;font-family:inherit;min-height:44px;line-height:1.5;box-sizing:border-box;margin:0;display:flex;align-items:center;justify-content:center}.btn-primary:hover:not(:disabled){background:#2980b9;transform:translateY(-2px);box-shadow:0 4px 12px #3498db4d}.btn-primary:disabled{background:#bdc3c7;cursor:not-allowed;transform:none}@media(max-width:768px){.profile-container{padding:15px}.profile-section{padding:1.5rem}.form-actions{flex-direction:column}.btn-primary{width:100%}}.pagination{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:16px;padding:12px}.pagination-info{color:#6b7280;font-size:.875rem;font-weight:500}.filters-section{display:flex;flex-wrap:wrap;gap:1rem;align-items:flex-end;margin-bottom:1.5rem;padding:1rem;background:#f9fafb;border-radius:8px}.filter-group{display:flex;flex-direction:column;gap:.25rem}.filter-input{padding:.5rem;border:1px solid #d1d5db;border-radius:6px;font-size:.875rem;min-width:150px;transition:border-color .2s}.filter-input:focus{outline:none;border-color:#3498db}.btn-clear-filters{padding:.5rem 1rem;background:#6b7280;color:#fff;border:none;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:background .2s;height:fit-content}@media(max-width:768px){.filters-section{flex-direction:column;align-items:stretch}.filter-group,.filter-input{width:100%}}.pending-approvals-page{padding:24px;max-width:1400px;margin:0 auto}.table-container{background:#fff;border-radius:8px;border:1px solid #e5e7eb;overflow:hidden}.approvals-table{width:100%;border-collapse:collapse}.approvals-table thead{background:#f9fafb;border-bottom:2px solid #e5e7eb}.approvals-table th{padding:12px 16px;text-align:left;font-weight:600;color:#374151;font-size:.8125rem;text-transform:uppercase;letter-spacing:.5px}.approvals-table td{padding:16px;border-bottom:1px solid #f3f4f6;color:#111827}.table-row-clickable{cursor:pointer;transition:background .2s}.table-row-clickable:hover{background:#f9fafb}.employee-cell{display:flex;flex-direction:column;gap:4px}.actions-header{text-align:center}.actions-cell{padding:8px 16px;text-align:center}.table-actions{display:flex;gap:8px;justify-content:center;align-items:center}.btn-icon{background:none;border:none;cursor:pointer;font-size:18px;padding:6px 8px;border-radius:4px;transition:all .2s;display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;flex-shrink:0}.btn-icon:hover{opacity:.8}.btn-approve{background:#27ae60;color:#fff}.btn-approve:hover{background:#229954}.btn-reject,.btn-return{background:#e74c3c;color:#fff}.btn-reject:hover,.btn-return:hover{background:#c0392b}.pagination{display:flex;justify-content:center;align-items:center;gap:16px;margin-top:24px;padding:20px;background:#fff;border-radius:8px;border:1px solid #e5e7eb}@media(max-width:768px){.pending-approvals-page{padding:16px}.filters-section{flex-direction:column}.filter-group{min-width:100%}.table-container{overflow-x:auto}.approvals-table{min-width:600px}}.approved-timesheets-page{padding:24px;max-width:1400px;margin:0 auto}.page-header{margin-bottom:24px}.page-header h1{margin:0 0 8px;font-size:28px;color:#2c3e50}.page-subtitle{margin:0;color:#6b7280;font-size:14px}.filters-section{display:flex;gap:16px;margin-bottom:24px;padding:20px;background:#fff;border-radius:8px;border:1px solid #e5e7eb;flex-wrap:wrap;align-items:flex-end}.filter-group{display:flex;flex-direction:column;gap:6px;min-width:200px;flex:1}.filter-group label{font-size:.875rem;font-weight:500;color:#374151}.filter-input{padding:8px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:.875rem;transition:border-color .2s}.filter-input:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 3px #3498db1a}.btn-clear-filters{padding:8px 16px;background:#6b7280;color:#fff;border:none;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:background .2s;white-space:nowrap}.btn-clear-filters:hover{background:#4b5563}.approvals-table{width:100%;border-collapse:collapse;font-size:14px}.approvals-table thead{background:#3498db!important;color:#fff!important}.approvals-table th{padding:12px!important;text-align:left;font-weight:600;font-size:13px;white-space:nowrap;color:#fff!important;background:#3498db!important}.approvals-table td{padding:10px 12px!important;border-bottom:1px solid #e5e7eb;color:#374151;font-size:14px;vertical-align:middle}.approvals-table tbody tr{border-bottom:1px solid #e5e7eb;transition:background .2s}.approvals-table tbody tr:hover{background:#f9fafb}.approvals-table tbody tr:nth-child(2n){background:#f9fafb}.approvals-table tbody tr:nth-child(2n):hover{background:#f3f4f6}.approvals-table tbody tr:last-child td{border-bottom:1px solid #e5e7eb}.table-row-clickable{cursor:pointer}.hours-cell{font-weight:600;color:#3498db}.status-badge.status-approved{background:#dbeafe;color:#1e40af}@media(max-width:768px){.approved-timesheets-page{padding:16px}.filters-section{flex-direction:column}.filter-group{min-width:100%}.table-container{overflow-x:auto}.approvals-table{min-width:700px}}.missing-submissions-page{padding:24px;max-width:1400px;margin:0 auto}.loading-container{padding:60px 20px;text-align:center}.loading-spinner{border:3px solid #f3f4f6;border-top:3px solid #3498db;border-radius:50%;width:40px;height:40px;animation:spin 1s linear infinite;margin:0 auto 16px}.empty-state{padding:60px 20px;text-align:center;background:#fff;border-radius:8px;border:1px solid #e5e7eb}.empty-state p{color:#6b7280;font-size:1rem}.table-container{background:#fff;border-radius:8px;border:1px solid #e5e7eb;overflow:hidden;box-shadow:0 2px 8px #0000001a;overflow-x:auto}.missing-submissions-table{width:100%;border-collapse:collapse;font-size:14px}.missing-submissions-table thead{background:#3498db;color:#fff!important}.missing-submissions-table th{padding:12px!important;text-align:left;font-weight:600;font-size:13px;white-space:nowrap;color:#fff!important;background:#3498db!important}.missing-submissions-table td{padding:10px 12px!important;border-bottom:1px solid #e5e7eb;color:#374151;font-size:14px;vertical-align:middle}.missing-submissions-table tbody tr:hover{background:#f9fafb}.employee-cell{display:flex;flex-direction:row;align-items:center;gap:6px;white-space:nowrap}.employee-name{font-weight:600;color:#111827}.employee-username{font-size:.8125rem;color:#6b7280}.status-badge{padding:4px 12px;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase}.status-badge.status-not-submitted{background:#fee2e2;color:#991b1b}.status-badge.status-pending{background:#fef3c7;color:#92400e}.status-badge.status-rejected{background:#fee2e2;color:#991b1b}.status-badge.status-unlocked{background:#dbeafe;color:#1e40af}.btn-remind{padding:6px 16px;background:#f59e0b;color:#fff;border:none;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:background .2s}.btn-remind:hover:not(:disabled){background:#d97706}.btn-remind.reminded{background:#6b7280}.btn-remind.reminded:hover:not(:disabled){background:#4b5563}.btn-remind:disabled{background:#d1d5db;cursor:not-allowed}.pagination{display:flex;justify-content:center;align-items:center;gap:16px;margin-top:24px}.pagination-btn{padding:8px 16px;background:#3498db;color:#fff;border:none;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:background .2s}.pagination-btn:hover:not(:disabled){background:#2980b9}.pagination-btn:disabled{background:#d1d5db;cursor:not-allowed}.pagination-info{color:#6b7280;font-size:.875rem}.timesheets-page{padding:60px 20px 20px;max-width:1400px;margin:0 auto;width:100%;box-sizing:border-box;overflow-x:hidden}.timesheets-toggle-container{margin-bottom:24px;display:flex;justify-content:flex-start;align-items:center;gap:8px;overflow:visible}.timesheets-toggle-container .toggle-switch-wrapper{display:flex;background:#e5e7eb;border-radius:8px;padding:4px;gap:4px;box-shadow:0 1px 3px #0000001a;border:1px solid #d1d5db;flex-shrink:0}.timesheets-toggle-container .toggle-option{padding:6px 32px;border:none;background:transparent;color:#6b7280;font-size:14px;font-weight:500;cursor:pointer;border-radius:6px;transition:all .2s ease;white-space:nowrap;font-family:inherit}.timesheets-toggle-container .toggle-option:hover{color:#374151;background:#0000000d}.timesheets-toggle-container .toggle-option.active{background:#3498db;color:#fff;font-weight:600;box-shadow:0 2px 4px #3498db4d}.timesheets-content{width:100%}.team-toggle-switch-wrapper{display:flex;background:#e5e7eb;border-radius:8px;padding:3px;gap:3px;box-shadow:0 1px 3px #0000001a;border:1px solid #d1d5db;animation:revealHorizontal 1s ease-out;flex-shrink:0;overflow:hidden}@keyframes revealHorizontal{0%{max-width:0;opacity:0}to{max-width:500px;opacity:1}}.team-toggle-option{padding:4px 16px;border:none;background:transparent;color:#6b7280;font-size:13px;font-weight:500;cursor:pointer;border-radius:5px;transition:all .2s ease;white-space:nowrap;font-family:inherit;position:relative;display:flex;align-items:center;gap:6px}.team-toggle-option:hover{color:#374151;background:#0000000d}.team-toggle-option.active{background:#3498db;color:#fff;font-weight:600;box-shadow:0 2px 4px #3498db4d}.team-toggle-badge{background:#ef4444;color:#fff;font-size:10px;font-weight:700;padding:2px 5px;border-radius:10px;min-width:16px;text-align:center;line-height:1.3}.team-toggle-option.active .team-toggle-badge{background:#ef4444;color:#fff}.timesheets-header{margin-bottom:24px;display:flex;justify-content:space-between;align-items:flex-start}.timesheets-header-left{flex:0 0 auto}.timesheets-header-left h1{margin:0;font-size:32px;color:#111827;font-weight:700}.timesheets-header-right{flex:0 0 auto;text-align:right;display:flex;flex-direction:column;align-items:flex-end;gap:8px}.timesheets-header-right .company-name{font-size:24px;color:#3498db;font-weight:600;letter-spacing:.5px;margin:0}.timesheets-subtitle{margin:0;font-size:16px;color:#4b5563;font-weight:500}.error-banner,.success-banner{padding:12px 16px;border-radius:6px;margin-bottom:20px;font-size:14px}.error-banner{background-color:#fee;color:#c33;border-left:3px solid #c33}.success-banner{background-color:#d4edda;color:#155724;border-left:3px solid #155724}.week-selector-container{display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:20px;position:relative;width:100%}.summary-table-container{width:100%;box-sizing:border-box;margin-bottom:0;overflow-x:hidden}.summary-table-container .timesheet-summary-table{width:100%}.summary-status-actions-panel{width:100%;box-sizing:border-box;margin-top:12px;margin-bottom:20px}.summary-status-actions-panel .week-status-info{display:flex;flex-direction:row;align-items:center;justify-content:space-between;gap:12px;width:100%}.summary-item{display:flex;flex-direction:column;align-items:center;gap:6px;flex:1}.summary-label{font-size:13px;color:#6c757d;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.summary-value{font-size:26px;font-weight:700;color:#3498db}.summary-separator{width:1px;height:60px;background:#e9ecef;flex-shrink:0;align-self:center}.summary-right-section{display:flex;flex-direction:column;gap:12px;align-items:flex-start;min-width:200px;flex-shrink:0;justify-content:center}@media(max-width:768px){.weekly-summary-panel{flex-direction:column;align-items:stretch}.summary-stats-section{margin-bottom:16px}.summary-separator{width:100%;height:1px;margin:8px 0}.summary-right-section{width:100%;min-width:auto}}.week-status-info{display:flex;align-items:flex-start;gap:8px;width:100%;flex-wrap:wrap}.status-badge{padding:6px 12px;border-radius:6px;font-size:13px;font-weight:600;display:inline-flex;align-items:center;gap:6px}.status-badge.status-draft{background:#f3f4f6;color:#6b7280;border:1px solid #e5e7eb;box-shadow:0 1px 2px #0000000d}.status-badge.status-draft-rejected{background:#fee2e2;color:#dc2626;border:1px solid #fca5a5;animation:pulse-warning 2s ease-in-out infinite}@keyframes pulse-warning{0%,to{box-shadow:0 0 #dc262666}50%{box-shadow:0 0 0 4px #dc262600}}.status-draft-flag{font-size:14px;animation:wave-flag 1s ease-in-out infinite}@keyframes wave-flag{0%,to{transform:rotate(0)}25%{transform:rotate(-10deg)}75%{transform:rotate(10deg)}}.status-badge.status-submitted{background:#28a745;color:#fff}.status-badge.status-missing{background:#fbbf24;color:#78350f;font-weight:700;box-shadow:0 2px 4px #fbbf244d}.status-badge.status-returned{background:#fee2e2;color:#dc2626;border:1px solid #fca5a5;display:inline-flex;flex-direction:row;align-items:center;gap:6px;padding:4px 10px}.status-returned-flag{display:inline-flex;align-items:center;justify-content:center;background:#ef4444;color:#fff;border-radius:3px;padding:1px 4px;font-size:11px;font-weight:700;min-width:18px;height:16px;flex-shrink:0}.status-badge.status-returned>span:not(.status-returned-flag){color:#dc2626;font-weight:600;white-space:nowrap}.status-badge.status-returned .return-reason{display:inline;font-size:11px;font-weight:400;color:#991b1b;margin-left:4px;line-height:1.4}.status-badge.status-unlocked{background:#fef3c7;color:#92400e}.rejection-reason,.unlocked-message{display:block;font-size:12px;font-weight:400;color:#dc2626;margin-top:4px}.reminder-banner{display:flex;align-items:center;gap:8px;padding:10px 14px;background:#fef3c7;border:1px solid #f59e0b;border-radius:6px;margin-bottom:8px;width:100%;box-sizing:border-box}.reminder-icon{font-size:18px;flex-shrink:0}.reminder-content{flex:1}.reminder-title{font-size:14px;font-weight:600;color:#92400e}.week-actions{display:flex;gap:8px;width:100%;justify-content:flex-start}.btn-submit-week,.btn-request-modify{padding:8px 16px;border:none;border-radius:var(--radius-md);font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.btn-submit-week:disabled{background:var(--color-disabled);cursor:not-allowed}.btn-request-modify{background:var(--color-info);color:#fff}.btn-request-modify:hover{background:var(--color-info-hover)}.week-status-container{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:24px;flex-wrap:wrap;gap:16px}.week-status-badges{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.status-badge{padding:6px 12px;border-radius:6px;font-size:13px;font-weight:500;white-space:nowrap}.status-draft{background:#e9ecef;color:#495057}.status-submitted{background:#fff3cd;color:#856404}.status-approved{background:#d4edda;color:#155724}.status-rejected{background:#f8d7da;color:#721c24}.week-actions{display:flex;gap:12px;align-items:center}.btn-submit-week,.btn-approve-week,.btn-reject-week{padding:8px 20px;border:none;border-radius:var(--radius-md);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap}.btn-submit-week{background:var(--color-success);color:#fff}.btn-submit-week:hover:not(:disabled){background:var(--color-success-hover)}.btn-approve-week{background:var(--color-success);color:#fff}.btn-approve-week:hover:not(:disabled){background:var(--color-success-hover)}.btn-reject-week{background:var(--color-danger);color:#fff}.btn-reject-week:hover:not(:disabled){background:var(--color-danger-hover)}.btn-submit-week:disabled,.btn-approve-week:disabled,.btn-reject-week:disabled{background:var(--color-disabled);cursor:not-allowed;opacity:.6}.edit-disabled-message{padding:12px 16px;background:#fff3cd;color:#856404;border-radius:6px;margin-bottom:16px;font-size:14px;border-left:3px solid #ffc107}.week-nav-btn{background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-sm);width:24px;height:44px;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;transition:background .2s;flex-shrink:0;font-weight:600;padding:0;box-sizing:border-box}.week-nav-btn:hover{background:var(--color-primary-hover)}.week-combobox-wrapper{width:30%;display:flex;align-items:center;position:relative}.week-combobox{width:100%;padding:10px 36px 10px 12px;font-size:14px;border:2px solid var(--color-gray-300);border-radius:var(--radius-md);background:var(--bg-white);color:var(--color-gray-800);cursor:pointer;outline:none;transition:border-color .2s;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%234a5568' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;box-sizing:border-box;height:44px}.week-combobox:hover{border-color:var(--color-gray-400)}.week-combobox:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #3498db1a}.week-combobox option{padding:8px;color:#2d3748;background:#fff}.week-combobox option[data-status=approved],.week-combobox option[data-status=submitted]{color:#10b981;background:#fff}.week-combobox option[data-status=missing]{color:#ef4444;background:#fff;border:none;outline:none}.week-combobox optgroup{font-weight:600;color:#4a5568;padding:4px 0}.calendar-wrapper{position:relative}.calendar-btn{background:#3498db;color:#fff;border:none;border-radius:4px;padding:0;height:44px;width:44px;cursor:pointer;font-size:24px;display:flex;align-items:center;box-sizing:border-box;justify-content:center;transition:background .2s;flex-shrink:0;white-space:nowrap}.calendar-btn:hover{background:#2980b9}.calendar-panel{position:absolute;top:calc(100% + 8px);right:0;background:#fff;border:2px solid #e9ecef;border-radius:8px;box-shadow:0 4px 12px #00000026;padding:16px;z-index:1000;min-width:360px;max-width:360px}.calendar-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;gap:8px}.calendar-month-year{flex:1;text-align:center;font-weight:600;font-size:16px;color:#2c3e50}.calendar-nav-btn{background:#f8f9fa;border:1px solid #dee2e6;border-radius:4px;width:32px;height:32px;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;transition:all .2s;color:#495057}.calendar-nav-btn:hover{background:#e9ecef;border-color:#adb5bd}.calendar-today-btn{background:#3498db;color:#fff;border:none;border-radius:4px;padding:6px 12px;font-size:12px;font-weight:500;cursor:pointer;transition:background .2s}.calendar-today-btn:hover{background:#2980b9}.calendar-grid{display:flex;flex-direction:column}.calendar-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:8px}.calendar-weekday{text-align:center;font-weight:600;font-size:12px;color:#6c757d;padding:8px 4px;text-transform:uppercase;letter-spacing:.5px}.calendar-days{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.calendar-day{aspect-ratio:1;background:#fff;border:1px solid #e9ecef;border-radius:4px;cursor:pointer;font-size:14px;color:#495057;display:flex;align-items:center;justify-content:center;transition:all .2s;padding:0;min-height:40px}.calendar-day:hover{background:#f8f9fa;border-color:#3498db;transform:scale(1.05)}.calendar-day.today{background:#e3f2fd;border-color:#3498db;font-weight:600;color:#1976d2}.calendar-day.in-current-week{background:#d1ecf1;border-color:#17a2b8;font-weight:600;color:#0c5460}.calendar-day.today.in-current-week{background:#bee5eb;border-color:#17a2b8;font-weight:700;color:#0c5460}.calendar-day.other-month{color:#adb5bd;background:#f8f9fa}.calendar-day.other-month:hover{background:#e9ecef;color:#6c757d}.calendar-day.selected-day{background:#007bff;color:#fff;border-color:#0056b3;font-weight:700;box-shadow:0 2px 4px #007bff4d}.calendar-day.selected-day:hover{background:#0056b3;border-color:#004085}.calendar-day.selected-day.in-current-week,.calendar-day.selected-day.today{background:#0056b3;color:#fff;border-color:#004085}.calendar-day.weekend{background:#f5f5f5;border-color:#d0d0d0;color:#888;font-weight:400}.calendar-day.weekend:hover{background:#e8e8e8;border-color:#b8b8b8}.calendar-day.weekend.other-month{background:#f0f0f0;color:#aaa}.calendar-day.weekend.in-current-week{background:#e8e8e8;border-color:silver;color:#777}.calendar-day.weekend.today{background:#d8d8d8;border-color:#a0a0a0;color:#666;font-weight:500}.calendar-day.weekend.selected-day{background:#888;color:#fff;border-color:#666}.calendar-day.weekend.selected-day:hover{background:#666;border-color:#444}.calendar-day.holiday{background:#fff5f5;border-color:#ff6b6b;color:#d32f2f;font-weight:600;position:relative}.calendar-day.holiday:hover{background:#ffe0e0;border-color:#ff5252}.calendar-day.holiday.other-month{background:#fff0f0;color:#f99}.calendar-day.holiday.in-current-week{background:#ffebee;border-color:#ff6b6b;color:#c62828}.calendar-day.holiday.today{background:#ffcdd2;border-color:#ff6b6b;color:#b71c1c;font-weight:700}.calendar-day.holiday.selected-day{background:#ff6b6b;color:#fff;border-color:#d32f2f}.calendar-day.holiday.selected-day:hover{background:#d32f2f;border-color:#b71c1c}.calendar-day.holiday.weekend{background:#fff0f0;border-color:#f99}.calendar-holiday-indicator{position:absolute;top:2px;right:2px;font-size:6px;color:#ff6b6b;line-height:1}.calendar-day.holiday.selected-day .calendar-holiday-indicator{color:#fff}.week-cards-wrapper{flex:1;overflow-x:auto;overflow-y:hidden;position:relative;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:#cbd5e0 transparent}.week-cards-wrapper::-webkit-scrollbar{height:6px}.week-cards-wrapper::-webkit-scrollbar-track{background:transparent}.week-cards-wrapper::-webkit-scrollbar-thumb{background:#cbd5e0;border-radius:3px}.week-cards-wrapper::-webkit-scrollbar-thumb:hover{background:#a0aec0}.week-cards-container{display:flex;gap:12px;padding:8px 0;align-items:center}.week-card-wrapper{height:130px;display:flex;align-items:center;justify-content:center;padding:3px;box-sizing:border-box}.week-card{flex-shrink:0;min-width:100px;max-width:110px;height:130px;min-height:124px;padding:12px 10px;background:#d1d5db;border:2px solid #6b7280;border-radius:8px;cursor:pointer;transition:all .2s;display:flex;flex-direction:column;gap:6px;box-sizing:border-box;text-align:center;align-items:center;width:100%}.week-card.in-month-group:not(.current-week):not(.next-week):not(.last-week):not(.selected-week){background:#d1d5db}.month-separator{width:3px;height:112px;background:#9ca3af;margin:0 6px;flex-shrink:0;border-radius:2px;opacity:.8}.week-card.current-week,.week-card.next-week,.week-card.last-week{border-color:#6b7280;background:#d1d5db}.week-card:has(.week-card-status .week-status-icon):not(.selected-week){border-color:#6b7280;background:#d1d5db}.week-card:not(:has(.week-card-status .week-status-icon)):not(.selected-week){border-color:#6b7280;background:#d1d5db}.week-card.selected-week{border-color:#ef4444;border-width:3px;font-weight:600;position:relative;background-image:repeating-linear-gradient(45deg,#d1d5db,#d1d5db 10px,#c4c9d0 10px 20px)}.week-card.selected-week:has(.week-card-status .week-status-icon){background-image:repeating-linear-gradient(45deg,#d1d5db,#d1d5db 10px,#c4c9d0 10px 20px)}.week-card.selected-week:not(:has(.week-card-status .week-status-icon)){background-image:repeating-linear-gradient(45deg,#d1d5db,#d1d5db 10px,#c4c9d0 10px 20px)}.week-card.selected-week.current-week,.week-card.selected-week.next-week,.week-card.selected-week.last-week{background-image:repeating-linear-gradient(45deg,#d1d5db,#d1d5db 10px,#c4c9d0 10px 20px)}.week-card.selected-week:before{content:"";position:absolute;top:-18px;left:50%;transform:translate(-50%);width:0;height:0;border-left:14px solid transparent;border-right:14px solid transparent;border-bottom:18px solid #ef4444;z-index:1}.week-card:focus,.week-card:focus-visible{outline:none!important;outline-offset:0!important}.week-card-date{display:flex;flex-direction:column;gap:4px;line-height:1.3;align-items:center;flex:1;justify-content:center}.week-card-year{font-size:12px;color:#9ca3af;font-weight:600}.week-card-month{font-size:13px;color:#0a61ee;font-weight:700;letter-spacing:.5px}.week-card-range{font-size:12px;color:#1e40af;font-weight:700}.week-card-icons{display:flex;align-items:center;justify-content:center;gap:6px;flex-wrap:wrap;margin-top:auto}.week-card-status{margin-top:auto;padding-top:8px;display:flex;align-items:center;justify-content:center;width:100%;height:20px;min-height:20px;flex-shrink:0}.week-status-text{font-size:10px;font-weight:600;padding:2px 6px;border-radius:4px;text-transform:uppercase;letter-spacing:.5px}.week-status-text.status-approved{background:#10b981;color:#fff;font-weight:700;box-shadow:0 2px 4px #10b9814d}.week-status-text.status-submitted{background:#d1ecf1;color:#0c5460}.week-status-text.status-rejected{background:#fbbf24;color:#78350f;font-weight:700;box-shadow:0 2px 4px #fbbf244d}.week-status-text.status-draft{background:#fff3cd;color:#856404}.week-status-text.status-missing{background:#ef4444;color:#fff;font-weight:700;font-size:10px;padding:2px 6px;border-radius:4px;text-transform:uppercase;letter-spacing:.5px;box-shadow:0 2px 4px #ef44444d}.week-status-icon{font-size:18px;font-weight:700;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;line-height:1;background:transparent;padding:0;border-radius:0}.week-status-icon.status-approved,.week-status-icon.status-submitted{color:#10b981}.week-status-icon.status-missing,.week-status-icon.status-rejected{color:#ef4444}.week-status-approved{color:#3498db;font-weight:900;font-size:18px;font-family:Arial,sans-serif}.week-status-action-needed{width:10px;height:10px;background-color:#ef4444;border-radius:50%;display:inline-block;flex-shrink:0}.week-card-badges{display:flex;align-items:center;justify-content:center;gap:6px;flex-wrap:wrap}.notification-week-badge{background:#ef4444;color:#fff;font-size:11px;font-weight:600;padding:2px 6px;border-radius:10px;min-width:18px;text-align:center;line-height:1.4}.current-badge,.next-badge,.last-badge{padding:2px 8px;border-radius:12px;font-size:11px;font-weight:500;white-space:nowrap;flex-shrink:0}.current-badge{background:#3498db;color:#fff}.next-badge{background:#28a745;color:#fff}.last-badge{background:#ffc107;color:#000}.days-header{display:grid;grid-template-columns:repeat(7,1fr);gap:8px;margin-bottom:20px}.day-header-btn{background:#e3f2fd;border:2px solid #bbdefb;border-radius:8px;padding:8px 12px;cursor:pointer;transition:background .2s,box-shadow .2s,transform .2s;display:flex;flex-direction:column;align-items:center;gap:4px;position:relative}.day-header-btn.weekend{background:#f5f5f5;border:2px solid #d0d0d0}.day-header-btn.holiday{border:2px solid #ffb3ba;background:#fff5f5}.day-header-btn.holiday.weekend{background:#f5f5f5;border:2px solid #d0d0d0}.day-header-btn:hover:not(.selected){border:2px solid #3498db;background:#d0e7ff}.day-header-btn.weekend:hover:not(.selected){background:#e8e8e8;border:2px solid #d0d0d0}.day-header-btn.holiday:hover:not(.selected){background:#ffe0e0;border:2px solid #ff5252}.day-header-btn.selected{border:2px solid #dc3545!important;background:#fff5f5!important;box-shadow:0 2px 8px #dc354533}.day-header-btn.selected:hover{border:2px solid #dc3545!important;background:#ffeaea!important}.day-header-btn.weekend.selected{border:2px solid #dc3545!important;background:#d8d8d8!important;box-shadow:0 2px 8px #dc354533}.day-header-btn.weekend.selected:hover{border:2px solid #dc3545!important;background:#d0d0d0!important}.day-header-btn.holiday.selected{border:2px solid #dc3545!important;background:#fff5f5!important;box-shadow:0 2px 8px #dc354533}.day-header-btn.holiday.selected:hover{border:2px solid #dc3545!important;background:#ffeaea!important}.day-header-btn.holiday.weekend.selected{border:2px solid #dc3545!important;background:#d8d8d8!important;box-shadow:0 2px 8px #dc354533}.day-header-btn.holiday.weekend.selected:hover{border:2px solid #dc3545!important;background:#d0d0d0!important}.day-header-btn.weekend .day-name,.day-header-btn.weekend .day-date{color:#888;font-weight:500}.day-header-btn:focus,.day-header-btn:focus-visible{outline:none!important;outline-offset:0!important}.holiday-label{font-size:10px;color:#ff6b6b;font-weight:600;margin-top:4px;text-align:center;line-height:1.2}.holiday-description{display:block;font-size:9px;color:#999;font-weight:400;margin-top:2px;font-style:italic}.day-name{font-weight:600;font-size:14px;color:#495057;text-transform:uppercase;letter-spacing:.5px}.day-date{font-size:13px;color:#6c757d}.day-total-badge{position:absolute;top:8px;right:8px;background:#28a745;color:#fff;padding:4px 8px;border-radius:12px;font-size:11px;font-weight:600}.entries-table{width:100%;border-collapse:collapse;margin-bottom:24px;overflow:hidden;border:none;border-radius:8px;background:#fff;box-shadow:0 2px 8px #0000001a;font-size:14px;min-width:600px}.entries-table thead{background:var(--color-primary)!important;color:#fff!important}.entries-table th{color:#fff!important;background:var(--color-primary)!important;border:none!important}.entries-table thead th{border:none!important}.entries-table tbody tr{border-bottom:1px solid var(--color-gray-200);transition:background .2s}.entries-table tbody tr:hover{background:var(--color-gray-50)}.entries-table tbody tr:nth-child(2n):not(.add-entry-row){background:#f9fafb}.entries-table tbody tr:nth-child(2n):not(.add-entry-row):hover{background:#f3f4f6}.entries-table tbody tr:last-child td{border-bottom:none}.entries-table tbody tr:first-child td{border-top:none}.col-project,.col-task{width:25%}.col-hour{width:10%;text-align:center}.col-description{width:30%}.col-actions{width:10%;text-align:center}.entries-table th.col-project,.entries-table th.col-task,.entries-table th.col-hour,.entries-table th.col-description,.entries-table th.col-actions{color:#fff!important;background:#3498db!important}.entries-table th.col-actions{text-align:center;color:#fff!important;background:#3498db!important}.no-entries-cell{text-align:center;padding:40px 20px!important}.no-entries{color:#6c757d;font-style:italic;font-size:14px}.entry-row{transition:background .2s}.add-entry-row{background:#e8f4f8!important;border-top:2px solid #3498db}.add-entry-row td{color:#374151}.entry-row td{font-size:14px;color:#374151}.entry-row .col-project{font-weight:600;color:#374151}.entry-row .col-task{color:#374151}.entry-row .col-hour{font-weight:600;color:#3498db}.entry-row .col-description{color:#6c757d;font-size:13px;word-wrap:break-word;max-width:300px;white-space:pre-wrap}.btn-edit-entry,.btn-delete-entry{padding:6px 12px;border:none;border-radius:var(--radius-sm);font-size:12px;font-weight:500;cursor:pointer;transition:all .2s;margin:0 4px}.btn-edit-entry:disabled,.btn-delete-entry:disabled{background:var(--color-disabled)!important;color:var(--color-gray-600)!important;cursor:not-allowed;opacity:.6}.btn-edit-entry{background:var(--color-warning);color:#fff}.btn-edit-entry:hover{background:var(--color-warning-hover)}.btn-delete-entry{background:var(--color-danger);color:#fff}.btn-delete-entry:hover{background:var(--color-danger-hover)}.entry-select-inline{width:100%;padding:4px 6px;border:1.5px solid #ddd;border-radius:6px;font-size:14px;background:#fff;cursor:pointer;transition:border-color .2s;box-sizing:border-box}.entry-select-inline:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 3px #3498db1a}.entry-select-inline:disabled{background:#f0f0f0;cursor:not-allowed}.entry-hours-input-inline{width:100%;padding:4px 6px;border:1.5px solid #ddd;border-radius:6px;font-size:14px;text-align:center;transition:border-color .2s;box-sizing:border-box}.entry-hours-input-inline:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 3px #3498db1a}.entry-description-input-inline{width:100%;padding:4px 6px;border:1.5px solid #ddd;border-radius:6px;font-size:14px;font-family:inherit;transition:border-color .2s;box-sizing:border-box}.entry-description-input-inline:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 3px #3498db1a}.entry-description-input-inline::placeholder{color:#999}.entry-select{flex:1;min-width:180px;padding:10px 12px;border:1.5px solid #ddd;border-radius:6px;font-size:14px;background:#fff;cursor:pointer;transition:border-color .2s;box-sizing:border-box}.entry-select:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 3px #3498db1a}.entry-select:disabled{background:#f0f0f0;cursor:not-allowed}.entry-hours-input{width:100px;padding:10px 12px;border:1.5px solid #ddd;border-radius:6px;font-size:14px;text-align:center;transition:border-color .2s;box-sizing:border-box}.entry-hours-input:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 3px #3498db1a}.btn-add-entry{padding:8px 16px;background:var(--color-success);color:#fff;border:none;border-radius:var(--radius-md);font-size:13px;font-weight:500;cursor:pointer;transition:background .2s;white-space:nowrap;margin-right:8px}.btn-save-entry{background:var(--color-success);border:none;cursor:pointer;font-size:18px;padding:6px 8px;border-radius:var(--radius-sm);transition:all .2s;display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;color:#fff;margin-right:4px}.btn-save-entry:hover:not(:disabled){background:var(--color-success-hover)}.btn-save-entry:disabled{opacity:.6;cursor:not-allowed}.btn-add-entry:hover:not(:disabled),.btn-save-entry:hover:not(:disabled){background:var(--color-success-hover)}.btn-add-entry:disabled,.btn-save-entry:disabled{background:var(--color-disabled);cursor:not-allowed}.btn-cancel-entry{background:var(--color-danger);border:none;cursor:pointer;font-size:18px;padding:6px 8px;border-radius:var(--radius-sm);transition:all .2s;display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;color:#fff}.btn-cancel-entry:hover{background:var(--color-danger-hover)}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:var(--color-gray-600)}.loading-spinner{width:40px;height:40px;border:4px solid var(--color-gray-100);border-top:4px solid var(--color-primary);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:15px}@media(max-width:768px){.days-header{grid-template-columns:repeat(7,1fr);gap:4px}.day-header-btn{padding:12px 8px}.day-name{font-size:12px}.day-date{font-size:11px}.add-entry-form,.entry-edit-form{flex-direction:column;align-items:stretch}.entry-select,.entry-hours-input{width:100%;min-width:auto}.entry-info{flex-direction:column;align-items:flex-start;gap:4px}.entry-hours{margin-left:0}}.submission-history-section{margin-top:40px;margin-bottom:20px}.history-toggle-btn{display:flex;align-items:center;gap:8px;padding:10px 16px;background:#f3f4f6;border:1px solid #d1d5db;border-radius:6px;cursor:pointer;transition:all .2s;font-size:14px;font-weight:500;color:#374151;font-family:inherit}.history-toggle-btn:hover{background:#e5e7eb;border-color:#9ca3af}.history-toggle-icon{font-size:12px;transition:transform .2s}.history-toggle-text{font-size:14px}.history-container{overflow:hidden;transition:max-height .3s ease,opacity .3s ease,margin-top .3s ease}.history-container.collapsed{max-height:0;opacity:0;margin-top:0}.history-container.expanded{max-height:5000px;opacity:1;margin-top:16px}.history-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px;gap:12px}.history-loading .loading-spinner{width:32px;height:32px;border:3px solid #e5e7eb;border-top-color:#3498db;border-radius:50%;animation:spin .8s linear infinite}.history-empty{text-align:center;padding:40px;color:#6b7280}.history-table-container{overflow-x:auto;margin-bottom:16px}.history-table{width:100%;border-collapse:collapse;background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 1px 3px #0000001a}.history-table thead{background:#f9fafb}.history-table th{padding:12px 16px;text-align:left;font-weight:600;font-size:13px;color:#374151;border-bottom:2px solid #e5e7eb}.history-table td{padding:12px 16px;border-bottom:1px solid #e5e7eb;font-size:14px;color:#1f2937}.history-table tbody tr:hover{background:#f9fafb}.history-table tbody tr:last-child td{border-bottom:none}.history-status-badge{display:inline-block;padding:4px 10px;border-radius:12px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.history-status-badge.status-approved{background:#10b981;color:#fff}.history-status-badge.status-submitted{background:#d1ecf1;color:#0c5460}.history-status-badge.status-rejected{background:#f8d7da;color:#721c24}.history-status-badge.status-missing{background:#ef4444;color:#fff;font-weight:700;box-shadow:0 2px 4px #ef44444d}.history-status-badge.status-returned{background:#fee2e2;color:#dc2626;font-weight:600;border:1px solid #fca5a5}.history-status-badge.status-draft{background:#f3f4f6;color:#6b7280;font-weight:600}.history-view-btn{padding:6px 12px;background:#3498db;color:#fff;border:none;border-radius:4px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s}.history-view-btn:hover{background:#2980b9;box-shadow:0 2px 4px #3498db4d}@keyframes spin{to{transform:rotate(360deg)}}.company-settings-page{padding:20px;max-width:1200px;margin:0 auto}.page-header{margin-bottom:30px}.page-header h1{margin:0;font-size:28px;color:#2c3e50}.page-subtitle{margin:5px 0 0;color:#666;font-size:14px}.error-banner{background-color:#fee;color:#c33;padding:12px 20px;border-radius:6px;margin-bottom:20px;border-left:4px solid #c33}.success-banner{background-color:#d4edda;color:#155724;padding:12px 20px;border-radius:6px;margin-bottom:20px;border-left:4px solid #28a745}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center}.loading-spinner{width:40px;height:40px;border:4px solid #f3f3f3;border-top:4px solid #3498db;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:20px}.settings-section{background:#fff;border-radius:12px;padding:24px;margin-bottom:24px;box-shadow:0 2px 8px #0000001a}.section-title{font-size:20px;color:#2c3e50;margin:0 0 20px;font-weight:600;padding-bottom:12px;border-bottom:2px solid #e9ecef}.settings-form{margin-bottom:24px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}.form-group{margin-bottom:16px}.form-group label{display:block;margin-bottom:6px;font-weight:500;color:#374151;font-size:14px}.form-group input[type=text],.form-group input[type=number],.form-group input[type=date],.form-group select,.form-group textarea{width:100%;padding:10px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;font-family:inherit;transition:border-color .2s,box-shadow .2s;background-color:#fff}.form-group input[type=text]:focus,.form-group input[type=number]:focus,.form-group input[type=date]:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 3px #3498db1a}.form-group select:disabled{background-color:#f3f4f6;cursor:not-allowed;opacity:.6}.form-group textarea{resize:vertical;min-height:60px}.form-hint{display:block;margin-top:4px;font-size:12px;color:#6c757d}.form-actions{display:flex;gap:12px;margin-top:20px}.form-actions .btn-primary,.btn-primary{background:var(--color-primary);color:#fff;border:none;padding:10px 20px;border-radius:var(--radius-lg)!important;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s}.btn-primary:hover:not(:disabled){background:var(--color-primary-hover)}.btn-primary:disabled{background:var(--color-disabled);cursor:not-allowed;opacity:.6}.btn-secondary{background:var(--color-gray-100);color:var(--color-gray-700);border:1px solid var(--color-gray-300);padding:10px 20px;border-radius:var(--radius-md);font-size:14px;font-weight:500;cursor:pointer;transition:background .2s}.btn-secondary:hover{background:var(--color-gray-200)}.table-container{margin-top:24px;border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);overflow:hidden;background:var(--bg-white)}.data-table{width:100%;border-collapse:collapse;font-size:14px}.data-table thead{background:var(--color-primary);color:#fff}.data-table th{padding:12px;text-align:left;font-weight:600;font-size:13px;white-space:nowrap}.data-table th:nth-child(3){text-align:center}.data-table td:nth-child(3){width:100px;min-width:100px;max-width:100px;text-align:center;padding:12px}.data-table tbody tr{border-bottom:1px solid #e5e7eb;transition:background .2s}.data-table tbody tr:hover{background:#f9fafb}.data-table tbody tr:nth-child(2n){background:#f9fafb}.data-table tbody tr:nth-child(2n):hover{background:#f3f4f6}.data-table td{padding:12px;color:var(--color-gray-700);font-size:14px;vertical-align:middle}.data-table tbody tr:last-child td{border-bottom:none}.no-data{text-align:center;color:#6c757d;font-style:italic;padding:40px!important}.table-actions{display:flex;gap:8px;justify-content:center}.btn-icon{width:32px;height:32px;padding:0;border:none;border-radius:6px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s;font-size:16px}.btn-edit{background:#e3f2fd;color:#1976d2}.btn-edit:hover{background:#bbdefb}.btn-delete{background:#ffebee;color:#c62828}.btn-delete:hover{background:#ffcdd2}@media(max-width:768px){.form-row{grid-template-columns:1fr}.company-settings-page,.settings-section{padding:16px}.table-container{overflow-x:auto}}.auth-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:authModalFadeIn .2s ease-in}@keyframes authModalFadeIn{0%{opacity:0}to{opacity:1}}.auth-modal-container{background:#fff;padding:1.5rem;border-radius:8px;width:90%;max-width:400px;max-height:90vh;overflow-y:auto;box-shadow:0 4px 20px #00000026;position:relative;animation:authModalSlideUp .3s ease-out;box-sizing:border-box}@keyframes authModalSlideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.auth-modal-close{position:absolute;top:1rem;right:1rem;background:none;border:none;font-size:2rem;color:#999;cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s;line-height:1;z-index:10}.auth-modal-close:hover{background:#f8f9fa;color:#333}.auth-modal-container h2{margin:0 0 1rem;color:#2c3e50;font-size:1.5rem;font-weight:600}.auth-modal-container .form-group{margin-bottom:.75rem}.auth-modal-container .form-group label{display:block;margin-bottom:.35rem;color:#555;font-weight:500;font-size:.875rem}.auth-modal-container .form-group input{width:100%;padding:.5rem .75rem;border:1.5px solid #ddd;border-radius:6px;font-size:.95rem;box-sizing:border-box;transition:all .2s;font-family:inherit;height:36px}.auth-modal-container .form-group input:focus{outline:none;border-color:#4caf50;box-shadow:0 0 0 3px #4caf501a}.auth-modal-container .form-group input::placeholder{color:#aaa}.auth-modal-container .error-message{color:#d32f2f;margin-bottom:.75rem;padding:.5rem .75rem;background:#ffebee;border-radius:6px;font-size:.85rem;border-left:3px solid #d32f2f}.auth-modal-container .btn-primary{width:100%;padding:.625rem;background:#4caf50;color:#fff;border:none;border-radius:6px;font-size:.95rem;font-weight:600;cursor:pointer;margin-top:.5rem;transition:all .2s;font-family:inherit;height:40px}.auth-modal-container .btn-primary:hover:not(:disabled){background:#45a049;transform:translateY(-1px);box-shadow:0 4px 8px #4caf504d}.auth-modal-container .btn-primary:active:not(:disabled){transform:translateY(0)}.auth-modal-container .btn-primary:disabled{background:#ccc;cursor:not-allowed;transform:none}.auth-modal-container .modal-footer{margin-top:1rem;padding-top:1rem;border-top:1px solid #eee;text-align:center;color:#666;font-size:.875rem}.auth-modal-container .link-button{background:none;border:none;color:#4caf50;cursor:pointer;text-decoration:none;padding:0;font-size:.95rem;font-weight:600;transition:color .2s}.auth-modal-container .link-button:hover{color:#45a049;text-decoration:underline}.auth-modal-container .signup-method-selector{margin-bottom:1.5rem}.auth-modal-container .method-tabs{display:flex;gap:.5rem;margin-bottom:1rem;border-bottom:2px solid #e8eaed}.auth-modal-container .method-tab{padding:.75rem 1.5rem;background:none;border:none;border-bottom:3px solid transparent;cursor:pointer;font-size:.9rem;font-weight:500;color:#666;transition:all .2s;font-family:inherit}.auth-modal-container .method-tab:hover{color:#333;background:#f5f5f5}.auth-modal-container .method-tab.active{color:#4caf50;border-bottom-color:#4caf50;background:#f0f8f0}.auth-modal-container .form-hint{display:block;margin-top:.2rem;font-size:.75rem;color:#999;font-style:italic;line-height:1.2}.auth-modal-container .invitation-info{background:#e3f2fd;border:1px solid #2196F3;border-radius:6px;padding:1rem;margin-bottom:1.5rem}.auth-modal-container .invitation-info p{margin:.25rem 0;color:#1976d2;font-size:.95rem}.auth-modal-container .invitation-role{font-weight:500;text-transform:capitalize}.auth-modal-container .loading-state{padding:2rem;text-align:center;color:#666;display:flex;flex-direction:column;align-items:center;gap:1rem}.auth-modal-container .loading-spinner-small{width:32px;height:32px;border:3px solid #f3f3f3;border-top:3px solid #4CAF50;border-radius:50%;animation:spin 1s linear infinite}.sidebar{width:280px;height:100vh;background:#2c3e50;border-right:none;display:flex;flex-direction:column;position:fixed;left:0;top:0;z-index:100}.sidebar-header{padding:1rem 1.25rem;border-bottom:1px solid rgba(255,255,255,.1);position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden}.sidebar-logo-link{display:flex;align-items:center;justify-content:center;width:100%;text-decoration:none;transition:opacity .2s ease}.sidebar-logo-link:hover{opacity:.8}.sidebar-logo{max-width:100%;width:auto;height:auto;max-height:60px;object-fit:contain;transform:scale(4.5) translateY(2px);transform-origin:center;image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges}.sidebar-clock-widget{text-align:center;padding:.75rem 1.25rem;border-top:1px solid rgba(255,255,255,.1);flex-shrink:0}.sidebar-current-time{font-size:2.25rem;font-weight:700;font-variant-numeric:tabular-nums;color:#fffffff2;margin-bottom:.15rem;line-height:1.1}.sidebar-current-date{font-size:.85rem;color:#ffffffb3;line-height:1.2}.company-header{position:relative}.company-header-button{width:100%;background:none;border:none;padding:.5rem;border-radius:6px;transition:background .2s;cursor:pointer;text-align:left}.company-header-button:hover{background:#ffffff1a}.company-header-content{display:flex;flex-direction:column;gap:.25rem;align-items:center;text-align:center}.company-code{font-size:1.25rem;font-weight:700;color:#3498db;line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.company-name{font-size:.65rem;color:#fff9;line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.company-dropdown{position:absolute;top:calc(100% + .5rem);left:0;right:0;background:#fff;border:1px solid #e0e0e0;border-radius:10px;box-shadow:0 4px 16px #0000001f;z-index:1000;animation:dropdownSlide .2s ease-out;overflow:hidden}.company-dropdown .dropdown-item{width:100%;padding:.875rem 1.25rem;background:none;border:none;text-align:left;cursor:pointer;color:#333;font-size:.95rem;transition:all .2s;display:flex;align-items:center;gap:.75rem;font-family:inherit}.company-dropdown .dropdown-item svg{flex-shrink:0}.company-dropdown .dropdown-item:hover{background:#f5f5f5;color:#4caf50}.company-dropdown .dropdown-item:active{background:#eee}.sidebar-calendar{padding:.75rem 1.25rem;border-top:1px solid rgba(255,255,255,.1);margin-top:0;background:transparent;flex-shrink:0}.sidebar-calendar .MuiPickersCalendarHeader-root{padding:0;margin-bottom:.5rem}.sidebar-calendar .MuiPickersCalendarHeader-labelContainer,.sidebar-calendar .MuiPickersArrowSwitcher-root{margin-left:0;margin-right:0}.sidebar-menu{flex:0 1 auto;padding:.75rem 0;overflow-y:auto;overflow-x:hidden;min-height:0}.menu-section{padding:0 1rem}.menu-label{display:block;font-size:.75rem;font-weight:600;color:#ffffff80;text-transform:uppercase;letter-spacing:.5px;padding:.5rem .75rem .35rem}.menu-item{display:flex;align-items:center;gap:.875rem;padding:.6rem .875rem;margin-bottom:.1rem;border-radius:6px;text-decoration:none;color:#fffc;font-weight:500;font-size:.95rem;transition:all .2s ease}.menu-item:hover{background:#ffffff1a;color:#fff}.menu-item.active{background:#3498db;color:#fff}.menu-item.active:hover{background:#2980b9}.menu-item.has-submenu{cursor:pointer;display:flex;justify-content:space-between;align-items:center}.menu-item-with-submenu{display:flex;align-items:center;justify-content:space-between;padding:0;margin-bottom:.25rem;border-radius:0;transition:all .2s ease;overflow:hidden}.menu-item-with-submenu:hover{background:#ffffff1a}.menu-item-with-submenu.active{background:#3498db}.menu-item-with-submenu.active:hover{background:#2980b9}.menu-item-with-submenu.expanded{background:#ffffff26}.menu-item-link{display:flex;align-items:center;gap:.875rem;padding:.75rem .875rem;flex:1;text-decoration:none;color:#fffc;font-weight:500;font-size:.95rem;transition:color .2s ease}.menu-item-with-submenu:hover .menu-item-link,.menu-item-with-submenu.active .menu-item-link{color:#fff}.menu-arrow-button{display:flex;align-items:center;justify-content:center;padding:.75rem .875rem;background:none;border:none;border-left:2px solid rgba(255,255,255,.2);cursor:pointer;color:#fff9;font-size:12px;transition:color .2s ease;margin-left:auto}.menu-arrow-button:hover{color:#ffffffe6}.menu-item-with-submenu.active .menu-arrow-button{color:#fffc}.menu-arrow{font-size:12px;color:inherit}.menu-item.expanded{background:#ffffff26}.submenu{padding-left:20px;background:#0003;margin-top:.25rem;border-radius:6px}.submenu-item{display:flex;align-items:center;gap:8px;padding:.625rem .875rem;color:#ffffffb3;text-decoration:none;font-size:.9rem;transition:all .2s;border-radius:4px;margin:.125rem .5rem}.submenu-item:hover{background:#ffffff1a;color:#fff}.submenu-item.active{background:#3498db4d;color:#fff;font-weight:500}.submenu-icon{color:#ffffff80;font-size:10px}.menu-icon{font-size:1.25rem;line-height:1;width:24px;display:flex;align-items:center;justify-content:center;color:inherit}.menu-icon svg{width:1.25rem;height:1.25rem;color:inherit}.menu-text{flex:1}@media(max-width:768px){.sidebar{width:60px}.logo-text,.menu-label,.menu-text{display:none}.sidebar-header{padding:1rem .75rem}.logo{justify-content:center}.menu-item{justify-content:center;padding:.75rem}}.notification-toast-container{position:fixed;top:80px;right:20px;z-index:10000;display:flex;flex-direction:column;gap:12px;max-width:400px}.notification-toast{background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 4px 12px #00000026;padding:16px;min-width:320px;max-width:400px;display:flex;align-items:flex-start;gap:12px;animation:slideInRight .3s ease-out}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.toast-icon{font-size:24px;flex-shrink:0;margin-top:2px}.toast-content{flex:1;min-width:0}.toast-title{font-size:14px;font-weight:600;color:#111827;margin-bottom:4px}.toast-message{font-size:13px;color:#6b7280;line-height:1.4;word-wrap:break-word}.toast-close{background:none;border:none;font-size:20px;color:#9ca3af;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:color .2s}.toast-close:hover{color:#374151}.notification-bell-container{position:relative}.notification-bell-btn{position:relative;background:none;border:none;font-size:1.25rem;cursor:pointer;padding:.5rem;color:#6b7280;border-radius:8px;transition:all .2s ease}.notification-bell-btn:hover{background:#f3f4f6;color:#111827}.notification-badge{position:absolute;top:2px;right:2px;background:#ef4444;color:#fff;font-size:.65rem;font-weight:600;padding:.125rem .375rem;border-radius:10px;min-width:18px;text-align:center;line-height:1.2}.notification-badge.pulse{animation:pulse-badge .6s ease-in-out}@keyframes pulse-badge{0%,to{transform:scale(1)}50%{transform:scale(1.3);box-shadow:0 0 15px #ef4444cc}}.notification-bell-btn.has-new-notification{animation:shake-bell .5s ease-in-out}@keyframes shake-bell{0%,to{transform:translate(0) rotate(0)}25%{transform:translate(-4px) rotate(-8deg)}75%{transform:translate(4px) rotate(8deg)}}.notification-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:400px;max-height:500px;background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 10px 25px #00000026;z-index:1000;display:flex;flex-direction:column;overflow:hidden}.notification-dropdown-header{display:flex;justify-content:space-between;align-items:center;padding:16px;border-bottom:1px solid #e5e7eb;background:#f9fafb}.notification-dropdown-header h3{margin:0;font-size:1rem;font-weight:600;color:#111827}.mark-all-read-btn{background:none;border:none;color:#3498db;font-size:.875rem;cursor:pointer;padding:4px 8px;border-radius:4px;transition:background .2s}.mark-all-read-btn:hover{background:#e3f2fd}.notification-list{overflow-y:auto;max-height:400px}.notification-item{display:flex;align-items:flex-start;padding:12px 16px;border-bottom:1px solid #f3f4f6;cursor:pointer;transition:background .2s;position:relative}.notification-item:hover{background:#f9fafb}.notification-item.unread{background:#eff6ff}.notification-item.unread:hover{background:#dbeafe}.notification-icon{font-size:1.5rem;margin-right:12px;flex-shrink:0;margin-top:2px;display:flex;align-items:center;justify-content:center}.notification-icon svg{font-size:1.5rem;width:1.5rem;height:1.5rem;color:#6b7280}.notification-icon-submit svg{color:#10b981}.notification-icon-request svg{color:#3b82f6}.notification-icon-remind svg{color:#f59e0b}.notification-icon-return svg{color:#ef4444}.notification-content{flex:1;min-width:0}.notification-title{font-weight:600;font-size:.875rem;color:#111827;margin-bottom:4px}.notification-message{font-size:.8125rem;color:#6b7280;line-height:1.4;margin-bottom:4px;word-wrap:break-word;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.notification-time{font-size:.75rem;color:#9ca3af}.notification-dot{position:absolute;top:16px;right:12px;width:8px;height:8px;background:#3498db;border-radius:50%;flex-shrink:0}.notification-empty,.notification-loading{padding:40px 20px;text-align:center;color:#9ca3af;font-size:.875rem}.notification-list::-webkit-scrollbar{width:6px}.notification-list::-webkit-scrollbar-track{background:#f1f1f1}.notification-list::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.notification-list::-webkit-scrollbar-thumb:hover{background:#a8a8a8}@media(max-width:480px){.notification-dropdown{width:400px;right:-10px}}.user-menu{position:relative}.user-icon{background:none;border:none;cursor:pointer;padding:.5rem;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s;color:#333}.user-icon:hover{background:#0000000d;transform:scale(1.05)}.user-icon:active{transform:scale(.98)}.user-icon svg{width:24px;height:24px}.user-dropdown{position:absolute;top:calc(100% + .5rem);right:0;background:#fff;border:1px solid #e0e0e0;border-radius:10px;box-shadow:0 4px 16px #0000001f;min-width:220px;z-index:1000;animation:dropdownSlide .2s ease-out;overflow:hidden}@keyframes dropdownSlide{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.user-info{padding:1.25rem;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);border-bottom:1px solid #e0e0e0;display:flex;flex-direction:column;gap:.35rem}.user-name{font-weight:600;color:#333;font-size:1rem;line-height:1.4;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-username{font-size:.85rem;color:#666;line-height:1.4;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{font-size:.75rem;color:#888;text-transform:uppercase;letter-spacing:.5px;font-weight:600;background:#fff9;display:inline-block;padding:.25rem .5rem;border-radius:4px;line-height:1.4;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:fit-content}.dropdown-divider{height:1px;background:#e0e0e0;margin:0}.dropdown-item{width:100%;padding:.875rem 1.25rem;background:none;border:none;text-align:left;cursor:pointer;color:#333;font-size:.95rem;transition:all .2s;display:flex;align-items:center;gap:.75rem;font-family:inherit}.dropdown-item svg{flex-shrink:0}.dropdown-item:hover{background:#f5f5f5;color:#4caf50}.dropdown-item:active{background:#eee}.dropdown-item:last-child{border-bottom-left-radius:10px;border-bottom-right-radius:10px}.topbar{height:93px;background:linear-gradient(135deg,#3498db,#2980b9);color:#fff;border-bottom:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.5rem;position:fixed;top:0;left:240px;right:0;z-index:90}.topbar-left{display:flex;align-items:center}.topbar-user-section{display:flex;flex-direction:column;align-items:flex-end;gap:.25rem}.topbar-icons{display:flex;align-items:center;gap:.75rem}.topbar-welcome-message{font-size:1rem;font-weight:500;color:#ff0;opacity:.9;white-space:nowrap}.menu-toggle{display:none;background:none;border:none;font-size:1.5rem;cursor:pointer;padding:.5rem;color:#fff;opacity:.9}.menu-toggle:hover{opacity:1}.topbar-center{flex:1;display:flex;align-items:center;justify-content:center;margin:0 2rem}.topbar-company-name{font-size:1.75rem;font-weight:700;text-align:center}.topbar-right{display:flex;align-items:center;justify-content:flex-end}.topbar-settings-btn{background:none;border:none;cursor:pointer;padding:.5rem;color:#fff;opacity:.9;border-radius:8px;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.topbar-settings-btn:hover{background:#fff3;color:#fff;opacity:1}.topbar-icons .notification-bell-btn{color:#fff;opacity:.9}.topbar-icons .notification-bell-btn:hover{background:#fff3;color:#fff;opacity:1}.topbar-icons .user-icon{color:#fff;opacity:.9}.topbar-icons .user-icon:hover{background:#fff3;color:#fff;opacity:1}.topbar-sign-in-btn{background:#fff3;border:1px solid rgba(255,255,255,.3);color:#fff;padding:8px 20px;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s ease;white-space:nowrap}.topbar-sign-in-btn:hover{background:#ffffff4d;border-color:#ffffff80;color:#fff}.topbar-demo-message{font-size:.85rem;color:#fffc;margin-top:4px;white-space:nowrap}.notification-badge{position:absolute;top:2px;right:2px;background:#ef4444;color:#fff;font-size:.65rem;font-weight:600;padding:.125rem .375rem;border-radius:10px;min-width:18px;text-align:center}@media(max-width:768px){.topbar{left:60px;padding:0 1rem}.menu-toggle{display:block}.topbar-center{margin:0 1rem}.topbar-company-name{font-size:1.5rem}}@media(max-width:480px){.topbar{left:0;padding:0 .75rem}.topbar-center{margin:0 .5rem}.topbar-company-name{font-size:1.25rem}}:root{--color-primary: #3498db;--color-primary-hover: #2980b9;--color-primary-dark: #2c3e50;--color-success: #28a745;--color-success-hover: #218838;--color-danger: #dc3545;--color-danger-hover: #c82333;--color-warning: #f59e0b;--color-warning-hover: #d97706;--color-info: #f39c12;--color-info-hover: #e67e22;--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-disabled: #9ca3af;--color-disabled-bg: #e5e7eb;--bg-primary: #ecf0f5;--bg-white: #ffffff;--bg-sidebar: #2c3e50;--radius-sm: 4px;--radius-md: 6px;--radius-lg: 8px}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--bg-primary)}.app{min-height:100vh;background:var(--bg-primary)}.main-layout{min-height:100vh}.main-layout.with-sidebar{margin-left:280px;padding-top:70px}.app-content{width:100%;max-width:1400px;margin:0 auto;min-height:calc(100vh - 70px);padding:0 20px;overflow-x:hidden}.main-layout{min-height:100vh;overflow-x:hidden}.app{min-height:100vh;background:#ecf0f5;overflow-x:hidden}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--bg-primary);overflow-x:hidden}.loading-container{display:flex;flex-direction:column;justify-content:center;align-items:center;height:100vh;gap:1rem;background:var(--bg-primary)}.loading-spinner{width:48px;height:48px;border:4px solid var(--color-gray-300);border-top:4px solid var(--color-primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-container p{color:#6b7280;font-size:1.1rem}.welcome-message{text-align:center;padding:4rem 2rem;min-height:100vh;display:flex;flex-direction:column;justify-content:center;align-items:center}.welcome-message h2{color:var(--color-gray-900);font-size:2rem;margin-bottom:1rem}.welcome-message p{color:var(--color-gray-500);font-size:1.1rem}@media(max-width:768px){.main-layout.with-sidebar{margin-left:60px}}@media(max-width:480px){.main-layout.with-sidebar{margin-left:0;padding-top:70px}}:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}
