:root{font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,SF Pro Text,Helvetica Neue,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}body{margin:0;min-width:320px;min-height:100vh}a{font-weight:500;color:#1a3a5c;text-decoration:none}a:hover{color:#2c5282;text-decoration:underline}.user-home .hero{text-align:center;margin-bottom:1.5rem}.user-error-card{text-align:center;padding:2rem;background:#fff3e0;color:#e65100;border-radius:10px;border:1px solid #ffe0b2;font-weight:500}.user-dashboard-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-bottom:1.5rem}.dashboard-card{background:var(--surface-color);border-radius:12px;padding:1.5rem;border:1px solid var(--border-light);box-shadow:0 1px 3px #0000000f}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem}.card-header h3{margin:0;font-size:1.125rem;font-weight:600;color:var(--text-primary)}.home-tier-badge{display:inline-block;padding:.25rem .75rem;border-radius:6px;font-size:.75rem;font-weight:700;white-space:nowrap}.points-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-bottom:1rem}.points-item{display:flex;flex-direction:column;align-items:center;padding:.75rem;background:var(--background-color);border-radius:8px}.points-value{font-size:1.75rem;font-weight:700;color:var(--primary-color)}.points-label{font-size:.6875rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em;text-align:center;margin-top:.25rem}.btn-link{background:none;border:none;color:var(--accent-color);font-size:.875rem;font-weight:600;cursor:pointer;padding:0;font-family:inherit}.btn-link:hover{color:var(--primary-color);text-decoration:underline}.entitlements-year{font-size:.8125rem;color:var(--text-muted);font-weight:500;background:var(--background-color);padding:.1875rem .625rem;border-radius:4px}.entitlements-grid{display:flex;flex-direction:column;gap:.875rem;margin-bottom:1rem}.entitlement-item{display:flex;align-items:center;gap:.875rem}.entitlement-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.vacation-icon{background:#e8f5e9;color:#2e7d32}.personal-icon{background:#e3f2fd;color:#1565c0}.sick-icon{background:#fce4ec;color:#c62828}.entitlement-info{display:flex;flex-direction:column}.entitlement-value{font-size:1.5rem;font-weight:700;color:var(--text-primary);line-height:1}.entitlement-label{font-size:.75rem;color:var(--text-muted);margin-top:.125rem}.entitlements-breakdown{border-top:1px solid var(--border-light);padding-top:.875rem;margin-top:.5rem}.entitlements-breakdown h4{font-size:.75rem;text-transform:uppercase;letter-spacing:.03em;color:var(--text-muted);margin:0 0 .5rem}.breakdown-row{display:flex;justify-content:space-between;padding:.25rem 0;font-size:.8125rem}.breakdown-label{color:var(--text-secondary)}.breakdown-value{font-weight:600;color:var(--text-primary)}.calendar-card{margin-bottom:1.5rem}.home-month-nav{display:flex;align-items:center;gap:.5rem}.month-nav-btn{background:none;border:1px solid var(--border-color);border-radius:6px;padding:.25rem;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:all .2s}.month-nav-btn:hover{border-color:var(--accent-color);color:var(--accent-color)}.month-label{font-weight:600;font-size:.9375rem;min-width:140px;text-align:center}.home-calendar-grid{margin-bottom:1rem}.calendar-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:4px}.weekday-label{text-align:center;font-size:.6875rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;padding:.375rem 0}.calendar-days{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.calendar-day{aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;border-radius:8px;position:relative;padding:.25rem;min-height:48px}.calendar-day.empty{background:none}.calendar-day.today{background:var(--accent-color);color:#fff}.calendar-day.today .day-number{color:#fff}.calendar-day.today .day-status-code{color:#ffffffd9}.calendar-day.has-markoff{background:#f5f5f5}.calendar-day.today.has-markoff{background:var(--accent-color)}.day-number{font-size:.8125rem;font-weight:500;color:var(--text-primary)}.day-markoffs{display:flex;gap:2px;margin-top:2px}.markoff-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.day-status-code{font-size:.5625rem;font-weight:700;color:var(--text-muted);margin-top:1px}.calendar-legend{display:flex;flex-wrap:wrap;gap:.75rem;padding:.5rem 0}.legend-item{display:flex;align-items:center;gap:.375rem;font-size:.75rem;color:var(--text-secondary)}.legend-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.calendar-markoff-list{border-top:1px solid var(--border-light);padding-top:1rem;margin-top:.5rem}.calendar-markoff-list h4{font-size:.875rem;font-weight:600;color:var(--text-primary);margin:0 0 .75rem}.markoff-list-item{display:flex;align-items:center;gap:.75rem;padding:.5rem 0;border-bottom:1px solid var(--border-light);font-size:.8125rem}.markoff-list-item:last-child{border-bottom:none}.markoff-date{font-weight:500;color:var(--text-primary);white-space:nowrap}.markoff-status{font-weight:600;white-space:nowrap}.markoff-notes{color:var(--text-muted);font-size:.75rem}@media(max-width:768px){.user-dashboard-grid{grid-template-columns:1fr}.calendar-day{min-height:40px}.markoff-list-item{flex-wrap:wrap;gap:.375rem}}@media(max-width:390px){.dashboard-card{padding:1rem}.points-value{font-size:1.375rem}.entitlement-value{font-size:1.25rem}.calendar-day{min-height:36px;padding:.125rem}.day-number{font-size:.6875rem}.day-status-code{display:none}}.employees-page{padding:1.5rem;max-width:1400px;margin:0 auto;width:100%}.employees-top-bar{margin-bottom:1.25rem}.employees-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.employees-header h1{font-size:1.75rem;font-weight:600;color:var(--text-primary);margin:0}.employees-header-controls{display:flex;align-items:center;gap:1rem}.employees-search-input{width:100%;padding:.75rem 1rem;border:1px solid var(--border-color);border-radius:8px;font-size:.9375rem;font-family:inherit;background-color:var(--surface-color);margin-bottom:.875rem}.employees-search-input:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 3px #4a90d926}.department-filter-pills{display:flex;gap:.5rem;flex-wrap:wrap}.dept-pill{display:flex;align-items:center;gap:.5rem;padding:.4375rem .875rem;border:1px solid var(--border-color);border-radius:999px;background:var(--surface-color);cursor:pointer;font-size:.8125rem;font-weight:500;color:var(--text-secondary);transition:all .2s;white-space:nowrap}.dept-pill:hover{border-color:var(--accent-color);color:var(--primary-color)}.dept-pill.active{background:var(--accent-color);border-color:var(--accent-color);color:#fff}.dept-pill-count{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 .375rem;border-radius:10px;font-size:.6875rem;font-weight:700;background:#0000001a;color:inherit}.dept-pill.active .dept-pill-count{background:#ffffff40}.toggle-label{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--text-secondary);cursor:pointer}.toggle-input{display:none}.toggle-slider{position:relative;width:44px;height:24px;background-color:var(--border-color);border-radius:12px;transition:background-color .2s}.toggle-slider:after{content:"";position:absolute;top:2px;left:2px;width:20px;height:20px;background-color:#fff;border-radius:50%;transition:transform .2s;box-shadow:0 2px 4px #0003}.toggle-input:checked+.toggle-slider{background-color:var(--primary-color)}.toggle-input:checked+.toggle-slider:after{transform:translate(20px)}.sort-button{display:flex;align-items:center;gap:.375rem;padding:.5rem .75rem;border:1px solid var(--border-color);border-radius:6px;background-color:transparent;color:var(--text-secondary);font-size:.8125rem;cursor:pointer;transition:all .2s}.sort-button:hover{background-color:var(--background-color);border-color:var(--text-muted)}.sort-icon{font-size:.75rem}.employees-content{background-color:var(--surface-color);border-radius:12px;overflow:hidden;border:1px solid var(--border-color);min-height:calc(100vh - 340px)}.employees-list-section{width:100%;display:flex;flex-direction:column}.employee-detail-view{background-color:var(--surface-color);border-radius:12px;overflow:hidden;border:1px solid var(--border-color)}.back-to-list-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background:var(--background-color);border:none;border-bottom:1px solid var(--border-light);cursor:pointer;font-size:.875rem;font-weight:500;color:var(--primary-color);transition:background .15s ease;width:100%;text-align:left;font-family:inherit}.back-to-list-btn:hover{background-color:var(--border-light)}.edit-form-title{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin:0 0 1.25rem}.employees-list-count{padding:.625rem 1rem;font-size:.8125rem;font-weight:500;color:var(--text-muted);background-color:var(--background-color);border-bottom:1px solid var(--border-light)}.employees-list{flex:1;overflow-y:auto}.employee-list-item{display:flex;align-items:center;gap:.875rem;padding:.75rem 1rem;border-bottom:1px solid var(--border-light);cursor:pointer;transition:background-color .15s}.employee-list-item:hover{background-color:#4a90d90f}.employee-list-item.selected{background-color:#4a90d91a;border-left:3px solid var(--primary-color);padding-left:calc(1rem - 3px)}.employee-avatar{flex-shrink:0}.employee-avatar img,.avatar-placeholder{width:40px;height:40px;border-radius:50%;object-fit:cover}.avatar-placeholder{display:flex;align-items:center;justify-content:center;background-color:var(--background-color);color:var(--text-muted)}.avatar-placeholder svg{width:24px;height:24px}.avatar-placeholder.large{width:80px;height:80px}.avatar-placeholder.large svg{width:48px;height:48px}.employee-info{flex:1;min-width:0}.employee-name{font-weight:500;color:var(--text-primary);font-size:.9375rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.employee-meta{display:flex;align-items:center;gap:.5rem;margin-top:.125rem}.employee-craft{font-size:.8125rem;color:var(--text-muted)}.employee-dept{font-size:.75rem;color:var(--text-secondary);background:var(--background-color);padding:.0625rem .5rem;border-radius:999px}.no-employees{padding:2rem;text-align:center;color:var(--text-muted);font-style:italic}.employee-header{display:flex;align-items:center;gap:1.25rem;padding:1.5rem 2rem;border-bottom:1px solid var(--border-light);background-color:var(--surface-color)}.header-avatar-container{position:relative}.header-avatar img,.header-avatar .avatar-placeholder{width:80px;height:80px;border-radius:50%;object-fit:cover}.avatar-actions{display:flex;gap:.25rem;margin-top:.5rem;justify-content:center}.avatar-upload-btn,.avatar-delete-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;border-radius:50%;cursor:pointer;transition:all .2s}.avatar-upload-btn{background-color:var(--primary-color);color:#fff}.avatar-upload-btn:hover{background-color:var(--primary-dark)}.avatar-upload-btn svg,.avatar-delete-btn svg{width:16px;height:16px}.avatar-delete-btn{background-color:var(--error-light);color:var(--error-color)}.avatar-delete-btn:hover{background-color:var(--error-color);color:#fff}.avatar-upload-btn:disabled,.avatar-delete-btn:disabled{opacity:.5;cursor:not-allowed}.header-info h2{font-size:1.5rem;font-weight:600;color:var(--text-primary);margin:0}.detail-tabs{display:flex;border-bottom:1px solid var(--border-light);padding:0 2rem;background-color:var(--surface-color)}.tab-button{padding:1rem 1.5rem;border:none;background:transparent;font-size:.9375rem;font-weight:500;color:var(--text-secondary);cursor:pointer;position:relative;transition:color .2s}.tab-button:hover,.tab-button.active{color:var(--primary-color)}.tab-button.active:after{content:"";position:absolute;bottom:-1px;left:0;right:0;height:3px;background-color:var(--primary-color);border-radius:3px 3px 0 0}.tab-content{flex:1;overflow-y:auto;padding:1.5rem 2rem}.overview-content{display:flex;flex-direction:column;gap:2rem}.overview-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}.overview-item{display:flex;flex-direction:column;gap:.375rem}.overview-item label{font-size:.75rem;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em}.overview-value{font-size:1rem;color:var(--text-primary);display:flex;align-items:center;gap:.5rem}.edit-icon-btn{background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:.25rem;font-size:.875rem;opacity:.6;transition:opacity .2s}.edit-icon-btn:hover{opacity:1;color:var(--primary-color)}.seniority-section{border-top:1px solid var(--border-light);padding-top:1.5rem}.seniority-section h3{font-size:.875rem;font-weight:600;color:var(--text-secondary);margin-bottom:1rem}.seniority-list{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.seniority-row{display:flex;gap:2rem;padding:.75rem 1rem;background-color:var(--background-color);border-radius:8px;font-size:.9375rem}.seniority-craft{font-weight:500;color:var(--text-primary);min-width:120px}.seniority-date{color:var(--text-secondary)}.seniority-rank{color:var(--text-muted)}.seniority-actions{display:flex;gap:.5rem;margin-left:auto}.no-data-text{color:var(--text-muted);font-style:italic;font-size:.875rem;margin-bottom:1rem}.details-content{max-width:800px}.details-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem;margin-bottom:1.5rem}.detail-item{display:flex;flex-direction:column;gap:.25rem}.detail-item label{font-size:.75rem;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em}.detail-item span{font-size:.9375rem;color:var(--text-primary)}.details-view,.edit-form{display:flex;flex-direction:column;gap:1.5rem}.edit-form .form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.tab-actions{margin-bottom:1.5rem}.certifications-content,.certifications-list{display:flex;flex-direction:column;gap:1rem}.certification-card{background-color:var(--background-color);border-radius:10px;padding:1.25rem;border:1px solid var(--border-light)}.cert-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.cert-header h4{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0}.cert-status{font-size:.75rem;font-weight:600;padding:.25rem .625rem;border-radius:4px;text-transform:uppercase}.cert-status.active{background-color:var(--success-light);color:var(--success-color)}.cert-status.expired{background-color:var(--error-light);color:var(--error-color)}.cert-status.pending{background-color:var(--warning-light);color:var(--warning-color)}.cert-status.revoked{background-color:var(--error-light);color:var(--error-color)}.cert-details{display:flex;flex-wrap:wrap;gap:1.5rem;margin-bottom:.75rem}.cert-detail{display:flex;gap:.375rem;font-size:.875rem}.cert-detail label{color:var(--text-muted)}.cert-detail span{color:var(--text-primary)}.cert-detail span.expired{color:var(--error-color);font-weight:500}.cert-actions{display:flex;gap:.5rem;margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--border-light)}.discipline-content,.discipline-list{display:flex;flex-direction:column;gap:1rem}.discipline-card{background-color:var(--background-color);border-radius:10px;padding:1.25rem;border:1px solid var(--border-light);border-left:4px solid var(--warning-color)}.discipline-card.expired{opacity:.7;border-left-color:var(--text-muted)}.disc-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.disc-header h4{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0}.disc-status{font-size:.75rem;font-weight:600;padding:.25rem .625rem;border-radius:4px;text-transform:uppercase}.disc-status.active{background-color:var(--warning-light);color:var(--warning-color)}.disc-status.expired{background-color:var(--background-color);color:var(--text-muted)}.disc-details{display:flex;flex-wrap:wrap;gap:1.5rem;margin-bottom:.75rem}.disc-detail{display:flex;gap:.375rem;font-size:.875rem}.disc-detail label{color:var(--text-muted)}.disc-detail span{color:var(--text-primary)}.disc-description{font-size:.875rem;color:var(--text-secondary);line-height:1.5;padding:.75rem;background-color:var(--surface-color);border-radius:6px}.disc-description p{margin:0}.disc-actions{display:flex;gap:.5rem;margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--border-light)}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background-color:var(--surface-color);border-radius:12px;padding:1.5rem;width:90%;max-width:480px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.modal-content.modal-large{max-width:640px}.modal-content h3{margin:0 0 1.5rem;font-size:1.25rem;font-weight:600;color:var(--primary-color)}.modal-subtitle{margin:-1rem 0 1.5rem;font-size:.9375rem;color:var(--text-secondary);font-weight:500}.modal-content .form-group{margin-bottom:1rem}.modal-content .form-group label{display:block;margin-bottom:.375rem;font-size:.8125rem;font-weight:600;color:var(--text-secondary)}.modal-content .form-group input,.modal-content .form-group select,.modal-content .form-group textarea{width:100%;padding:.625rem .875rem;border:1px solid var(--border-color);border-radius:8px;font-size:.9375rem;font-family:inherit}.modal-content .form-group textarea{resize:vertical}.modal-content .form-group input:focus,.modal-content .form-group select:focus,.modal-content .form-group textarea:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 3px #4a90d926}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.modal-actions{display:flex;gap:.75rem;margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--border-light)}.attendance-tab-content{display:flex;flex-direction:column;gap:1.5rem}.attendance-summary-card{background:var(--surface-color);border:1px solid var(--border-color);border-radius:8px;padding:1.25rem}.summary-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.summary-header h3{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0}.summary-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}.summary-stat{display:flex;flex-direction:column;align-items:center;padding:.75rem;background:var(--background-color);border-radius:6px}.summary-stat .stat-value{font-size:1.5rem;font-weight:700;color:var(--text-primary)}.summary-stat .stat-label{font-size:.75rem;color:var(--text-secondary);margin-top:.25rem;text-align:center}.attendance-section{background:var(--surface-color);border:1px solid var(--border-color);border-radius:8px;padding:1.25rem}.attendance-section h3{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0 0 1rem}.attendance-tab-content .attendance-table-container{overflow-x:auto}.attendance-tab-content .attendance-table{width:100%;border-collapse:collapse;font-size:.85rem}.attendance-tab-content .attendance-table th{background:var(--primary-dark);color:#fff;padding:.5rem .75rem;text-align:left;font-weight:600;white-space:nowrap}.attendance-tab-content .attendance-table td{padding:.5rem .75rem;border-bottom:1px solid var(--border-light)}.points-negative{color:var(--error-color);font-weight:600}.points-positive{color:var(--success-color);font-weight:600}@media(max-width:1024px){.employees-page{padding:1rem}.employees-header h1{font-size:1.5rem}.overview-grid,.details-grid{grid-template-columns:1fr}}@media(max-width:768px){.employees-page{padding:.75rem}.employees-header{flex-direction:column;align-items:flex-start;gap:.75rem;margin-bottom:.75rem}.employees-header h1{font-size:1.375rem}.employees-header-controls{width:100%;justify-content:space-between}.employees-search-input{font-size:16px;padding:.625rem .75rem;margin-bottom:.625rem}.department-filter-pills{overflow-x:auto;-webkit-overflow-scrolling:touch;flex-wrap:nowrap;padding-bottom:2px;gap:.375rem}.dept-pill{flex-shrink:0;padding:.375rem .75rem;font-size:.75rem}.employees-content{border-radius:8px;min-height:auto}.employee-detail-view{border-radius:8px}.employee-list-item{padding:.625rem .75rem}.detail-tabs{padding:0 .75rem;overflow-x:auto;-webkit-overflow-scrolling:touch;flex-wrap:nowrap}.tab-button{padding:.625rem .75rem;font-size:.8rem;flex-shrink:0;white-space:nowrap}.tab-content,.employee-header{padding:.75rem}.header-info h2{font-size:1.125rem}.header-avatar img,.header-avatar .avatar-placeholder{width:50px;height:50px}.form-row,.form-grid{grid-template-columns:1fr}.modal-overlay{padding:2rem .5rem .5rem;align-items:flex-start}.modal-content{width:95%;max-width:100%;max-height:85vh}.modal-content.modal-large{max-width:100%}.modal-actions{flex-direction:column}.modal-actions button{width:100%;text-align:center}.summary-stats{grid-template-columns:repeat(2,1fr)}.attendance-tab-content .attendance-table th,.attendance-tab-content .attendance-table td{padding:.375rem .5rem;font-size:.8rem}.attendance-summary-card,.attendance-section{padding:.75rem}}@media(max-width:390px){.employees-page{padding:.5rem}.employees-header h1{font-size:1.125rem}.dept-pill{padding:.25rem .5rem;font-size:.7rem}.dept-pill-count{min-width:16px;height:16px;font-size:.6rem}.employee-list-item{padding:.5rem .625rem}.employee-name{font-size:.8rem}.employee-craft{font-size:.7rem}.employee-dept{font-size:.65rem}.tab-button{padding:.5rem .625rem;font-size:.75rem}.header-info h2{font-size:1rem}.header-avatar img,.header-avatar .avatar-placeholder{width:40px;height:40px}.overview-item label{font-size:.7rem}.overview-value{font-size:.8rem}.summary-stats{grid-template-columns:1fr 1fr;gap:.5rem}.summary-stat .stat-value{font-size:1.25rem}.summary-stat .stat-label{font-size:.65rem}}.notifications-page{padding:24px;max-width:1200px;margin:0 auto}.notifications-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px}.notifications-header h1{font-size:1.75rem;font-weight:600;color:var(--primary-color);letter-spacing:-.02em;margin:0}.role-badge{background-color:var(--background-color);color:var(--text-muted);padding:6px 14px;border-radius:6px;font-size:.6875rem;text-transform:uppercase;font-weight:600;letter-spacing:.05em}.categories-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}.category-card{background:var(--surface-color);border-radius:12px;padding:28px;box-shadow:0 2px 8px #1a3a5c0f;cursor:pointer;transition:all .2s ease;border:1px solid var(--border-color)}.category-card:hover{transform:translateY(-4px);box-shadow:0 12px 32px #1a3a5c1f;border-color:var(--accent-color)}.category-icon{display:none}.category-card h3{font-size:1.125rem;font-weight:600;color:var(--primary-color);margin:0 0 8px;letter-spacing:-.01em}.category-description{color:var(--text-secondary);font-size:.875rem;margin:0 0 16px;line-height:1.5}.notification-count{background-color:var(--background-color);color:var(--text-secondary);padding:6px 12px;border-radius:6px;font-size:.75rem;font-weight:600}.besafe-card{border-left:4px solid var(--warning-color)}.besafe-card:hover{border-color:var(--warning-color)}.notification-list-container{background:var(--surface-color);border-radius:12px;box-shadow:0 2px 8px #1a3a5c0f;overflow:hidden;border:1px solid var(--border-color)}.notification-list-header{background:linear-gradient(135deg,var(--primary-color) 0%,var(--primary-dark) 100%);color:#fff;padding:20px 28px;display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap}.back-button{background:#ffffff26;color:#fff;border:none;padding:10px 18px;border-radius:8px;cursor:pointer;font-size:.875rem;font-weight:500;transition:all .2s ease;font-family:inherit}.back-button:hover{background:#ffffff40}.category-title{display:flex;align-items:center;gap:12px;flex:1}.category-icon-large{display:none}.category-title h2{margin:0;font-size:1.375rem;font-weight:600;letter-spacing:-.01em}.add-button{background-color:#fff;color:var(--primary-color);border:none;padding:10px 20px;border-radius:8px;cursor:pointer;font-size:.875rem;font-weight:600;transition:all .2s ease;font-family:inherit}.add-button:hover{background-color:#ffffffe6;box-shadow:0 4px 12px #00000026}.notification-table-container{overflow-x:auto}.notification-table{width:100%;border-collapse:collapse}.notification-table thead{background-color:var(--primary-color);color:#fff}.notification-table th{padding:16px 28px;text-align:left;font-weight:600;font-size:.8125rem;text-transform:uppercase;letter-spacing:.03em}.notification-table th:last-child{text-align:right;width:160px}.notification-table tbody tr{border-bottom:1px solid var(--border-light);transition:background .2s ease}.notification-table tbody tr:hover{background-color:#4a90d90a}.notification-table td{padding:18px 28px}.notification-title-cell{display:flex;flex-direction:column;gap:4px}.notification-number{font-weight:600;color:var(--primary-color);font-size:.9375rem}.notification-title{color:var(--text-secondary);font-size:.875rem}.date-cell{color:var(--text-muted);font-size:.875rem;white-space:nowrap}.actions-cell{text-align:right;display:flex;gap:10px;justify-content:flex-end}.view-button{background-color:var(--accent-color);color:#fff;border:none;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:.8125rem;font-weight:500;transition:all .2s ease;font-family:inherit}.view-button:hover{background-color:var(--primary-light);box-shadow:0 4px 12px #4a90d940}.delete-button{background-color:var(--error-color);color:#fff;border:none;padding:8px 14px;border-radius:6px;cursor:pointer;font-size:.8125rem;font-weight:500;transition:all .2s ease;font-family:inherit}.delete-button:hover{background-color:#b71c1c;box-shadow:0 4px 12px #c6282840}.empty-state{text-align:center;padding:64px 24px;color:var(--text-muted)}.empty-state p{margin-bottom:24px;font-size:1rem}.modal-overlay{position:fixed;inset:0;background-color:#0f254099;display:flex;align-items:center;justify-content:center;z-index:1000;padding:24px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal{background:var(--surface-color);border-radius:16px;width:100%;max-width:560px;max-height:90vh;overflow-y:auto;box-shadow:0 24px 64px #0f25404d}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px 28px;border-bottom:1px solid var(--border-light)}.modal-header h2{margin:0;font-size:1.25rem;font-weight:600;color:var(--primary-color);letter-spacing:-.01em}.close-button{background:none;border:none;font-size:1.75rem;color:var(--text-muted);cursor:pointer;line-height:1;padding:0;transition:color .2s ease}.close-button:hover{color:var(--primary-color)}.modal form{padding:28px}.form-error{background-color:var(--error-light);color:var(--error-color);padding:12px 16px;border-radius:8px;margin-bottom:24px;font-size:.875rem;font-weight:500;border:1px solid rgba(198,40,40,.2)}.form-group{margin-bottom:20px}.form-group small{display:block;color:var(--text-muted);font-size:.75rem;margin-top:6px}.file-info{color:var(--primary-color)!important;font-weight:500}.form-actions{display:flex;gap:12px;justify-content:flex-end;padding-top:24px;border-top:1px solid var(--border-light);margin-top:12px}.cancel-button{background-color:var(--background-color);color:var(--text-primary);border:1px solid var(--border-color);padding:12px 24px;border-radius:8px;cursor:pointer;font-size:.875rem;font-weight:500;transition:all .2s ease;font-family:inherit}.cancel-button:hover{background-color:var(--border-light);border-color:var(--text-muted)}.submit-button{background-color:var(--primary-color);color:#fff;border:none;padding:12px 28px;border-radius:8px;cursor:pointer;font-size:.875rem;font-weight:600;transition:all .2s ease;font-family:inherit}.submit-button:hover{background-color:var(--primary-dark);box-shadow:0 4px 12px #1a3a5c40}.submit-button:disabled{background-color:var(--text-muted);cursor:not-allowed;box-shadow:none}@media(max-width:768px){.notifications-page{padding:12px}.notifications-header{margin-bottom:20px}.notifications-header h1{font-size:1.375rem}.categories-grid{grid-template-columns:1fr;gap:12px}.category-card{padding:20px}.notification-list-header{flex-direction:column;align-items:flex-start;padding:12px 16px;gap:12px}.category-title{order:-1;width:100%}.category-title h2{font-size:1.125rem}.back-button{padding:8px 14px;font-size:.8125rem}.add-button{width:100%;text-align:center}.notification-table th,.notification-table td{padding:12px 14px}.notification-table th:first-child,.notification-table td:first-child{min-width:160px}.form-row{grid-template-columns:1fr}.modal{max-width:100%;width:95%;margin:0 auto;max-height:90vh;border-radius:12px}.modal-overlay{padding:2rem .5rem .5rem;align-items:flex-start}.modal-header{padding:16px 20px}.modal form{padding:20px}.form-actions{flex-direction:column}.cancel-button,.submit-button{width:100%;text-align:center}}@media(max-width:390px){.notifications-page{padding:8px}.notifications-header h1{font-size:1.125rem}.category-card{padding:16px}.category-card h3{font-size:1rem}.notification-table th,.notification-table td{padding:10px 12px;font-size:.8rem}.notification-number{font-size:.8125rem}.notification-title{font-size:.8rem}}.besafe-page{padding:24px;max-width:1400px;margin:0 auto}.besafe-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.besafe-header h1{font-size:1.75rem;font-weight:600;color:var(--primary-color);letter-spacing:-.02em;margin:0}.besafe-toolbar{background:var(--surface-color);border-radius:12px;padding:16px 20px;margin-bottom:20px;display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;border:1px solid var(--border-color);box-shadow:0 2px 8px #1a3a5c0f}.toolbar-left{display:flex;gap:10px}.toolbar-filters{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.btn-new{background-color:var(--primary-color);color:#fff;border:none;padding:10px 20px;border-radius:8px;cursor:pointer;font-size:.875rem;font-weight:600;transition:all .2s ease;font-family:inherit}.btn-new:hover{background-color:var(--primary-dark);box-shadow:0 4px 12px #1a3a5c40}.search-input{padding:8px 14px;border:1px solid var(--border-color);border-radius:8px;font-size:.875rem;font-family:inherit;width:150px;transition:all .2s ease}.search-input:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 3px #4a90d926}.filter-select{padding:8px 12px;border:1px solid var(--border-color);border-radius:8px;font-size:.875rem;font-family:inherit;background-color:var(--surface-color);cursor:pointer;min-width:120px;transition:all .2s ease}.filter-select:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 3px #4a90d926}.btn-reset{background-color:var(--background-color);color:var(--text-primary);border:1px solid var(--border-color);padding:8px 16px;border-radius:8px;cursor:pointer;font-size:.8125rem;font-weight:500;transition:all .2s ease;font-family:inherit}.btn-reset:hover{background-color:var(--border-light);border-color:var(--text-muted)}.besafe-table-container{background:var(--surface-color);border-radius:12px;overflow:hidden;border:1px solid var(--border-color);box-shadow:0 2px 8px #1a3a5c0f}.besafe-table{width:100%;border-collapse:collapse}.besafe-table thead{background-color:var(--primary-color);color:#fff}.besafe-table th{padding:16px 20px;text-align:left;font-weight:600;font-size:.8125rem;text-transform:uppercase;letter-spacing:.03em}.besafe-table th:last-child{text-align:right}.besafe-table tbody tr{border-bottom:1px solid var(--border-light);transition:background .2s ease}.besafe-table tbody tr:hover{background-color:#4a90d90a}.besafe-table td{padding:16px 20px;font-size:.875rem}.id-cell{font-weight:600;color:var(--primary-color);white-space:nowrap}.issue-cell{max-width:300px}.issue-text{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;color:var(--text-primary)}.date-cell{white-space:nowrap;color:var(--text-muted)}.locomotive-tag{color:var(--accent-color);font-weight:500}.status-badge{display:inline-block;padding:6px 12px;border-radius:6px;font-size:.75rem;font-weight:600;letter-spacing:.02em}.actions-cell{text-align:right;display:flex;gap:8px;justify-content:flex-end}.btn-view{background-color:var(--accent-color);color:#fff;border:none;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:.8125rem;font-weight:500;transition:all .2s ease;font-family:inherit}.btn-view:hover{background-color:var(--primary-light);box-shadow:0 4px 12px #4a90d940}.btn-delete{background-color:var(--error-color);color:#fff;border:none;padding:8px 14px;border-radius:6px;cursor:pointer;font-size:.8125rem;font-weight:500;transition:all .2s ease;font-family:inherit}.btn-delete:hover{background-color:#b71c1c;box-shadow:0 4px 12px #c6282840}.no-data{text-align:center;color:var(--text-muted);padding:48px 24px!important;font-style:italic}@media(max-width:768px){.besafe-page{padding:16px}.besafe-toolbar{flex-direction:column;align-items:stretch}.toolbar-left,.toolbar-filters{justify-content:center}.filter-select{min-width:100px}.hide-mobile{display:none}.besafe-table th,.besafe-table td{padding:12px 14px}}.besafe-form-page{padding:24px;max-width:900px;margin:0 auto}.form-header{display:flex;align-items:center;gap:20px;margin-bottom:24px;flex-wrap:wrap}.form-header h1{font-size:1.75rem;font-weight:600;color:var(--primary-color);letter-spacing:-.02em;margin:0;flex:1}.btn-back{background-color:var(--background-color);color:var(--text-primary);border:1px solid var(--border-color);padding:10px 18px;border-radius:8px;cursor:pointer;font-size:.875rem;font-weight:500;transition:all .2s ease;font-family:inherit}.btn-back:hover{background-color:var(--border-light);border-color:var(--text-muted)}.status-badge{display:inline-block;padding:8px 16px;border-radius:8px;font-size:.8125rem;font-weight:600;letter-spacing:.02em}.form-container{background:var(--surface-color);border-radius:12px;padding:32px;border:1px solid var(--border-color);box-shadow:0 2px 8px #1a3a5c0f}.form-container h2{font-size:1.25rem;font-weight:600;color:var(--primary-color);margin:0 0 24px;padding-bottom:12px;border-bottom:1px solid var(--border-light)}.form-group{margin-bottom:24px}.form-group label{display:block;font-weight:600;color:var(--text-secondary);margin-bottom:8px;font-size:.8125rem;letter-spacing:.01em}.form-group input,.form-group select,.form-group textarea{width:100%;padding:12px 16px;border:1px solid var(--border-color);border-radius:8px;font-size:.9375rem;font-family:inherit;transition:all .2s ease;background-color:var(--surface-color)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 3px #4a90d926}.form-group textarea{resize:vertical;min-height:100px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px}.form-actions{display:flex;gap:12px;justify-content:flex-end;padding-top:24px;border-top:1px solid var(--border-light);margin-top:8px}.btn-cancel{background-color:var(--background-color);color:var(--text-primary);border:1px solid var(--border-color);padding:12px 24px;border-radius:8px;cursor:pointer;font-size:.875rem;font-weight:500;transition:all .2s ease;font-family:inherit}.btn-cancel:hover{background-color:var(--border-light);border-color:var(--text-muted)}.btn-submit{background-color:var(--primary-color);color:#fff;border:none;padding:12px 28px;border-radius:8px;cursor:pointer;font-size:.875rem;font-weight:600;transition:all .2s ease;font-family:inherit}.btn-submit:hover{background-color:var(--primary-dark);box-shadow:0 4px 12px #1a3a5c40}.btn-submit:disabled{background-color:var(--text-muted);cursor:not-allowed;box-shadow:none}.detail-section{margin-bottom:32px}.detail-grid{display:flex;flex-direction:column;gap:20px}.detail-row{display:grid;grid-template-columns:1fr 1fr;gap:20px}.detail-item{margin-bottom:0}.detail-item label{display:block;font-weight:600;color:var(--text-muted);margin-bottom:6px;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em}.detail-value{color:var(--text-primary);font-size:.9375rem;margin:0;line-height:1.6}.locomotive-info{color:var(--accent-color);font-weight:500}.action-section{display:flex;justify-content:flex-end;padding-top:24px;border-top:1px solid var(--border-light)}.btn-edit{background-color:var(--accent-color);color:#fff;border:none;padding:12px 24px;border-radius:8px;cursor:pointer;font-size:.875rem;font-weight:600;transition:all .2s ease;font-family:inherit}.btn-edit:hover{background-color:var(--primary-light);box-shadow:0 4px 12px #4a90d940}.edit-section{margin-top:32px;padding-top:32px;border-top:2px solid var(--border-color)}.error-message{background-color:var(--error-light);color:var(--error-color);padding:16px 24px;border-radius:8px;margin-bottom:24px;border:1px solid rgba(198,40,40,.2);font-weight:500}.warning-message{background-color:var(--warning-light);color:var(--warning-color);padding:16px 24px;border-radius:8px;margin-bottom:24px;border:1px solid rgba(245,124,0,.2);font-weight:500}.loading{text-align:center;padding:48px;color:var(--text-muted);font-weight:500}.access-denied{text-align:center;padding:64px 24px}.access-denied h2{color:var(--error-color);font-weight:600;margin-bottom:8px}.access-denied p{color:var(--text-secondary)}@media(max-width:768px){.besafe-form-page{padding:16px}.form-header{flex-direction:column;align-items:flex-start}.form-container{padding:20px}.form-row,.detail-row{grid-template-columns:1fr}}.lineup-page{padding:1.5rem;max-width:1400px;margin:0 auto;width:100%}.lineup-page h1{font-size:1.75rem;font-weight:600;color:var(--text-primary);margin-bottom:1.5rem}.shift-tabs{display:flex;gap:.25rem;margin-bottom:1.5rem;border-bottom:2px solid var(--border-color);padding-bottom:0}.shift-tab{padding:.625rem 1.25rem;border:none;background:none;cursor:pointer;font-size:.9rem;font-weight:500;color:var(--text-secondary);border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .2s}.shift-tab:hover{color:var(--primary-color)}.shift-tab.active{color:var(--primary-color);border-bottom-color:var(--accent-color);font-weight:600}.lineup-table-container{background:var(--surface-color);border-radius:8px;border:1px solid var(--border-color);overflow-x:auto}.lineup-table{width:100%;border-collapse:collapse;font-size:.85rem}.lineup-table th{background:var(--primary-dark);color:#fff;padding:.625rem .75rem;text-align:left;font-weight:600;white-space:nowrap;position:sticky;top:0}.lineup-table td{padding:.5rem .75rem;border-bottom:1px solid var(--border-light);white-space:nowrap}.lineup-table tr:hover{background-color:#f0f4f8}.lineup-table tr:last-child td{border-bottom:none}.yard-group-header td{background:var(--primary-light);color:#fff;font-weight:600;padding:.375rem .75rem;font-size:.8rem;letter-spacing:.025em}.yard-group-header:hover td{background:var(--primary-light)}.off-days-cell{font-family:SF Mono,SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:.8rem;color:var(--text-secondary)}.position-cell{position:relative}.employee-cell{font-size:.825rem;display:flex;align-items:center;justify-content:space-between;gap:.5rem}.employee-name{flex:1}.edit-icon{opacity:.3;display:inline-flex;align-items:center;color:var(--primary-color);flex-shrink:0;transition:opacity .15s}.employee-cell.clickable{cursor:pointer;border-radius:4px;padding:.25rem .5rem;margin:-.25rem -.5rem;transition:background-color .15s;border:1px solid transparent}.employee-cell.clickable:hover{background-color:var(--accent-light);color:var(--primary-dark);border-color:var(--primary-color)}.employee-cell.clickable:hover .edit-icon{opacity:1}.employee-cell.no-bid{color:var(--warning-color);font-weight:600;font-size:.775rem}.employee-cell.vacancy{color:var(--error-color);font-weight:600;font-size:.775rem}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:var(--surface-color);border-radius:12px;padding:1.5rem;width:90%;max-width:550px;max-height:80vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.modal-content h2{font-size:1.25rem;margin-bottom:.25rem;color:var(--text-primary)}.modal-subtitle{font-size:.85rem;color:var(--text-secondary);margin-bottom:1.25rem}.modal-current{background:var(--background-color);padding:.75rem;border-radius:6px;margin-bottom:1rem;font-size:.85rem}.modal-current label{font-weight:600;color:var(--text-secondary);display:block;margin-bottom:.25rem;font-size:.75rem;text-transform:uppercase}.assignment-type-selector{display:flex;gap:.5rem;margin-bottom:1rem}.assignment-type-btn{flex:1;padding:.5rem;border:2px solid var(--border-color);border-radius:6px;background:var(--surface-color);cursor:pointer;font-size:.85rem;font-weight:500;color:var(--text-secondary);transition:all .2s}.assignment-type-btn:hover{border-color:var(--accent-color)}.assignment-type-btn.active{border-color:var(--accent-color);background:#e8f0fe;color:var(--primary-color)}.assignment-type-btn.no-bid-btn.active{border-color:var(--warning-color);background:var(--warning-light);color:var(--warning-color)}.assignment-type-btn.vacancy-btn.active{border-color:var(--error-color);background:var(--error-light);color:var(--error-color)}.employee-search{margin-bottom:1rem}.employee-search input{width:100%;padding:.5rem .75rem;border:1px solid var(--border-color);border-radius:6px;font-size:.9rem;outline:none}.employee-search input:focus{border-color:var(--accent-color);box-shadow:0 0 0 2px #4a90d926}.employee-list{max-height:200px;overflow-y:auto;border:1px solid var(--border-light);border-radius:6px;margin-bottom:1rem}.employee-option{padding:.5rem .75rem;cursor:pointer;display:flex;justify-content:space-between;align-items:center;font-size:.85rem;border-bottom:1px solid var(--border-light)}.employee-option:last-child{border-bottom:none}.employee-option:hover{background:#f0f4f8}.employee-option.selected{background:#e8f0fe;border-color:var(--accent-color)}.employee-option .current-assignment{font-size:.75rem;color:var(--warning-color);font-style:italic}.change-reason{margin-bottom:1rem}.change-reason label{display:block;font-size:.8rem;font-weight:500;color:var(--text-secondary);margin-bottom:.25rem}.change-reason textarea{width:100%;padding:.5rem .75rem;border:1px solid var(--border-color);border-radius:6px;font-size:.85rem;resize:vertical;min-height:60px;font-family:inherit}.duplicate-warning{background:var(--warning-light);border:1px solid var(--warning-color);border-radius:6px;padding:.75rem;margin-bottom:1rem;font-size:.85rem;color:#7a4a00}.modal-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1rem}.modal-actions button{padding:.5rem 1.25rem;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer;border:none;transition:all .2s}.btn-cancel{background:var(--background-color);color:var(--text-secondary);border:1px solid var(--border-color)!important}.btn-cancel:hover{background:#e8edf3}.btn-save{background:var(--accent-color);color:#fff}.btn-save:hover{background:var(--primary-light)}.btn-save:disabled{opacity:.5;cursor:not-allowed}.history-section{margin-top:2rem}.history-toggle{display:flex;align-items:center;gap:.5rem;background:none;border:none;cursor:pointer;font-size:1rem;font-weight:600;color:var(--text-primary);padding:.5rem 0}.history-toggle:hover{color:var(--accent-color)}.history-table{width:100%;border-collapse:collapse;font-size:.825rem;margin-top:.75rem}.history-table th{background:var(--background-color);padding:.5rem .75rem;text-align:left;font-weight:600;color:var(--text-secondary);border-bottom:2px solid var(--border-color)}.history-table td{padding:.5rem .75rem;border-bottom:1px solid var(--border-light)}.history-arrow{color:var(--accent-color);font-weight:600}.lineup-loading{display:flex;align-items:center;justify-content:center;padding:3rem;color:var(--text-secondary);font-size:1rem}.lineup-error{padding:1.5rem;background:var(--error-light);border-radius:8px;color:var(--error-color);text-align:center}.crew-id-col{font-weight:600;color:var(--primary-color)}.start-time-col{color:var(--text-secondary);font-size:.8rem}.department-tabs{display:flex;gap:.5rem;margin-bottom:1.25rem;flex-wrap:wrap}.department-tab{padding:.5rem 1.15rem;border:2px solid var(--border-color);border-radius:999px;background:var(--surface-color);cursor:pointer;font-size:.85rem;font-weight:500;color:var(--text-secondary);transition:all .2s;white-space:nowrap}.department-tab:hover{border-color:var(--accent-color);color:var(--primary-color)}.department-tab.active{background:var(--accent-color);border-color:var(--accent-color);color:#fff;font-weight:600}.lineup-empty{text-align:center;padding:3rem 1.5rem;color:var(--text-secondary)}.lineup-empty h3{font-size:1.1rem;margin-bottom:.5rem;color:var(--text-primary)}.lineup-empty p{font-size:.9rem}@media(max-width:1024px){.lineup-page{padding:1rem}.lineup-page h1{font-size:1.5rem;margin-bottom:1rem}}@media(max-width:768px){.lineup-page{padding:.5rem}.lineup-page h1{font-size:1.25rem;margin-bottom:.75rem}.shift-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;margin-bottom:1rem;gap:0}.shift-tab{padding:.5rem .875rem;font-size:.8rem;flex-shrink:0}.department-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;flex-wrap:nowrap;margin-bottom:1rem;padding-bottom:2px}.department-tab{padding:.375rem .875rem;font-size:.8rem;flex-shrink:0}.lineup-table th,.lineup-table td{padding:.375rem .5rem;font-size:.8rem}.yard-group-header td{padding:.25rem .5rem;font-size:.75rem}.employee-cell{font-size:.775rem}.modal-content{width:95%;max-width:100%;padding:1rem;max-height:90vh}.modal-overlay{padding:2rem .5rem .5rem;align-items:flex-start}.assignment-type-selector{flex-wrap:wrap}.assignment-type-btn{font-size:.8rem;padding:.375rem}.modal-actions{flex-direction:column}.modal-actions button{width:100%;text-align:center}.history-table th,.history-table td{padding:.375rem .5rem;font-size:.775rem}}@media(max-width:390px){.lineup-page h1{font-size:1.125rem}.shift-tab{padding:.375rem .625rem;font-size:.75rem}.lineup-table th,.lineup-table td{padding:.25rem .375rem;font-size:.75rem}.crew-id-col,.start-time-col{font-size:.7rem}}.admin-page{display:flex;height:calc(100vh - 140px);margin:-2rem;background-color:var(--surface-color);border-radius:12px;overflow:hidden;border:1px solid var(--border-color);width:calc(100% + 4rem)}.admin-sidebar{width:280px;min-width:250px;max-width:280px;flex-shrink:0;background-color:var(--primary-dark);color:#fff;display:flex;flex-direction:column}.sidebar-header{padding:1.5rem;border-bottom:1px solid rgba(255,255,255,.1)}.sidebar-header h2{margin:0;font-size:1.25rem;font-weight:600;letter-spacing:-.01em}.sidebar-nav{flex:1;padding:.75rem;display:flex;flex-direction:column;gap:.25rem}.sidebar-item{display:flex;align-items:center;gap:.875rem;width:100%;padding:.875rem 1rem;border:none;border-radius:8px;background-color:transparent;color:#ffffffbf;font-size:.9375rem;font-weight:500;cursor:pointer;transition:all .2s;text-align:left}.sidebar-item:hover{background-color:#ffffff1a;color:#fff}.sidebar-item.active{background-color:#ffffff26;color:#fff}.sidebar-icon{display:flex;align-items:center;justify-content:center;width:24px;height:24px}.sidebar-icon svg{width:20px;height:20px}.sidebar-label{flex:1}.admin-content{flex:1;min-width:0;overflow-y:auto;overflow-x:hidden;background-color:var(--background-color)}.admin-content .page-container{margin:0;padding:1.5rem;width:100%;box-sizing:border-box}.admin-content .table-container{width:100%;overflow:hidden}.admin-content .table-container table{width:100%;table-layout:fixed}.admin-content .table-container th,.admin-content .table-container td{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.admin-content .table-container th:nth-child(1),.admin-content .table-container td:nth-child(1){width:9%}.admin-content .table-container th:nth-child(2),.admin-content .table-container td:nth-child(2){width:14%}.admin-content .table-container th:nth-child(3),.admin-content .table-container td:nth-child(3){width:18%}.admin-content .table-container th:nth-child(4),.admin-content .table-container td:nth-child(4){width:10%}.admin-content .table-container th:nth-child(5),.admin-content .table-container td:nth-child(5){width:10%}.admin-content .table-container th:nth-child(6),.admin-content .table-container td:nth-child(6){width:10%}.admin-content .table-container th:nth-child(7),.admin-content .table-container td:nth-child(7){width:10%}.admin-content .table-container th:nth-child(8),.admin-content .table-container td:nth-child(8){width:8%}.admin-content .table-container th:nth-child(9),.admin-content .table-container td:nth-child(9){width:11%}.admin-content .table-container tr[style*="cursor: pointer"]:hover{background:var(--background-color)}.system-status-page{padding:2rem}.system-status-header{margin-bottom:2rem}.system-status-header h3{font-size:1.5rem;font-weight:600;color:var(--text-primary);margin:0 0 .5rem}.system-status-header p{color:var(--text-muted);font-size:.9375rem;margin:0}.system-status-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}.system-status-card{background-color:var(--surface-color);padding:1.5rem;border-radius:12px;border:1px solid var(--border-color);box-shadow:0 2px 8px #1a3a5c0f}.system-status-card h4{margin:0 0 1rem;color:var(--text-secondary);font-weight:600;font-size:.9375rem}.system-status-indicator{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border-radius:8px}.system-status-icon{font-size:1.125rem;font-weight:600}.system-status-text{text-transform:capitalize;font-weight:500}.system-status-message{margin-top:.75rem;font-size:.8125rem;color:var(--text-secondary)}.coming-soon{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;padding:3rem;text-align:center;color:var(--text-muted)}.coming-soon-icon{width:80px;height:80px;background-color:var(--border-light);border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:1.5rem}.coming-soon-icon svg{width:40px;height:40px;color:var(--text-muted)}.coming-soon h3{font-size:1.5rem;font-weight:600;color:var(--text-primary);margin:0 0 .5rem}.coming-soon p{font-size:1rem;margin:0}.modal-content.employee-modal,.modal-content.crew-edit-modal{max-width:550px;width:90%;padding:0;display:flex;flex-direction:column}.modal-overlay .modal-header{display:flex;justify-content:space-between;align-items:flex-start;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-light);flex-shrink:0}.modal-overlay .modal-header h2{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin:0}.modal-overlay .modal-header .modal-subtitle{font-size:.8125rem;color:var(--text-secondary);margin:.25rem 0 0}.modal-close-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;background:transparent;color:var(--text-muted);cursor:pointer;border-radius:6px;font-size:1rem;transition:all .15s;flex-shrink:0}.employee-modal .modal-body,.crew-edit-modal .modal-body{padding:1.25rem 1.5rem;overflow-y:auto}.modal-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.modal-form-grid .form-group label{display:block;font-size:.8125rem;font-weight:600;color:var(--text-secondary);margin-bottom:.25rem}.modal-form-grid .form-group input,.modal-form-grid .form-group select{width:100%;padding:.5rem .625rem;border:1px solid var(--border-color);border-radius:6px;font-size:.875rem;background:var(--surface-color);color:var(--text-primary);transition:border-color .15s;box-sizing:border-box}.modal-form-grid .form-group input:focus,.modal-form-grid .form-group select:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 2px #4a90d926}.modal-form-grid .form-group input.input-disabled,.modal-form-grid .form-group input:disabled{background:var(--background-color);color:var(--text-muted);cursor:not-allowed}.employee-modal .modal-actions,.crew-edit-modal .modal-actions{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid var(--border-light);flex-shrink:0}.modal-section-label{font-size:.6875rem;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;margin:1.25rem 0 .5rem;padding-bottom:.375rem;border-bottom:1px solid var(--border-light)}.modal-section-label:first-child{margin-top:0}.positions-checkboxes{display:flex;flex-wrap:wrap;gap:1rem;padding:.25rem 0}.positions-checkboxes label{display:flex;align-items:center;gap:.375rem;font-size:.875rem;color:var(--text-primary);cursor:pointer}.offday-row{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin-bottom:.75rem}.offday-row label{display:block;font-size:.8125rem;font-weight:600;color:var(--text-secondary);margin-bottom:.25rem}.offday-row select{width:100%;padding:.5rem .625rem;border:1px solid var(--border-color);border-radius:6px;font-size:.875rem;background:var(--surface-color);color:var(--text-primary);box-sizing:border-box}.offday-row select:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 2px #4a90d926}.success-message{padding:.75rem 1rem;margin-bottom:1rem;border-radius:6px;background:#e8f5e9;color:#2e7d32;border:1px solid #a5d6a7;font-size:.875rem}.data-import-page{padding:2rem}.data-import-header{margin-bottom:2rem}.data-import-header h3{font-size:1.5rem;font-weight:600;color:var(--text-primary);margin:0 0 .5rem}.data-import-header p{color:var(--text-muted);font-size:.9375rem;margin:0}.data-import-sections{display:flex;flex-direction:column;gap:1.5rem}.import-card{background-color:var(--surface-color);padding:1.5rem;border-radius:12px;border:1px solid var(--border-color);box-shadow:0 2px 8px #1a3a5c0f}.import-card-header h4{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin:0 0 .375rem}.import-card-description{font-size:.875rem;color:var(--text-secondary);margin:0 0 1rem;line-height:1.4}.import-card-columns{margin-bottom:1rem;font-size:.8125rem}.import-columns-row{margin-bottom:.375rem}.import-columns-label{font-weight:600;color:var(--text-secondary);margin-right:.375rem}.import-columns-value{color:var(--text-primary);font-family:monospace;font-size:.75rem}.import-columns-value.optional{display:block;margin-top:.25rem;color:var(--text-muted);word-break:break-word}.import-columns-toggle{background:none;border:none;color:var(--accent-color);cursor:pointer;font-size:.8125rem;padding:0;text-decoration:underline}.import-columns-toggle:hover{opacity:.8}.import-card-upload{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.import-card-upload input[type=file]{font-size:.875rem;color:var(--text-primary)}.import-card-buttons{display:flex;gap:.5rem}.import-card-error{margin-top:1rem;padding:.75rem 1rem;border-radius:6px;background:#fef2f2;color:#dc2626;border:1px solid #fecaca;font-size:.875rem;display:flex;align-items:center;gap:.5rem}.import-error-icon{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;background:#dc2626;color:#fff;font-size:.75rem;font-weight:700;flex-shrink:0}.import-card-result{margin-top:1rem}.import-result-summary{display:flex;gap:1rem;padding:.75rem 1rem;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:6px;font-size:.875rem;font-weight:500}.import-result-created{color:#16a34a}.import-result-updated{color:#2563eb}.import-result-errors{color:#dc2626}.import-error-list{margin-top:.75rem;max-height:200px;overflow-y:auto;border:1px solid var(--border-color);border-radius:6px}.import-error-table{width:100%;border-collapse:collapse;font-size:.8125rem}.import-error-table th{background:var(--background-color);padding:.5rem .75rem;text-align:left;font-weight:600;color:var(--text-secondary);position:sticky;top:0}.import-error-table td{padding:.375rem .75rem;border-top:1px solid var(--border-light, var(--border-color));color:var(--text-primary)}.import-error-table td:first-child{width:60px;font-weight:600;color:#dc2626}@media(max-width:900px){.admin-page{flex-direction:column;height:auto;margin:-1.25rem;width:calc(100% + 2.5rem)}.admin-sidebar{width:100%;min-width:auto;max-width:none}.sidebar-header{padding:1rem}.sidebar-nav{flex-direction:row;flex-wrap:wrap;padding:.5rem}.sidebar-item{flex:1;min-width:120px;justify-content:center;padding:.75rem}.sidebar-label{display:none}.admin-content{min-height:500px}}@media(max-width:768px){.admin-page{margin:-.75rem;width:calc(100% + 1.5rem);border-radius:8px}.sidebar-header{padding:.75rem}.sidebar-header h2{font-size:1rem}.sidebar-nav{padding:.375rem;gap:.25rem}.sidebar-item{min-width:60px;padding:.5rem;font-size:.8rem}.sidebar-icon svg{width:16px;height:16px}.admin-content{min-height:400px}.admin-content .page-container{padding:.75rem}.admin-content .table-container{overflow-x:auto}.admin-content .table-container table{table-layout:auto;min-width:600px}}@media(max-width:600px){.modal-content.employee-modal,.modal-content.crew-edit-modal{width:95%;max-width:100%;max-height:90vh}.modal-form-grid,.offday-row{grid-template-columns:1fr}.employee-modal .modal-body,.crew-edit-modal .modal-body,.modal-overlay .modal-header{padding:1rem}.employee-modal .modal-actions,.crew-edit-modal .modal-actions{padding:.75rem 1rem;flex-direction:column}.employee-modal .modal-actions button,.crew-edit-modal .modal-actions button{width:100%;text-align:center}}@media(max-width:390px){.admin-page{margin:-.5rem;width:calc(100% + 1rem)}.sidebar-item{min-width:50px;padding:.375rem}.admin-content .page-container{padding:.5rem}.employee-modal .modal-body,.crew-edit-modal .modal-body{padding:.75rem}.positions-checkboxes{gap:.5rem}}.attendance-page{padding:1.5rem;max-width:1400px;margin:0 auto;width:100%}.attendance-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem;flex-wrap:wrap;gap:1rem}.attendance-header h1{font-size:1.75rem;font-weight:600;color:var(--text-primary);margin:0}.attendance-controls{display:flex;align-items:center;gap:1.25rem}.date-picker{padding:.5rem .75rem;border:1px solid var(--border-color);border-radius:6px;font-size:.9rem;color:var(--text-primary);background:var(--surface-color)}.attendance-stats{display:flex;gap:.75rem}.stat{padding:.375rem .75rem;border-radius:6px;font-size:.8rem;font-weight:600}.stat-available{background:var(--success-light);color:var(--success-color)}.stat-markedoff{background:var(--error-light);color:var(--error-color)}.attendance-toolbar{display:flex;gap:1rem;margin-bottom:1rem;align-items:center;flex-wrap:wrap}.search-input{flex:1;min-width:200px;padding:.5rem .75rem;border:1px solid var(--border-color);border-radius:6px;font-size:.85rem;outline:none}.search-input:focus{border-color:var(--accent-color);box-shadow:0 0 0 2px #4a90d926}.filter-pills{display:flex;gap:.375rem}.filter-pill{padding:.375rem .875rem;border:1px solid var(--border-color);border-radius:999px;background:var(--surface-color);cursor:pointer;font-size:.8rem;font-weight:500;color:var(--text-secondary);transition:all .2s}.filter-pill:hover{border-color:var(--accent-color)}.filter-pill.active{background:var(--accent-color);border-color:var(--accent-color);color:#fff}.attendance-table-container{background:var(--surface-color);border-radius:8px;border:1px solid var(--border-color);overflow-x:auto}.attendance-table{width:100%;border-collapse:collapse;font-size:.85rem}.attendance-table th{background:var(--primary-dark);color:#fff;padding:.625rem .75rem;text-align:left;font-weight:600;white-space:nowrap;position:sticky;top:0}.attendance-table td{padding:.5rem .75rem;border-bottom:1px solid var(--border-light);white-space:nowrap}.attendance-table tr:hover{background-color:#f0f4f8}.attendance-table tr.row-markedoff{background-color:#fff5f5}.attendance-table tr.row-markedoff:hover{background-color:#ffecec}.emp-number{font-weight:600;color:var(--primary-color)}.points-cell{font-weight:600;text-align:center}.status-badge{display:inline-block;padding:.2rem .625rem;border-radius:999px;font-size:.75rem;font-weight:600}.status-available{background:var(--success-light);color:var(--success-color)}.status-markedoff{background:#f3e8ff;color:#7c3aed}.status-markedoff.unexcused{background:var(--error-light);color:var(--error-color)}.tier-badge{display:inline-block;padding:.2rem .5rem;border-radius:4px;font-size:.7rem;font-weight:600;white-space:nowrap}.tier-good{background:var(--success-light);color:var(--success-color)}.tier-advisory{background:var(--warning-light);color:var(--warning-color)}.tier-warning{background:#fff3cd;color:#856404}.tier-final{background:var(--error-light);color:var(--error-color)}.tier-disqualified{background:#1a1a2e;color:#ff6b6b}.action-buttons{display:flex;gap:.375rem;align-items:center}.btn-view{background:transparent;color:var(--primary-color);border:1px solid var(--primary-color);padding:.25rem .75rem;border-radius:4px;font-size:.75rem;font-weight:500;cursor:pointer;transition:all .15s}.btn-view:hover{background:var(--primary-color);color:#fff}.btn-markoff{background:var(--primary-color);color:#fff;border:none;padding:.25rem .75rem;border-radius:4px;font-size:.75rem;cursor:pointer}.btn-markoff:hover{background:var(--primary-light)}.btn-cancel-markoff{background:var(--error-light);color:var(--error-color);border:1px solid var(--error-color);padding:.25rem .75rem;border-radius:4px;font-size:.75rem;cursor:pointer}.btn-cancel-markoff:hover{background:var(--error-color);color:#fff}.markoff-modal{max-width:520px}.markoff-modal .form-group{margin-bottom:1rem}.markoff-modal .form-group label{display:block;font-size:.8rem;font-weight:600;color:var(--text-secondary);margin-bottom:.375rem}.markoff-modal select,.markoff-modal input[type=text],.markoff-modal textarea{width:100%;padding:.5rem .75rem;border:1px solid var(--border-color);border-radius:6px;font-size:.85rem;font-family:inherit;outline:none}.markoff-modal select:focus,.markoff-modal input[type=text]:focus,.markoff-modal textarea:focus{border-color:var(--accent-color);box-shadow:0 0 0 2px #4a90d926}.modifiers-section{background:var(--background-color);border-radius:8px;padding:1rem;margin-bottom:1rem}.section-label{display:block;font-size:.8rem;font-weight:600;color:var(--text-secondary);margin-bottom:.625rem}.modifier-checkboxes{display:flex;flex-direction:column;gap:.5rem}.checkbox-label{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--text-primary);cursor:pointer}.checkbox-label input[type=checkbox]{width:auto;cursor:pointer}.points-preview{margin-top:.75rem;padding-top:.625rem;border-top:1px solid var(--border-color);font-size:.85rem;color:var(--text-secondary)}.points-deduction{color:var(--error-color);font-size:1rem}.form-error{background:var(--error-light);color:var(--error-color);padding:.5rem .75rem;border-radius:6px;font-size:.85rem;margin-bottom:1rem}.attendance-loading{display:flex;align-items:center;justify-content:center;padding:3rem;color:var(--text-secondary);font-size:1rem}.attendance-empty{text-align:center;padding:2rem;color:var(--text-secondary);font-size:.9rem}@media(max-width:1024px){.attendance-page{padding:1rem}.attendance-header h1{font-size:1.5rem}}@media(max-width:768px){.attendance-page{padding:.5rem}.attendance-header{flex-direction:column;align-items:flex-start;gap:.75rem}.attendance-header h1{font-size:1.25rem}.attendance-controls{width:100%;flex-wrap:wrap;gap:.75rem}.date-picker{flex:1;min-width:140px}.attendance-stats{width:100%;justify-content:flex-start}.attendance-toolbar{flex-direction:column;gap:.75rem}.search-input{width:100%;min-width:unset}.filter-pills{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:2px}.filter-pill{flex-shrink:0}.attendance-table .hide-mobile{display:none}.attendance-table th,.attendance-table td{padding:.375rem .5rem;font-size:.8rem}.markoff-modal{max-width:100%;width:95%;margin:.5rem;max-height:90vh}.modal-overlay{padding:2rem .5rem .5rem;align-items:flex-start}.modifiers-section{padding:.75rem}}@media(max-width:390px){.attendance-header h1{font-size:1.125rem}.stat{padding:.25rem .5rem;font-size:.7rem}.attendance-table th,.attendance-table td{padding:.25rem .375rem;font-size:.75rem}.tier-badge{font-size:.6rem;padding:.125rem .375rem}.btn-markoff,.btn-cancel-markoff,.btn-view{padding:.2rem .5rem;font-size:.7rem}.action-buttons{gap:.25rem}}.markoff-calendar-page{padding:1.5rem;max-width:1400px;margin:0 auto;width:100%}.calendar-header{margin-bottom:1.25rem}.calendar-header h1{font-size:1.75rem;font-weight:600;color:var(--text-primary);margin:0 0 1rem}.craft-tabs{display:flex;gap:.5rem;margin-bottom:1rem;flex-wrap:wrap}.craft-tab{padding:.5rem 1.25rem;border:1px solid var(--border-color);border-radius:999px;background:var(--surface-color);cursor:pointer;font-size:.875rem;font-weight:500;font-family:inherit;color:var(--text-secondary);transition:all .2s}.craft-tab:hover{border-color:var(--accent-color);color:var(--primary-color)}.craft-tab.active{background:var(--primary-color);border-color:var(--primary-color);color:#fff}.month-nav{display:flex;align-items:center;gap:.75rem}.month-nav-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:1px solid var(--border-color);border-radius:8px;background:var(--surface-color);cursor:pointer;color:var(--text-secondary);transition:all .15s}.month-nav-btn:hover{background:var(--background-color);border-color:var(--text-muted)}.month-title{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin:0;min-width:180px;text-align:center}.today-btn{padding:.5rem 1rem;border:1px solid var(--border-color);border-radius:8px;background:var(--surface-color);cursor:pointer;font-size:.8125rem;font-weight:500;font-family:inherit;color:var(--text-secondary);transition:all .15s}.today-btn:hover{background:var(--background-color);border-color:var(--text-muted)}.calendar-layout{display:flex;gap:1.5rem;align-items:flex-start}.calendar-grid-container{flex:1;background:var(--surface-color);border:1px solid var(--border-color);border-radius:12px;overflow:hidden}.calendar-day-headers{display:grid;grid-template-columns:repeat(7,1fr);background:var(--primary-dark);color:#fff}.day-header{padding:.625rem;text-align:center;font-size:.75rem;font-weight:600;letter-spacing:.05em}.calendar-days-grid{display:grid;grid-template-columns:repeat(7,1fr)}.calendar-day{min-height:100px;border-right:1px solid var(--border-light);border-bottom:1px solid var(--border-light);padding:.375rem;cursor:pointer;transition:background .15s;position:relative}.calendar-day:nth-child(7n){border-right:none}.calendar-day:hover{background:#4a90d90a}.calendar-day.selected{background:#4a90d914;box-shadow:inset 0 0 0 2px var(--primary-color)}.calendar-day.other-month{background:var(--background-color);opacity:.5}.calendar-day.today .day-number{background:var(--primary-color);color:#fff;border-radius:50%;width:28px;height:28px;display:flex;align-items:center;justify-content:center}.day-number{font-size:.8125rem;font-weight:500;color:var(--text-primary);display:flex;align-items:center;justify-content:flex-end;padding:.125rem .25rem}.day-markoffs{display:flex;flex-direction:column;gap:2px;margin-top:.25rem}.day-markoff-dot{display:flex;align-items:center;padding:1px 4px;border-radius:3px;overflow:hidden}.dot-label{font-size:.625rem;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.day-markoff-more{font-size:.625rem;color:var(--text-muted);padding:1px 4px;font-weight:500}.calendar-side-panel{width:320px;flex-shrink:0;background:var(--surface-color);border:1px solid var(--border-color);border-radius:12px;padding:1.25rem}.calendar-side-panel h3{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0 0 1rem}.select-day-prompt h3{margin-bottom:1rem}.calendar-legend{margin-bottom:1.25rem}.legend-title{font-size:.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em;display:block;margin-bottom:.5rem}.legend-items{display:flex;flex-wrap:wrap;gap:.375rem}.legend-item{display:inline-block;padding:.25rem .625rem;border-radius:4px;font-size:.6875rem;font-weight:600;color:#fff;white-space:nowrap}.day-detail-list{margin-bottom:1rem}.day-detail-list h4{font-size:.875rem;font-weight:600;color:var(--text-secondary);margin:0 0 .75rem}.day-detail-item{padding:.75rem;background:var(--background-color);border-radius:8px;margin-bottom:.5rem}.detail-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.375rem}.detail-emp-name{font-size:.8125rem;font-weight:500;color:var(--text-primary)}.detail-status-badge{font-size:.6875rem;font-weight:700;color:#fff;padding:.125rem .5rem;border-radius:4px}.detail-item-info{display:flex;flex-direction:column;gap:.25rem}.detail-status-name{font-size:.75rem;color:var(--text-secondary)}.detail-notes{font-size:.75rem;color:var(--text-muted);font-style:italic}.cancel-markoff-btn{margin-top:.5rem;padding:.25rem .75rem;border:1px solid var(--error-color);border-radius:4px;background:transparent;color:var(--error-color);font-size:.75rem;font-weight:500;font-family:inherit;cursor:pointer;transition:all .15s}.cancel-markoff-btn:hover{background:var(--error-color);color:#fff}.no-markoffs-text{color:var(--text-muted);font-size:.875rem;font-style:italic;margin-bottom:1rem}.create-markoff-btn{width:100%;padding:.75rem;border:2px dashed var(--border-color);border-radius:8px;background:transparent;color:var(--text-muted);font-size:.875rem;font-weight:500;font-family:inherit;cursor:pointer;transition:all .15s}.create-markoff-btn:hover:not(.disabled){border-color:var(--primary-color);color:var(--primary-color);background:#4a90d90a}.create-markoff-btn.disabled{cursor:not-allowed;opacity:.5}.loading-small{color:var(--text-muted);font-size:.875rem;padding:1rem 0}.markoff-create-modal{background:var(--surface-color);border-radius:12px;width:90%;max-width:800px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.markoff-create-modal .modal-header{display:flex;justify-content:space-between;align-items:flex-start;padding:1.5rem 1.5rem 1rem;border-bottom:1px solid var(--border-light)}.markoff-create-modal .modal-header h2{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin:0}.modal-subtitle{font-size:.8125rem;color:var(--text-secondary);margin:.25rem 0 0}.modal-close-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;background:transparent;color:var(--text-muted);cursor:pointer;border-radius:6px;transition:all .15s}.modal-close-btn:hover{background:var(--background-color);color:var(--text-primary)}.modal-error{padding:.75rem 1.5rem;background:var(--error-light);color:var(--error-color);font-size:.875rem;font-weight:500}.modal-body{display:flex;gap:1.5rem;padding:1.5rem}.modal-left{flex:1}.modal-right{width:280px;flex-shrink:0}.modal-section{margin-bottom:1.25rem}.modal-label{display:block;font-size:.8125rem;font-weight:600;color:var(--primary-color);margin-bottom:.5rem}.modal-search-input{width:100%;padding:.625rem .875rem;border:1px solid var(--border-color);border-radius:8px;font-size:.875rem;font-family:inherit;margin-bottom:.5rem}.modal-search-input:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 3px #4a90d926}.employee-select-list{max-height:180px;overflow-y:auto;border:1px solid var(--border-color);border-radius:8px}.employee-select-item{display:flex;justify-content:space-between;align-items:center;padding:.625rem .75rem;border-bottom:1px solid var(--border-light);font-size:.8125rem;color:var(--text-primary)}.employee-select-item:last-child{border-bottom:none}.employee-select-item.selected{background:#4a90d914}.select-emp-btn{padding:.25rem .75rem;border:1px solid var(--border-color);border-radius:4px;background:var(--surface-color);cursor:pointer;font-size:.75rem;font-family:inherit;color:var(--text-secondary);transition:all .15s}.select-emp-btn:hover,.employee-select-item.selected .select-emp-btn{background:var(--primary-color);border-color:var(--primary-color);color:#fff}.no-employees-text{padding:1rem;text-align:center;color:var(--text-muted);font-size:.8125rem;font-style:italic}.modal-select{width:100%;padding:.625rem .875rem;border:1px solid var(--border-color);border-radius:8px;font-size:.875rem;font-family:inherit;background:var(--surface-color)}.modal-select:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 3px #4a90d926}.modal-date-row{display:flex;gap:1rem}.modal-date-row .modal-section{flex:1}.modal-date-input{width:100%;padding:.625rem .875rem;border:1px solid var(--border-color);border-radius:8px;font-size:.875rem;font-family:inherit}.modal-date-input:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 3px #4a90d926}.modal-textarea{width:100%;padding:.625rem .875rem;border:1px solid var(--border-color);border-radius:8px;font-size:.875rem;font-family:inherit;resize:vertical}.modal-textarea:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 3px #4a90d926}.due-back-time{display:flex;align-items:center;gap:.5rem;margin-top:.75rem}.time-select{padding:.5rem .75rem;border:1px solid var(--border-color);border-radius:8px;font-size:.875rem;font-family:inherit;background:var(--surface-color);min-width:70px}.time-separator{font-size:1.25rem;font-weight:600;color:var(--text-secondary)}.due-back-display{margin-top:.5rem;font-size:.8125rem;color:var(--text-secondary)}.modal-actions{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid var(--border-light)}.modal-cancel-btn{padding:.625rem 1.5rem;border:1px solid var(--border-color);border-radius:8px;background:var(--surface-color);cursor:pointer;font-size:.875rem;font-weight:500;font-family:inherit;color:var(--text-secondary);transition:all .15s}.modal-cancel-btn:hover{background:var(--background-color)}.modal-save-btn{padding:.625rem 1.5rem;border:none;border-radius:8px;background:var(--primary-color);cursor:pointer;font-size:.875rem;font-weight:500;font-family:inherit;color:#fff;transition:all .15s}.modal-save-btn:hover:not(:disabled){background:var(--primary-dark)}.modal-save-btn:disabled{opacity:.5;cursor:not-allowed}@media(max-width:1024px){.markoff-calendar-page{padding:1rem}.calendar-layout{flex-direction:column}.calendar-side-panel{width:100%;order:-1}.calendar-day{min-height:80px}.modal-body{flex-direction:column}.modal-right{width:100%}}@media(max-width:768px){.markoff-calendar-page{padding:.75rem}.calendar-header h1{font-size:1.375rem}.craft-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;flex-wrap:nowrap;gap:.375rem;padding-bottom:2px}.craft-tab{flex-shrink:0;padding:.375rem .875rem;font-size:.8125rem}.month-title{font-size:1rem;min-width:140px}.calendar-day{min-height:60px;padding:.25rem}.day-number{font-size:.75rem}.dot-label{font-size:.5625rem}.day-header{font-size:.625rem;padding:.5rem .25rem}.modal-search-input,.modal-select,.modal-date-input,.modal-textarea{font-size:16px!important}.markoff-create-modal{width:95%;max-height:90vh}.modal-body{padding:1rem}.modal-date-row{flex-direction:column;gap:0}.modal-actions{flex-direction:column}.modal-actions button{width:100%;text-align:center}}@media(max-width:390px){.markoff-calendar-page{padding:.5rem}.calendar-header h1{font-size:1.125rem}.craft-tab{padding:.25rem .625rem;font-size:.75rem}.calendar-day{min-height:48px}.day-number{font-size:.6875rem}.day-markoffs{display:none}.calendar-day.selected .day-markoffs,.calendar-day.today .day-markoffs{display:flex}.month-title{font-size:.875rem;min-width:110px}}.discipline-add-btn{white-space:nowrap}.discipline-cat-badge{display:inline-block;padding:.25rem .625rem;border-radius:6px;font-size:.75rem;font-weight:600;white-space:nowrap;background:var(--accent-color);color:#fff}.discipline-cat-equipment{background:#0dcaf0;color:#333}.discipline-type-badge{display:inline-block;padding:.1875rem .5rem;border-radius:4px;font-size:.75rem;font-weight:600;background:#e9ecef;color:#495057}.flag-badge{display:inline-block;padding:.1875rem .5rem;border-radius:4px;font-size:.75rem;font-weight:600}.flag-yes{background:#dc3545;color:#fff}.flag-no{background:#e9ecef;color:#666}.description-truncate{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;max-width:250px;font-size:.8125rem;color:var(--text-secondary)}.discipline-row-actions{display:flex;gap:.375rem}.discipline-day-display{font-size:.8125rem;color:var(--text-secondary);margin-bottom:1rem;padding:.375rem .75rem;background:var(--background-color);border-radius:6px;display:inline-block}.discipline-modal{max-width:700px;width:95%;padding:0;display:flex;flex-direction:column;max-height:90vh}.discipline-modal .modal-body{padding:1.25rem 1.5rem;overflow-y:auto}.discipline-modal .modal-actions{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid var(--border-light);flex-shrink:0}.modal-form-grid-4{grid-template-columns:1fr 1fr 1fr 1fr!important}.discipline-modal textarea{width:100%;padding:.5rem .625rem;border:1px solid var(--border-color);border-radius:6px;font-size:.875rem;background:var(--surface-color);color:var(--text-primary);font-family:inherit;resize:vertical;box-sizing:border-box}.discipline-modal textarea:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 2px #4a90d926}.employee-selector-section{margin-bottom:1rem}.employee-selector-input{display:flex;gap:.5rem}.employee-selector-input input{flex:1;padding:.5rem .625rem;border:1px solid var(--border-color);border-radius:6px;font-size:.875rem;background:var(--surface-color);color:var(--text-primary)}.employee-selector-input input:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 2px #4a90d926}.selected-employee-tag{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .75rem;margin-top:.5rem;background:#4a90d914;border:1px solid rgba(74,144,217,.25);border-radius:6px;font-size:.8125rem;color:var(--text-primary)}.selected-employee-tag button{display:flex;align-items:center;justify-content:center;width:18px;height:18px;border:none;border-radius:50%;background:transparent;color:var(--text-muted);font-size:1rem;line-height:1;cursor:pointer;padding:0}.selected-employee-tag button:hover{background:#f8d7da;color:#dc3545}@media(max-width:768px){.ehr-header-actions{flex-direction:column;width:100%}.ehr-header-actions .ehr-search-input{width:100%}.discipline-modal{max-width:100%;width:100%;max-height:95vh}.modal-form-grid-3{grid-template-columns:1fr!important}.modal-form-grid-4{grid-template-columns:1fr 1fr!important}.discipline-modal .modal-body{padding:1rem}.discipline-modal .modal-actions{flex-direction:column;padding:.75rem 1rem}.discipline-modal .modal-actions button{width:100%;text-align:center}}.balance-value{font-weight:700;font-size:1rem}.balance-success{color:var(--success-color)}.balance-advisory{color:var(--warning-color)}.balance-warning{color:#e65100}.balance-error{color:var(--error-color)}.balance-critical{color:#b71c1c}.deducted-value{color:var(--error-color);font-weight:600}.tier-badge{display:inline-block;padding:.25rem .625rem;border-radius:6px;font-size:.75rem;font-weight:700;white-space:nowrap}.tier-success{background:#e8f5e9;color:#2e7d32}.tier-advisory{background:#fff3e0;color:#e65100}.tier-warning{background:#fff8e1;color:#f57c00}.tier-error{background:#fce4ec;color:#c62828}.tier-critical{background:#c62828;color:#fff}.ehr-header-controls{display:flex;flex-direction:column;gap:.75rem}.days-filter-pills{display:flex;gap:.5rem}.days-pill{padding:.375rem .875rem;border:1px solid var(--border-color);border-radius:999px;background:var(--surface-color);cursor:pointer;font-size:.8125rem;font-weight:500;color:var(--text-secondary);font-family:inherit;transition:all .2s}.days-pill:hover{border-color:var(--accent-color);color:var(--primary-color)}.days-pill.active{background:var(--accent-color);border-color:var(--accent-color);color:#fff}.days-remaining{display:inline-block;padding:.25rem .625rem;border-radius:6px;font-size:.8125rem;font-weight:700;white-space:nowrap}.urgency-critical{background:#fce4ec;color:#c62828}.urgency-warning{background:#fff3e0;color:#e65100}.urgency-moderate{background:#fff8e1;color:#f57c00}@media(max-width:768px){.days-filter-pills{flex-wrap:wrap}}.ehr-header-actions{display:flex;align-items:center;gap:.75rem}.incident-add-btn{white-space:nowrap}.incident-kpi-cards{display:grid;grid-template-columns:repeat(5,1fr);gap:1rem;margin-bottom:1.25rem}.incident-kpi-card{background:var(--surface-color);border:1px solid var(--border-color);border-radius:10px;padding:1rem 1.25rem;text-align:center;transition:transform .15s,box-shadow .15s}.incident-kpi-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000014}.incident-kpi-value{font-size:2rem;font-weight:700;line-height:1.1;margin-bottom:.25rem}.incident-kpi-label{font-size:.8125rem;color:var(--text-secondary);font-weight:500}.incident-kpi-total{border-left:4px solid var(--accent-color)}.incident-kpi-total .incident-kpi-value{color:var(--accent-color)}.incident-kpi-injury{border-left:4px solid #dc3545}.incident-kpi-injury .incident-kpi-value{color:#dc3545}.incident-kpi-hfi{border-left:4px solid #fd7e14}.incident-kpi-hfi .incident-kpi-value{color:#fd7e14}.incident-kpi-nonhfi{border-left:4px solid #ffc107}.incident-kpi-nonhfi .incident-kpi-value{color:#b38f00}.incident-kpi-crossing{border-left:4px solid #6f42c1}.incident-kpi-crossing .incident-kpi-value{color:#6f42c1}.incident-filters{background:var(--surface-color);border:1px solid var(--border-color);border-radius:10px;padding:1rem;margin-bottom:1.25rem}.incident-filters-row{display:flex;flex-wrap:wrap;align-items:center;gap:.75rem}.incident-filter-search{flex:1;min-width:200px;padding:.5rem .75rem;border:1px solid var(--border-color);border-radius:6px;font-size:.875rem;background:var(--background-color);color:var(--text-primary)}.incident-filter-search:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 2px #4a90d926}.incident-filter-select{padding:.5rem .75rem;border:1px solid var(--border-color);border-radius:6px;font-size:.875rem;background:var(--background-color);color:var(--text-primary);min-width:180px;cursor:pointer}.incident-filter-select-narrow{min-width:110px}.incident-filter-select:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 2px #4a90d926}.incident-filter-date-group{display:flex;align-items:center;gap:.5rem}.incident-filter-date{padding:.5rem .625rem;border:1px solid var(--border-color);border-radius:6px;font-size:.875rem;background:var(--background-color);color:var(--text-primary);width:140px}.incident-filter-date:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 2px #4a90d926}.incident-filter-date-sep{color:var(--text-secondary);font-size:.8125rem}.incident-clear-filters-btn{white-space:nowrap}.incident-type-badge{display:inline-block;padding:.25rem .625rem;border-radius:6px;font-size:.75rem;font-weight:600;white-space:nowrap;background:var(--accent-color);color:#fff}.incident-type-injury{background:#dc3545}.incident-type-hfi{background:#fd7e14}.incident-type-nonhfi{background:#ffc107;color:#333}.incident-type-crossing{background:#6f42c1}.fra-badge{display:inline-block;padding:.1875rem .5rem;border-radius:4px;font-size:.75rem;font-weight:600}.fra-yes{background:#dc3545;color:#fff}.fra-no{background:#e9ecef;color:#666}.incident-row-actions{display:flex;gap:.375rem}.btn-icon{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border:none;border-radius:6px;background:var(--background-color);color:var(--text-secondary);cursor:pointer;transition:all .15s}.btn-icon:hover{background:var(--border-color);color:var(--text-primary)}.btn-icon-danger:hover{background:#f8d7da;color:#dc3545}.incident-day-display{font-size:.8125rem;color:var(--text-secondary);margin-bottom:1rem;padding:.375rem .75rem;background:var(--background-color);border-radius:6px;display:inline-block}.incident-modal{max-width:700px;width:95%;padding:0;display:flex;flex-direction:column;max-height:90vh}.incident-modal .modal-body{padding:1.25rem 1.5rem;overflow-y:auto}.incident-modal .modal-actions{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid var(--border-light);flex-shrink:0}.modal-form-grid-3{grid-template-columns:1fr 1fr 1fr!important}.incident-modal textarea{width:100%;padding:.5rem .625rem;border:1px solid var(--border-color);border-radius:6px;font-size:.875rem;background:var(--surface-color);color:var(--text-primary);font-family:inherit;resize:vertical;box-sizing:border-box}.incident-modal textarea:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 2px #4a90d926}.multi-add-section{margin-bottom:1rem}.multi-add-input{display:flex;gap:.5rem}.multi-add-input input{flex:1;padding:.5rem .625rem;border:1px solid var(--border-color);border-radius:6px;font-size:.875rem;background:var(--surface-color);color:var(--text-primary)}.multi-add-input input:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 2px #4a90d926}.btn-add{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;border-radius:6px;background:var(--accent-color);color:#fff;font-size:1.25rem;font-weight:700;cursor:pointer;flex-shrink:0;transition:background .15s}.btn-add:hover{background:var(--accent-dark, #3a7bc8)}.multi-add-list{display:flex;flex-wrap:wrap;gap:.375rem;margin-top:.5rem}.multi-add-tag{display:inline-flex;align-items:center;gap:.375rem;padding:.25rem .625rem;background:var(--background-color);border:1px solid var(--border-color);border-radius:6px;font-size:.8125rem;color:var(--text-primary)}.multi-add-tag-employee{background:#4a90d914;border-color:#4a90d940}.multi-add-tag button{display:flex;align-items:center;justify-content:center;width:18px;height:18px;border:none;border-radius:50%;background:transparent;color:var(--text-muted);font-size:1rem;line-height:1;cursor:pointer;padding:0}.multi-add-tag button:hover{background:#f8d7da;color:#dc3545}.employee-dropdown{border:1px solid var(--border-color);border-radius:6px;margin-top:.25rem;max-height:200px;overflow-y:auto;background:var(--surface-color);box-shadow:0 4px 12px #0000001a}.employee-dropdown-item{display:flex;align-items:center;gap:.5rem;width:100%;padding:.5rem .75rem;border:none;background:transparent;cursor:pointer;font-size:.8125rem;color:var(--text-primary);text-align:left;transition:background .1s}.employee-dropdown-item:hover{background:var(--background-color)}.employee-dropdown-item .emp-number{font-weight:600;color:var(--accent-color);min-width:40px}.employee-dropdown-item .emp-craft{margin-left:auto;font-size:.75rem;color:var(--text-muted)}.employee-dropdown-empty{padding:.75rem;text-align:center;font-size:.8125rem;color:var(--text-muted)}@media(max-width:1200px){.incident-kpi-cards{grid-template-columns:repeat(3,1fr)}}@media(max-width:768px){.ehr-header-actions{flex-direction:column;width:100%}.ehr-header-actions .ehr-search-input{width:100%}.incident-kpi-cards{grid-template-columns:repeat(2,1fr);gap:.75rem}.incident-kpi-card{padding:.75rem}.incident-kpi-value{font-size:1.5rem}.incident-kpi-label{font-size:.75rem}.incident-filters-row{flex-direction:column;align-items:stretch}.incident-filter-search,.incident-filter-select,.incident-filter-date-group{width:100%;min-width:unset}.incident-filter-date{flex:1;width:auto}.incident-modal{max-width:100%;width:100%;max-height:95vh}.modal-form-grid-3{grid-template-columns:1fr!important}.incident-modal .modal-body{padding:1rem}.incident-modal .modal-actions{flex-direction:column;padding:.75rem 1rem}.incident-modal .modal-actions button{width:100%;text-align:center}}@media(max-width:480px){.incident-kpi-cards{grid-template-columns:1fr 1fr}.incident-kpi-card:first-child{grid-column:span 2}}.incident-view-page{max-width:900px;margin:0 auto;padding:1rem}.incident-view-actions{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;gap:.75rem}.incident-view-actions .btn{display:inline-flex;align-items:center;gap:.375rem}.incident-view-action-buttons{display:flex;gap:.5rem}.incident-view-content{background:var(--surface-color);border:1px solid var(--border-color);border-radius:10px;padding:2rem}.incident-view-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;padding-bottom:1.25rem;border-bottom:2px solid var(--border-color)}.incident-view-title h1{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0 0 .25rem}.incident-view-number{font-size:1.125rem;font-weight:600;color:var(--accent-color)}.incident-view-type-badge-container{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.incident-view-section{margin-bottom:1.75rem}.incident-view-section-title{font-size:1rem;font-weight:700;color:var(--text-primary);margin:0 0 .75rem;padding-bottom:.5rem;border-bottom:1px solid var(--border-light, var(--border-color))}.incident-view-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1rem 1.5rem}.incident-view-field{display:flex;flex-direction:column;gap:.25rem}.incident-view-field label{font-size:.75rem;font-weight:600;color:var(--text-muted, var(--text-secondary));text-transform:uppercase;letter-spacing:.03em}.incident-view-field span{font-size:.9375rem;color:var(--text-primary)}.incident-view-total label{color:var(--text-primary);font-weight:700}.incident-view-total span{font-weight:700;font-size:1rem}.incident-view-description{font-size:.9375rem;line-height:1.6;color:var(--text-primary);background:var(--background-color);padding:1rem;border-radius:6px;white-space:pre-wrap}.incident-view-tag-list{display:flex;flex-wrap:wrap;gap:.5rem}.incident-view-tag{display:inline-block;padding:.375rem .75rem;background:var(--background-color);border:1px solid var(--border-color);border-radius:6px;font-size:.875rem;font-weight:500;color:var(--text-primary)}.incident-view-employees-table{overflow-x:auto}.incident-view-employees-table table{width:100%;border-collapse:collapse;font-size:.875rem}.incident-view-employees-table th{text-align:left;font-weight:600;color:var(--text-secondary);padding:.5rem .75rem;border-bottom:2px solid var(--border-color);font-size:.8125rem;text-transform:uppercase;letter-spacing:.03em}.incident-view-employees-table td{padding:.5rem .75rem;border-bottom:1px solid var(--border-light, var(--border-color));color:var(--text-primary)}.incident-view-employees-table tr:last-child td{border-bottom:none}.incident-view-empty{font-size:.875rem;color:var(--text-muted, var(--text-secondary));font-style:italic;margin:0}.incident-view-footer{margin-top:2rem;padding-top:1rem;border-top:1px solid var(--border-light, var(--border-color))}.incident-view-meta{display:flex;gap:1.5rem;font-size:.75rem;color:var(--text-muted, var(--text-secondary))}@media(max-width:768px){.incident-view-content{padding:1rem}.incident-view-header{flex-direction:column;gap:.75rem}.incident-view-grid{grid-template-columns:1fr 1fr}.incident-view-actions{flex-direction:column;align-items:stretch}.incident-view-action-buttons{justify-content:flex-end}.incident-view-meta{flex-direction:column;gap:.375rem}}@media(max-width:480px){.incident-view-grid{grid-template-columns:1fr}}@media print{.no-print,nav,header,.layout-sidebar,.layout-header,.mobile-nav,.desktop-nav{display:none!important}body{background:#fff;color:#000;font-size:11pt;-webkit-print-color-adjust:exact;print-color-adjust:exact}.incident-view-page{max-width:100%;margin:0;padding:0}.incident-view-content{border:none;border-radius:0;padding:0;box-shadow:none;background:#fff}.incident-view-header{border-bottom:2px solid #333}.incident-view-title h1{font-size:18pt;color:#000}.incident-view-number{color:#333}.incident-view-section-title{font-size:12pt;color:#000;border-bottom-color:#ccc}.incident-view-field label{color:#666}.incident-view-field span{color:#000}.incident-view-description{background:#f9f9f9;border:1px solid #ddd}.incident-view-tag{background:#f0f0f0;border-color:#ccc}.incident-view-employees-table th{color:#333;border-bottom-color:#333}.incident-view-employees-table td{border-bottom-color:#ddd;color:#000}.incident-view-footer{border-top-color:#ccc}.incident-view-meta{color:#666}.incident-type-badge,.fra-badge{-webkit-print-color-adjust:exact;print-color-adjust:exact}.incident-view-section,.incident-view-employees-table{page-break-inside:avoid}}.discipline-view-page{max-width:900px;margin:0 auto;padding:1rem}.discipline-view-actions{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;gap:.75rem}.discipline-view-actions .btn{display:inline-flex;align-items:center;gap:.375rem}.discipline-view-action-buttons{display:flex;gap:.5rem}.discipline-view-content{background:var(--surface-color);border:1px solid var(--border-color);border-radius:10px;padding:2rem}.discipline-view-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;padding-bottom:1.25rem;border-bottom:2px solid var(--border-color)}.discipline-view-title h1{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0 0 .25rem}.discipline-view-number{font-size:1.125rem;font-weight:600;color:var(--accent-color)}.discipline-view-badge-container{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.discipline-category-badge{display:inline-block;padding:.25rem .625rem;border-radius:6px;font-size:.75rem;font-weight:600;white-space:nowrap;background:var(--accent-color);color:#fff}.discipline-cat-attendance{background:#0d6efd}.discipline-cat-conduct{background:#fd7e14}.discipline-cat-drugalcohol,.discipline-cat-injury{background:#dc3545}.discipline-cat-policy{background:#6f42c1}.discipline-cat-critical{background:#842029}.discipline-cat-equipment{background:#0dcaf0}.discipline-view-section{margin-bottom:1.75rem}.discipline-view-section-title{font-size:1rem;font-weight:700;color:var(--text-primary);margin:0 0 .75rem;padding-bottom:.5rem;border-bottom:1px solid var(--border-light, var(--border-color))}.discipline-view-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1rem 1.5rem}.discipline-view-field{display:flex;flex-direction:column;gap:.25rem}.discipline-view-field label{font-size:.75rem;font-weight:600;color:var(--text-muted, var(--text-secondary));text-transform:uppercase;letter-spacing:.03em}.discipline-view-field span{font-size:.9375rem;color:var(--text-primary)}.discipline-view-description{font-size:.9375rem;line-height:1.6;color:var(--text-primary);background:var(--background-color);padding:1rem;border-radius:6px;white-space:pre-wrap}.discipline-view-flags{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:1rem}.discipline-view-flag{display:flex;align-items:center;gap:.625rem;padding:.75rem;background:var(--background-color);border-radius:8px;border:1px solid var(--border-light, var(--border-color))}.discipline-view-flag-indicator{width:10px;height:10px;border-radius:50%;flex-shrink:0}.discipline-view-flag-indicator.flag-yes{background:#198754}.discipline-view-flag-indicator.flag-no{background:#adb5bd}.discipline-view-flag-content{display:flex;flex-direction:column;gap:.125rem}.discipline-view-flag-content label{font-size:.75rem;font-weight:600;color:var(--text-muted, var(--text-secondary));text-transform:uppercase;letter-spacing:.03em}.discipline-view-flag-content span{font-size:.9375rem;font-weight:500;color:var(--text-primary)}.discipline-view-footer{margin-top:2rem;padding-top:1rem;border-top:1px solid var(--border-light, var(--border-color))}.discipline-view-meta{display:flex;gap:1.5rem;font-size:.75rem;color:var(--text-muted, var(--text-secondary))}@media(max-width:768px){.discipline-view-content{padding:1rem}.discipline-view-header{flex-direction:column;gap:.75rem}.discipline-view-grid,.discipline-view-flags{grid-template-columns:1fr 1fr}.discipline-view-actions{flex-direction:column;align-items:stretch}.discipline-view-action-buttons{justify-content:flex-end}.discipline-view-meta{flex-direction:column;gap:.375rem}}@media(max-width:480px){.discipline-view-grid,.discipline-view-flags{grid-template-columns:1fr}}@media print{.no-print,nav,header,.layout-sidebar,.layout-header,.mobile-nav,.desktop-nav{display:none!important}body{background:#fff;color:#000;font-size:11pt;-webkit-print-color-adjust:exact;print-color-adjust:exact}.discipline-view-page{max-width:100%;margin:0;padding:0}.discipline-view-content{border:none;border-radius:0;padding:0;box-shadow:none;background:#fff}.discipline-view-header{border-bottom:2px solid #333}.discipline-view-title h1{font-size:18pt;color:#000}.discipline-view-number{color:#333}.discipline-view-section-title{font-size:12pt;color:#000;border-bottom-color:#ccc}.discipline-view-field label,.discipline-view-flag-content label{color:#666}.discipline-view-field span,.discipline-view-flag-content span{color:#000}.discipline-view-description{background:#f9f9f9;border:1px solid #ddd}.discipline-view-flag{background:#f9f9f9;border-color:#ddd}.discipline-view-footer{border-top-color:#ccc}.discipline-view-meta{color:#666}.discipline-category-badge,.discipline-view-flag-indicator{-webkit-print-color-adjust:exact;print-color-adjust:exact}.discipline-view-section{page-break-inside:avoid}}:root{--primary-color: #1a3a5c;--primary-dark: #0f2540;--primary-light: #2c5282;--primary-lighter: #3d6ba3;--accent-color: #4a90d9;--accent-light: #7fb3eb;--success-color: #2e7d32;--success-light: #e8f5e9;--error-color: #c62828;--error-light: #ffebee;--warning-color: #f57c00;--warning-light: #fff3e0;--background-color: #f5f7fa;--surface-color: #ffffff;--text-primary: #1a2b3c;--text-secondary: #5a6b7c;--text-muted: #8a9bac;--border-color: #d4dce6;--border-light: #e8edf3}*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,SF Pro Text,Helvetica Neue,Helvetica,Arial,sans-serif;background-color:var(--background-color);color:var(--text-primary);line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh;display:flex;flex-direction:column}.app-container{display:flex;flex-direction:column;min-height:100vh}.app-header{background:linear-gradient(135deg,var(--primary-color) 0%,var(--primary-dark) 100%);color:#fff;padding:0 2rem;box-shadow:0 2px 12px #1a3a5c26}.header-content{max-width:1400px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;height:64px}.app-title{font-size:1.375rem;font-weight:600;letter-spacing:-.02em}.nav-menu{display:flex;align-items:center;gap:1rem}.user-name{font-size:.875rem;font-weight:500;opacity:.9}.main-content{flex:1;max-width:1400px;margin:0 auto;padding:2rem;width:100%}.app-footer{background:linear-gradient(135deg,var(--primary-dark) 0%,var(--primary-color) 100%);color:#ffffffd9;text-align:center;padding:1.25rem;font-size:.8125rem;font-weight:500;letter-spacing:.01em}.btn{padding:.625rem 1.25rem;border:none;border-radius:8px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;font-family:inherit}.btn:hover{transform:translateY(-1px)}.btn:active{transform:translateY(0)}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-login{background-color:#fff;color:var(--primary-color);font-weight:600}.btn-login:hover{background-color:#ffffffe6;box-shadow:0 4px 12px #00000026}.btn-logout{background-color:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.4)}.btn-logout:hover{background-color:#ffffff1a;border-color:#fff9}.btn-check{background-color:var(--accent-color);color:#fff;margin-top:1rem}.btn-check:hover{background-color:var(--primary-light)}.home-page{display:flex;flex-direction:column;gap:2rem}.hero{text-align:center;padding:3.5rem 2rem;background:linear-gradient(135deg,var(--primary-color) 0%,var(--primary-light) 100%);color:#fff;border-radius:16px;box-shadow:0 8px 32px #1a3a5c33}.hero h2{font-size:2.25rem;font-weight:700;margin-bottom:.75rem;letter-spacing:-.02em}.hero p{font-size:1.125rem;opacity:.9;font-weight:400}.auth-notice{text-align:center;padding:1rem 1.5rem;background-color:var(--warning-light);border:1px solid var(--warning-color);border-radius:8px;color:var(--warning-color);font-weight:500}.status-unknown{background-color:var(--background-color);color:var(--text-muted)}.status-checking{background-color:#4a90d91a;color:var(--accent-color)}.status-success{background-color:var(--success-light);color:var(--success-color)}.status-error{background-color:var(--error-light);color:var(--error-color)}.features h3{margin-bottom:1rem;font-size:1.25rem;font-weight:600;color:var(--primary-color)}.feature-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}.feature-card{background-color:var(--surface-color);padding:1.75rem;border-radius:12px;border:1px solid var(--border-color);transition:all .2s ease}.feature-card:hover{box-shadow:0 8px 24px #1a3a5c1f;transform:translateY(-2px);border-color:var(--accent-color)}.feature-card h4{color:var(--primary-color);margin-bottom:.5rem;font-weight:600;font-size:1.0625rem}.feature-card p{font-size:.875rem;color:var(--text-secondary);line-height:1.6}.app-title-link{text-decoration:none;color:inherit}.main-nav{display:flex;gap:.375rem}.nav-link{color:#ffffffbf;text-decoration:none;padding:.5rem 1rem;border-radius:8px;font-weight:500;font-size:.9375rem;transition:all .2s ease}.nav-link:hover{background-color:#ffffff1a;color:#fff}.nav-link.active{background-color:#fff3;color:#fff}.nav-dropdown{position:relative}.nav-dropdown-trigger{display:flex;align-items:center;gap:.375rem;background:none;border:none;cursor:pointer;font-family:inherit}.dropdown-arrow{transition:transform .2s ease}.nav-dropdown:hover .dropdown-arrow,.nav-dropdown-trigger.active .dropdown-arrow{opacity:1}.nav-dropdown-menu{position:absolute;top:calc(100% + .375rem);left:0;min-width:200px;background:var(--surface-color);border-radius:8px;box-shadow:0 8px 32px #0f254040;z-index:1000;overflow:hidden;animation:dropdownFadeIn .15s ease}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.nav-dropdown-item{display:block;width:100%;padding:.625rem 1rem;color:var(--text-primary);text-decoration:none;font-size:.875rem;font-weight:500;font-family:inherit;border:none;background:none;cursor:pointer;text-align:left;transition:all .15s ease}.nav-dropdown-item:hover{background-color:var(--background-color);color:var(--primary-color)}.nav-dropdown-item.active{background-color:#4a90d91a;color:var(--accent-color);font-weight:600}.nav-link-admin{border:1px solid rgba(255,255,255,.3)}.nav-link-admin:hover{border-color:#ffffff80}.nav-link-admin.active{border-color:#fff9}.user-nav{display:flex;align-items:center;gap:1.25rem}.page-container{display:flex;flex-direction:column;gap:1.5rem}.page-header{display:flex;justify-content:space-between;align-items:center}.page-header h2{font-size:1.5rem;font-weight:600;color:var(--primary-color);letter-spacing:-.01em}.btn-primary{background-color:var(--primary-color);color:#fff}.btn-primary:hover{background-color:var(--primary-dark);box-shadow:0 4px 12px #1a3a5c40}.btn-secondary{background-color:var(--background-color);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover{background-color:var(--border-light);border-color:var(--text-muted)}.btn-danger{background-color:var(--error-color);color:#fff}.btn-danger:hover{background-color:#b71c1c;box-shadow:0 4px 12px #c6282840}.btn-small{padding:.375rem .75rem;font-size:.8125rem}.form-card{background-color:var(--surface-color);padding:1.75rem;border-radius:12px;border:1px solid var(--border-color);box-shadow:0 2px 8px #1a3a5c0f}.form-card h3{margin-bottom:1.25rem;color:var(--primary-color);font-weight:600}.employee-form{display:flex;flex-direction:column;gap:1rem}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.form-group{display:flex;flex-direction:column;gap:.375rem}.form-group label{font-size:.8125rem;font-weight:600;color:var(--text-secondary);letter-spacing:.01em}.form-group input,.form-group select{padding:.625rem .875rem;border:1px solid var(--border-color);border-radius:8px;font-size:.9375rem;font-family:inherit;transition:all .2s ease}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 3px #4a90d926}.form-actions{display:flex;gap:.75rem;margin-top:.75rem}.table-container{background-color:var(--surface-color);border-radius:12px;border:1px solid var(--border-color);overflow:hidden;box-shadow:0 2px 8px #1a3a5c0f}.data-table{width:100%;border-collapse:collapse}.data-table th,.data-table td{padding:1rem 1.25rem;text-align:left;border-bottom:1px solid var(--border-light)}.data-table th{background-color:var(--primary-color);color:#fff;font-weight:600;font-size:.8125rem;text-transform:uppercase;letter-spacing:.03em}.data-table tr:hover{background-color:#4a90d90a}.data-table td{font-size:.9375rem}.no-data{text-align:center;color:var(--text-muted);padding:3rem!important;font-style:italic}.status-badge{display:inline-block;padding:.375rem .75rem;border-radius:6px;font-size:.75rem;font-weight:600;letter-spacing:.02em}.status-active{background-color:var(--success-light);color:var(--success-color)}.status-inactive{background-color:var(--warning-light);color:var(--warning-color)}.status-terminated{background-color:var(--error-light);color:var(--error-color)}.error-message{padding:1rem 1.25rem;background-color:var(--error-light);border:1px solid rgba(198,40,40,.2);border-radius:8px;color:var(--error-color);font-weight:500}.loading{text-align:center;padding:3rem;color:var(--text-muted);font-weight:500}.actions-cell{display:flex;gap:.5rem}.input-disabled{background-color:var(--background-color);color:var(--text-muted);cursor:not-allowed}.role-badge{display:inline-block;font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);background-color:var(--background-color);padding:.25rem .625rem;border-radius:4px}.hamburger-btn{display:none;flex-direction:column;justify-content:center;gap:5px;background:none;border:none;cursor:pointer;padding:6px;z-index:1001}.hamburger-line{display:block;width:22px;height:2px;background-color:#fff;border-radius:2px;transition:all .3s ease}.hamburger-btn.open .hamburger-line:nth-child(1){transform:rotate(45deg) translate(5px,5px)}.hamburger-btn.open .hamburger-line:nth-child(2){opacity:0}.hamburger-btn.open .hamburger-line:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}.header-right{display:flex;align-items:center;gap:1rem}.mobile-nav-overlay{position:fixed;inset:0;background:#0f254099;z-index:999;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.mobile-nav{position:fixed;top:0;right:0;width:280px;max-width:85vw;height:100vh;background:var(--surface-color);z-index:1000;display:flex;flex-direction:column;animation:slideIn .25s ease;overflow-y:auto;-webkit-overflow-scrolling:touch}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.mobile-nav-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;background:linear-gradient(135deg,var(--primary-color) 0%,var(--primary-dark) 100%);color:#fff}.mobile-user-name{font-size:.875rem;font-weight:600}.mobile-close-btn{background:none;border:none;color:#fff;cursor:pointer;padding:4px;display:flex;align-items:center}.mobile-nav-link{display:flex;align-items:center;justify-content:space-between;padding:.875rem 1.25rem;color:var(--text-primary);text-decoration:none;font-size:.9375rem;font-weight:500;border-bottom:1px solid var(--border-light);transition:background .15s ease;background:none;border-left:none;border-right:none;border-top:none;width:100%;text-align:left;cursor:pointer;font-family:inherit}.mobile-nav-link:hover,.mobile-nav-link:active{background-color:var(--background-color)}.mobile-nav-link.active{color:var(--accent-color);font-weight:600;border-left:3px solid var(--accent-color)}.mobile-nav-section{border-bottom:1px solid var(--border-light)}.mobile-nav-section-trigger{border-bottom:none}.mobile-dropdown-arrow{transition:transform .2s ease}.mobile-dropdown-arrow.open{transform:rotate(180deg)}.mobile-nav-sub{background-color:var(--background-color)}.mobile-nav-sublink{display:block;width:100%;padding:.75rem 1.25rem .75rem 2.25rem;color:var(--text-secondary);text-decoration:none;font-size:.875rem;font-weight:500;font-family:inherit;background:none;border:none;border-bottom:1px solid var(--border-light);cursor:pointer;text-align:left;transition:background .15s ease}.mobile-nav-sublink:hover,.mobile-nav-sublink:active{background-color:var(--border-light)}.mobile-nav-sublink.active{color:var(--accent-color);font-weight:600}.mobile-nav-footer{margin-top:auto;padding:1.25rem;border-top:1px solid var(--border-color)}.mobile-logout-btn{width:100%;padding:.75rem;background:var(--error-light);color:var(--error-color);border:1px solid rgba(198,40,40,.2);border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;font-family:inherit;transition:background .15s ease}.mobile-logout-btn:hover{background:#c6282826}@media(max-width:768px){input[type=text],input[type=search],input[type=email],input[type=tel],input[type=date],select,textarea{font-size:16px!important}}@media(max-width:1024px){.app-header{padding:0 1rem}.main-content{padding:1.25rem}.nav-link{padding:.5rem .625rem;font-size:.875rem}}@media(max-width:768px){.app-header{padding:0 1rem}.header-content{height:56px}.app-title{font-size:1.125rem}.desktop-nav{display:none}.hamburger-btn{display:flex}.user-nav{display:none}.main-content{padding:.75rem}.hero{padding:2rem 1.25rem;border-radius:12px}.hero h2{font-size:1.5rem}.hero p{font-size:.9375rem}.page-header{flex-direction:column;gap:.75rem;align-items:flex-start}.feature-grid,.form-grid{grid-template-columns:1fr}}.ehr-page{padding:1.5rem;max-width:1400px;margin:0 auto;width:100%}.ehr-header{margin-bottom:1.5rem}.ehr-header-info{display:flex;align-items:center;gap:1rem;margin-bottom:1rem;flex-wrap:wrap}.ehr-header-info h1{font-size:1.75rem;font-weight:600;color:var(--text-primary);margin:0}.ehr-record-count{font-size:.875rem;color:var(--text-secondary);background:var(--background-color);padding:.25rem .75rem;border-radius:999px;font-weight:500}.ehr-search-input{width:100%;padding:.75rem 1rem;border:1px solid var(--border-color);border-radius:8px;font-size:.9375rem;font-family:inherit;background-color:var(--surface-color)}.ehr-search-input:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 3px #4a90d926}.ehr-table-container{overflow-x:auto;border-radius:10px;border:1px solid var(--border-light);background:var(--surface-color)}.ehr-table{width:100%;border-collapse:collapse;font-size:.875rem}.ehr-table thead{background:var(--background-color)}.ehr-table th{padding:.75rem 1rem;text-align:left;font-weight:600;color:var(--text-secondary);font-size:.75rem;text-transform:uppercase;letter-spacing:.03em;border-bottom:2px solid var(--border-color);white-space:nowrap}.ehr-table td{padding:.75rem 1rem;border-bottom:1px solid var(--border-light);vertical-align:middle}.ehr-table tbody tr:hover{background:var(--background-color)}.ehr-table tbody tr:last-child td{border-bottom:none}.ehr-employee-link{background:none;border:none;color:var(--accent-color);font-weight:600;cursor:pointer;font-size:.875rem;font-family:inherit;padding:0;text-align:left}.ehr-employee-link:hover{color:var(--primary-color);text-decoration:underline}.ehr-employee-meta{display:block;font-size:.75rem;color:var(--text-muted);margin-top:.125rem}.ehr-empty-state{text-align:center;padding:3rem 1rem;color:var(--text-secondary);background:var(--surface-color);border-radius:10px;border:1px solid var(--border-light)}.ehr-empty-state p{font-size:1rem;margin:0}@media(max-width:768px){.ehr-page{padding:1rem}.ehr-header-info h1{font-size:1.375rem}.ehr-table th,.ehr-table td{padding:.5rem .625rem}.ehr-table .hide-mobile{display:none}.ehr-search-input{font-size:16px!important}}@media(max-width:390px){.ehr-header-info{flex-direction:column;align-items:flex-start;gap:.375rem}.ehr-header-info h1{font-size:1.25rem}}@media(max-width:390px){.app-title{font-size:1rem}.main-content{padding:.5rem}.hero{padding:1.5rem 1rem;border-radius:8px}.hero h2{font-size:1.25rem}}
