/* =========================
   Akkordeon Plugin für moziloCMS
   Version 1.0
   ========================= */

.mz-akk-box {

  /* =========================
     Layout
     ========================= */
  --mz-akk-max-width: 64rem;
  --mz-akk-gap: 1rem;

  /* =========================
     Typografie
     ========================= */
  --mz-akk-font: system-ui, Arial, sans-serif;
  --mz-akk-font-size: 1rem;
  --mz-akk-text: #1d1d1b;

  /* =========================
     Farben (neutraler Default)
     ========================= */
  --mz-akk-bg: #ffffff;
  --mz-akk-header-bg: #f5f5f3;
  --mz-akk-header-bg-hover: #ecece8;
  --mz-akk-border: #d4d4cf;
  --mz-akk-focus: #1769ff;

  /* =========================
     Frame (Rand, Radius, Schatten)
     ========================= */
  --mz-akk-radius: 10px;
  --mz-akk-shadow: 0 1px 2px rgba(0,0,0,.06);

  /* =========================
     Header (Titelbereich)
     ========================= */
  --mz-akk-header-padding-y: 0.9rem;
  --mz-akk-header-padding-x: 1rem;

  /* =========================
     Body (Inhaltsbereich)
     ========================= */
  --mz-akk-body-padding-top: 0.9rem;
  --mz-akk-body-padding-right: 1rem;
  --mz-akk-body-padding-bottom: 1rem;
  --mz-akk-body-padding-left: 1rem;

  /* Abstand zwischen Inhaltselementen */
  --mz-akk-content-flow-space: 0.8rem;

  /* =========================
     Animation
     ========================= */
  --mz-akk-duration: 380ms;
  --mz-akk-ease: cubic-bezier(.2,.6,.2,1);
  --mz-akk-max-body: 1200px;

  /* =========================
     Icons / Medien
     ========================= */
  --mz-akk-title-img-h: 2.5rem;
  --mz-akk-icon-url: url("icons/caret-right.svg");
  --mz-akk-icon-size: 1.5rem;

  /* =========================
     Sonstiges
     ========================= */
  --akk-scroll-offset: 16px;

  /* =========================
     Basislayout
     ========================= */
  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: .65rem;
  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-titlewrap {
  display: block;
  width: 100%;
  min-width: 0;
  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-header::before {
  content: "";
  display: inline-block;
  width: var(--mz-akk-icon-size);
  height: var(--mz-akk-icon-size);
  flex-shrink: 0;
  margin-right: .4rem;
  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: .9;
}

.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 {
  max-height: var(--mz-akk-max-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
   ------------------------------------------------- */

.mz-akk-titlewrap > br:first-child,
.mz-akk-titlewrap > br:last-child,
.mz-akk-body > br:first-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.layout-small {
  --mz-akk-max-width: 42rem;
  --mz-akk-gap: 0.75rem;
}

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

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

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

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

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

/* -------------------------------------------------
   Theme
   Steuert Farben und Symbolik
   Default bleibt neutral, Themes überschreiben gezielt
   ------------------------------------------------- */

.mz-akk-box.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-icon-url: url("icons/caret-right.svg");
}

.mz-akk-box.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;
  --mz-akk-icon-url: url("icons/caret-right-white.svg");
}

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

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

/* 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;
}