{"time": "2026-05-13T21:08:33.004387+00:00", "step": "scrape_start", "week_start": "2026-05-11"} {"time": "2026-05-13T21:08:33.444281+00:00", "step": "loaded_session", "file": "storage/sessions/teamhours_state.json"} {"time": "2026-05-13T21:08:33.549268+00:00", "step": "open_rota", "url": "https://greeneking.teamhours.com/ScheduleHotels#/schedule/weekly/"} {"time": "2026-05-13T21:08:38.599343+00:00", "step": "week_selector_not_found", "week_start": "2026-05-11"} {"time": "2026-05-13T21:08:38.606660+00:00", "step": "rota_week_confirmed_from_page_text", "week_start": "2026-05-11"} {"time": "2026-05-13T21:08:42.608287+00:00", "step": "teamhours_dom_rota_collected", "rows": 264, "employees": 48} {"time": "2026-05-13T21:08:42.650383+00:00", "step": "rota_parsed", "rows": 264, "tables": 0} {"time": "2026-05-13T21:08:42.650492+00:00", "step": "open_forecast", "url": "https://greeneking.teamhours.com/Forecast/Weekly/"} {"time": "2026-05-13T21:08:46.115789+00:00", "step": "week_selector_not_found", "week_start": "2026-05-11"} {"time": "2026-05-13T21:08:46.118700+00:00", "step": "forecast_week_confirmed_from_page_text", "week_start": "2026-05-11"} {"time": "2026-05-13T21:08:46.135272+00:00", "step": "forecast_parsed", "rows": 7, "tables": 1} {"time": "2026-05-13T21:08:46.194909+00:00", "step": "scrape_complete", "output_file": "storage/cache/teamhours_2026-05-11.json"}