#key-visual {
  background-color: #F8EB79;
  background-image: url(../image/curry/curry-cloud.svg);
  background-position-y: 6%;
  background-position-x: center;
  background-repeat: no-repeat;
  background-size: 100%;
}
@media screen and (max-width: 768px) {
  #key-visual {
    background-position-y: 3%;
    transition-property: all;
    transition-duration: 0.3s;
  }
}
#key-visual h2, #key-visual h3, #key-visual p, #key-visual a {
  font-family: "Zen Maru Gothic", serif;
  font-weight: 400;
}
#key-visual .key-wrap {
  background-image: url(../image/curry/curry-border.svg);
  background-repeat: repeat-x;
  background-position: top left;
  background-size: 70%;
  padding: 0 3%;
}
@media screen and (max-width: 768px) {
  #key-visual .key-wrap {
    background-size: 100%;
    transition-property: all;
    transition-duration: 0.3s;
  }
}
#key-visual .key-wrap section {
  max-width: 1084px;
  margin: 0 auto;
  padding-top: 10%;
  padding-bottom: 5%;
}
@media screen and (max-width: 768px) {
  #key-visual .key-wrap section {
    padding-top: 15%;
    padding-bottom: 10%;
    transition-property: all;
    transition-duration: 0.3s;
  }
}
#key-visual .key-wrap img {
  width: 100%;
}
#key-visual .key-bottom {
  background-image: url(../image/curry/curry-border.svg);
  background-repeat: repeat-x;
  background-position: bottom left;
  background-size: 70%;
  padding: 0 3%;
}
@media screen and (max-width: 768px) {
  #key-visual .key-bottom {
    background-size: 100%;
    transition-property: all;
    transition-duration: 0.3s;
  }
}
#key-visual .key-bottom section {
  padding-bottom: 10%;
}
#key-visual .key-bottom .title-area {
  max-width: 50%;
  margin: 0 auto;
  padding-bottom: 4%;
  background-image: url(../image/curry/curry-title-bar.svg);
  background-repeat: no-repeat;
  background-position: bottom center;
  background-size: 70%;
}
#key-visual .key-bottom .title-area h3 {
  text-align: center;
  font-weight: bolder;
  font-size: clamp(21px, 3vw, 28px);
  line-height: 140%;
}
@media screen and (max-width: 768px) {
  #key-visual .key-bottom .title-area {
    max-width: 100%;
    background-size: 50%;
    padding-bottom: 7%;
    transition-property: all;
    transition-duration: 0.3s;
  }
}
#key-visual .key-bottom .img-area {
  max-width: 600px;
  margin: 40px auto;
}
@media screen and (max-width: 768px) {
  #key-visual .key-bottom .img-area {
    max-width: 80%;
    transition-property: all;
    transition-duration: 0.3s;
  }
}
#key-visual .key-bottom .img-area img {
  width: 100%;
}
#key-visual .key-bottom .text-area {
  max-width: 770px;
  margin: 0 auto;
}
#key-visual .key-bottom .text-area p {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 500;
  font-size: clamp(12px, 3vw, 21px);
  line-height: 160%;
}
@media screen and (max-width: 768px) {
  #key-visual .key-bottom .text-area p {
    font-size: clamp(14px, 3vw, 21px);
    padding: 0 3%;
    transition-property: all;
    transition-duration: 0.3s;
  }
}

#checklist {
  padding: 6% 3%;
}
#checklist .title-area {
  max-width: 600px;
  margin: 0 auto;
  padding-bottom: 4%;
  text-align: center;
  position: relative;
  background-image: url(../image/curry/curry-title-bar.svg);
  background-repeat: no-repeat;
  background-position: bottom center;
  background-size: 70%;
}
@media screen and (max-width: 768px) {
  #checklist .title-area {
    padding-bottom: 8%;
    transition-property: all;
    transition-duration: 0.3s;
  }
}
#checklist .title-area h3 {
  font-family: "Zen Maru Gothic", serif;
  font-weight: 400;
  font-weight: bold;
  font-size: clamp(21px, 3vw, 36px);
}
@media screen and (max-width: 768px) {
  #checklist .title-area {
    background-size: 50%;
    transition-property: all;
    transition-duration: 0.3s;
  }
}
#checklist .title-area::before {
  content: "";
  width: 7%;
  height: 100%;
  background-image: url(../image/curry/curry-check-icon.svg);
  background-repeat: no-repeat;
  background-size: 100%;
  left: 3%;
  position: absolute;
}
#checklist .sub-title {
  background-color: #C42121;
  max-width: 870px;
  margin: 2% auto;
  padding: 1% 0;
}
#checklist .sub-title p {
  color: white;
  font-size: clamp(12px, 2vw, 21px);
  font-weight: bold;
  text-align: center;
}
@media screen and (max-width: 768px) {
  #checklist .sub-title p {
    line-height: 140%;
    transition-property: all;
    transition-duration: 0.3s;
  }
}
#checklist .sub-title br {
  display: none;
}
@media screen and (max-width: 768px) {
  #checklist .sub-title br {
    display: block;
    transition-property: all;
    transition-duration: 0.3s;
  }
}
#checklist .check-list-img {
  margin: 3% auto;
  max-width: 690px;
}
@media screen and (max-width: 768px) {
  #checklist .check-list-img {
    margin: 8% 3%;
    transition-property: all;
    transition-duration: 0.3s;
  }
}
#checklist .check-list-img img {
  width: 100%;
}
#checklist .arart-area {
  max-width: 870px;
  margin: 0 auto;
  border: solid 1px #C42121;
}
#checklist .arart-area p {
  padding: 3% 0;
  text-align: center;
  font-size: clamp(12px, 2vw, 21px);
  font-weight: bold;
  line-height: 160%;
  color: #C42121;
}

#roling {
  background-color: #F8EB79;
}
#roling section {
  background-image: url(../image/curry/curry-border.svg);
  background-repeat: repeat-x;
  background-position: top left;
  background-size: 70%;
  padding: 6% 3%;
}
@media screen and (max-width: 768px) {
  #roling section {
    background-size: 100%;
    transition-property: all;
    transition-duration: 0.3s;
  }
}
#roling .title-area {
  max-width: 60%;
  margin: 0 auto;
  padding-bottom: 4%;
  text-align: center;
  position: relative;
  background-image: url(../image/curry/curry-title-bar.svg);
  background-repeat: no-repeat;
  background-position: bottom center;
  background-size: 70%;
}
#roling .title-area h3 {
  font-family: "Zen Maru Gothic", serif;
  font-weight: 400;
  font-weight: 900;
  font-size: clamp(21px, 3vw, 36px);
  line-height: 140%;
}
#roling .roling-text {
  display: flex;
  max-width: 974px;
  margin: 3% auto 0% auto;
  background-color: white;
  border-radius: 15px;
  padding: 2% 3%;
  align-items: center;
  justify-content: space-between;
}
#roling .roling-text .img-area {
  max-width: 220px;
  padding-right: 3%;
}
#roling .roling-text .img-area img {
  width: 100%;
}
#roling .roling-text .text-area {
  width: 75%;
}
#roling .roling-text .text-area p {
  font-size: clamp(12px, 2vw, 21px);
  line-height: 160%;
}

#cta {
  background-image: url(../image/curry/curry-cta-bg.svg);
  background-repeat: no-repeat;
  background-position: center top;
  background-size: 10%;
  padding: 0 3%;
}
#cta section {
  padding: 6% 0;
}
#cta .title-area h3 {
  font-family: "Zen Maru Gothic", serif;
  font-weight: 400;
  font-size: clamp(21px, 3vw, 36px);
  line-height: 160%;
  font-weight: bold;
  text-align: center;
}
@media screen and (max-width: 768px) {
  #cta .title-area h3 {
    font-size: clamp(18px, 2vw, 24px);
    transition-property: all;
    transition-duration: 0.3s;
  }
}
#cta .title-area .pc {
  display: block;
}
@media screen and (max-width: 768px) {
  #cta .title-area .pc {
    display: none;
    transition-property: all;
    transition-duration: 0.3s;
  }
}
#cta .title-area .sp {
  display: none;
}
@media screen and (max-width: 768px) {
  #cta .title-area .sp {
    display: block;
    transition-property: all;
    transition-duration: 0.3s;
  }
}
#cta .title-area span {
  font-family: "Zen Maru Gothic", serif;
  font-weight: 400;
  font-weight: bold;
  position: relative;
}
#cta .title-area span::after {
  content: "";
  width: 100%;
  height: 20px;
  background-color: #F8EB79;
  position: absolute;
  left: 0;
  bottom: 0;
  z-index: -5;
}
@media screen and (max-width: 768px) {
  #cta .title-area span::after {
    height: 10px;
    transition-property: all;
    transition-duration: 0.3s;
  }
}
#cta .cta-area {
  margin: 3% auto;
  max-width: 960px;
}
#cta .cta-area .cta-copy {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
@media screen and (max-width: 768px) {
  #cta .cta-area .cta-copy {
    display: block;
    transition-property: all;
    transition-duration: 0.3s;
  }
}
#cta .cta-area .cta-copy .img-area {
  width: 30%;
}
@media screen and (max-width: 768px) {
  #cta .cta-area .cta-copy .img-area {
    margin: 20px auto;
    width: 50%;
    transition-property: all;
    transition-duration: 0.3s;
  }
}
#cta .cta-area .cta-copy .img-area img {
  width: 100%;
}
#cta .cta-area .cta-copy .text-area {
  width: 100%;
  padding-left: 5%;
}
#cta .cta-area .cta-copy .text-area p {
  font-size: clamp(12px, 2vw, 21px);
  font-weight: bold;
  line-height: 140%;
}
@media screen and (max-width: 768px) {
  #cta .cta-area .cta-copy .text-area p {
    font-size: clamp(14px, 3vw, 21px);
    transition-property: all;
    transition-duration: 0.3s;
  }
}
#cta .cta-area .cta-copy .text-area p br {
  display: block;
}
@media screen and (max-width: 768px) {
  #cta .cta-area .cta-copy .text-area p br {
    display: none;
    transition-property: all;
    transition-duration: 0.3s;
  }
}
#cta .cta-btn {
  max-width: 690px;
  margin: 6% auto;
}
#cta .cta-btn img {
  width: 100%;
}
#cta .arart-text p {
  font-size: clamp(12px, 2vw, 21px);
  line-height: 140%;
  color: #C42121;
}
@media screen and (max-width: 768px) {
  #cta .arart-text p {
    font-size: clamp(14px, 3vw, 21px);
    transition-property: all;
    transition-duration: 0.3s;
  }
}