.loading-spinner-container{gap:15px;padding:20px}.loading-spinner-container,.loading-spinner-fullscreen{align-items:center;display:flex;flex-direction:column;justify-content:center}.loading-spinner-fullscreen{background-color:#f5f5f5;gap:20px;min-height:100vh}.spinner{animation:spin 1s linear infinite;border:3px solid #f3f3f3;border-radius:50%;border-top-color:#667eea}.spinner-small{border-width:2px;height:24px;width:24px}.spinner-medium{border-width:3px;height:40px;width:40px}.spinner-large{border-width:4px;height:60px;width:60px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.loading-message{color:#666;font-size:14px;margin:0;text-align:center}.skeleton{animation:loading 1.5s ease-in-out infinite;background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0 50%,#f0f0f0 75%);background-size:200% 100%;border-radius:4px}@keyframes loading{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-text{height:16px;margin-bottom:8px}.skeleton-title{height:24px;margin-bottom:12px;width:60%}.skeleton-card{height:120px;margin-bottom:16px}.login-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;padding:20px}.login-box{background:#fff;border-radius:10px;box-shadow:0 10px 40px #0003;max-width:400px;padding:40px;width:100%}.login-box h1{color:#333;font-size:24px;margin:0 0 10px;text-align:center}.login-box h2{color:#666;font-size:16px;font-weight:400;margin:0 0 30px;text-align:center}.form-group{margin-bottom:20px}.form-group label{color:#333;display:block;margin-bottom:8px}.form-group input{border-radius:5px;box-sizing:border-box;font-size:16px;padding:12px;width:100%}.form-group input:focus{border-color:#667eea;outline:none}.login-button{background:#667eea;border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:12px;transition:background .3s;width:100%}.login-button:hover:not(:disabled){background:#5568d3}.login-button:disabled{cursor:not-allowed;opacity:.6}.error-message{background:#fee;border-radius:5px;color:#e74c3c;font-size:14px;margin-bottom:15px}.login-info{border-top:1px solid #eee;color:#999;font-size:12px;margin-top:20px;padding-top:20px;text-align:center}@media (max-width:480px){.login-container{padding:15px}.login-box{padding:30px 20px}.login-box h1{font-size:20px}.login-box h2{font-size:14px}.form-group input,.login-button{font-size:16px}}.dashboard{background:#f5f5f5;min-height:100vh}.dashboard-header{background:#fff;box-shadow:0 2px 4px #0000001a;flex-wrap:wrap;justify-content:space-between;padding:20px}.dashboard-header,.dashboard-header .header-logo{align-items:center;display:flex}.dashboard-header .header-logo img.company-logo{height:auto;max-height:50px;max-width:200px;object-fit:contain}.dashboard-header h1{color:#333;display:none;font-size:24px;margin:0}.dashboard-header h1:only-child{display:block}.header-actions{align-items:center;display:flex;gap:15px}.user-info{color:#666;font-weight:500}.user-role{color:#999;font-size:14px;text-transform:uppercase}.logout-button{background:#e74c3c}.logout-button:hover{background:#c0392b}.dashboard-content{margin:0 auto;max-width:1200px;padding:20px}.dashboard-actions{display:flex;flex-wrap:wrap;gap:15px;margin-bottom:30px}.primary-button,.secondary-button{border:none;border-radius:5px;cursor:pointer;font-size:16px;font-weight:600;padding:12px 24px;transition:all .3s}.primary-button{background:#667eea;color:#fff}.primary-button:hover{background:#5568d3}.secondary-button{background:#fff;border:2px solid #667eea;color:#667eea}.secondary-button:hover{background:#f0f0ff}.projects-list h2{color:#333;margin-bottom:20px}.empty-state{color:#999;padding:60px 20px}.project-card{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;margin-bottom:12px;overflow:hidden;transition:box-shadow .2s}.project-card:hover{box-shadow:0 2px 6px #00000026}.project-header-collapsed{align-items:center;border-bottom:1px solid #f0f0f0;cursor:pointer;display:flex;justify-content:space-between;padding:16px 20px;transition:background-color .2s}.project-header-collapsed:hover{background-color:#fafafa}.project-header-content{align-items:center;display:flex;flex:1 1;gap:16px}.project-identifier{display:flex;flex-direction:column;gap:4px}.project-number-primary{color:#1a1a1a;font-size:16px;font-weight:600;line-height:1.2}.project-name-secondary{color:#666;font-size:13px;font-weight:400}.project-summary{color:#888;font-size:13px;margin-left:auto}.project-header-actions{align-items:center;display:flex;gap:12px}.accordion-toggle{color:#999;font-size:12px;text-align:center;-webkit-user-select:none;user-select:none;width:20px}.project-content{background-color:#fafafa;border-top:1px solid #f0f0f0;padding:16px 20px}.tasks-list{display:flex;flex-direction:column;gap:8px}.task-item{align-items:center;background:#fff;border:1px solid #e5e5e5;border-radius:6px;cursor:pointer;display:flex;gap:16px;padding:12px 16px;transition:all .2s}.task-item:hover{background:#f8f9fa;border-color:#d0d0d0;transform:translateX(2px)}.task-status-badge-container{flex-shrink:0}.task-status-badge{border-radius:12px;font-size:11px;font-weight:600;letter-spacing:.5px;padding:5px 12px;text-transform:uppercase;white-space:nowrap}.status-draft{background:#e5e5e5;color:#666}.status-assigned{background:#dbeafe;color:#1e40af}.status-in-progress{background:#fed7aa;color:#9a3412}.status-ready-for-review{background:#cffafe;color:#0e7490}.status-approved{background:#d1fae5;color:#065f46}.status-rejected{background:#fee2e2;color:#991b1b}.status-default{background:#f3f4f6;color:#4b5563}.task-info{display:flex;flex:1 1;flex-direction:column;gap:4px;min-width:0}.task-name{color:#1a1a1a;font-size:14px;font-weight:500}.task-technician{color:#888;font-size:12px;font-weight:400}.no-tasks-message{color:#999;font-size:14px;padding:20px;text-align:center}.project-details-button{background:#007bff;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:13px;font-weight:600;padding:8px 16px;transition:background-color .2s;white-space:nowrap}.project-details-button:hover{background:#0056b3}.create-task-button-primary{background:#28a745;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:13px;font-weight:600;padding:8px 16px;transition:background-color .2s;white-space:nowrap}.create-task-button-primary:hover{background:#218838}.edit-task-button-secondary{background:#007bff;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:12px;font-weight:500;margin-left:auto;padding:6px 14px;transition:all .2s;white-space:nowrap}.edit-task-button-secondary:hover{background:#0056b3}.dashboard-loading{align-items:center;color:#666;display:flex;font-size:18px;justify-content:center;min-height:100vh}@media (max-width:768px){.dashboard-header{align-items:flex-start;flex-direction:column;gap:15px;padding:15px}.header-actions{flex-wrap:wrap;gap:10px;width:100%}.user-info,.user-role{font-size:12px}.dashboard-content{padding:15px}.dashboard-actions{flex-direction:column;gap:10px}.primary-button,.secondary-button{padding:14px 20px;width:100%}.project-header-collapsed{align-items:flex-start;flex-direction:column;gap:12px;padding:12px 15px}.project-header-content{align-items:flex-start;flex-direction:column;gap:8px;width:100%}.project-summary{font-size:12px;margin-left:0}.project-header-actions{flex-wrap:wrap;gap:8px;justify-content:space-between;width:100%}.create-task-button-primary,.project-details-button{flex:1 1;font-size:12px;min-width:120px;padding:8px 12px}.task-item{align-items:flex-start;flex-direction:column;gap:12px;padding:12px}.task-status-badge-container{align-self:flex-start}.edit-task-button-secondary{margin-left:0;margin-top:8px;width:100%}.work-package-item{align-items:flex-start;flex-direction:column}.notifications-container,.wp-info{width:100%}.notifications-container>div{max-width:350px;right:15px;width:calc(100vw - 30px)}}@media (max-width:480px){.dashboard-header .header-logo img.company-logo{max-height:40px;max-width:150px}.dashboard-header h1{font-size:18px}.projects-list h2{font-size:20px}.project-number-primary{font-size:14px}.project-name-secondary{font-size:12px}}.modal-overlay{align-items:center;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.task-detail-modal{background:#fff;border-radius:10px;box-shadow:0 10px 40px #0003;display:flex;flex-direction:column;max-height:90vh;max-width:700px;overflow:hidden;width:100%}.modal-header{align-items:center;background:#f8f9fa;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;padding:20px 24px}.modal-header h2{color:#333;font-size:20px;font-weight:600;margin:0}.modal-close{align-items:center;background:none;border:none;border-radius:4px;color:#666;cursor:pointer;display:flex;font-size:28px;height:32px;justify-content:center;padding:0;transition:all .2s;width:32px}.modal-close:hover{background:#e0e0e0;color:#333}.task-detail-body{flex:1 1;overflow-y:auto;padding:24px}.admin-instructions-section{background:#fff3cd;border:2px solid #ffc107;border-radius:8px;margin-bottom:24px;padding:20px}.admin-instructions-section h3{color:#856404;font-size:18px;font-weight:600;margin:0 0 16px}.admin-instructions-section.no-instructions{background:#f8f9fa;border-color:#dee2e6}.admin-instructions-section.no-instructions p{color:#6c757d;font-style:italic;margin:0}.instruction-block{margin-bottom:16px}.instruction-block:last-child{margin-bottom:0}.instruction-label{color:#856404;font-size:14px;font-weight:600;letter-spacing:.5px;margin-bottom:8px;text-transform:uppercase}.instruction-content{background:#fff;border:1px solid #ffc107;border-radius:4px;color:#333;line-height:1.6;padding:12px;white-space:pre-wrap}.task-info-section{margin-top:0}.task-info-section h3{border-bottom:2px solid #e0e0e0;color:#333;font-size:18px;font-weight:600;margin:0 0 16px;padding-bottom:12px}.info-grid{display:flex;flex-direction:column;gap:12px}.info-row{grid-gap:16px;align-items:start;border-bottom:1px solid #f0f0f0;display:grid;gap:16px;grid-template-columns:160px 1fr;padding:8px 0}.info-row:last-child{border-bottom:none}.info-row.full-width{gap:8px;grid-template-columns:1fr}.info-label{color:#666;font-size:14px;font-weight:600}.info-value{color:#333;font-size:14px;line-height:1.5;word-break:break-word}.rejection-remarks{background:#fff5f5;border-left:3px solid #dc3545;border-radius:4px;color:#dc3545;padding:12px;white-space:pre-wrap}.status-badge{font-weight:600;letter-spacing:.5px;text-transform:uppercase}.status-badge.status-assigned{background-color:#6c757d;color:#fff}.status-badge.status-in-progress-tech{background-color:#007bff;color:#fff}.status-badge.status-ready-for-review{background-color:#17a2b8;color:#fff}.status-badge.status-approved{background-color:#28a745;color:#fff}.status-badge.status-rejected-needs-fix{background-color:#dc3545;color:#fff}.modal-footer{background:#f8f9fa;border-top:1px solid #e0e0e0;display:flex;justify-content:flex-end;padding:16px 24px}.close-button{background:#6c757d;border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:10px 24px;transition:background .3s}.close-button:hover{background:#5a6268}@media (max-width:768px){.task-detail-modal{max-height:95vh;max-width:95%}.info-row{gap:8px;grid-template-columns:1fr}.info-label{font-size:13px}}.technician-dashboard{background:#f5f5f5;min-height:100vh}.technician-dashboard-loading{align-items:center;color:#666;display:flex;font-size:18px;height:100vh;justify-content:center}.technician-dashboard-header{align-items:center;background:#fff;box-shadow:0 2px 4px #0000001a;display:flex;flex-wrap:wrap;gap:15px;justify-content:space-between;padding:15px 20px}.header-left h1{color:#333;font-size:20px;margin:0}.header-left .user-info{color:#666;display:block;font-size:14px;margin-top:5px}.header-right{align-items:center;display:flex;gap:15px}.notifications-container{position:relative}.notifications-button{background:none;border:none;border-radius:5px;cursor:pointer;font-size:24px;padding:5px 10px;position:relative;transition:background .2s}.notifications-button:hover{background:#f0f0f0}.notification-badge{align-items:center;background:#dc3545;border-radius:50%;color:#fff;display:flex;font-size:12px;font-weight:700;height:20px;justify-content:center;position:absolute;right:0;top:0;width:20px}.notifications-dropdown{background:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026;margin-top:10px;max-height:400px;max-width:90vw;overflow:hidden;position:absolute;right:0;top:100%;width:350px;z-index:1000}.notifications-header{align-items:center;border-bottom:1px solid #eee;display:flex;justify-content:space-between;padding:15px}.notifications-header h3{font-size:16px;margin:0}.clear-all-notifications{background:none;border:none;border-radius:4px;color:#007bff;cursor:pointer;font-size:12px;font-weight:500;padding:5px 10px;transition:background .2s}.clear-all-notifications:hover{background:#f0f0f0}.notifications-list{max-height:300px;overflow-y:auto}.notification-item{border-bottom:1px solid #f0f0f0;cursor:pointer;padding:12px 15px;transition:background .2s}.notification-item:hover{background:#f8f9fa}.notification-item.unread{background:#e7f3ff;font-weight:500}.notification-item.read{background:#fff}.notification-message{color:#333;font-size:14px;margin-bottom:5px}.notification-time{color:#666;font-size:12px}.no-notifications{color:#666;font-size:14px;padding:20px;text-align:center}.logout-button{background:#dc3545;border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:14px;padding:8px 16px;transition:background .2s}.logout-button:hover{background:#c82333}.filter-tabs{display:flex;gap:10px;margin-bottom:20px}.filter-tab{background-color:#fff;border:1px solid #ddd;border-radius:4px 4px 0 0;color:#666;cursor:pointer;font-weight:500;padding:10px 20px;transition:all .2s}.filter-tab:hover{background-color:#f8f9fa}.filter-tab.active{background-color:#007bff;border-color:#007bff;color:#fff}.date-picker-container{align-items:center;background-color:#fff;border-radius:4px;display:flex;gap:10px;margin-bottom:20px;padding:10px}.date-picker-container label{color:#333;font-weight:500}.date-picker{border:1px solid #ddd;border-radius:4px;font-size:14px;padding:8px 12px}.activity-log-container{background-color:#fff;border-radius:4px;box-shadow:0 2px 4px #0000001a;overflow-x:auto}.activity-table{border-collapse:collapse;width:100%}.activity-table thead{background-color:#f8f9fa}.activity-table th{border-bottom:2px solid #ddd;color:#333;font-weight:600;padding:12px;text-align:left}.activity-table td{border-bottom:1px solid #eee;padding:12px}.activity-row:hover{background-color:#f8f9fa}.action-badge{border-radius:3px;font-size:12px;font-weight:600;padding:4px 8px;text-transform:uppercase}.action-badge.action-submitted{background-color:#007bff;color:#fff}.action-badge.action-approved{background-color:#28a745;color:#fff}.action-badge.action-rejected{background-color:#dc3545;color:#fff}.action-badge.action-reassigned{background-color:#ffc107;color:#333}.action-badge.action-status_changed{background-color:#6c757d;color:#fff}.technician-dashboard-content{margin:0 auto;max-width:1400px;padding:20px}.empty-state{background:#fff;border-radius:10px;box-shadow:0 2px 4px #0000001a;padding:40px;text-align:center}.empty-state p{color:#666;font-size:16px;margin:10px 0}.work-packages-table{background:#fff;border-radius:10px;box-shadow:0 2px 4px #0000001a;overflow:hidden}.work-packages-table table{border-collapse:collapse;width:100%}.work-packages-table thead{background:#f8f9fa}.work-packages-table th{border-bottom:2px solid #dee2e6;color:#333;font-size:14px;font-weight:600;padding:15px;text-align:left}.work-packages-table td{border-bottom:1px solid #f0f0f0;color:#333;font-size:14px;padding:15px}.work-package-row{cursor:pointer;transition:background .2s}.work-package-row:hover{background:#f8f9fa}.details-button{background:#007bff;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:13px;font-weight:500;padding:6px 14px;transition:background-color .2s}.details-button:hover{background:#0056b3}.task-detail-button{background:#28a745;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:13px;font-weight:500;margin-right:8px;padding:6px 14px;transition:background-color .2s}.task-detail-button:hover{background:#218838}.task-detail-button-small{background:#28a745;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:12px;font-weight:500;margin-right:8px;padding:6px 12px;transition:background-color .2s}.task-detail-button-small:hover{background:#218838}.task-actions{flex-wrap:wrap}.task-badge{border-radius:10px;display:inline-block;font-size:10px;font-weight:600;margin-left:8px;padding:2px 8px;text-transform:uppercase}.badge-overdue,.badge-rejected{background-color:#dc3545;color:#fff}.badge-ready_for_review{background-color:#28a745;color:#fff}.status-badge{border-radius:12px;display:inline-block;font-size:12px;font-weight:500;padding:4px 12px}.status-draft{background:#e9ecef;color:#495057}.status-assigned{background:#fff3cd;color:#856404}.status-in-progress,.status-in-progress-tech{background:#cfe2ff;color:#084298}.status-approved,.status-ready-for-review,.status-submitted{background:#d1e7dd;color:#0f5132}@media (max-width:768px){.technician-dashboard-header{align-items:flex-start;flex-direction:column}.header-right{justify-content:space-between;width:100%}.notifications-dropdown{left:0;max-width:100%;right:0;width:100%}.work-packages-table{overflow-x:auto}.work-packages-table table{min-width:600px}.work-packages-table td,.work-packages-table th{font-size:12px;padding:10px 8px}}.tomorrow-snapshot{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:20px;padding:20px}.tomorrow-snapshot h2{border-bottom:2px solid #007bff;color:#333;font-size:18px;margin:0 0 15px;padding-bottom:10px}.snapshot-list{display:flex;flex-direction:column;gap:12px}.snapshot-item{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:6px;padding:15px}.snapshot-item-main{align-items:center;display:flex;gap:15px;justify-content:space-between}.snapshot-item-info{flex:1 1}.snapshot-item-info strong{color:#333;font-size:15px}.snapshot-item-details{color:#666;display:flex;font-size:13px;gap:10px;margin-top:6px}.snapshot-action{border:none;border-radius:4px;cursor:pointer;font-size:13px;font-weight:500;padding:8px 16px;white-space:nowrap}.snapshot-action.mark-complete{background:#28a745;color:#fff}.snapshot-action.mark-complete:hover{background:#218838}.snapshot-action.continue-report{background:#007bff;color:#fff}.snapshot-action.continue-report:hover{background:#0056b3}.snapshot-action.task-detail{background:#17a2b8;color:#fff}.snapshot-action.task-detail:hover{background:#138496}.snapshot-item-actions{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.open-reports-section{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:20px;padding:20px}.open-reports-section h2{border-bottom:2px solid #ffc107;color:#333;font-size:18px;margin:0 0 15px;padding-bottom:10px}.open-reports-list{display:flex;flex-direction:column;gap:12px}.open-report-item{background:#fffbf0;border:1px solid #e0e0e0;border-radius:6px;padding:15px}.open-report-main{align-items:center;display:flex;gap:15px;justify-content:space-between}.open-report-actions{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.open-report-info{flex:1 1}.open-report-info strong{color:#333;font-size:15px}.open-report-details{align-items:center;color:#666;display:flex;flex-wrap:wrap;font-size:13px;gap:10px;margin-top:6px}.continue-report-btn{background:#007bff;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:13px;font-weight:500;padding:8px 16px;white-space:nowrap}.continue-report-btn:hover{background:#0056b3}.rejection-badge{background:#dc3545;border-radius:3px;color:#fff;cursor:pointer;font-size:11px;font-weight:600;padding:3px 8px}.rejection-badge:hover{background:#c82333}.task-actions{align-items:center;display:flex;gap:8px}.mark-complete-button{background:#28a745;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:12px;font-weight:500;padding:6px 12px}.mark-complete-button:hover{background:#218838}.continue-report-button{background:#007bff;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:12px;font-weight:500;padding:6px 12px}.continue-report-button:hover{background:#0056b3}.change-password-container{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin:20px auto;max-width:500px;padding:20px}.change-password-container h2{color:#333;margin-bottom:20px}.change-password-form{gap:20px}.change-password-form,.form-group{display:flex;flex-direction:column}.form-group{gap:5px}.form-group label{color:#555;font-weight:500}.form-group input{border:1px solid #ddd;border-radius:4px;font-size:14px;padding:10px}.form-group input:disabled{background-color:#f5f5f5;cursor:not-allowed}.form-group small{color:#666;font-size:12px}.error-message{background-color:#fee;border:1px solid #fcc;border-radius:4px;color:#c33;padding:10px}.success-message{background-color:#efe;border:1px solid #cfc;border-radius:4px;color:#3c3;padding:10px}.form-actions{display:flex;gap:10px;justify-content:flex-end}.submit-button{background-color:#007bff;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px}.submit-button:hover:not(:disabled){background-color:#0056b3}.submit-button:disabled{background-color:#ccc;cursor:not-allowed}*{box-sizing:border-box}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}
/*# sourceMappingURL=main.65c609ef.css.map*/