@charset "UTF-8";
/*_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/

Staff CSS

_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/*/
/* Variables
-------------------------------------------- */
/* Content
-------------------------------------------- */
#container {
  /* ------------------------------------
  メインビジュアル
  ------------------------------------ */ }
  #container .page_ttl .main span + p {
    padding-right: 10px;
    display: inline-block; }
  #container #main.se_box .se_img_box {
    width: 100%;
    transform: translateX(0); }
  #container #main.se_box:hover .se_img_box .se_img img {
    transform: scale(1) rotate(0.001deg); }
  #container section.contents {
    max-width: 1000px;
    margin: 100px auto;
    text-align: center; }
    @media (max-width: 480px) {
      #container section.contents {
        margin: 60px auto; } }
    #container section.contents h2 {
      display: inline-block;
      text-align: center;
      line-height: 2.0; }
      @media (max-width: 960px) {
        #container section.contents h2 {
          margin-bottom: 40px; } }
      @media (max-width: 480px) {
        #container section.contents h2 {
          margin-bottom: 0; }
      }
      #container section.contents h2 p {
        display: inline-block;
        position: relative;
        font-size: 5.2rem;
        font-style: italic;
        font-family: "a-otf-ryumin-pr6n", serif;
        letter-spacing: 0.1em;
        opacity: 0;
        transform: translateX(5%);
        transition: all .5s; }
        #container section.contents h2 p::before {
          position: absolute;
          content: "";
          width: 0;
          height: 0.5em;
          left: 0;
          bottom: 0.3em;
          background: #FED8D8;
          z-index: 1;
          transition: width .5s; }
        #container section.contents h2 p.cc-anim-init::before {
          width: 100%; }
        #container section.contents h2 p span {
          position: relative;
          z-index: 2; }
        #container section.contents h2 p.cc-anim-init {
          opacity: 1;
          transform: translateX(0); }
        @media (max-width: 960px) {
          #container section.contents h2 p {
            font-size: 5.3vw; } }
        @media (max-width: 480px) {
          #container section.contents h2 p {
            font-size: 5.8vw; }
          #container section.contents h2 p span {
             font-size: 2rem;
          }
        }
    #container section.contents > p {
      text-align: left;
      margin-top: 40px;
      line-height: 2.0;
      opacity: 0;
      transform: translateY(5%);
      transition: all .5s; }
      #container section.contents > p.cc-anim-init {
        opacity: 1;
        transform: translateY(0); }
  #container section.report_section h3 {
    font-size: 3.4rem;
    font-family: "Cormorant Garamond", "Frank Ruhl Libre", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN W3", HiraMinProN-W3, "ヒラギノ明朝 ProN", "Hiragino Mincho ProN", "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "游明朝体", "YuMincho", "游明朝", "Yu Mincho", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", Georgia, serif;
    text-align: center;
    padding: 0 0 90px; }
    @media (max-width: 960px) {
      #container section.report_section h3 {
        font-size: 3rem;
        padding: 0 0 60px; } }
    @media (max-width: 480px) {
      #container section.report_section h3 {
        font-size: 2.4rem;
        padding: 0 0 40px; } }
  #container section.report_section.photo_album {
    max-width: 1220px;
    width: 100%;
    margin: 0 auto 40px; }
    #container section.report_section.photo_album .photo_album_list {
      margin: 0 -30px; }
      @media (max-width: 768px) {
        #container section.report_section.photo_album .photo_album_list {
          margin: 0 -20px; } }
      @media (max-width: 480px) {
        #container section.report_section.photo_album .photo_album_list {
          margin: 0 -5px; } }
      #container section.report_section.photo_album .photo_album_list li {
        width: 50%;
        float: left;
        padding: 0 30px; }
        @media (max-width: 768px) {
          #container section.report_section.photo_album .photo_album_list li {
            padding: 0 20px; } }
        @media (max-width: 480px) {
          #container section.report_section.photo_album .photo_album_list li {
            padding: 0 5px; } }
        #container section.report_section.photo_album .photo_album_list li:nth-child(2) {
          padding-top: 60px; }
          @media (max-width: 768px) {
            #container section.report_section.photo_album .photo_album_list li:nth-child(2) {
              padding-top: 40px; } }
          @media (max-width: 480px) {
            #container section.report_section.photo_album .photo_album_list li:nth-child(2) {
              padding-top: 10px; } }
        #container section.report_section.photo_album .photo_album_list li .img {
          margin: 0 0 60px; }
          @media (max-width: 768px) {
            #container section.report_section.photo_album .photo_album_list li .img {
              margin: 0 0 40px; } }
          @media (max-width: 480px) {
            #container section.report_section.photo_album .photo_album_list li .img {
              margin: 0 0 10px; } }


#container .page_ttl {
  padding: 0 0 70px; }



#container section#main.se_box .se_img_box, #container section.item.se_box .se_img_box {
  width: 100%;
  transform: translateX(0); }
#container section#main.se_box:hover .se_img_box .se_img img, #container section.item.se_box:hover .se_img_box .se_img img {
  transform: scale(1) rotate(0.001deg); }


#container section .uneven_box_wrap {
  margin-bottom: 100px;
}
@media (max-width: 480px) {
  #container section .uneven_box_wrap {
    margin-bottom: 40px;
  }
}
#container section .uneven_box_wrap > li {
  position: relative;
  margin-top: 100px; }
@media (max-width: 480px) {
  #container section .uneven_box_wrap > li {
    margin-top: 60px; } }
#container section .uneven_box_wrap > li ul li {
  width: 59.7%;
  margin: 0 auto 0 0; }
#container section .uneven_box_wrap > li ul li:last-child {
  width: 49.55%;
  margin: -5vw 14.18% 0 auto; }
@media (max-width: 960px) {
  #container section .uneven_box_wrap > li ul li:last-child {
    width: 70%;
    margin: -5vw 0 0 auto; } }
#container section .uneven_box_wrap > li ul li img {
  display: block; }
@media (max-width: 960px) {
  #container section .uneven_box_wrap > li ul li {
    width: 90%; } }
#container section .uneven_box_wrap > li .txt {
  position: absolute;
  width: 40%;
  top: 3.1%;
  right: 0;
  padding: 0px 0 30px 50px;
  background-color: #FFF; }
@media (max-width: 960px) {
  #container section .uneven_box_wrap > li .txt {
    position: relative;
    width: 100%;
    padding: 30px 0 0; } }
#container section .uneven_box_wrap > li .txt h4 span {
  display: block;
  font-size: 1.6rem;
  letter-spacing: 0;
  font-family: "Cormorant Garamond", "Frank Ruhl Libre", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN W3", HiraMinProN-W3, "ヒラギノ明朝 ProN", "Hiragino Mincho ProN", "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "游明朝体", "YuMincho", "游明朝", "Yu Mincho", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", Georgia, serif; }
#container section .uneven_box_wrap > li .txt p {
  margin-top: 20px;
  line-height: 1.8; }
#container section .uneven_box_wrap > li .txt p br {
  display: block; }
@media (max-width: 414px) {
  #container section .uneven_box_wrap > li .txt p br {
    display: none; } }



#container .point_box {
  position: relative;
  max-width: 1220px;
  width: 100%;
  padding: 70px 0 30px;
  margin: 0 auto 100px auto; }
#container .point_box::before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 50%;
  width: 100vw;
  height: 100%;
  transform: translateX(-50%);
  background: #F9F9F9;
  z-index: 1; }
#container .point_box header {
  position: relative;
  z-index: 2;
}
#container .point_box h4 {
  font-size: 2rem;
  font-family: "a-otf-ryumin-pr6n", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN W3", HiraMinProN-W3, "ヒラギノ明朝 ProN", "Hiragino Mincho ProN", "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "游明朝体", "YuMincho", "游明朝", "Yu Mincho", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", "Cormorant Garamond", "Frank Ruhl Libre", Georgia, serif;
  text-align: center;
  padding: 0 0 20px;
  position: relative;
  z-index: 2; }
@media (max-width: 960px) {
  #container .point_box h4 {
    font-size: 1.8rem;
    padding: 0 0 40px; } }
@media (max-width: 480px) {
  #container .point_box h4 {
    font-size: 1.6rem;
    padding: 0 0 20px; } }
#container .point_box h4 + p {
  position: relative;
  text-align: center;
  z-index: 2;
  padding: 0 0 70px;
}
#container .point_box ul {
  margin: 0 -30px;
  position: relative;
  z-index: 2; }
#container .point_box ul li {
  width: calc(100% / 3);
  float: left;
  padding: 0 30px 30px; }
#container .point_box ul li::after {
  background: #F9F9F9; }
#container .point_box ul li img {
  display: block;
  width: 100%; }
#container .point_box ul li h5 {
  font-size: 1.6rem;
  font-weight: bold;
  padding: 25px 0; }
#container .point_box ul li p {
  padding: 0 0 1.6em; }
@media (max-width: 768px) {
  #container .point_box ul {
    margin: 0 -20px; }
  #container .point_box ul li {
    padding: 0 20px 30px; } }
@media (max-width: 480px) {
  #container .point_box ul {
    margin: 0; }
  #container .point_box ul li {
    width: 100%;
    float: none;
    padding: 0 0 30px; }
  #container .point_box ul li:nth-child(2n)::after {
    transition-delay: 0s; } }

.plan {
  text-align: center;
  margin-bottom: 100px;
}
.plan img {
  width: initial;
}
@media (max-width: 480px) {
  .plan img {
    width: 100%;
  }
}



.flow {
  margin-bottom: 100px;
}
#container section .flowslider li {
  margin-top: 0;
  position: relative; }
#container section .flowslider li .controller {
  position: absolute;
  display: flex;
  justify-content: space-between;
  width: 100%;
  top: calc(50% - 25px); }
@media (max-width: 480px) {
  #container section .flowslider li .controller {
    top: 28%;
    height: 0; } }
#container section .flowslider li .controller li {
  position: relative;
  left: -20px;
  width: 50px;
  height: 50px; }
@media (max-width: 480px) {
  #container section .flowslider li .controller li {
    left: -10px;
    width: 40px;
    height: 40px; } }
#container section .flowslider li .controller li a {
  position: absolute;
  display: block;
  width: 50px;
  height: 50px;
  left: 0;
  top: 0; }
@media (max-width: 480px) {
  #container section .flowslider li .controller li a {
    width: 40px;
    height: 40px; } }
#container section .flowslider li .controller li a::after {
  position: absolute;
  content: "";
  left: 17px;
  top: 8px;
  width: 36px;
  height: 36px;
  border-top: 3px solid #000;
  border-right: 3px solid #000;
  -webkit-transform: rotate(-135deg);
  transform: rotate(-135deg); }
@media (max-width: 480px) {
  #container section .flowslider li .controller li a::after {
    left: 8px;
    width: 24px;
    height: 24px; } }
#container section .flowslider li .controller li a:last-child {
  /*display: none;*/ }
#container section .flowslider li .controller li:last-child {
  left: auto;
  right: -20px;
  margin: 0; }
@media (max-width: 480px) {
  #container section .flowslider li .controller li:last-child {
    right: -10px; } }
#container section .flowslider li .controller li:last-child a::after {
  right: 17px;
  left: auto;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg); }
@media (max-width: 480px) {
  #container section .flowslider li .controller li:last-child a::after {
    right: 8px; } }
#container section .flowslider li .txt {
  position: absolute;
  width: 50%;
  left: 0;
  top: auto;
  bottom: 0;
  padding: 30px 30px 0 30px;
  background-color: #FFF; }
@media (max-width: 768px) {
  #container section .flowslider li .txt {
    position: relative;
    width: 100%;
    padding: 30px 0 0; } }

.flowslider .bx-wrapper {
  width: 100% !important;
  max-width: 100% !important;
}

.flowslider .flow_num {
  color: #fff;
  background-color: #AB9169;
  font-size: 2.4rem;
  text-align: center;
  width: 50px;
  height: 50px;
  position: absolute;
  top: 0;
  left: 0;
  display: table;
}
.flowslider .flow_num span {
  display: table-cell;
  vertical-align: middle;
}
.flowslider .flow_num + div {
  padding: 25px;
}



#container section.report_section h3 {
  font-size: 3.4rem;
  font-family: "Cormorant Garamond", "Frank Ruhl Libre", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN W3", HiraMinProN-W3, "ヒラギノ明朝 ProN", "Hiragino Mincho ProN", "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "游明朝体", "YuMincho", "游明朝", "Yu Mincho", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", Georgia, serif;
  text-align: center;
  padding: 0 0 90px; }
@media (max-width: 960px) {
  #container section.report_section h3 {
    font-size: 3rem;
    padding: 0 0 60px; } }
@media (max-width: 480px) {
  #container section.report_section h3 {
    font-size: 2.4rem;
    padding: 0 0 40px; } }
#container section.report_section.photo_album {
  max-width: 1220px;
  width: 100%;
  margin: 0 auto 40px; }
#container section.report_section.photo_album .photo_album_list {
  margin: 0 -30px; }
@media (max-width: 768px) {
  #container section.report_section.photo_album .photo_album_list {
    margin: 0 -20px; } }
@media (max-width: 480px) {
  #container section.report_section.photo_album .photo_album_list {
    margin: 0 -5px; } }
#container section.report_section.photo_album .photo_album_list li {
  width: 50%;
  float: left;
  padding: 0 30px; }
@media (max-width: 768px) {
  #container section.report_section.photo_album .photo_album_list li {
    padding: 0 20px; } }
@media (max-width: 480px) {
  #container section.report_section.photo_album .photo_album_list li {
    padding: 0 5px; } }
#container section.report_section.photo_album .photo_album_list li:nth-child(2) {
  padding-top: 60px; }
@media (max-width: 768px) {
  #container section.report_section.photo_album .photo_album_list li:nth-child(2) {
    padding-top: 40px; } }
@media (max-width: 480px) {
  #container section.report_section.photo_album .photo_album_list li:nth-child(2) {
    padding-top: 10px; } }
#container section.report_section.photo_album .photo_album_list li .img {
  margin: 0 0 60px; }
@media (max-width: 768px) {
  #container section.report_section.photo_album .photo_album_list li .img {
    margin: 0 0 40px; } }
@media (max-width: 480px) {
  #container section.report_section.photo_album .photo_album_list li .img {
    margin: 0 0 10px; } }





#container .contents aside {
  max-width: 1220px;
  margin: 100px auto; }
@media (max-width: 768px) {
  #container .contents aside {
    margin: 40px auto; } }
#container .contents aside dl {
  display: flex;
  position: relative;
  background: #f9f7f4; }
#container .contents aside dl dt {
  width: 33.3%;
  height: auto;
  background: url(../img/cuisine/staff.jpg) center center no-repeat;
  background-size: cover; }
#container .contents aside dl dd {
  width: 66.6%;
  padding: 30px; }
#container .contents aside dl dd span {
  font-size: 1.4rem;
  font-family: "a-otf-ryumin-pr6n", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN W3", HiraMinProN-W3, "ヒラギノ明朝 ProN", "Hiragino Mincho ProN", "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "游明朝体", "YuMincho", "游明朝", "Yu Mincho", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", "Cormorant Garamond", "Frank Ruhl Libre", Georgia, serif; }
#container .contents aside dl dd h4 {
  position: relative;
  font-size: 3.8rem;
  font-family: "Cormorant Garamond", "Frank Ruhl Libre", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN W3", HiraMinProN-W3, "ヒラギノ明朝 ProN", "Hiragino Mincho ProN", "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "游明朝体", "YuMincho", "游明朝", "Yu Mincho", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", Georgia, serif;
  margin-bottom: 20px;
  padding-bottom: 15px; }
@media (max-width: 480px) {
  #container .contents aside dl dd h4 {
    font-size: 3.0rem; } }
#container .contents aside dl dd h4::after {
  position: absolute;
  content: "";
  width: 40px;
  height: 2px;
  background-color: #d8ccb8;
  left: 0;
  bottom: 0; }
#container .contents aside dl dd p {
  line-height: 2; }
@media (max-width: 900px) {
  #container .contents aside dl {
    display: block; }
  #container .contents aside dl dt {
    position: absolute;
    top: 32px;
    left: 30px;
    width: 64px;
    height: 64px;
    border-radius: 100%;
    overflow: hidden;
    background-position: center 25%;
    background-size: auto 200%; }
  #container .contents aside dl dd {
    width: 100%;
    padding: 30px 30px 30px 114px; }
  #container .contents aside dl dd p {
    margin: 0 0 0 -84px; } }
@media (max-width: 480px) {
  #container .contents aside dl dt {
    top: 30px;
    left: 20px; }
  #container .contents aside dl dd {
    padding: 30px 20px 30px 104px; }
  #container .contents aside dl dd h4 {
    font-size: 3rem; } }

#container aside {
  margin: 100px auto; }
  @media (max-width: 480px) {
    #container aside {
      margin: 60px auto; } }
  #container aside dl {
    display: flex;
    background-color: #f9f7f4; }
    @media (max-width: 900px) {
      #container aside dl {
        flex-direction: column; } }
    #container aside dl dt {
      width: 33.3%;
      height: auto;
      background: url(../img/cuisine/staff.jpg) center center no-repeat;
      background-size: cover; }
      @media (max-width: 900px) {
        #container aside dl dt {
          width: 100%;
          height: 200px; } }
    #container aside dl dd {
      width: 66.6%;
      padding: 30px; }
      @media (max-width: 900px) {
        #container aside dl dd {
          width: 100%; } }
      @media (max-width: 480px) {
        #container aside dl dd {
          padding: 30px 20px; } }
      #container aside dl dd span {
        font-family: "a-otf-ryumin-pr6n", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN W3", HiraMinProN-W3, "ヒラギノ明朝 ProN", "Hiragino Mincho ProN", "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "游明朝体", "YuMincho", "游明朝", "Yu Mincho", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", "Cormorant Garamond", "Frank Ruhl Libre", Georgia, serif; }
      #container aside dl dd h4 {
        position: relative;
        font-size: 3.8rem;
        font-family: "Cormorant Garamond", "Frank Ruhl Libre", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN W3", HiraMinProN-W3, "ヒラギノ明朝 ProN", "Hiragino Mincho ProN", "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "游明朝体", "YuMincho", "游明朝", "Yu Mincho", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", Georgia, serif;
        margin-bottom: 20px;
        padding-bottom: 15px; }
        @media (max-width: 480px) {
          #container aside dl dd h4 {
            font-size: 3.0rem; } }
        #container aside dl dd h4::after {
          position: absolute;
          content: "";
          width: 40px;
          height: 2px;
          background-color: #d8ccb8;
          left: 0;
          bottom: 0; }
      #container aside dl dd p {
        line-height: 2.0; }

.cc-slide-cover {
  display: block;
  height: 100%; }

.cc-slide-cover::after {
  z-index: 100; }





.point {
  margin-bottom: 100px;
}
.reason_point header.page_ttl {
  margin-bottom: 2rem !important;
  padding: 0 !important;
}
#container section .pointslider li {
  margin-top: 0;
  position: relative;
}
#container section .pointslider h3 {
  color: #AB9169;
  font-weight: 600;
  text-align: left;
}
#container section .pointslider p {
  text-align: left;
}
#container section .pointslider li .controller {
  position: absolute;
  display: flex;
  justify-content: space-between;
  width: 100%;
  top: calc(50% - 25px);
}
@media (max-width: 480px) {
  #container section .pointslider li .controller {
    top: 28%;
    height: 0;
  }
}
#container section .pointslider li .controller li {
  position: relative;
  left: -20px;
  width: 50px;
  height: 50px;
}
@media (max-width: 480px) {
  #container section .pointslider li .controller li {
    left: -10px;
    width: 40px;
    height: 40px;
  }
}
#container section .pointslider li .controller li a {
  position: absolute;
  display: block;
  width: 50px;
  height: 50px;
  left: 0;
  top: 0;
}
@media (max-width: 480px) {
  #container section .pointslider li .controller li a {
    width: 40px;
    height: 40px;
  }
}
#container section .pointslider li .controller li a::after {
  position: absolute;
  content: "";
  left: 17px;
  top: 8px;
  width: 36px;
  height: 36px;
  border-top: 3px solid #000;
  border-right: 3px solid #000;
  -webkit-transform: rotate(-135deg);
  transform: rotate(-135deg);
}
@media (max-width: 480px) {
  #container section .pointslider li .controller li a::after {
    left: 8px;
    width: 24px;
    height: 24px;
  }
}
#container section .pointslider li .controller li a:last-child {
  /*display: none;*/
}
#container section .pointslider li .controller li:last-child {
  left: auto;
  right: -20px;
  margin: 0;
}
@media (max-width: 480px) {
  #container section .pointslider li .controller li:last-child {
    right: -10px;
  }
}
#container section .pointslider li .controller li:last-child a::after {
  right: 17px;
  left: auto;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}
@media (max-width: 480px) {
  #container section .pointslider li .controller li:last-child a::after {
    right: 8px;
  }
}
#container section .pointslider li .txt {
  position: absolute;
  width: 50%;
  left: 0;
  top: auto;
  bottom: 0;
  padding: 30px 30px 0 30px;
  background-color: #FFF;
}
@media (max-width: 768px) {
  #container section .pointslider li .txt {
    position: relative;
    width: 100%;
    padding: 30px 0 0;
  }
}
.pointslider .bx-wrapper {
  width: 100% !important;
  max-width: 100% !important;
}
.pointslider .point_num {
  color: #fff;
  background-color: #AB9169;
  font-size: 2.4rem;
  text-align: center;
  width: 50px;
  height: 50px;
  position: absolute;
  top: 0;
  left: 0;
  display: table;
}
.pointslider .point_num span {
  display: table-cell;
  vertical-align: middle;
}
.pointslider .point_num+div {
  padding: 25px;
}


.reason_flow {
  margin-bottom: 100px;
}
.reason_flow header {
  padding-bottom: 3rem !important;
}
.reason_flow h3 {
  font-size: 6rem;
  text-align: center;
  line-height: 1.2;
  margin-bottom: 2rem;
}
.reason_flow h3 span {
  display: block;
  font-size: 1.6rem;
}
.reason_flow_content {
  display: flex;
  justify-content: space-between;
}
.reason_flow_content > div {
  width: calc(100% / 5 - 20px);
  position: relative;
}
.reason_flow_content .reason_flow_content_img {
  margin-bottom: 1rem;
}
.reason_flow_content img {
  border-radius: 500px;
}
.reason_flow_content h4 {
  color: #AB9169;
  text-align: center;
  font-weight: 600;
}
.reason_flow_content > div:after {
  color: #AB9169;
  content: "▼";
  position: absolute;
  top: 90px;
  right: -20px;
  transform: rotate(-90deg);
}
.reason_flow_content > div:last-child:after {
  content: "";
}
.reason_flow_content p {
  padding: 0 10px;
}
@media (max-width: 480px) {
  .reason_flow h3 {
    font-size: 3.6rem;
  }
  .reason_flow h3 span {
    font-size: 1.2rem;
  }
  .reason_flow_content {
    display: block;
  }
  .reason_flow_content > div {
    width: 100%;
    display: flex;
    justify-content: space-between;
    margin-bottom: 2rem;
  }
  .reason_flow_content .reason_flow_content_img {
    width: calc(30% - 10px);
  }
  .reason_flow_content .reason_flow_content_text {
    width: calc(70% - 10px);
  }
  .reason_flow_content > div:after {
    top: auto;
    right: auto;
    bottom: -15px;
    left: 12%;
    transform: none;
  }
  .reason_flow_content p {
    padding: 0;
  }
}

.banner_fair {
  text-align: center;
  margin-bottom: 20px;
}
.banner_fair img {
  width: auto;
}
@media (max-width: 480px) {
  .banner_fair img {
    width: 100%;
  }
}