/* =============================================

   CONTACTS CTA SECTION (Figma: yellow+green)
   ============================================= */
.contacts-cta {
  padding-top: 80px;
  padding-bottom: 80px;
}
.contacts-cta__inner {
  background: var(--color-yellow);
  border-radius: 8px;
  overflow: hidden;
  display: flex;
  min-height: 378px;
  position: relative;
}
.contacts-cta__left {
  background: var(--color-green);
  flex: 0 0 55%;
  display: flex;
  align-items: center;
  padding: 60px 80px;
  position: relative;
  clip-path: polygon(0 0, 100% 0, 88% 100%, 0 100%);
  z-index: 1;
}
.contacts-cta__content {
  max-width: 520px;
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.contacts-cta__title {
  font-size: 52px;
  font-weight: 600;
  color: var(--color-white);
  margin: 0;
  line-height: 1.05;
}
.contacts-cta__title--highlight {
  color: var(--color-yellow);
  display: block;
}
.contacts-cta__desc {
  font-size: 16px;
  font-weight: 500;
  color: #fbfbfb;
  margin: 0;
  line-height: 1.5;
}
.contacts-cta__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--color-blue);
  color: var(--color-white);
  border-radius: 8px;
  padding: 12px 40px;
  font-size: 16px;
  font-weight: 500;
  text-decoration: none;
  border: none;
  width: fit-content;
  transition: background 0.2s;
}
.contacts-cta__btn:hover,
.contacts-cta__btn:focus {
  background: #2e5caa;
  color: var(--color-white);
}
.contacts-cta__right {
  flex: 1;
  position: relative;
  display: flex;
  align-items: flex-end;
  justify-content: flex-end;
}
.contacts-cta__img {
  width: 550px;
  height: 250px;
  object-fit: cover;
  display: block;
  position: absolute;
  right: 0;
  bottom: 40px;
}
@media (max-width: 1200px) {
  .contacts-cta__title { font-size: 40px; }
  .contacts-cta__img { width: 360px; height: 280px; }
}
@media (max-width: 991px) {
  .contacts-cta__left {
    flex: 0 0 60%;
    clip-path: polygon(0 0, 100% 0, 83% 100%, 0 100%);
    padding: 40px;
  }
  .contacts-cta__title { font-size: 32px; }
  .contacts-cta__img { width: 280px; height: 218px; }
}
@media (max-width: 767px) {
  .contacts-cta__inner { flex-direction: column; min-height: auto; }
  .contacts-cta__left {
    flex: none;
    clip-path: none;
    padding: 32px 20px;
  }
  .contacts-cta__title { font-size: 26px; }
  .contacts-cta__desc { font-size: 14px; }
  .contacts-cta__btn { padding: 12px 24px; font-size: 14px; }
  .contacts-cta__right { display: none; }
}

/* =============================================
