@import url(index.css);
@import url(swiper.css);

a {
  text-decoration: none;
}

.wrapper {
  background: url("../image/cheering_bg.png");
}

.top_main {
  max-width: 1900px;
  margin: 0 auto;
}

.pc_br {
  display: block;
}
@media only screen and (max-width: 640px) {
  .pc_br {
    display: none;
  }
}

.sp_br {
  display: none;
}
@media only screen and (max-width: 640px) {
  .sp_br {
    display: block;
  }
}

.memu_block_link {
  height: 94px;
}
@media only screen and (max-width: 640px) {
  .memu_block_link {
    height: 59px;
  }
}
.memu_block_link_inner {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: fixed;
  bottom: 0;
  background: #171c42;
  z-index: 10;
}
.memu_block_link_box {
  width: 50%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start;
  padding: 0.9375rem 0;
}
@media only screen and (max-width: 640px) {
  .memu_block_link_box {
    padding: 0.5375rem 0;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
  }
}
@media only screen and (max-width: 640px) {
  .memu_block_link_box:nth-child(1) {
    width: 20%;
  }
}
@media only screen and (max-width: 640px) {
  .memu_block_link_box:nth-child(2) {
    width: 80%;
  }
}
.memu_block_link_logo {
  max-width: 31px;
  width: 100%;
  margin: 0 auto;
}
.memu_block_link_btn {
  max-width: 21.5625rem;
  width: 100%;
  background: -webkit-gradient(
    linear,
    left top,
    right top,
    from(#9b7300),
    to(#c5993f)
  );
  background: linear-gradient(to right, #9b7300, #c5993f);
  text-align: center;
  border: 1px solid #fff;
  margin-right: 1.6875rem;
}
.memu_block_link_btn:hover {
  background: linear-gradient(
    to right,
    rgba(155, 115, 0, 0.7),
    rgba(197, 153, 63, 0.7)
  );
}
@media only screen and (max-width: 640px) {
  .memu_block_link_btn {
    max-width: 200px;
    height: initial;
    margin-right: 1.5rem;
  }
}
.memu_block_link_btn_link {
  color: #fff !important;
  text-decoration: none;
  width: 100%;
  display: block;
  font-size: 1.5rem;
  letter-spacing: 0.3em;
  padding: 1.1875rem 0;
  position: relative;
}
@media only screen and (max-width: 640px) {
  .memu_block_link_btn_link {
    font-size: 15px;
    padding: 11px 0;
    padding-left: 0.5rem;
  }
}
.memu_block_link_btn_link::before {
  content: "";
  width: 0.625rem;
  height: 0.625rem;
  border: 0;
  border-top: solid 1px #fff;
  border-right: solid 1px #fff;
  position: absolute;
  top: 50%;
  left: 5%;
  margin-top: -3px;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}
@media only screen and (max-width: 640px) {
  .memu_block_link_btn_link::before {
    width: 6px;
    height: 6px;
  }
}
.memu_block_link_flex {
  display: block;
  border-left: 1px solid #fff;
  padding-left: 1.6875rem;
  position: relative;
}
@media only screen and (max-width: 640px) {
  .memu_block_link_flex {
    padding-left: 1.5rem;
  }
}
.memu_block_link_flex_phone {
  height: 100%;
  width: 100%;
  display: block;
  text-decoration: none;
}
.memu_block_link_flex_info {
  color: #fff;
  font-size: 1.8125rem;
  letter-spacing: 0.1em;
}
@media only screen and (max-width: 640px) {
  .memu_block_link_flex_info {
    display: none;
  }
}
.memu_block_link_flex_time {
  font-size: 0.8125rem;
  color: #fff;
  letter-spacing: 0.1em;
}
@media only screen and (max-width: 640px) {
  .memu_block_link_flex_time {
    display: none;
  }
}
.memu_block_link_flex img {
  display: none;
}
@media only screen and (max-width: 640px) {
  .memu_block_link_flex img {
    display: block;
    width: 23px;
    padding: 10px 0;
  }
}

.l-container {
  width: 87%;
  margin: 0 auto;
}

.l-wrapper {
  width: 94%;
  margin: 0 auto;
}

.h2_title_sub {
  font-size: 26px !important;
  font-family: "EB Garamond", serif;
  letter-spacing: 0.2em;
}
@media only screen and (max-width: 640px) {
  .h2_title_sub {
    font-size: 14px !important;
  }
}

/* indexcss　エンド */

.top_visual {
  position: relative;
}
.top_visual_inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 100%;
}
@media only screen and (max-width: 640px) {
  .top_visual_inner {
    display: block;
  }
}
@media (min-width: 640px) {
  .top_visual_inner {
    height: 600px;
  }
}
.top_visual_i {
  position: absolute;
  right: 3%;
  top: -30px;
  max-width: 310px;
}
@media (min-width: 640px) {
  .top_visual_i {
    max-width: 350px;
    top: 40%;
    left: 180px;
    right: auto;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
  }
}
@media (min-width: 1000px) {
  .top_visual_i {
    max-width: 520px;
    top: 40%;
    left: 65px;
    right: auto;
    -webkit-transform: translate(0%, -50%);
    transform: translate(0%, -50%);
  }
}
.top_visual_left {
  background-image: url("../image/kv01.png");
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
  width: 50%;
  height: 699px;
  z-index: 1;
}
@media only screen and (max-width: 640px) {
  .top_visual_left {
    width: 100%;
    height: 224px;
  }
}
.top_visual_right {
  background-image: url("../image/kv02.png");
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
  width: 50%;
  z-index: 1;
  padding-bottom: 1.375rem;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  position: relative;
}
@media only screen and (max-width: 640px) {
  .top_visual_right {
    width: 100%;
    height: 370px;
    background-image: url("../image/kv_bk_sp.png");
  }
}
.top_visual_right::before {
  content: "";
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
  width: 100%;
  max-width: 742px;
  height: 600px;
  position: absolute;
  top: 50%;
  left: 50%;
  margin-right: -50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
}
@media only screen and (max-width: 640px) {
  .top_visual_right::before {
    height: 400px;
  }
}
.top_visual_right_block {
  width: 100%;
  height: 100%;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}
@media only screen and (max-width: 640px) {
  .top_visual_right_block {
    margin: initial;
  }
}
.top_visual_right_block_txt {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  position: absolute;
  bottom: 54px;
  font-size: 12px;
  color: #fff;
}
@media only screen and (max-width: 640px) {
  .top_visual_right_block_txt {
    font-size: 9px;
  }
}
.top_visual_right_block_txt.sp {
  display: none;
  width: 90%;
}
@media only screen and (max-width: 640px) {
  .top_visual_right_block_txt.sp {
    display: block;
  }
}
.top_visual_right_block_txt.lg {
  display: block;
}
@media only screen and (max-width: 640px) {
  .top_visual_right_block_txt.lg {
    display: none;
  }
}

@media screen and (min-width: 1000px) {
  .top_visual_right_block_txt.lg {
    left: 60%;
    bottom: 45px;
    -webkit-transform: translateX(-50%);
    transform: translateX(-52%);
    width: 80%;
  }
}
@media screen and (min-width: 1441px) {
  .top_visual_right_block_txt.lg {
    left: 65%;
    bottom: 25px;
    -webkit-transform: translateX(-50%);
    transform: translateX(-52%);
    width: 60%;
  }
}
@media screen and (min-width: 1442px) and (max-width: 1640px){
  .top_visual_right_block_txt.lg{
    left: 70% !important;
  }
}
.top_visual_right_block_txt span {
  word-wrap: break-word;
  text-decoration: none;
  color: #fff;
}
.top_visual_block {
  position: absolute;
  top: 34%;
  margin-right: -50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  max-width: 153px;
  z-index: 2;
}
@media only screen and (max-width: 640px) {
  .top_visual_block {
    max-width: 130px;
    height: 182px;
  }
}
@media (min-width: 640px) {
  .top_visual_block {
    left: 50%;
    top: 30%;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    max-width: 253px;
    width: 100%;
  }
}
.top_visual_block a {
  height: 100%;
}
.top_visual_block_ttl {
  width: 100%;
  height: auto;
}
.top_visual_list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}
.top_visual_list_item {
  text-align: center;
}
.top_visual_list_item:nth-child(1) {
  margin-bottom: 2rem;
  margin-left: 8.925rem;
}
.top_visual_list_flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.top_visual_list_flex_item:nth-child(1) {
  padding-top: 30px;
}
.top_visual_list_flex_item:nth-child(2) {
  margin-left: 3.5rem;
}
.top_visual_list_ttl {
  color: #fff;
  font-size: 1.5rem;
  letter-spacing: 0.1em;
  line-height: 1.5;
  text-align: center;
  white-space: nowrap;
}
@media only screen and (max-width: 640px) {
  .top_visual_list_ttl {
    font-size: 0.875rem;
  }
}
.top_visual_list_ttl_service {
  font-size: 2rem;
}
@media only screen and (max-width: 640px) {
  .top_visual_list_ttl_service {
    font-size: 1.25rem;
  }
}
.top_visual_list_ttl_numbers {
  font-size: 2.5rem;
  padding-bottom: 0.125rem;
  border-bottom: 1px solid #707070;
}
@media only screen and (max-width: 640px) {
  .top_visual_list_ttl_numbers {
    font-size: 1.5625rem;
  }
}
.top_visual_list_ttl_note {
  font-size: 1rem;
}
@media only screen and (max-width: 640px) {
  .top_visual_list_ttl_note {
    font-size: 0.5625rem;
  }
}
.top_visual_btn {
  position: absolute;
  bottom: -70px;
  left: 50%;
  margin-right: -50%;
  -webkit-transform: translate(-50%, -92%);
  transform: translate(-50%, -92%);
  z-index: 2;
  max-width: 34.1875rem;
  width: 100%;
  text-align: center;
}
@media only screen and (max-width: 640px) {
  .top_visual_btn {
    max-width: 256px;
    -webkit-transform: translate(-50%, -57%);
    transform: translate(-50%, -57%);
  }
}
@media (min-width: 640px) {
  .top_visual_btn {
    bottom: -160px;
  }
}
.top_visual_btn_link {
  background: -webkit-gradient(
    linear,
    left top,
    right top,
    from(#9b7300),
    to(#c5993f)
  );
  background: linear-gradient(to right, #9b7300, #c5993f);
  position: relative;
  color: #fff !important;
  text-decoration: none;
  width: 100%;
  display: block;
  font-size: 1.875rem;
  letter-spacing: 0.3em;
  padding: 1.8vw 0;
  border: 1px solid #fff;
  display: inline-block;
  -webkit-transition: 0.5s;
  transition: 0.5s;
  bottom: 0px;
  -webkit-box-shadow: 0px 8px 0px 0px rgba(18, 23, 113, 0.4);
  box-shadow: 0px 8px 0px 0px rgba(18, 23, 113, 0.4);
  font-weight: 500;
}
@media only screen and (max-width: 640px) {
  .top_visual_btn_link {
    -webkit-box-shadow: 0px 5px 0px 0px rgba(18, 23, 113, 0.4);
    box-shadow: 0px 5px 0px 0px rgba(18, 23, 113, 0.4);
  }
}
.top_visual_btn_link:hover {
  -webkit-transform: translate3d(0, 8px, 0);
  transform: translate3d(0, 8px, 0);
  -webkit-box-shadow: none;
  box-shadow: none;
}
@media only screen and (max-width: 640px) {
  .top_visual_btn_link {
    font-size: 1.125rem;
    padding: 1.125rem 0;
    font-weight: 600;
    padding-left: 10px;
    background: -webkit-gradient(
      linear,
      left top,
      left bottom,
      from(#9b7300),
      to(#c5993f)
    );
    background: linear-gradient(to bottom, #9b7300, #c5993f);
  }
}
.top_visual_btn_link::before {
  content: "";
  width: 0.625rem;
  height: 0.625rem;
  border: 0;
  border-top: solid 2px #fff;
  border-right: solid 2px #fff;
  position: absolute;
  top: 50%;
  left: 5%;
  margin-top: -5px;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}

.inner_line {
  line-height: 1.3;
}
.inner_line_numbers {
  margin-bottom: 1rem;
}

/* top visual */

.top_message {
  position: relative;
  padding: 15.1875rem 0 7.1875rem;
}
@media only screen and (max-width: 640px) {
  .top_message {
    padding: 8.1875rem 0 7.1875rem;
    padding-bottom: 0px;
  }
}
.top_message_box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.top_message_box_left {
  max-width: 1200px;
  width: 62.5vw;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
  -ms-flex-align: end;
  align-items: end;
  padding-top: 70px;
}
@media only screen and (max-width: 640px) {
  .top_message_box_left {
    width: 283px;
    height: 167px;
    padding-top: 0;
  }
}
.top_message_box_left_img {
  width: 100%;
  height: 100%;
}
.top_message_box_right {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  -webkit-box-orient: vertical;
  -webkit-box-direction: reverse;
  -ms-flex-direction: column-reverse;
  flex-direction: column-reverse;
  -webkit-writing-mode: vertical-rl;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  margin-left: 9.625rem;
  position: relative;
}

@media only screen and (max-width: 1440px) {
  .top_message_box_right {
    margin-left: 4.625rem;
  }
}

@media only screen and (max-width: 640px) {
  .top_message_box_right {
    margin-left: initial;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
  }
}
.top_message_box_right_ttl {
  font-size: 50px;
  color: #171c42;
  letter-spacing: 0.3em;
  font-weight: 700;
}
@media only screen and (max-width: 640px) {
  .top_message_box_right_ttl {
    font-size: 24px;
    line-height: 2.4;
  }
}
.top_message_box_right_ttl_main {
  padding-top: 0.9125rem;
  font-size: 60px;
}
@media only screen and (max-width: 640px) {
  .top_message_box_right_ttl_main {
    font-size: 30px;
  }
}
.top_message_box_right_txt {
  font-size: 30px;
  font-weight: normal;
  letter-spacing: 0.2em;
  color: #171c42;
  margin-left: 6.5375rem;
  position: absolute;
  top: -45px;
  font-family: "EB Garamond", serif;
}
@media only screen and (max-width: 640px) {
  .top_message_box_right_txt {
    font-size: 14px;
    margin-left: initial;
    right: -10px;
  }
}
.top_message_wrap {
  max-width: 770px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: end;
  -ms-flex-pack: end;
  justify-content: end;
  margin: 0 18.33vw 0 auto;
  padding: 4.9375rem 0 6.875rem;
}

@media only screen and (max-width: 1440px) {
  .top_message_wrap {
    margin: 0 13.33vw 0 auto;
  }
}
@media only screen and (max-width: 640px) {
  .top_message_wrap {
    padding: 2.5rem 0.6875rem 1.4375rem;
    margin: 0 auto;
  }
}
.top_message_wrap_txt {
  font-size: 1.15rem;
  line-height: 1.9;
  letter-spacing: 0.04em;
}
@media only screen and (max-width: 640px) {
  .top_message_wrap_txt {
    font-size: 1.125rem;
    line-height: 1.4;
  }
}
.top_message_profile {
  max-width: 750px;
  margin: 0 auto;
  margin-bottom: 100px;
  text-align: center;
  overflow: hidden;
}
@media only screen and (max-width: 640px) {
  .top_message_profile {
    padding-top: 40px;
    margin-bottom: 0px;
  }
}
.top_message_profile_block {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: distribute;
  justify-content: space-around;
  position: relative;
  margin-bottom: 6.8125rem;
  padding-top: 30px;
}
@media only screen and (max-width: 640px) {
  .top_message_profile_block {
    margin-bottom: 4.1875rem;
  }
}
.top_message_profile_inner {
  display: block;
}
.top_message_profile_sub_ttl {
  font-weight: 700;
  font-size: 34px;
  color: #171c42;
}
@media only screen and (max-width: 640px) {
  .top_message_profile_sub_ttl {
    letter-spacing: 0.26em;
    font-size: 5.87vw;
  }
}
.top_message_profile_sub_ttl::before {
  content: "";
  width: 10.925rem;
  height: 16.925rem;
  border-top: solid 1px #171c42;
  position: absolute;
  top: -10%;
  left: -2%;
  -webkit-transform: rotate(30deg);
  transform: rotate(30deg);
}
@media only screen and (max-width: 640px) {
  .top_message_profile_sub_ttl::before {
    left: -40%;
    -webkit-transform: rotate(23deg);
    transform: rotate(23deg);
  }
}
.top_message_profile_sub_ttl::after {
  content: "";
  width: 4.925rem;
  height: 4.925rem;
  border-bottom: solid 1px #171c42;
  position: absolute;
  bottom: -30%;
  right: 15%;
  -webkit-transform: rotate(30deg);
  transform: rotate(30deg);
}
@media only screen and (max-width: 640px) {
  .top_message_profile_sub_ttl::after {
    right: -4%;
    -webkit-transform: rotate(23deg);
    transform: rotate(23deg);
  }
}
.top_message_profile_ttl {
  font-size: 45px;
  color: #171c42;
  letter-spacing: 0.2em;
  line-height: 1.7;
}
@media only screen and (max-width: 640px) {
  .top_message_profile_ttl {
    font-size: 8vw;
    letter-spacing: 0.26em;
  }
}
.top_message_profile_img {
  width: 100%;
}
.top_message_profile_img_pc {
  display: block;
}
@media only screen and (max-width: 640px) {
  .top_message_profile_img_pc {
    display: none;
  }
}
.top_message_profile_img_sp {
  display: none;
}
@media only screen and (max-width: 640px) {
  .top_message_profile_img_sp {
    display: block;
  }
}
.top_message_profile_txt {
  text-align: left;
  margin-top: 4.25rem;
  font-size: 1.25rem;
  line-height: 1.4;
  letter-spacing: 0.1em;
}
@media only screen and (max-width: 640px) {
  .top_message_profile_txt {
    font-size: 1.125rem;
    line-height: 1.5;
    margin-top: 2.5rem;
    text-align: justify;
  }
}
.top_message_profile_banner {
  background-image: url("../image/cheering_banner.png");
  background-position: center center;
  background-repeat: no-repeat;
  background-size: contain;
  height: 266px;
  max-width: 1200px;
  width: 100%;
  margin: 0 auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: relative;
  z-index: 0;
}
@media only screen and (max-width: 640px) {
  .top_message_profile_banner {
    background-image: url("../image/cheering_banner_sp.png");
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
    -ms-flex-direction: column-reverse;
    flex-direction: column-reverse;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    background-size: contain;
  }
}
.top_message_profile_banner_left {
  width: 50%;
  display: -ms-grid;
  display: grid;
  place-content: center;
  place-items: center;
}
@media only screen and (max-width: 640px) {
  .top_message_profile_banner_left {
    width: 100%;
    margin-top: 0.425rem;
  }
}
.top_message_profile_banner_left_ttl {
  font-size: 2.1875rem;
  color: #fff;
  font-weight: 700;
  letter-spacing: 0.1em;
  position: relative;
}
@media only screen and (max-width: 640px) {
  .top_message_profile_banner_left_ttl {
    font-size: 1.3125rem;
  }
}
.top_message_profile_banner_left_ttl::before {
  content: "";
  background: url("../image/top_message_profile_banner_left_img.png");
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
  width: 29px;
  height: 37px;
  position: absolute;
  top: 24%;
  left: -16%;
}
@media only screen and (max-width: 640px) {
  .top_message_profile_banner_left_ttl::before {
    width: 17px;
    height: 22px;
    top: 20%;
  }
}
.top_message_profile_banner_left_txt {
  font-size: 1.25rem;
  color: #fff;
  font-weight: 700;
  letter-spacing: 0.1em;
}
@media only screen and (max-width: 640px) {
  .top_message_profile_banner_left_txt {
    font-size: 0.75rem;
  }
}
.top_message_profile_banner_right {
  width: 50%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}
@media only screen and (max-width: 640px) {
  .top_message_profile_banner_right {
    width: 100%;
  }
}
.top_message_profile_banner_right_btn {
  max-width: 22.4375rem;
  width: 100%;
  background: -webkit-gradient(
    linear,
    left top,
    right top,
    from(#9b7300),
    to(#c5993f)
  );
  background: linear-gradient(to right, #9b7300, #c5993f);
  text-align: center;
  position: relative;
}

.top_message_profile_banner_right_btn:hover {
  background: linear-gradient(
    to right,
    rgba(155, 115, 0, 0.7),
    rgba(197, 153, 63, 0.7)
  );
}

.top_message_profile_banner_right_btn::after {
  content: "";
  position: absolute;
  top: 5px;
  left: 5px;
  background-color: rgba(18, 23, 113, 0.4);
  width: 100%;
  height: 100%;
  z-index: -1;
}
@media only screen and (max-width: 640px) {
  .top_message_profile_banner_right_btn {
    max-width: 15.375rem;
    background: -webkit-gradient(
      linear,
      left top,
      left bottom,
      from(#9b7300),
      to(#c5993f)
    );
    background: linear-gradient(to bottom, #9b7300, #c5993f);
  }
}
.top_message_profile_banner_right_btn_link {
  color: #fff !important;
  border: 1px solid #fff;
  text-decoration: none;
  width: 100%;
  display: block;
  font-size: 1.5rem;
  letter-spacing: 0.3em;
  padding: 1.2rem 0;
  position: relative;
  z-index: 1;
}

@media only screen and (max-width: 640px) {
  .top_message_profile_banner_right_btn_link {
    font-size: 1.125rem;
    padding: 1.125rem 0;
  }
}
.top_message_profile_banner_right_btn_link::before {
  content: "";
  width: 0.625rem;
  height: 0.625rem;
  border: 0;
  border-top: solid 1px #fff;
  border-right: solid 1px #fff;
  position: absolute;
  top: 50%;
  left: 5%;
  margin-top: -5px;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}

@media only screen and (max-width: 640px) {
  .flex-s {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
    -ms-flex-direction: row-reverse;
    flex-direction: row-reverse;
  }
}

/* top_message.css エンド */

.top_access {
  background: #171c42;
  padding: 3.75rem 0 3.625rem;
}
.top_access_inner {
  padding: 0 1.25rem;
  box-sizing: border-box;
}
.top_access_block {
  display: flex;
  justify-content: space-between;
  margin: 0 auto;
  max-width: 1200px;
  margin-bottom: 3.5rem;
}
@media only screen and (max-width: 640px) {
  .top_access_block {
    flex-wrap: wrap;
    justify-content: initial;
    margin-bottom: initial;
  }
}
.top_access_block_left {
  writing-mode: vertical-rl;
}
.top_access_block_left_ttl {
  color: #fff;
  font-size: 3.125rem;
  letter-spacing: 0.3em;
  margin-top: 0.625rem;
}
@media only screen and (max-width: 640px) {
  .top_access_block_left_ttl {
    font-weight: normal;
    font-size: 1.5rem;
  }
}
.top_access_block_left_txt {
  color: #fff;
  font-size: 1rem;
  letter-spacing: 0.3em;
}
@media only screen and (max-width: 640px) {
  .top_access_block_left_txt {
    font-size: 0.9375rem;
  }
}
.top_access_block_img {
  display: flex;
  align-items: center;
  height: 100%;
  width: 100%;
  max-width: 110px;
  margin-top: 3.125rem;
}
.top_access_block_img img {
  width: 110px;
}
@media only screen and (max-width: 640px) {
  .top_access_block_img {
    margin: 0 auto;
    max-width: 61px;
  }
}
.top_access_block_right {
  margin-top: 3.125rem;
}
.top_access_block_right_box {
  margin-bottom: 1.875rem;
}
.top_access_block_right_ttl {
  color: #fff;
  font-size: 1.25rem;
  letter-spacing: 0.1em;
}
.top_access_block_right_txt {
  color: #fff;
  margin-top: 0.875rem;
  font-size: 0.925rem;
  line-height: 1.2;
  letter-spacing: 0.1em;
  white-space: nowrap;
}
.top_access_map {
  width: 100%;
  display: flex;
  justify-content: center;
  margin-top: 1.5rem;
  max-width: 1200px;
  margin: 0 auto;
} /*# sourceMappingURL=top_access.css.map */

/* top_accesscss　エンド */

.top_service {
  position: relative;
  padding: 9.1875rem 0 12.4375rem;
}

@media only screen and (max-width: 640px) {
  .top_service {
    padding: 3.125rem 0 5.125rem;
  }
}

.top_service_block {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  max-width: 1000px;
  margin: 0 auto 0 16.5rem;
  padding: 0 1.25rem;
}

@media only screen and (max-width: 640px) {
  .top_service_block {
    margin: 0 auto;
    display: block;
  }
}

.top_service_block_left {
  padding: 0 10.625rem;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

@media only screen and (max-width: 640px) {
  .top_service_block_left {
    padding: initial;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: baseline;
    -ms-flex-align: baseline;
    align-items: baseline;
  }
}

.top_service_block_left_ttl {
  -webkit-writing-mode: vertical-rl;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  font-size: 3.125rem;
  letter-spacing: 0.3em;
  color: #171c42;
  margin: 0 auto 1.15rem;
}

@media only screen and (max-width: 640px) {
  .top_service_block_left_ttl {
    -webkit-writing-mode: initial;
    -ms-writing-mode: initial;
    writing-mode: initial;
    font-size: 1.875rem;
    margin: initial;
  }
}

@media only screen and (max-width: 640px) {
  .top_service_block_left_ttl_flex {
    font-size: 2.4625rem;
  }
}

.top_service_block_left_txt {
  font-size: 1.825rem;
  letter-spacing: 0.3em;
  color: #171c42;
}

@media only screen and (max-width: 640px) {
  .top_service_block_left_txt {
    font-size: 1rem;
  }
}

.top_service_block_right {
  margin-top: 1.25rem;
}

.top_service_block_right_txt {
  font-size: 1.25rem;
  letter-spacing: 0.13em;
  line-height: 2;
}

@media only screen and (max-width: 640px) {
  .top_service_block_right_txt {
    font-size: 1.125rem;
    line-height: 1.5;
    letter-spacing: 0.12em;
  }
}

.top_service_wrap {
  padding: 100px 0 0;
}

@media only screen and (max-width: 640px) {
  .top_service_wrap {
    padding: 20px 0 0;
  }
}

.top_service_wrap_block {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  max-width: 1200px;
  margin: 0 auto 0 13.5rem;
}

@media only screen and (max-width: 640px) {
  .top_service_wrap_block {
    margin: initial;
    display: block;
  }
}

@media only screen and (max-width: 640px) {
  .top_service_wrap_block::before {
    content: "";
    background: url("../image/alacalte_bg1.png");
    background-position: center center;
    background-repeat: no-repeat;
    background-size: cover;
    display: block;
    width: 186px;
    height: 1084px;
    position: absolute;
    top: 36%;
    left: 0;
    z-index: -1;
    opacity: 0.7;
  }
}

@media only screen and (max-width: 640px) {
  .top_service_wrap_block::after {
    content: "";
    background: url("../image/alacalte_bg1.png");
    background-position: center center;
    background-repeat: repeat;
    background-size: cover;
    display: block;
    width: 186px;
    height: 1018px;
    position: absolute;
    top: 10%;
    right: 0;
    z-index: -1;
    opacity: 0.7;
  }
}

@media (min-width: 1000px) {
  .top_service_wrap_block:nth-child(2) {
    margin: 10rem 5rem 0 24rem;
  }
}

@media only screen and (max-width: 640px) {
  .top_service_wrap_block:nth-child(2) {
    margin: initial;
  }
}

.top_service_wrap_box {
  display: block;
}

.top_service_wrap_box:nth-child(2) {
  margin-top: 2.8125rem;
  margin-left: 3.75rem;
}

@media only screen and (max-width: 640px) {
  .top_service_wrap_box:nth-child(2) {
    margin-left: initial;
    margin-top: initial;
  }
}

.top_service_wrap_box_line {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: relative;
}

@media only screen and (max-width: 640px) {
  .top_service_wrap_box_line {
    padding-top: 2rem;
  }
}

.top_service_wrap_box_line::after {
  content: "";
  background-image: url("../image/cheering_sv.png");
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
  max-width: 278px;
  width: 100%;
  min-height: 578px;
  position: absolute;
  right: 0;
  z-index: -1;
}

@media only screen and (max-width: 640px) {
  .top_service_wrap_box_line::after {
    display: none;
  }
}

.top_service_wrap_box_line_ttl {
  -webkit-writing-mode: vertical-rl;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  font-size: 1.925rem;
  color: #171c42;
  letter-spacing: 0.3em;
  margin-right: 1.9375rem;
}

@media only screen and (max-width: 640px) {
  .top_service_wrap_box_line_ttl {
    margin: 0 10px;
    font-size: 24px;
  }
}

.top_service_wrap_box_line_img {
  max-width: 342px;
  width: 100%;
  margin-top: 3.075rem;
}

@media only screen and (max-width: 640px) {
  .top_service_wrap_box_line_img {
    max-width: 640px;
    width: 100%;
    margin-left: auto;
  }
}

.top_service_wrap_box_line_img_pc {
  display: block;
}

@media only screen and (max-width: 640px) {
  .top_service_wrap_box_line_img_pc {
    display: none;
  }
}

.top_service_wrap_box_line_img_sp {
  display: none;
}

@media only screen and (max-width: 640px) {
  .top_service_wrap_box_line_img_sp {
    display: block;
  }
}

.top_service_wrap_box_line_position {
  display: block;
  margin-right: 1.9375rem;
}

@media only screen and (max-width: 640px) {
  .top_service_wrap_box_line_position {
    margin-right: initial;
  }
}

.top_service_wrap_box_line_position_txt {
  margin-top: 2rem;
  max-width: 342px;
  font-size: 17px;
  letter-spacing: 0.1em;
  line-height: 1.5;
}

@media only screen and (max-width: 640px) {
  .top_service_wrap_box_line_position_txt {
    margin-top: 1rem;
    padding: 0 10px;
    max-width: 640px;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
  }
}

.top_service_wrap_obsession {
  position: relative;
  padding-top: 15.5625rem;
}

@media only screen and (max-width: 640px) {
  .top_service_wrap_obsession {
    padding-top: 5.3125rem;
  }
}

.top_service_wrap_obsession::before {
  content: "";
  position: absolute;
  top: 53%;
  right: 0;
  margin-top: -5px;
  z-index: -2;
  width: 17.875rem;
  height: 10rem;
  z-index: -1;
  background-image: url("../image/top_service_wrap_obsession_img.png");
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
}

.top_service_wrap_obsession::after {
  content: "";
  position: absolute;
  top: 27%;
  left: 0;
  margin-top: -5px;
  z-index: -2;
  width: 30.875rem;
  height: 11rem;
  z-index: -1;
  background-image: url("../image/line_left.png");
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
}

@media only screen and (max-width: 1440px) {
  .top_service_wrap_obsession::after {
    top: 26%;
    width: 16.875rem;
  }
}

@media only screen and (max-width: 640px) {
  .top_service_wrap_obsession::before {
    width: 14.875rem;
    top: 28%;
  }
}

@media only screen and (max-width: 640px) {
  .top_service_wrap_obsession::after {
    content: "";
    width: 12.875rem;
    position: absolute;
    top: 10%;
    right: 0;
    margin-top: -5px;
    z-index: -2;
  }
}

.top_service_wrap_obsession_block {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  margin: 0 auto;
  max-width: 1200px;
}

@media only screen and (max-width: 640px) {
  .top_service_wrap_obsession_block {
    display: block;
  }
}

.top_service_wrap_obsession_block_left {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

@media only screen and (max-width: 640px) {
  .top_service_wrap_obsession_block_left {
    margin-bottom: 2.6875rem;
  }
}

.top_service_wrap_obsession_block_left_ttl {
  font-size: 2.8125rem;
  letter-spacing: 0.2em;
  line-height: 2;
  color: #171c42;
}

@media only screen and (max-width: 640px) {
  .top_service_wrap_obsession_block_left_ttl {
    font-size: 1.5rem;
    line-height: 1.6;
    padding-left: 4vw;
  }
}

.top_service_wrap_obsession_block_right {
  max-width: 870px;
  width: 100%;
  height: 100%;
  position: relative;
  left: -40px;
}

@media only screen and (max-width: 640px) {
  .top_service_wrap_obsession_block_right {
    max-width: 289px;
    left: 0px;
  }
}

.top_service_wrap_obsession_block_right_img_pc {
  display: block;
}

@media only screen and (max-width: 640px) {
  .top_service_wrap_obsession_block_right_img_pc {
    display: none;
  }
}

.top_service_wrap_obsession_block_right_img_sp {
  display: none;
}

@media only screen and (max-width: 640px) {
  .top_service_wrap_obsession_block_right_img_sp {
    display: block;
  }
}

.top_service_wrap_obsession_block_wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  padding-top: 6.6875rem;
  margin: 0 auto 0 24rem;
  max-width: 1200px;
}

@media only screen and (max-width: 640px) {
  .top_service_wrap_obsession_block_wrap {
    margin: initial;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
    -ms-flex-direction: column-reverse;
    flex-direction: column-reverse;
    padding-top: 1.375rem;
  }
}

.top_service_wrap_obsession_block_wrap_left {
  display: block;
  padding-right: 30px;
}

.top_service_wrap_obsession_block_wrap_left_box:nth-child(1) {
  margin-bottom: 5rem;
}

@media only screen and (max-width: 640px) {
  .top_service_wrap_obsession_block_wrap_left_box:nth-child(1) {
    margin-bottom: initial;
    width: 94%;
  }
}

.top_service_wrap_obsession_block_wrap_left_box:nth-child(2) {
  margin-left: 1rem;
}

.top_service_wrap_obsession_block_wrap_left_txt {
  font-size: 1.25rem;
  letter-spacing: 0.1em;
  line-height: 2;
}

@media only screen and (max-width: 640px) {
  .top_service_wrap_obsession_block_wrap_left_txt {
    font-size: 1.125rem;
    line-height: 1.7;
    width: 100%;
    margin-top: 2.3125rem !important;
    margin-bottom: 2.125rem !important;
  }
}

@media only screen and (max-width: 640px) {
  .top_service_wrap_obsession_block_wrap_left_txt.saler {
    font-size: 17px;
  }
}

.top_service_wrap_obsession_block_wrap_right {
  max-width: 438px;
  width: 100%;
  height: 100%;
}

@media only screen and (max-width: 640px) {
  .top_service_wrap_obsession_block_wrap_right {
    max-width: 176px;
    margin-left: auto;
  }
}

.top_service_item {
  display: none;
}

@media only screen and (max-width: 640px) {
  .top_service_item {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    padding: 2.75rem 0 3.9375rem;
    position: relative;
  }
  .top_service_item:after {
    content: "";
    position: absolute;
    top: 78%;
    right: 10%;
    margin-top: -5px;
    z-index: -2;
    width: 17.875rem;
    height: 10rem;
    z-index: -1;
    background-image: url(../image/obsession_line_sp.png);
    background-position: center center;
    background-repeat: no-repeat;
    background-size: cover;
  }
}

.top_service_item_left {
  width: 53%;
  position: absolute;
  left: 0%;
}

.top_service_item_right {
  width: 53%;
  position: absolute;
  right: 0%;
  top: 111%;
}

.left-flex {
  margin-right: auto;
}

/* top_service.css エンド*/

.top_course {
  position: relative;
}
.top_course_inner {
  padding: 0 1.25rem;
  margin-bottom: 5.5625rem;
  padding-top: 170px;
}
@media only screen and (max-width: 640px) {
  .top_course_inner {
    padding: initial;
    margin-bottom: 2.25rem;
  }
}
.top_course_block {
  text-align: center;
  margin-bottom: 6.5rem;
}
@media only screen and (max-width: 640px) {
  .top_course_block {
    padding: 5.25rem 0;
    margin-bottom: initial;
    background: #fff;
  }
}
.top_course_ttl {
  font-size: 3.6875rem;
  letter-spacing: 0.2em;
  color: #171c42;
}
@media only screen and (max-width: 640px) {
  .top_course_ttl {
    font-size: 1.875rem;
  }
}
.top_course_txt {
  font-size: 1.825rem;
  letter-spacing: 0.3em;
  color: #171c42;
}
@media only screen and (max-width: 640px) {
  .top_course_txt {
    font-size: 1rem;
  }
}
.top_course_sp_box {
  display: none;
}
@media only screen and (max-width: 640px) {
  .top_course_sp_box {
    display: block;
  }
}
.top_course_sp_box_block {
  display: flex;
  justify-content: space-around;
  background: #fff;
  margin-bottom: 0.375rem;
}
.top_course_sp_box_block_menu {
  text-align: center;
  border-bottom: 1px solid #151b41;
  width: 49%;
}
.top_course_sp_box_block_ttl {
  font-size: 1rem;
  font-weight: 600;
}
.top_course_sp_box_inner {
  display: flex;
}
.top_course_sp_box_menu {
  max-width: 93px;
  width: 100%;
}
.top_course_sp_box_line {
  border: 1px solid #707070;
  margin: 0.5625rem 0.6875rem;
  padding: 1.4375rem 0;
  text-align: center;
}
.top_course_sp_box_line_box {
  border-bottom: 1px solid #707070;
  display: inline-block;
  margin: 0 0.5625rem;
}
.top_course_sp_box_line_ttl {
  font-size: 1.375rem;
  letter-spacing: 0.05em;
}
@media only screen and (max-width: 640px) {
  .top_course_sp_box_line_ttl {
    font-size: 1.175rem;
    color: #151b41;
  }
}
.top_course_sp_box_line_ttl span {
  font-size: 1.1875rem;
}
.top_course_sp_box_line_txt {
  font-size: 1.375rem;
  text-align: center;
  margin-top: 1.1875rem;
  margin-bottom: 1.1875rem;
  letter-spacing: 0.05em;
}
.top_course_sp_box_line_txt_an {
  font-size: 1.125rem;
}
.top_course_sp_box_line_menu {
  max-width: 262px;
  width: 100%;
  margin: 0 auto;
  margin-bottom: 1.5625rem;
}
.top_course_sp_box_line_img {
  max-width: 320px;
  width: 100%;
  margin: 0 auto;
}
.top_course_box {
  display: flex;
  justify-content: center;
  margin-bottom: 1.875rem;
}
@media only screen and (max-width: 640px) {
  .top_course_box {
    display: none;
  }
}
.top_course_box_left {
  display: flex;
  align-items: baseline;
  border: 1px solid #707070;
  padding: 0 3.8125rem 3.75rem;
  box-sizing: border-box;
}
.top_course_box_left_img {
  max-width: 335px;
  width: 100%;
  height: 100%;
  display: grid;
  place-content: center;
  place-items: center;
}
.top_course_box_left_menu {
  display: grid;
  place-content: center;
  place-items: center;
  margin-left: 1.6875rem;
}
.top_course_box_left_menu_img {
  max-width: 367px;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  margin-bottom: 1.25rem;
}
.top_course_box_left_menu_txt {
  font-size: 1.875rem;
  color: #171c42;
  letter-spacing: 0.05em;
  font-weight: 600;
}
.top_course_box_right {
  max-width: 122px;
  width: 100%;
  height: 100%;
}

.menu_img01 {
  display: none;
}

.menu_img02 {
  display: none;
}

.menu_img03 {
  display: none;
}

.menu_img04 {
  display: none;
} /*# sourceMappingURL=top_course.css.map */

@media only screen and (max-width: 640px) {
  img[src*="_op"] {
    display: none;
  }
}

/* top_course.css エンド*/

.top_atmosphere {
  position: relative;
}
.top_atmosphere_inner {
  padding: 13.875rem 0 12.25rem;
}
@media only screen and (max-width: 640px) {
  .top_atmosphere_inner {
    padding: initial;
  }
}
.top_atmosphere_sp_img {
  display: none;
}
@media only screen and (max-width: 640px) {
  .top_atmosphere_sp_img {
    max-width: 291px;
    width: 100%;
    margin-right: auto;
    display: block;
    margin-top: 36px;
  }
}
.top_atmosphere_block {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.top_atmosphere_block_left {
  display: block;
  width: 50%;
}
.top_atmosphere_block_left_img {
  max-width: 973px;
  width: 100%;
}
@media only screen and (max-width: 640px) {
  .top_atmosphere_block_left_img {
    display: none;
  }
}
.top_atmosphere_block_left_img_pc {
  display: block;
}
@media only screen and (max-width: 640px) {
  .top_atmosphere_block_left_img_pc {
    display: none;
  }
}
.top_atmosphere_block_left_box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
  -ms-flex-align: end;
  align-items: end;
  width: 100%;
  height: 400px;
  padding: 0 0 7.875rem;
  -webkit-box-pack: end;
  -ms-flex-pack: end;
  justify-content: end;
  max-width: 973px;
}
@media only screen and (max-width: 640px) {
  .top_atmosphere_block_left_box {
    padding: 25px 0 0;
    height: initial;
  }
}
.top_atmosphere_block_left_box_flex {
  width: 100%;
}
.top_atmosphere_block_left_box_ttl {
  font-weight: 700;
  font-size: 2.8125rem;
  letter-spacing: 0.2em;
  line-height: 2;
  color: #171c42;
  -webkit-writing-mode: vertical-rl;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  margin: 0 auto;
  color: #171c42;
}
@media only screen and (max-width: 640px) {
  .top_atmosphere_block_left_box_ttl {
    font-size: 1.875rem;
    margin: initial;
  }
}
.top_atmosphere_block_left_box_img {
  max-width: 197px;
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
  -ms-flex-align: end;
  align-items: end;
}
@media only screen and (max-width: 640px) {
  .top_atmosphere_block_left_box_img {
    display: none;
  }
}
.top_atmosphere_block_right {
  width: 50%;
  display: -ms-grid;
  display: grid;
  place-content: center;
  place-items: center;
}
@media only screen and (max-width: 640px) {
  .top_atmosphere_block_right {
    padding-right: 0.6875rem;
  }
}
.top_atmosphere_block_right_img {
  max-width: 483px;
  width: 100%;
  height: 100%;
}
@media only screen and (max-width: 640px) {
  .top_atmosphere_block_right_img {
    max-width: 228px;
    height: 158px;
  }
}
.top_atmosphere_block_right_img_pc {
  display: block;
}
@media only screen and (max-width: 640px) {
  .top_atmosphere_block_right_img_pc {
    display: none;
  }
}
.top_atmosphere_block_right_img_sp {
  display: none;
}
@media only screen and (max-width: 640px) {
  .top_atmosphere_block_right_img_sp {
    display: block;
  }
}
.top_atmosphere_block_right_txt {
  font-size: 1.4rem;
  letter-spacing: 0.2em;
  margin-bottom: 2.75rem;
}
@media only screen and (max-width: 640px) {
  .top_atmosphere_block_right_txt {
    font-size: 1.1rem;
    display: inline-block;
    margin-left: auto;
    margin-bottom: 1.3125rem;
  }
}
.top_atmosphere_wrap {
  max-width: 800px;
  margin: 0 auto;
  position: relative;
}
@media only screen and (max-width: 640px) {
  .top_atmosphere_wrap {
    display: contents;
  }
}
@media only screen and (max-width: 640px) {
  .top_atmosphere_wrap::before {
    content: "";
    background-image: url("../image/img_seat20.png");
    background-position: center center;
    background-repeat: no-repeat;
    background-size: cover;
    width: 118px;
    height: 118px;
    position: absolute;
    top: 40%;
    left: 20%;
  }
}
.top_atmosphere_wrap_ttl {
  font-size: 1.875rem;
  letter-spacing: 0.2em;
  line-height: 1.7;
  margin-bottom: 3.8125rem;
  color: #171c42;
}
@media only screen and (max-width: 640px) {
  .top_atmosphere_wrap_ttl {
    -webkit-writing-mode: vertical-rl;
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl;
    margin: 0 0 0 auto;
    position: absolute;
    top: 39%;
    right: 5%;
    text-align: center;
    font-size: 1.3125rem;
  }
}
.top_atmosphere_wrap_ttl_flex {
  padding-left: 4.175rem;
}
.top_atmosphere_wrap_txt {
  font-size: 1.25rem;
  letter-spacing: 0.1em;
  line-height: 2;
  padding-left: 2.875rem;
}
@media only screen and (max-width: 640px) {
  .top_atmosphere_wrap_txt {
    padding: 0 0.75rem;
    font-size: 1.125rem;
    margin-top: 12.625rem;
    letter-spacing: 0em;
  }
}

/* top_atmosphere.css　エンド */

@charset "UTF-8";
.top_feature {
  position: relative;
}
@media only screen and (max-width: 640px) {
  .top_feature {
    padding-top: 7rem;
  }
}
.top_feature_inner {
  padding: 0 1.25rem;
  max-width: 1100px;
  margin: 0 auto;
}
@media only screen and (max-width: 640px) {
  .top_feature_inner {
    padding: initial;
  }
}
.top_feature_block {
  text-align: left;
  margin-bottom: 10.5625rem;
}
@media only screen and (max-width: 640px) {
  .top_feature_block {
    margin-bottom: 4.625rem;
    text-align: left;
    display: inline-block;
    padding-left: 0.6875rem;
  }
}
.top_feature_block_ttl {
  font-size: 3.6875rem;
  letter-spacing: 0.2em;
  color: #171c42;
}
@media only screen and (max-width: 640px) {
  .top_feature_block_ttl {
    font-size: 1.875rem;
  }
}
.top_feature_block_txt {
  font-size: 1.825rem;
  letter-spacing: 0.3em;
  color: #171c42;
}
@media only screen and (max-width: 640px) {
  .top_feature_block_txt {
    font-size: 1rem;
  }
}
.top_feature_box_01 {
  position: relative;
  max-width: 813px;
  margin: 0 auto 7rem;
  text-align: center;
}
@media only screen and (max-width: 640px) {
  .top_feature_box_01 {
    text-align: right;
    margin: 0 auto 4.0625rem;
  }
}
.top_feature_box_01::before {
  content: "好立地";
  color: #fff;
  background: #171c42;
  width: 200px;
  padding: 5.25rem 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  font-size: 2rem;
  letter-spacing: 0.1em;
  position: absolute;
  left: -150px;
  top: -35px;
}
@media only screen and (max-width: 640px) {
  .top_feature_box_01::before {
    left: 0;
    padding: 3.75rem 0;
    font-size: 1.375rem;
    width: 145px;
  }
}
.top_feature_box_01_ttl {
  font-size: 1.75rem;
  letter-spacing: 0.1em;
  line-height: 0.8;
}
@media only screen and (max-width: 640px) {
  .top_feature_box_01_ttl {
    font-size: 1.125rem;
    display: inline-block;
    text-align: left;
    line-height: 1.3;
    padding-right: 1.25rem;
  }
}
.top_feature_box_01_img {
  max-width: 813px;
  width: 100%;
  margin: 2.6875rem auto 0;
}
@media only screen and (max-width: 640px) {
  .top_feature_box_01_img {
    max-width: 346px;
    height: 175px;
    margin: 1.875rem 0 0 auto;
  }
}
.top_feature_box_01_img img {
  height: 100%;
}
.top_feature_box_02 {
  position: relative;
  max-width: 813px;
  margin: 0 auto 16.9375rem;
  text-align: center;
  padding-left: 6.25rem;
  text-align: left;
}
@media only screen and (max-width: 640px) {
  .top_feature_box_02 {
    padding-left: initial;
    margin: 0 auto 15.9375rem;
  }
}
.top_feature_box_02::before {
  content: "";
  background: url("../image/img_seat24.png");
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
  display: block;
  height: 216px;
  width: 417px;
  position: absolute;
  left: -130px;
  bottom: -129px;
}
@media only screen and (max-width: 640px) {
  .top_feature_box_02::before {
    left: initial;
    right: 0;
    max-width: 257px;
    height: 159px;
    bottom: -175px;
  }
}
.top_feature_box_02::before img {
  height: 100%;
}
.top_feature_box_02::after {
  content: "こだわりのお酒";
  color: #fff;
  background: #171c42;
  width: 200px;
  padding: 3.75rem 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  font-size: 2rem;
  letter-spacing: 0.1em;
  position: absolute;
  right: -150px;
  top: -35px;
  word-wrap: break-word;
  text-align: center;
}
@media only screen and (max-width: 640px) {
  .top_feature_box_02::after {
    right: 0;
    padding: 2.4375rem 0;
    font-size: 1.375rem;
    width: 145px;
    text-align: center;
  }
}
.top_feature_box_02_ttl {
  font-size: 1.75rem;
  letter-spacing: 0.1em;
  line-height: 0.8;
}
@media only screen and (max-width: 640px) {
  .top_feature_box_02_ttl {
    font-size: 1.125rem;
    display: inline-block;
    text-align: left;
    line-height: 1.3;
    padding-left: 1.875rem;
  }
}
.top_feature_box_02_img {
  max-width: 813px;
  width: 100%;
  margin: 2.6875rem auto 0;
}
@media only screen and (max-width: 640px) {
  .top_feature_box_02_img {
    margin: 1.375rem 0 0;
    max-width: 346px;
    height: 175px;
  }
}
.top_feature_box_02_img img {
  height: 100%;
}
.top_feature_box_03 {
  position: relative;
  max-width: 813px;
  margin: 0 auto 8.8125rem;
  text-align: center;
}
@media only screen and (max-width: 640px) {
  .top_feature_box_03 {
    margin: 0 0 3.4375rem;
    text-align: right;
  }
}
.top_feature_box_03::before {
  content: "韓国語\a英語での\a接客";
  color: #fff;
  background: #171c42;
  width: 200px;
  padding: 2.1875rem 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  font-size: 2rem;
  letter-spacing: 0.1em;
  position: absolute;
  left: -150px;
  top: -35px;
  word-wrap: break-word;
  white-space: pre-wrap;
}
@media only screen and (max-width: 640px) {
  .top_feature_box_03::before {
    left: 0;
    width: 145px;
    padding: 1.625rem 0;
    font-size: 1.375rem;
    text-align: center;
  }
}
.top_feature_box_03_ttl {
  font-size: 1.75rem;
  letter-spacing: 0.1em;
  line-height: 0.8;
}
@media only screen and (max-width: 640px) {
  .top_feature_box_03_ttl {
    font-size: 1.125rem;
    display: inline-block;
    text-align: left;
    line-height: 1.3;
    padding-right: 1.3125rem;
  }
}
.top_feature_box_03_img {
  max-width: 813px;
  width: 100%;
  margin: 2.6875rem auto 0;
}
@media only screen and (max-width: 640px) {
  .top_feature_box_03_img {
    max-width: 347px;
    margin: 2.125rem 0 0 auto;
  }
}
.top_feature_box_03_img_pc {
  display: block;
}
@media only screen and (max-width: 640px) {
  .top_feature_box_03_img_pc {
    display: none;
  }
}
.top_feature_box_03_img_sp {
  display: none;
}
@media only screen and (max-width: 640px) {
  .top_feature_box_03_img_sp {
    display: block;
  }
}
.top_feature_box_04 {
  position: relative;
  max-width: 813px;
  margin: 0 auto;
  text-align: center;
  padding-left: 6.25rem;
}
@media only screen and (max-width: 640px) {
  .top_feature_box_04 {
    padding-left: initial;
    text-align: left;
  }
}
.top_feature_box_04::before {
  content: "お土産";
  color: #fff;
  background: #171c42;
  width: 200px;
  padding: 5.25rem 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  font-size: 2rem;
  letter-spacing: 0.1em;
  position: absolute;
  right: -150px;
  top: -35px;
  word-wrap: break-word;
  white-space: pre-wrap;
}
@media only screen and (max-width: 640px) {
  .top_feature_box_04::before {
    right: 0;
    width: 145px;
    padding: 3.8125rem 0;
    font-size: 1.375rem;
    top: -18px;
  }
}
.top_feature_box_04_ttl {
  font-size: 1.75rem;
  letter-spacing: 0.1em;
  line-height: 0.8;
}
@media only screen and (max-width: 640px) {
  .top_feature_box_04_ttl {
    font-size: 1.125rem;
    padding-left: 0.75rem;
    display: inline-block;
    text-align: left;
    line-height: 1.3;
    letter-spacing: 0em;
  }
}
.top_feature_box_04_img {
  max-width: 813px;
  width: 100%;
  margin: 2.6875rem auto 0;
}
@media only screen and (max-width: 640px) {
  .top_feature_box_04_img {
    max-width: 346px;
    margin: 1.375rem 0 0;
  }
}

/* top_feature.css エンド*/

.top_contact {
  position: relative;
}
.top_contact_inner {
  max-width: 900px;
  margin: 0 auto;
  padding-bottom: 7.1875rem;
}
@media only screen and (max-width: 640px) {
  .top_contact_inner {
    padding-bottom: 3.5rem;
  }
}
.top_contact_block {
  text-align: center;
}
.top_contact_block_ttl {
  font-size: 1.5rem;
  letter-spacing: 0.1em;
  font-weight: 600;
}
@media only screen and (max-width: 640px) {
  .top_contact_block_ttl {
    font-size: 1.125rem;
  }
}
.top_contact_block_txt {
  font-size: 1.375rem;
  letter-spacing: 0.1em;
  margin-top: 2.5625rem;
  position: relative;
  margin-bottom: 2.4375rem;
}
@media only screen and (max-width: 640px) {
  .top_contact_block_txt {
    font-size: 1.25rem;
    margin-top: 2.3125rem;
    margin-bottom: 2rem;
  }
}
.top_contact_block_txt::after {
  content: "";
  width: 26px;
  height: 1px;
  display: inline-block;
  background-color: #171c42;
  position: absolute;
  bottom: -10px;
  left: calc(50% - 10px);
}
.top_contact_block_info {
  font-size: 2.5rem;
  margin-top: 2.4375rem;
  letter-spacing: 0.2em;
  font-weight: 600;
  position: relative;
  padding-left: 3.125rem;
  color: #151b41 !important;
  text-decoration: none !important;
}
@media only screen and (max-width: 640px) {
  .top_contact_block_info {
    font-size: 1.875rem;
    padding-left: initial;
  }
}
.top_contact_block_info::before {
  content: "";
  background: url("../image/info_icon.png");
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
  width: 29px;
  height: 37px;
  position: absolute;
  top: 25%;
  left: 0;
}
@media only screen and (max-width: 640px) {
  .top_contact_block_info::before {
    display: none;
  }
}
.top_contact_block_time {
  font-size: 1.125rem;
  letter-spacing: 0.1em;
  margin-top: 1.375rem;
}
@media only screen and (max-width: 640px) {
  .top_contact_block_time {
    font-size: 0.875rem;
    margin-top: 0.875rem;
  }
}
.top_contact_block_btn {
  max-width: 34.1875rem;
  width: 100%;
  background: -webkit-gradient(
    linear,
    left top,
    right top,
    from(#9b7300),
    to(#c5993f)
  );
  background: linear-gradient(to right, #9b7300, #c5993f);
  text-align: center;
  border: 1px solid #fff;
  margin: 2.75rem auto 0;
}
@media only screen and (max-width: 640px) {
  .top_contact_block_btn {
    margin: 1.625rem auto 0;
    max-width: 15.5rem;
    background: -webkit-gradient(
      linear,
      left top,
      left bottom,
      from(#9b7300),
      to(#c5993f)
    );
    background: linear-gradient(to bottom, #9b7300, #c5993f);
  }
}
.top_contact_block_btn_link {
  color: #fff !important;
  text-decoration: none;
  width: 100%;
  display: block;
  font-size: 1.875rem;
  letter-spacing: 0.3em;
  padding: 2.5rem 0;
  position: relative;
}
.top_contact_block_btn_link:hover {
  bottom: -3px;
  -webkit-box-shadow: none;
  box-shadow: none;
}
.top_contact_block_btn_link:hover::after {
  top: 0;
  left: 0;
}
@media only screen and (max-width: 640px) {
  .top_contact_block_btn_link {
    font-size: 1rem;
    padding: 1.0625rem 0;
  }
}
.top_contact_block_btn_link::before {
  content: "";
  width: 0.625rem;
  height: 0.625rem;
  border: 0;
  border-top: solid 1px #fff;
  border-right: solid 1px #fff;
  position: absolute;
  top: 50%;
  left: 5%;
  margin-top: -5px;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}
@media only screen and (max-width: 640px) {
  .top_contact_block_btn_link::before {
    width: 0.325rem;
    height: 0.325rem;
    top: 54%;
  }
}
.top_contact_block_btn_link::after {
  content: "";
  position: absolute;
  top: 10px;
  left: 10px;
  background-color: rgba(18, 23, 113, 0.4);
  width: 100%;
  height: 100%;
  z-index: -1;
}
@media only screen and (max-width: 640px) {
  .top_contact_block_btn_link::after {
    top: 6px;
    left: 6px;
  }
}
.top_contact_banner {
  width: 100%;
  display: block;
}
@media only screen and (max-width: 640px) {
  .top_contact_banner {
    display: none;
  }
}
.top_contact_banner_sp {
  display: none;
}
@media only screen and (max-width: 640px) {
  .top_contact_banner_sp {
    width: 100%;
    display: block;
  }
}
.info{
  margin-top: 2.75rem;
  font-size: 1.125rem;
  letter-spacing: 0.1em;
}
.info_flex{
  text-align: left;
}
.top_contact_banner_sp img {
  width: 100%;
}

/* topcontact css エンド */

.top_review {
  padding: 9.4375rem 0 9.3125rem;
}

@media only screen and (max-width: 640px) {
  .top_review {
    padding: 6.5625rem 0 6.9375rem;
  }
}

.top_review_inner {
  max-width: 1300px;
  margin: 0 auto;
  position: relative;
}

.top_review_block {
  margin: 0 auto 16.4375rem;
  width: 100%;
}

@media only screen and (max-width: 640px) {
  .top_review_block {
    margin: 0 auto 6.4375rem;
  }
}

.top_review_block::before {
  content: "";
  background: url("../image/top_review.png");
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
  display: block;
  height: 143px;
  width: 867px;
  position: absolute;
  top: 8%;
  left: -20%;
  z-index: -1;
}

@media only screen and (max-width: 640px) {
  .top_review_block::before {
    width: 100%;
    left: initial;
    top: 2%;
  }
}

.top_review_block_ttl {
  font-size: 3.125rem;
  letter-spacing: 0.2em;
  line-height: 1.8;
  color: #171c42;
}

@media only screen and (max-width: 640px) {
  .top_review_block_ttl {
    font-size: 1.875rem;
    padding-left: 0.9375rem;
    line-height: 1.5;
  }
}

@media only screen and (max-width: 640px) {
  .top_review_block_ttl_main {
    font-size: 2.5rem;
  }
}

.top_review_block_ttl_space {
  padding-left: 100px;
}

@media only screen and (max-width: 640px) {
  .top_review_block_ttl_space {
    padding-left: 68px;
  }
}

.top_review_box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  margin-top: 10.75rem;
}

@media only screen and (max-width: 640px) {
  .top_review_box {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    margin-top: 2.9375rem;
  }
}

@media only screen and (max-width: 640px) {
  .top_review_box:nth-child(3) {
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
    -ms-flex-direction: column-reverse;
    flex-direction: column-reverse;
  }
}

.top_review_box_left {
  width: 50%;
  position: relative;
}

@media only screen and (max-width: 640px) {
  .top_review_box_left {
    width: 100%;
  }
}

.top_review_box_left_img {
  max-width: 456px;
  width: 100%;
}

@media only screen and (max-width: 640px) {
  .top_review_box_left_img {
    max-width: 306px;
  }
}

.top_review_box_right {
  width: 50%;
}

@media only screen and (max-width: 640px) {
  .top_review_box_right {
    width: 100%;
    padding: 0 1.4375rem;
    margin-top: 3.125rem;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
  }
}

.top_review_box_right_txt {
  font-size: 1.25rem;
  letter-spacing: 0.02em;
}

@media only screen and (max-width: 640px) {
  .top_review_box_right_txt {
    font-size: 1.0625rem;
    line-height: 1.7;
  }
}

.top_review_box_right_name {
  text-align: right;
  font-size: 1.125rem;
  letter-spacing: 0.1em;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: end;
  -ms-flex-pack: end;
  justify-content: end;
  padding-top: 2.1875rem;
}

@media only screen and (max-width: 640px) {
  .top_review_box_right_name {
    font-size: 0.9375rem;
    padding-top: initial;
  }
}

.top_review_wrap {
  padding-top: 13.75rem;
  position: relative;
}

@media only screen and (max-width: 640px) {
  .top_review_wrap {
    padding-top: 7.125rem;
  }
}

.top_review_wrap::after {
  content: "";
  background: url("../image/cheering_sv_review.png");
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
  display: block;
  height: 624px;
  width: 1200px;
  position: absolute;
  top: 34%;
  right: 0;
  z-index: -1;
}

@media only screen and (max-width: 640px) {
  .top_review_wrap::after {
    background: url("../image/cheering_sv_review_sp.png");
    width: 186px;
    height: 1018px;
    top: 5%;
  }
}

.top_review_wrap_inner {
  max-width: 1000px;
  margin: 0 auto;
  position: relative;
}

@media only screen and (max-width: 640px) {
  .top_review_wrap {
    padding-left: 0.9375rem;
    padding-right: 0.9375rem;
  }
}

.top_review_wrap_block {
  text-align: center;
  margin-bottom: 5.25rem;
}

@media only screen and (max-width: 640px) {
  .top_review_wrap_block {
    margin-bottom: 2rem;
  }
}

.top_review_wrap_ttl {
  font-size: 2.5rem;
  letter-spacing: 0.2em;
  line-height: 1.6;
  color: #171c42;
}

@media only screen and (max-width: 640px) {
  .top_review_wrap_ttl {
    text-align: left;
    font-size: 1.5625rem;
    letter-spacing: 0.1em;
    line-height: 1.6;
  }
}

.top_review_wrap_box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  flex-wrap: wrap;
}

@media only screen and (max-width: 640px) {
  .top_review_wrap_box {
    display: block;
  }
}

.top_review_wrap_box_flex {
  margin-top: 5%;
  width: 50%;
}

@media only screen and (max-width: 640px) {
  .top_review_wrap_box_flex {
    width: 100%;
    margin-bottom: 1.625rem;
  }
}

.top_review_wrap_box_flex_img {
  max-width: 427px;
  width: 100%;
  margin-bottom: 2.125rem;
}

@media only screen and (max-width: 640px) {
  .top_review_wrap_box_flex_img {
    margin-bottom: 0.8125rem;
  }
}

.top_review_wrap_box_flex_time {
  font-size: 1.125rem;
  letter-spacing: 0.1em;
}

@media only screen and (max-width: 640px) {
  .top_review_wrap_box_flex_time {
    font-size: 0.9375rem;
    line-height: 1.5;
  }
}

.top_review_wrap_box_flex_txt {
  font-size: 1.25rem;
  line-height: 1.7;
  letter-spacing: 0.1em;
  margin-top: 1rem;
}

@media only screen and (max-width: 640px) {
  .top_review_wrap_box_flex_txt {
    font-size: 1.0625rem;
    line-height: 1.5;
    margin-top: 0.35rem;
  }
}

.flex_item {
  margin-left: auto;
}

.box_flex_01::after {
  content: "";
  background: url("../image/top_review_img06.png");
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
  display: block;
  height: 173px;
  width: 247px;
  position: absolute;
  right: 60px;
  bottom: -99px;
}

@media only screen and (max-width: 640px) {
  .box_flex_01::after {
    height: 118px;
    width: 172px;
    right: 0;
    bottom: -32px;
  }
}

.box_flex_02::after {
  content: "";
  background: url("../image/top_review_img07.png");
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
  display: block;
  height: 173px;
  width: 247px;
  position: absolute;
  right: 21px;
  bottom: -99px;
}

@media only screen and (max-width: 640px) {
  .box_flex_02::after {
    height: 118px;
    width: 172px;
    left: 0;
    bottom: -37px;
  }
}

.box_flex_03::after {
  content: "";
  background: url("../image/top_review_img08.png");
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
  display: block;
  height: 173px;
  width: 247px;
  position: absolute;
  right: 60px;
  bottom: -99px;
}

@media only screen and (max-width: 640px) {
  .box_flex_03::after {
    height: 118px;
    width: 172px;
    right: 0;
    bottom: -32px;
  }
}

.flex-box-s::before {
  content: "";
  width: 17.875rem;
  height: 10rem;
  position: absolute;
  top: 32%;
  left: 0;
  margin-top: -5px;
  z-index: 2;
  background-image: url("../image/top_service_wrap_obsession_img.png");
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
}

@media only screen and (max-width: 640px) {
  .flex-box-s::before {
    top: 0%;
    width: 6.875rem;
  }
}

.flex-box-s::after {
  content: "";
  width: 17.875rem;
  height: 21rem;
  position: absolute;
  bottom: -18%;
  right: 0;
  margin-top: -5px;
  background-image: url(../image/top_service_wrap_obsession_img.png);
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
  z-index: 2;
}

@media only screen and (max-width: 640px) {
  .flex-box-s::after {
    bottom: -23%;
    width: 9.875rem;
  }
}

/* top_review.css　エンド */

.photo_image {
  position: absolute;
  bottom: -130px;
  right: 0;
}

@media only screen and (max-width: 640px) {
  .photo_image {
    position: absolute;
    bottom: -35px;
    right: 0;
    padding: 0 1.4375rem;
  }
  .photo_image p {
    font-size: 13px;
  }
}

/* 一品料理 */

.top_alacarte {
  position: relative;
  z-index: 2;
  display: flex;
  justify-content: space-between;
}
.top_alacarte_block {
  text-align: left;
  margin-bottom: 10.5625rem;
  position: relative;
}

@media only screen and (min-width: 640px) {
  .top_alacarte {
    max-width: 1200px;
    margin: 0 auto;
    width: 90%;
  }
}

@media only screen and (max-width: 900px) {
  .top_alacarte {
    flex-direction: column;
  }
}

@media only screen and (min-width: 640px) {
  .top_alacarte_block::before {
    position: absolute;
    content: "";
    display: inline-block;
    background-image: url(../image/alacalte_bg1.png);
    width: 50%;
    height: 300px;
    background-size: cover;
    bottom: -60%;
    right: -120%;
    z-index: -1;
  }
  .top_alacarte_block::after {
    position: absolute;
    content: "";
    display: inline-block;
    background-image: url(../image/alacalte_bg1.png);
    width: 50%;
    height: 150px;
    background-size: cover;
    bottom: -110%;
    left: -50%;
    z-index: -1;
  }
}

@media only screen and (max-width: 640px) {
  .top_alacarte_block::before {
    position: absolute;
    content: "";
    display: inline-block;
    background-image: url(../image/alacalte_bg1.png);
    width: 50%;
    height: 300px;
    background-size: cover;
    bottom: -60%;
    right: 0;
    z-index: -1;
  }
  .top_alacarte_block::after {
    position: absolute;
    content: "";
    display: inline-block;
    background-image: url(../image/alacalte_bg1.png);
    width: 50%;
    height: 150px;
    background-size: cover;
    bottom: -110%;
    left: 0;
    z-index: -1;
  }
}

@media only screen and (max-width: 640px) {
  .top_alacarte_block {
    margin-bottom: 2rem;
    text-align: left;
    display: inline-block;
    padding-left: 0.6875rem;
    padding: 0 1.25rem;
  }
}
.top_alacarte_block_ttl {
  font-size: 50px;
  letter-spacing: 0.2em;
  color: #171c42;
  display: inline;
}
@media only screen and (max-width: 640px) {
  .top_alacarte_block_ttl {
    font-size: 1.875rem;
  }
}
.top_alacarte_block_txt {
  font-size: 1.825rem;
  letter-spacing: 0.3em;
  color: #171c42;
  margin-left: 20px;
}
@media only screen and (max-width: 640px) {
  .top_alacarte_block_txt {
    font-size: 1rem;
    margin-left: 10px;
  }
}
.top_alacarte_discription {
  margin-top: 4.25rem;
}

@media only screen and (max-width: 640px) {
  .top_alacarte_discription {
    margin-top: 1.25rem;
  }
}
.top_alacarte_discription p {
  font-size: 20px;
}

@media only screen and (max-width: 640px) {
  .top_alacarte_discription p {
    font-size: 17px;
  }
}

@media only screen and (min-width: 900px) {
  .alacalte_img_wrap {
    margin-top: 160px;
    width: 50%;
    display: flex;
  }
}

@media only screen and (max-width: 900px) {
  .alacalte_img_wrap {
    position: relative;
    flex-direction: column;
  }
}

.alacalte_img1 {
  width: 55%;
  margin-left: auto;
  /* margin-bottom: 14px; */
  position: relative;
  order: 2;
}
.alacalte_img2 {
  width: 55%;
  position: relative;
  bottom: -154px;
  order: 1;
  margin-right: 12px;
}

@media only screen and (max-width: 900px) {
  .alacalte_img1 {
    width: 55%;
    margin-left: auto;
    /* margin-bottom: 14px; */
    position: relative;
  }
  .alacalte_img2 {
    width: 55%;
    position: relative;
    bottom: -14px;
  }
}

.top_feature_box_01_img img,
.top_feature_box_02_img img {
  height: auto;
  max-width: 100%;
}
