.hiw {
  background: var(--bg-tinted);
  padding: 64px 0;
  align-items: center;
  column-gap: 72px;
}

.hiw-visual { grid-column: content-start / half; }
.hiw-content { grid-column: half / content-end; }

.hiw-visual img { width: 100%; display: block; }

.hiw-content .section-title {
  color: var(--text); margin-bottom: 10px;
}

.hiw-sub {
  font-size: var(--fs-base); line-height: 1.65; color: var(--text-secondary);
  margin-bottom: 40px;
}

.steps-v {
  display: flex; flex-direction: column;
  list-style: none; margin-bottom: 36px;
}

.step-v {
  display: flex; gap: 18px;
  padding-bottom: 24px; position: relative;
}

.step-v:not(:last-child)::after {
  content: ''; position: absolute;
  left: 21px; top: 44px; bottom: 0;
  width: 1px; border-left: 2px dashed rgba(20,130,136,.3);
}

.step-v-num {
  width: 44px; height: 44px; border-radius: var(--r-circle); flex-shrink: 0;
  border: 2px solid var(--c-teal-500); background: var(--bg-page);
  display: flex; align-items: center; justify-content: center;
  font-weight: 800; font-size: var(--fs-xs); color: var(--text-accent);
  letter-spacing: .04em;
}

.step-v-body { padding-top: 7px; }

.step-v-title {
  font-weight: 700; font-size: 16px; color: var(--text);
  margin-bottom: 3px; line-height: 1.3;
}

.step-v-desc {
  font-size: 13px; color: var(--text-secondary); line-height: 1.55;
}
