/**
 *  mida-portal/mida/static/mida/components/accordion-block/style.css
 */

.accordion-block .block {
  display: block;
}

.accordion-block ul {
  list-style: inside;
}

.accordion-block .block-with {
  height: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2rem;
  padding: 2rem 1rem;
  background-color: var(--light-blue);
  overflow-y: scroll
}

.accordion-block .heading-leadership {
  font-family: var(--h4-font-family);
  font-weight: var(--h4-font-weight);
  color: var(--dark-blue);
  font-size: var(--h4-font-size);
  text-align: center;
  letter-spacing: var(--h4-letter-spacing);
  line-height: var(--h4-line-height);
  font-style: var(--h4-font-style);
  text-align: center;
}

.accordion-block .frame {
  align-items: center;
  gap: 32px;
  flex: 0 0 auto;
  display: inline-flex;
  flex-direction: column;
}

.accordion-block .element {
  background-color: #ffffff;
  padding: 4rem 2rem;
}

.accordion-block .preferences .element {
  padding: 2rem 2rem;
}

.accordion-block .preferences .element p {
  color: var(--dark-blue);
}

.accordion-block .text-content {
  font-family: var(--p3-font-family);
  font-weight: var(--p3-font-weight);
  color: var(--grey-dark);
  font-size: var(--p3-font-size);
  letter-spacing: var(--p3-letter-spacing);
  line-height: var(--p3-line-height);
  font-style: var(--p3-font-style);
}

.accordion-block .left-items {
  display: flex;
  flex-direction: row;
  gap: 3rem;
}

.accordion-block .data-group {
  background-color: var(--white);
  width: 100%;
  padding: 15px 18px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  border: none;
}

.accordion-block .group-header {
  font-family: var(--FAQ-headline-font-family);
  font-weight: var(--FAQ-headline-font-weight);
  color: #22408f;
  font-size: var(--FAQ-headline-font-size);
  letter-spacing: var(--FAQ-headline-letter-spacing);
  line-height: var(--FAQ-headline-line-height);
  font-style: var(--FAQ-headline-font-style);
}

.accordion-block .text-number {
  color: var(--green);
  font-family: var(--FAQ-headline-font-family);
  font-weight: var(--FAQ-headline-font-weight);
  font-size: var(--FAQ-headline-font-size);
  letter-spacing: var(--FAQ-headline-letter-spacing);
  line-height: var(--FAQ-headline-line-height);
  font-style: var(--FAQ-headline-font-style);
}

.accordion-block .data-groups {
  width: 100%;
}

.accordion-block .overlap-group {
  background-color: #ffffff;
  border-radius: 12px;
  box-shadow: 0px 0px 35px #0000001a;
}

.accordion-block .list {
  font-family: var(--p3-font-family);
  font-weight: var(--p3-font-weight);
  color: #6c6c6c;
  font-size: var(--p3-font-size);
  letter-spacing: var(--p3-letter-spacing);
  line-height: var(--p3-line-height);
}

.accordion-block .marcodataportal {
  width: 20px;
  height: 20px;
}

.accordion-block .img {
  width: 20px;
  height: 20px;
}

.accordion-block .polygon {
  width: 20px;
  height: 20px;
}

.accordion-block .text {
  font-family: var(--FAQ-headline-font-family);
  font-weight: var(--FAQ-headline-font-weight);
  font-size: var(--FAQ-headline-font-size);
  letter-spacing: var(--FAQ-headline-letter-spacing);
  line-height: var(--FAQ-headline-line-height);
  white-space: nowrap;
  font-style: var(--FAQ-headline-font-style);
}

.accordion-block .vector {
  width: 18px;
  height: 14px;
}

.accordion-block .list-item {
  width: 100%;
}

.accordion-block .overlap {
  display: flex;
  background-color: #ffffff;
  flex-wrap: wrap;
  gap: 2rem;
  padding: 29px;
  justify-content: space-between;
}

.accordion-block .accordion-center {
  justify-content: center;
}

.accordion-block .space-evenly {
  justify-content: space-evenly;
}

.accordion-block .rectangle {
  background-color: var(--white);
  border-radius: 12px;
  box-shadow: 0px 4px 35px #0000001a;
  padding: 3rem;
}

.accordion-block .overlap-group-wrapper,
.accordion-block .overlap-wrapper {
  width: 48%;
  max-width: 496px;
}

.accordion-block .element-wrapper,
.accordion-block .div-wrapper {
  background-color: #22408f;
  border-radius: 12px 12px 0px 0px;
  padding: 19px 39px;
}

.accordion-block .card-contents {
  padding: 1rem;
}

.accordion-block .card-header {
  width: fit-content;
  font-family: var(--p3-font-family);
  font-weight: var(--p3-font-weight);
  color: var(--white);
  font-size: var(--p3-font-size);
  text-align: center;
  letter-spacing: var(--p3-letter-spacing);
  line-height: var(--p3-line-height);
  white-space: nowrap;
  font-style: var(--p3-font-style);
}

.accordion-block .card-header-contents {
  display: flex;
  align-items: center;
  gap: 8px;
  border-radius: 12px;
}

.accordion-block .head {
  background-color: var(--green);
  padding: 15px 18px;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  border: none;
}

.accordion-block .property-default {
  background-color: var(--white);
  padding: 14px 18px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.accordion-block .list-item {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-direction: row;
}

.accordion-block .list-text {
  width: fit-content;
  font-family: var(--p3-font-family);
  font-weight: var(--p3-font-weight);
  color: #6c6c6c;
  font-size: var(--p3-font-size);
  text-align: center;
  letter-spacing: var(--p3-letter-spacing);
  line-height: var(--p3-line-height);
  white-space: nowrap;
}

.accordion-block .expand-icon {
  width: 10px;
  height: 18px;
}

.accordion-block details.property {
  background: var(--white);
  overflow: hidden;
}

.accordion-block details.property>summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 15px 18px;
  cursor: pointer;
}


.accordion-block details.property[open]>summary {
  background: var(--green);
  color: var(--white);
}

.accordion-block details.property[open] .text-wrapper,
.accordion-block details.property[open] .text-wrapper h3 {
  color: var(--white);
}

.accordion-block details.property:not([open])>summary {
  background: var(--white);
  color: #22408f;
}

.accordion-block details.property:not([open]) .header {
  color: #22408f;
}

.accordion-block details.property:not([open]) .text-wrapper {
  color: #22408f;
}


.accordion-block details>summary {
  list-style: none;
}

.accordion-block summary .img {
  transition: transform 220ms ease-in-out;
  transform-origin: center;
}

.accordion-block details>summary::-webkit-details-marker {
  display: none;
}

.accordion-block details[open] summary .img {
  transform: rotate(90deg);
}

/* Icon visibility: show white arrow when open, blue arrow when closed */
.accordion-block summary .icon-open,
.accordion-block summary .icon-closed {
  width: 18px;
  height: 18px;
  display: inline-block;
  vertical-align: middle;
  transition: opacity 180ms ease-in-out, transform 180ms ease-in-out;
  opacity: 0;
}

/* Container that occupies the flex slot; icons are absolutely stacked inside */
.accordion-block .icon-wrap {
  display: inline-block;
  width: 18px;
  height: 18px;
  position: relative;
  flex: 0 0 auto;
}

.accordion-block .icon-wrap img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: block;
  transition: opacity 180ms ease-in-out, transform 180ms ease-in-out;
}

/* Strong override to counter duplicate .vector rules elsewhere */
.accordion-block .icon-wrap .vector,
.accordion-block .icon-wrap img.icon-open,
.accordion-block .icon-wrap img.icon-closed {
  width: 100%;
  height: 100%;
}

/* Closed by default: show closed (blue) icon */
.accordion-block details:not([open]) summary .icon-closed {
  opacity: 1;
}

/* When open: show open (white) icon */
.accordion-block details[open] summary .icon-open {
  opacity: 1;
}

/* Ensure only one icon is interactable/visible at a time */
.accordion-block summary .icon-open {
  pointer-events: none;
}

.accordion-block summary .icon-closed {
  pointer-events: none;
}

@media (max-width: 768px) {
  .accordion-block .overlap {
    flex-direction: column;
    justify-content: flex-start;
  }

  .accordion-block .overlap-group-wrapper,
  .accordion-block .overlap-wrapper {
    width: 100%;
    margin-bottom: 20px;
  }
}