# 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 >> accordion
- Location: visual/mfc-corporate-de.spec.ts:30:9

# Error details

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

  7471 pixels (ratio 0.01 of all image pixels) are different.

  Snapshot: content-accordion.png

Call log:
  - Expect "toHaveScreenshot(content-accordion.png)" with timeout 15000ms
    - verifying given screenshot expectation
  - taking page screenshot
    - disabled all CSS animations
  - waiting for fonts to load...
  - fonts loaded
  - 7471 pixels (ratio 0.01 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
  - 7471 pixels (ratio 0.01 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: /
          - generic [ref=e16]: Accordion
  - main [ref=e17]:
    - generic [ref=e19]:
      - heading "Accordion (geschlossen)" [level=2] [ref=e21]
      - generic [ref=e22]:
        - group [ref=e23]:
          - generic "Accordion-Element 1" [ref=e24] [cursor=pointer]:
            - text: Accordion-Element 1
            - img [ref=e25]
        - group [ref=e27]:
          - generic "Accordion-Element 2" [ref=e28] [cursor=pointer]:
            - text: Accordion-Element 2
            - img [ref=e29]
        - group [ref=e31]:
          - generic "Accordion-Element 3" [ref=e32] [cursor=pointer]:
            - text: Accordion-Element 3
            - img [ref=e33]
    - generic [ref=e36]:
      - heading "Accordion (nur Text, erstes Element aktiv)" [level=2] [ref=e38]
      - generic [ref=e39]:
        - group [ref=e40]:
          - generic "Accordion-Element 1" [ref=e41] [cursor=pointer]:
            - text: Accordion-Element 1
            - img [ref=e42]
          - paragraph [ref=e47]: 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 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.
        - group [ref=e48]:
          - generic "Accordion-Element 2" [ref=e49] [cursor=pointer]:
            - text: Accordion-Element 2
            - img [ref=e50]
        - group [ref=e52]:
          - generic "Accordion-Element 3" [ref=e53] [cursor=pointer]:
            - text: Accordion-Element 3
            - img [ref=e54]
    - generic [ref=e57]:
      - 'heading "Erstes Accordion-Element aktiv: Bildausrichtung links" [level=2] [ref=e59]'
      - generic [ref=e60]:
        - group [ref=e61]:
          - generic "1 Bild links" [ref=e62] [cursor=pointer]:
            - text: 1 Bild links
            - img [ref=e63]
          - generic [ref=e66]:
            - figure [ref=e70]:
              - link "Zeige größere Version" [ref=e71] [cursor=pointer]:
                - /url: /fileadmin/_processed_/2/b/csm_dummy-1600x1000-FairyLights-plain_04e01dbade.jpg
                - generic [ref=e72]: Zeige größere Version
            - paragraph [ref=e75]: 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 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.
        - group [ref=e76]:
          - generic "1 Bild rechts" [ref=e77] [cursor=pointer]:
            - text: 1 Bild rechts
            - img [ref=e78]
        - group [ref=e80]:
          - generic "2 Bilder oben" [ref=e81] [cursor=pointer]:
            - text: 2 Bilder oben
            - img [ref=e82]
        - group [ref=e84]:
          - generic "1 Bild unten" [ref=e85] [cursor=pointer]:
            - text: 1 Bild unten
            - img [ref=e86]
    - generic [ref=e89]:
      - 'heading "Zweites Accordion-Element aktiv: Bildausrichtung rechts" [level=2] [ref=e91]'
      - generic [ref=e92]:
        - group [ref=e93]:
          - generic "1 Bild links" [ref=e94] [cursor=pointer]:
            - text: 1 Bild links
            - img [ref=e95]
        - group [ref=e97]:
          - generic "1 Bild rechts" [ref=e98] [cursor=pointer]:
            - text: 1 Bild rechts
            - img [ref=e99]
          - generic [ref=e102]:
            - figure [ref=e106]
            - generic [ref=e108]:
              - paragraph [ref=e109]: Lorem ipsum dolor sit amet, consetetur sadipscing elitr, sed diam nonumy eirmod tempor invidunt ut labore et dolore magna aliquyam erat, sed diam voluptua.
              - paragraph [ref=e110]: 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 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.
        - group [ref=e111]:
          - generic "2 Bilder oben" [ref=e112] [cursor=pointer]:
            - text: 2 Bilder oben
            - img [ref=e113]
        - group [ref=e115]:
          - generic "1 Bild unten" [ref=e116] [cursor=pointer]:
            - text: 1 Bild unten
            - img [ref=e117]
    - generic [ref=e120]:
      - 'heading "Drittes Accordion-Element aktiv: Bildausrichtung oben" [level=2] [ref=e122]'
      - generic [ref=e123]:
        - group [ref=e124]:
          - generic "1 Bild links" [ref=e125] [cursor=pointer]:
            - text: 1 Bild links
            - img [ref=e126]
        - group [ref=e128]:
          - generic "1 Bild rechts" [ref=e129] [cursor=pointer]:
            - text: 1 Bild rechts
            - img [ref=e130]
        - group [ref=e132]:
          - generic "2 Bilder oben" [ref=e133] [cursor=pointer]:
            - text: 2 Bilder oben
            - img [ref=e134]
          - generic [ref=e137]:
            - generic [ref=e139]:
              - figure [ref=e141]:
                - link "Zeige größere Version" [ref=e142] [cursor=pointer]:
                  - /url: /fileadmin/_processed_/d/1/csm_dummy-1600x1000-DesiccationCracks-plain_df5005429d.jpg
                  - generic [ref=e143]: Zeige größere Version
              - figure [ref=e146]:
                - link "Zeige größere Version" [ref=e147] [cursor=pointer]:
                  - /url: /fileadmin/_processed_/4/9/csm_dummy-1600x1000-RedDots-plain_def88c9059.jpg
                  - generic [ref=e148]: Zeige größere Version
            - paragraph [ref=e151]: 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 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.
        - group [ref=e152]:
          - generic "1 Bild unten" [ref=e153] [cursor=pointer]:
            - text: 1 Bild unten
            - img [ref=e154]
    - generic [ref=e157]:
      - 'heading "Viertes Accordion-Element aktiv: Bildausrichtung unten" [level=2] [ref=e159]'
      - generic [ref=e160]:
        - group [ref=e161]:
          - generic "1 Bild links" [ref=e162] [cursor=pointer]:
            - text: 1 Bild links
            - img [ref=e163]
        - group [ref=e165]:
          - generic "1 Bild rechts" [ref=e166] [cursor=pointer]:
            - text: 1 Bild rechts
            - img [ref=e167]
        - group [ref=e169]:
          - generic "2 Bilder oben" [ref=e170] [cursor=pointer]:
            - text: 2 Bilder oben
            - img [ref=e171]
        - group [ref=e173]:
          - generic "1 Bild unten" [ref=e174] [cursor=pointer]:
            - text: 1 Bild unten
            - img [ref=e175]
          - generic [ref=e178]:
            - figure [ref=e182]
            - paragraph [ref=e185]: 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 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.
    - generic [ref=e187]:
      - 'heading "Viertes Accordion-Element aktiv: Bildausrichtung unten (1 Bild, zwei Bildspalten)" [level=2] [ref=e189]'
      - generic [ref=e190]:
        - group [ref=e191]:
          - generic "1 Bild links" [ref=e192] [cursor=pointer]:
            - text: 1 Bild links
            - img [ref=e193]
        - group [ref=e195]:
          - generic "1 Bild rechts" [ref=e196] [cursor=pointer]:
            - text: 1 Bild rechts
            - img [ref=e197]
        - group [ref=e199]:
          - generic "2 Bilder oben" [ref=e200] [cursor=pointer]:
            - text: 2 Bilder oben
            - img [ref=e201]
        - group [ref=e203]:
          - generic "1 Bild unten (2 Bildspalten)" [ref=e204] [cursor=pointer]:
            - text: 1 Bild unten (2 Bildspalten)
            - img [ref=e205]
          - generic [ref=e208]:
            - figure [ref=e212]
            - paragraph [ref=e215]: 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 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.
  - contentinfo [ref=e216]:
    - generic [ref=e219]:
      - navigation [ref=e220]:
        - list [ref=e221]:
          - listitem [ref=e222]:
            - button "Cookie-Einstellungen" [ref=e223] [cursor=pointer]
          - listitem [ref=e224]:
            - link "Datenschutzerklärung" [ref=e225] [cursor=pointer]:
              - /url: https://www.marketing-factory.de/datenschutzerklaerung/
          - listitem [ref=e226]:
            - link "Impressum" [ref=e227] [cursor=pointer]:
              - /url: https://www.marketing-factory.de/impressum/
      - generic [ref=e228]:
        - paragraph [ref=e229]: © Marketing Factory Digital GmbH
        - paragraph [ref=e230]:
          - text: Alternativtexte für Bilder sind teilweise
          - link "KI-generiert" [ref=e231] [cursor=pointer]:
            - /url: https://www.marketing-factory.de/technologie/typo3/unsere-typo3-extensions/ai-filemetadata/
    - generic [ref=e234]:
      - strong [ref=e235]: Bildnachweise
      - list
```

# Test source

```ts
  1   | import { test, expect } from '@playwright/test';
  2   | import { setup, scrollToBottom, setDarkTheme, hideElements } from '../helpers/utils';
  3   | 
  4   | const PAGE_HEADER = ['.c-page-header'];
  5   | const snap = (name: string) => ({ name: `${name}.png`, fullPage: true } as const);
  6   | 
  7   | test.describe('other', () => {
  8   |     test('styling', async ({ page }) => {
  9   |         await setup(page, '/design-basiseigenschaften/');
  10  |         await page.waitForTimeout(2000);
  11  |         await expect(page).toHaveScreenshot(snap('other-styling'));
  12  |         await setDarkTheme(page);
  13  |         await expect(page).toHaveScreenshot(snap('other-styling-dark'));
  14  |     });
  15  | 
  16  |     test('rte', async ({ page }) => {
  17  |         await setup(page, '/richtext-editor/');
  18  |         await expect(page).toHaveScreenshot(snap('other-rte'));
  19  |         await setDarkTheme(page);
  20  |         await expect(page).toHaveScreenshot(snap('other-rte-dark'));
  21  |     });
  22  | 
  23  |     test('rte-syntax-highlighting', async ({ page }) => {
  24  |         await setup(page, '/richtext-editor/syntax-highlighting/');
  25  |         await expect(page).toHaveScreenshot(snap('other-rte-syntax-highlighting'));
  26  |     });
  27  | });
  28  | 
  29  | test.describe('content', () => {
  30  |     test('accordion', async ({ page }) => {
  31  |         await setup(page, '/inhaltselemente/accordion/');
  32  |         await hideElements(page, PAGE_HEADER);
  33  |         await scrollToBottom(page);
> 34  |         await expect(page).toHaveScreenshot(snap('content-accordion'));
      |                            ^ Error: expect(page).toHaveScreenshot(expected) failed
  35  |     });
  36  | 
  37  |     test('keyvisual', async ({ page }) => {
  38  |         await setup(page, '/inhaltselemente/keyvisual/');
  39  |         await expect(page).toHaveScreenshot(snap('content-keyvisual'));
  40  |         await setDarkTheme(page);
  41  |         await expect(page).toHaveScreenshot(snap('content-keyvisual-dark'));
  42  |     });
  43  | 
  44  |     test('hero-image', async ({ page }) => {
  45  |         await setup(page, '/inhaltselemente/hero-image/');
  46  |         await expect(page).toHaveScreenshot(snap('content-hero-image'));
  47  |     });
  48  | 
  49  |     test('slider-slide2grid', async ({ page }) => {
  50  |         await setup(page, '/inhaltselemente/slider-slide2grid/');
  51  |         await expect(page).toHaveScreenshot(snap('content-slider-slide2grid'));
  52  |         await setDarkTheme(page);
  53  |         await expect(page).toHaveScreenshot(snap('content-slider-slide2grid-dark'));
  54  |     });
  55  | 
  56  |     test('comparison-module', async ({ page }) => {
  57  |         await setup(page, '/inhaltselemente/comparison-modul/');
  58  |         await page.locator('.o-radio-switch__label[for=switchLeft]').click();
  59  |         await page.waitForTimeout(2000);
  60  |         await expect(page).toHaveScreenshot(snap('content-comparison-module-left'));
  61  |         await page.locator('.o-radio-switch__label[for=switchRight]').click();
  62  |         await page.waitForTimeout(2000);
  63  |         await expect(page).toHaveScreenshot(snap('content-comparison-module-right'));
  64  |         await setDarkTheme(page);
  65  |         await expect(page).toHaveScreenshot(snap('content-comparison-module-dark'));
  66  |     });
  67  | 
  68  |     test('text-full-height-image', async ({ page }) => {
  69  |         await setup(page, '/inhaltselemente/text-full-height-image/');
  70  |         await hideElements(page, PAGE_HEADER);
  71  |         await scrollToBottom(page);
  72  |         await expect(page).toHaveScreenshot(snap('content-text-full-height-image'));
  73  |     });
  74  | 
  75  |     test('timeline', async ({ page }) => {
  76  |         await setup(page, '/inhaltselemente/timeline/');
  77  |         await hideElements(page, PAGE_HEADER);
  78  |         await scrollToBottom(page);
  79  |         await expect(page).toHaveScreenshot(snap('content-timeline'));
  80  |     });
  81  | 
  82  |     test('divider', async ({ page }) => {
  83  |         await setup(page, '/inhaltselemente/divider/');
  84  |         await expect(page).toHaveScreenshot(snap('content-divider'));
  85  |     });
  86  | 
  87  |     test('container', async ({ page }) => {
  88  |         await setup(page, '/inhaltselemente/container/');
  89  |         await hideElements(page, PAGE_HEADER);
  90  |         await scrollToBottom(page);
  91  |         await expect(page).toHaveScreenshot(snap('content-container'));
  92  |     });
  93  | 
  94  |     test('card-group', async ({ page }) => {
  95  |         await setup(page, '/inhaltselemente/card-group/');
  96  |         await expect(page).toHaveScreenshot(snap('content-card-group'));
  97  |     });
  98  | 
  99  |     test('quote', async ({ page }) => {
  100 |         await setup(page, '/inhaltselemente/quote/');
  101 |         await expect(page).toHaveScreenshot(snap('content-quote'));
  102 |     });
  103 | 
  104 |     test('text-icon', async ({ page }) => {
  105 |         await setup(page, '/inhaltselemente/text-icon/');
  106 |         await expect(page).toHaveScreenshot(snap('content-text-icon'));
  107 |         await setDarkTheme(page);
  108 |         await expect(page).toHaveScreenshot(snap('content-text-icon-dark'));
  109 |     });
  110 | 
  111 |     test('text-in-columns', async ({ page }) => {
  112 |         await setup(page, '/inhaltselemente/text-in-columns/');
  113 |         await expect(page).toHaveScreenshot(snap('content-text-in-columns'));
  114 |     });
  115 | 
  116 |     test('menu-sitemap', async ({ page }) => {
  117 |         await setup(page, '/inhaltselemente/menu-sitemap/');
  118 |         await expect(page).toHaveScreenshot(snap('content-menu-sitemap'));
  119 |     });
  120 | 
  121 |     test('menu-section', async ({ page }) => {
  122 |         await setup(page, '/inhaltselemente/menu-section/');
  123 |         await expect(page).toHaveScreenshot(snap('content-menu-section'));
  124 |     });
  125 | 
  126 |     test('menu-pages', async ({ page }) => {
  127 |         await setup(page, '/inhaltselemente/menu-pages/');
  128 |         await expect(page).toHaveScreenshot(snap('content-menu-pages'));
  129 |     });
  130 | 
  131 |     test('space-before-after', async ({ page }) => {
  132 |         await setup(page, '/inhaltselemente/space-before-after/');
  133 |         await expect(page).toHaveScreenshot(snap('content-space-before-after'));
  134 |     });
```