@charset "UTF-8";
/* CSS Document */

/* index
---------------------------------------------- */
.index01 .main_img_w {
  position: relative;
  margin-bottom: 40px;
}

.index01 .main_img01 {
  transform: scale(1.2);
  transform-origin: center top;
  padding-bottom: 8vw;
}

.index01 .origin {
  position: absolute;
  left: 4%;
  bottom: 1%;
  mix-blend-mode: darken;
  transform: translateY(24%);
  width: 50%;
}

@media (max-width:960px) {
  .index01 .main_img01 {
    transform: scale(1.4);
    padding: 0 0 18vw;
  }

  .index01 .origin {
    transform: scale(1.4) translateY(10%);
    transform-origin: left top;
  }
}

@media (max-width:768px) {}

@media (max-width:600px) {}

@media (max-width:480px) {}

.index02 .inner {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  flex-direction: row-reverse;
}

.index02 .h2_sttl {
  text-align: right;
}

.index02 .news_w {
  width: 60%;
}

.index02 .news_li li {
  padding: 0 0 0.7em;
  margin: 0.7em 0 0;
  border-bottom: solid 1px rgba(30, 23, 23, 0.6);
}

.index02 .bnr {
  width: 30%;
  margin: 0 auto 3.6vw;
}

.index02 .bnr img {
  box-shadow: 7px 7px 10px rgba(30, 23, 23, 0.4);
}

@media (max-width:960px) {}

@media (max-width:768px) {
  .index02 .inner {
    flex-wrap: wrap;
  }

  .index02 .news_w {
    width: 100%;
    margin: 2vw 0 4vw;
  }

  .index02 .bnr {
    width: 74%;
    max-width: 400px;
    margin-top: 10px;
  }
}

@media (max-width:600px) {}

@media (max-width:480px) {
  .index02 .bnr {
    width: 86%;
  }
}

.index03 .inner {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  width: calc(112vw + 90px);
}

.index03 .h2_ttl_w {
  width: 8%;
}

.index03 .menu_li {
  /*display: flex;
  align-items:flex-start;
  justify-content: space-between;*/
  position: relative;
  width: 92%;
}

.index03 .menu_li:before {
  position: absolute;
  top: -6%;
  left: 4%;
  width: 100%;
  height: 26vw;
  z-index: -1;
  content: "";
  display: block;
  background: #C8121B;
  border-radius: 1.2em;
}

.index03 .menu_li li {
  width: 34vw;
  margin: 0 30px 0 0;
}

.index03 .menu_li dt {
  position: relative;
  padding-top: 2em;
}

.index03 .menu_li .h2_sttl {
  font-size: 2.7em;
  color: #fff;
  text-shadow: 10px 5px 10px rgba(30, 23, 23, 0.6), 0 0 1px rgba(30, 23, 23, 0.4);
  position: absolute;
  z-index: 3;
  top: 0;
  right: 0.6em;
  column-count: 1;
  white-space: nowrap;
  mix-blend-mode: hard-light;
}

.index03 .menu_li .h2_sttl .kana01 {
  letter-spacing: 0;
}

.index03 .menu_li .h2_sttl .kana02 {
  letter-spacing: -0.1em;
  padding: 0.05em 0;
}

.index03 .menu_li figure {
  overflow: hidden;
  width: 34vw;
  height: 22.66667vw;
  box-shadow: 10px 10px 10px rgba(30, 23, 23, 0.4);
  border-radius: 1px;
}

.index03 .menu_li video {
  transform: scale(1.2);
  transform-origin: top center;
  background-blend-mode: hard-light;
}

.index03 .menu_li dd {
  margin-top: 2em;
}

.slick-prev,
.slick-next {
  width: 3vw;
  height: 4vw;
  border-radius: 2px;
}

.index03 .menu_li .slick-prev {
  background: #C8121B;
  right: auto;
  left: -10vw;
}

.index03 .menu_li .slick-next {
  background: #C8121B;
  right: auto;
  left: -6vw;
}

.slick-prev:before {
  content: '\f053';
  font-family: "Font Awesome 5 Free";
  font-style: normal;
  font-weight: 700 !important;
  opacity: .96;
  font-size: 2vw;
}

.slick-next:before {
  content: '\f054';
  font-family: "Font Awesome 5 Free";
  font-style: normal;
  font-weight: 700 !important;
  opacity: .96;
  font-size: 2vw;
}

@media (max-width:960px) {
  .index03 .menu_li li {
    width: 38vw;
  }

  .index03 .menu_li figure {
    width: 38vw;
    height: 25.33333vw;
  }
}

@media (max-width:768px) {}

@media (max-width:600px) {
  .index03 .menu_li:before {
    height: 53vw;
  }

  .index03 .menu_li li {
    width: 71vw;
  }

  .index03 .menu_li figure {
    width: 71vw;
    height: 47.33334vw;
  }
}

@media (max-width:480px) {
  .index03 .menu_li .h2_sttl {
    writing-mode: horizontal-tb;
  }

  .index03 .menu_li figure {
    margin-top: 0.6em;
  }

  .index03 .menu_li .slick-current figure {}
}

.index04 {
  overflow: hidden;
}

.index04 .bgndVideo_ww {
  top: -4vw;
  width: 100%;
}

.index04 .bgndVideo_w {
  width: 100%;
}

.index04 .inner {
  /*padding-top: 100px;*/
}

.index04 .inner,
.concept01 .inner.yamitsuki {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  flex-direction: row-reverse;
}

.concept01 .inner.yamitsuki {
  padding: 0 4%;
  overflow: hidden;
}

.concept01 .inner.yamitsuki #wrapper_bgndVideo {
  margin-top: -60px;
  margin-bottom: -60px;
}

.concept01 .inner.yamitsuki #iframe_bgndVideo {
  width: 100%;
  max-width: 100vw !important;
  margin: 0 auto !important;
}

.index04 .h2_ttl_w,
.concept01 .inner.yamitsuki .h2_ttl_w {
  font-size: 140%;
  width: 7em;
}

.index04 .h2_ttl,
.concept01 .inner.yamitsuki .h2_ttl {
  margin: 0.4em 0 0.8em;
  color: rgba(255, 255, 255, 0.96);
  text-shadow: 10px 5px 10px rgba(30, 23, 23, 0.6), 0 0 1px rgba(30, 23, 23, 0.4);
  letter-spacing: 0 !important;
  transform: scale(1.2);
}

.index04 .h2_ttl span {
  display: inline-block;
}

.index04 .h2_ttl .do {
  margin-bottom: 0.06em;
}

.index04 .h2_ttl .ro {
  margin-bottom: -0.12em;
}

.index04 .h2_ttl .ltsu {
  margin-bottom: -0.05em;
}

.index04 .h2_ttl .to {
  margin-bottom: 0.1em;
}

.index04 .h2_ttl .ya {
  margin-bottom: -0.01em;
}

.index04 .h2_ttl .mi {
  margin-bottom: -0.06em;
}

.index04 .h2_ttl .tsu {
  margin-bottom: 0.02em;
}

.index04 .h2_ttl .ki {
  margin-bottom: 0.14em;
}

.index04 .txt_w p {
  font-size: 210%;
  color: rgba(255, 255, 255, 0.96);
  line-height: 1.46;
}

@media (max-width:960px) {
  .concept01 .inner.yamitsuki #wrapper_bgndVideo {
    margin-top: -11vw;
    margin-bottom: -11vw;
    width: 100vw;
    height: 55vw;
    position: relative;
  }

  .concept01 .inner.yamitsuki #iframe_bgndVideo {
    top: 50% !important;
    transform: translateY(-50%);
  }
}

@media (max-width:768px) {
  .index04 .inner {
    margin-bottom: 7vw;
  }
}

@media (max-width:600px) {
  .index04 .inner {
    margin-bottom: 45vw;
  }

  .index04 .h2_ttl_w,
  .concept01 .inner.yamitsuki .h2_ttl_w {
    width: 24vw;
  }

  .index04 .h2_ttl {
    font-size: 8vw;
    transform: scale(1.2) translateX(-40%);
  }

  .concept01 .inner.yamitsuki .h2_ttl {
    font-size: 8vw;
  }

  .index04 .txt_w {
    transform: translate(10vw, 45vw);
    width: 100%;
    white-space: nowrap;
  }

  .index04 .txt_w p {
    color: rgba(30, 23, 23, 1.0);
  }
}

@media (max-width:480px) {
  .index04 .inner {
    margin-bottom: 52vw;
    flex-wrap: wrap;
    justify-content: center;
  }

  .index04 .bgndVideo_ww {
    /*height: 164vw;*/
    height: calc(100vw + 20em);
  }

  .index04 .bgndVideo_w {
    height: 100vw;
  }

  .index04 .h2_ttl_w {
    width: 30vw;
    margin-top: -2.5em;
  }

  .index04 .h2_ttl {
    font-size: 14vw;
    transform: none;
    white-space: nowrap;
    margin: 0;
  }

  .index04 .txt_w {
    transform: translate(0, 10vw);
  }
}

.index05 {
  position: relative;
  z-index: 2;
}

.index05 .inner {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  /*width: calc(112vw + 90px);*/
  padding-right: 0;
  width: 96%;
}

.index05 .h2_ttl_w {
  width: 10%;
  /*width: 24%;*/
}

.index05 .h2_ttl {
  margin-top: 4.6em;
}

.index05 .h2_ttl span {
  transform: scale(0.9);
  display: inline-block;
}

.index05 .h2_ttl span a {
  letter-spacing: 0.04em !important;
  font-weight: 700 !important;
  color: rgba(200, 18, 27, 0.86);
  transform: scale(0.5);
  padding: 0.5em 0.2em 0.7em;
  border-radius: 0.2em;
  display: inline-block;
}

.index05 .shop_w {
  width: 90%;
}

.index05 .catch01 {
  /*padding-right: 24%;*/
  padding-right: 4vw;
}

.index05 .kochira {
  font-size: 120%;
}

.index05 .shop_li,
.store11 .shop_li {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  position: relative;
  flex-wrap: wrap;
}

.index05 .shop_li {
  /*margin-right: -4vw;*/
  /*width: 78%;*/
  width: 98%;
}

.store11 .shop_li:before {
  content: "";
  display: block;
  width: 22%;
  order: 1;
}

.store11 .shop_li:after {
  content: "";
  display: block;
  width: 22%;
}

.index05 .shop_li li,
.store11 .shop_li li {
  border-radius: 1px;
  font-size: 86%;
}

.index05 .shop_li li {
  width: 23%;
}

.store11 .shop_li li {
  width: 22%;
  margin-bottom: 30px;
}

.index05 .shop_li a,
.store11 .shop_li a {
  display: block;
  background: url(img/common/fbg01.jpg) center center no-repeat;
  box-shadow: 7px 7px 10px rgba(30, 23, 23, 0.4);
  color: rgba(255, 255, 255, 0.96);
  text-align: center;
  padding-bottom: 0.7em;
  position: relative;
  font-weight: bold;
}

.index05 .shop_li a:after,
.store11 .shop_li a:after {
  content: "";
  margin: 0.8rem 0 0 0.8em;
  width: 0.6rem;
  height: 0.6rem;
  border-top: solid 3px rgba(255, 255, 255, 1.0);
  border-left: solid 3px rgba(255, 255, 255, 1.0);
  transform: translateY(-50%) rotate(135deg);
  transform-origin: center center;
  display: block;
  padding: 0;
  position: absolute;
  bottom: 1em;
  left: 0;
  -webkit-transition: all 0.2s ease-out 0s;
  transition: all 0.2s ease-out 0s;
}

.index05 .shop_li a:hover:after,
.store11 .shop_li a:hover:after {
  left: 0.2em;
}

.index05 .shop_li figure,
.store11 .shop_li figure {
  margin-bottom: 0.7em;
}

.index05 .shop_li figure img,
.store11 .shop_li figure img {
  border-radius: 1px;
}

.index05 .shop_li a br,
.store11 .shop_li a br {
  display: none;
}

.index05 .shop_li dd,
.store11 .shop_li dd {
  margin-top: 1.4em;
  font-weight: 500;
  color: rgba(74, 61, 44, 0.86);
  letter-spacing: 0.07em;
  transform: rotate(-5deg) skewX(-5deg) translateX(1%);
}

.index05 .shop_li dd {
  font-size: 86%;
}

.store11 .shop_li dd {
  font-size: 80%;
}

/*.index05 .gmap{
  margin-right: -4vw;
}*/
.index05 .gmap_btn {
  padding-right: 1vw;
}

.index05 .gmap_btn img {
  width: 54px;
  height: 54px;
  border-radius: 50%;
  vertical-align: middle;
  transform: scale(0.8);
  transform-origin: center top;
}

@media (max-width:960px) {
  .index05 .shop_li li {
    width: 31%;
    margin-bottom: 30px;
  }

  .index05 .shop_li li:last-child {
    display: none;
  }
}

@media (max-width:768px) {
  .index05 .h2_ttl_w {
    transform: translateX(-1vw);
  }

  .store11 .shop_li li {
    width: 31%;
    margin-bottom: 30px;
  }

  .store11 .shop_li:after {
    width: 31%;
  }

  .index05 .shop_li a {
    font-size: 2.3vw;
  }

  .index05 .catch01.mt90 {
    margin: 0 0 40px -8% !important;
  }

  .index05 .kochira {
    padding-left: 1.5em;
  }

  .index05 .gmap {
    width: 84vw;
    margin-left: -6.8vw;
  }

  .index05 .gmap_btn {
    margin-left: -6.8vw;
    text-align: left !important;
    font-size: 96%;
  }

  .index05 .gmap_btn img {
    width: 36px;
    height: 36px;
  }
}

@media (max-width:600px) {
  .index05 .shop_li li {
    width: 47%;
  }

  .index05 .shop_li li:last-child {
    display: block;
  }

  .store11 .shop_li li {
    width: 47%;
  }

  .store11 .shop_li:after {
    width: 47%;
  }

  .index05 .shop_li a:after,
  .store11 .shop_li a:after {
    transform: translateY(-10%) rotate(135deg);
    left: -0.5em;
  }
}

@media (max-width:480px) {
  .store11 .shop_li li {
    margin-bottom: 15px;
  }

  .store11 .shop_li li dd {
    margin-top: 10px !important;
  }

  .index05 .gmap_btn {
    margin-left: -8.8vw;
  }
}


/* menu
---------------------------------------------- */
.menu01 {
  padding-bottom: 40px;
}

.menu01 .menu_img_w {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  flex-wrap: wrap;
}

.menu01 .menu_img_w .menu_img {
  width: calc((100% - 20px) / 2);
  box-shadow: 0 0 10px rgba(30, 23, 23, 0.12);
  margin-bottom: 30px !important;
}

@media (max-width:960px) {}

@media (max-width:768px) {}

@media (max-width:600px) {
  .menu01 .menu_img_w .menu_img {
    width: 90%;
    margin: 0 auto;
  }
}

@media (max-width:480px) {}

/* store
---------------------------------------------- */
/* 一覧 */
.store11 {
  padding-bottom: 40px;
}

.store11 .inner {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
}

.store11 .h3_ttl_w {
  width: 8%;
  padding-top: 1em;
  position: relative;
}

.store11 .h3_ttl_w:before {
  content: "";
  display: block;
  height: 20vw;
  width: 100vw;
  position: absolute;
  z-index: -1;
  top: -1.5em;
  right: -80vw;
  background: rgba(30, 23, 23, 0.06);
  border-radius: 0 1.2em 1.2em 0;
}

.store11 .shop_w {
  width: 92%;
}

@media (max-width:960px) {}

@media (max-width:768px) {}

@media (max-width:600px) {
  .store11 .inner {
    padding: 30px 4% 0;
  }

  .store11 .shop_w {
    margin-top: 0 !important;
  }

  .store11 .h3_ttl_w {
    left: -1vw;
  }

  .store11 .h3_ttl_w:before {
    height: 38vw;
  }
}

@media (max-width:480px) {}

/* 各店舗 */
.store_w .main {
  /*padding-bottom: 100px;*/
}

.store_w .main_img_sub {
  position: relative;
}

.store_w .main_img_sub:after {
  content: "";
  display: block;
  width: 100%;
  height: 80%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
  background: url(img/common/fbg01.jpg) center top repeat-y;
  background-size: cover;
}

.store_w .breadcrumb_w {
  color: rgba(255, 255, 255, 0.96);
}

.store_w .sbtn01 {
  display: flex;
  align-items: stretch;
  justify-content: space-around;
  width: 100%;
}

.store_w .hotpapper-menu {
  max-width: 700px;
  margin-right: auto;
  margin-left: auto;
}

.store_w .hotpapper-menu p {
  margin-bottom: 20px;
  text-align: center;
}

.store_w .sbtn01 li {
  width: 20%;
  min-width: 90px;
  padding: 1em 0.5em;
  box-sizing: border-box;
  border-radius: 0.1em;
  box-shadow: 0 0 10px rgba(30, 23, 23, 0.12);
}

.store_w .sbtn01 li a {
  display: block;
  padding: 1em 0.5em 2em;
  text-align: center;
  line-height: 1.36;
  height: 100%;
  box-sizing: border-box;
  color: rgba(255, 255, 255, 0.96);
  font-size: 74%;
  letter-spacing: 0.07em;
  font-weight: bold;
  border-radius: 0.1em;
  position: relative;
}

.store_w .sbtn01 li .fas {
  font-size: 240%;
  padding-bottom: 20px;
  border-bottom: solid 1px aliceblue;
  margin-bottom: 0.5em;
}

.store_w .sbtn01 li .fas.fa-angle-down {
  position: absolute;
  bottom: -1.5em;
  left: 50%;
  transform: translateX(-50%);
  font-size: 160%;
}

.store_w .sbtn01 .sbtn01_menu {
  background: #1E1717;
}

.store_w .sbtn01 .sbtn01_reserve {
  background: #D2570D;
  /*background: #e1ac0c;*/
}

.store_w .sbtn01 .sbtn01_map {
  background: #4a3d2c;
}

.store_w .sbtn01 li .tb-rl {
  text-align: left;
  font-weight: 500;
  font-size: 80%;
  padding: 0 0 0 1em;
}

.store_w .sbtn01 li .tb-rl span {
  font-size: 190%;
  font-weight: normal;
  font-family: 'Shippori Antique B1', sans-serif;
}

.store_w .h2_ttl {
  margin-top: -0.5em;
  color: rgba(255, 255, 255, 0.96);
}

.store_w .h2_ttl span {
  font-size: 0.7em;
  letter-spacing: 0.07em;
  padding-bottom: 0.3em;
  display: inline-block;
}

.store_w .r_area p {
  font-size: 86%;
  color: rgba(255, 255, 255, 0.86);
  letter-spacing: 0.07em;
  transform: rotate(-5deg) skewX(-5deg) translateX(3%);
}

.store01 .note01 {
  border: solid 2px rgba(200, 18, 27, 0.6);
  padding: 30px 4% 25px;
}

.store01 .note01 dt {
  width: fit-content;
  margin: 0 auto 0.8em;
  border-bottom: solid 2px rgba(200, 18, 27, 0.6);
  padding: 0 0.4em 0.1em;
}

.store01 .note01 dt br {
  display: none;
}

.store01 .note01 .youtube_w,
.store01 .note01 .short_w {
  display: none;
}

.store01 .menu_w {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  width: 112vw;
  position: relative;
}

.store01 .menu_w:before {
  position: absolute;
  left: 0.5em;
  bottom: 5.6em;
  content: "\f122";
  font-family: "Font Awesome 5 Free";
  font-style: normal;
  font-weight: 700 !important;
  opacity: 0.15;
}

.store01 .menu_w:after {
  position: absolute;
  left: 0;
  bottom: 2em;
  content: "SCROLL";
  font-family: 'Noto Sans JP', sans-serif;
  letter-spacing: 0.04em !important;
  font-weight: 700 !important;
  opacity: 0.15;
  transform: rotate(90deg);
  transform-origin: center top;
}

.store01 .menu_w .h3_ttl_w {
  width: 8%;
}

.store01 .menu_img_w {
  width: 103vw;
  position: relative;
  /*display: flex;
  align-items: flex-start;
  justify-content: space-between;
  flex-wrap: wrap;
  width: 120vw;
  overflow-x: scroll;*/
}

.store01 .menu_img_w:after {
  position: absolute;
  top: 6%;
  left: -2%;
  width: 100%;
  height: 94%;
  z-index: -1;
  content: "";
  display: block;
  background: rgba(30, 23, 23, 0.06);
  border-radius: 1.2em;
}

.store01 .menu_img_w .slick-track {
  min-width: 100% !important;
}

.store01 .menu_img_w .menu_img {
  width: 30vw;
  float: left;
  margin: 0 1vw 40px;
  box-shadow: 0 0 10px rgba(30, 23, 23, 0.12);
}

.store01 .menu_img_w .menu_img.w2 {
  width: 64.7vw !important;
}

.store02 .table01 th {
  width: 200px;
}

.store02 .table01 th.note01 {
  padding: 0.7em 0.5em;
}

.store03 {
  opacity: 0.68;
  color: #4a3d2c;
}

.store03 h3 {
  margin-bottom: 0.5em;
}

.store03 dl {
  font-size: 74%;
}

.store03 dt {
  font-weight: bold;
  background: rgba(30, 23, 23, 0.1);
  padding: 0 0.5em;
  width: 6.4em;
  text-align: center;
  float: left;
}

.store03 dd {
  margin-bottom: 0.3em;
  margin-left: 7.5em;
}

.store03 dd a {
  display: inline-block;
  margin-left: 0.5em;
  letter-spacing: 0;
}

.store03 dd a br {
  display: none;
}

.store04 .img_w {
  display: -webkit-flex;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  /*width: 94%;*/
  margin: 0 auto;
  box-sizing: border-box;
}

.store04 .img_w div {
  padding: 0 0.5vw;
}

/*.store04 .img_w img:first-child{
  transform: rotate(3deg) translateY(-2%) scale(1.05);
}
.store04 .img_w img:nth-child(2){
  transform: rotate(-1deg);
}
.store04 .img_w img:nth-child(3){
  transform: rotate(-5deg) translateY(-8%) scale(1.1);
}*/
@media (max-width:960px) {}

@media (max-width:768px) {
  .store01 .menu_w:after {
    left: 0.3em;
    content: "SWIPE";
  }

  .store01 .menu_img_w .menu_img.w2 {
    width: 99vw !important;
  }
}

@media (max-width:600px) {
  .store01 .note01 {
    width: 92%;
    margin: 40px auto 0;
    box-sizing: border-box;
  }

  .store03 dl {
    line-height: 2.7;
  }
}

@media (max-width:480px) {
  .store11 .h3_ttl_w {
    left: -0.5em;
  }

  .store01 .menu_img_w {
    width: 100vw;
  }

  .store01 .menu_img_w .menu_img.w2 {
    width: 196vw !important;
  }

  .store03 dd a {
    padding: 0.2em 0;
    margin-left: 1em;
  }

  .store04 .img_w {
    flex-wrap: wrap;
  }

  .store04 .img_w img {
    margin-bottom: 1em;
  }
}


/* about
---------------------------------------------- */
#about .header01,
#about .footer02 {
  background: rgba(74, 61, 44, 0.86);
}

.about01 {
  padding-bottom: 40px;
}

.about01 .greeting .catch01 {
  text-align: left;
  font-size: 2.4em;
}

.about01 .history td {
  opacity: 0.96;
}

.about01 .history .month {
  display: inline-block;
  width: 2.4em;
  text-align: right;
  padding-right: 1em;
}

.about01 .history .area {
  display: inline-block;
  min-width: 3em;
  text-align: center;
  padding: 0 0.5em 0.1em;
  line-height: 1.24;
  vertical-align: 0.1em;
  margin-right: 1em;
  border-radius: 0.2em;
  background: rgba(30, 23, 23, 0.12);
  font-size: 70%;
  color: rgba(30, 23, 23, 0.86);
}

.about01 .history td p {
  padding: 0.4em 0 0.5em;
}

.about01 .history .senba {
  padding: 0 1em 1em 0;
  display: inline;
  max-width: 270px;
}

.about01 .point_li {
  display: -webkit-flex;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  width: 100%;
}

.about01 .point_li li {
  width: 28%;
  padding: 1em;
  background: url(img/about/point_bg.png) left 60% top 15% no-repeat;
  background-size: 80% auto;
}

.about01 .point_li li img {
  width: 60%;
  display: inline-block;
  margin: 0 auto 0.5em;
}

.about01 .point_li li dd {
  font-size: 86%;
  opacity: 0.86;
}

@media (max-width:960px) {}

@media (max-width:768px) {
  .about01 .area_w {
    flex-wrap: wrap;
  }

  .about01 .l_area {
    width: 100%;
    text-align: center;
  }

  .about01 .l_area img {
    max-width: 460px;
  }

  .about01 .r_area {
    width: 100%;
  }

  .about01 .point_li {
    flex-wrap: wrap;
  }

  .about01 .point_li li {
    width: 86%;
    margin: 0 auto;
  }

  .about01 .point_li li dt {
    max-width: 360px;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 1em;
  }

  .about01 .point_li li dd {
    font-size: 96%;
  }
}

@media (max-width:600px) {}

@media (max-width:480px) {
  .about01 .greeting .catch01 {
    font-size: 2.1em;
  }
}


/* concept
---------------------------------------------- */
.concept01 .main_img_w {
  position: relative;
}

.concept01 .origin {
  position: absolute;
  left: -14%;
  bottom: -18%;
  mix-blend-mode: darken;
  transform: translateY(24%);
  width: 70%;
}

.concept01 .main_img01 {
  transform: scale(1.2);
  transform-origin: center top;
  padding-bottom: 10%;
}

.concept01 .h3_ttl {
  font-size: 2.4em;
  line-height: 1.46;
}

.concept01 .l_area figure {
  margin-top: -120px;
}

.concept01 .r_area figure {
  margin-top: -240px;
}

.concept01 .txt_w {
  font-size: 170%;
  transform: translateY(-50%);
  background: #fff;
  padding: 0.5em 0 0.5em 1em;
}

.concept02 {
  padding-bottom: 40px;
}

.concept02 p {
  opacity: 0.96;
  mix-blend-mode: multiply;
}

.concept02 .catch01 {
  opacity: 0.86;
  font-size: 2.4em;
  line-height: 1.46;
}

.concept02 .h3_ttl {
  opacity: 0.96;
  line-height: 1.46;
}

.concept02 .txt_w01,
.concept02 .txt_w03 {
  /*transform: translateX(-1vw);*/
  letter-spacing: 0;
}

.concept02 .txt_w02 {
  /*transform: translateX(1vw);*/
  letter-spacing: 0;
}

.concept02 .txt_w01 .l_area,
.concept02 .txt_w02 .r_area,
.concept02 .txt_w03 .l_area {
  width: 38%;
}

.concept02 .txt_w01 .r_area,
.concept02 .txt_w02 .l_area,
.concept02 .txt_w03 .r_area {
  width: 56%;
}

.concept02 .txt_w02 em {
  font-size: 110%;
}

.concept02 figure img {
  border-radius: 0.7em;
  transform: scale(1.2);
}

.concept02 .txt_w01 figure img,
.concept02 .txt_w03 figure img {
  transform-origin: right top;
}

.concept02 .txt_w02 figure img {
  transform-origin: left top;
}

@media (max-width:1280px) {
  .concept01 .main_img01 {
    transform: none;
    padding-bottom: 0;
  }

  .concept01 .origin {
    left: -3%;
    bottom: -22%;
    width: 60%;
  }

  .concept02 figure img {
    transform: none;
  }
}

@media (max-width:960px) {
  .concept01 .l_area figure {
    margin-top: 0;
  }

  .concept01 .r_area figure {
    margin-top: 0;
  }
}

@media (max-width:768px) {
  .concept01 .area_w {
    flex-wrap: wrap;
    margin-top: 1em !important;
  }

  .concept01 .l_area {
    width: 100%;
    text-align: center;
  }

  .concept01 .area_w img {
    max-width: 460px;
  }

  .concept01 .r_area {
    width: 100%;
    text-align: center;
  }

  .concept01 .takoyaki .l_area {
    order: 2;
  }

  .concept01 .takoyaki .r_area {
    order: 1;
  }

  .concept02 .area_w {
    flex-wrap: wrap;
  }

  .concept02 .txt_w01 .l_area,
  .concept02 .txt_w02 .r_area,
  .concept02 .txt_w03 .l_area {
    width: 100%;
    text-align: center;
  }

  .concept02 .txt_w02 .r_area {
    order: 1;
  }

  .concept02 .txt_w01 .r_area,
  .concept02 .txt_w02 .l_area,
  .concept02 .txt_w03 .r_area {
    width: 100%;
  }

  .concept02 .txt_w02 .l_area {
    order: 2;
  }

  .concept02 .txt_w01 .l_area figure,
  .concept02 .txt_w02 .r_area figure,
  .concept02 .txt_w03 .l_area figure {
    width: 86%;
    margin: 0 auto;
  }

  .concept02 figure img {
    max-width: 460px;
  }
}

@media (max-width:600px) {
  .concept01 .inner {
    padding: 30px 4% 40px !important;
  }

  .concept01 .main_img01 {
    transform: scale(1.4);
    transform-origin: center center;
    padding: 2vw 0;
  }

  .concept01 .txt_w {
    font-size: 140%;
  }
}

@media (max-width:480px) {
  .concept02 .catch01 {
    font-size: 2.0em;
  }
}


/* for-franchising-partners
---------------------------------------------- */
#for-franchising-partners .header01,
#for-franchising-partners .footer02 {
  background: rgba(74, 61, 44, 0.86);
}

#for-franchising-partners .main_img .h2_ttl img {
  padding-bottom: 0.5em;
}

#for-franchising-partners .img_w {
  display: -webkit-flex;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  width: 94%;
  margin: 0 auto;
  box-sizing: border-box;
}

#for-franchising-partners .img_w img {
  padding: 0 0.5vw;
}

/*#for-franchising-partners .img_w img:first-child{
  transform: rotate(3deg) translateY(-2%) scale(1.05);
}
#for-franchising-partners .img_w img:nth-child(2){
  transform: rotate(-1deg);
}
#for-franchising-partners .img_w img:nth-child(3){
  transform: rotate(-5deg) translateY(-8%) scale(1.1);
}*/
.f-partners01 .table01.f_table {
  font-size: 80%;
}

.f-partners01 .table01 th {
  text-align: center;
}

.f-partners01 .toggle {
  display: none;
}

.f-partners01 .label {
  padding: 0.7em;
  display: block;
  color: #fff;
  background: rgba(200, 18, 27, 0.86);
  font-size: 1.7em;
}

.f-partners01 .label:before {
  content: "";
  width: 6px;
  height: 6px;
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
  -webkit-transform: rotate(45deg);
  position: absolute;
  top: calc(50% - 3px);
  right: 20px;
  transform: rotate(135deg);
}

.f-partners01 .label,
.f-partners01 .content {
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  transform: translateZ(0);
  transition: all 0.3s;
}

.f-partners01 .txt_w {
  height: 0;
  margin-bottom: 10px;
  padding: 0 20px;
  overflow: hidden;
  font-size: 90%;
}

.f-partners01 .toggle:checked+.label+.txt_w {
  height: auto;
  padding: 20px;
  transition: all .3s;
}

.f-partners01 .toggle:checked+.label:before {
  transform: rotate(-45deg) !important;
}

.f-partners01 .catch02 {
  font-size: 140%;
}

.f-partners01 dl dt {
  border: solid 2px rgba(200, 18, 27, 0.6);
  border-radius: 2px;
  font-size: 110%;
  padding: 0 1em 0.2em;
  width: fit-content;
}

@media (max-width:960px) {}

@media (max-width:768px) {
  #for-franchising-partners .main_img .h2_ttl img {
    max-width: 320px;
    width: 40%;
  }
}

@media (max-width:600px) {
  .f-partners01 .table01.f_table {
    font-size: 96%;
  }

  .f-partners01 .table01 th {
    text-align: left;
  }

  .f-partners01 .table01 td {
    opacity: 0.86;
  }
}

@media (max-width:480px) {}


/* recruit
---------------------------------------------- */
/*#recruit .header01,
#recruit .footer02{
  background: rgba(74,61,44,0.86);
}*/
#recruit .catch03 {
  font-size: 2.4em;
  text-align: center;
  line-height: 1.54;
  opacity: 0.96;
  letter-spacing: 0.09em !important;
}

#recruit .h3_ttl {
  line-height: 1.86;
}

.recruit01 {
  padding-bottom: 40px;
}

.recruit01 .kankyo .h3_ttl {
  font-size: 1.6em;
}

.recruit01 .points_w {
  position: relative;
  background: url(img/common/bg01.jpg) center top repeat-y;
  background-size: cover;
}

.recruit01 .points_w .h3_ttl {
  width: fit-content;
  margin: 0 auto;
  padding: 0 0.3em;
  border-bottom: solid 3px rgba(200, 18, 27, 0.86);
  transform: translateY(-20%);
}

.recruit01 .points_li {
  line-height: 2.4;
  font-size: 130%;
}

.recruit01 .points_li li {
  padding-left: 1.5em;
  position: relative;
  line-height: 1.36;
  padding: 0.5em 0 0.5em 1.5em;
}

.recruit01 .points_li li:before {
  content: "\f00c";
  font-family: "Font Awesome 5 Free";
  font-weight: 700;
  position: absolute;
  left: 0;
  top: 0;
  transform: scale(0.8) translateY(58%);
  color: #C8121B;
}

.recruit01 .catch04 {
  font-size: 400%;
  letter-spacing: 0.1em;
  position: relative;
  z-index: 2;
}

.recruit01 .catch04 strong {
  color: inherit;
  display: inline-block;
  position: relative;
}

.recruit01 .catch04 strong:after {
  background: url(img/about/point_bg.png) left 60% top 15% no-repeat;
  background-size: 100% auto;
  display: block;
  position: absolute;
  left: 50%;
  top: 50%;
  z-index: -1;
  content: "";
  width: 100%;
  height: 100%;
  aspect-ratio: attr(width) / attr(height);
  transform: translate(-50%, -40%) scale(1.9);
}

.recruit01 .catch04 span {
  display: inline-block;
  margin-right: -0.1em;
}

.recruit01 .baitoru {
  background: rgba(200, 18, 27, 0.86);
  font-size: 130%;
  color: #fff;
  width: fit-conetnt;
  padding: 0.5em 2em;
  border-radius: 0.1em;
}

.recruit01 .baitoru img {
  width: 100px;
  padding-right: 1em;
  vertical-align: middle;
}

.recruit01 .baitoru span {
  display: inline-block;
  transform: translateY(7%);
}

/*#recruit dt.catch01{
  color: #4a3d2c;
}
.recruit01 .miryoku li span{
  color:#C8121B;
  font-size: 110%;
}
.recruit01 .kankyo .txt{
  padding: 1em;
  border-radius: 0.3em;
  border:solid 2px rgba(200,18,27,0.68);
  font-size: 90%;
  text-align: center;
}
.recruit01 .kankyo .txt span{
  display: inline-block;
  padding-right: 1em;
}
.recruit01 .r_info_li{
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  flex-wrap: wrap;
}
.recruit01 .r_info_li li{
  width: 31%;
  color:#C8121B;
  font-size: 120%;
  line-height: 1.64;
}
.recruit01 .r_info_li li img{
  padding-bottom: 0.2em;
}*/
@media (max-width:960px) {}

@media (max-width:768px) {
  .recruit01 .kankyo .area_w {
    flex-wrap: wrap;
  }

  .recruit01 .kankyo .l_area {
    width: 100%;
    text-align: center;
  }

  .recruit01 .kankyo .l_area img {
    max-width: 460px;
  }

  .recruit01 .kankyo .r_area {
    width: 100%;
  }
}

@media (max-width:600px) {
  #recruit .main_img img {
    transform: scale(1.15);
    transform-origin: 35% top;
    padding-bottom: 3vw;
  }

  .recruit01 .catch04 {
    font-size: 300%;
    text-align: center;
  }
}

@media (max-width:480px) {
  .recruit01 .kankyo p.h3_ttl {
    font-size: 1.4em;
  }

  .recruit01 .baitoru {
    padding: 0.5em 1em;
  }

  .recruit01 .baitoru a {
    display: flex;
    align-items: center;
  }

  .recruit01 .baitoru img {
    float: left;
  }

  .recruit01 .baitoru span {
    display: inline;
  }
}


/* activity-report
---------------------------------------------- */
.a-report01 {
  padding-bottom: 7vw;
  background: url(img/a-report/a-report_bg01.png?20230127) center bottom no-repeat;
  background-size: 100% auto;
}

.a-report01 .report_item {
  transform: rotate(-3deg);
}


/* policy
---------------------------------------------- */
.policy01 {
  padding-bottom: 40px;
}

#policy .h2_ttl {
  font-size: 2.4em;
}

.policy01 .h3_ttl {
  font-size: 1.2em;
}

.policy01 p {
  font-size: 90%;
  opacity: 0.96;
}

.policy01 ul {
  font-size: 86%;
  opacity: 0.9;
  letter-spacing: 0.07em;
  margin-top: 0.3em;
}

@media (max-width:960px) {}

@media (max-width:768px) {}

@media (max-width:600px) {
  .policy01 .inner {
    padding: 30px 4% 40px !important;
  }
}

@media (max-width:480px) {}



/* 紙吹雪
---------------------------------------------- */
/*#index .main{
  position: relative;
}
#index .header_w{
  position: relative;
  z-index: 3;
}
.confetti {
	width: 100%;
  height: 100%;
  position: fixed;
  top: 0;
  left: 0;
}
.confetti span {
	position: absolute;
	top: -10%;
	left: 0;
	width: 1.5vw;
	height: 1vw;
	background: #FFF;
}
@media (max-width:600px){
.confetti span {
	width: 3vw;
	height: 2vw;
}
}*/
/* add animation */
/*.confetti span:nth-child(2n+1) {
	animation: confetti-anim-1 10s 0s linear infinite;
}
.confetti span:nth-child(2n+2) {
	animation: confetti-anim-2 10s 0s linear infinite;
}*/
/* side position */
/*.confetti span:nth-child(1) {
	left: 0%;
}
.confetti span:nth-child(2) {
	left: 2%;
}
.confetti span:nth-child(3) {
	left: 4%;
}
.confetti span:nth-child(4) {
	left: 6%;
}
.confetti span:nth-child(5) {
	left: 8%;
}
.confetti span:nth-child(6) {
	left: 10%;
}
.confetti span:nth-child(7) {
	left: 12%;
}
.confetti span:nth-child(8) {
	left: 14%;
}
.confetti span:nth-child(9) {
	left: 16%;
}
.confetti span:nth-child(10) {
	left: 18%;
}
.confetti span:nth-child(11) {
	left: 20%;
}
.confetti span:nth-child(12) {
	left: 22%;
}
.confetti span:nth-child(13) {
	left: 24%;
}
.confetti span:nth-child(14) {
	left: 26%;
}
.confetti span:nth-child(15) {
	left: 28%;
}
.confetti span:nth-child(16) {
	left: 30%;
}
.confetti span:nth-child(17) {
	left: 32%;
}
.confetti span:nth-child(18) {
	left: 34%;
}
.confetti span:nth-child(19) {
	left: 36%;
}
.confetti span:nth-child(20) {
	left: 38%;
}
.confetti span:nth-child(21) {
	left: 40%;
}
.confetti span:nth-child(22) {
	left: 42%;
}
.confetti span:nth-child(23) {
	left: 44%;
}
.confetti span:nth-child(24) {
	left: 46%;
}
.confetti span:nth-child(25) {
	left: 48%;
}
.confetti span:nth-child(26) {
	left: 50%;
}
.confetti span:nth-child(27) {
	left: 52%;
}
.confetti span:nth-child(28) {
	left: 54%;
}
.confetti span:nth-child(29) {
	left: 56%;
}
.confetti span:nth-child(30) {
	left: 58%;
}
.confetti span:nth-child(31) {
	left: 60%;
}
.confetti span:nth-child(32) {
	left: 62%;
}
.confetti span:nth-child(33) {
	left: 64%;
}
.confetti span:nth-child(34) {
	left: 66%;
}
.confetti span:nth-child(35) {
	left: 68%;
}
.confetti span:nth-child(36) {
	left: 70%;
}
.confetti span:nth-child(37) {
	left: 72%;
}
.confetti span:nth-child(38) {
	left: 74%;
}
.confetti span:nth-child(39) {
	left: 76%;
}
.confetti span:nth-child(40) {
	left: 78%;
}
.confetti span:nth-child(41) {
	left: 80%;
}
.confetti span:nth-child(42) {
	left: 82%;
}
.confetti span:nth-child(43) {
	left: 84%;
}
.confetti span:nth-child(44) {
	left: 86%;
}
.confetti span:nth-child(45) {
	left: 88%;
}
.confetti span:nth-child(46) {
	left: 90%;
}
.confetti span:nth-child(47) {
	left: 92%;
}
.confetti span:nth-child(48) {
	left: 94%;
}
.confetti span:nth-child(49) {
	left: 96%;
}
.confetti span:nth-child(50) {
	left: 98%;
}*/
/* colors */
/*.confetti span:nth-child(5n+1) {
	background: red;
}
.confetti span:nth-child(5n+2) {
	background: blue;
}
.confetti span:nth-child(5n+3) {
	background: green;
}
.confetti span:nth-child(5n+4) {
	background: pink;
}
.confetti span:nth-child(5n+5) {
	background: yellow;
}*/
/* animation-duration */
/*.confetti span:nth-child(4n+1) {
	animation-duration: 5s;
}
.confetti span:nth-child(4n+2) {
	animation-duration: 12s;
}
.confetti span:nth-child(4n+3) {
	animation-duration: 8s;
}
.confetti span:nth-child(4n+4) {
	animation-duration: 6s;
}*/
/* animation-delay */
/*.confetti span:nth-child(11n+1) {
	animation-delay: 0s;
}
.confetti span:nth-child(11n+2) {
	animation-delay: 9s;
}
.confetti span:nth-child(11n+3) {
	animation-delay: 2s;
}
.confetti span:nth-child(11n+4) {
	animation-delay: 5s;
}
.confetti span:nth-child(11n+5) {
	animation-delay: 6s;
}
.confetti span:nth-child(11n+6) {
	animation-delay: 7s;
}
.confetti span:nth-child(11n+7) {
	animation-delay: 3s;
}
.confetti span:nth-child(11n+8) {
	animation-delay: 1s;
}
.confetti span:nth-child(11n+9) {
	animation-delay: 2s;
}
.confetti span:nth-child(11n+10) {
	animation-delay: 11s;
}
.confetti span:nth-child(11n+11) {
	animation-delay: 10s;
}*/
/* animation */
/*@keyframes confetti-anim-1 {
	0% {
		top: -10%;
		transform: translateX(0) rotateX(0) rotateY(0);
	}
	100% {
		top: 100%;
		transform: translateX(20vw) rotateX(180deg) rotateY(360deg);
	}
}
@keyframes confetti-anim-2 {
	0% {
		top: -10%;
		transform: translateX(0) rotateX(0) rotateY(0);
	}
	100% {
		top: 100%;
		transform: translateX(-20vw) rotateX(180deg) rotateY(360deg);
	}
}*/
/* クリックできる様に！ */
/*#index .index02 .inner {
  position: relative;
  z-index: 1;
}
#index .index03 .menu_li {
  z-index: 1;
}
#index .index04 .inner{
  position: relative;
  z-index: 1;
}
#index .notice01{
  position: relative;
  z-index: 1;
}*/


/* index20240226 TV紹介 */
.index07 .inner {
  padding: 30px 4% 30px;
}

.index07 .tv_w {
  padding: 24px 100px 24px 20px;
  box-sizing: border-box;
  border: solid 8px rgba(74, 61, 44, 0.68);
  border-radius: 1.3em;
  background: rgba(74, 61, 44, 0.68) url(img/index/tv_bg01.png) right 2% top 30% no-repeat;
  background-size: auto 70%;
  position: relative;
}

.index07 .tv_w:after {
  position: absolute;
  left: 50%;
  top: 0;
  width: 250px;
  height: 80px;
  content: "";
  display: block;
  background: url(img/index/tv_bg02.png) center center no-repeat;
  background-size: 100% 100%;
  transform: translateY(calc(-100% - 6px));
}

.index07 .tv_w:before {
  position: absolute;
  right: 0;
  top: 0;
  content: "Media Information";
  transform: translateX(100%) rotate(90deg);
  transform-origin: left bottom;
  padding-bottom: 0.2em;
  font-size: 2.1vw;
  text-indent: -1.5em;
}

.index07 .tv_li {
  padding: 10px 20px 20px;
  box-sizing: border-box;
  border-left: solid 6px rgba(74, 61, 44, 0.1);
  border-right: solid 6px rgba(74, 61, 44, 0.1);
  border-radius: 0.2em;
  text-align: center;
  position: relative;
  background: #fff;
}

.index07 .tv_li:before {
  position: absolute;
  left: 0;
  top: 0;
  content: "";
  display: block;
  width: calc(100% + 6px);
  height: 0;
  border-top: solid 6px rgba(74, 61, 44, 0.68);
  border-radius: 200vw 200vw 0 0 / 10vw 10vw 0 0;
  transform: translateY(-100%);
  margin: 0 -3px;
}

.index07 .tv_li:after {
  position: absolute;
  left: 0;
  bottom: 0;
  content: "";
  display: block;
  width: calc(100% + 6px);
  height: 0;
  border-bottom: solid 6px rgba(74, 61, 44, 0.68);
  border-radius: 0 0 200vw 200vw / 0 0 10vw 10vw;
  transform: translateY(100%);
  margin: 0 -3px;
}

/*.index07 .tv_w{
  background: url(img/index/tv_bg02.png) center center no-repeat;
  background-size: 100% 100%;
  padding: 180px 1% 80px;
  position: relative;
  margin: 0 10vw 0 auto;
}
.index07 .tv_w:before{
  position: absolute;
  left:0;
  top:0;
  transform: translateX(-100%);
  content: "";
  display: block;
  height: 100%;
  width: 12vw;
  background: url(img/index/tv_bg01.png) center center no-repeat;
  background-size: 100% 100%;
}
.index07 .tv_w:after{
  position: absolute;
  right:0;
  top:0;
  transform: translateX(100%);
  content: "";
  display: block;
  height: 100%;
  width: 15vw;
  background: url(img/index/tv_bg03.png) center center no-repeat;
  background-size: 100% 100%;
}*/
.index07 .tv_w li {
  display: inline-block;
  padding: 0.7em 0.4em 0.9em;
  line-height: 1.0;
  transform: scaleX(96%);
}

.index07 .tv_w li.l {
  font-size: 150%;
}

.index07 .tv_w .bangumi {
  font-weight: lighter;
  font-size: 124%;
  display: inline-block;
  letter-spacing: 0.024em;
}

.index07 .tv_w .bangumi .s {
  font-size: 74%;
  vertical-align: 1px;
}

.index07 .tv_w .keiretsu {
  font-size: 50%;
  font-weight: 600;
  font-family: 'Noto Sans JP', sans-serif;
  opacity: 0.86;
  padding-bottom: 0.4em;
  display: inline-block;
}

.index07 .tv_w .green {
  font-weight: bold;
  color: #3a960c;
}

.index07 .tv_w .naiyo {
  font-size: 58%;
  letter-spacing: 0;
  font-family: 'Noto Sans JP', sans-serif;
  color: rgba(147, 105, 62, 0.74);
  font-weight: bold;
  display: inline-block;
  line-height: 1.24;
  padding-top: 0.5em;
}

@media (max-width:960px) {
  .index07 .tv_w {
    padding: 24px 7vw 24px 2vw;
    background: rgba(74, 61, 44, 0.68) url(img/index/tv_bg01.png) right 1vw top 30% no-repeat;
    background-size: 5vw auto;
  }
}

@media (max-width:768px) {
  .index07 .inner {
    padding: 30px 7vw 30px 4vw;
    width: 87vw;
  }

  .index07 .tv_w:before {
    padding-bottom: 0;
    font-size: 6vw;
  }

  .index07 .tv_li {
    padding: 20px 0;
  }

  .index07 .tv_w li {
    padding: 0 0.4em 0.9em;
  }
}

@media (max-width:600px) {}

@media (max-width:480px) {}



/* allergic アレルギー情報 */
.allergic01 {
  padding-bottom: 70px;
}

.allergic01 .catch02 {
  text-align: center;
  font-size: 1.36em;
  line-height: 1.2;
  letter-spacing: 0.04em;
}

.allergic01 .red {
  color: #C8121B;
}

.allergic01 .toggle-content {
  padding: 2em 1em 4em;
  background: rgba(30, 23, 23, 0.06);
}

.allergic01 label {
  cursor: pointer;
  display: inline-block;
  line-height: 1.0;
}

.allergic01 #toggle-checkbox {
  /*vertical-align: 0.8em;*/
  display: inline-block;
  line-height: 1.0;
}

.allergic01 .tabs {
  display: flex;
  border-bottom: 1px solid rgba(30, 23, 23, 0.36);
  margin-bottom: 1.4em;
}

.allergic01 .tabs button {
  flex: 1;
  padding: 0.7em 0.2em 0.4em;
  border-radius: 0.4em 0.4em 0 0;
  border: none;
  cursor: pointer;
  text-align: center;
  font-size: 100%;
  color: rgba(30, 23, 23, 1);
}

.allergic01 .tabs button.active {
  background: #fff;
  border-bottom: 4px solid #C8121B;
  font-weight: bold;
}

.allergic01 .tab-content {
  display: none;
}

.allergic01 .tab-content.active {
  display: block;
}

.allergic01 .s02 {
  font-size: 68%;
  opacity: 0.68;
}

@media (max-width:768px) {
  .allergic01 .tabs {
    margin-bottom: 1.7em;
  }

  .allergic01 .tabs button {
    font-size: 116%;
  }
}

/* 20260326追記 */
.sponsor-main {
  background: url(img/sponsor/sponsor-main.jpg);
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  width: 100%;
  height: 574px;
  position: relative
}
.sponsor-main::before {
  content: "";
  background: url(img/sponsor/sponsor-mask.png);
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  width: 100%;
  height: 100%;
  position: absolute;
top: 0;
left: 0;
z-index: 1;
}
.sponsor-main::after {
  content: "";
  background: url(img/sponsor/sponsor-main-eff.png);
  background-position: center;
  background-repeat: no-repeat;
  background-size: 100% 100%;
  width: 100%;
  height: 15.3vw;
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: 2;
}

.sponsor_main_ttl {
  font-size: 5.5rem!important;
  font-family: 'Shippori Antique B1', sans-serif;
  color: #ffffff;
  text-align: center;
  position: absolute;
  top: 48%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 100%;
  z-index: 3;
}

.sponsor_h3_ttl {
  font-family: 'Shippori Antique B1', sans-serif;
  font-size: 3.7rem;
  color: #1C1C1C;
}

.sponsor_catch {
  font-family: 'Shippori Antique B1', sans-serif;
  font-size: 1.8rem;
  color: #1C1C1C;
  line-height: 1.94;
}

.catch_container {
  width: 100%;
  position: relative;

}

.catch_container::after {
  position: absolute;
  content: "";
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 455px;
  height: 451px;
  background: url(img/sponsor/catch_eff.png);
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
}

.sponsor_h3 {
  font-family: 'Shippori Antique B1', sans-serif;
  font-size: 3.3rem;
  color: #1C1C1C;
  line-height: 1;
  margin-bottom: 10px;
}

.h4_en {
  font-family: 'Shippori Antique B1', sans-serif;
  font-size: 1.4rem;
  letter-spacing: 0.04em;
  color: #C8121B;
  line-height: 1;
  margin-bottom: 60px;
}

.sponsor_photo_flex {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 60px;
}
.sponsor_photo_sp{
  display: none;
}

.sponsor_photo_flex .photo_box {
  width: 31.8%;
}

.sponsor_contents_flex {
  display: flex;
  justify-content: space-between;
  margin-bottom: 160px;
}
.activity_container:last-child .sponsor_contents_flex{
  margin-bottom: 50px;
}
.sponsor_contents_flex .box-L {
  width: 29.8%;
}

.sponsor_contents_flex .box-R {
    width: 66%;
}

.sponsor_contents_flex .box-R .sponsor_contents_txt {
  font-family: 'Shippori Antique B1', sans-serif;
  font-size: 1.6rem;
  line-height: 2;
  color: #1C1C1C;
  text-align: left;
  margin-top: -7px;
  margin-bottom: 50px;
}

.activitiy_ttl {
  font-family: 'Shippori Antique B1', sans-serif;
  font-size: 2.1rem;
  line-height: 1.8;
  color: #FFFFFF;
  background: #C8121B;
  width: 136px;
  border-radius: 30px;
  margin-bottom: 30px;
}

.activity_flex {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  margin-bottom: 10px;
  text-align: left;
}

.date {
  font-family: 'Shippori Antique B1', sans-serif;
  font-size: 1.8rem;
  line-height: 1;
  color: #030000;
  letter-spacing: 0.04em;
  margin-right: 20px;
}

.place {
  font-family: 'Shippori Antique B1', sans-serif;
  font-size: 1.6rem;
  line-height: 1;
  color: #030000;
  letter-spacing: 0.04em;
  margin-top: 0 !important;
}

.sponsored {
  font-family: 'Shippori Antique B1', sans-serif;
  font-size: 1.3rem;
  line-height: 1;
  color: #030000;
  text-align: left;
  letter-spacing: 0.04em;
}

.activity_name {
  font-size: 2rem;
  line-height: 1.5;
  color: #030000;
  margin-top: 10px!important;
  text-align: left;
}

.place::before {
  content: "";
  display: inline-block;
  width: 11px;
  height: 15px;
  background: url(img/sponsor/pin.png);
  background-size: 100% 100%;
  background-position: center;
  background-repeat: no-repeat;
  position: relative;
  top: 1px;
  margin-right: 5px;
}

.activity_item {
  position: relative;
  padding-left: 15px;
  margin-bottom: 30px;
}

.activity_item::before {
  content: "";
  width: 3px;
  height: 95%;
  background: #BBBABA;
  position: absolute;
  left: 0;
  top: 50%;
  transform: translate(0,-50%);
}



.activity_btn{
    font-family: 'Shippori Antique B1', sans-serif;
  font-size: 1.9rem;
  line-height: 1;
  font-weight: 400;
  color: #FFFFFF;
  display: block;
  text-align: center;
  width: 290px;
  padding: 20px 0;
margin: 80px auto 0 0;
    background: #C8121B;
}
.activity_btn:hover{
  color: #ffffff;
}
.activity_btn::before {
  content: "";
  display: inline-block;
  width: 0.4em;
  height: 0.4em;
  border-top: solid 2px #ffffff;
  border-right: solid 2px #ffffff;
  transform: rotate(45deg);
  vertical-align: middle;
  margin-right: 2rem;
  margin-top: -4px;
}
.activity_footer{
  background: #FEF6ED;
  text-align: center;
  padding: 110px 0;
}
.activity_footer_container{
  width: 92%;
  max-width:674px;
  display: flex;
  justify-content: space-between;
margin: 45px auto 0;
}
.activity_footer_btn{
    font-family: 'Shippori Antique B1', sans-serif;
  font-size: 2.1rem;
  line-height: 1;
  font-weight: 400;
  color: #FFFFFF;
  display: block;
  text-align: center;
  width: 320px;
  padding: 30px 0;
    background: #C8121B;
}
.activity_footer_btn::before{
  content: "";
  width: 15px;
  height: 15px;
    display: inline-block;
    background: url(img/sponsor/other.png);
    background-size: 100% 100%;
    background-position: center;
    background-repeat: no-repeat;
    margin-right: 20px;
}
.activity_footer_btn:hover{
  color: #ffffff;
}


/* TikTok embed
---------------------------------------------- */
.tiktok-embed {
  width: 100% !important;
  max-width: 340px !important;
  min-width: 0 !important;
  margin: 0 auto !important;
  border-radius: 5px;
}

.tiktok-embed iframe {
  width: 100% !important;
  height: auto !important;
  aspect-ratio: 325 / 850;
  border: none !important;
}




@media (max-width:768px){
  .sponsor-main {
  background: url(img/sponsor/sponsor-main_sp.jpg);
    background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  height: 51.2vw;
}
.sponsor-main::before {
  content: "";
  background: url(img/sponsor/sponsor-mask_sp.png);
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  width: 100%;
  height: 100%;
  position: absolute;
top: 0;
left: 0;
z-index: 1;
}
.sponsor-main::after {
  content: "";
  background: url(img/sponsor/sponsor-main-eff_sp.png);
    background-position: center;
  background-repeat: no-repeat;
  background-size: 100% 100%;
  height: 18.2vw;
  z-index: 2;
}
.sponsor_main_ttl {
  font-size: 3.1rem!important;
  top: 45%;
    z-index: 3;
}
.catch_container.mt160{
  margin-top: 90px!important;
  margin-bottom: 100px!important;
}
.sponsor_h3_ttl {
  font-size: 2.2rem!important;
}

.sponsor_catch {
  font-size: 1.3rem!important;
  line-height: 1.61;
}
.sponsor_catch br{
  display: none;
}

.catch_container::after {
  position: absolute;
  width: 83.8vw;
  height: 83.8vw;
  background: url(img/sponsor/catch_eff.png);
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
}
.sponsor_h3 {
  font-size: 2rem;
  margin-bottom: 5px;
}

.h4_en {
  font-size: 1.2rem;
  text-align: center!important;
  margin-bottom: 35px;
  display: block;
  width: 100%;
}
.sponsor_photo_flex{
  display: none;
}
.sponsor_photo_sp{
  display: block;
  margin-bottom: 30px;
}
.sponsor_contents_flex {
  display: flex;
  justify-content: center;
  flex-direction: column-reverse;
  align-items: center;
  margin-bottom: 70px;
}
.activity_container:last-child .sponsor_contents_flex{
  margin-bottom: 50px;
}
.sponsor_contents_flex .box-L {
  width:100%;
}

.sponsor_contents_flex .box-R {
   width:100%;
}
.sponsor_contents_flex .box-R .sponsor_contents_txt {
  font-family: 'Shippori Antique B1', sans-serif;
  font-size: 1.3rem;
  line-height: 1.61;
  color: #1C1C1C;
  text-align: left;
  margin-top: 0;
  margin-bottom: 40px;
}

.activitiy_ttl {
  font-family: 'Shippori Antique B1', sans-serif;
  font-size:1.7rem;
  line-height: 2;
  color: #FFFFFF;
  background: #C8121B;
  width: 130px;
  border-radius: 30px;
  padding: 2px 0;
  margin: 0 auto 30px;
}

.activity_flex {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: flex-start;
  margin-bottom: 10px;
  text-align: left;
}

.date {
  font-family: 'Shippori Antique B1', sans-serif;
  font-size: 1.4rem;
  line-height: 1;
  color: #030000;
  letter-spacing: 0.04em;
  margin-right: 0;
  margin-bottom: 5px;
}

.place {
  font-family: 'Shippori Antique B1', sans-serif;
  font-size: 1.4rem;
  line-height: 1;
  color: #030000;
  letter-spacing: 0.04em;
  margin-top: 0 !important;
}

.sponsored {
  font-family: 'Shippori Antique B1', sans-serif;
  font-size: 1rem;
  line-height: 1;
  color: #030000;
  text-align: left;
  letter-spacing: 0.04em;
}

.activity_name {
  font-size: 1.6rem;
  line-height: 1.5;
  color: #030000;
  margin-top: 10px!important;
  text-align: left;
}
.place::before {
  content: "";
  display: inline-block;
  width: 11px;
  height: 15px;
  background: url(img/sponsor/pin.png);
  background-size: 100% 100%;
  background-position: center;
  background-repeat: no-repeat;
  position: relative;
  top: 1px;
  margin-right: 5px;
}
.activity_item {
  position: relative;
  padding-left: 20px;
  margin-bottom: 30px;
}
.activity_item:last-child {
  margin-bottom: 60px;
}
.activity_item::before {
  content: "";
  width: 3px;
  height: 95%;
  background: #BBBABA;
  position: absolute;
  left: 0;
  top: 50%;
  transform: translate(0,-50%);
}
.activity_btn{
    font-family: 'Shippori Antique B1', sans-serif;
  font-size: 1.5rem;
  line-height: 1;
  font-weight: 400;
  color: #FFFFFF;
  display: block;
  text-align: center;
  width: 260px;
  padding: 20px 0;
margin: 25px auto 60px;
    background: #C8121B;
}
.activity_btn:hover{
  color: #ffffff;
}
.activity_btn::before {
  content: "";
  display: inline-block;
  width: 0.4em;
  height: 0.4em;
  border-top: solid 2px #ffffff;
  border-right: solid 2px #ffffff;
  transform: rotate(45deg);
  vertical-align: middle;
  margin-right: 2rem;
  margin-top: -4px;
}
.activity_footer{
  background: #FEF6ED;
  text-align: center;
  padding: 70px 0 100px;
}
.activity_footer_container{
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
margin: 55px auto 0;
}
.activity_footer_btn{
    font-family: 'Shippori Antique B1', sans-serif;
  font-size: 1.5rem;
  line-height: 1;
  font-weight: 400;
  color: #FFFFFF;
  display: block;
  text-align: center;
  width: 72.2%;
  padding: 20px 0;
    background: #C8121B;
}
.activity_footer_btn:nth-child(1){
  margin-bottom: 25px;
}
.activity_footer_btn::before{
  content: "";
  width: 15px;
  height: 15px;
    display: inline-block;
    background: url(img/sponsor/other.png);
    background-size: 100% 100%;
    background-position: center;
    background-repeat: no-repeat;
    margin-right: 20px;
}
.activity_footer_btn:hover{
  color: #ffffff;
}

.tiktok-embed {
  width: 100% !important;
  min-width: 0 !important;
  margin: 0 auto !important;
  border-radius: 5px;
  border: none;
}

.tiktok-embed iframe {
  width: 100% !important;
  height: auto !important;
  aspect-ratio: 325 / 850;
  border: none !important;
}
}
