*   {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
    }

body {
    background-color: #fff;
    font-family: sans-serif;
    }

.image-section {
    width: 100%;
}

.image-section picture,
.image-section img {
    width: 100%;
    max-width: 2500px; /* 最大横幅 */
    margin: 0 auto;
    display: block;
    padding: 0;
}

/* セクション間の余白（必要に応じて調整） */
.image-section + .image-section {
    margin-top: 55px;
}

/* バナーセクション（小さめ） */
.banner-section {
  width: 100%;
  margin: 30px auto 0px;
  text-align: center;
}

.banner-section picture,
.banner-section img {
  width: 100%;
  max-width: 2500px;
  height: auto;
  display: inline-block;
  padding: 0;
}

/* SP用微調整 */
@media (max-width: 750px) {
  .image-section img,
  .banner-section img {
    padding: 0px;
  }
}

.redzone {
  width: 100%;
  background-color: #e70013;
}

.mdparts {
  width: 80%;
  margin: auto;
  padding: 0px 20px 85px 20px;
}

@media (max-width: 750px) {
.mdparts {
    width: 100%;
  margin: auto;
  padding: 15px 5px 80px 5px;
  }
}

