*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{color:#1a1a1a;background:#f5f5f5;min-height:100vh;font-family:system-ui,-apple-system,sans-serif}.page{justify-content:center;align-items:center;min-height:100vh;padding:1rem;display:flex}.card{background:#fff;border-radius:10px;width:100%;max-width:420px;padding:2.5rem 2rem;box-shadow:0 2px 16px #00000014}.card h1{margin-bottom:.25rem;font-size:1.6rem}.card .subtitle{color:#666;margin-bottom:1.75rem;font-size:.9rem}.form-group{flex-direction:column;gap:.4rem;margin-bottom:1rem;display:flex}label{font-size:.875rem;font-weight:500}input,select{border:1px solid #d1d5db;border-radius:6px;width:100%;padding:.6rem .8rem;font-size:1rem;transition:border-color .15s}input:focus,select:focus{border-color:#2563eb;outline:none}.btn{color:#fff;cursor:pointer;background:#2563eb;border:none;border-radius:6px;width:100%;margin-top:.5rem;padding:.7rem 1rem;font-size:1rem;font-weight:600;transition:background .15s}.btn:hover{background:#1d4ed8}.btn:disabled{cursor:not-allowed;background:#93c5fd}.error{color:#dc2626;background:#fef2f2;border:1px solid #fecaca;border-radius:6px;margin-top:.75rem;padding:.6rem .8rem;font-size:.875rem}.link-row{text-align:center;margin-top:1.25rem;font-size:.875rem}.link-row a{color:#2563eb;text-decoration:none}.link-row a:hover{text-decoration:underline}textarea{resize:vertical;border:1px solid #d1d5db;border-radius:6px;width:100%;min-height:80px;padding:.6rem .8rem;font-family:inherit;font-size:1rem;transition:border-color .15s}textarea:focus{border-color:#2563eb;outline:none}.card-wide{max-width:600px}.onboarding-steps{gap:6px;margin-bottom:1.75rem;display:flex}.onboarding-step{background:#e5e7eb;border-radius:2px;flex:1;height:4px;transition:background .2s}.onboarding-step.active{background:#2563eb}.onboarding-step.done{background:#059669}.form-row-2{grid-template-columns:1fr 1fr;gap:.75rem;display:grid}.form-row-3{grid-template-columns:1fr 1fr 1fr;gap:.75rem;display:grid}@media (width<=500px){.form-row-2,.form-row-3{grid-template-columns:1fr}}.file-drop{cursor:pointer;border:1px dashed #d1d5db;border-radius:6px;padding:.75rem 1rem;transition:border-color .15s;position:relative}.file-drop:hover{border-color:#2563eb}.file-drop input[type=file]{opacity:0;cursor:pointer;width:100%;height:100%;position:absolute;inset:0}.file-drop .file-name{color:#1a1a1a;font-size:.9rem}.file-drop .file-placeholder{color:#6b7280;font-size:.875rem}.btn-skip{color:#6b7280;cursor:pointer;text-align:center;background:0 0;border:none;width:100%;margin-top:.75rem;padding:0;font-size:.875rem;display:block}.btn-skip:hover{color:#374151;text-decoration:underline}.alert-banner{background:#fffbeb;border:1px solid #fde68a;border-radius:8px;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.5rem;padding:.875rem 1.25rem;font-size:.9rem;display:flex}.alert-link{color:#d97706;white-space:nowrap;font-weight:600;text-decoration:none}.alert-link:hover{text-decoration:underline}.dashboard{background:#f5f5f5;min-height:100vh}.navbar{background:#fff;border-bottom:1px solid #e5e7eb;justify-content:space-between;align-items:center;height:60px;padding:0 2rem;display:flex}.navbar .brand{color:#2563eb;font-size:1.2rem;font-weight:700}.navbar .btn-logout{cursor:pointer;background:0 0;border:1px solid #d1d5db;border-radius:6px;padding:.4rem .9rem;font-size:.875rem;transition:background .15s}.navbar .btn-logout:hover{background:#f3f4f6}.dashboard-content{max-width:800px;margin:2.5rem auto;padding:0 1rem}.welcome-card{background:#fff;border-radius:10px;margin-bottom:1.5rem;padding:2rem;box-shadow:0 2px 16px #00000014}.welcome-card h2{margin-bottom:.75rem;font-size:1.4rem}.role-badge{letter-spacing:.05em;text-transform:uppercase;border-radius:999px;padding:.25rem .75rem;font-size:.8rem;font-weight:600;display:inline-block}.role-badge.operator{color:#059669;background:#ecfdf5}.role-badge.contractor{color:#2563eb;background:#eff6ff}.info-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-top:1.5rem;display:grid}.info-item{background:#f9fafb;border-radius:8px;padding:1rem}.info-item .label{color:#6b7280;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.25rem;font-size:.75rem}.info-item .value{font-weight:600}.job-list{flex-direction:column;gap:.875rem;display:flex}.job-card{border:1px solid #e5e7eb;border-radius:8px;padding:1rem 1.25rem}.job-card-header{justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:.5rem;display:flex}.job-title{margin-bottom:.2rem;font-size:1rem;font-weight:600}.job-location{color:#6b7280;font-size:.85rem}.job-meta{flex-wrap:wrap;gap:.5rem;margin-bottom:.75rem;display:flex}.job-meta-item{color:#6b7280;background:#f9fafb;border-radius:4px;padding:.2rem .5rem;font-size:.8rem}.job-actions{gap:.5rem;display:flex}.job-action-btn{color:#374151;cursor:pointer;background:0 0;border:1px solid #d1d5db;border-radius:5px;align-items:center;padding:.3rem .75rem;font-size:.8rem;text-decoration:none;transition:background .15s;display:inline-flex}.job-action-btn:hover{background:#f3f4f6}.job-action-btn--danger{color:#dc2626;border-color:#fca5a5}.job-action-btn--danger:hover{background:#fef2f2}.cert-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.5rem;margin-top:.25rem;display:grid}.cert-checkbox{cursor:pointer;border-radius:5px;align-items:center;gap:.5rem;padding:.35rem .5rem;font-size:.875rem;font-weight:400;transition:background .1s;display:flex}.cert-checkbox:hover{background:#f3f4f6}.cert-checkbox input[type=checkbox]{cursor:pointer;flex-shrink:0;width:15px;height:15px}.notif-wrapper{position:relative}.notif-bell{color:#374151;cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;padding:.4rem;transition:background .15s;display:flex;position:relative}.notif-bell:hover{background:#f3f4f6}.notif-badge{color:#fff;background:#dc2626;border-radius:999px;justify-content:center;align-items:center;min-width:16px;height:16px;padding:0 3px;font-size:.65rem;font-weight:700;line-height:1;display:flex;position:absolute;top:0;right:0;transform:translate(30%,-30%)}.notif-dropdown{z-index:100;background:#fff;border:1px solid #e5e7eb;border-radius:10px;width:340px;max-height:420px;position:absolute;top:calc(100% + 8px);right:0;overflow-y:auto;box-shadow:0 8px 24px #0000001f}.notif-dropdown-header{background:#fff;border-bottom:1px solid #e5e7eb;justify-content:space-between;align-items:center;padding:.875rem 1rem;font-size:.9rem;font-weight:600;display:flex;position:sticky;top:0}.notif-unread-label{color:#2563eb;background:#eff6ff;border-radius:999px;padding:.15rem .6rem;font-size:.75rem;font-weight:600}.notif-empty{color:#6b7280;text-align:center;padding:2rem 1rem;font-size:.875rem}.notif-list{list-style:none}.notif-item{cursor:default;border-bottom:1px solid #f3f4f6;padding:.875rem 1rem;transition:background .1s}.notif-item:last-child{border-bottom:none}.notif-item--unread{cursor:pointer;background:#eff6ff}.notif-item--unread:hover{background:#dbeafe}.notif-title{margin-bottom:.2rem;font-size:.875rem;font-weight:600}.notif-message{color:#374151;margin-bottom:.3rem;font-size:.8rem;line-height:1.4}.notif-time{color:#9ca3af;font-size:.75rem}.back-link{color:#6b7280;font-size:.875rem;text-decoration:none}.back-link:hover{color:#374151;text-decoration:underline}
