.top {
  display: flex;
  flex-direction: column;
  gap: 96px;
  padding: 96px;
  margin: 0 auto;
}

.top__hero {
  display: flex;
  flex-direction: column;
  gap: 8px;

  align-items: center;
  justify-content: center;
  min-height: calc(100vh - 192px);
  background: url("../images/hero.png") center/cover no-repeat;

  h1 {
    font-size: 64px;
  }

  p {
    font-size: 24px;
    line-height: 1;
  }
}

.top__contents {
  display: flex;
  flex-direction: column;
  gap: 48px;
  align-items: center;

  h2 {
    font-size: 2.5rem;
  }
}

@media (width <= 768px) {
  .top {
    padding: 0;
  }

  .top__hero {
    min-height: 100vh;

    h1 {
      font-size: 48px;
    }

    p {
      font-size: 24px;
    }
  }

  .top__contents {
    padding: 0 32px;

    h2 {
      font-size: 2rem;
      line-height: 1.5;
    }
  }
}

/* コメントセクション */
.comment {
  padding: 48px 48px 48px 0;
}

.comment__container {
  display: grid;
  grid-template-rows: 3rem auto;
  grid-template-columns: 1fr 1fr;
  gap: 96px 48px;
  width: 90%;
  padding: 96px 48px 96px 96px;
  background-color: #bacad3;

  h2 {
    font-size: 2.5rem;
    text-align: center;
  }

  img {
    grid-row: 1 / 3;
    grid-column-start: 2;
    width: 100%;
  }
}

.comment__text {
  display: flex;
  flex-direction: column;
  gap: 32px;
  align-items: flex-end;
}

@media (width <= 768px) {
  .comment {
    padding: 48px 0;
  }

  .comment__container {
    display: flex;
    flex-direction: column;
    gap: 32px;
    align-items: center;
    padding: 20% 10%;

    h2 {
      font-size: min(8vw, 2rem);
    }

    img {
      max-width: 480px;
    }
  }
}

/* "ものづくりはひとづくり"セクション */
.training {
  display: flex;
  flex-direction: column;
  gap: 96px;
  align-items: center;
  max-width: 1280px;
  padding: 96px 48px;
  margin: 0 auto;
}

.training__contents {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;

  p {
    width: 50%;
    padding: 32px;
  }

  img {
    width: 50%;
  }
}

@media (width <= 768px) {
  .training {
    gap: 16px;
    padding: 48px 0;

    h2 {
      padding: 0 32px;
    }
  }

  .training__contents p {
    width: 100%;
  }
}

/* "社内一貫生産"セクション */
.in-house {
  display: flex;
  flex-direction: column;
  gap: 96px;
  align-items: center;
  max-width: 1280px;
  padding: 96px 48px;
  margin: 0 auto;
}

.in-house__process {
  display: grid;
  grid-template-rows: 3rem auto;
  grid-template-columns: 1fr 1fr;
  gap: 2rem 8%;
  padding: 48px;

  h3 {
    font-size: 2rem;
    text-decoration: underline;
    text-decoration-thickness: 1px;
    text-underline-offset: 0.5rem;
  }

  img {
    grid-row: 1 / 3;
    grid-column-start: 2;
    width: 100%;
  }
}

.in-house__process--reverse {
  img {
    grid-column-start: 1;
  }
}

.in-house__view-more {
  width: 24rem;
  padding: 1rem;
  text-align: center;
  border: 1px solid #000;
  transition: all 0.3s ease;

  &:hover {
    color: #fff;
    letter-spacing: 3px;
    background-color: #000;
  }
}

@media (width <= 768px) {
  .in-house {
    gap: 48px;
    align-items: center;
    padding: 48px 0;

    h2,
    p {
      padding: 0 32px;
    }
  }

  .in-house__contents {
    display: flex;
    flex-direction: column;
    gap: 48px;
  }

  .in-house__process {
    display: flex;
    flex-direction: column;
    padding: 0;

    h3 {
      padding: 0 32px;
      font-size: 1.5rem;
      text-decoration: none;
    }

    img {
      align-self: flex-start;
      width: 70%;
    }

    p {
      align-self: flex-end;
      width: 90%;
      padding: 32px;
      margin-top: -20vw;
      background-color: #bacad3cc;
    }
  }

  .in-house__process--reverse {
    img {
      align-self: flex-end;
    }

    p {
      align-self: flex-start;
    }
  }

  .in-house__view-more {
    max-width: 80%;
  }
}

/* 品質セクション */
.quality {
  display: flex;
  flex-direction: column;
  gap: 96px;
  align-items: center;
  max-width: 1280px;
  padding: 96px 48px;
  margin: 0 auto;
}

.quality__contents {
  display: flex;
  flex-flow: row-reverse wrap;
}

.quality__contents p {
  width: 50%;
  padding: 32px;
}

.quality__contents img {
  width: 50%;
}

.quality__view-more {
  width: 24rem;
  padding: 1rem;
  text-align: center;
  border: 1px solid #000;
  transition: all 0.3s ease;
}

.quality__view-more:hover {
  color: #fff;
  letter-spacing: 3px;
  background-color: #000;
}

@media (width <= 768px) {
  .quality {
    gap: 32px;
    padding: 48px 32px;
  }

  .quality__contents {
    p {
      width: 100%;
      padding: 0;
    }
  }

  .quality__view-more {
    max-width: 100%;
  }
}
