/* =========================
   Akkordeon Plugin für moziloCMS
   Version 1.0.6
   29.04.2026
   ========================= */

.mz-akk-box {

  /* =================================================
     A) Überschreibbare Design-Variablen
     Diese Variablen bilden die öffentliche Styling-API.
     Sie dürfen von Modifikator-Klassen sowie in akk-custom.css
     überschrieben werden.
     ================================================= */

  /* Layout */
  --mz-akk-max-width: 64rem; /* Steuert die maximale Breite des gesamten Akkordeons */
  --mz-akk-gap: 1rem; /* Steuert den Abstand zwischen den Akkordeon-Items */

  /* Typografie */
  --mz-akk-font: system-ui, Arial, sans-serif; /* Definiert die Schriftfamilie des Akkordeons */
  --mz-akk-font-size: 1rem; /* Steuert die Grundschriftgröße des Akkordeons */
  --mz-akk-text: #1d1d1b; /* Steuert die Standard-Textfarbe */

  /* Farben */
  --mz-akk-bg: #ffffff; /* Steuert die Hintergrundfarbe der Items und des Inhaltsbereichs */
  --mz-akk-header-bg: #f5f5f3; /* Steuert die Hintergrundfarbe des Header-Bereichs */
  --mz-akk-header-bg-hover: #ecece8; /* Steuert die Hintergrundfarbe des Headers bei Hover */
  --mz-akk-border: #d4d4cf; /* Steuert die Rahmen- und Trennlinienfarbe */
  --mz-akk-focus: #1769ff; /* Steuert die Farbe der Fokusmarkierung (Keyboard-Navigation) */

  /* Frame */
  --mz-akk-radius: 10px; /* Steuert die Rundung der Item-Ecken */
  --mz-akk-shadow: 0 1px 2px rgba(0,0,0,.06); /* Steuert den Schatten der Akkordeon-Items */

  /* Header */
  --mz-akk-header-padding-y: 0.9rem; /* Steuert den vertikalen Innenabstand im Header */
  --mz-akk-header-padding-x: 1rem; /* Steuert den horizontalen Innenabstand im Header */

  /* Body */
  --mz-akk-body-padding-top: 0.9rem; /* Steuert den oberen Innenabstand des Inhaltsbereichs */
  --mz-akk-body-padding-right: 1rem; /* Steuert den rechten Innenabstand des Inhaltsbereichs */
  --mz-akk-body-padding-bottom: 1.8rem; /* Steuert den unteren Innenabstand des Inhaltsbereichs */
  --mz-akk-body-padding-left: 1rem; /* Steuert den linken Innenabstand des Inhaltsbereichs */
  --mz-akk-content-flow-space: 0.8rem; /* Steuert den vertikalen Abstand zwischen Inhaltselementen */

  /* Animation */
  --mz-akk-duration: 380ms; /* Steuert die Dauer der Öffnen-/Schließen-Animation */
  --mz-akk-ease: cubic-bezier(.2,.6,.2,1); /* Definiert die Timing-Funktion der Animation */

  /* Icons / Medien */
  --mz-akk-title-img-h: 2.5rem; /* Steuert die maximale Höhe von Bildern im Titelbereich */
  --mz-akk-icon-url: url("icons/dreieck.svg"); /* Definiert die Symbolgrafik vor dem Header-Titel */
  --mz-akk-icon-size: 1.5rem; /* Steuert die Größe des Header-Symbols */

  /* Sonstiges */
  --akk-scroll-offset: 64px; /* Steuert den Scroll-Abstand zum oberen Viewportrand bei automatischer Nachkorrektur */

  /* =================================================
     B) Feste Basisregeln
     Diese Regeln definieren das Grundlayout des Containers.
     Änderungen sollten bevorzugt über die Variablen erfolgen.
     ================================================= */

  max-width: var(--mz-akk-max-width);
  margin: 0 auto;

  font-family: var(--mz-akk-font);
  font-size: var(--mz-akk-font-size);
  color: var(--mz-akk-text);

  display: grid;
  gap: var(--mz-akk-gap);
}

.mz-akk-item {
  background: var(--mz-akk-bg);
  border: 1px solid var(--mz-akk-border);
  border-radius: var(--mz-akk-radius);
  box-shadow: var(--mz-akk-shadow);
  overflow: clip;
  position: relative;
  scroll-margin-top: var(--akk-scroll-offset, 16px);
}

.mz-akk-header {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  width: 100%;
  cursor: pointer;
  padding: var(--mz-akk-header-padding-y) var(--mz-akk-header-padding-x);
  background: var(--mz-akk-header-bg);
  border: 0;
  border-bottom: 1px solid var(--mz-akk-border);
  user-select: none;
  transition: background-color var(--mz-akk-duration) var(--mz-akk-ease);
  text-align: left;
  font: inherit;
  color: inherit;
}

.mz-akk-header:hover {
  background: var(--mz-akk-header-bg-hover);
}

.mz-akk-header:focus-visible {
  outline: 2px solid var(--mz-akk-focus);
  outline-offset: 2px;
  border-radius: calc(var(--mz-akk-radius) - 2px);
}

.mz-akk-header::before {
  content: "";
  display: block;
  width: var(--mz-akk-icon-size);
  height: var(--mz-akk-icon-size);
  flex: 0 0 var(--mz-akk-icon-size);
  align-self: center;
  background-image: var(--mz-akk-icon-url);
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  transition: transform var(--mz-akk-duration) var(--mz-akk-ease);
  opacity: 0.9;
}

.mz-akk-titlewrap {
  display: block;
  width: 100%;
  min-width: 0;
  flex: 1 1 auto;
  font-weight: 600;
}

.mz-akk-titlewrap img {
  max-height: var(--mz-akk-title-img-h);
  width: auto;
  display: block;
  margin-bottom: 0.2rem;
}

.mz-akk-titlewrap img + br {
  display: none;
}

.mz-akk-item.is-open .mz-akk-header::before {
  transform: rotate(90deg);
}

.mz-akk-body {
  max-height: 0;
  overflow: hidden;
  padding: 0;
  transition:
    max-height var(--mz-akk-duration) var(--mz-akk-ease),
    padding-top var(--mz-akk-duration) var(--mz-akk-ease),
    padding-right var(--mz-akk-duration) var(--mz-akk-ease),
    padding-bottom var(--mz-akk-duration) var(--mz-akk-ease),
    padding-left var(--mz-akk-duration) var(--mz-akk-ease);
  background: var(--mz-akk-bg);
}

.mz-akk-item.is-open .mz-akk-body {
  padding:
    var(--mz-akk-body-padding-top)
    var(--mz-akk-body-padding-right)
    var(--mz-akk-body-padding-bottom)
    var(--mz-akk-body-padding-left);
}

.mz-akk-body p {
  margin: 0 0 var(--mz-akk-content-flow-space) 0;
  line-height: 1.6;
}

.mz-akk-body ul,
.mz-akk-body ol {
  margin: 0 0 var(--mz-akk-content-flow-space) 1.2rem;
}

.mz-akk-body img,
.mz-akk-body video,
.mz-akk-body svg,
.mz-akk-body canvas,
.mz-akk-body iframe {
  max-width: 100%;
  height: auto;
  display: block;
  margin-top: 0.6rem;
}

/* -------------------------------------------------
   Entfernt automatisch erzeugte Rand-<br> von mozilo
   - vor erster Titelzeile
   - nach letzter Titelzeile
   - nach letzter Zeile im Inhalt
   ------------------------------------------------- */

.mz-akk-titlewrap > br:first-child,
.mz-akk-titlewrap > br:last-child,
.mz-akk-body > br:last-child {
  display: none;
}

.mz-akk-item:first-child .mz-akk-header {
  border-top-left-radius: var(--mz-akk-radius);
  border-top-right-radius: var(--mz-akk-radius);
}

.mz-akk-item:last-child .mz-akk-body {
  border-bottom-left-radius: var(--mz-akk-radius);
  border-bottom-right-radius: var(--mz-akk-radius);
}

@media (prefers-reduced-motion: reduce) {
  .mz-akk-header,
  .mz-akk-body {
    transition: none;
  }
}

/* =========================
   Modifikatoren
   Systematik:
   - layout-*  = Breite und Elementabstand
   - frame-*   = Rand, Radius, Schatten
   - theme-*   = Farbgestaltung
   - content-* = Anordnung / Luft im Inhaltsbereich
   ========================= */

/* -------------------------------------------------
   Layout
   Steuert Breite und Abstand zwischen den Elementen
   ------------------------------------------------- */

.mz-akk-box.akk-layout-small {
  --mz-akk-max-width: 42rem;
  --mz-akk-gap: 0.75rem;
}

.mz-akk-box.akk-layout-medium {
  --mz-akk-max-width: 64rem;
  --mz-akk-gap: 1rem;
}

.mz-akk-box.akk-layout-full {
  --mz-akk-max-width: 100%;
  --mz-akk-gap: 1rem;
}

/* -------------------------------------------------
   Modifikator – akk-layout-tile
   Kachelartige Darstellung:
   Symbol bleibt links, Bild/Text im Titelbereich
   sauber untereinander bzw. mit bildlinks nebeneinander
   ------------------------------------------------- */

.mz-akk-box.akk-layout-tile .mz-akk-header {
  align-items: center;
}

.mz-akk-box.akk-layout-tile .mz-akk-titlewrap {
  display: block;
  overflow: hidden;
}

.mz-akk-box.akk-layout-tile .mz-akk-titlewrap img {
  max-height: 8rem;
  width: auto;
  max-width: 100%;
  margin: 0 1rem 0.25rem 0;
}

.mz-akk-box.akk-layout-tile .mz-akk-titlewrap img + br {
  display: none;
}

/* -------------------------------------------------
   Frame
   Steuert Rahmen, Ecken und Schatten
   ------------------------------------------------- */

.mz-akk-box.akk-frame-square {
  --mz-akk-radius: 0;
}

.mz-akk-box.akk-frame-elevated {
  --mz-akk-shadow: 0 6px 18px rgba(0,0,0,.14);
}

/* -------------------------------------------------
   Theme
   Steuert die Farbgestaltung von Titel und Inhalt
   ------------------------------------------------- */

.mz-akk-box.akk-theme-sand {
  --mz-akk-bg: #fbf8ef;
  --mz-akk-header-bg: #f4eedf;
  --mz-akk-header-bg-hover: #ece3cd;
  --mz-akk-border: #d5c49a;
  --mz-akk-focus: #b78a1e;
  --mz-akk-text: #2f2617;
}

.mz-akk-box.akk-theme-dark {
  --mz-akk-bg: #111418;
  --mz-akk-header-bg: #1a1f26;
  --mz-akk-header-bg-hover: #222833;
  --mz-akk-border: #3a4352;
  --mz-akk-focus: #63a4ff;
  --mz-akk-text: #e9eef7;
}

/* -------------------------------------------------
   Content
   Steuert den Luft- und Leseraum im Inhaltsbereich
   Nur exemplarisch als erste content-* Klasse
   ------------------------------------------------- */

.mz-akk-box.akk-content-spacious {
  --mz-akk-body-padding-top: 1.2rem;
  --mz-akk-body-padding-right: 1.25rem;
  --mz-akk-body-padding-bottom: 1.8rem;
  --mz-akk-body-padding-left: 1.25rem;
  --mz-akk-content-flow-space: 1rem;
}

/* -------------------------------------------------
   Icons
   Steuert das Symbol im Header
   ------------------------------------------------- */

.mz-akk-box.akk-icon-klammer {
  --mz-akk-icon-url: url("icons/klammer.svg") !important;
}

.mz-akk-box.akk-icon-dreieck {
  --mz-akk-icon-url: url("icons/dreieck.svg") !important;
}

.mz-akk-box.akk-icon-pfeilkreis {
  --mz-akk-icon-url: url("icons/pfeilkreis.svg") !important;
}

.mz-akk-box.akk-icon-pfeil {
  --mz-akk-icon-url: url("icons/pfeil.svg") !important;
}

.mz-akk-box.akk-icon-dreieck-weiss {
  --mz-akk-icon-url: url("icons/dreieck-weiss.svg") !important;
}

/* Fehlerausgabe */

.mz-akk-errors {
  margin: 1rem 0;
}

.mz-akk-error {
  margin: 0 0 .5rem 0;
  padding: .85rem 1rem;
  border: 1px solid #dba3a3;
  border-left: 4px solid #b40000;
  background: #fff3f3;
  color: #7a1111;
  border-radius: 6px;
}