@charset "UTF-8";

/*--------------
ここから
--------------*/


/* ▽ 初期設定 --------------*/

#open {
  position: relative;
  /* padding-bottom: 120px; */
  width: 100vw;
  margin-left: calc(50% - 50vw) !important;
  font-family: "Noto Sans JP", "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN", "Yu Gothic UI", "Yu Gothic", sans-serif;
  font-weight: 500;
  line-height: 1.6;
  color: var(--color_base);
  overflow: hidden;
} 

#open * {
  box-sizing: border-box;
}

#open img {
  display: block;
  width: 100%;
  max-width: 100%;
  height: auto;
}

#open a {
  transition: 0.5s ease-in-out;
  text-decoration: none;
}

#open a:hover {
  opacity: 0.5;
  transition: 0.5s ease-in-out;
}

@media screen and (max-width: 767px) {
  #open a:hover {
    opacity: 1;
  }
}

.pc {
  display:block !important;
}

.sp {
  display: none !important;
}

@media screen and (max-width: 767px) {
  .pc {
    display: none !important;
  }

  .sp {
    display: block !important;
  }
}

#open ul, #open li {
  list-style: none;
}

#open .center {
  text-align: center;
  margin: 0 auto;
} 


/*--------------
レイアウト
--------------*/

#open .base_container {
  max-width: 1280px;
  margin: 0 auto;
}

#open .l_container {
  max-width: 1024px;
  margin: 0 auto;
  padding: 0 calc(40/1280*100%);
}

@media screen and (max-width: 767px) {
  #open .l_container {
    padding: 0 calc(40/750*100%);
  }
}

/*--------------
メソッド
--------------*/

:root {
  --color_base: #222;
  --color_white: #fff;
  --color_purple: #9b0ba0;
  --color_red: #a32123;
  --ff_yakuhan: "YakuHanJPs", "Noto Sans JP", "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN", "Yu Gothic UI", "Yu Gothic", sans-serif;
}

/* ▽ タイトル --------------*/
#open .ttl_kiyaku {
  font-size: 28px;
  color: var(--color_red);
  font-weight: 700;
  text-align: center;
  padding-top: calc(80/1024*100%);
  margin-bottom: 1em;
}

@media screen and (max-width: 1000px) {
  #open .ttl_kiyaku {
    font-size: 2.8vw;
  }
}

@media screen and (max-width: 767px) {
  #open .ttl_kiyaku {
    font-size: 5.3vw;
  }
}


#open .ttl_kiyaku_sub01 {
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: var(--color_red);
  border-radius: 6px;
  font-size: 24px;
  font-weight: 700;
  color: var(--color_white);
  line-height: 1;
  padding: .5em 0;
  margin-bottom: 1em;
}

@media screen and (max-width: 1000px) {
  #open .ttl_kiyaku_sub01 {
    font-size: 2vw;
  }
}

@media screen and (max-width: 767px) {
  #open .ttl_kiyaku_sub01 {
    font-size: 4.8vw;
    border-radius: 1.3vw;
  }
}

#open .ttl_kiyaku_sub02 {
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: var(--color_red);
  font-size: 20px;
  font-weight: 700;
  color: var(--color_white);
  line-height: 1;
  padding: .5em 0;
  margin-bottom: 1em;
  margin-top: calc(65/1024*100%);
}

@media screen and (max-width: 1000px) {
  #open .ttl_kiyaku_sub02 {
    font-size: 2.0vw;
  }
}

@media screen and (max-width: 767px) {
  #open .ttl_kiyaku_sub02 {
    font-size: 4.7vw;
    margin-top: calc(75/670*100%);
  }
}

#open .ttl_kiyaku_sub03 {
  font-size: 18px;
  line-height: 1.5;
  font-weight: 700;
}

@media screen and (max-width: 1000px) {
  #open .ttl_kiyaku_sub03 {
    font-size: 1.8vw;
  }
}

@media screen and (max-width: 767px) {
  #open .ttl_kiyaku_sub03 {
    font-size: 4.2vw;
  }
}

#open .ttl_line {
  display: flex;
  align-items: center;
  font-weight: 700;
  font-size: 20px;
  color: var(--color_base);
  width: 100%;
  margin: 2em 0 .5em;
}

@media screen and (max-width: 1000px) {
  #open .ttl_line {
    font-size: 2.0vw;
  }
}

@media screen and (max-width: 767px) {
  #open .ttl_line {
    font-size: 4.2vw;
    margin: 1em 0 .3em;
  }
}

#open .ttl_line::after {
  content: '';
  height: 1px;
  background-color: var(--color_base);
  margin-left: 1em;
  flex-grow: 1;
}


/* ▽ テキスト --------------*/

#open .text_16 {
  font-size: 16px;
  line-height: 1.5;
  text-align: justify;
  font-family: var(--ff_yakuhan);
}

@media screen and (max-width: 1000px) {
  #open .text_16 {
    font-size: 1.6vw;
  }
}

@media screen and (max-width: 767px) {
  #open .text_16 {
    font-size: 3.7vw;
  }
}

#open .text_16 a {
  text-decoration: underline;
}

/* ▽ リスト --------------*/
#open .line_process {
  font-size: 20px;
  line-height: 1.5;
  font-weight: 700;
  text-indent: -1.2em;
  padding-left: 1.2em;
}

@media screen and (max-width: 1000px) {
  #open .line_process {
    font-size: 2vw;
  }
}

@media screen and (max-width: 767px) {
  #open .line_process {
    font-size: 4.2vw;
  }
}

#open .line_process li {
  margin-top: .5em;
}

#open .line_process li span {
  color: var(--color_red);
  margin-right: .2em;
}

#open .line_process li:first-child {
  margin-top: 0em;
}

#open .kiyaku_list {
  text-indent: -1em;
  padding-left: 1em;
  font-size: 16px;
  line-height: 1.5;
  font-family: var(--ff_yakuhan);
}

#open .kiyaku_list li {
  margin-top: .3em;
}

#open .kiyaku_list li span {
  font-size: 14px;
}

#open .kiyaku_list li a {
  text-decoration: underline;
}

@media screen and (max-width: 1000px) {
  #open .kiyaku_list {
    font-size: 1.6vw;
  }

  #open .kiyaku_list li span {
    font-size: 1.4vw;
  }
}

@media screen and (max-width: 767px) {
  #open .kiyaku_list {
    font-size: 3.7vw;
  }

  #open .kiyaku_list li span {
    font-size: 3.2vw;
  }
}

#open .kiyaku_notes {
  text-indent: -1em;
  padding-left: 1em;
  font-size: 14px;
  line-height: 1.5;
  font-family: var(--ff_yakuhan);
  margin-top: 1em;
}

#open .kiyaku_notes li {
  margin-top: .3em;
}

@media screen and (max-width: 1000px) {
  #open .kiyaku_notes {
    font-size: 1.4vw;
  }
}

@media screen and (max-width: 767px) {
  #open .kiyaku_notes {
    font-size: 3.2vw;
  }
}


/* ▽ ボタン --------------*/

#open .btn_pdf a {
  width: 460px;
  display: block;
  font-size: 20px;
  font-weight: 700;
  border-radius: 9999px;
  background-color: #cdcdcd;
  color: var(--color_base);
  text-align: center;
  margin: 50px auto 85px;
  padding: 1em 0;
  font-family: var(--ff_yakuhan);
}

@media screen and (max-width: 1000px) {
  #open .btn_pdf a {
    width: calc(460/1000*100%);
    font-size: 1.8vw;
    margin: calc(50/1000*100%) auto calc(85/1000*100%);
  }
}

@media screen and (max-width: 767px) {
  #open .btn_pdf a {
    width: 100%;
    font-size: 4.2vw;
    margin: calc(50/590*100%) auto calc(85/590*100%);
  }
}

#open .btn_friend {
  text-align: center;
  text-indent: 0; 
  padding-left: 0; 
}

#open .btn_friend a {
  width: 8em;
  background-color: #06c755;
  border-radius: 9999px;
  font-size: 20px;
  font-weight: 500;
  color: #fff;
  text-decoration: none;
  display: flex;
  justify-content: center;
  align-items: center;
  margin-top: .5em;
  margin-left: .5em;
  padding: .3em 0;
  text-align: center;
}

@media screen and (max-width: 1000px) {
  #open .btn_friend a {
    font-size: 2vw;
  }
}

@media screen and (max-width: 767px) {
  #open .btn_friend a {
    font-size: 4.2vw;
  }
}

/* ▽ パディング --------------*/

#open .pb_75 {
  padding-bottom: 75px;
}

@media screen and (max-width: 1000px) {
  #open .pb_75 {
    padding-bottom: 7.5vw;
  }
}

@media screen and (max-width: 767px) {
  #open .pb_75 {
    padding-bottom: 10vw;
  }
}

#open .pb_160 {
  padding-bottom: 160px;
}

@media screen and (max-width: 1000px) {
  #open .pb_160 {
    padding-bottom: 16vw;
  }
}

@media screen and (max-width: 767px) {
  #open .pb_160 {
    padding-bottom: 21vw;
  }
}

/* ▽ マージン --------------*/

.kiyaku_list + .ttl_kiyaku_sub03 {
  margin-top: 1em;
}

.kiyaku_notes + .kiyaku_list {
  margin-top: 1em;
}

.kiyaku_notes + .ttl_kiyaku_sub03 {
  margin-top: 1em;
}

.text_16 + .kiyaku_list {
  margin-top: 1em;
}

.kiyaku_list + .kiyaku_list {
  margin-top: 1em;
}

/* ▽ シャドウ --------------*/

.shadow {
  filter:drop-shadow(8px 8px 8px rgba(119, 185, 205, .3));
  will-change: filter;
}

/* ▽ スクロールインビュー(フェードアップ) --------------*/

#open .fade_up{
  opacity: 0;
  transform: translateY(30px);
}

#open .fade_up.active {
  opacity: 1;
  transform: translateY(0);
  animation-fill-mode: backwards;
  animation: fadeUp 1s forwards;
}

@keyframes fadeUp{
  0% {
    opacity: 0;
    transform: translateY(30px);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}


/*--------------
キービジュアル
--------------*/  

#open .kv_container {
  background-color: #2e0708;
}

#open .kv {
  max-width: 1440px;
  margin: 0 auto;
}

#open .banner_container {
  background-color: #b6040b;
  border-top: 8px solid;
  border-bottom: 8px solid;
  border-image: linear-gradient(to right, #ebad24, #f9e64c, #d49a14) 1;
}

@media screen and (max-width: 1000px) {
  #open .banner_container {
    border-top: .8vw solid;
    border-bottom: .8vw solid;
  }
}

@media screen and (max-width: 767px) {
  #open .banner_container {
    border-top: 1.5vw solid;
    border-bottom: 1.5vw solid;
  }
}

#open .banner_text {
  font-size: 28px;
  color: var(--color_white);
  font-weight: 700;
  text-align: center;
  margin: 0 auto;
  padding: calc(60/1024*100%) 0 calc(15/1024*100%);
}

@media screen and (max-width: 1000px) {
  #open .banner_text {
    font-size: 2.8vw;
  }
}

@media screen and (max-width: 767px) {
  #open .banner_text {
    font-size: 5.3vw;
    padding: calc(70/670*100%) 0 calc(30/670*100%);
  }
}

#open .banner_closed {
  width: calc(720/1024*100%);
  margin: 0 auto;
  padding-bottom: calc(80/1024*100%);
  filter:drop-shadow(10px 10px 10px rgba(34, 34, 34, .3));
  will-change: filter;
}

@media screen and (max-width: 767px) {
  #open .banner_closed {
    width: 100%;
    margin: 0 auto;
    padding-bottom: calc(120/670*100%);
    filter:drop-shadow(1.3vw 1.3vw 1.3vw rgba(34, 34, 34, .3));
    will-change: filter;
  }
}

/*--------------
セクション01
--------------*/

#open .sec01 {
    background-image: radial-gradient(circle 120vw at center, #a90f17, #2e0708);
}

@media screen and (max-width: 767px) {
  #open .sec01 {
    background-image: radial-gradient(circle 315vw at center, #a90f17, #2e0708);
  }
}

#open .sec01_kikan {
  width: calc(840/1024*100%);
  font-size: 28px;
  font-weight: 700;
  line-height: 1;
  font-family: var(--ff_yakuhan);
  color: var(--color_white);
  text-align: center;
  margin:  auto;
  padding: calc(20/1024*100%) 0;
  border-top: 4px solid;
  border-bottom: 4px solid;
  border-image: linear-gradient(to right, #ebad24, #f9e64c, #ebad24) 1;
}

@media screen and (max-width: 1000px) {
  #open .sec01_kikan {
    font-size: 2.8vw;
    border-top: .4vw solid;
    border-bottom: .4vw solid;
  }
}

@media screen and (max-width: 767px) {
  #open .sec01_kikan {
    width: 100%;
    font-size: 4.8vw;
    line-height: 1.5;
    padding: calc(40/670*100%) 0;
    border-top: .5vw solid;
    border-bottom: .5vw solid;
  }
}

#open .l_container.has-sec01_kikan {
  padding-top: calc(80/1280*100%);
  padding-bottom: calc(160/1280*100%);
}

@media screen and (max-width: 767px) {
  #open .l_container.has-sec01_kikan {
    padding-top: calc(80/750*100%);
    padding-bottom: calc(160/750*100%);
  }
}

#open .sec01_movie_ttl_sub {
  font-size: 22px;
  text-align: center;
  font-weight: 700;
  font-family: var(--ff_yakuhan);
  line-height: 1;
  color: var(--color_white);
  margin: calc(70/1024*100%) auto 0;
}

@media screen and (max-width: 1000px) {
  #open .sec01_movie_ttl_sub {
    font-size: 2.2vw;
  }
}

@media screen and (max-width: 767px) {
  #open .sec01_movie_ttl_sub {
    font-size: 4.8vw;
    line-height: 1.5;
    margin: calc(75/670*100%) auto 0;
  }
}

#open .sec01_movie_ttl {
  width: calc(740/1024*100%);
  margin: calc(10/1024*100%) auto 0;
}

@media screen and (max-width: 767px) {
  #open .sec01_movie_ttl {
    width: 100%;
    margin: calc(10/670*100%) auto 0;
  }
}

#open .movie_wrap {
  width: calc(720/1024*100%);
  margin: calc(35/1024*100%) auto 0;
  aspect-ratio: 16 / 9;
}

@media screen and (max-width: 767px) {
  #open .movie_wrap {
    width: 100%;
    margin: calc(75/670*100%) auto 0;
  }
}

#open .movie_wrap iframe {
  width: 100%;
  height: 100%;
}

#open .sec01_local_ttl_sub {
  font-size: 24px;
  text-align: center;
  font-weight: 700;
  line-height: 1;
  color: var(--color_white);
  margin: calc(115/1024*100%) auto 0;
}

@media screen and (max-width: 1000px) {
  #open .sec01_local_ttl_sub {
    font-size: 2.4vw;
  }
}

@media screen and (max-width: 767px) {
  #open .sec01_local_ttl_sub {
    font-size: 5.3vw;
    margin: calc(115/670*100%) auto 0;
  }
}

#open .sec01_local_ttl {
  width: calc(480/1024*100%);
  margin: calc(20/1024*100%) auto 0;
}

@media screen and (max-width: 767px) {
  #open .sec01_local_ttl {
    width: calc(600/670*100%);
    margin: calc(20/670*100%) auto 0;
  }
}

#open .sec01_local_map {
  width: 100%;
  margin: calc(30/1024*100%) auto 0;
}

@media screen and (max-width: 767px) {
  #open .sec01_local_map {
    margin: calc(30/670*100%) auto 0;
  }
}

/*--------------
セクション02
--------------*/

#open .sec02 {
    background: url(/cp/yakioni/open/img/sec02_bg.jpg) repeat center / auto;
}


#open .l_container.has-sec02_container {
  padding-top: calc(140/1280*100%);
  padding-bottom: calc(160/1280*100%);
}

@media screen and (max-width: 767px) {
  #open .l_container.has-sec02_container {
    padding-top: calc(160/670*100%);
    padding-bottom: calc(160/670*100%);
  }
}

#open .sec02_container {
  position: relative;
  background-color: var(--color_white);
  z-index: 0;
  margin: calc(100/1024*100%) auto 0;
}

@media screen and (max-width: 767px) {
  #open .sec02_container {
    margin: calc(115/670*100%) auto 0;
  }
}

#open .sec02_container:first-child {
  margin: 0 auto;
}

#open .sec02_container::before {
  content: "";
  position: absolute;
  inset: 0;
  padding: 4px;
  background: linear-gradient(135deg, #ebad24, #f9e64c, #ebad24);
  -webkit-mask: 
    linear-gradient(#fff 0 0) content-box, 
    linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor; /* Safari用 */
          mask-composite: exclude; /* 他ブラウザ */
  z-index: -1;
}

@media screen and (max-width: 767px) {
  #open .sec02_container::before {
    padding: 1vw;
  }
}

#open .sec02_ttl {
  position: absolute;
  width: calc(230/1024*100%);
  top: 0;
  left: 0;
  right: 0;
  margin: calc(-22/1024*100%) auto 0;
}

@media screen and (max-width: 767px) {
  #open .sec02_ttl {
    width: calc(326/750*100%);
    top: 0;
    left: 0;
    right: 0;
    margin: calc(-30/670*100%) auto 0;
  }
}

#open .sec02_shouhin_flex {
  padding: calc(65/1024*100%) 0;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: calc(35/1024*100%);
}

@media screen and (max-width: 767px) {
  #open .sec02_shouhin_flex {
    padding: calc(80/670*100%) 0;
    display: flex;
    flex-direction: column;
    gap: 5.3vw;
  }
}

#open .sec02_shouhin_image {
  width: calc(465/1024*100%);
}

@media screen and (max-width: 767px) {
  #open .sec02_shouhin_image {
    width: calc(584/670*100%);
    margin: 0 auto;
  }
}

#open .sec02_shouhin_text {
  width: calc(420/1024*100%);
}

@media screen and (max-width: 767px) {
  #open .sec02_shouhin_text {
    width: 100%;
  }
}

#open .shouhin_ttl {
  font-size: 32px;
  font-weight: 700;
  text-align: center;
  color: #a32123;
  line-height: 1.3;
}

@media screen and (max-width: 1000px) {
  #open .shouhin_ttl {
    font-size: 3.0vw;
  }
}

@media screen and (max-width: 767px) {
  #open .shouhin_ttl {
    font-size: 6.4vw;
  }
}

#open .shouhin_number {
  position: relative;
  background: linear-gradient(90deg, #ffe930, #fef28f, #ffe930);
  z-index: 0;
  margin: calc(10/400*100%) auto 0;
  border-radius: 9999px;
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 32px;
  font-weight: 700;
  line-height: 1;
  color: #a32123;
  padding: .1em 0 .3em;
}

@media screen and (max-width: 1000px) {
  #open .shouhin_number {
    font-size: 3.2vw;
  }
}

@media screen and (max-width: 767px) {
  #open .shouhin_number {
    width: calc(540/670*100%);
    margin: calc(30/670*100%) auto 0;
    font-size: 6.4vw;
    color: #a32123;
  }
}

#open .shouhin_number::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 9999px;
  padding: 3px;
  background: linear-gradient(90deg, #ebad24, #f9e64c 25%, #b87101);
  -webkit-mask: 
    linear-gradient(#fff 0 0) content-box, 
    linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor; /* Safari用 */
          mask-composite: exclude; /* 他ブラウザ */
  z-index: -1;
}

@media screen and (max-width: 767px) {
  #open .shouhin_number::before {
    padding: .8vw;
  }
}

#open .shouhin_number span {
  font-size: 150%;
}

#open .shouhin_number_sub {
  font-size: 24px;
  font-weight: 700;
  line-height: 1;
  text-align: center;
  color: #a32123;
  margin: calc(10/400*100%) auto 0;
}

@media screen and (max-width: 1000px) {
  #open .shouhin_number_sub {
    font-size: 2.4vw;
  }
}

@media screen and (max-width: 767px) {
  #open .shouhin_number_sub {
    font-size: 4.8vw;
    margin: calc(20/750*100%) auto 0;
  }
}

#open .shouhin_number_sub span {
  font-size: 150%;
}

#open .sec02_oubo_container {
  width: calc(784/1024*100%);
  margin: 0 auto;
  padding: calc(70/1024*100%) 0 calc(60/1024*100%);
}

@media screen and (max-width: 767px) {
  #open .sec02_oubo_container {
    width: 100%;
    margin: 0 auto;
    padding: calc(85/670*100%) calc(40/670*100%) calc(80/670*100%);
  }
}

#open .sec02_x_ttl_wrap, #open .sec02_insta_ttl_wrap {
  background-color: #d2d2d2;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: calc(10/784*100%);
  padding: calc(20/784*100%) 0;
  position: relative;
  margin-bottom: calc(20/784*100%);
}

#open .sec02_insta_ttl_wrap {
  background-color: #ebc8eb;
}

@media screen and (max-width: 767px) {
  #open .sec02_x_ttl_wrap, #open .sec02_insta_ttl_wrap {
    gap: calc(20/590*100%);
    padding: calc(20/590*100%) 0;
    position: relative;
    margin-bottom: calc(30/590*100%);
  }
}

#open .sec02_x_ttl_wrap::after, #open .sec02_insta_ttl_wrap::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: -9px; 
  transform: translateX(-50%);
  width: 0;
  height: 0;
  border-left: 9px solid transparent;
  border-right: 9px solid transparent;
  border-top: 11px solid #d2d2d2;
}

@media screen and (max-width: 767px) {
  #open .sec02_x_ttl_wrap::after, #open .sec02_insta_ttl_wrap::after {
    bottom: -2.1vw; 
    border-left: 1.7vw solid transparent;
    border-right: 1.7vw solid transparent;
    border-top: 2.2vw solid #d2d2d2;
  }
}

#open .sec02_insta_ttl_wrap::after {
  border-top: 11px solid #ebc8eb;
}

#open .sec02_x_ttl_icon, #open .sec02_insta_ttl_icon {
  width: calc(51/784*100%);
}

@media screen and (max-width: 767px) {
  #open .sec02_x_ttl_icon, #open .sec02_insta_ttl_icon {
    width: calc(78/590*100%);
  }
}

#open .sec02_x_ttl, #open .sec02_insta_ttl {
  font-size: 24px;
  line-height: 1.1;
  font-weight: 700;
  color:var(--color_base);
  text-align: left;
}

#open .sec02_insta_ttl {
  color:var(--color_purple);
}

@media screen and (max-width: 1000px) {
  #open .sec02_x_ttl, #open .sec02_insta_ttl {
    font-size: 2.4vw;
  }
}

@media screen and (max-width: 767px) {
  #open .sec02_x_ttl, #open .sec02_insta_ttl {
    font-size: 4.2vw;
  }
}

#open .sec02_x_flex {
  display: flex;
  justify-content: center;
  align-items: flex-end;
  gap: calc(30/784*100%);
}

@media screen and (max-width: 767px) {
  #open .sec02_x_flex {
    display: flex;
    flex-direction: column;
    gap: 5.3vw;
  }
}

#open .sec02_x_text {
  width: calc(574/784*100%);
}

@media screen and (max-width: 767px) {
  #open .sec02_x_text {
    width: 100%;
  }
}

#open .sec02_x_image {
  width: calc(180/784*100%);
}

@media screen and (max-width: 767px) {
  #open .sec02_x_image {
    width: calc(394/590*100%);
    margin: 0 auto;
  }
}

#open .how_list li {
  display: flex;
  align-items: flex-start;
  color: var(--color_base);
  gap:.5em;
}

@media screen and (max-width: 767px) {
  #open .how_list li {
    margin-bottom: .5em;
  }
}

#open .how_list .number {
  font-size: 30px;
  font-weight: 700;
}

@media screen and (max-width: 1000px) {
  #open .how_list .number {
    font-size: 3vw;
  }
}

@media screen and (max-width: 767px) {
  #open .how_list .number {
    font-size: 5.3vw;
  }
}

#open .how_list .number span {
  color: var(--color_purple);
}

#open .how_list .text {
  font-size: 18px;
  line-height: 1.5;
  font-weight: 500;
  text-align: left;
  flex: 1;
  padding-top: .6em;
}

@media screen and (max-width: 1000px) {
  #open .how_list .text {
    font-size: 1.8vw;
  }
}

@media screen and (max-width: 767px) {
  #open .how_list .text {
    font-size: 4.2vw;
    padding-top: .3em;
  }
}

#open .btn_x, #open .btn_insta {
  width: calc(342/574*100%);
  margin: calc(70/574*100%) auto 0;
  background-color: #000;
  border-radius: 9999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .2em;
  padding: calc(10/574*100%) 0;
  color: var(--color_white);
  text-decoration: none;
  font-size: 24px;
  font-weight: 700;
  line-height: 1;
}

#open .btn_insta {
  width: calc(342/784*100%);
  margin: calc(40/784*100%) auto 0;
  background-color: var(--color_purple);
  padding: calc(15/784*100%) 0;
  text-decoration: none;
  font-size: 24px;
  font-weight: 700;
  line-height: 1;
}

@media screen and (max-width: 1000px) {
  #open .btn_x, #open .btn_insta {
    font-size: 2.4vw;
  }
}

@media screen and (max-width: 767px) {
  #open .btn_x, #open .btn_insta {
    width: calc(513/590*100%);
    margin: calc(60/590*100%) auto 0;
    padding: calc(20/590*100%) 0;
    color: var(--color_white);
    text-decoration: none;
    font-size: 4.8vw;
  }
}

#open .btn_x .icon_x {
  width: calc(50/342*100%);
  height: auto;
  display: block;
}

#open .btn_insta .icon_insta {
  width: calc(40/342*100%);
  height: auto;
  display: block;
  margin-right: .3em;
}

@media screen and (max-width: 767px) {
  #open .btn_x .icon_x {
    width: calc(75/513*100%);
  }

#open .btn_insta .icon_insta {
    width: calc(60/513*100%);
  }
}

#open .sec02_hr {
  width: calc(864/1024*100%);
  margin: 0 auto;
  border-top: 2px solid #e9e9e9;
}

@media screen and (max-width: 767px) {
  #open .sec02_hr {
    max-width: 100%;
    border-top: .5vw solid #e9e9e9;
  }
}

#open .sec02_oubo_wrap {
  width: calc(750/784*100%);
  margin: .5em 0 .5em auto;
  border: 2px solid var(--color_purple);
  border-radius: 10px;
  padding: 1em 2em;
  display: flex;
  flex-wrap: wrap;
  gap:0 2em;
  font-size: 16px;
  color:var(--color_purple);
}


@media screen and (max-width: 1000px) {
  #open .sec02_oubo_wrap {
    font-size: 1.7vw;
  }
}

@media screen and (max-width: 767px) {
  #open .sec02_oubo_wrap {
    width: calc(544/590*100%);
    margin: 1em 0 1em auto;
    padding: 1em;
    display: flex;
    flex-wrap: nowrap;
    flex-direction: column;
    font-size: 3.7vw;
  }
}

.sec02_oubo_wrap li {
  flex: 0 0 auto;
}

#open .sec02_ex_wrap {
  display: flex;
  align-items: flex-end;
  margin-top: calc(40/794*100%);
}

@media screen and (max-width: 767px) {
  #open .sec02_ex_wrap {
    align-items: flex-start;
    margin-top: calc(70/590*100%);
  }
}

#open .sec02_ex_wrap .sec02_ex {
  width: calc(63/784*100%);
}

@media screen and (max-width: 767px) {
  #open .sec02_ex_wrap .sec02_ex {
    width: calc(90/590*100%);
  }
}

#open .sec02_ex_wrap p {
  font-size: 24px;
  font-weight: 700;
  color: var(--color_base);
  margin-left: .3em;
  line-height: 1;
}

@media screen and (max-width: 1000px) {
  #open .sec02_ex_wrap p {
    font-size: 2.4vw;
  }
}

@media screen and (max-width: 767px) {
  #open .sec02_ex_wrap p {
    font-size: 4.8vw;
    line-height: 1.5;
    margin-left: .5em;
  }
}

#open .sec02_ex_wrap p span {
  color: var(--color_purple);
}

/*--------------
問い合わせ
--------------*/

#open .toiawase_container {
  margin-top: calc(65/1024*100%);
  width: 100%;
  background-color: #ededed;
  padding: calc(25/1024*100%) calc(25/1024*100%) calc(35/1024*100%);
}

@media screen and (max-width: 767px) {
  #open .toiawase_container {
    margin-top: calc(75/670*100%);
    padding: 2em;
  }
}

#open .toiawase_ttl {
  font-size: 24px;
  color: var(--color_base);
  font-weight: 700;
  text-align: center;
}

@media screen and (max-width: 1000px) {
  #open .toiawase_ttl {
    font-size: 2.4vw;
  }
}

@media screen and (max-width: 767px) {
  #open .toiawase_ttl {
    font-size: 4.7vw;
  }
}

#open .toiawase_flex {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  margin: 1em auto 0;
}

#open .toiawase_list {
  font-size: 16px;
  line-height: 1.5;
  font-family: var(--ff_yakuhan);
  margin-top: 1em;
}

#open .toiawase_list li {
  margin-top: .3em;
}

@media screen and (max-width: 1000px) {
  #open .toiawase_list {
    font-size: 1.6vw;
  }
}

@media screen and (max-width: 767px) {
  #open .toiawase_list {
    font-size: 3.7vw;
  }
}