@charset "UTF-8";
@import url("https://fonts.googleapis.com/earlyaccess/notosansjapanese.css");

/* CSS Document */

*,
*:before,
*:after {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

/* グローバルスタイル */
html {
  font-size: 62.5%;
  scroll-padding-top: 10rem;
}

body {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 500;
  font-size: 1.6rem;
  color: #343434;
  line-height: 1.75;
  -webkit-font-feature-settings: "palt";
  font-feature-settings: "palt";
  text-align: justify;
  text-justify: inter-ideograph;
  letter-spacing: 0.05em;
}

img {
  max-width: 100%;
  height: auto;
  vertical-align: middle;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  line-height: 1.3;
  /* line-height: 1.6; */
}

a {
  color: #000;
  text-decoration: none;
}

a:hover {
  opacity: 0.9;
}

section {
  padding: 8rem 0;
}

#consulting_point_services,
#ryosyo_consulting {
  padding-top: 0;
}
#ryosyo_top_fv {
  padding: 0;
}

.dpb1100 {
  display: none;
}
.dpn1100 {
  display: block;
}
.dpb768 {
  display: none;
}
.dpn768 {
  display: block;
}

/* ヘッダー */
header {
  box-shadow: 0px 4px 6px rgba(0, 0, 0, 0.16);
  position: fixed; /* ヘッダーを固定 */
  width: 100%; /* ヘッダーを幅100%に設定 */
  top: 0; /* 画面上端に固定 */
  left: 0;
  background-color: #fff;
  z-index: 1000;
}
.header_flex_wrapper {
  display: flex;
  justify-content: space-between;
  gap: 8rem;
  align-items: center;
  max-width: 1100px;
  margin: 0 auto;
  height: 100px;
}

.header_flex_right {
  display: flex;
  gap: 2rem;
  align-items: center;
  font-family: "ヒラギノ角ゴ ProN", sans-serif;
  /* font-family: hiragino-kaku-gothic-pron, sans-serif; */
  font-weight: 600;
  font-style: normal;
  letter-spacing: normal;
}

.header_contact_btn a {
  font-size: 2.5rem;
  background-color: #ec6432;
  color: #fff;
  padding: 2rem;
  display: flex;
  width: 212px;
  height: 100px;
  justify-content: center;
  align-items: center;
  font-weight: bold;
  flex-direction: column;
}

.hamburger_nav {
  display: none;
}

/* フッター */
footer {
  background-color: #ec6432;
  color: #fff;
  font-weight: normal;
  padding: 5rem 0;
}

.footer_flex {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 16rem;
}

.footer_flex p {
  color: #fff !important;
}

/* ファーストビュー */
.top_fv_wrapper img {
  vertical-align: middle;
}

#top_fv_img {
  width: 100vw;
}

.top_fv_bottom {
  text-align: center;
  background-color: #ec6432;
  padding: 4rem 0;
}

.top_fv_btn_wrapper {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 1rem;
}

.top_fv_btn {
  position: relative;
}

.top_fv_btn::after {
  background: url(../img/ryosyo_top_btn.png) no-repeat center;
  width: 682px;
  height: 119px;
  content: "";
  display: inline-block;
}
.top_fv_btn:hover:after {
  background: url(../img/ryosyo_top_btn_hover.png) no-repeat center;
  width: 682px;
  height: 119px;
  content: "";
  display: inline-block;
  transition: 0.3s;
}

/* コンサルティング対応できる飲食業種 */
.consulting_heading_wrapper {
  text-align: center;
  font-weight: bold;
  color: #ec6432;
  background-color: #fff8e8;
  padding: 4rem 0;
  position: relative;
}

.consulting_heading_wrapper:after {
  content: "";
  position: absolute;
  right: 0;
  bottom: -40px;
  left: 0;
  width: 0px;
  height: 0px;
  margin: auto;
  border-style: solid;
  border-color: #fff8e8 transparent transparent transparent;
  border-width: 40px 40px 0 40px;
}

.consulting_heading_wrapper h1 {
  font-size: 4.7rem;
}

.consulting_food_flex {
  padding-top: 8rem;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 4rem;
}

.consulting_bnr_wrapper {
  text-align: center;
  margin-top: 8rem;
}

/* 3つのポイント */
#consulting_point {
  background-color: #fff8e8;
  padding: 8rem 0;
}

.ryosyo_heading_wrapper {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.ryosyo_heading_wrapper h1 {
  text-align: center;
  font-size: 5rem;
  font-weight: bold;
}

.ryosyo_heading_wrapper .span1 {
  font-size: 6rem;
}

.ryosyo_heading_wrapper .span2 {
  font-size: 8rem;
  color: #ec6432;
}

.ryosyo_heading_wrapper > div {
  margin: 0 1rem;
}

.orange_heading_wrapper_s {
  position: relative;
}

.orange_heading_wrapper_s h2 {
  text-align: center;
  font-size: 4rem;
  max-width: 1100px;
  margin: 8rem auto;
  background-color: #ec6432;
  color: #fff;
  font-weight: bold;
  padding: 2rem 0;
}

.orange_heading_wrapper_s span {
  font-size: 7rem;
}

.orange_heading_wrapper_s:after {
  content: "";
  position: absolute;
  right: 0;
  bottom: -40px;
  left: 0;
  width: 0px;
  height: 0px;
  margin: auto;
  border-style: solid;
  border-color: #ec6432 transparent transparent transparent;
  border-width: 40px 20px 0 20px;
}

.ryosyo_container {
  max-width: 1100px;
  margin: 0 auto;
}

#consulting_point .ryosyo_container h3 {
  text-align: center;
  font-size: 4.5rem;
  font-weight: bold;
  color: #ec6432;
  border-bottom: 3px solid #ec6432;
  padding-bottom: 1rem;
  padding-left: 4rem;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 4rem;
  text-align: left;
}

.ryosyo_container h3 span {
  font-size: 10rem;
  /* font-family: "urw-din", sans-serif; */
  font-family: 'Fira Sans Condensed', sans-serif;
  font-weight: 700;
  font-style: normal;
}

.point_contents_flex {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 4rem;
  padding: 6rem 0;
}

.point_contents_flex > div:first-child {
  width: 30%;
  text-align: center;
}

.point_contents_flex > div:nth-child(2) {
  width: 70%;
}

.point_txt_ttl {
  font-size: 3rem;
  color: #ec6432;
  padding-bottom: 2rem;
  font-weight: 600;
}

.point_txt {
  font-size: 2rem;
  font-weight: normal;
  line-height: 2;
}

.point_flex_wrapper {
  margin-bottom: 4rem;
}

/* 集客&収益が出る */
.orange_heading_wrapper {
  color: #fff;
  font-weight: bold;
  background-color: #ec6432;
  text-align: center;
  padding: 6rem 0;
  position: relative;
}

.orange_heading_wrapper:after {
  content: "";
  position: absolute;
  right: 0;
  bottom: -40px;
  left: 0;
  width: 0px;
  height: 0px;
  margin: auto;
  border-style: solid;
  border-color: #ec6432 transparent transparent transparent;
  border-width: 40px 40px 0 40px;
}

.orange_heading_wrapper h2 {
  font-size: 4.5rem;
}

#consulting_point_services {
  background: url(../img/consulting_point_services_bg.png) no-repeat center;
  background-size: cover;
}

.point_service_container {
  max-width: 1100px;
  background-color: rgba(255, 255, 255, 0.58);
  margin: 16rem auto;
  padding-bottom: 6rem;
}

.point_service_container:last-child {
  margin-bottom: 0;
}

.point_service_heading_wrapper {
  display: flex;
  justify-content: center;
  padding-left: 4rem;
}

.point_service_heading_border {
  width: calc(100% - 4rem);
  margin-left: 4rem;
  border-bottom: 3px solid #ec6432;
  margin-bottom: 8rem;
}

.point_service_heading_wrapper > div:first-child {
  padding-top: 6rem;
  width: 50%;
  display: flex;
  justify-content: center;
  flex-direction: column;
}

.point_service_heading_wrapper > div:first-child p {
  font-size: 2rem;
  padding-top: 1rem;
}

.point_service_heading_wrapper h3 {
  font-size: 4.5rem;
  color: #ec6432;
  font-weight: bold;
  position: relative;
}

.point_service_heading_wrapper h3 span {
  font-size: 3rem;
}

.point_service_heading_wrapper h3::after {
  position: absolute;
  content: "";
  background: url(../img/ryosyo_service01.png) no-repeat center;
  width: 390px;
  height: 222px;
  bottom: 105%;
  left: 0;
}

#service_heading_pc_02 h3::after {
  position: absolute;
  content: "";
  background: url(../img/ryosyo_service02.png) no-repeat center;
  width: 390px;
  height: 222px;
  bottom: 110%;
  left: 0;
}
/* 20231030: */
#service_heading_pc {
  display: flex;
}
#service_heading_sp h3::after {
  background: none;
}

#service_heading_sp {
  display: none;
}

.point_flow_flex_container {
  display: flex;
  flex-direction: column;
  gap: 7rem;
}

.point_flow_flex_items {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 2rem;
  background-color: #fff;
  padding: 2rem 4rem;
  margin: 0 4rem;
  border-radius: 30px;
  position: relative;
}

.point_flow_flex_items::after {
  position: absolute;
  content: "";
  background: url(../img/point_flow_arrow.png) no-repeat center;
  width: 44px;
  height: 27px;
  bottom: -25%;
  right: 50%;
  left: 50%;
  margin: auto;
}

.point_flow_flex_items:last-child:after {
  display: none;
}

.point_flow_flex_items > div:first-child {
  width: 20%;
}

.point_flow_flex_items > div:nth-child(2) {
  width: 80%;
}

.point_flow_flex_items h4 {
  font-size: 3rem;
  color: #ec6432;
}

.point_flow_flex_items p {
  font-size: 2rem;
  font-weight: normal;
  padding-top: 1rem;
}

.point_flow_flex_items_02 {
  padding: 0 4rem;
  font-size: 2rem;
  font-weight: normal;
}

/* 料金 */
.orange_border_ttl_wrapper {
  margin: 0 auto;
  text-align: center;
}

.orange_border_ttl_wrapper h2 {
  font-size: 7rem;
  font-weight: bold;
  padding-bottom: 1rem;
  display: inline-block;
  border-bottom: 10px solid #ec8f32;
}

.fee_border_wrapper {
  font-size: 4.8rem;
  max-width: 792px;
  margin: 6rem auto 0;
  padding: 8rem 3rem 6rem 3rem;
  border: 6px solid #ec6432;
  border-radius: 38px;
  text-align: center;
}

.fee_border_inner {
  max-width: 600px;
  margin: 0 auto;
}

.fee_border_inner p {
  line-height: 1.3;
}

.fee_border_wrapper .fee_span1,
.fee_border_wrapper .fee_span3 {
  font-size: 10.4rem;
  position: relative;
  /* 20231030: */
  /* font-family: "urw-din", sans-serif; */
  font-family: 'Roboto', sans-serif;
}

.fee_border_wrapper .fee_span2 {
  font-size: 10rem;
}

.fee_border_wrapper .fee_span4 {
  font-size: 2.9rem;
}

.caution_txt {
  font-size: 2rem;
  text-align: right;
}

.fee_span1::after {
  content: "成果報酬";
  font-size: 3.4rem;
  font-weight: bold;
  position: absolute;
  width: 146px;
  height: 49px;
  top: -15%;
  left: -70%;
}

.fee_span3::after {
  content: "月額";
  font-size: 3.4rem;
  font-weight: bold;
  position: absolute;
  width: 72px;
  height: 49px;
  left: 0;
  top: -15%;
}

/* 導入までの流れ */
#consulting_flow {
  background-color: #f9f9f9;
}

#flow_ttl h2 {
  padding: 0 4rem 1rem;
}

.flow_ttl_span {
  font-size: 5rem;
}

.flow_flex_container {
  display: flex;
  flex-direction: column;
  margin: 10rem 0;
  gap: 8rem;
}

.flow_contents_flex_contents {
  display: flex;
  justify-content: center;
  align-items: flex-start;
  gap: 2rem;
  counter-increment: title;
}

.flow_contents_flex_contents h3 {
  font-size: 4rem;
  font-weight: bold;
  color: #ec6432;
  position: relative;
}

.flow_contents_flex_contents h3::before {
  position: absolute;
  top: 0;
  left: -109px;
  content: counter(title);
  width: 70px;
  height: 70px;
  line-height: 70px;
  background-color: #ec6432;
  border-radius: 100%;
  color: #f9f9f9;
  font-size: 5rem;
  padding-bottom: 0.5rem;
  font-weight: bold;
  text-align: center;
  display: flex;
  justify-content: center;
  align-items: center;
}

.flow_contents_flex_contents p {
  font-size: 2rem;
}

.flow_contents_flex_contents > div:first-child {
  width: 10%;
  position: relative;
  z-index: 10;
}
.flow_contents_flex_contents > div:nth-child(2) {
  width: 50%;
  position: relative;
  z-index: 10;
}
.flow_contents_flex_contents > div:nth-child(3) {
  width: 40%;
  text-align: center;
  position: relative;
  z-index: 10;
}

#flow_num01_wrapper {
  background-color: #f9f9f9;
}

#flow_num01_wrapper::after {
  position: absolute;
  content: "";
  border-left: 3px solid #ec6432;
  width: 3px;
  height: 613px;
  right: 0;
  left: 0;
  margin: auto;
  top: 50%;
  z-index: 1;
  transform: translateX(50%);
}

/* よくあるご質問 */
#accordion {
  margin: 8rem auto;
  width: 1100px;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  font-weight: normal;
}

.ac-title {
  background-color: #fff8e8;
  border: 1px solid #ec6432;
  color: #ec6432;
  padding: 2rem 6rem;
  display: flex;
  align-items: center;
  gap: 2rem;
  border-radius: 20px;
  font-size: 2.6rem;
  line-height: 1.5;
  position: relative;
}

.ac-content p:first-child,
.ac-title p:first-child {
  /* font-family: "Nirmala UI"; */
  font-family: 'Poppins', sans-serif;
}

.ac-content p:nth-child(2),
.ac-title p:nth-child(2) {
  font-family: "ヒラギノ角ゴ ProN", sans-serif;
  font-weight: 300;
  font-style: normal;
}

.ac-title::after {
  position: absolute;
  content: "";
  background: url(../img/faq_open.png) no-repeat center;
  width: 32px;
  height: 18px;
  right: 6rem;
}

.ac-title01-active::after,
.ac-title02-active::after,
.ac-title03-active::after {
  position: absolute;
  content: "";
  background: url(../img/faq_close.png) no-repeat center;
  width: 32px;
  height: 18px;
  right: 6rem;
}

.ac-title span {
  font-size: 4rem;
}

.ac-title01-active,
.ac-title02-active,
.ac-title03-active {
  border-radius: 20px 20px 0 0;
}

.ac-title:hover {
  cursor: pointer;
}

/* アコーディオンの内容部分 */
.ac-content {
  padding: 2rem 6rem;
  border-right: 1px solid #ec6432;
  border-left: 1px solid #ec6432;
  border-bottom: 1px solid #ec6432;
  border-radius: 0 0 20px 20px;
  display: flex;
  align-items: center;
  gap: 2rem;
  font-size: 2.6rem;
}

.ac-content span {
  font-size: 4rem;
}

/* お問い合わせ */
#contact {
  padding-top: 0;
  background-color: #fff8e8;
}

.contact_top_txt {
  text-align: center;
  font-size: 2.2rem;
  font-weight: bold;
  margin: 10rem 0 6rem;
}

.contact_container {
  display: flex;
  flex-direction: column;
  margin: 8rem auto 0;
}

label {
  display: block;
  margin-bottom: 10px;
  color: #333;
  font-weight: bold;
  font-size: 2rem;
}
/* 
select#car {
  width: 464px;
} */

form img {
  vertical-align: middle;
  padding-left: 1.3rem;
}

input#zip-code {
  width: 171px;
  margin-right: 2rem;
}

label#purpose {
  margin-bottom: 0;
}
input#purpose,
input#purpose2,
input#purpose3 {
  margin-bottom: 3rem;
  margin-right: 0.5rem;
}
input#purpose2,
input#purpose3 {
  margin-left: 2rem;
}

#zip-button {
  font-weight: bold;
  background-color: #fff;
  border: none;
  padding: 1rem 3.5rem;
  box-shadow: 0px 4px 6px rgba(0, 0, 0, 0.16);
  margin-bottom: 2rem;
  font-family: "Noto Sans JP", sans-serif;
  /* 20231030: */
  color: #333;
}

#zip-button:hover {
  opacity: 0.9;
  cursor: pointer;
}

.zip_code_flex {
  display: flex;
  align-items: center;
  margin-left: 10rem;
}

input[type="text"],
input[type="email"],
input[type="date"],
select {
  width: 70%;
  padding: 20px;
  margin-bottom: 20px;
  border: 1px solid #fff;
  border-radius: 5px;
  font-size: 1.6rem;
}
input[type="submit"] {
  background-color: #ec6432;
  color: #fff;
  padding: 1rem 2rem;
  border: none;
  border-radius: 59px;
  cursor: pointer;
  display: block;
  margin: 0 auto;
  width: 336px;
  font-weight: bold;
  font-size: 3rem;
  box-shadow: 0 5px 0 #d24e68;
  /* font-family: "ヒラギノ角ゴ ProN"; */
}
input[type="submit"]:hover {
  opacity: 0.9;
}

.form_container {
  max-width: 873px;
  margin: 5rem auto;
  padding-top: 3rem;
}

textarea {
  width: 70%;
  /* width: 873px;  */
  height: 244px;
  padding: 10px;
  margin-bottom: 6rem;
  border: 1px solid #fff;
}

.form_items_flex {
  display: flex;
  gap: 10%;
  align-items: center;
}

.form_items_flex label {
  width: 20%;
}

#zip_flex_wrapper {
  gap: 0;
}
#zip_flex_wrapper span {
  padding-left: 10%;
  margin-bottom: 2rem;
  margin-right: 1rem;
}

#textarea_flex_wrapper {
  align-items: flex-start;
}

.contact_container dd {
  width: 100%;
  margin-left: 30%;
}

/* サンクスページ */
#thanks {
  padding: 20rem 0 10rem;
}

.thanks_txt_container {
  margin: 8rem auto;
  text-align: center;
}

.thanks_txt_container h2 {
  font-size: 4rem;
  font-weight: bold;
  color: #ec6432;
  margin-bottom: 4rem;
}

.thanks_txt_container p {
  font-size: 2rem;
}

.thanks_btn_wrapper {
  font-size: 3rem;
  background-color: #ec6432;
  color: #fff;
  padding: 1rem 2rem;
  border: none;
  border-radius: 59px;
  cursor: pointer;
  display: block;
  margin: 6rem auto 0;
  width: 336px;
  font-weight: bold;
  font-size: 3rem;
  box-shadow: 0 5px 0 #d24e68;
}
.thanks_btn_wrapper a {
  color: #fff;
}

@media screen and (max-width: 1100px) {
  /* グローバル */
  html {
    scroll-padding-top: 8rem;
  }
  p {
    font-size: 1.6rem;
  }

  .dpb1100 {
    display: block;
  }

  .dpn1100 {
    display: none;
  }

  /* ヘッダー */
  .header_flex_wrapper {
    height: 80px;
  }

  .header_flex_wrapper img {
    max-width: 150px;
    padding-left: 2rem;
  }

  .header_flex_right {
    display: none;
  }

  .hamburger_nav .menu-icon {
    display: block;
    margin-right: 2rem;
  }

  .hamburger_nav {
    display: block;
  }

  .hamburger_nav ul.active {
    display: flex;
    z-index: 100;
    margin-top: 2.8rem;
    background-color: #ec6432;
    padding: 2rem 0;
  }

  .footer_contents_right ul {
    display: flex;
  }

  .hamburger_nav ul li {
    margin-right: 20px;
  }

  .hamburger_nav ul {
    display: none;
    flex-direction: column;
    background-color: #444;
    position: absolute;
    top: 60px;
    left: 0;
    width: 100%;
  }

  .hamburger_nav ul.active {
    display: flex;
    z-index: 100;
    margin-top: 2rem;
    background-color: #ec6432;
    padding: 2rem 0;
  }

  ul#menuList.active a {
    display: block;
    padding: 1.5rem 1.5rem 1.5rem 2rem;
    font-size: 2rem;
    color: #fff;
    font-weight: bold;
  }

  .openbtn1 {
    position: relative;
    background: #ec6432;
    cursor: pointer;
    width: 50px;
    height: 50px;
    border-radius: 5px;
  }

  .openbtn1 span {
    display: inline-block;
    transition: all 0.4s;
    position: absolute;
    left: 14px;
    height: 3px;
    border-radius: 2px;
    background: #fff;
    width: 45%;
  }

  .openbtn1 span:nth-of-type(1) {
    top: 15px;
  }

  .openbtn1 span:nth-of-type(2) {
    top: 23px;
  }

  .openbtn1 span:nth-of-type(3) {
    top: 31px;
  }

  /* 閉じる */
  .active.openbtn1 span {
    left: 12px;
  }
  .active span:nth-of-type(1) {
    transform: rotate(45deg);
    width: 52%;
    top: 24px;
  }
  .active span:nth-of-type(2) {
    opacity: 0;
  }
  .active span:nth-of-type(3) {
    top: 24px;
    transform: rotate(-45deg);
    width: 52%;
  }

  /* 20231030: */
  .hamburger_nav ul.active {
    display: flex;
    z-index: 100;
    margin-top: 2rem;
    background-color: #ec6432;
    padding: 2rem 0;
  }

  /* トップ */
  #top_fv_img {
    padding-top: 8rem;
  }

  .top_fv_btn_wrapper {
    transform: scale(0.7);
  }

  .top_fv_bottom {
    padding: 0;
  }

  .consulting_heading_wrapper h1 {
    font-size: 4rem;
  }

  .consulting_bnr_wrapper {
    margin: 8rem 3rem 0;
  }

  .consulting_food_flex {
    margin: 0 3rem;
  }

  /* 3つのポイント */
  .ryosyo_heading_wrapper {
    max-width: 700px;
    margin: 0 auto;
    padding: 0 2rem;
  }

  .ryosyo_heading_wrapper h1 {
    font-size: 4rem;
  }

  .ryosyo_heading_wrapper .span1 {
    font-size: 5rem;
  }

  .ryosyo_heading_wrapper .span2 {
    font-size: 6rem;
  }

  .orange_heading_wrapper_s span {
    font-size: 5rem;
  }

  .ryosyo_container h3 span {
    font-size: 8rem;
  }

  #consulting_point .ryosyo_container h3 {
    font-size: 3rem;
    margin: 0 3rem;
  }

  .point_txt_ttl {
    font-size: 2rem;
  }

  #consulting_point .point_txt {
    font-size: 1.6rem;
  }

  .point_contents_flex {
    margin: 0 3rem;
  }

  /* サービス */
  .point_service_container {
    margin: 8rem 3rem 0;
  }

  .point_service_heading_wrapper {
    padding-left: 2rem;
  }

  .point_service_heading_wrapper > div:first-child {
    padding-top: 0;
  }

  .point_service_heading_wrapper > div:first-child p,
  .point_flow_flex_items p {
    font-size: 1.6rem;
  }

  .point_flow_flex_items h4 {
    font-size: 3rem;
  }

  .point_flow_flex_items {
    padding: 2rem 3rem;
    margin: 0 3rem;
  }

  .orange_heading_wrapper {
    padding: 3rem 0;
  }

  .orange_heading_wrapper:after {
    bottom: -37px;
  }

  .orange_heading_wrapper h2 {
    font-size: 4rem;
  }

  .point_service_heading_wrapper h3::after {
    bottom: 70px;
  }

  #service_heading_pc_02 h3::after {
    bottom: 150px;
  }

  .point_service_heading_wrapper h3 {
    font-size: 3rem;
  }

  .point_service_heading_border {
    width: calc(100% - 3rem);
    margin-left: 3rem;
    margin-bottom: 6rem;
  }

  .point_flow_flex_container {
    gap: 6rem;
  }

  .point_flow_flex_items::after {
    bottom: -24%;
  }

  /* 20231030: */
  #service_heading_pc,
  #service_heading_pc_02 {
    display: none;
  }
  #service_heading_sp {
    display: flex;
  }
  .service_heading_sp_img {
    max-width: 250px;
    height: auto;
  }

  /* 料金 */
  .orange_border_ttl_wrapper h2 {
    font-size: 5rem;
  }

  .fee_border_wrapper {
    /* margin: 3rem 3rem 0 3rem; */
    padding: 4rem 3rem 3rem;
  }

  .fee_border_wrapper {
    font-size: 4rem;
  }

  .fee_border_inner p {
    font-size: 2rem;
  }

  .fee_span1::after,
  .fee_span3::after {
    font-size: 2.4rem;
  }

  .fee_border_wrapper .fee_span1,
  .fee_border_wrapper .fee_span3 {
    font-size: 8rem;
  }

  .fee_border_wrapper .fee_span2 {
    font-size: 8rem;
  }

  .fee_border_wrapper .fee_span4 {
    font-size: 2rem;
  }

  .caution_txt {
    font-size: 1.6rem !important;
  }

  /* 導入までの流れ */
  #flow_ttl h2,
  .flow_ttl_span {
    font-size: 4rem;
  }

  .flow_flex_container {
    margin: 8rem 3rem 3rem;
  }

  .flow_contents_flex_contents h3::before {
    left: -22%;
  }

  .flow_contents_flex_contents h3 {
    font-size: 3rem;
  }

  .flow_contents_flex_contents p {
    font-size: 1.6rem;
    margin-top: 1rem;
  }

  #flow_num01_wrapper::after {
    height: 626px;
  }

  #accordion {
    margin: 4rem auto;
    width: 100%;
    max-width: 800px;
  }

  .ac-title,
  .ac-content {
    padding: 1rem 3rem;
    margin: 0 3rem;
  }

  .ac-title span,
  .ac-content span {
    font-size: 3rem;
  }

  .ac-title::after {
    right: 3rem;
  }

  .contact_top_txt {
    margin: 8rem 0 3rem;
  }

  .contact_top_txt p {
    font-size: 2rem;
  }

  .form_items_flex {
    gap: 4%;
    justify-content: center;
  }

  #zip_flex_wrapper {
    justify-content: flex-start;
  }

  #zip_flex_wrapper label {
    padding-left: 4%;
  }

  #zip_flex_wrapper span {
    padding-left: 4%;
    margin-bottom: 2rem;
    margin-right: 1rem;
  }

  .zip_code_flex {
    margin-left: 6rem;
  }

  #address {
    padding-left: 4%;
  }

  .contact_container dd {
    width: 100%;
    margin-left: 27%;
  }
}
@media screen and (max-width: 1000px) {
  #flow_num01_wrapper::after {
    display: none;
  }
  .flow_contents_flex_contents {
    flex-direction: column;
  }
  .flow_contents_flex_contents h3 {
    display: flex;
    flex-direction: column;
    font-size: 2.4rem;
    justify-content: center;
    align-items: center;
  }
  .flow_contents_flex_contents h3::before {
    left: 0;
    right: 0;
    margin: auto;
    display: inline-block;
    position: relative;
    margin-bottom: 1rem;
    width: 60px;
    height: 60px;
    line-height: 60px;
    font-size: 4rem;
  }
  .flow_contents_flex_contents > div:first-child,
  .flow_contents_flex_contents > div:nth-child(2),
  .flow_contents_flex_contents > div:nth-child(3) {
    width: 100%;
  }
  .flow_flex_container {
    gap: 3rem;
  }
  .flow_contents_flex_contents p {
    text-align: center;
    max-width: 600px;
    margin: 0 auto;
  }
}

@media screen and (max-width: 768px) {
  /* グローバル */
  section,
  #consulting_point {
    padding: 4rem 0;
  }

  .dpb768 {
    display: block;
  }
  .dpn768 {
    display: none;
  }

  /* フッター */
  .footer_flex {
    flex-direction: column;
    text-align: center;
    gap: 3rem;
  }

  /* トップページ */
  .top_fv_btn::after {
    display: none;
  }
  .top_fv_btn:hover:after {
    display: none;
  }

  .top_fv_btn_txt {
    max-width: 250px;
  }

  .consulting_heading_wrapper h1 {
    font-size: 2.4rem;
  }

  .consulting_heading_wrapper {
    padding: 3rem 0;
  }

  .consulting_heading_wrapper:after {
    bottom: -25px;
  }

  .consulting_food_flex {
    flex-direction: column;
  }

  .consulting_bnr_wrapper {
    margin: 4rem 3rem 0;
  }

  /* 3つのポイント */
  .orange_heading_wrapper_s:after {
    bottom: -30px;
  }

  /* キャッチコピー */
  .ryosyo_heading_wrapper h1 {
    font-size: 2.4rem;
  }
  /* 集客&利益UPを */
  .ryosyo_heading_wrapper .span1 {
    font-size: 3rem;
  }
  /* 最大限発揮 */
  .ryosyo_heading_wrapper .span2 {
    font-size: 4rem;
  }

  /* RYOSYOの飲食コンサルティング */
  .orange_heading_wrapper_s h2 {
    text-align: center;
    font-size: 2.4rem;
    max-width: 1100px;
    margin: 4rem auto;
    background-color: #ec6432;
    color: #fff;
    font-weight: bold;
    padding: 2rem 0;
  }
  /* 3つのポイント */
  .orange_heading_wrapper_s span {
    font-size: 3rem;
  }

  #consulting_point .ryosyo_container h3 {
    padding-left: 0;
    gap: 1rem;
    flex-direction: column;
    font-size: 2.2rem;
  }
  .point_contents_flex {
    padding: 3rem 0;
    flex-direction: column;
    gap: 2rem;
  }
  .point_contents_flex > div:first-child {
    width: 80%;
  }
  .point_contents_flex > div:nth-child(2) {
    width: 100%;
    max-width: 500px;
    margin: 0 auto;
  }
  .point_txt_ttl {
    font-size: 1.8rem;
    padding-bottom: 1rem;
  }
  .point_flex_wrapper {
    margin-bottom: 2rem;
  }

  /* サービス */
  .orange_heading_wrapper h2 {
    font-size: 2.4rem;
  }
  .orange_heading_wrapper:after {
    bottom: -30px;
  }

  .point_service_container {
    max-width: 1100px;
    background-color: rgba(255, 255, 255, 0.58);
    margin: 6rem 2rem;
    padding-bottom: 6rem;
  }

  .point_service_heading_wrapper h3::after {
    display: none;
  }

  .point_service_heading_wrapper {
    flex-direction: column;
  }
  .point_service_heading_wrapper > div:first-child {
    width: 100%;
  }

  .point_service_heading_wrapper h3 {
    font-size: 2.4rem;
    padding-top: 2rem;
    margin-bottom: 1rem;
  }
  .point_service_heading_wrapper > div:first-child p,
  .point_flow_flex_items p {
    padding-bottom: 2rem;
  }

  .point_service_heading_border {
    width: calc(100% - 2rem);
    margin: 0 0 3rem 2rem;
  }
  .point_flow_flex_items {
    flex-direction: column;
    padding: 2rem;
  }
  .point_flow_flex_items h4 {
    font-size: 2.4rem;
    text-align: center;
  }
  .point_flow_flex_items > div:nth-child(2) {
    width: 100%;
  }
  .point_flow_flex_container {
    gap: 2rem;
  }
  .point_service_container {
    margin: 6rem 2rem 3rem;
    padding-bottom: 3rem;
  }
  /* service02 */
  .point_service_container:last-child {
    margin-top: 3rem;
  }
  .point_service_heading_wrapper h3 span {
    font-size: 1.6rem;
  }
  .point_flow_flex_items_02 {
    padding: 0 2rem;
  }

  /* 料金 */
  .orange_border_ttl_wrapper h2 {
    font-size: 3rem;
    border-bottom: 5px solid #ec8f32;
  }
  .fee_border_wrapper {
    margin: 3rem 3rem 0 3rem;
    padding: 3rem 2rem 1rem;
  }

  .fee_border_wrapper .fee_span1,
  .fee_border_wrapper .fee_span3 {
    font-size: 3rem;
    font-weight: bold;
  }

  .fee_border_wrapper .fee_span2 {
    font-size: 2rem;
  }
  .fee_span1::after {
    content: "成果報酬";
    font-size: 1.6rem;
    left: -58px;
    top: -15px;
  }
  .fee_span3::after {
    content: "月額";
    font-size: 1.6rem;
    left: -20px;
    top: -15px;
  }
  .fee_border_wrapper .fee_span4 {
    font-size: 1.6rem;
  }
  .caution_txt {
    text-align: center;
  }

  /* 導入までの流れ */
  .flow_flex_container {
    margin: 3rem;
  }
  #flow_ttl h2,
  .flow_ttl_span {
    font-size: 2.4rem;
  }
  /* #flow_ttl h2,
  .flow_ttl_span {
    font-size: 2.4rem;
  }
  #flow_num01_wrapper::after {
    height: 730px;
  }
  .flow_contents_flex_contents h3::before {
    left: -42%;
    position: absolute;
    top: 0;
    width: 50px;
    height: 50px;
    line-height: 70px;
    background-color: #ec6432;
    border-radius: 100%;
    color: #f9f9f9;
    font-size: 3rem;
    padding-bottom: 0.5rem;
    font-weight: bold;
    text-align: center;
    display: flex;
    justify-content: center;
    align-items: center;
  } */
  /* #flow_num01_wrapper::after {
    display: none;
  }
  .flow_contents_flex_contents {
    flex-direction: column;
  }
  .flow_contents_flex_contents h3 {
    display: flex;
    flex-direction: column;
    font-size: 2.4rem;
    justify-content: center;
    align-items: center;
  }
  .flow_contents_flex_contents h3::before {
    left: 0;
    right: 0;
    margin: auto;
    display: inline-block;
    position: relative;
    margin-bottom: 1rem;
    width: 60px;
    height: 60px;
    line-height: 60px;
    font-size: 4rem;
  }
  .flow_contents_flex_contents > div:first-child,
  .flow_contents_flex_contents > div:nth-child(2),
  .flow_contents_flex_contents > div:nth-child(3) {
    width: 100%;
  }
  .flow_flex_container {
    gap: 3rem;
  } */

  /* よくあるご質問 */
  .ac-title {
    gap: 0;
  }
  .ac-title span,
  .ac-content span {
    font-size: 2.4rem;
  }
  .ac-title p {
    padding-right: 2rem;
  }
  .ac-title::after {
    right: 1rem;
    transform: scale(0.7);
  }
  #accordion {
    margin: 4rem auto 2rem;
  }

  /* お問い合わせ */
  .contact_top_txt {
    margin: 6rem 0 4rem;
  }

  .contact_top_txt p {
    font-size: 1.6rem;
    margin: 0 3rem;
  }

  .contact_container {
    display: flex;
    flex-direction: column;
    margin: 3rem auto 0;
  }

  label {
    font-size: 1.6rem;
  }
  .form_items_flex {
    flex-direction: column;
    align-items: flex-start;
    margin: 0 3rem;
  }
  .form_items_flex label {
    width: 100%;
  }
  input[type="text"],
  input[type="email"],
  input[type="date"],
  input#zip-code,
  textarea {
    width: 100%;
  }
  #zip_flex_wrapper label {
    padding-left: 0;
  }
  #zip_flex_wrapper span {
    padding-left: 0;
  }
  .zip_code_flex {
    margin-left: 0;
    width: 100%;
  }
  input#zip-code {
    margin-right: 0;
  }
  #zip-button {
    margin-left: 3rem;
    padding: 1rem 2rem;
  }
  input[type="submit"] {
    margin: 0 auto;
    max-width: 280px;
    font-size: 2.4rem;
  }
  textarea {
    margin-bottom: 4rem;
  }
  .contact_container dd {
    width: 100%;
    margin: 0 auto;
    padding: 0 3rem;
  }

  /* サンクスページ */
  #thanks {
    padding: 10rem 0 6rem;
  }

  .thanks_txt_container {
    margin: 6rem auto;
    padding: 0 2rem;
  }

  .thanks_txt_container h2 {
    font-size: 3rem;
  }

  .thanks_txt_container p {
    font-size: 2rem;
  }

  .thanks_btn_wrapper {
    font-size: 2rem;
    width: 250px;
  }
}
