# Instructions

- Following Playwright test failed.
- Explain why, be concise, respect Playwright best practices.
- Provide a snippet of code with the fix, if possible.

# Test info

- Name: mfc-corporate-de.spec.ts >> content › textmedia › local-videos >> 1-video-beside-text-centered
- Location: visual/mfc-corporate-de.spec.ts:305:9

# Error details

```
Error: expect(page).toHaveScreenshot(expected) failed

  10987 pixels (ratio 0.02 of all image pixels) are different.

  Snapshot: content-textmedia-local-1-video-beside-text-centered.png

Call log:
  - Expect "toHaveScreenshot(content-textmedia-local-1-video-beside-text-centered.png)" with timeout 15000ms
    - verifying given screenshot expectation
  - taking page screenshot
    - disabled all CSS animations
  - waiting for fonts to load...
  - fonts loaded
  - 10987 pixels (ratio 0.02 of all image pixels) are different.
  - waiting 100ms before taking screenshot
  - taking page screenshot
    - disabled all CSS animations
  - waiting for fonts to load...
  - fonts loaded
  - captured a stable screenshot
  - 10987 pixels (ratio 0.02 of all image pixels) are different.

```

# Page snapshot

```yaml
- generic [ref=e2]:
  - link "Zum Inhalt springen" [ref=e3] [cursor=pointer]:
    - /url: "#page-content"
  - navigation "Brotkrumen-Navigation" [ref=e4]:
    - generic [ref=e5]:
      - paragraph [ref=e6]: "Sie sind here:"
      - list [ref=e7]:
        - listitem [ref=e8]:
          - link "Startseite" [ref=e9] [cursor=pointer]:
            - /url: /
            - img [ref=e10]
        - listitem [ref=e12]:
          - text: /
          - link "Inhaltselemente" [ref=e13] [cursor=pointer]:
            - /url: /inhaltselemente/
            - generic [ref=e14]: Inhaltselemente
        - listitem [ref=e15]:
          - text: /
          - link "Textmedia" [ref=e16] [cursor=pointer]:
            - /url: /inhaltselemente/textmedia/
            - generic [ref=e17]: Textmedia
        - listitem [ref=e18]:
          - text: /
          - link "Videos (lokal gehostet)" [ref=e19] [cursor=pointer]:
            - /url: /inhaltselemente/textmedia/videos-lokal-gehostet/
            - generic [ref=e20]: Videos (lokal gehostet)
        - listitem [ref=e21]:
          - text: /
          - generic [ref=e22]: 1 Video, neben Text zentriert
  - main [ref=e23]:
    - generic [ref=e26]:
      - figure [ref=e30]
      - generic [ref=e33]:
        - heading "Video, Neben Text, zentriert links" [level=3] [ref=e35]
        - paragraph [ref=e36]: Lorem ipsum dolor sit amet, consetetur sadipscing elitr, sed diam nonumy eirmod tempor invidunt ut labore et dolore magna aliquyam erat, sed diam voluptua. At vero eos et accusam et justo duo dolores et ea rebum. Stet clita kasd gubergren, no sea takimata sanctus est Lorem ipsum dolor sit amet. Lorem ipsum dolor sit amet, consetetur sadipscing elitr, sed diam nonumy eirmod tempor invidunt.
    - generic [ref=e39]:
      - figure [ref=e43]
      - generic [ref=e46]:
        - heading "Video, Neben Text, zentriert rechts" [level=3] [ref=e48]
        - paragraph [ref=e49]: Lorem ipsum dolor sit amet, consetetur sadipscing elitr, sed diam nonumy eirmod tempor invidunt ut labore et dolore magna aliquyam erat, sed diam voluptua. At vero eos et accusam et justo duo dolores et ea rebum. Stet clita kasd gubergren, no sea takimata sanctus est Lorem ipsum dolor sit amet. Lorem ipsum dolor sit amet, consetetur sadipscing elitr, sed diam nonumy eirmod tempor invidunt.
  - contentinfo [ref=e50]:
    - generic [ref=e53]:
      - navigation [ref=e54]:
        - list [ref=e55]:
          - listitem [ref=e56]:
            - button "Cookie-Einstellungen" [ref=e57] [cursor=pointer]
          - listitem [ref=e58]:
            - link "Datenschutzerklärung" [ref=e59] [cursor=pointer]:
              - /url: https://www.marketing-factory.de/datenschutzerklaerung/
          - listitem [ref=e60]:
            - link "Impressum" [ref=e61] [cursor=pointer]:
              - /url: https://www.marketing-factory.de/impressum/
      - generic [ref=e62]:
        - paragraph [ref=e63]: © Marketing Factory Digital GmbH
        - paragraph [ref=e64]:
          - text: Alternativtexte für Bilder sind teilweise
          - link "KI-generiert" [ref=e65] [cursor=pointer]:
            - /url: https://www.marketing-factory.de/technologie/typo3/unsere-typo3-extensions/ai-filemetadata/
    - generic [ref=e68]:
      - strong [ref=e69]: Bildnachweise
      - list
```

# Test source

```ts
  209 |         await setDarkTheme(page);
  210 |         await expect(page).toHaveScreenshot(snap('content-textmedia-svg-1-image-beside-text-dark'));
  211 |     });
  212 | 
  213 |     test('2-images-top-bottom-centered', async ({ page }) => {
  214 |         await setup(page, '/inhaltselemente/textmedia/svg-bilder/2-bilder-oben-unten-zentriert/');
  215 |         await expect(page).toHaveScreenshot(snap('content-textmedia-svg-2-images-top-bottom-centered'));
  216 |     });
  217 | 
  218 |     test('2-images-beside-text-centered', async ({ page }) => {
  219 |         await setup(page, '/inhaltselemente/textmedia/svg-bilder/2-bilder-neben-text-zentriert/');
  220 |         await expect(page).toHaveScreenshot(snap('content-textmedia-svg-2-images-beside-text-centered'));
  221 |     });
  222 | 
  223 |     test('2-images-beside-text', async ({ page }) => {
  224 |         await setup(page, '/inhaltselemente/textmedia/svg-bilder/2-bilder-neben-text/');
  225 |         await expect(page).toHaveScreenshot(snap('content-textmedia-svg-2-images-beside-text'));
  226 |     });
  227 | 
  228 |     test('1-image-beside-text-centered-33-percent', async ({ page }) => {
  229 |         await setup(page, '/inhaltselemente/textmedia/svg-bilder/1-bild-neben-text-zentriert-33-bildbreite/');
  230 |         await expect(page).toHaveScreenshot(snap('content-textmedia-svg-1-image-beside-text-centered-33-percent'));
  231 |     });
  232 | 
  233 |     test('1-image-beside-text-33-percent', async ({ page }) => {
  234 |         await setup(page, '/inhaltselemente/textmedia/svg-bilder/1-bild-neben-text-33-bildbreite/');
  235 |         await expect(page).toHaveScreenshot(snap('content-textmedia-svg-1-image-beside-text-33-percent'));
  236 |     });
  237 | });
  238 | 
  239 | test.describe('content › textmedia › extern-videos', () => {
  240 |     test('1-video-top-bottom-centered', async ({ page }) => {
  241 |         await setup(page, '/inhaltselemente/textmedia/videos-extern/1-video-oben-unten-zentriert/');
  242 |         await hideElements(page, PAGE_HEADER);
  243 |         await scrollToBottom(page);
  244 |         await expect(page).toHaveScreenshot(snap('content-textmedia-extern-1-video-top-bottom-centered'));
  245 |     });
  246 | 
  247 |     test('1-video-beside-text-centered', async ({ page }) => {
  248 |         await setup(page, '/inhaltselemente/textmedia/videos-extern/1-video-neben-text-zentriert/');
  249 |         await hideElements(page, PAGE_HEADER);
  250 |         await scrollToBottom(page);
  251 |         await expect(page).toHaveScreenshot(snap('content-textmedia-extern-1-video-beside-text-centered'));
  252 |     });
  253 | 
  254 |     test('1-video-beside-text', async ({ page }) => {
  255 |         await setup(page, '/inhaltselemente/textmedia/videos-extern/1-video-neben-text/');
  256 |         await hideElements(page, PAGE_HEADER);
  257 |         await scrollToBottom(page);
  258 |         await expect(page).toHaveScreenshot(snap('content-textmedia-extern-1-video-beside-text'));
  259 |     });
  260 | 
  261 |     test('2-videos-top-bottom-centered', async ({ page }) => {
  262 |         await setup(page, '/inhaltselemente/textmedia/videos-extern/2-videos-oben-unten-zentriert/');
  263 |         await hideElements(page, PAGE_HEADER);
  264 |         await scrollToBottom(page);
  265 |         await expect(page).toHaveScreenshot(snap('content-textmedia-extern-2-videos-top-bottom-centered'));
  266 |     });
  267 | 
  268 |     test('2-videos-beside-text-centered', async ({ page }) => {
  269 |         await setup(page, '/inhaltselemente/textmedia/videos-extern/2-videos-neben-text-zentriert/');
  270 |         await hideElements(page, PAGE_HEADER);
  271 |         await scrollToBottom(page);
  272 |         await expect(page).toHaveScreenshot(snap('content-textmedia-extern-2-videos-beside-text-centered'));
  273 |     });
  274 | 
  275 |     test('2-videos-beside-text', async ({ page }) => {
  276 |         await setup(page, '/inhaltselemente/textmedia/videos-extern/2-videos-neben-text/');
  277 |         await hideElements(page, PAGE_HEADER);
  278 |         await scrollToBottom(page);
  279 |         await expect(page).toHaveScreenshot(snap('content-textmedia-extern-2-videos-beside-text'));
  280 |     });
  281 | 
  282 |     test('1-video-beside-text-centered-33-percent', async ({ page }) => {
  283 |         await setup(page, '/inhaltselemente/textmedia/videos-extern/1-video-neben-text-zentriert-33-bildbreite/');
  284 |         await hideElements(page, PAGE_HEADER);
  285 |         await scrollToBottom(page);
  286 |         await expect(page).toHaveScreenshot(snap('content-textmedia-extern-1-video-beside-text-centered-33-percent'));
  287 |     });
  288 | 
  289 |     test('1-video-beside-text-33-percent', async ({ page }) => {
  290 |         await setup(page, '/inhaltselemente/textmedia/videos-extern/1-video-neben-text-33-bildbreite/');
  291 |         await hideElements(page, PAGE_HEADER);
  292 |         await scrollToBottom(page);
  293 |         await expect(page).toHaveScreenshot(snap('content-textmedia-extern-1-video-beside-text-33-percent'));
  294 |     });
  295 | });
  296 | 
  297 | test.describe('content › textmedia › local-videos', () => {
  298 |     test('1-video-top-bottom-centered', async ({ page }) => {
  299 |         await setup(page, '/inhaltselemente/textmedia/videos-lokal-gehostet/1-video-oben-unten-zentriert/');
  300 |         await hideElements(page, PAGE_HEADER);
  301 |         await scrollToBottom(page);
  302 |         await expect(page).toHaveScreenshot(snap('content-textmedia-local-1-video-top-bottom-centered'));
  303 |     });
  304 | 
  305 |     test('1-video-beside-text-centered', async ({ page }) => {
  306 |         await setup(page, '/inhaltselemente/textmedia/videos-lokal-gehostet/1-video-neben-text-zentriert/');
  307 |         await hideElements(page, PAGE_HEADER);
  308 |         await scrollToBottom(page);
> 309 |         await expect(page).toHaveScreenshot(snap('content-textmedia-local-1-video-beside-text-centered'));
      |                            ^ Error: expect(page).toHaveScreenshot(expected) failed
  310 |     });
  311 | 
  312 |     test('1-video-beside-text', async ({ page }) => {
  313 |         await setup(page, '/inhaltselemente/textmedia/videos-lokal-gehostet/1-video-neben-text/');
  314 |         await hideElements(page, PAGE_HEADER);
  315 |         await scrollToBottom(page);
  316 |         await expect(page).toHaveScreenshot(snap('content-textmedia-local-1-video-beside-text'));
  317 |     });
  318 | 
  319 |     test('2-videos-top-bottom-centered', async ({ page }) => {
  320 |         await setup(page, '/inhaltselemente/textmedia/videos-lokal-gehostet/2-videos-oben-unten-zentriert/');
  321 |         await hideElements(page, PAGE_HEADER);
  322 |         await scrollToBottom(page);
  323 |         await expect(page).toHaveScreenshot(snap('content-textmedia-local-2-videos-top-bottom-centered'));
  324 |     });
  325 | 
  326 |     test('2-videos-beside-text-centered', async ({ page }) => {
  327 |         await setup(page, '/inhaltselemente/textmedia/videos-lokal-gehostet/2-videos-neben-text-zentriert/');
  328 |         await hideElements(page, PAGE_HEADER);
  329 |         await scrollToBottom(page);
  330 |         await expect(page).toHaveScreenshot(snap('content-textmedia-local-2-videos-beside-text-centered'));
  331 |     });
  332 | 
  333 |     test('2-videos-beside-text', async ({ page }) => {
  334 |         await setup(page, '/inhaltselemente/textmedia/videos-lokal-gehostet/2-videos-neben-text/');
  335 |         await hideElements(page, PAGE_HEADER);
  336 |         await scrollToBottom(page);
  337 |         await expect(page).toHaveScreenshot(snap('content-textmedia-local-2-videos-beside-text'));
  338 |     });
  339 | 
  340 |     test('1-video-beside-text-centered-33-percent', async ({ page }) => {
  341 |         await setup(page, '/inhaltselemente/textmedia/videos-lokal-gehostet/1-video-neben-text-zentriert-33-bildbreite/');
  342 |         await hideElements(page, PAGE_HEADER);
  343 |         await scrollToBottom(page);
  344 |         await expect(page).toHaveScreenshot(snap('content-textmedia-local-1-video-beside-text-centered-33-percent'));
  345 |     });
  346 | 
  347 |     test('1-video-beside-text-33-percent', async ({ page }) => {
  348 |         await setup(page, '/inhaltselemente/textmedia/videos-lokal-gehostet/1-video-neben-text-33-bildbreite/');
  349 |         await hideElements(page, PAGE_HEADER);
  350 |         await scrollToBottom(page);
  351 |         await expect(page).toHaveScreenshot(snap('content-textmedia-local-1-video-beside-text-33-percent'));
  352 |     });
  353 | });
  354 | 
  355 | test.describe('page-types', () => {
  356 |     test('search', async ({ page }) => {
  357 |         await setup(page, '/seitentypen/suche/?tx_solr%5Bq%5D=obermeyer');
  358 |         await expect(page).toHaveScreenshot(snap('page-type-search'));
  359 |     });
  360 | 
  361 |     test('client-list', async ({ page }) => {
  362 |         await setup(page, '/seitentypen/kunden-listenansicht/');
  363 |         await expect(page).toHaveScreenshot(snap('page-type-client-list'));
  364 |     });
  365 | 
  366 |     test('client-pfm', async ({ page }) => {
  367 |         await setup(page, '/seitentypen/kunden-listenansicht/pfm-medical-sg/');
  368 |         await expect(page).toHaveScreenshot(snap('page-type-client-pfm'));
  369 |     });
  370 | });
  371 | 
  372 | test.describe('plugins', () => {
  373 |     test('project-list', async ({ page }) => {
  374 |         await setup(page, '/plugins/projekt-liste/');
  375 |         await expect(page).toHaveScreenshot(snap('plugin-project-list'));
  376 |     });
  377 | 
  378 |     test('project-obermeyer-corporate', async ({ page }) => {
  379 |         await setup(page, '/seitentypen/kunden-listenansicht/obermeyer-sg/launch-der-neuen-corporate-site-der-unternehmensgruppe-obermeyer-sg/');
  380 |         await hideElements(page, PAGE_HEADER);
  381 |         await scrollToBottom(page);
  382 |         await expect(page).toHaveScreenshot(snap('plugin-project-obermeyer-corporate'));
  383 |     });
  384 | 
  385 |     test('picturecredits', async ({ page }) => {
  386 |         await setup(page, '/plugins/picturecredits/');
  387 |         await expect(page).toHaveScreenshot(snap('plugin-picturecredits'));
  388 |     });
  389 | });
  390 | 
  391 | test.describe('blog', () => {
  392 |     test('overview', async ({ page }) => {
  393 |         await setup(page, '/blog/');
  394 |         await hideElements(page, PAGE_HEADER);
  395 |         await scrollToBottom(page);
  396 |         await expect(page).toHaveScreenshot(snap('blog-overview'));
  397 |         await setDarkTheme(page);
  398 |         await expect(page).toHaveScreenshot(snap('blog-overview-dark'));
  399 |     });
  400 | 
  401 |     test('list-authors', async ({ page }) => {
  402 |         await setup(page, '/blog/autoren/');
  403 |         await expect(page).toHaveScreenshot(snap('blog-list-authors'));
  404 |     });
  405 | 
  406 |     test('author', async ({ page }) => {
  407 |         await setup(page, '/blog/autoren/max-powers/');
  408 |         await expect(page).toHaveScreenshot(snap('blog-author'));
  409 |     });
```