html,body{margin:0;padding:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Inter,sans-serif}#root{min-height:100vh}*,*:before,*:after{box-sizing:border-box}*{margin:0;padding:0}:root{--efs-blue: #2D3990;--efs-blue-dark: #1f2870;--efs-red: #E62024;--grey-bg: #f4f6fa;--grey-light: #e3e7ee;--grey-dark: #5f6368;--text: #1a1d2e;--green: #1e8e3e}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Inter,sans-serif;background:var(--grey-bg);color:var(--text);font-size:15px}.loading{display:flex;align-items:center;justify-content:center;min-height:100vh;color:var(--grey-dark)}.login-wrapper{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:linear-gradient(135deg,var(--efs-blue),var(--efs-blue-dark))}.login-card{background:#fff;border-radius:8px;padding:36px 32px;width:100%;max-width:400px;box-shadow:0 10px 40px #0003;border-top:4px solid var(--efs-red)}.login-card .brand{text-align:center;margin-bottom:28px}.login-card h1{color:var(--efs-blue);font-size:28px;font-weight:800;letter-spacing:.05em}.login-card .brand p{color:var(--grey-dark);font-size:12px;text-transform:uppercase;letter-spacing:.15em;margin-top:4px}.login-card form{display:flex;flex-direction:column;gap:16px}.login-card label{display:flex;flex-direction:column;gap:6px;font-size:12px;text-transform:uppercase;letter-spacing:.1em;color:var(--grey-dark);font-weight:600}.login-card input{font-family:inherit;font-size:16px;padding:12px 14px;border:1px solid var(--grey-light);border-radius:5px;color:var(--text)}.login-card input:focus{outline:none;border-color:var(--efs-blue);box-shadow:0 0 0 2px #2d399026}.login-card button{background:var(--efs-blue);color:#fff;border:none;padding:14px;font-size:14px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;border-radius:5px;cursor:pointer;margin-top:8px}.login-card button:hover{background:var(--efs-blue-dark)}.error{background:#fff5f5;color:var(--efs-red);padding:10px 14px;border-radius:5px;font-size:13px;border-left:3px solid var(--efs-red)}.app{min-height:100vh}.topbar{background:#fff;border-bottom:3px solid var(--efs-red);box-shadow:0 2px 6px #2d399014}.topbar-inner{max-width:1280px;margin:0 auto;padding:14px 24px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}.brand-mini strong{color:var(--efs-blue);font-weight:800;font-size:18px;letter-spacing:.05em}.brand-mini span{color:var(--grey-dark);font-size:11px;text-transform:uppercase;letter-spacing:.12em;margin-left:10px;border-left:1px solid var(--grey-light);padding-left:10px}.user-menu{display:flex;align-items:center;gap:14px;font-size:13px;color:var(--grey-dark)}.btn-secondary{background:transparent;color:var(--efs-blue);border:1px solid var(--efs-blue);padding:8px 14px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;border-radius:4px;cursor:pointer}.btn-secondary:hover{background:var(--efs-blue);color:#fff}.container{max-width:1280px;margin:0 auto;padding:28px 24px}.welcome-card{background:#fff;border-radius:8px;padding:32px;border-top:3px solid var(--efs-blue);box-shadow:0 1px 3px #0000000f}.welcome-card h2{color:var(--efs-blue);font-size:24px;margin-bottom:6px}.welcome-card .subtitle{color:var(--grey-dark);font-size:14px;margin-bottom:24px}.admin-dashboard{display:flex;flex-direction:column;gap:20px}.page-header h1{color:var(--efs-blue);font-size:28px;font-weight:700;letter-spacing:-.02em}.page-header .subline{color:var(--grey-dark);font-size:13px;text-transform:uppercase;letter-spacing:.1em;margin-top:4px}.tabs{display:flex;gap:0;border-bottom:2px solid var(--grey-light);flex-wrap:wrap}.tab{background:transparent;border:none;font-family:inherit;font-size:13px;font-weight:600;color:var(--grey-dark);padding:12px 20px;cursor:pointer;border-bottom:3px solid transparent;margin-bottom:-2px;text-transform:uppercase;letter-spacing:.06em}.tab:hover{color:var(--efs-blue)}.tab.active{color:var(--efs-blue);border-bottom-color:var(--efs-red)}.tab .badge{display:inline-block;background:var(--efs-blue);color:#fff;border-radius:10px;padding:1px 7px;font-size:10px;margin-left:6px;font-weight:700}.tab-content{display:flex;flex-direction:column;gap:16px}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px;flex-wrap:wrap;gap:12px}.section-header h2{color:var(--efs-blue);font-size:20px;font-weight:700}.btn-primary{background:var(--efs-blue);color:#fff;border:none;padding:12px 18px;font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;border-radius:5px;cursor:pointer;font-family:inherit}.btn-primary:hover{background:var(--efs-blue-dark)}.btn-danger{background:transparent;color:var(--efs-red);border:1px solid var(--efs-red);padding:8px 14px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;border-radius:4px;cursor:pointer;font-family:inherit}.btn-danger:hover{background:var(--efs-red);color:#fff}.form-card{background:#fff;border:1px solid var(--grey-light);border-top:3px solid var(--efs-red);border-radius:8px;padding:24px;box-shadow:0 1px 3px #0000000d}.form-card h3{color:var(--efs-blue);margin-bottom:16px;font-size:17px}.form-card form{display:flex;flex-direction:column;gap:14px}.form-card label{display:flex;flex-direction:column;gap:6px;font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--grey-dark);font-weight:600}.form-card input,.form-card select{font-family:inherit;font-size:15px;padding:10px 12px;border:1px solid var(--grey-light);border-radius:5px;color:var(--text);background:#fff}.form-card input:focus,.form-card select:focus{outline:none;border-color:var(--efs-blue);box-shadow:0 0 0 2px #2d399026}.form-actions{display:flex;gap:8px;margin-top:8px}.depot-list{display:flex;flex-direction:column;gap:8px}.depot-row{background:#fff;border:1px solid var(--grey-light);border-left:4px solid var(--efs-blue);border-radius:6px;padding:14px 18px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}.depot-name{font-weight:700;font-size:15px;color:var(--text);margin-bottom:3px}.depot-meta{font-size:12px;color:var(--grey-dark);text-transform:uppercase;letter-spacing:.06em}.empty-state{background:#fff;border:2px dashed var(--grey-light);border-radius:6px;padding:32px 20px;text-align:center;color:var(--grey-dark);font-size:13px}.empty-state strong{display:block;color:var(--text);font-size:15px;margin-bottom:6px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.form-help{font-size:12px;color:var(--grey-dark);margin-bottom:14px;line-height:1.5;background:var(--grey-bg);padding:10px 12px;border-radius:4px;border-left:3px solid var(--efs-blue)}.pending-row{flex-direction:column;align-items:stretch}.pending-row-top{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;width:100%}.link-form{margin-top:12px;padding:14px;background:var(--grey-bg);border-radius:6px}.link-form input{width:100%;font-family:inherit;font-size:14px;padding:10px 12px;border:1px solid var(--grey-light);border-radius:5px}.days-row{display:flex;gap:6px;flex-wrap:wrap}.day-pill{background:#fff;border:1px solid var(--grey-light);color:var(--grey-dark);padding:8px 14px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;border-radius:4px;cursor:pointer;font-family:inherit}.day-pill:hover{border-color:var(--efs-blue);color:var(--efs-blue)}.day-pill.on{background:#2d3990;border-color:#2d3990;color:#fff}.day-pill.on:hover{background:#1f2870;border-color:#1f2870;color:#fff}.checkbox-row{display:flex;flex-direction:column;gap:8px}.checkbox-label{display:flex;flex-direction:row;align-items:center;gap:10px;text-transform:none;letter-spacing:normal;color:var(--text);font-size:14px;font-weight:500;cursor:pointer}.checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer}.task-row{border-left-color:var(--efs-blue)}.task-desc{font-size:13px;color:var(--grey-dark);margin-top:6px;line-height:1.5}.critical-badge{display:inline-block;background:var(--efs-red);color:#fff;font-size:9px;font-weight:800;text-transform:uppercase;letter-spacing:.12em;padding:2px 8px;border-radius:3px;margin-left:8px;vertical-align:middle}.staff-dashboard{display:flex;flex-direction:column;gap:18px}.progress-card{background:#fff;border:1px solid var(--grey-light);border-left:4px solid var(--efs-blue);border-radius:6px;padding:14px 18px;display:flex;align-items:center;gap:16px;font-size:13px}.progress-text strong{color:var(--efs-blue);font-size:16px}.progress-bar{flex:1;height:10px;background:var(--grey-light);border-radius:5px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--efs-blue),var(--efs-red))}.progress-pct{font-weight:700;color:var(--efs-red);min-width:40px;text-align:right}.task-cards{display:flex;flex-direction:column;gap:10px}.task-card{background:#fff;border:1px solid var(--grey-light);border-left:4px solid var(--efs-blue);border-radius:6px;padding:16px;display:grid;grid-template-columns:70px 1fr auto;gap:14px;align-items:start}.task-card.status-completed,.task-card.status-completed-late{background:#f6fbf7;border-left-color:var(--green)}.task-card.status-overdue{background:#fff5f5;border-left-color:var(--efs-red)}.task-card.status-due-now{border-left-color:#f29900}.task-card.critical{border-left-color:var(--efs-red)}.task-time-col{font-weight:700;font-size:17px;color:var(--efs-blue);border-right:1px solid var(--grey-light);padding-right:10px;min-height:40px;display:flex;align-items:center;justify-content:center}.task-card.status-completed .task-time-col,.task-card.status-completed-late .task-time-col{color:var(--green)}.task-card.status-overdue .task-time-col{color:var(--efs-red)}.anytime-marker{font-size:22px;color:var(--efs-blue)}.task-body{min-width:0}.task-title{font-weight:700;font-size:15px;color:var(--text);margin-bottom:4px}.task-card-desc{font-size:13px;color:var(--grey-dark);line-height:1.5;margin-bottom:8px}.task-status-tag{display:inline-block;font-size:10px;text-transform:uppercase;letter-spacing:.12em;font-weight:700;padding:4px 10px;border-radius:3px;background:var(--grey-bg);color:var(--grey-dark)}.tag-completed,.tag-completed-late{background:#d8f0de;color:var(--green)}.tag-overdue{background:var(--efs-red);color:#fff}.tag-due-now{background:#fef0d4;color:#f29900}.tag-pending-anytime{background:#e8f0fb;color:var(--efs-blue)}.task-checkbox{width:44px;height:44px;border:2px solid var(--grey-light);background:#fff;border-radius:6px;cursor:pointer;font-size:22px;font-weight:700;display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.task-checkbox:hover{border-color:var(--efs-blue)}.task-checkbox.checked{background:var(--green);border-color:var(--green)}.btn-link{background:none;border:none;color:var(--efs-blue);font-size:12px;font-weight:600;cursor:pointer;padding:6px 0;margin-top:6px;font-family:inherit}.btn-link:hover{text-decoration:underline}.note-edit{margin-top:10px}.note-edit textarea{width:100%;font-family:inherit;font-size:14px;padding:10px;border:1px solid var(--grey-light);border-radius:4px;resize:vertical;min-height:60px}.note-edit textarea:focus{outline:none;border-color:var(--efs-blue);box-shadow:0 0 0 2px #2d399026}.note-actions{display:flex;gap:8px;margin-top:8px}.btn-small{padding:8px 14px;font-size:11px}.note-display{margin-top:10px;padding:10px 12px;background:var(--grey-bg);border-left:2px solid var(--efs-blue);border-radius:0 4px 4px 0;font-size:13px;color:var(--grey-dark);cursor:pointer}.note-display .edit-hint{display:block;font-size:10px;color:var(--grey-dark);text-transform:uppercase;letter-spacing:.1em;margin-top:4px;font-style:normal}.date-picker{font-family:inherit;font-size:14px;padding:8px 12px;border:1px solid var(--grey-light);border-radius:5px;background:#fff;cursor:pointer}.signoff-row{flex-direction:column;align-items:stretch;gap:12px}.signoff-row.signed{background:#f6fbf7;border-left-color:var(--green)}.signoff-row-top{width:100%;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}.signed-badge{display:inline-block;background:var(--green);color:#fff;font-size:9px;font-weight:800;text-transform:uppercase;letter-spacing:.12em;padding:3px 9px;border-radius:3px;margin-left:10px;vertical-align:middle}.stat-pill{display:inline-block;font-size:10px;text-transform:uppercase;letter-spacing:.1em;font-weight:700;padding:3px 8px;border-radius:3px;margin-left:6px}.stat-pill.on-time{background:#d8f0de;color:var(--green)}.stat-pill.late{background:#fef0d4;color:#b25800}.stat-pill.missed{background:var(--efs-red);color:#fff}.signoff-tasks{background:var(--grey-bg);border-radius:5px;padding:10px;display:flex;flex-direction:column;gap:4px}.signoff-task{display:grid;grid-template-columns:50px 1fr auto;gap:10px;align-items:center;font-size:12px;padding:6px 8px;border-radius:3px;background:#fff}.signoff-task.late{border-left:3px solid #f29900}.signoff-task.open{border-left:3px solid var(--efs-red);background:#fff8f8}.signoff-task-time{font-weight:700;color:var(--efs-blue)}.signoff-task-title{color:var(--text);font-weight:500}.signoff-task-status{font-weight:700;font-size:11px}.signoff-task.done .signoff-task-status{color:var(--green)}.signoff-task.late .signoff-task-status{color:#b25800}.signoff-task.open .signoff-task-status{color:var(--efs-red)}.signoff-task-note{grid-column:1 / -1;font-size:11px;color:var(--grey-dark);font-style:italic;padding-left:60px;margin-top:2px}.critical-mini{color:var(--efs-red);font-weight:700;margin-left:4px}.signoff-action{display:flex;gap:8px;align-items:stretch}.signoff-action input{flex:1;font-family:inherit;font-size:14px;padding:10px 12px;border:1px solid var(--grey-light);border-radius:5px}.signoff-action input:focus{outline:none;border-color:var(--efs-blue);box-shadow:0 0 0 2px #2d399026}.signoff-confirmed{background:#d8f0de;border-left:3px solid var(--green);border-radius:0 4px 4px 0;padding:10px 12px;font-size:12px;color:var(--green)}.signoff-confirmed strong{font-weight:700}.signoff-note-display{font-style:italic;color:var(--grey-dark);margin-top:4px;font-weight:400}@media (max-width: 600px){.topbar-inner{padding:12px 14px}.container{padding:18px 14px}.brand-mini span{display:none}.welcome-card{padding:22px 18px}.section-header{flex-direction:column;align-items:stretch}.form-row{grid-template-columns:1fr}.task-card{grid-template-columns:56px 1fr 44px;gap:10px;padding:12px}.task-time-col{font-size:14px;padding-right:6px}.task-title{font-size:14px}.signoff-action{flex-direction:column}.signoff-task{grid-template-columns:40px 1fr auto;gap:6px;font-size:11px}.signoff-task-note{padding-left:46px}}.login-logo{display:block;max-width:200px;height:auto;margin:0 auto}.topbar-logo{height:32px;width:auto;display:block}.role-pill{display:inline-block;margin-left:.5rem;padding:.15rem .55rem;font-size:.75rem;font-weight:600;background:#e0e7ff;color:#3730a3;border-radius:999px;vertical-align:middle}.breadcrumb{display:flex;align-items:center;gap:1rem;margin-bottom:1rem;padding:.75rem 1rem;background:#f3f4f6;border-radius:8px;flex-wrap:wrap}.breadcrumb-trail{color:#4b5563;font-size:.95rem}.filter-bar{display:flex;gap:.5rem;margin-bottom:1rem}.filter-pill{padding:.4rem 1rem;border:1px solid #d1d5db;background:#fff;color:#374151;border-radius:999px;cursor:pointer;font-size:.9rem;transition:all .15s ease}.filter-pill:hover{background:#f9fafb}.filter-pill.on{background:#1e40af;color:#fff;border-color:#1e40af}.row-disabled{opacity:.55}.row-disabled .depot-name{text-decoration:line-through;text-decoration-color:#9ca3af}.disabled-badge{display:inline-block;margin-left:.5rem;padding:.1rem .5rem;font-size:.7rem;font-weight:600;background:#fee2e2;color:#991b1b;border-radius:999px;vertical-align:middle}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal{background:#fff;border-radius:12px;padding:1.5rem;max-width:500px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 10px 40px #0003}.modal h3{margin-top:0;margin-bottom:1rem}.modal label{display:block;margin-bottom:.75rem;font-weight:500}.modal input[type=text],.modal input[type=email],.modal input[type=time],.modal select{width:100%;padding:.5rem;border:1px solid #d1d5db;border-radius:6px;margin-top:.25rem;font-size:.95rem;box-sizing:border-box}.warning-box{background:#fef3c7;border:1px solid #fbbf24;color:#78350f;padding:.75rem 1rem;border-radius:8px;margin:.75rem 0;font-size:.9rem}.warning-box strong{color:#78350f}.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.75rem;margin-bottom:1.25rem}.summary-card{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:1rem 1.25rem}.summary-card.summary-good{background:#f0fdf4;border-color:#bbf7d0}.summary-card.summary-good .summary-num{color:#15803d}.summary-card.summary-warn{background:#fffbeb;border-color:#fde68a}.summary-card.summary-warn .summary-num{color:#b45309}.summary-card.summary-bad{background:#fef2f2;border-color:#fecaca}.summary-card.summary-bad .summary-num{color:#b91c1c}.summary-num{font-size:1.75rem;font-weight:600;line-height:1.1}.summary-label{font-size:.85rem;color:#6b7280;margin-top:.25rem}.summary-detail{font-size:.8rem;color:#b91c1c;margin-top:.5rem;font-weight:500}.signoff-row.offender{border-left:3px solid #ef4444}.prior-overdue-banner{background:#fef2f2;border:1px solid #fecaca;border-radius:8px;padding:.75rem 1rem;margin-bottom:1rem;color:#7f1d1d}.prior-overdue-banner strong{display:block;margin-bottom:.5rem}.prior-overdue-banner ul{margin:0;padding-left:1.25rem;list-style:none}.prior-overdue-banner li{font-size:.9rem;margin-bottom:.25rem}.leave-section-heading{font-size:.85rem;text-transform:uppercase;letter-spacing:.08em;color:var(--grey-dark);margin-top:1.25rem;margin-bottom:.5rem;font-weight:700}.leave-section-heading:first-child{margin-top:0}.leave-type-badge{display:inline-block;margin-left:.5rem;padding:.1rem .55rem;font-size:.7rem;font-weight:600;border-radius:999px;text-transform:capitalize;vertical-align:middle}.leave-type-badge.type-annual{background:#dbeafe;color:#1e3a8a}.leave-type-badge.type-sick{background:#fee2e2;color:#991b1b}.leave-type-badge.type-other{background:#f3f4f6;color:#374151}.signoff-row.on-leave-row{border-left:4px solid #94a3b8;background:#f8fafc;opacity:.85}.leave-cancelled{opacity:.6}.leave-cancelled .depot-name{text-decoration:line-through;text-decoration-color:#9ca3af}.leave-type-badge.type-cancelled{background:#fee2e2;color:#991b1b}.big-progress-card{background:#fff;border:1px solid #e5e7eb;border-radius:10px;padding:1.25rem 1.5rem;margin-bottom:1.25rem;box-shadow:0 1px 3px #0000000d;transition:background .4s ease,border-color .4s ease}.big-progress-card.all-done{background:linear-gradient(135deg,#fef9c3,#fde68a);border-color:#facc15}.big-progress-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:.75rem;flex-wrap:wrap;gap:.5rem}.big-progress-counts{font-size:1.05rem;color:#374151}.big-progress-done{font-size:2rem;font-weight:700;color:#16a34a}.big-progress-divider{font-size:1.5rem;color:#9ca3af}.big-progress-total{font-size:1.5rem;font-weight:600;color:#4b5563}.big-progress-label{margin-left:.4rem;color:#6b7280;font-size:.95rem}.big-progress-pct{font-size:2rem;font-weight:700;color:#16a34a;font-variant-numeric:tabular-nums}.big-progress-card.all-done .big-progress-pct,.big-progress-card.all-done .big-progress-done{color:#ca8a04}.big-progress-bar{width:100%;height:14px;background:#f3f4f6;border-radius:999px;overflow:hidden}.big-progress-fill{height:100%;background:linear-gradient(90deg,#22c55e,#16a34a);border-radius:999px;transition:width .5s cubic-bezier(.4,0,.2,1)}.big-progress-card.all-done .big-progress-fill{background:linear-gradient(90deg,#facc15,#ca8a04)}.big-progress-done-text{margin-top:.6rem;text-align:center;font-weight:600;color:#ca8a04;font-size:.95rem}.congrats-banner{background:linear-gradient(135deg,#16a34a,#0d9488);color:#fff;padding:1rem 1.5rem;border-radius:10px;margin-bottom:1rem;font-size:1.1rem;font-weight:600;text-align:center;box-shadow:0 4px 12px #16a34a40;animation:congrats-pop .4s cubic-bezier(.34,1.56,.64,1)}@keyframes congrats-pop{0%{opacity:0;transform:scale(.9) translateY(-10px)}to{opacity:1;transform:scale(1) translateY(0)}}
