@charset "UTF-8";

@media screen and (max-width: 768px) {
  .section_session {
    margin-top: 45px;
  }
}

.studio {
  margin-top: 64px;
}
@media screen and (max-width: 768px) {
  .studio {
    margin-top: 30px;
  }
}

.section_inner .studio_title {
  font-size: 40px;
  font-weight: bold;
  color: #504c4d;
  margin-left: 0;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .section_inner .studio_title {
    font-size: 28px;
  }
}
.section_inner .studio_block {
  margin-left: 20px;
  margin-top: 4px;
}
@media screen and (max-width: 768px) {
  .section_inner .studio_block {
    margin-left: 0;
    margin-top: 25px;
  }
}
.section_inner .studio_block h2 {
  font-size: 24px;
  font-weight: bold;
  text-align: left;
}
@media screen and (max-width: 768px) {
  .section_inner .studio_block h2 {
    font-size: 20px;
    text-align: center;
  }
}
.section_inner .studio_intro {
  margin-top: 61px;
}
@media screen and (max-width: 768px) {
  .section_inner .studio_intro {
    margin-top: 41px;
  }
}
@media screen and (max-width: 768px) {
  .section_inner .studio_intro .studio_pic {
    margin: 0 auto;
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
  }
}
.section_inner .studio_link {
  min-width: 175px;
  font-size: 16px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  border-radius: 4px;
}
@media screen and (min-width: 769px) {
  .section_inner .studio_site {
    margin-top: 19px;
  }
}
@media screen and (max-width: 768px) {
  .section_inner .studio_site {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
        -ms-flex-pack: center;
            justify-content: center;
    margin-top: 14px;
  }
}
@media screen and (max-width: 768px) {
  .section_inner .studio_site .studio_insta {
    display: inline-block;
  }
  .section_inner .studio_site .studio_insta img {
    width: 48px;
  }
}
@media screen and (min-width: 769px) {
  .section_inner .studio_site > * {
    margin-right: 9px;
  }
}
@media screen and (max-width: 768px) {
  .section_inner .studio_site > * {
    margin-right: 13px;
  }
  .section_inner .studio_site > *:last-child {
    margin-right: 0;
  }
}

.studio p {
  margin-top: 21px;
}

.studio_slide {
  margin-top: 24px;
}

.studio_slide .slick-slide.thumbnail-img {
  margin-right: 15px;
  height: 105px;
}
@media screen and (max-width: 768px) {
  .studio_slide .slick-slide.thumbnail-img {
    margin-right: -1px;
    height: 54px;
    border-radius: 5px;
  }
}
.studio_slide .slick-slide.thumbnail-img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
}
@media screen and (max-width: 768px) {
  .studio_slide .slick-slide.thumbnail-img img {
    border-radius: 5px;
  }
}

@media screen and (max-width: 768px) {
  .studio_thumbnail {
    margin-top: 14px;
  }
}

.access {
  margin-top: 65px;
}
@media screen and (max-width: 768px) {
  .access {
    margin-top: 26px;
  }
}
@media screen and (max-width: 768px) {
  .access_content {
    margin-top: 18px;
  }
}
.access h3 {
  font-size: 32px;
  font-weight: bold;
  text-align: center;
  line-height: 42px;
}
@media screen and (max-width: 768px) {
  .access h3 {
    font-size: 23px;
    line-height: 28px;
  }
}
@media screen and (max-width: 768px) {
  .access .access_map {
    margin-top: 22px;
    height: 78.5vw;
  }
}
.access .butotn-area {
  margin-top: 35px;
}

@media screen and (max-width: 768px) {
  .studiorecommend {
    margin-top: 60px;
    padding-top: 49px !important;
    padding-bottom: 51px !important;
  }
  .studiorecommend h2 {
    font-size: 28px;
  }
  .studiorecommend h2 .studioname {
    font-size: 18px;
  }
  .studiorecommend .recommend-title {
    margin-top: 6px;
  }
}

.studioreport {
  padding: 70px 0 84px !important;
  background-color: #fcefdf;
}
@media screen and (max-width: 768px) {
  .studioreport {
    padding-top: 49px !important;
    padding-bottom: 51px !important;
  }
  .studioreport .studioname {
    font-size: 18px !important;
    line-height: 24px;
  }
}
.studioreport .report-title {
  display: inline-block;
  margin-top: 14px;
}
.studioreport .locationBlock {
  margin-top: 20px;
}
@media screen and (min-width: 769px) {
  .studioreport .locationBlock figure {
    height: 208px;
  }
}
.studioreport .locationBlock figure img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.studioreport .locationBlock ul {
  padding-top: 0;
  border-top: none;
}
.studioreport .locationBlock:after {
  height: calc(100% + 21px);
  bottom: -13px;
  right: -57px;
}
@media screen and (max-width: 768px) {
  .studioreport .locationBlock:after {
    width: 160px;
    bottom: -22px;
    right: -8px;
  }
}

.container {
  padding-bottom: 70px;
}

#location {
  margin-top: 0;
}
#location .section-body {
  -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
  gap: 25px;
  min-height: auto;
}
@media screen and (max-width: 768px) {
  #location .section-body {
    gap: 25px 16px;
  }
}
#location .section-body .locationBlock {
  margin-left: 0;
}
#location .section-body .locationBlock:after {
  display: none;
}
@media screen and (max-width: 768px) {
  #location .section-body .locationBlock a {
    padding: 12px 8px 24px;
  }
  #location .section-body .locationBlock .icon {
    top: -22px;
  }
  #location .section-body .locationBlock figure {
    height: 120px;
    margin: 0;
  }
  #location .section-body .locationBlock figure img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
  }
  #location .section-body .locationBlock .priceBox {
    margin-top: 1px;
  }
  #location .section-body .locationBlock .priceBox .price {
    font-size: 25px;
  }
  #location .section-body .locationBlock .priceBox .num {
    margin-top: 4px;
  }
  #location .section-body .locationBlock .priceBox .num,
  #location .section-body .locationBlock .priceBox small {
    font-size: 12px;
  }
  #location .section-body .locationBlock ul {
    padding-top: 6px;
  }
  #location .section-body .locationBlock ul li {
    line-height: 17px;
  }
  #location .section-body .locationBlock ul li:before {
    font-size: 15px;
    margin-right: 5px;
  }
}
#location .section-body .locationBlock .reception_end {
  position: absolute;
  top: 50%;
  left: 50%;
  display: block;
  width: calc(100% - 36px);
  padding: 20px 0;
  border-radius: 35px;
  background-color: rgba(80, 60, 60, 0.6);
  text-align: center;
  -webkit-transform: translate(-50%, -50%);
      -ms-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  z-index: 20;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}
@media screen and (max-width: 768px) {
  #location .section-body .locationBlock .reception_end {
    border-radius: 17px;
  }
}
#location .section-body .locationBlock .reception_end .text {
  font-size: 24px;
  color: #fff;
  font-weight: 600;
  letter-spacing: 0.04em;
}
@media screen and (max-width: 768px) {
  #location .section-body .locationBlock .reception_end .text {
    font-size: 14px;
    line-height: 22px;
  }
}
#location .section-body .locationBlock:nth-child(n+3) {
  margin-top: 20px;
}

#costume .section-inner {
  padding: 0;
}

@media screen and (max-width: 768px) {
  #costume {
    padding-bottom: 52px;
  }
}

.butotn-area {
  margin-top: 37px;
}
@media screen and (max-width: 768px) {
  .butotn-area {
    margin-top: 26px;
  }
}