.p-front-concept {
  padding: 86px 0 92px;
  background:
    radial-gradient(circle at 18% 0%, rgba(255, 250, 240, .68), transparent 34%),
    linear-gradient(180deg, var(--sou-bg), #efe3d2);
  color: var(--sou-ink);
}

.p-front-concept__inner {
  max-width: 920px;
  margin: 0 auto;
}

.p-front-concept__head {
  margin-bottom: 34px;
}

.p-front-concept__eyebrow {
  margin: 0 0 14px;
  color: var(--sou-accent-dark);
  font-size: .74rem;
  font-weight: 700;
  letter-spacing: .2em;
  text-transform: uppercase;
}

.p-front-concept__title {
  margin: 0;
  color: var(--sou-brown);
  font-size: clamp(1.7rem, 2.35vw, 2.45rem);
  font-weight: 600;
  line-height: 1.55;
  letter-spacing: .1em;
}

.p-front-concept__title::after {
  content: "";
  display: block;
  width: 56px;
  height: 2px;
  margin-top: 24px;
  background: var(--sou-accent);
}

.p-front-concept__title .pc_only {
  display: none;
}

.p-front-concept__body {
  max-width: 860px;
  padding-top: 4px;
}

.p-front-concept__body p {
  margin: 0 0 1.5em;
  color: var(--sou-ink);
  font-size: .98rem;
  line-height: 2.08;
  letter-spacing: .045em;
}

.p-front-concept__body p:last-child {
  margin-bottom: 0;
}

@media (max-width: 767px) {
  .p-front-concept {
    padding: 58px 0 64px;
  }

  .p-front-concept__head {
    margin-bottom: 26px;
  }

  .p-front-concept__title {
    font-size: 1.55rem;
    line-height: 1.58;
  }

  .p-front-concept__title::after {
    margin-top: 20px;
  }

  .p-front-concept__body p {
    font-size: .94rem;
    line-height: 1.96;
  }
}
