/* Stable, font-independent fixes for legacy catalog accordions and big titles. */

.catalogList > h2,
h1.bigBoyTitle {
  line-height: 1.05 !important;
  white-space: normal !important;
  word-break: normal !important;
  overflow-wrap: anywhere;
  text-wrap: balance;
}

h1.bigBoyTitle {
  display: inline-block !important;
  max-width: min(100%, 18ch);
  font-size: clamp(1.9rem, 5vw, 4.15rem) !important;
}

.catalogList > h2 {
  max-width: min(100%, 18ch);
  margin: 0 auto 40px !important;
  padding: 0 16px 40px !important;
  font-size: clamp(2rem, 4.6vw, 3.8rem) !important;
}

.catalogList .collapseomatic {
  display: block;
  position: relative;
  padding: 24px 24px 19px 72px !important;
  line-height: 1.2;
  white-space: normal;
  overflow-wrap: anywhere;
  background-color: #d5ebff;
  border: 2px solid #70aadf;
  border-top-color: #e6f3ff;
  border-left-color: #e6f3ff;
  border-radius: 20px;
  text-decoration: none;
}

.catalogList .collapseomatic::before {
  content: "" !important;
  position: absolute;
  left: 24px;
  top: 50%;
  width: 28px;
  height: 28px;
  transform: translateY(-50%);
  background-repeat: no-repeat;
  background-position: center;
  background-size: 100% 100%;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%234d2a7b' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='10'/%3E%3Cpath d='M8 10l4 4 4-4'/%3E%3C/svg%3E");
}

.catalogList .collapseomatic.colomat-close::before {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%234d2a7b' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='10'/%3E%3Cpath d='M9 9l6 6M15 9l-6 6'/%3E%3C/svg%3E");
}

.catalogList .collapseomatic:hover,
.catalogList .collapseomatic:focus {
  cursor: pointer;
}

.catalogList .collapseomatic:focus-visible {
  outline: 3px solid rgba(77, 42, 123, 0.22);
  outline-offset: 2px;
}

.catalogList .collapseomatic_content {
  margin-left: 10px;
  margin-right: 10px;
}

.catalogList .collapseomatic_content h2 {
  line-height: 1.15;
  white-space: normal;
  overflow-wrap: anywhere;
  text-wrap: balance;
}

@media (max-width: 900px) {
  h1.bigBoyTitle {
    max-width: 100%;
    font-size: clamp(1.7rem, 7vw, 3rem) !important;
  }

  .catalogList > h2 {
    max-width: 100%;
    font-size: clamp(1.8rem, 8vw, 3rem) !important;
    padding-bottom: 28px !important;
  }

  .catalogList .collapseomatic {
    padding: 20px 18px 18px 60px !important;
    font-size: clamp(1.3rem, 4.8vw, 1.8rem);
  }

  .catalogList .collapseomatic::before {
    left: 18px;
    width: 24px;
    height: 24px;
  }
}
