*{margin:0;padding:0;box-sizing:border-box}:root{--color-primary: #007AFF;--color-primary-hover: #0056CC;--color-success: #34C759;--color-warning: #FF9500;--color-danger: #FF3B30;--color-bg: #F5F5F7;--color-surface: #FFFFFF;--color-border: #E5E5EA;--color-text: #1D1D1F;--color-text-secondary: #86868B;--color-text-tertiary: #AEAEB2;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 4px 12px rgba(0, 0, 0, .08);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .12);--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px}body{font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,Segoe UI,Roboto,sans-serif;background-color:var(--color-bg);color:var(--color-text);line-height:1.5;-webkit-font-smoothing:antialiased}.loading-screen{display:flex;justify-content:center;align-items:center;height:100vh;font-size:1.25rem;color:#6b7280}.login-container{min-height:100vh;display:flex;justify-content:center;align-items:center;padding:1rem;background:linear-gradient(135deg,#667eea,#764ba2)}.login-card{background:#fff;padding:2rem;border-radius:.5rem;box-shadow:0 10px 25px #0003;width:100%;max-width:400px}.login-header{text-align:center;margin-bottom:2rem}.login-header h1{font-size:1.5rem;color:#1f2937;margin-bottom:.5rem}.login-header p{color:#6b7280}.login-form{display:flex;flex-direction:column;gap:1rem}.form-group{display:flex;flex-direction:column;gap:.25rem}.form-group label{font-size:.875rem;font-weight:500;color:#374151}.form-group input,.form-group select,.form-group textarea{padding:.5rem .75rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:.875rem;transition:border-color .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.form-group textarea{resize:vertical;min-height:80px}.error-message{background:#fef2f2;border:1px solid #fecaca;color:#dc2626;padding:.5rem;border-radius:.375rem;font-size:.875rem}.submit-button{background:#6366f1;color:#fff;padding:.75rem;border:none;border-radius:.375rem;font-weight:500;cursor:pointer;transition:background-color .2s}.submit-button:hover{background:#4f46e5}.submit-button:disabled{background:#9ca3af;cursor:not-allowed}.login-footer{margin-top:1rem;text-align:center}.toggle-button{background:none;border:none;color:#6366f1;cursor:pointer;font-size:.875rem}.toggle-button:hover{text-decoration:underline}.test-credentials{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid #e5e7eb}.test-credentials h4{font-size:.875rem;color:#6b7280;margin-bottom:.75rem;text-align:center}.credential-item{display:flex;align-items:center;gap:.75rem;padding:.5rem;background:#f9fafb;border-radius:.375rem;margin-bottom:.5rem}.role-badge{padding:.25rem .5rem;border-radius:.25rem;font-size:.7rem;font-weight:600;text-transform:uppercase;min-width:70px;text-align:center}.role-badge.admin{background:#fef3c7;color:#92400e}.role-badge.manager{background:#dbeafe;color:#1e40af}.role-badge.user{background:#d1fae5;color:#065f46}.credential-info{display:flex;flex-direction:column;gap:.125rem}.credential-info code{font-family:monospace;font-size:.75rem;color:#374151;background:transparent}.dashboard-container,.admin-container{min-height:100vh;background:var(--color-bg)}.dashboard-header{background:#fffc;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);padding:.875rem 2rem;border-bottom:1px solid var(--color-border);display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;z-index:100}.header-left{display:flex;align-items:center;gap:1rem}.header-left h1{font-size:1.125rem;font-weight:600;color:var(--color-text)}.user-info{color:var(--color-text-secondary);font-size:.8125rem}.header-right{display:flex;gap:.5rem}.logout-button{background:var(--color-danger);color:#fff;padding:.5rem .875rem;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:.8125rem;font-weight:500;transition:all .2s}.logout-button:hover{filter:brightness(.9)}.nav-link{background:transparent;color:var(--color-primary);padding:.5rem .875rem;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:.8125rem;font-weight:500;transition:all .2s}.nav-link:hover{background:#007aff1a}.error-banner{background:#fef2f2;border:1px solid #fecaca;color:#dc2626;padding:1rem;margin:1rem 2rem;border-radius:.375rem}.dashboard-main,.admin-main{padding:2rem}.week-navigation{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem}.week-title{font-size:1.125rem;font-weight:600;color:var(--color-text)}.nav-button{background:var(--color-surface);color:var(--color-primary);padding:.5rem 1rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;font-size:.8125rem;font-weight:500;transition:all .2s}.nav-button:hover{background:var(--color-bg);border-color:var(--color-primary)}.timesheet-container{background:var(--color-surface);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);overflow-x:auto;border:1px solid var(--color-border)}.timesheet-table{width:100%;border-collapse:collapse}.timesheet-table th,.timesheet-table td{padding:.75rem;text-align:center;border:1px solid var(--color-border)}.timesheet-table th{background:var(--color-bg);font-weight:600;font-size:.8125rem;color:var(--color-text-secondary)}.project-column{text-align:left!important;width:200px}.day-column{width:100px}.total-column{width:80px;background:#f3f4f6!important}.day-name{font-size:.75rem;color:#6b7280}.day-number{font-size:1rem;font-weight:600}.project-cell{text-align:left!important}.project-name{display:flex;align-items:center;gap:.5rem}.project-color{width:12px;height:12px;border-radius:50%;flex-shrink:0}.hours-cell{cursor:pointer;transition:all .2s}.hours-cell:hover{background:#007aff14}.total-cell{background:var(--color-bg);font-weight:600;color:var(--color-text)}.totals-row td{background:var(--color-bg);font-weight:600}.total-label{text-align:right!important}.daily-total{color:var(--color-primary)}.week-total{color:var(--color-success);font-size:1.1rem}.no-projects{text-align:center;color:#6b7280;padding:2rem!important}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0006;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;justify-content:center;align-items:center;z-index:1000}.modal{background:var(--color-surface);padding:1.5rem;border-radius:var(--radius-lg);width:100%;max-width:420px;box-shadow:var(--shadow-lg);animation:modalSlideIn .2s ease-out}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-10px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.modal h3{margin-bottom:1.25rem;color:var(--color-text);font-size:1.125rem;font-weight:600}.modal-actions{display:flex;justify-content:flex-end;gap:.5rem;margin-top:1.5rem}.cancel-button{background:var(--color-bg);color:var(--color-text);padding:.5rem 1rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;font-weight:500;transition:all .2s}.cancel-button:hover{background:var(--color-border)}.save-button{background:var(--color-primary);color:#fff;padding:.5rem 1rem;border:none;border-radius:var(--radius-sm);cursor:pointer;font-weight:500;transition:all .2s}.save-button:hover{filter:brightness(.9)}.save-button:disabled{background:var(--color-text-tertiary);cursor:not-allowed}.admin-section{background:#fff;border-radius:.5rem;padding:1.5rem;box-shadow:0 1px 3px #0000001a}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.section-header h2{font-size:1.125rem;color:#1f2937}.add-button{background:#10b981;color:#fff;padding:.5rem 1rem;border:none;border-radius:.375rem;cursor:pointer;font-size:.875rem}.add-button:hover{background:#059669}.admin-table{width:100%;border-collapse:collapse}.admin-table th,.admin-table td{padding:.75rem;text-align:left;border-bottom:1px solid #e5e7eb}.admin-table th{background:#f9fafb;font-weight:600;font-size:.875rem;color:#374151}.admin-table tr.inactive{opacity:.6}.color-badge{display:inline-block;width:20px;height:20px;border-radius:.25rem}.status-badge{padding:.25rem .5rem;border-radius:9999px;font-size:.75rem;font-weight:500}.status-badge.active{background:#d1fae5;color:#065f46}.status-badge.inactive{background:#fee2e2;color:#991b1b}.actions-cell{display:flex;gap:.5rem}.action-button{background:#6366f1;color:#fff;padding:.25rem .5rem;border:none;border-radius:.25rem;cursor:pointer;font-size:.75rem}.action-button:hover{background:#4f46e5}.delete-button{background:#ef4444;color:#fff;padding:.25rem .5rem;border:none;border-radius:.25rem;cursor:pointer;font-size:.75rem}.delete-button:hover{background:#dc2626}.no-data{text-align:center;color:#6b7280;padding:2rem}.timesheets-container,.approvals-container{min-height:100vh;background:#f3f4f6;padding:2rem}.timesheets-header,.approvals-header{margin-bottom:2rem}.timesheets-header h1,.approvals-header h1{font-size:1.5rem;color:#1f2937;margin-bottom:.5rem}.timesheets-header p,.approvals-header p{color:#6b7280}.current-timesheet-card{background:#fff;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;padding:1.5rem;margin-bottom:2rem}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.card-header h2{font-size:1.125rem;color:#1f2937}.card-body{margin-bottom:1rem}.timesheet-info{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1rem}.info-item{display:flex;flex-direction:column;gap:.25rem}.info-item .label{font-size:.75rem;color:#6b7280;text-transform:uppercase}.info-item .value{font-size:1rem;color:#1f2937}.info-item .value.highlight{font-size:1.25rem;font-weight:600;color:#6366f1}.card-actions{display:flex;gap:.5rem;align-items:center}.action-button.recalculate{background:#f59e0b}.action-button.recalculate:hover{background:#d97706}.action-button.submit{background:#10b981}.action-button.submit:hover{background:#059669}.action-button.approve{background:#10b981}.action-button.approve:hover{background:#059669}.action-button.reject{background:#ef4444}.action-button.reject:hover{background:#dc2626}.action-button.small{padding:.25rem .5rem;font-size:.75rem}.status-message{color:#f59e0b;font-weight:500}.status-message.success{color:#10b981}.status-badge.draft{background:#e5e7eb;color:#374151}.status-badge.submitted{background:#fef3c7;color:#92400e}.status-badge.approved{background:#d1fae5;color:#065f46}.status-badge.rejected{background:#fee2e2;color:#991b1b}.comments-section{border-top:1px solid #e5e7eb;padding-top:1rem}.comments-section h3{font-size:.875rem;color:#374151;margin-bottom:.75rem}.comment{background:#f9fafb;padding:.75rem;border-radius:.375rem;margin-bottom:.5rem}.comment-header{display:flex;justify-content:space-between;margin-bottom:.25rem}.comment-author{font-weight:500;font-size:.875rem;color:#374151}.comment-date{font-size:.75rem;color:#6b7280}.comment-content{font-size:.875rem;color:#1f2937}.filter-section{margin-bottom:1.5rem;display:flex;align-items:center;gap:.5rem}.filter-section label{font-size:.875rem;color:#374151}.filter-section select{padding:.5rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:.875rem}.timesheets-history{background:#fff;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;padding:1.5rem}.timesheets-history h2{font-size:1.125rem;color:#1f2937;margin-bottom:1rem}.timesheets-table{width:100%;border-collapse:collapse}.timesheets-table th,.timesheets-table td{padding:.75rem;text-align:left;border-bottom:1px solid #e5e7eb}.timesheets-table th{background:#f9fafb;font-weight:600;font-size:.875rem;color:#374151}.timesheets-table .hours-cell{font-weight:600;color:#6366f1}.stats-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin-bottom:2rem}.stat-card{background:#fff;padding:1.5rem;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;text-align:center}.stat-card.pending{border-left:4px solid #f59e0b}.stat-card.approved{border-left:4px solid #10b981}.stat-card.rejected{border-left:4px solid #ef4444}.stat-card.draft{border-left:4px solid #9ca3af}.stat-number{font-size:2rem;font-weight:600;color:#1f2937}.stat-label{font-size:.875rem;color:#6b7280;margin-top:.25rem}.pending-section{background:#fff;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;padding:1.5rem}.pending-section h2{font-size:1.125rem;color:#1f2937;margin-bottom:1rem}.pending-list{display:flex;flex-direction:column;gap:1rem}.pending-card{border:1px solid #e5e7eb;border-radius:.5rem;padding:1rem}.pending-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.user-info{display:flex;flex-direction:column}.user-name{font-weight:600;color:#1f2937}.user-email{font-size:.75rem;color:#6b7280}.timesheet-hours{font-size:1.5rem;font-weight:600;color:#6366f1}.pending-card-body{margin-bottom:1rem}.info-row{display:flex;gap:.5rem;margin-bottom:.25rem}.info-row .label{font-size:.875rem;color:#6b7280}.info-row .value{font-size:.875rem;color:#1f2937}.pending-card-actions{display:flex;justify-content:space-between;align-items:center}.approve-section{display:flex;gap:.5rem;flex:1;margin-right:.5rem}.comment-input{flex:1;padding:.5rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:.875rem}.error-container{text-align:center;padding:4rem 2rem}.error-container h2{color:#dc2626;margin-bottom:1rem}.stats-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2rem;padding:0 2rem}.stat-card{background:#fff;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;padding:1.5rem;text-align:center}.stat-card h3{font-size:.875rem;color:#6b7280;margin-bottom:.5rem;text-transform:uppercase}.stat-value{font-size:2rem;font-weight:700;color:#6366f1}.tab-navigation{display:flex;gap:0;margin:0 2rem 1rem;border-bottom:2px solid #e5e7eb}.tab-button{padding:.75rem 1.5rem;background:none;border:none;font-size:1rem;font-weight:500;color:#6b7280;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .2s}.tab-button:hover{color:#6366f1}.tab-button.active{color:#6366f1;border-bottom-color:#6366f1}.role-badge{display:inline-block;padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:600;text-transform:uppercase}.role-admin{background:#fef3c7;color:#92400e}.role-manager{background:#dbeafe;color:#1e40af}.role-user{background:#d1fae5;color:#065f46}.you-badge{font-size:.75rem;color:#6366f1;font-weight:600}.current-user{background:#fef3c7}.form-hint{display:block;font-size:.75rem;color:#f59e0b;margin-top:.25rem}.loading{text-align:center;padding:2rem;color:#6b7280}.type-badge{display:inline-block;padding:.25rem .5rem;border-radius:.25rem;font-size:.7rem;font-weight:600;white-space:nowrap}.type-billable{background:#dcfce7;color:#166534}.type-non-billable{background:#fef9c3;color:#854d0e}.type-internal{background:#dbeafe;color:#1e40af}.type-rd{background:#f3e8ff;color:#7c3aed}.type-training{background:#fce7f3;color:#be185d}.type-overhead{background:#f3f4f6;color:#4b5563}.client-code,.project-code{font-family:Courier New,monospace;font-size:.8rem;font-weight:600;background:#f3f4f6;padding:.125rem .375rem;border-radius:.25rem;color:#374151}.client-ref{font-size:.8rem;color:#6b7280}.project-desc{font-size:.75rem;color:#6b7280;margin-top:.25rem}.project-dates{font-size:.75rem;color:#6b7280}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1rem}.modal-large{max-width:700px}.project-header-row{background:#fff}.entry-detail-row{background:#f9fafb;font-size:.8rem}.entry-detail-row:hover{background:#f3f4f6}.entry-detail-cell{text-align:left!important;padding-left:2rem!important}.entry-info{display:flex;flex-direction:column;gap:.25rem}.entry-location{font-weight:600;font-size:.75rem;color:#6366f1;background:#ede9fe;padding:.125rem .5rem;border-radius:.25rem;display:inline-block;width:fit-content}.entry-comment{font-size:.75rem;color:#6b7280;font-style:italic;max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.entry-hours-cell{text-align:center;vertical-align:middle}.entry-hours{display:inline-flex;align-items:center;gap:.5rem;font-size:.8rem;color:#6366f1}.delete-entry-btn{background:#ef4444;color:#fff;border:none;border-radius:50%;width:18px;height:18px;font-size:.75rem;line-height:1;cursor:pointer;padding:0;display:inline-flex;align-items:center;justify-content:center}.delete-entry-btn:hover{background:#dc2626}.entry-total-cell{background:#f3f4f6;font-size:.8rem;color:#6b7280}.cell-content{display:flex;flex-direction:column;align-items:center;gap:.125rem}.hours-value{font-weight:600}.entry-count{font-size:.65rem;color:#9ca3af}.absence-row{background:#fff7ed}.absence-cell{position:relative}.has-absence{cursor:default!important}.absence-badge{font-size:.65rem;font-weight:600;padding:.125rem .25rem;border-radius:.25rem}.work-location-row{background:#fefce8!important}.work-location-row td{background:#fefce8;padding:.5rem!important}.location-label{text-align:right!important;font-weight:600;font-size:.85rem;color:#374151}.location-cell{text-align:center}.location-badge{display:inline-block;padding:.25rem .5rem;border-radius:.25rem;font-size:.7rem;font-weight:600;border:1px solid;white-space:nowrap}.location-summary{background:#fefce8!important;color:#9ca3af}.add-absence-button{background:var(--color-warning);color:#fff;padding:.5rem 1rem;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:.8125rem;font-weight:500;transition:all .2s}.add-absence-button:hover{filter:brightness(.9)}.hours-cell.expanded{background:#007aff1a!important;border-bottom:none}.expanded-cell-row{background:var(--color-bg)}.expanded-cell-content{padding:1rem!important;text-align:left!important;background:var(--color-bg);border:1px solid var(--color-border);border-top:none;border-radius:0 0 var(--radius-sm) var(--radius-sm)}.expanded-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:1px solid var(--color-border)}.expanded-header strong{color:var(--color-primary)}.add-entry-btn{background:var(--color-primary);color:#fff;padding:.375rem .75rem;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:.8rem;font-weight:500;transition:all .2s}.add-entry-btn:hover{filter:brightness(.9)}.no-entries{color:#9ca3af;font-style:italic;padding:.5rem}.entries-list{display:flex;flex-direction:column;gap:.75rem}.entry-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:.75rem}.entry-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.entry-location-badge{background:var(--color-bg);color:var(--color-text-secondary);padding:.25rem .5rem;border-radius:var(--radius-sm);font-size:.75rem;font-weight:500}.entry-hours-badge{background:#007aff1a;color:var(--color-primary);padding:.25rem .5rem;border-radius:var(--radius-sm);font-size:.875rem;font-weight:600}.entry-card-body{margin-bottom:.5rem}.entry-description{color:#4b5563;font-size:.875rem;line-height:1.4;margin:0}.entry-card-actions{display:flex;gap:.5rem;justify-content:flex-end}.edit-btn{background:var(--color-bg);color:var(--color-text);padding:.25rem .75rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;font-size:.75rem;font-weight:500;transition:all .2s}.edit-btn:hover{background:var(--color-border)}.delete-btn{background:transparent;color:var(--color-danger);padding:.25rem .75rem;border:1px solid var(--color-danger);border-radius:var(--radius-sm);cursor:pointer;font-size:.75rem;font-weight:500;transition:all .2s}.delete-btn:hover{background:var(--color-danger);color:#fff}.timesheet-status-bar{background:var(--color-surface);border-radius:var(--radius-md);padding:1rem;margin-bottom:1rem;border:1px solid var(--color-border);display:flex;justify-content:space-between;align-items:center}.status-info{display:flex;align-items:center;gap:.75rem}.status-label{font-weight:500;color:#374151}.status-badge-large{padding:.375rem .75rem;border-radius:.375rem;font-weight:600;font-size:.875rem}.locked-message{color:#ef4444;font-weight:500;font-size:.875rem}.status-actions{display:flex;gap:.5rem}.submit-timesheet-btn{background:var(--color-success);color:#fff;padding:.5rem 1rem;border:none;border-radius:var(--radius-sm);cursor:pointer;font-weight:500;font-size:.8125rem;transition:all .2s}.submit-timesheet-btn:hover{filter:brightness(.9)}.submit-timesheet-btn:disabled{background:var(--color-text-tertiary);cursor:not-allowed}.add-absence-button:disabled{background:#9ca3af!important;cursor:not-allowed}.weekly-summary-card{background:#fff;border-radius:.5rem;padding:1.5rem;margin-bottom:1rem;box-shadow:0 1px 3px #0000001a}.summary-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:.75rem;border-bottom:2px solid #e5e7eb}.summary-header h3{margin:0;font-size:1.25rem;color:#1f2937}.incomplete-alert{background:#fef3c7;color:#92400e;padding:.375rem .75rem;border-radius:.375rem;font-size:.875rem;font-weight:600}.progress-section{margin-bottom:1.5rem}.progress-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.progress-label{font-size:.875rem;color:#6b7280}.progress-percentage{font-size:1.125rem;font-weight:700;color:#1f2937}.progress-bar-container{width:100%;height:24px;background:#e5e7eb;border-radius:12px;overflow:hidden;position:relative}.progress-bar-fill{height:100%;transition:width .3s ease,background-color .3s ease;border-radius:12px;display:flex;align-items:center;justify-content:flex-end;padding-right:.5rem}.hours-remaining{display:block;margin-top:.5rem;font-size:.875rem;color:#ef4444;font-weight:500}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem}.stat-card{background:#f9fafb;border:1px solid #e5e7eb;border-radius:.5rem;padding:1rem}.stat-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:1px solid #e5e7eb}.stat-icon{font-size:1.25rem}.stat-title{font-weight:600;color:#374151;font-size:.875rem}.stat-content{display:flex;flex-direction:column;gap:.5rem}.stat-item{display:flex;justify-content:space-between;align-items:center;font-size:.875rem;color:#6b7280}.stat-item.alert{color:#dc2626;font-weight:600}.stat-value{font-weight:700}.stat-summary{margin-top:.5rem;padding-top:.5rem;border-top:1px solid #e5e7eb;text-align:center}.stat-summary small{color:#6b7280;font-size:.75rem;font-weight:500}.stat-empty{font-size:.875rem;color:#9ca3af;font-style:italic}@media (max-width: 768px){.dashboard-header{flex-direction:column;gap:1rem;text-align:center}.week-navigation{flex-direction:column;gap:1rem}.timesheet-table th,.timesheet-table td{padding:.5rem;font-size:.75rem}.day-column{width:60px}.project-column{width:120px}.header-right{flex-wrap:wrap;justify-content:center}.stats-cards{grid-template-columns:repeat(2,1fr)}.pending-card-actions{flex-direction:column;gap:.5rem}.approve-section{flex-direction:column;margin-right:0}}.entries-summary{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid #e5e7eb}.entries-summary h3{font-size:1rem;color:#1f2937;margin-bottom:1rem;font-weight:600}.entries-table{width:100%;border-collapse:collapse;font-size:.875rem}.entries-table thead{background:#f9fafb;border-bottom:2px solid #e5e7eb}.entries-table th{text-align:left;padding:.75rem;font-weight:600;color:#6b7280;font-size:.75rem;text-transform:uppercase}.entries-table td{padding:.75rem;border-bottom:1px solid #e5e7eb;color:#1f2937}.entries-table tbody tr:hover{background:#f9fafb}.project-badge{display:inline-block;padding:.25rem .75rem;border-radius:9999px;color:#fff;font-weight:600;font-size:.75rem}.absence-badge{display:inline-block;padding:.25rem .75rem;border-radius:9999px;background:#ef4444;color:#fff;font-weight:600;font-size:.75rem}.status-badge{display:inline-block;padding:.25rem .5rem;background:#f3f4f6;border-radius:.25rem;font-size:.75rem;color:#6b7280}.description-cell{max-width:300px;white-space:normal;word-wrap:break-word}.no-description{color:#9ca3af;font-style:italic}.no-entries-message{text-align:center;padding:2rem;background:#f9fafb;border-radius:.5rem;margin-top:1rem}.no-entries-message p{margin:.5rem 0;color:#6b7280}.no-entries-message a{color:#6366f1;text-decoration:underline;font-weight:600}.no-entries-message a:hover{color:#4f46e5}.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:2rem}.summary-card{background:#fff;border:1px solid #e5e7eb;border-radius:.5rem;padding:1.5rem;display:flex;align-items:center;gap:1rem;transition:box-shadow .2s}.summary-card:hover{box-shadow:0 4px 6px #0000001a}.summary-icon{font-size:2rem;opacity:.8}.summary-content{flex:1}.summary-value{font-size:1.75rem;font-weight:700;color:#1f2937;line-height:1}.summary-label{font-size:.875rem;color:#6b7280;margin-top:.25rem}.daily-breakdown{margin-top:2rem}.daily-breakdown h4{font-size:1rem;color:#1f2937;margin-bottom:1rem;font-weight:600}.day-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.day-card{background:#fff;border:1px solid #e5e7eb;border-radius:.5rem;overflow:hidden;transition:transform .2s,box-shadow .2s}.day-card:hover{transform:translateY(-2px);box-shadow:0 4px 6px #0000001a}.day-card-header{background:#f9fafb;padding:.75rem 1rem;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #e5e7eb}.day-date{font-weight:600;color:#1f2937;font-size:.875rem}.day-hours{font-weight:700;color:#6366f1;font-size:1rem}.day-card-body{padding:1rem}.day-info{margin-bottom:.75rem}.day-location{font-size:.875rem;color:#6b7280}.day-projects{display:flex;flex-wrap:wrap;gap:.5rem}.mini-project-badge{display:inline-block;padding:.25rem .5rem;background:#6366f1;color:#fff;border-radius:.25rem;font-size:.75rem;font-weight:600}:root{--primary-blue: #2563eb;--primary-blue-hover: #1d4ed8;--success-green: #059669;--warning-orange: #d97706;--danger-red: #dc2626;--info-teal: #0891b2;--gray-50: #f9fafb;--gray-100: #f3f4f6;--gray-200: #e5e7eb;--gray-300: #d1d5db;--gray-400: #9ca3af;--gray-500: #6b7280;--gray-600: #4b5563;--gray-700: #374151;--gray-800: #1f2937;--gray-900: #111827;--sidebar-width: 260px;--sidebar-bg: #1e293b;--sidebar-text: #cbd5e1;--sidebar-text-hover: #ffffff;--sidebar-active: #2563eb}.app-layout{display:flex;min-height:100vh;background:var(--gray-50)}.sidebar{width:var(--sidebar-width);background:var(--sidebar-bg);color:var(--sidebar-text);display:flex;flex-direction:column;position:fixed;left:0;top:0;bottom:0;z-index:100;box-shadow:2px 0 10px #0000001a}.sidebar-header{padding:1.5rem 1.25rem;border-bottom:1px solid rgba(255,255,255,.1)}.logo{display:flex;align-items:center;gap:.75rem}.logo-icon{font-size:1.75rem}.logo-text{font-size:1.25rem;font-weight:700;color:#fff;letter-spacing:-.5px}.sidebar-nav{flex:1;padding:1.5rem .75rem;display:flex;flex-direction:column;gap:.25rem}.nav-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:none;border:none;border-radius:.5rem;color:var(--sidebar-text);font-size:.9375rem;font-weight:500;cursor:pointer;transition:all .2s;text-align:left;width:100%}.nav-item:hover{background:#ffffff14;color:var(--sidebar-text-hover)}.nav-item.active{background:var(--sidebar-active);color:#fff}.nav-icon{font-size:1.25rem;width:24px;text-align:center}.nav-label{flex:1}.sidebar-footer{padding:1rem;border-top:1px solid rgba(255,255,255,.1)}.user-profile{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:#ffffff0d;border-radius:.5rem;margin-bottom:.75rem}.user-avatar{width:40px;height:40px;border-radius:50%;background:var(--primary-blue);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1rem}.user-details{flex:1;min-width:0}.user-name{font-size:.875rem;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{font-size:.75rem;color:var(--sidebar-text);text-transform:uppercase;letter-spacing:.5px}.logout-btn{width:100%;padding:.75rem 1rem;background:#dc26261a;border:1px solid rgba(220,38,38,.3);border-radius:.5rem;color:#fca5a5;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:.5rem}.logout-btn:hover{background:#dc262633;color:#fef2f2}.main-content{margin-left:var(--sidebar-width);flex:1;padding:2rem;min-height:100vh}.page-header{margin-bottom:2rem}.page-title{font-size:2rem;font-weight:700;color:var(--gray-900);margin-bottom:.25rem}.page-subtitle{font-size:1rem;color:var(--gray-500)}.week-navigation{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem;padding:1rem;background:#fff;border-radius:.75rem;box-shadow:0 1px 3px #0000001a}.week-nav-btn{padding:.625rem 1.25rem;background:var(--gray-100);border:1px solid var(--gray-300);border-radius:.5rem;color:var(--gray-700);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.week-nav-btn:hover{background:var(--gray-200);border-color:var(--gray-400)}.add-absence-btn{margin-left:auto;padding:.625rem 1.25rem;background:var(--warning-orange);border:none;border-radius:.5rem;color:#fff;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:.5rem}.add-absence-btn:hover:not(:disabled){background:#b45309;transform:translateY(-1px)}.add-absence-btn:disabled{opacity:.5;cursor:not-allowed}.timesheet-container{background:#fff;border-radius:.75rem;box-shadow:0 1px 3px #0000001a;overflow:hidden}.timesheet-table th{background:var(--gray-50);color:var(--gray-700);border-bottom:2px solid var(--gray-200)}.timesheet-table .project-header-row:hover{background:var(--gray-50)}.hours-cell{background:#fff}.hours-cell:hover{background:var(--gray-50)}.absence-row{background:#fef3c7!important}.absence-row .project-cell{border-left:4px solid var(--warning-orange)!important}.absence-row .total-cell{background:#fef3c7!important;color:var(--warning-orange)!important}.timesheet-status-bar{margin-bottom:1.5rem;padding:1rem;background:#fff;border-radius:.75rem;box-shadow:0 1px 3px #0000001a;display:flex;align-items:center;justify-content:space-between}.status-badge-large{padding:.5rem 1rem;border-radius:.5rem;font-weight:600;font-size:.875rem}.submit-timesheet-btn{background:var(--primary-blue)!important}.submit-timesheet-btn:hover:not(:disabled){background:var(--primary-blue-hover)!important}.add-entry-btn{background:var(--primary-blue)!important;color:#fff!important}.edit-btn{background:var(--info-teal)!important;color:#fff!important}.delete-btn{background:var(--danger-red)!important;color:#fff!important}.save-button{background:var(--primary-blue)!important}.save-button:hover:not(:disabled){background:var(--primary-blue-hover)!important}.dashboard-section{margin-bottom:2rem}.section-title{font-size:1.25rem;font-weight:700;color:var(--gray-900);margin-bottom:1rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.stat-card{background:#fff;border-radius:.75rem;padding:1.5rem;box-shadow:0 1px 3px #0000001a;display:flex;align-items:center;gap:1rem;transition:all .2s}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.stat-icon{font-size:2.5rem;line-height:1}.stat-content{flex:1}.stat-value{font-size:2rem;font-weight:700;line-height:1;margin-bottom:.25rem}.stat-label{font-size:.875rem;color:var(--gray-500);font-weight:500}.stat-card.draft{border-left:4px solid var(--gray-400)}.stat-card.draft .stat-value{color:var(--gray-700)}.stat-card.pending{border-left:4px solid var(--warning-orange)}.stat-card.pending .stat-value{color:var(--warning-orange)}.stat-card.approved{border-left:4px solid var(--success-green)}.stat-card.approved .stat-value{color:var(--success-green)}.stat-card.rejected{border-left:4px solid var(--danger-red)}.stat-card.rejected .stat-value{color:var(--danger-red)}.stat-card.team{border-left:4px solid var(--primary-blue)}.stat-card.team .stat-value{color:var(--primary-blue)}.stat-card.admin-badge{border-left:4px solid #9333ea}.stat-card.admin-badge .stat-value{color:#9333ea}.stat-card.manager-badge{border-left:4px solid #0891b2}.stat-card.manager-badge .stat-value{color:#0891b2}.stat-card.user-badge{border-left:4px solid var(--gray-600)}.stat-card.user-badge .stat-value{color:var(--gray-600)}.quick-actions{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem}.action-card{background:#fff;border-radius:.75rem;padding:1.5rem;box-shadow:0 1px 3px #0000001a;display:flex;align-items:flex-start;gap:1rem;text-decoration:none;color:inherit;transition:all .2s;border:2px solid transparent}.action-card:hover{border-color:var(--primary-blue);transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.action-icon{font-size:2rem;line-height:1}.action-content{flex:1}.action-title{font-size:1rem;font-weight:600;color:var(--gray-900);margin-bottom:.25rem}.action-description{font-size:.875rem;color:var(--gray-500)}.tips-card{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:.75rem;padding:1.5rem;color:#fff;display:flex;gap:1rem}.tips-icon{font-size:2rem;line-height:1}.tips-content h3{font-size:1.125rem;font-weight:700;margin-bottom:.75rem}.tips-content ul{list-style:none;padding:0;margin:0}.tips-content li{padding-left:1.5rem;position:relative;margin-bottom:.5rem;font-size:.9375rem}.tips-content li:before{content:"•";position:absolute;left:.5rem;font-weight:700}.tips-content li:last-child{margin-bottom:0}.mobile-menu-btn{display:none;position:fixed;top:1rem;left:1rem;z-index:200;width:44px;height:44px;border-radius:10px;background:var(--sidebar-bg);border:none;color:#fff;font-size:1.5rem;cursor:pointer;box-shadow:0 2px 10px #0003;align-items:center;justify-content:center}.sidebar-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:90}.sidebar-overlay.active{display:block}.mobile-close-btn{display:none;position:absolute;top:1rem;right:1rem;width:36px;height:36px;border-radius:50%;background:#ffffff1a;border:none;color:#fff;font-size:1.25rem;cursor:pointer;align-items:center;justify-content:center}@media (max-width: 1024px){.main-content{padding:1.5rem}.page-title{font-size:1.5rem}.stats-cards{grid-template-columns:repeat(2,1fr)}.guide-content{max-width:100%!important}}@media (max-width: 768px){.mobile-menu-btn,.mobile-close-btn{display:flex}.sidebar{transform:translate(-100%);transition:transform .3s ease}.sidebar.open{transform:translate(0)}.main-content{margin-left:0;padding:4.5rem 1rem 1rem}.page-header{margin-bottom:1rem}.page-title{font-size:1.25rem}.page-subtitle{font-size:.875rem}.dashboard-header{flex-direction:column;gap:1rem;text-align:center}.header-right{flex-wrap:wrap;justify-content:center;gap:.5rem}.week-navigation{flex-direction:column;gap:.75rem}.week-nav-btn{padding:.5rem .75rem;font-size:.8125rem}.current-week{font-size:.9375rem}.stats-cards{grid-template-columns:1fr;gap:.75rem}.stat-card{padding:1rem}.stat-number{font-size:1.5rem}.timesheet-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:0 -1rem;padding:0 1rem}.timesheet-table{min-width:600px}.timesheet-table th,.timesheet-table td{padding:.5rem .375rem;font-size:.75rem}.day-column{width:55px}.project-column{width:100px}.total-column{width:50px}.time-entry-cell{padding:.25rem;font-size:.75rem}.submit-btn,.btn-primary,.btn-secondary{width:100%;justify-content:center}.action-buttons{flex-direction:column;gap:.5rem}.modal-content{width:95%;max-width:none;margin:1rem;max-height:90vh;overflow-y:auto}.modal-header,.modal-body{padding:1rem}.modal-footer{padding:1rem;flex-direction:column;gap:.5rem}.modal-footer button{width:100%}.form-group{margin-bottom:.75rem}.form-group label{font-size:.8125rem}.form-group input,.form-group select,.form-group textarea{padding:.625rem;font-size:.875rem}.pending-card{padding:1rem}.pending-card-header{flex-direction:column;gap:.5rem;align-items:flex-start}.pending-card-actions{flex-direction:column;gap:.5rem;width:100%}.pending-card-actions button{width:100%}.approve-section{flex-direction:column;margin-right:0;width:100%}.approve-section input{width:100%}.admin-tabs{flex-wrap:wrap;gap:.5rem}.admin-tab{flex:1;min-width:calc(50% - .25rem);text-align:center;padding:.625rem .5rem;font-size:.8125rem}.project-table-wrapper,.user-table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch}.project-table,.user-table{min-width:500px}.login-container{padding:1rem}.login-card{padding:1.5rem}.login-header h1{font-size:1.5rem}.guide-section{padding:1rem!important}.guide-section h2{font-size:1.125rem!important}.entries-table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch}.entries-table{min-width:500px}.absences-table-wrapper,.supervision-table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch}.section-card{padding:1rem;margin-bottom:1rem}.section-title{font-size:1rem}.summary-card{padding:1rem}.stat-summary{flex-direction:column;gap:.5rem}}@media (max-width: 480px){.main-content{padding:4rem .75rem .75rem}.page-title{font-size:1.125rem}.stat-card{padding:.75rem}.stat-number{font-size:1.25rem}.stat-label{font-size:.75rem}.timesheet-table th,.timesheet-table td{padding:.375rem .25rem;font-size:.6875rem}.day-column{width:45px}.project-column{width:80px}.week-nav-btn{padding:.375rem .5rem;font-size:.75rem}.current-week{font-size:.8125rem}.modal-content{margin:.5rem}.modal-header,.modal-body,.modal-footer{padding:.75rem}}
