.accordions {
  gap: var(--gap-smaller);
  margin: var(--gap) auto;
  align-items: flex-start;
  width: 100%;
}
.accordions__item {
  --item-color: var(--color-main);
  --item-text-color: var(--color-main);
  --item-background: var(--color-white);
  --item-shadow: none;
  background-color: var(--item-background);
  border-radius: var(--border-radius);
  overflow: hidden;
  text-decoration: none;
  position: relative;
  border: 1px solid var(--color-border);
  box-shadow: var(--item-shadow);
  width: 100%;
  padding: 1em 1.5em;
  transition: var(--transition);
}
.accordions__item-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.4em;
  color: var(--item-color);
  z-index: 2;
  width: 100%;
  cursor: pointer;
}
.accordions__item-header::after {
  content: "";
  width: 1.25em;
  aspect-ratio: 1/1;
  mask: var(--icon-arrow-right) center/contain no-repeat;
  background-color: var(--color-primary);
  transition: var(--transition);
  flex-shrink: 0;
  transform: rotate(90deg);
}
.accordions__item-header.active, .accordions__item-header:hover {
  --item-color: var(--color-primary-dark);
}
.accordions__item-header.active::after {
  transform: rotate(270deg);
}
.accordions__item-title {
  font-family: var(--font-heading);
  font-weight: var(--font-weight-medium);
  font-optical-sizing: auto;
  letter-spacing: var(--letter-spacing);
  font-size: var(--font-size-24);
  transition: var(--transition);
  margin: 0;
  text-decoration: none;
  line-height: 1.2;
  flex-grow: 1;
}
.accordions__item-content {
  z-index: 2;
  position: relative;
  width: 100%;
  color: var(--item-text-color);
  opacity: 0;
  visibility: hidden;
  height: 0;
  transition: var(--transition);
  overflow: hidden;
}
.accordions__item-content.visible {
  opacity: 1;
  visibility: visible;
  overflow: visible;
}
.accordions__item-content-inner > *:first-child {
  margin-top: 0;
}
.accordions__item-content-inner > *:last-child {
  margin-bottom: 0;
}
.accordions__item-content-inner::after {
  content: "";
  display: block;
  width: 95px;
  height: 2px;
  background-color: var(--color-secondary);
  margin-top: 1.5em;
  margin-bottom: 1.5em;
  position: absolute;
  left: 0;
  top: 0;
}
.accordions__item-content-inner::before {
  content: "";
  display: block;
  width: 100%;
  height: calc(3em + 2px);
  background: transparent;
  pointer-events: none;
}