@charset "UTF-8";
.pc-only1 {
  display: block;
}
@media (max-width: 820px) {
  .pc-only1 {
    display: none;
  }
}

.sp-only1 {
  display: none;
}
@media (max-width: 820px) {
  .sp-only1 {
    display: block;
  }
}

.pc-only2 {
  display: block;
}
@media (max-width: 520px) {
  .pc-only2 {
    display: none;
  }
}

.sp-only2 {
  display: none;
}
@media (max-width: 576px) {
  .sp-only2 {
    display: block;
  }
}

/* カラー設定
=========================================== */
/* フォント設定
=========================================== */
.noto {
  font-family: "Noto Sans JP";
  font-weight: 400;
}

.home {
  overflow-x: hidden;
  /*-----------------------

  　メインビジュアル

    -------------------------*/
}
.home .mv {
  --frame-size: 25px;
  position: relative;
  overflow: hidden;
  min-height: clamp(800px, 62.5vw, 900px);
  padding: 90px var(--frame-size) 90px;
}
@media screen and (max-width: 1024px) {
  .home .mv {
    min-height: 700px;
  }
}
@media screen and (max-width: 576px) {
  .home .mv {
    --frame-size: 15px;
    padding: 60px 0;
  }
}
.home .mv_inner {
  position: relative;
  z-index: 5;
  width: min(55%, 900px);
  margin-inline: auto;
  text-align: center;
}
@media screen and (max-width: 1024px) {
  .home .mv_inner {
    width: 80%;
  }
}
.home .mv_copy {
  max-width: 722px;
  margin: 0 auto 34px;
}
@media screen and (max-width: 576px) {
  .home .mv_copy {
    margin-bottom: 20px;
  }
}
.home .mv_copy_img {
  display: block;
  margin-inline: auto;
}
.home .mv_image_sp {
  display: none;
}
@media screen and (max-width: 1024px) {
  .home .mv_image_sp {
    display: block;
    margin-right: auto;
    margin-left: auto;
  }
}
.home .mv_info {
  max-width: 966px;
  position: relative;
  margin-top: -60px;
  margin-bottom: 45px;
  text-align: center;
}
@media screen and (max-width: 1024px) {
  .home .mv_info {
    margin-top: 0px;
  }
}
@media screen and (max-width: 576px) {
  .home .mv_info {
    margin-bottom: 25px;
  }
}
.home .mv_info_img {
  display: block;
  width: 100%;
}
.home .mv_info_btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: clamp(0px, 27.3611111111vw, 394px);
  min-height: clamp(0px, 3.6111111111vw, 52px);
  margin: -22px auto 0;
  padding: 12px 54px 12px 30px;
  border-radius: 9999px;
  background: #e42c86;
  color: #fff;
  font-size: clamp(15px, 1.25vw, 18px);
  font-weight: 700;
  text-decoration: none;
  position: relative;
  z-index: 2;
  transition: opacity 0.3s;
  line-height: 1;
  border: 2px solid #e42c86;
  transition:
    background-color 0.3s ease,
    color 0.3s ease,
    border-color 0.3s ease;
}
.home .mv_info_btn:hover {
  background: #fff;
  color: #e42c86;
}
.home .mv_info_btn:hover .mv_btn_arrow {
  border-color: #e42c86;
}
@media screen and (max-width: 1024px) {
  .home .mv_info_btn {
    margin-top: -30px;
    width: 400px;
    min-height: 65px;
    padding: 12px 62px;
    font-size: 20px;
  }
}
@media screen and (max-width: 576px) {
  .home .mv_info_btn {
    width: 200px;
    font-size: 14px;
    padding: 0;
    min-height: 40px;
    margin-top: -20px;
  }
}
.home .mv_zunchaka {
  position: relative;
  margin-inline: auto;
}
.home .mv_zunchaka_img {
  width: clamp(0px, 74.0833333333vw, 889px);
  display: block;
  width: 100%;
}
.home .mv_zunchaka_btn {
  position: absolute;
  top: 50%;
  right: clamp(0px, 0.3125vw, 5px);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: clamp(0px, 8.75vw, 140px);
  min-height: clamp(0px, 2.375vw, 38px);
  padding: clamp(0px, 0.3125vw, 5px) 5px clamp(0px, 0.3125vw, 5px) 14px;
  border-radius: 999px;
  background: #109b6c;
  color: #fff;
  font-size: clamp(0px, 1vw, 16px);
  font-weight: 700;
  text-align: center;
  text-decoration: none;
  line-height: 1.4;
  transform: translateY(-50%);
  border: 2px solid #109b6c;
  transition:
    background-color 0.3s ease,
    color 0.3s ease,
    border-color 0.3s ease;
}
.home .mv_zunchaka_btn:hover {
  background: #fff;
  color: #109b6c;
}
.home .mv_zunchaka_btn:hover .zunchaka_btn_arrow {
  border-color: #109b6c;
}
@media screen and (max-width: 1024px) {
  .home .mv_zunchaka_btn {
    left: 50%;
    transform: translateX(-50%);
    top: auto;
    bottom: -25px;
    width: 400px;
    min-height: 65px;
    padding: 12px 62px;
    font-size: 20px;
  }
  .home .mv_zunchaka_btn br {
    display: none;
  }
}
@media screen and (max-width: 576px) {
  .home .mv_zunchaka_btn {
    width: 200px;
    font-size: 14px;
    padding: 0;
    min-height: 40px;
    margin-top: -70px;
  }
}
.home .mv_zunchaka_btn .zunchaka_btn_arrow {
  width: 7px;
  height: 7px;
  flex-shrink: 0;
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
  transform: rotate(45deg);
}
@media screen and (max-width: 1024px) {
  .home .mv_zunchaka_btn .zunchaka_btn_arrow {
    position: absolute;
    top: 50%;
    right: 24px;
    width: 9px;
    height: 9px;
    flex-shrink: 0;
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
    transform: translateY(-50%) rotate(45deg);
  }
}
.home .mv_zunchaka_btn:hover {
  opacity: 0.8;
}
.home .mv_btn_arrow {
  position: absolute;
  top: 50%;
  right: 24px;
  width: 9px;
  height: 9px;
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
  transform: translateY(-50%) rotate(45deg);
}
.home .mv_photo,
.home .mv_illust {
  position: absolute;
  z-index: 2;
  display: block;
  pointer-events: none;
}
.home .mv_photo {
  border-radius: 50%;
  -o-object-fit: cover;
  object-fit: cover;
}
.home .mv_photo--brandoff {
  top: 88px;
  left: 0;
  aspect-ratio: 1/1;
  width: clamp(0px, 25.0694444444vw, 361px);
}
@media screen and (max-width: 1024px) {
  .home .mv_photo--brandoff {
    display: none;
  }
}
.home .mv_photo--zunchaka {
  top: 48%;
  left: 9%;
  aspect-ratio: 1/1;
  width: clamp(0px, 17.2916666667vw, 249px);
}
@media screen and (max-width: 1024px) {
  .home .mv_photo--zunchaka {
    display: none;
  }
}
.home .mv_photo--komehyo {
  top: 185px;
  right: 0;
  aspect-ratio: 1/1;
  width: clamp(0px, 25.0694444444vw, 361px);
}
@media screen and (max-width: 1024px) {
  .home .mv_photo--komehyo {
    display: none;
  }
}
.home .mv_illust--left {
  width: clamp(0px, 21.3541666667vw, 410px);
  left: 48px;
  bottom: 34px;
}
@media screen and (max-width: 1024px) {
  .home .mv_illust--left {
    display: none;
  }
}
.home .mv_illust--right {
  width: clamp(0px, 21.3541666667vw, 410px);
  right: 48px;
  bottom: 34px;
}
@media screen and (max-width: 1024px) {
  .home .mv_illust--right {
    display: none;
  }
}
.home {
  /*-----------------------

  　黄色い枠線

    -------------------------*/
}
.home .mv_frame {
  position: fixed;
  inset: 0;
  z-index: 20;
  pointer-events: none;
}
.home .mv_frame_line {
  position: absolute;
  overflow: hidden;
  background: #fff20e;
  color: #222;
  font-size: 15px;
  font-weight: 700;
  white-space: nowrap;
}
@media screen and (max-width: 576px) {
  .home .mv_frame_line {
    font-size: 10px;
  }
}
.home .mv_frame_track {
  display: flex;
  align-items: center;
  width: -moz-max-content;
  width: max-content;
  will-change: transform;
}
.home .mv_frame_group {
  display: flex;
  align-items: center;
  flex-shrink: 0;
}
.home .mv_frame_group span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: var(--frame-size);
  padding-inline: 5px;
  line-height: 1.5;
}
.home .mv_frame_line--top {
  top: 0;
  left: 0;
  width: 100%;
  height: var(--frame-size);
  display: flex;
  align-items: center;
}
.home .mv_frame_line--top .mv_frame_track {
  animation: frameMoveRight 50s linear infinite;
  animation-delay: -20s;
}
.home .mv_frame_line--right {
  top: 0;
  right: 0;
  width: var(--frame-size);
  height: 100%;
}
.home .mv_frame_line--right .mv_frame_track {
  position: absolute;
  top: 0;
  left: var(--frame-size);
  transform-origin: left top;
  animation: frameMoveDown 50s linear infinite;
}
.home .mv_frame_line--bottom {
  bottom: 0;
  left: 0;
  width: 100%;
  height: var(--frame-size);
  display: flex;
  align-items: center;
}
.home .mv_frame_line--bottom .mv_frame_track {
  animation: frameMoveLeft 50s linear infinite;
}
.home .mv_frame_line--bottom span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transform: rotate(180deg);
}
.home .mv_frame_line--left {
  top: 0;
  left: 0;
  width: var(--frame-size);
  height: 100%;
}
.home .mv_frame_line--left .mv_frame_track {
  position: absolute;
  top: 100%;
  left: 0;
  transform-origin: left top;
  animation: frameMoveUp 50s linear infinite;
}
.home .mv_frame_line--left span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
@keyframes frameMoveRight {
  from {
    transform: translateX(-50%);
  }
  to {
    transform: translateX(0);
  }
}
@keyframes frameMoveDown {
  from {
    transform: rotate(90deg) translateX(-50%);
  }
  to {
    transform: rotate(90deg) translateX(0);
  }
}
@keyframes frameMoveLeft {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-50%);
  }
}
@keyframes frameMoveUp {
  from {
    transform: rotate(-90deg) translateX(-50%);
  }
  to {
    transform: rotate(-90deg) translateX(0);
  }
}
.home {
  /*-----------------------

  　イントロ

    -------------------------*/
}
.home .zunchaka_intro {
  padding: 120px 0 0;
  background: #fff;
  color: #222;
  text-align: center;
}
@media screen and (max-width: 576px) {
  .home .zunchaka_intro {
    padding-top: 40px;
  }
}
.home .zunchaka_intro_inner {
  width: min(90%, 1080px);
  margin-inline: auto;
}
.home .zunchaka_intro_title {
  margin: 0;
  font-size: 70px;
  font-weight: 700;
  line-height: 1.4;
}
@media screen and (max-width: 820px) {
  .home .zunchaka_intro_title {
    font-size: clamp(0px, 7.3170731707vw, 60px);
  }
}
@media screen and (max-width: 576px) {
  .home .zunchaka_intro_title {
    font-size: 28px;
  }
}
.home .zunchaka_intro_lead {
  margin-top: 60px;
  font-size: 25px;
  font-weight: 700;
  line-height: 1.6;
}
@media screen and (max-width: 820px) {
  .home .zunchaka_intro_lead {
    font-size: clamp(18px, 3.0487804878vw, 25px);
  }
}
@media screen and (max-width: 576px) {
  .home .zunchaka_intro_lead {
    font-size: 16px;
    margin-top: 30px;
  }
}
.home .zunchaka_intro_message {
  margin-top: 70px;
  font-size: clamp(25px, 2.5694444444vw, 37px);
  font-weight: 700;
}
@media screen and (max-width: 820px) {
  .home .zunchaka_intro_message {
    font-size: clamp(18px, 3.0487804878vw, 25px);
  }
}
@media screen and (max-width: 576px) {
  .home .zunchaka_intro_message {
    margin-top: 35px;
    font-size: 16px;
  }
}
.home .zunchaka_intro_message_text {
  display: inline-flex;
  align-items: center;
}
@media screen and (max-width: 576px) {
  .home .zunchaka_intro_message_text {
    width: 30%;
  }
}
.home .zunchaka_intro_message_text img {
  display: block;
  height: auto;
}
.home .zunchaka_intro_slider {
  margin-top: clamp(50px, 6.25vw, 90px);
  overflow: hidden;
}
@media screen and (max-width: 576px) {
  .home .zunchaka_intro_slider {
    margin-top: 35px;
  }
}
.home .zunchaka_intro_slider_row {
  overflow: hidden;
}
.home .zunchaka_intro_slider_row + .home .zunchaka_intro_slider_row {
  margin-top: 8px;
}
.home .zunchaka_intro_slider_track {
  display: flex;
  width: -moz-max-content;
  width: max-content;
  will-change: transform;
}
.home .zunchaka_intro_slider_group {
  display: flex;
  gap: clamp(5px, 1.0416666667vw, 15px);
  flex-shrink: 0;
  padding-right: clamp(5px, 1.0416666667vw, 15px);
}
.home .zunchaka_intro_slider_group img {
  display: block;
  width: auto;
  max-width: none;
  height: clamp(120px, 19.5833333333vw, 282px);
  flex-shrink: 0;
}
.home .zunchaka_intro_slider_row--top .zunchaka_intro_slider_track {
  animation: zunchakaSlideRight 60s linear infinite;
}
.home .zunchaka_intro_slider_row--bottom {
  margin-top: clamp(5px, 1.0416666667vw, 15px);
}
.home .zunchaka_intro_slider_row--bottom .zunchaka_intro_slider_track {
  animation: zunchakaSlideLeft 60s linear infinite;
}
@keyframes zunchakaSlideRight {
  from {
    transform: translateX(-50%);
  }
  to {
    transform: translateX(0);
  }
}
@keyframes zunchakaSlideLeft {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-50%);
  }
}
.home {
  /*-----------------------

  　各店舗体コーナー

    -------------------------*/
}
.home .experience {
  padding: 90px 0 65px;
  overflow: hidden;
}
@media screen and (max-width: 576px) {
  .home .experience {
    padding: 45px 0;
  }
}
.home .experience_inner {
  position: relative;
  width: min(85%, 1150px);
  margin-inline: auto;
  background: #ecf6f3;
  border-radius: 20px 20px 0 0;
}
.home .experience_body {
  padding: 0px clamp(30px, 6.5972222222vw, 95px) 50px;
}
@media screen and (max-width: 576px) {
  .home .experience_body {
    padding: 40px 20px;
  }
}
.home .experience_inner--bottom {
  padding: 10px clamp(30px, 6.5972222222vw, 95px) 50px;
  border-radius: 0;
}
@media screen and (max-width: 576px) {
  .home .experience_inner--bottom {
    padding: 10px 20px 40px;
  }
}
.home .experience_head {
  margin-right: calc(clamp(30px, 6.5972222222vw, 95px) * -1);
  margin-left: calc(clamp(30px, 6.5972222222vw, 95px) * -1);
  width: min(100%, 1150px);
  margin-inline: auto;
  background: #109b6c;
  color: #fff;
  font-size: 30px;
  font-weight: 700;
  text-align: center;
  border-radius: 20px 20px 0 0;
}
@media screen and (max-width: 576px) {
  .home .experience_head {
    font-size: 20px;
  }
}
.home .experience_block {
  position: relative;
  padding-top: 65px;
}
@media screen and (max-width: 576px) {
  .home .experience_block {
    padding-top: 10px;
  }
}
.home .experience_shop_title {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 24px;
  margin: 0 0 28px;
}
@media screen and (max-width: 576px) {
  .home .experience_shop_title {
    gap: 8px;
  }
  .home .experience_shop_title img {
    width: min(58vw, 240px);
    flex-shrink: 0;
  }
}
.home .experience_shop_title::before,
.home .experience_shop_title::after {
  content: "";
  flex: 1;
  width: min(24vw, 312px);
  height: 1px;
  background: #109b6c;
}
@media screen and (max-width: 576px) {
  .home .experience_shop_title::before,
  .home .experience_shop_title::after {
    min-width: 20px;
  }
}
.home .experience_shop_image {
  margin-top: 40px;
  display: flex;
  justify-content: center;
}
@media screen and (max-width: 576px) {
  .home .experience_shop_image {
    margin-top: 10px;
  }
}
.home .experience_komehyo_content,
.home .experience_brandoff_content {
  margin-top: 15px;
  text-align: center;
}
.home .experience_title {
  margin: 0;
  font-size: clamp(20px, 3.125vw, 45px);
  font-weight: 700;
}
@media screen and (max-width: 576px) {
  .home .experience_title {
    font-size: 20px;
    line-height: 1.4;
    margin-bottom: 10px;
  }
}
.home .experience_text {
  font-size: clamp(16px, 1.25vw, 18px);
  font-weight: 400;
  line-height: 1.8;
}
@media screen and (max-width: 576px) {
  .home .experience_text {
    font-size: 14px;
    text-align: left;
  }
}

.home .experience_text span {
  font-weight: 700;
  border-bottom: 1px solid #222;
}

.exhibition_text {
  font-size: 16px;
}
@media screen and (max-width: 576px) {
  .exhibition_text {
    font-size: 13px;
  }
}

.exhibition_image {
  margin-top: 30px;
  width: 70%;
  margin-right: auto;
  margin-left: auto;
}
@media screen and (max-width: 576px) {
  .exhibition_image {
    margin-top: 20px;
    width: 80%;
  }
}

.home .experience_cycle {
  position: absolute;
  z-index: 2;
  width: 180px;
  aspect-ratio: 1/1;
  pointer-events: none;
}
@media screen and (max-width: 576px) {
  .home .experience_cycle {
    width: 90px;
  }
}
.home .experience_cycle_base,
.home .experience_cycle_ring {
  position: absolute;
  top: 50%;
  left: 50%;
  display: block;
  max-width: none;
  height: auto;
}
.home .experience_cycle_base {
  z-index: 1;
  width: 100%;
  transform: translate(-50%, -50%);
}
.home .experience_cycle_ring {
  z-index: 2;
  width: 130%;
  animation: experienceCycleRotate 45s linear infinite;
  transform-origin: center center;
}
.home .experience_cycle--right {
  top: 700px;
  right: -60px;
}
@media screen and (max-width: 576px) {
  .home .experience_cycle--right {
    top: 224px;
    right: -10px;
  }
}
.home .experience_cycle--left {
  top: 2100px;
  left: -45px;
}
@media screen and (max-width: 576px) {
  .home .experience_cycle--left {
    top: 1410px;
    left: -10px;
  }
}
.home .experience_guitar_grid {
  display: grid;
  gap: 18px;
  width: min(90%, 860px);
  margin: 40px auto 0;
}
@media screen and (max-width: 576px) {
  .home .experience_guitar_grid {
    width: 100%;
    margin-top: 30px;
    gap: 25px;
  }
}
.home .experience_guitar_grid--four {
  grid-template-columns: repeat(2, 1fr);
}
@media screen and (max-width: 576px) {
  .home .experience_guitar_grid--four {
    grid-template-columns: 1fr;
  }
}
.home .experience_guitar_grid--two {
  grid-template-columns: repeat(2, 1fr);
}
@media screen and (max-width: 576px) {
  .home .experience_guitar_grid--two {
    grid-template-columns: 1fr;
  }
}
.home .experience_guitar_item {
  margin: 0;
}
.home .experience_guitar_item img {
  display: block;
  width: 100%;
}
.home .experience_note {
  margin: 28px 0 0;
  color: #109b6c;
  font-size: 32px;
  font-weight: 700;
  text-align: center;
}
@media screen and (max-width: 576px) {
  .home .experience_note {
    font-size: 18px;
    line-height: 1.6;
    margin-top: 20px;
    margin-bottom: 25px;
  }
}
.home .experience_note span {
  display: inline;
  padding: 0 0.1em;
  background: linear-gradient(
    transparent 65%,
    rgba(255, 242, 14, 0.7) 65%,
    rgba(255, 242, 14, 0.7) 84%,
    transparent 84%
  );
  box-decoration-break: clone;
  -webkit-box-decoration-break: clone;
}
.home .experience_note--bottom {
  margin-top: 30px;
}
.home .experience_timetable {
  position: relative;
  width: min(90%, 820px);
  margin: 34px auto 0;
}
@media screen and (max-width: 576px) {
  .home .experience_timetable {
    width: 100%;
    margin-top: 20px;
  }
}
.home .experience_timetable_time {
  margin-bottom: 10px;
}
@media screen and (max-width: 576px) {
  .home .experience_timetable_time {
    margin-bottom: 15px;
    width: 30%;
    margin-right: auto;
    margin-left: auto;
    border-bottom: 1px solid #222;
    padding-bottom: 2px;
  }
}
.home .experience_timetable_head {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 28px;
  color: #109b6c;
  font-size: clamp(12px, 1.8055555556vw, 26px);
  font-weight: 700;
}
@media screen and (max-width: 576px) {
  .home .experience_timetable_head {
    font-size: 16px;
    line-height: 1.4;
  }
}
.home .experience_timetable_head::before,
.home .experience_timetable_head::after {
  content: "";
  width: clamp(150px, 11.8055555556vw, 170px);
  height: 0;
  border-top: 1.5px solid #109b6c;
  background: none;
}
@media screen and (max-width: 820px) {
  .home .experience_timetable_head::before,
  .home .experience_timetable_head::after {
    width: 100px;
  }
}
@media screen and (max-width: 576px) {
  .home .experience_timetable_head::before,
  .home .experience_timetable_head::after {
    width: clamp(0px, 18.3333333333vw, 110px);
  }
}
.home .experience_timetable_head::before {
  margin-right: 12px;
}
@media screen and (max-width: 576px) {
  .home .experience_timetable_head::before {
    margin-right: 5px;
  }
}
.home .experience_timetable_head::after {
  margin-left: 12px;
}
@media screen and (max-width: 576px) {
  .home .experience_timetable_head::after {
    margin-left: 5px;
  }
}
.home .experience_timetable_head span {
  position: relative;
  display: inline-block;
}
.home .experience_timetable_head span::before,
.home .experience_timetable_head span::after {
  content: "";
  position: absolute;
  top: 50%;
  width: 10px;
  height: 10px;
  background: #109b6c;
  transform: translateY(-50%) rotate(45deg);
}
.home .experience_timetable_head span::before {
  left: -205px;
}
@media screen and (max-width: 820px) {
  .home .experience_timetable_head span::before {
    left: -80%;
  }
}
.home .experience_timetable_head span::after {
  right: -205px;
}
@media screen and (max-width: 820px) {
  .home .experience_timetable_head span::after {
    right: -80%;
  }
}
.home .experience_timetable_list {
  display: grid;
  gap: 20px;
  width: min(100%, 600px);
  margin-inline: auto;
}
@media screen and (max-width: 576px) {
  .home .experience_timetable_list {
    width: -moz-fit-content;
    width: fit-content;
    max-width: 100%;
    gap: 30px;
    margin-inline: auto;
  }
}
.home .experience_timetable_item {
  display: grid;
  grid-template-columns: 120px 1fr;
  align-items: center;
  -moz-column-gap: 42px;
  column-gap: 42px;
  text-align: left;
}
@media screen and (max-width: 576px) {
  .home .experience_timetable_item {
    grid-template-columns: 1fr;
  }
}
.home .experience_timetable_body {
  display: flex;
  align-items: center;
  gap: 22px;
}
@media screen and (max-width: 576px) {
  .home .experience_timetable_body {
    width: -moz-fit-content;
    width: fit-content;
    max-width: 100%;
    gap: 10px;
    justify-content: flex-start;
    text-align: left;
  }
}
.home .experience_timetable_artist_img {
  margin: 0;
  flex-shrink: 0;
}
.home .experience_timetable_artist {
  min-width: 0;
}
.home .experience_timetable_name {
  margin: 0;
  font-size: 20px;
  font-weight: 700;
  line-height: 1;
}
@media screen and (max-width: 576px) {
  .home .experience_timetable_name {
    font-size: 15px;
  }
}
.home .experience_timetable_detail {
  margin: 8px 0 0;
  font-size: 14px;
  font-weight: 400;
  line-height: 1;
}
@media screen and (max-width: 576px) {
  .home .experience_timetable_detail {
    line-height: 1.3;
    font-size: 12px;
    margin-top: 5px;
  }
}
.home .experience_timetable_bottom {
  display: flex;
  align-items: center;
  gap: 14px;
  width: 96%;
  margin-right: auto;
  margin-left: auto;
  margin-top: 28px;
  height: 1.5px;
}
@media screen and (max-width: 576px) {
  .home .experience_timetable_bottom {
    width: 99%;
  }
}
.home .experience_timetable_bottom::before,
.home .experience_timetable_bottom::after {
  content: "";
  width: 10px;
  height: 10px;
  background: #109b6c;
  transform: rotate(45deg);
  flex-shrink: 0;
}
.home .experience_timetable_bottom span {
  display: block;
  flex: 1;
  height: 0;
  border-top: 1.5px solid #109b6c;
  background: none;
}
.home .experience_shop_slider {
  width: 100%;
  overflow: hidden;
}
.home .experience_shop_slider_track {
  display: flex;
  width: -moz-max-content;
  width: max-content;
  animation: experienceShopSlideRight 50s linear infinite;
  will-change: transform;
}
.home .experience_shop_slider_group {
  display: flex;
  gap: clamp(5px, 1.0416666667vw, 15px);
  flex-shrink: 0;
  padding-right: clamp(5px, 1.0416666667vw, 15px);
}
.home .experience_shop_slider_group img {
  display: block;
  width: auto;
  max-width: none;
  height: clamp(120px, 19.5833333333vw, 282px);
  flex-shrink: 0;
}
.home .experience_btn_wrap {
  margin-top: 34px;
  text-align: center;
}
.home .experience_btn {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: min(100%, 545px);
  min-height: 48px;
  padding: 5px 48px 5px 32px;
  border: 2px solid #109b6c;
  border-radius: 999px;
  color: #109b6c;
  font-size: 20px;
  font-weight: 700;
  text-decoration: none;
  transition:
    background-color 0.3s ease,
    color 0.3s ease,
    border-color 0.3s ease;
}
.home .experience_btn:hover {
  background: #109b6c;
  color: #fff;
}
.home .experience_btn:hover span {
  border-color: #fff;
}
@media screen and (max-width: 576px) {
  .home .experience_btn {
    font-size: 14px;
    min-height: 30px;
  }
}
.home .experience_btn span {
  position: absolute;
  top: 50%;
  right: 24px;
  width: 8px;
  height: 8px;
  border-top: 2px solid #109b6c;
  border-right: 2px solid #109b6c;
  transform: translateY(-50%) rotate(45deg);
}
@keyframes experienceShopSlideRight {
  from {
    transform: translateX(-50%);
  }
  to {
    transform: translateX(0);
  }
}
@keyframes experienceCycleRotate {
  from {
    transform: translate(-50%, -50%) rotate(0deg);
  }
  to {
    transform: translate(-50%, -50%) rotate(360deg);
  }
}
.home {
  /*-----------------------

  　店舗情報

    -------------------------*/
}
.home .shop_info {
  padding: 65px 0;
}
@media screen and (max-width: 576px) {
  .home .shop_info {
    padding-top: 40px;
    padding-bottom: 20px;
  }
}
.home .shop_info_inner {
  width: min(80%, 1150px);
  margin-inline: auto;
  background: #fffafc;
  border-radius: 20px 20px 0 0;
  position: relative;
}
.home .shop_info_cycle {
  position: absolute;
  top: -40px;
  right: -40px;
  z-index: 5;
  width: 180px;
  aspect-ratio: 1/1;
  pointer-events: none;
}
@media screen and (max-width: 576px) {
  .home .shop_info_cycle {
    width: 90px;
    top: -25px;
    right: -15px;
  }
}
.home .shop_info_cycle_base,
.home .shop_info_cycle_ring {
  position: absolute;
  top: 50%;
  left: 50%;
  display: block;
  max-width: none;
  height: auto;
}
.home .shop_info_cycle_base {
  z-index: 1;
  width: 100%;
  transform: translate(-50%, -50%);
}
.home .shop_info_cycle_ring {
  z-index: 2;
  width: 132%;
  transform: translate(-50%, -50%) rotate(0deg);
  transform-origin: 50% 50%;
  animation: shopCycleRotate 45s linear infinite;
  will-change: transform;
}
.home .shop_info_head {
  background: #e42c86;
  color: #fff;
  font-size: 30px;
  font-weight: 700;
  text-align: center;
  border-radius: 20px 20px 0 0;
}
@media screen and (max-width: 576px) {
  .home .shop_info_head {
    font-size: 20px;
  }
}
.home .shop_info_body {
  padding: 70px clamp(30px, 6.5972222222vw, 95px) 90px;
}
@media screen and (max-width: 576px) {
  .home .shop_info_body {
    padding: 50px 30px;
  }
}
.home .shop_info_store {
  display: flex;
  justify-content: space-between;
  align-items: start;
  gap: clamp(0px, 4.1666666667vw, 60px);
}
@media screen and (max-width: 820px) {
  .home .shop_info_store {
    flex-direction: column;
  }
}
@media screen and (max-width: 576px) {
  .home .shop_info_store {
    gap: 30px;
  }
}
.home .shop_info_store--komehyo {
  grid-template-columns: 1fr 430px;
  margin-top: 70px;
}
@media screen and (max-width: 576px) {
  .home .shop_info_store--komehyo {
    margin-top: 50px;
  }
}
.home .shop_info_image {
  margin: 0;
  width: clamp(0px, 29.7222222222vw, 428px);
}
@media screen and (max-width: 820px) {
  .home .shop_info_image {
    order: 2;
    width: 100%;
  }
}
.home .shop_info_image img {
  display: block;
  width: 100%;
}
.home .shop_info_title {
  margin: 0 0 45px;
}
@media screen and (max-width: 576px) {
  .home .shop_info_title {
    margin-bottom: 30px;
  }
}
.home .shop_info_table {
  margin: 0;
}
@media screen and (max-width: 1024px) {
  .home .shop_info_table br {
    display: none;
  }
}
@media screen and (max-width: 820px) {
  .home .shop_info_content {
    order: 1;
    width: 100%;
  }
}
.home .shop_info_row {
  display: grid;
  grid-template-columns: 150px 1fr;
  gap: 26px;
  padding: 17px 0;
  border-bottom: 1px solid #c3c3c3;
}
.home .shop_info_row:first-child {
  padding-top: 0;
}
.home .shop_info_row dt {
  color: #222;
  font-size: clamp(15px, 1.25vw, 18px);
  font-weight: 700;
  line-height: 1.8;
}
@media screen and (max-width: 576px) {
  .home .shop_info_row dt {
    line-height: 1.4;
  }
}
.home .shop_info_row dd {
  margin: 0;
  color: #222;
  font-size: clamp(15px, 1.25vw, 18px);
  font-weight: 400;
  line-height: 1.8;
}
@media screen and (max-width: 576px) {
  .home .shop_info_row dd {
    line-height: 1.4;
  }
}
@media screen and (max-width: 576px) {
  .home .shop_info_row {
    grid-template-columns: 1fr;
    gap: 3px;
    padding: 12px 0;
  }
}
.home .shop_info_row dt {
  color: #222;
  font-size: clamp(15px, 1.25vw, 18px);
  font-weight: 700;
  line-height: 1.8;
}
.home .shop_info_row dd {
  margin: 0;
  color: #222;
  font-size: clamp(15px, 1.25vw, 18px);
  font-weight: 400;
  line-height: 1.8;
}
.home .shop_info_instagram {
  display: inline-flex;
  align-items: center;
}
.home .shop_info_instagram img {
  display: block;
  width: 24px;
  height: auto;
}
.home .shop_info_btn_wrap {
  margin-top: 55px;
  text-align: center;
}
@media screen and (max-width: 576px) {
  .home .shop_info_btn_wrap {
    margin-top: 30px;
  }
}
.home .shop_info_btn {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: min(100%, 545px);
  min-height: 48px;
  padding: 5px 48px 5px 32px;
  border: 2px solid #e42c86;
  border-radius: 999px;
  color: #e42c86;
  font-size: 20px;
  font-weight: 700;
  text-decoration: none;
  transition:
    background-color 0.3s ease,
    color 0.3s ease,
    border-color 0.3s ease;
}
.home .shop_info_btn:hover {
  background: #e42c86;
  color: #fff;
}
.home .shop_info_btn:hover span {
  border-color: #fff;
}
@media screen and (max-width: 576px) {
  .home .shop_info_btn {
    font-size: 14px;
    min-height: 30px;
  }
}
.home .shop_info_btn span {
  position: absolute;
  top: 50%;
  right: 24px;
  width: 8px;
  height: 8px;
  border-top: 2px solid #e42c86;
  border-right: 2px solid #e42c86;
  transform: translateY(-50%) rotate(45deg);
}
.home .shop_info_map {
  width: min(100%, 958px);
  margin: 70px auto 0;
  overflow: hidden;
}
@media screen and (max-width: 576px) {
  .home .shop_info_map {
    margin-top: 35px;
  }
}
.home .shop_info_map iframe {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 958/491;
  border: 0;
}
@media screen and (max-width: 576px) {
  .home .shop_info_map iframe {
    height: 300px;
  }
}
.home .shop_info_map_share {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 34px;
  background: #e42c86;
  color: #fff;
  font-size: 14px;
  font-weight: 700;
  text-decoration: none;
  transition:
    background-color 0.3s ease,
    color 0.3s ease;
}
@media screen and (max-width: 576px) {
  .home .shop_info_map_share {
    min-height: 25px;
    font-size: 13px;
    line-height: 1;
  }
  .home .shop_info_map_share img {
    width: 20px;
  }
}
.home .shop_info_map_share:hover {
  background: #fff;
  color: #e42c86;
  border: 1px solid #e42c86;
}
.home .shop_info_map_share:hover .shop_info_map_icon--white {
  display: none;
}
.home .shop_info_map_share:hover .shop_info_map_icon--pink {
  display: block;
}
.home .shop_info_map_icon {
  width: 24px;
  height: auto;
}
.home .shop_info_map_icon--pink {
  display: none;
}
.home .shop_info_map--komehyo {
  margin-top: 50px;
}
@keyframes shopCycleRotate {
  from {
    transform: translate(-50%, -50%) rotate(0deg);
  }
  to {
    transform: translate(-50%, -50%) rotate(360deg);
  }
}
.home .official_banner {
  padding: 0px 0 40px;
  background: #fff;
}
@media screen and (max-width: 576px) {
  .home .official_banner {
    padding-top: 0;
    padding-bottom: 30px;
    width: 80%;
    margin-right: auto;
    margin-left: auto;
  }
}
.home .official_banner_link {
  display: block;
  width: min(90%, 1150px);
  margin-inline: auto;
  transition: transform 0.3s ease;
}
.home .official_banner_link:hover {
  transform: translateY(-15px);
}
.home {
  /*-----------------------

  　フッター

    -------------------------*/
}
.home .lp_footer {
  padding: 35px 0 30px;
  background: #2b2b2b;
  color: #fff;
}
@media screen and (max-width: 576px) {
  .home .lp_footer {
    padding: 25px 0 20px;
  }
}
.home .lp_footer_inner {
  width: min(80%, 640px);
  margin-inline: auto;
}
.home .lp_footer_license {
  margin: 0;
  font-size: 18px;
  font-weight: 500;
  text-align: center;
}
@media screen and (max-width: 576px) {
  .home .lp_footer_license {
    font-size: 14px;
  }
}
.home .lp_footer_company {
  margin-top: 35px;
  font-size: 16px;
  font-weight: 400;
}
@media screen and (max-width: 576px) {
  .home .lp_footer_company {
    margin-top: 20px;
    font-size: 12px;
  }
}
.home .lp_footer_company p {
  margin: 0;
  line-height: 1.6;
}
.home .lp_footer_company p + p {
  margin-top: 20px;
}
.home .lp_footer_company strong {
  font-weight: 500;
}
.home .lp_footer_copy {
  margin: 45px 0 0;
  font-size: 14px;
  text-align: center;
  font-weight: 400;
}
@media screen and (max-width: 576px) {
  .home .lp_footer_copy {
    margin-top: 20px;
    font-size: 11px;
  }
} /*# sourceMappingURL=top.css.map */
