/**
 * ==========================================================================
 * HOW IT WORKS — Three-step timeline section for Divi Code Module
 * ==========================================================================
 *
 * Usage:
 * 1) Add the HTML from /how-it-works-html.html into a Divi Code Module.
 * 2) Ensure this stylesheet is loaded on the target template/page.
 * 3) Optional: wrap in .new-single-product for template-level scoping.
 */

.co-how-it-works {
  --hiw-gold: #b8a888;
  --hiw-text: #222222;
  --hiw-muted: #4f4f4f;
  --hiw-bg: #f6f5ef;
  --hiw-max-width: 1080px;

  background-color: var(--hiw-bg);
  color: var(--hiw-text);
  padding: clamp(60px, 8vw, 110px) clamp(20px, 4vw, 40px);
}

.co-how-it-works__inner {
  max-width: var(--hiw-max-width);
  margin: 0 auto;
}

.co-how-it-works__eyebrow {
  display: block;
  margin: 0 0 20px;
  text-align: center;
  color: var(--hiw-gold);
  font-family: var(--ff-sans, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.co-how-it-works__title {
  margin: 0 auto;
  max-width: 900px;
  text-align: center;
  color: var(--hiw-text);
  font-family: var(--ff-serif, Georgia, "Times New Roman", serif);
  font-size: clamp(34px, 4.6vw, 60px);
  line-height: 1.12;
  font-weight: 400;
  letter-spacing: -0.01em;
}

.co-how-it-works__timeline {
  margin: clamp(42px, 6vw, 68px) 0 0;
  padding: 0;
  list-style: none;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  column-gap: clamp(18px, 3vw, 44px);
  row-gap: 28px;
}

.co-how-it-works__step {
  text-align: center;
}

.co-how-it-works__step-number {
  display: inline-block;
  margin: 0 0 12px;
  color: var(--hiw-gold);
  font-family: var(--ff-serif, Georgia, "Times New Roman", serif);
  font-size: clamp(50px, 5.2vw, 72px);
  line-height: 1;
  font-weight: 400;
  letter-spacing: 0.01em;
}

.co-how-it-works__step-title {
  margin: 0;
  color: var(--hiw-text);
  font-family: var(--ff-serif, Georgia, "Times New Roman", serif);
  font-size: clamp(34px, 2vw, 42px);
  line-height: 1.2;
  font-weight: 400;
}

.co-how-it-works__step-description {
  margin: 18px auto 0;
  max-width: 320px;
  color: var(--hiw-muted);
  font-family: var(--ff-serif, Georgia, "Times New Roman", serif);
  font-size: clamp(16px, 1.2vw, 20px);
  line-height: 1.55;
}

@media (max-width: 980px) {
  .co-how-it-works__title {
    max-width: 780px;
  }

  .co-how-it-works__timeline {
    column-gap: 22px;
  }

  .co-how-it-works__step-title {
    font-size: clamp(28px, 3vw, 36px);
  }
}

@media (max-width: 767px) {
  .co-how-it-works {
    padding: 56px 20px;
  }

  .co-how-it-works__title {
    font-size: clamp(30px, 9vw, 44px);
  }

  .co-how-it-works__timeline {
    grid-template-columns: 1fr;
    row-gap: 34px;
    margin-top: 40px;
  }

  .co-how-it-works__step-number {
    font-size: clamp(46px, 14vw, 62px);
  }

  .co-how-it-works__step-title {
    font-size: clamp(32px, 11vw, 44px);
  }

  .co-how-it-works__step-description {
    max-width: 34ch;
    margin-top: 14px;
    font-size: 20px;
  }
}
