.principal-image-text { padding: 64px 0; padding-bottom: 32px; }
.principal-image-text .container { max-width: 1440px; margin: 0 auto; padding: 0 20px; }

.principal-image-text .principal-row-container {
  display: flex; max-width: 1136px; margin: 0 auto;
  flex-wrap: wrap; align-items: flex-start; justify-content: space-between; gap: 32px;
}

/* Orden (desktop) controlado por clase */
.principal-row--image-first .image-column { order: 1; }
.principal-row--image-first .text-column  { order: 2; }
.principal-row--text-first  .text-column  { order: 1; }
.principal-row--text-first  .image-column { order: 2; }

.principal-image-text .text-column { flex: 1 1 45%; max-width: 45%; }
.principal-image-text .text-column h2 {
  font-size: 32px; margin: 0 0 24px 0; font-weight: 700; line-height: 40px; color: #002855; text-align: left;
}
.principal-image-text .text-column p {
  font-size: 18px; margin: 0 0 24px 0; line-height: 28px; color: #2F2F2F;
}

.principal-image-text .image-column { flex: 1 1 50%; max-width: 50%; text-align: center; }
.principal-image-text .image-column .img-area img {
  max-width: 100%; height: auto; object-fit: contain; display: block; margin: 0 auto;
}
.principal-image-text .button-area{
    justify-content: start;
}

/* ===== Responsive ===== */
@media (max-width: 900px) {
  .principal-image-text { padding: 40px 0; }
  .principal-image-text .principal-row-container { gap: 20px; flex-direction: column-reverse; align-items: center; }
  .principal-image-text .text-column, .principal-image-text .image-column { flex: 1 1 100%; max-width: 100%; text-align: center; }
  .principal-image-text .text-column h2 { font-size: 28px; line-height: 36px; margin-bottom: 18px; }
  .principal-image-text .text-column p { font-size: 16px; line-height: 24px; margin-bottom: 28px; }
  .principal-image-text .image-column .img-area img { max-width: 80%; }
  .principal-image-text .text-column .button-area a { padding: 10px 28px; }
}
@media (max-width: 600px) {
  .principal-image-text { padding: 24px 0; }
  .principal-image-text .container { padding: 0 16px; }
  .principal-image-text .text-column { text-align: left; }
  .principal-image-text .text-column h2 { font-size: 24px; line-height: 32px; margin-bottom: 12px; }
  .principal-image-text .text-column p { font-size: 15px; line-height: 22px; margin-bottom: 18px; }
  .principal-image-text .image-column .img-area img { max-width: 100%; }
  .principal-image-text .text-column .button-area { text-align: left; }
}
