.container {
  display: flex;
  gap: 40px;
}

@media (max-width: 900px) {
  .container {
    flex-direction: column;
  }
}

.content {
  width: 70%;
  container-type: inline-size;
}

.sidebar {
  width: 30%;
  container-type: inline-size;
}

@media (max-width: 1050px) {
  .content,
  .sidebar {
    width: 100%;
  }
}

.sidebar h2 {
  margin-top: 0;
}

.box {
  display: flex;
  margin-bottom: 20px;
}

@container (max-width: 750px) {
  .box {
    flex-direction: column;
  }
}

.box_image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.box_text {
  padding: 20px;
  background-color: var(--primary-light);
}

.box_text p {
  margin-top: 0;
}

.button {
  padding: 7px 18px;
  background-color: transparent;
  border: 2px solid var(--secondary);
  border-radius: 8px;
  color: var(--white);
  cursor: pointer;
  transition: background-color 0.4s;
}

.button:hover {
  background-color: var(--secondary);
}
