/* ==========================================================================
   Solucoes Processo Section
   ========================================================================== */

.srv-processo {
  padding: clamp(37px, 2.92vw, 56px) 0;
}

.srv-processo__inner {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: center;
  gap: var(--gap-md);
}

/* Image Column
   ========================================================================== */

.srv-processo__image {
  width: min(100%, 552px);
  max-width: 552px;
  position: relative;
  /* 2/3 do recuo original (32px 18px 36px 36px) entre moldura e foto */
  padding: 21px 12px 24px 24px;
}

/* Borda em gradiente (ref. Figma 14347:3097) — SVG por cima porque um
   `border` CSS seria recortado pelo clip-path da imagem. */
.srv-processo__frame {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
}

.srv-processo__frame svg {
  display: block;
  width: 100%;
  height: 100%;
  overflow: visible; /* mostra a metade externa do traço */
}

/* Imagem recortada exatamente com o mesmo path do frame (ref. Figma) —
   clip em objectBoundingBox p/ acompanhar o redimensionamento e casar
   pixel a pixel com o traço do .srv-processo__frame. */
.srv-processo__image-wrapper {
  position: relative;
  z-index: 0;
}

.srv-processo__image-wrapper img {
  display: block;
  width: 100%;
  height: auto;
  clip-path: url(#srvProcessoClip);
}

/* Content Column
   ========================================================================== */

.srv-processo__content {
  min-width: 0;
  max-width: none;
}

.srv-processo__label {
  display: flex;
  align-items: center;
  gap: 12px;
  font-family: var(--font-text);
  font-size: var(--fs-label);
  font-weight: 400;
  color: var(--color-dark);
  line-height: 1.7;
  letter-spacing: -0.18px;
  margin-bottom: 16px;
  letter-spacing: -0.18px;
}

.srv-processo__line {
  display: inline-block;
  width: 71px;
  height: 0;
  border-top: 1.5px solid var(--color-primary);
}

.srv-processo__title {
  font-family: var(--font-heading);
  font-size: var(--fs-heading-xl);
  font-weight: 600;
  line-height: 1.2;
  color: var(--color-dark);
  margin-bottom: 24px;
}

.srv-processo__text {
  font-family: var(--font-body);
  font-size: var(--fs-body);
  line-height: 1.7;
  color: #64748B;
  margin-bottom: 24px;
}

.srv-processo__subtitle {
  font-family: var(--font-body);
  font-size: var(--fs-body);
  font-weight: 500;
  color: var(--color-dark);
  margin-bottom: 20px;
}

/* Checks (grid 2x2)
   ========================================================================== */

.srv-processo__checks {
  margin: 8px 0 0;
  padding: 0;
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.srv-processo__checks-row {
  display: flex;
  flex-wrap: wrap;
  gap: 16px 32px;
}

.srv-processo__check {
  display: inline-flex;
  align-items: flex-start;
  gap: 12px;
  padding: 4px 0;
}

.srv-processo__check-icon {
  flex-shrink: 0;
}

.srv-processo__check-text {
  font-family: var(--font-body);
  font-size: var(--fs-body);
  line-height: 1.5;
  color: #252B37;
}

/* Responsive
   ========================================================================== */

@media (max-width: 768px) {
  .srv-processo {
    padding: 48px 0;
  }

  .srv-processo__inner {
    grid-template-columns: 1fr;
    gap: 32px;
  }

  .srv-processo__content {
    order: 1;
  }

  .srv-processo__image {
    order: 2;
    width: 100%;
  }

  .srv-processo__image {
    max-width: 100%;
  }

  .srv-processo__checks {
    gap: 12px;
  }

  .srv-processo__checks-row {
    flex-direction: column;
    gap: 12px;
  }
}
