:root{--primary:#0f1e3d;--primary-light:#1a2c54;--accent:#b87333;--accent-dark:#9a5f29;--cream:#f5f0e8;--cream-light:#faf7f2;--bg:#f7f8fa;--surface:#fff;--border:#e3e6eb;--border-strong:#c8cdd5;--text:#1a1f2e;--text-muted:#6b7280;--text-light:#9ca3af;--success:#10b981;--success-bg:#d1fae5;--warning:#f59e0b;--warning-bg:#fef3c7;--danger:#ef4444;--danger-bg:#fee2e2;--info:#3b82f6;--info-bg:#dbeafe;--sidebar-width:260px;--header-height:64px;--radius:8px;--radius-lg:12px;--shadow-sm:0 1px 2px #0000000d;--shadow:0 4px 6px #0000000d, 0 2px 4px #0000000a;--shadow-lg:0 10px 25px #00000014}*{box-sizing:border-box;margin:0;padding:0}html,body{max-width:100vw;min-height:100vh;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;font-size:14px;line-height:1.5}a{color:inherit;text-decoration:none}button{cursor:pointer;background:0 0;border:none;font-family:inherit}input,select,textarea{font-family:inherit;font-size:inherit}.btn{border-radius:var(--radius);white-space:nowrap;cursor:pointer;justify-content:center;align-items:center;gap:8px;padding:10px 18px;font-size:.9rem;font-weight:600;text-decoration:none;transition:all .15s;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btnPrimary{background:var(--accent);color:#fff}.btnPrimary:hover:not(:disabled){background:var(--accent-dark)}.btnSecondary{background:var(--primary);color:#fff}.btnSecondary:hover:not(:disabled){background:var(--primary-light)}.btnOutline{border:1.5px solid var(--border-strong);color:var(--text);background:0 0}.btnOutline:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.btnDanger{background:var(--danger);color:#fff}.btnGhost{color:var(--text-muted);background:0 0}.btnGhost:hover:not(:disabled){background:var(--bg);color:var(--text)}.btnSm{padding:6px 12px;font-size:.8rem}.btnLg{padding:14px 24px;font-size:1rem}.formGroup{margin-bottom:18px}.formLabel{color:var(--text);margin-bottom:6px;font-size:.85rem;font-weight:600;display:block}.formInput,.formSelect,.formTextarea{border:1.5px solid var(--border);border-radius:var(--radius);width:100%;color:var(--text);background:#fff;padding:10px 12px;transition:border-color .15s}.formInput:focus,.formSelect:focus,.formTextarea:focus{border-color:var(--accent);outline:none}.formTextarea{resize:vertical;min-height:100px;font-family:inherit}.formHint{color:var(--text-muted);margin-top:4px;font-size:.8rem}.formError{color:var(--danger);margin-top:4px;font-size:.8rem}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:20px}.cardHeader{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:12px;display:flex}.cardTitle{color:var(--primary);font-size:1.1rem;font-weight:700}.authPage{background:linear-gradient(135deg, var(--cream) 0%, var(--cream-light) 100%);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.authCard{background:var(--surface);border-radius:var(--radius-lg);width:100%;max-width:420px;box-shadow:var(--shadow-lg);padding:40px 32px}.authLogo{text-align:center;margin-bottom:24px}.authLogo h1{color:var(--primary);margin-bottom:4px;font-size:1.5rem}.authLogo p{color:var(--text-muted);font-size:.85rem}.appShell{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-width);background:var(--primary);color:#fff;z-index:50;flex-direction:column;height:100vh;transition:transform .2s;display:flex;position:fixed;top:0;left:0}.sidebarHeader{border-bottom:1px solid #ffffff1a;padding:20px}.sidebarHeader h2{margin:0;font-size:1.1rem}.sidebarHeader p{opacity:.7;margin:4px 0 0;font-size:.75rem}.sidebarNav{flex:1;padding:16px 0;overflow-y:auto}.sidebarNav a{color:#fffc;border-left:3px solid #0000;align-items:center;gap:12px;padding:11px 20px;font-size:.9rem;font-weight:500;transition:all .15s;display:flex}.sidebarNav a:hover{color:#fff;background:#ffffff0d}.sidebarNav a.active{color:#fff;border-left-color:var(--accent);background:#b8733326}.sidebarFooter{border-top:1px solid #ffffff1a;padding:16px 20px;font-size:.8rem}.sidebarFooter .userName{font-weight:600}.sidebarFooter .userRole{opacity:.7;margin-top:2px;font-size:.75rem}.mainContent{margin-left:var(--sidebar-width);flex-direction:column;flex:1;display:flex}.appHeader{height:var(--header-height);background:var(--surface);border-bottom:1px solid var(--border);z-index:40;justify-content:space-between;align-items:center;padding:0 24px;display:flex;position:sticky;top:0}.appHeader h1{color:var(--primary);font-size:1.2rem}.pageContent{flex:1;padding:24px}.mobileMenuBtn{padding:8px;display:none}@media (max-width:768px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.mainContent{margin-left:0}.mobileMenuBtn{display:block}.pageContent{padding:16px}}.pageHeader{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:20px;display:flex}.pageHeader h1{color:var(--primary);margin-bottom:4px;font-size:1.5rem}.pageHeader p{color:var(--text-muted);font-size:.9rem}.table{border-collapse:collapse;background:var(--surface);border-radius:var(--radius);width:100%;overflow:hidden}.table th,.table td{text-align:left;border-bottom:1px solid var(--border);padding:12px 14px}.table th{background:var(--bg);text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);font-size:.8rem;font-weight:600}.table tr:hover td{background:var(--bg)}.tableScroll{border-radius:var(--radius);border:1px solid var(--border);overflow-x:auto}.pill{text-transform:capitalize;border-radius:999px;padding:3px 10px;font-size:.75rem;font-weight:600;display:inline-block}.pillSuccess{background:var(--success-bg);color:var(--success)}.pillWarning{background:var(--warning-bg);color:var(--warning)}.pillDanger{background:var(--danger-bg);color:var(--danger)}.pillInfo{background:var(--info-bg);color:var(--info)}.pillNeutral{background:var(--bg);color:var(--text-muted)}.alert{border-radius:var(--radius);margin-bottom:16px;padding:12px 16px;font-size:.9rem}.alertSuccess{background:var(--success-bg);color:var(--success);border:1px solid var(--success)}.alertError{background:var(--danger-bg);color:var(--danger);border:1px solid var(--danger)}.alertInfo{background:var(--info-bg);color:var(--info);border:1px solid var(--info)}.alertWarning{background:var(--warning-bg);color:var(--warning);border:1px solid var(--warning)}.grid{gap:20px;display:grid}.grid2{grid-template-columns:repeat(2,1fr)}.grid3{grid-template-columns:repeat(3,1fr)}.grid4{grid-template-columns:repeat(4,1fr)}@media (max-width:768px){.grid2,.grid3,.grid4{grid-template-columns:1fr}}.statCard{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px}.statCard .statLabel{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;font-size:.8rem}.statCard .statValue{color:var(--primary);font-size:1.8rem;font-weight:700}.statCard .statHint{color:var(--text-muted);margin-top:6px;font-size:.8rem}.spinner{border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:20px;height:20px;animation:.8s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.emptyState{text-align:center;color:var(--text-muted);padding:48px 20px}.emptyState h3{color:var(--text);margin-bottom:8px}.srOnly{clip:rect(0,0,0,0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.flex{display:flex}.flexBetween{justify-content:space-between;align-items:center;display:flex}.flexGap{gap:12px;display:flex}.mt2{margin-top:8px}.mt4{margin-top:16px}.mt6{margin-top:24px}.mb2{margin-bottom:8px}.mb4{margin-bottom:16px}.mb6{margin-bottom:24px}.textCenter{text-align:center}.textMuted{color:var(--text-muted)}.textSmall{font-size:.85rem}.reportCard{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);color:inherit;padding:14px 16px;text-decoration:none;transition:border-color .15s,box-shadow .15s;display:block}.reportCard:hover{border-color:var(--accent);box-shadow:var(--shadow)}.reportCard:active{transform:scale(.995)}.reportCardTopRow{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:8px;display:flex}.reportShift{color:var(--primary);font-size:.95rem;font-weight:700}.reportWeather{color:var(--text-muted);font-size:.85rem}.reportWork{color:var(--text);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0 0 10px;line-height:1.4;display:-webkit-box;overflow:hidden}.reportMeta{color:var(--text-muted);flex-wrap:wrap;gap:14px;font-size:.82rem;display:flex}.shiftPicker{grid-template-columns:repeat(3,1fr);gap:10px;display:grid}@media (max-width:480px){.shiftPicker{grid-template-columns:1fr}}.shiftOption{border:2px solid var(--border);border-radius:var(--radius);background:var(--bg);cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:center;align-items:center;min-height:54px;padding:18px 12px;font-size:1rem;font-weight:600;transition:all .15s;display:flex;position:relative}.shiftOption:hover{border-color:var(--accent)}.shiftOptionActive{border-color:var(--accent);color:var(--primary);background:#b8733314}.weatherGrid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:8px;display:grid}.weatherChip{border:1.5px solid var(--border);border-radius:var(--radius);background:var(--bg);cursor:pointer;-webkit-user-select:none;user-select:none;text-align:center;justify-content:center;align-items:center;min-height:44px;padding:12px 10px;font-size:.9rem;transition:all .15s;display:flex;position:relative}.weatherChip:hover{border-color:var(--accent)}.weatherChipActive{border-color:var(--accent);color:var(--primary);background:#b8733314;font-weight:600}.bigNumInput{text-align:center;padding:14px 12px;font-size:1.25rem;font-weight:600}.photoActions{grid-template-columns:repeat(2,1fr);gap:10px;display:grid}.photoActionBtn{background:var(--primary);color:#fff;cursor:pointer;border-radius:var(--radius);white-space:nowrap;justify-content:center;align-items:center;gap:8px;min-height:56px;padding:16px 12px;font-size:1rem;display:flex}.photoActionBtn:hover{background:var(--primary-light)}.photoGrid{grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:8px;display:grid}.photoThumb{aspect-ratio:1;background:var(--bg);border-radius:var(--radius);border:1px solid var(--border);position:relative;overflow:hidden}.photoThumb img{object-fit:cover;width:100%;height:100%;display:block}.photoOverlay{color:#fff;background:#00000059;justify-content:center;align-items:center;font-size:1.2rem;display:flex;position:absolute;inset:0}.photoOverlayError{background:#ef4444a6}.photoRemoveBtn{color:#fff;cursor:pointer;background:#000000a6;border:none;border-radius:50%;justify-content:center;align-items:center;width:30px;height:30px;padding:0;font-size:.9rem;line-height:1;display:flex;position:absolute;top:4px;right:4px}.photoRemoveBtn:hover{background:var(--danger)}.lightbox{z-index:200;background:#000000e6;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.lightboxInner{flex-direction:column;align-items:center;gap:12px;max-width:100%;max-height:100%;display:flex}.lightboxInner img{object-fit:contain;border-radius:var(--radius);max-width:100%;max-height:85vh}.lightboxCaption{color:#ffffffd9;flex-wrap:wrap;justify-content:center;gap:16px;font-size:.85rem;display:flex}.lightboxClose{color:#fff;cursor:pointer;background:#ffffff26;border:none;border-radius:50%;width:44px;height:44px;font-size:1.4rem;position:absolute;top:12px;right:12px}.lightboxClose:hover{background:#ffffff4d}.lightboxNav{color:#fff;cursor:pointer;background:#ffffff26;border:none;border-radius:50%;width:48px;height:48px;font-size:2rem;line-height:1;position:absolute;top:50%;transform:translateY(-50%)}.lightboxNav:hover{background:#ffffff4d}.lightboxPrev{left:12px}.lightboxNext{right:12px}.formStickyBar{background:var(--surface);border-top:1px solid var(--border);z-index:10;gap:10px;margin-top:24px;padding:12px 0;display:flex;position:sticky;bottom:0}@media (max-width:768px){.formStickyBar{padding:10px 16px calc(10px + env(safe-area-inset-bottom));margin-top:0;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -2px 10px #0000000f}.siteReportForm{padding-bottom:90px}.formInput,.formSelect,.formTextarea{padding:12px 14px;font-size:16px}.btn{min-height:42px}.btnLg{min-height:48px}}
