@charset "UTF-8";
/* 
  css設定 @charsetが消されるsass仕様へのハック用コメントです。削除しないでください。新規作成時も必須！
 */
/*==================================================================================
 default
==================================================================================*/
/* -------------------------------------------
 * initialize
 */
html, body, div, span, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, abbr, address, cite, code, del, dfn, em, img, ins, kbd, q, samp, small, strong, sub, sup, var, b, i, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, dialog, figure, footer, header, hgroup, menu, nav, section, time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  line-height: 1;
  font-size: 0;
  vertical-align: baseline;
  background: transparent;
  background: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAyhpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdpbj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuNi1jMDE0IDc5LjE1Njc5NywgMjAxNC8wOC8yMC0wOTo1MzowMiAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlwdGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvIiB4bWxuczp4bXBNTT0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL21tLyIgeG1sbnM6c3RSZWY9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9zVHlwZS9SZXNvdXJjZVJlZiMiIHhtcDpDcmVhdG9yVG9vbD0iQWRvYmUgUGhvdG9zaG9wIENDIDIwMTQgKE1hY2ludG9zaCkiIHhtcE1NOkluc3RhbmNlSUQ9InhtcC5paWQ6MEI1MzY2NTA1RTY2MTFFNUExRTlDMDdERTNCNDFENkIiIHhtcE1NOkRvY3VtZW50SUQ9InhtcC5kaWQ6MEI1MzY2NTE1RTY2MTFFNUExRTlDMDdERTNCNDFENkIiPiA8eG1wTU06RGVyaXZlZEZyb20gc3RSZWY6aW5zdGFuY2VJRD0ieG1wLmlpZDowQjUzNjY0RTVFNjYxMUU1QTFFOUMwN0RFM0I0MUQ2QiIgc3RSZWY6ZG9jdW1lbnRJRD0ieG1wLmRpZDowQjUzNjY0RjVFNjYxMUU1QTFFOUMwN0RFM0I0MUQ2QiIvPiA8L3JkZjpEZXNjcmlwdGlvbj4gPC9yZGY6UkRGPiA8L3g6eG1wbWV0YT4gPD94cGFja2V0IGVuZD0iciI/Pj3ggHcAAAAQSURBVHjaYvj//z8DQIABAAj8Av7bok0WAAAAAElFTkSuQmCC");
}

body * {
  -webkit-text-size-adjust: none;
  -webkit-font-smoothing: antialiased;
}

article, aside, dialog, figure, footer, header, hgroup, nav, section, main {
  display: block;
}

sup {
  font-size: 10rem;
  vertical-align: super;
}

sub {
  font-size: 10rem;
  vertical-align: sub;
}

div,
figure {
  line-height: 0;
}

ul li, ol li {
  list-style: none;
}

input, select {
  vertical-align: middle;
}

.hide {
  display: none;
}

body {
  font-family: "Noto Sans JP", YuGothic, Yu Gothic, "游ゴシック", sans-serif;
}

img {
  ms-interpolation-mode: bicubic;
}

a {
  text-decoration: none;
}
@media (min-width: 1025px) {
  a:hover {
    opacity: .7;
  }
}

.clearfix {
  zoom: 1;
}
.clearfix:before, .clearfix:after {
  content: "";
  display: table;
}
.clearfix:after {
  clear: both;
}

iframe {
  position: relative;
  top: 0;
  left: 0;
  width: 100%;
}

video {
  width: 100%;
  height: auto;
}

.serif {
  font-family: YuMincho, Yu Mincho, "游明朝", serif;
}

.sansSerif {
  font-family: YuGothic, Yu Gothic, "游ゴシック", sans-serif;
}

.Prompt {
  font-family: "Prompt", YuGothic, Yu Gothic, "游ゴシック", sans-serif;
}

.bold {
  font-weight: bold !important;
  font-size: 100%;
}

.weightNormal {
  font-weight: normal !important;
  font-size: 100%;
}

.colorBlack {
  color: #333 !important;
  font-size: 100%;
}

.colorWhite {
  color: #fff !important;
  font-size: 100%;
}

.colorRed {
  color: #ff0000 !important;
  font-size: 100%;
}

.colorPink01 {
  color: #E4017C !important;
  font-size: 100%;
}

.wrap {
  margin: auto;
  padding: 0 12rem;
  max-width: 1200px;
}
.wrap.smallWrap {
  max-width: 900px;
}

.inlineBlock {
  display: inline-block;
  font-size: 100%;
}

.noBreaks {
  word-break: keep-all;
}

.alignCenter {
  text-align: center;
}

.alignLeft {
  text-align: left;
}

.alignRight {
  text-align: right;
}

@media (min-width: 768px) {
  a.tel {
    pointer-events: none;
  }
}

main img,
header img,
footer img {
  max-width: 100%;
  height: auto;
}

.fontSize50 {
  font-size: 50%;
}

.fontSize55 {
  font-size: 55%;
}

.fontSize60 {
  font-size: 60%;
}

.fontSize65 {
  font-size: 65%;
}

.fontSize70 {
  font-size: 70%;
}

.fontSize75 {
  font-size: 75%;
}

.fontSize80 {
  font-size: 80%;
}

.fontSize85 {
  font-size: 85%;
}

.fontSize90 {
  font-size: 90%;
}

.fontSize95 {
  font-size: 95%;
}

.fontSize100 {
  font-size: 100%;
}

.fontSize105 {
  font-size: 105%;
}

.fontSize110 {
  font-size: 110%;
}

.fontSize115 {
  font-size: 115%;
}

.fontSize120 {
  font-size: 120%;
}

.fontSize125 {
  font-size: 125%;
}

.fontSize130 {
  font-size: 130%;
}

.fontSize135 {
  font-size: 135%;
}

.fontSize140 {
  font-size: 140%;
}

.fontSize145 {
  font-size: 145%;
}

.fontSize150 {
  font-size: 150%;
}

.fontSize155 {
  font-size: 155%;
}

.fontSize160 {
  font-size: 160%;
}

.fontSize165 {
  font-size: 165%;
}

.fontSize170 {
  font-size: 170%;
}

.fontSize175 {
  font-size: 175%;
}

.fontSize180 {
  font-size: 180%;
}

.fontSize185 {
  font-size: 185%;
}

.fontSize190 {
  font-size: 190%;
}

.fontSize195 {
  font-size: 195%;
}

.fontSize200 {
  font-size: 200%;
}

.fontSize205 {
  font-size: 205%;
}

.fontSize210 {
  font-size: 210%;
}

.fontSize215 {
  font-size: 215%;
}

.fontSize220 {
  font-size: 220%;
}

.fontSize225 {
  font-size: 225%;
}

.fontSize230 {
  font-size: 230%;
}

.fontSize235 {
  font-size: 235%;
}

.fontSize240 {
  font-size: 240%;
}

.fontSize245 {
  font-size: 245%;
}

.fontSize250 {
  font-size: 250%;
}

.fontSize255 {
  font-size: 255%;
}

.fontSize260 {
  font-size: 260%;
}

.fontSize265 {
  font-size: 265%;
}

.fontSize270 {
  font-size: 270%;
}

.fontSize275 {
  font-size: 275%;
}

.fontSize280 {
  font-size: 280%;
}

.fontSize285 {
  font-size: 285%;
}

.fontSize290 {
  font-size: 290%;
}

.fontSize295 {
  font-size: 295%;
}

.fontSize300 {
  font-size: 300%;
}

@media (min-width: 768px) {
  .sp {
    display: none !important;
  }
}
@media (max-width: 767px) {
  sup,
  sub {
    font-size: 8rem;
  }

  .pc {
    display: none !important;
  }
}
/*==================================================================================
 common
==================================================================================*/
html {
  font-size: 1px;
  font-feature-settings: "palt";
}
@media (max-width: 1224px) {
  html {
    font-size: .0816993vw;
  }
}

main {
  padding-bottom: 150rem;
}
main li,
main .image,
main figure {
  position: relative;
}
main .caption {
  display: inline-block;
  line-height: 1;
  font-size: 12rem;
  color: #fff;
}
main img + .caption {
  position: absolute;
  bottom: 1.2%;
  right: .8%;
}
main img + .caption.outside {
  display: block;
  position: static;
}

.commonCatch01 {
  line-height: 1.5;
  font-size: 32rem;
}

.commonCatch02 {
  line-height: 1.4;
  font-size: 34rem;
}

.commonCatch03 {
  line-height: 1.4;
  font-size: 20rem;
}

.commonCatch04 {
  line-height: 1.7;
  font-size: 24rem;
}

.commonLead01 {
  line-height: 2;
  font-size: 16rem;
}

.commonLead02 {
  line-height: 1.9;
  font-size: 14rem;
}

.commonLead03 {
  line-height: 2.1;
  font-size: 18rem;
}

.commonAnnotation01 {
  line-height: 1.3;
  font-size: 10rem;
}

.commonButton01 a {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0 14rem;
  box-sizing: border-box;
  width: 240rem;
  height: 50rem;
  border-radius: 25rem;
  letter-spacing: .1em;
  line-height: 1.3;
  font-size: 14rem;
  border: 1px solid #E4017C;
  color: #fff;
  background: #E4017C;
}
.commonButton01 a:after {
  content: '';
  display: block;
  width: 17rem;
  height: 15rem;
  background: url("../img/common/icon-arrow01.svg") no-repeat center center;
  background-size: 100% 100%;
  filter: grayscale(1) brightness(10);
}
.commonButton01.color02 a {
  color: #E4017C;
  background: #fff;
}
.commonButton01.color02 a:after {
  filter: none;
}
.commonButton01.center {
  display: flex;
  justify-content: center;
}
.commonButton01.pattern02 a {
  gap: 0 24rem;
  width: 416rem;
  height: 80rem;
  border-radius: 40rem;
  font-size: 18rem;
}
.commonButton01.pattern02 a:after {
  width: 30rem;
  height: 16rem;
  background-image: url("../img/common/icon-arrow02.svg");
}

.commonButton02 a {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0 14rem;
  box-sizing: border-box;
  width: 200rem;
  height: 65rem;
  border-radius: 16rem;
  letter-spacing: .1em;
  line-height: 1.3;
  font-size: 14rem;
  border: 1px solid #fff;
  color: #fff;
  background: #231815;
}
.commonButton02 a:after {
  content: '';
  display: block;
  width: 17rem;
  height: 15rem;
  background: url("../img/common/icon-arrow01.svg") no-repeat center center;
  background-size: 100% 100%;
  filter: grayscale(1) brightness(10);
}
.commonButton02.wide a {
  width: 320rem;
}
.commonButton02.color02 a {
  color: #fff;
  background: #E4017C;
}
.commonButton02.color03 a {
  border-color: #E4017C;
  color: #E4017C;
  background: #fff;
}
.commonButton02.color03 a:after {
  filter: none;
}
.commonButton02.center {
  display: flex;
  justify-content: center;
}
.commonButton02.noIcon a:after {
  display: none;
}
.commonButton02.reverse a {
  flex-direction: row-reverse;
}
.commonButton02.reverse a:after {
  transform: rotate(180deg);
}

.commonButtons01 {
  display: flex;
  justify-content: center;
  gap: 0 16rem;
  padding-top: 40rem;
}
.commonButtons01.pattern02 {
  gap: 0 2%;
  margin: auto;
  padding-top: 0;
  width: calc(100% - 12rem);
}
.commonButtons01.pattern02 li {
  flex: 0 0 49%;
}
.commonButtons01 li {
  flex: 0 0 228rem;
}
.commonButtons01 li a {
  width: 100%;
}

.commonAnchorLinks01 {
  display: flex;
  justify-content: center;
  gap: 0 45rem;
  margin-bottom: 50rem;
  font-weight: bold;
  border-bottom: 1px solid #D9D9D9;
}
.commonAnchorLinks01 li {
  margin-bottom: -1px;
}
.commonAnchorLinks01 li a {
  display: block;
  padding-bottom: 24rem;
  border-bottom: 1px solid #D9D9D9;
  font-size: 14rem;
  color: #7F7F7F;
}
.commonAnchorLinks01 li a:hover {
  opacity: 1;
}
@media (min-width: 1025px) {
  .commonAnchorLinks01 li a:hover {
    color: #E4017C;
    border-bottom-color: #E4017C;
  }
}
.commonAnchorLinks01 li.current a {
  pointer-events: none;
  color: #E4017C;
  border-bottom-color: #E4017C;
}

.commonTitle01 {
  display: inline-flex;
  flex-direction: column;
  gap: 10rem 0;
  position: relative;
  margin-bottom: 60rem;
  padding: 8rem 20rem 0 40rem;
}
.commonTitle01:before {
  content: '';
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 34rem;
  height: 17rem;
  background: url("../img/common/icon-arrow02.svg") no-repeat center center;
  background-size: 100% 100%;
}
.commonTitle01.left {
  display: flex;
  text-align: left;
}
.commonTitle01.pattern02 {
  display: flex;
  align-items: flex-start;
  margin-bottom: 40rem;
  padding-top: 0;
  font-size: 40rem;
  font-weight: bold;
}
.commonTitle01 .en {
  line-height: .75;
  font-size: 64rem;
  font-weight: 500;
}
.commonTitle01 .en.twoLines {
  margin: -6rem 0 -10rem;
  line-height: 1;
}
.commonTitle01 .ja {
  font-size: 13rem;
  align-self: flex-start;
}

.commonTitle02 {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0 8rem;
  margin-bottom: 40rem;
  font-size: 20rem;
  font-weight: 500;
  color: #E4017C;
}
.commonTitle02:before {
  content: '';
  display: block;
  width: 34rem;
  height: 17rem;
  background: url("../img/common/icon-arrow02.svg") no-repeat center center;
  background-size: 100% 100%;
}
.commonTitle02.noIcon:before {
  display: none;
}

.commonSlider01 {
  overflow: hidden;
  position: relative;
  z-index: 1;
}
.commonSlider01 .slick-slide {
  float: left !important;
  clear: none !important;
  padding-top: 0 !important;
}
.commonSlider01 .slick-dots {
  display: flex;
  justify-content: center;
  gap: 0 16rem;
  position: absolute;
  right: 0;
  bottom: 15rem;
  left: 0;
  line-height: 0;
  z-index: 1000;
}
.commonSlider01 .slick-dots li {
  display: block;
  margin: 0;
  width: 12rem;
  height: 12rem;
}
.commonSlider01 .slick-dots li button {
  cursor: pointer;
  padding: 0;
  width: 100%;
  height: 100%;
  border: none;
  border-radius: 50%;
  font-size: 0;
  background: #fff;
}
.commonSlider01 .slick-dots li button:before {
  display: none;
}
.commonSlider01 .slick-dots li.slick-active button {
  background: #E4017C;
}

.commonSlideArea01 {
  position: relative;
  padding: 0 180rem;
}
.commonSlideArea01 .commonSlideController01 li {
  cursor: pointer;
  box-sizing: border-box;
  position: absolute;
  top: calc(50% - 58rem);
  width: 90rem;
  height: 66rem;
  border: 1px solid #E4017C;
  border-radius: 33rem;
  background: url("../img/common/icon-arrow02.svg") no-repeat center center;
  background-size: 34rem 17rem;
}
@media (min-width: 1025px) {
  .commonSlideArea01 .commonSlideController01 li:hover {
    opacity: .7;
  }
}
.commonSlideArea01 .commonSlideController01 li.next {
  right: 0;
}
.commonSlideArea01 .commonSlideController01 li.prev {
  left: 0;
  transform: rotate(180deg);
}
.commonSlideArea01 .commonSlideController01.color02 li {
  background-color: #fff;
}
.commonSlideArea01 .commonSlideController02 li {
  cursor: pointer;
  box-sizing: border-box;
  position: absolute;
  bottom: -12rem;
  width: 42rem;
  height: 36rem;
  background: url("../img/common/icon-arrow01.svg") no-repeat center center;
  background-size: 100% 100%;
  z-index: 999;
}
@media (min-width: 1025px) {
  .commonSlideArea01 .commonSlideController02 li:hover {
    opacity: .7;
  }
}
.commonSlideArea01 .commonSlideController02 li.next {
  left: calc(50% - -200rem);
}
.commonSlideArea01 .commonSlideController02 li.prev {
  left: calc(50% - 242rem);
  transform: rotate(180deg);
}
.commonSlideArea01.thumbnailPattern {
  box-sizing: border-box;
  margin: auto;
  max-width: 1000px;
}
.commonSlideArea01.thumbnailPattern .slider {
  padding-bottom: 25rem;
}
.commonSlideArea01.thumbnailPattern .commonSlideController01 li {
  top: calc(50% - 110rem);
}
.commonSlideArea01.thumbnailPattern .thumbnails .slick-track {
  display: flex;
  flex-wrap: wrap;
  gap: 20rem 2%;
  margin: 0 -45rem;
  width: auto !important;
  transform: none !important;
}
.commonSlideArea01.thumbnailPattern .thumbnails .slick-track .slick-slide {
  cursor: pointer;
  flex: 0 0 15%;
}
.commonSlideArea01.thumbnailPattern .thumbnails .slick-track .slick-slide.slick-current {
  opacity: .5;
}
.commonSlideArea01.pattern02 {
  padding: 0;
}

.commonSlider02 {
  overflow: hidden;
  position: relative;
  padding-bottom: 45rem;
  z-index: 1;
}
.commonSlider02 .slick-slide {
  float: left !important;
  clear: none !important;
  padding-top: 0 !important;
}
.commonSlider02 .slick-dots {
  display: flex;
  justify-content: center;
  gap: 0 16rem;
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  line-height: 0;
  z-index: 1000;
}
.commonSlider02 .slick-dots li {
  display: block;
  margin: 0;
  width: 12rem;
  height: 12rem;
}
.commonSlider02 .slick-dots li button {
  cursor: pointer;
  padding: 0;
  width: 100%;
  height: 100%;
  border: none;
  border-radius: 50%;
  font-size: 0;
  background: #D9D9D9;
}
.commonSlider02 .slick-dots li button:before {
  display: none;
}
.commonSlider02 .slick-dots li.slick-active button {
  background: #E4017C;
}
.commonSlider02 .slideItems {
  display: flex;
  justify-content: space-between;
  gap: 0 50rem;
}
.commonSlider02 .slideItems .image {
  flex: 0 0 374rem;
}
.commonSlider02 .slideItems .textArea .text01 {
  display: flex;
  align-items: center;
  gap: 0 18rem;
  padding-bottom: 30rem;
}
.commonSlider02 .slideItems .textArea .text01 .name {
  display: flex;
  gap: 0 3rem;
  font-size: 13rem;
}
.commonSlider02 .slideItems .textArea .text01 .name:before {
  content: '';
  display: block;
  width: 21rem;
  height: 10rem;
  background: url("../img/common/icon-arrow02.svg") no-repeat center center;
  background-size: 100% 100%;
}
.commonSlider02 .slideItems .textArea .text01 .name .nameText01,
.commonSlider02 .slideItems .textArea .text01 .name .nameText02 {
  font-size: 100%;
}
.commonSlider02 .slideItems .textArea .text01 .name .initial {
  line-height: .75;
  font-weight: bold;
}
.commonSlider02 .slideItems .textArea .text01 .name .nameText02 {
  align-self: flex-end;
}
.commonSlider02 .slideItems .textArea .text01 .result {
  display: flex;
  justify-content: center;
  align-items: center;
  box-sizing: border-box;
  padding: 0 20rem;
  width: 250rem;
  height: 52rem;
  border-radius: 26rem;
  font-size: 16rem;
  color: #fff;
  background: #E4017C;
}
.commonSlider02 .slideItems .textArea .text01 .result .number {
  position: relative;
  top: -2rem;
}

.commonSlider03 {
  overflow: hidden;
  position: relative;
  padding-bottom: 50rem;
  z-index: 1;
}
.commonSlider03 .slick-slide {
  float: left !important;
  clear: none !important;
  padding-top: 0 !important;
}
@media (min-width: 768px) {
  .commonSlider03 .slick-slide {
    transition: transform .3s;
    transform: scale(0.8);
  }
}
@media (min-width: 768px) {
  .commonSlider03 .slick-current {
    transform: scale(1);
  }
}
.commonSlider03 .slick-dots {
  display: flex;
  justify-content: center;
  gap: 0 16rem;
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  line-height: 0;
  z-index: 1000;
}
.commonSlider03 .slick-dots li {
  display: block;
  margin: 0;
  width: 12rem;
  height: 12rem;
}
.commonSlider03 .slick-dots li button {
  cursor: pointer;
  padding: 0;
  width: 100%;
  height: 100%;
  border: none;
  border-radius: 50%;
  font-size: 0;
  background: #D9D9D9;
}
.commonSlider03 .slick-dots li button:before {
  display: none;
}
.commonSlider03 .slick-dots li.slick-active button {
  background: #E4017C;
}

.commonSearchArea01 {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0 50rem;
  padding-bottom: 60rem;
}
.commonSearchArea01 .searchs .searchText {
  display: flex;
  align-items: center;
  gap: 0 4rem;
  padding-bottom: 8rem;
  color: #E4017C;
  font-weight: bold;
  font-size: 18rem;
}
.commonSearchArea01 .searchs .searchText img {
  width: 24rem;
}
.commonSearchArea01 + .allDisplayButton {
  cursor: pointer;
  position: relative;
  margin: -30rem auto 60rem;
  letter-spacing: 1rem;
  text-align: center;
  line-height: 1;
  font-size: 16rem;
  text-decoration: underline;
  color: #E4017C;
  z-index: 1;
}
@media (min-width: 1025px) {
  .commonSearchArea01 + .allDisplayButton:hover {
    text-decoration: none;
  }
}

.commonTabs01 {
  display: flex;
  gap: 0 13rem;
  padding: 8rem;
  border-radius: 32rem;
  background: #F5F5F5;
}
.commonTabs01 li {
  display: flex;
  justify-content: center;
  align-items: center;
  cursor: pointer;
  padding: 0 16rem;
  height: 48rem;
  border-radius: 32rem;
  font-size: 14rem;
  font-weight: bold;
}
@media (min-width: 1025px) {
  .commonTabs01 li:hover {
    color: #fff;
    background: #E4017C;
  }
}
.commonTabs01 li.current {
  pointer-events: none;
  color: #fff;
  background: #E4017C;
}

.commonTabs02 {
  display: flex;
  justify-content: center;
  gap: 0 45rem;
  margin: auto;
  margin-bottom: 80rem;
  padding-bottom: 24rem;
  max-width: 900px;
  border-bottom: 1px solid #D9D9D9;
}
.commonTabs02 li a {
  display: block;
  font-size: 14rem;
  font-weight: bold;
  color: #7F7F7F;
}
.commonTabs02 li a:hover {
  opacity: 1;
}
@media (min-width: 1025px) {
  .commonTabs02 li a:hover {
    color: #E4017C;
  }
}
.commonTabs02 li.current {
  color: #E4017C;
}

.commonItems01 {
  display: flex;
  flex-wrap: wrap;
  gap: 32rem 32rem;
}
.commonItems01 li {
  flex: 0 0 276rem;
}
.commonItems01 li a {
  box-sizing: border-box;
  display: block;
  position: relative;
  padding: 16rem 8rem 24rem;
  color: #fff;
  background: #F5F5F5;
}
.commonItems01 li .categorys {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0 4rem;
  position: absolute;
  top: 6rem;
  left: 4rem;
  z-index: 2;
}
.commonItems01 li .categorys .category {
  padding: 8rem;
  border-radius: 16rem;
  border: 1px solid #fff;
  letter-spacing: .1em;
  font-size: 13rem;
  background: #231815;
}
.commonItems01 li .categorys .category.color02 {
  background: #E4017C;
}
.commonItems01 li .thumbnail {
  margin-bottom: 16rem;
  height: 190rem;
  border-radius: 4rem;
  overflow: hidden;
}
.commonItems01 li .thumbnail img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.commonItems01 li .name {
  line-height: 1.4;
  letter-spacing: .05em;
  font-size: 20rem;
  font-weight: bold;
  color: #231815;
}

.commonItems02 {
  display: flex;
  flex-wrap: wrap;
  gap: 20rem 27rem;
}
.commonItems02 > li {
  flex: 0 0 382rem;
  box-sizing: border-box;
  padding: 16rem 8rem;
  color: #fff;
  background: #F5F5F5;
}
.commonItems02 > li .thumbnail {
  margin-bottom: 8rem;
  height: 240rem;
  border-radius: 4rem;
  overflow: hidden;
}
.commonItems02 > li .thumbnail img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.commonItems02 > li .categorys {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0 4rem;
  padding-bottom: 14rem;
}
.commonItems02 > li .categorys .category {
  padding: 8rem;
  border-radius: 16rem;
  border: 1px solid #fff;
  letter-spacing: .1em;
  font-size: 13rem;
  background: #231815;
}
.commonItems02 > li .categorys .category.color02 {
  background: #E4017C;
}
.commonItems02 > li .name {
  padding-bottom: 14rem;
  line-height: 1.4;
  letter-spacing: .05em;
  font-size: 20rem;
  font-weight: bold;
  color: #231815;
}
.commonItems02 > li .informations {
  padding: 13rem 16rem 14rem;
  border-radius: 4rem;
  background: #fff;
}
.commonItems02 > li .informations + .informations {
  margin-top: 4rem;
}
.commonItems02 > li .informations:last-of-type {
  margin-bottom: 16rem;
}
.commonItems02 > li .informations dt {
  display: flex;
  gap: 0 4rem;
  padding-bottom: 5rem;
  letter-spacing: .1em;
  line-height: 1.3;
  font-size: 14rem;
}
.commonItems02 > li .informations dt:before {
  content: '';
  display: block;
  position: relative;
  top: 3rem;
  width: 17rem;
  height: 15rem;
  background: url(../img/common/icon-arrow01.svg) no-repeat center center;
  background-size: 100% 100%;
}
.commonItems02 > li .informations dd {
  text-align: left;
  line-height: 1.4;
  font-size: 14rem;
  color: #231815;
}
.commonItems02.color02 li {
  background: #fff;
}
.commonItems02.color02 li .informations {
  background: #F5F5F5;
}

.commonInformationList01 {
  display: flex;
  flex-direction: column;
  gap: 40rem 0;
  margin: auto;
  width: 90%;
  max-width: 900px;
}
.commonInformationList01 li {
  padding-bottom: 30rem;
  border-bottom: 1px solid #D9D9D9;
  text-align: left;
}
.commonInformationList01 li a {
  display: block;
  color: #231815;
}
.commonInformationList01 li a:hover {
  opacity: 1;
}
@media (min-width: 1025px) {
  .commonInformationList01 li a:hover {
    text-decoration: underline;
  }
}
.commonInformationList01 li span {
  display: block;
}
.commonInformationList01 li .date {
  display: flex;
  align-items: center;
  gap: 0 5rem;
  padding-bottom: 12rem;
  font-size: 16rem;
}
.commonInformationList01 li .date:before {
  content: '';
  display: block;
  width: 13rem;
  height: 13rem;
  background: url(../img/common/icon-calendar.svg) no-repeat center center;
  background-size: 100% 100%;
}
.commonInformationList01 li .content {
  line-height: 1.5;
  font-size: 18rem;
  font-weight: bold;
}

.commonInformationList02 {
  display: flex;
  flex-direction: column;
  gap: 40rem 0;
  margin: auto;
  max-width: 900px;
  text-align: left;
}
.commonInformationList02 li {
  padding-bottom: 40rem;
  border-bottom: 1px solid #D9D9D9;
  text-align: left;
}
.commonInformationList02 li a {
  display: flex;
  gap: 0 60rem;
  color: #231815;
}
.commonInformationList02 li a:hover {
  opacity: 1;
}
@media (min-width: 1025px) {
  .commonInformationList02 li a:hover {
    text-decoration: underline;
  }
}
.commonInformationList02 li .date {
  flex: 0 0 130rem;
  padding-top: 7rem;
  font-size: 16rem;
}
.commonInformationList02 li .content {
  flex: 1 1 auto;
  line-height: 1.5;
  font-size: 18rem;
  font-weight: bold;
}

.commonFaqList01 {
  text-align: left;
  letter-spacing: 1.5rem;
}
.commonFaqList01 + .commonFaqList01 {
  padding-top: 80rem;
}
.commonFaqList01 dt,
.commonFaqList01 dd {
  position: relative;
}
.commonFaqList01 dt:before,
.commonFaqList01 dd:before {
  content: 'Q';
  position: absolute;
  top: 0;
  left: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 32rem;
  height: 32rem;
  border-radius: 50%;
  font-size: 20rem;
  font-family: "Prompt", YuGothic, Yu Gothic, "游ゴシック", sans-serif;
  color: #fff;
  background: #E4017C;
}
.commonFaqList01 dt {
  cursor: pointer;
  padding: 4rem 40rem 22rem;
  border-bottom: 1px solid #E4017C;
  line-height: 1.4;
  font-size: 16rem;
}
.commonFaqList01 dt:after {
  content: '';
  position: absolute;
  top: 0;
  right: 0;
  width: 32rem;
  height: 32rem;
  background: url("../img/common/icon-plus01.svg") no-repeat center center;
  background-size: 100% 100%;
}
.commonFaqList01 dt.open:after {
  background-image: url("../img/common/icon-close01.svg");
}
.commonFaqList01 dd {
  display: none;
  margin-top: 20rem;
  padding-left: 40rem;
  line-height: 2.1;
  font-size: 14rem;
}
.commonFaqList01 dd:before {
  content: 'A';
  background: #231815;
}
.commonFaqList01 dd .annotation {
  font-size: 10rem;
}
.commonFaqList01 dd a {
  display: inline-block;
  text-decoration: underline;
  color: #E4017C;
}
.commonFaqList01 dd a:hover {
  opacity: 1;
}
@media (min-width: 1025px) {
  .commonFaqList01 dd a:hover {
    text-decoration: none;
  }
}
.commonFaqList01 dd span.space {
  font-size: 100%;
}

.commonTableList01 dl {
  display: flex;
  align-items: flex-start;
  gap: 0 20rem;
  padding: 24rem 0;
  border-bottom: 1px solid #FFDEF0;
}
.commonTableList01 dt {
  flex: 0 0 300rem;
  display: flex;
  align-items: center;
  gap: 0 8rem;
  font-weight: 500;
  letter-spacing: 1.5rem;
}
.commonTableList01 dt:before {
  content: '';
  display: block;
  width: 34rem;
  height: 17rem;
  background: url("../img/common/icon-arrow02.svg") no-repeat center center;
  background-size: 100% 100%;
}
.commonTableList01 dd {
  flex: 1 1 auto;
}
.commonTableList01 dd span.space {
  font-size: 100%;
}
.commonTableList01 + .button {
  padding-top: 100rem;
}

.commonPlanDetail01 {
  box-sizing: border-box;
  margin: auto;
  padding: 30rem 15rem;
  width: 620rem;
  border: 2px solid #E4017C;
  border-radius: 20rem;
  text-align: center;
}
.commonPlanDetail01 .planName {
  padding-bottom: 15rem;
  font-size: 20rem;
}
.commonPlanDetail01 .planPrice {
  padding-bottom: 25rem;
  font-size: 20rem;
}
.commonPlanDetail01 .planPoints {
  display: inline-flex;
  flex-direction: column;
  gap: 20rem 0;
}
.commonPlanDetail01 .planPoints li {
  position: relative;
  padding-left: 19rem;
  text-align: left;
  letter-spacing: 1.5rem;
  font-size: 18rem;
}
.commonPlanDetail01 .planPoints li:after {
  content: '';
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 15rem;
  height: 13rem;
  background: url(../img/common/icon-arrow01.svg) no-repeat center center;
  background-size: 100% 100%;
}
.commonPlanDetail01 .planPoints li .annotation {
  display: block;
  padding-top: 5rem;
  line-height: 1.3;
}

.commonDefinitions01 {
  display: flex;
  flex-direction: column;
  gap: 50rem 0;
}
.commonDefinitions01 dl {
  position: relative;
  padding-left: 42rem;
}
.commonDefinitions01 dl:after {
  content: '';
  display: block;
  position: absolute;
  top: 5rem;
  left: 0;
  width: 34rem;
  height: 17rem;
  background: url(../img/common/icon-arrow02.svg) no-repeat center center;
  background-size: 100% 100%;
}
.commonDefinitions01 dt {
  padding-bottom: 5rem;
  letter-spacing: 1.5rem;
  line-height: 1.4;
  font-size: 24rem;
  font-weight: 500;
  color: #E4017C;
}
.commonDefinitions01 dd + dd:not(.topNoSpace) {
  padding-top: 1.3em;
}
.commonDefinitions01 dd.leftSpace01 {
  padding-left: 1.5em;
}
.commonDefinitions01 dd.leftSpace02 {
  padding-left: 3em;
}
.commonDefinitions01 dd a {
  text-decoration: underline;
  color: #231815;
}
.commonDefinitions01 dd a:hover {
  opacity: 1;
}
@media (min-width: 1025px) {
  .commonDefinitions01 dd a:hover {
    text-decoration: none;
  }
}

.commonPagination01 {
  padding-top: 60rem;
  text-align: center;
  font-weight: bold;
}
.commonPagination01 ul {
  display: flex;
  justify-content: center;
  gap: 0 10rem;
}
.commonPagination01 li span,
.commonPagination01 li a {
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  width: 40rem;
  height: 40rem;
  border-radius: 5rem;
  color: #E4017C;
  font-size: 18rem;
  line-height: 1;
}
.commonPagination01 li span:hover,
.commonPagination01 li a:hover {
  opacity: 1;
}
@media (min-width: 1025px) {
  .commonPagination01 li span:hover,
  .commonPagination01 li a:hover {
    color: #fff;
    background: #E4017C;
  }
}
.commonPagination01 li.current span,
.commonPagination01 li.current a {
  pointer-events: none;
  color: #fff;
  background: #E4017C;
}
.commonPagination01 li.previous a:after, .commonPagination01 li.next a:after {
  content: '';
  display: block;
  width: 13rem;
  height: 13rem;
  background: url("../img/common/icon-arrow04.svg") no-repeat center center;
  background-size: 100% 100%;
}
.commonPagination01 li.previous a:hover:after, .commonPagination01 li.next a:hover:after {
  background-image: url("../img/common/icon-arrow03.svg");
}
.commonPagination01 li.previous.previous a:after, .commonPagination01 li.next.previous a:after {
  transform: rotate(180deg);
}
.commonPagination01 li.first, .commonPagination01 li.last {
  display: none;
}

.sections {
  text-align: center;
}
.sections:not(:last-of-type) {
  padding-bottom: 160rem;
}

@media (max-width: 1024px) {
  .printBtn {
    display: none !important;
  }
}
/*==================================================================================
 siteHeader
==================================================================================*/
.siteHeader {
  display: flex;
  justify-content: space-between;
  align-items: center;
  box-sizing: border-box;
  position: fixed;
  top: 0;
  right: 0;
  left: 0;
  padding: 0 24rem;
  height: 90rem;
  text-align: center;
  z-index: 100;
  transition: background .3s;
}
.siteHeader.bgWhite {
  background: #fff;
}
.siteHeader .headerLogo {
  position: relative;
  width: 277rem;
  line-height: 0;
  z-index: 2;
}
.siteHeader .headerLogo a:hover {
  opacity: 1;
}
.siteHeader .headerLogo img {
  width: 100%;
}
.siteHeader .menuButton {
  cursor: pointer;
  position: relative;
  width: 34rem;
  z-index: 2;
}
@media (min-width: 1025px) {
  .siteHeader .menuButton:hover {
    opacity: .7;
  }
}
.siteHeader .menuButton .lines {
  display: block;
  position: absolute;
  right: 0;
  left: 0;
  border-radius: 2rem;
  height: 4rem;
  background: #E4017C;
}
.siteHeader .menuButton .lines.line01 {
  top: 0;
}
.siteHeader .menuButton .lines.line02 {
  top: 9rem;
}
.siteHeader .menuButton .lines.line03 {
  top: 18rem;
}
.siteHeader .menuButton.open .lines {
  background: #fff;
}
.siteHeader .menuButton.open .lines.line01 {
  top: 9rem;
  transform: rotate(45deg);
}
.siteHeader .menuButton.open .lines.line02 {
  display: none;
}
.siteHeader .menuButton.open .lines.line03 {
  top: 9rem;
  transform: rotate(-45deg);
}
.siteHeader .menuButton.open .text {
  color: #fff;
}
.siteHeader .menuButton .text {
  display: block;
  line-height: 1;
  padding-top: 26rem;
  color: #E4017C;
  font-size: 12rem;
}
.siteHeader .globalNavi {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  display: none;
  gap: 40rem 0;
  box-sizing: border-box;
  position: absolute;
  top: 0;
  right: 0;
  padding: 0 15rem;
  width: 50vw;
  height: 100vh;
  height: 100dvh;
  background: rgba(35, 24, 21, 0.8);
  backdrop-filter: blur(5px);
  overflow: auto;
}
.siteHeader .globalNavi .links {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 24rem 0;
  width: 480rem;
}
.siteHeader .globalNavi .links li {
  flex: 0 0 224rem;
}
.siteHeader .globalNavi .links li a {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 5rem 0;
  position: relative;
  padding-right: 20rem;
  height: 76rem;
  border-bottom: 1px solid #fff;
  text-align: center;
  font-size: 10rem;
  color: #fff;
}
.siteHeader .globalNavi .links li a:after {
  content: '';
  display: block;
  position: absolute;
  top: 0;
  bottom: 0;
  right: 40rem;
  width: 17rem;
  background: url("../img/common/icon-arrow01.svg") no-repeat center center;
  background-size: 100% auto;
  filter: grayscale(1) brightness(10);
}
.siteHeader .globalNavi .links li a .en {
  display: block;
  font-size: 14rem;
}
.siteHeader .globalNavi .links li.current a {
  border-bottom-color: #E4017C;
  color: #E4017C;
}
.siteHeader .globalNavi .links li.current a:after {
  filter: none;
}
.siteHeader .globalNavi .otherLinks {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 24rem 0;
  width: 480rem;
  text-align: center;
}
.siteHeader .globalNavi .otherLinks li {
  flex: 0 0 224rem;
}
.siteHeader .globalNavi .otherLinks li a {
  display: inline-block;
  text-decoration: underline;
  font-size: 13rem;
  color: #fff;
}

/*==================================================================================
 siteFooter
==================================================================================*/
.siteFooter {
  padding: 40rem 0;
  color: #fff;
  background: #231815;
}
.siteFooter a {
  color: #fff;
  font-size: 100%;
}
.siteFooter ul,
.siteFooter li,
.siteFooter small {
  font-size: 100%;
}
.siteFooter .areas {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 14rem;
}
.siteFooter .area01 {
  position: relative;
  margin-bottom: 16rem;
  padding-bottom: 81rem;
}
.siteFooter .area01:after {
  content: '';
  display: block;
  position: absolute;
  right: 12rem;
  left: 12rem;
  bottom: 0;
  height: 1px;
  background: #fff;
}
.siteFooter .area01 .logo {
  width: 356rem;
}
.siteFooter .area01 .logo img {
  width: 100%;
}
.siteFooter .area01 .naviArea {
  flex: 0 0 790rem;
  font-size: 100%;
}
.siteFooter .area01 .naviArea .footerNavi {
  padding-bottom: 24rem;
  font-size: 100%;
}
.siteFooter .area01 .naviArea .footerNavi > ul {
  display: flex;
  justify-content: space-between;
}
.siteFooter .area01 .naviArea .instagram a {
  display: flex;
  align-items: center;
  gap: 0 15rem;
}
.siteFooter .area01 .naviArea .instagram a .text {
  font-size: 16rem;
  font-weight: 500;
}
.siteFooter .area01 .naviArea .instagram a img {
  width: 28rem;
}
.siteFooter .area02 a,
.siteFooter .area02 .copyright {
  color: #7F7F7F;
}
.siteFooter .area02 .otherLinks {
  display: flex;
  gap: 0 24rem;
}
.siteFooter .fixingReserveBanner {
  position: fixed;
  right: 15rem;
  bottom: 15rem;
  width: 168rem;
  z-index: 99;
}

/*==================================================================================
 print
==================================================================================*/
@media print {
  .siteHeader,
  .siteFooter {
    display: none !important;
  }
}
/*==================================================================================
 top
==================================================================================*/
#top .mainVisual {
  position: relative;
  margin-bottom: 75rem;
}
#top .mainVisual h2 {
  line-height: 0;
  font-size: 0;
  text-indent: -10000;
  opacity: 0;
}
#top .mainVisual .searchButtons {
  display: none;
}
#top .mainVisual .campaignBanner {
  box-sizing: border-box;
  padding-top: 70rem;
  max-width: 600px;
  width: 90%;
}
#top section.service h2 {
  margin-bottom: 80rem;
}
#top section.service .services {
  display: flex;
  justify-content: space-between;
}
#top section.service .services li {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 60rem 0;
  flex: 0 0 584rem;
  box-sizing: border-box;
  padding-top: 40rem;
  height: 580rem;
  color: #fff;
  background: url("../img/top/service-img01.png") no-repeat center center;
  background-size: 100% 100%;
}
#top section.service .services li:last-child {
  margin-top: 100rem;
  background-image: url("../img/top/service-img02.png");
}
#top section.about {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  padding-right: 70rem;
  text-align: left;
}
#top section.about .textArea h2 {
  margin-bottom: 55rem;
}
#top section.about .textArea .catch {
  padding-bottom: 30rem;
}
#top section.about .textArea .lead {
  padding-bottom: 40rem;
}
#top section.about .textArea .button a {
  width: 245rem;
}
#top section.about > .image {
  flex: 0 0 560rem;
}
#top section.voice > header {
  padding-bottom: 40rem;
}
#top section.voice > header h2 {
  margin-bottom: 30rem;
}
#top section.gym h2 .en {
  padding-bottom: 10rem;
}
#top section.gym .button,
#top section.information .button {
  padding-top: 50rem;
}
#top section.gym .button a,
#top section.information .button a {
  width: 245rem;
}

/*==================================================================================
 lower common
==================================================================================*/
.lower main {
  padding-top: 145rem;
  text-align: center;
  overflow: hidden;
}
.lower main > h1 {
  margin-bottom: 100rem;
}
.lower main article.contents {
  text-align: left;
}
.lower main article.contents > header {
  padding-bottom: 50rem;
}
.lower main article.contents .address {
  padding-top: 50rem;
}
.lower .commonNewsArticle01 {
  text-align: left;
}
.lower .commonNewsArticle01 > header {
  display: flex;
  flex-direction: column;
  gap: 12rem 0;
  padding-bottom: 30rem;
}
.lower .commonNewsArticle01 > header h2 {
  line-height: 1.5;
  font-size: 16rem;
}
.lower .commonNewsArticle01 > header .date {
  order: -1;
  font-size: 13rem;
}
.lower .commonNewsArticle01 .contentsArea {
  margin-bottom: 60rem;
  padding-bottom: 40rem;
  border-bottom: 1px solid #F5F5F5;
}
.lower .commonNewsArticle01 .contentsArea > p {
  line-height: 2;
  font-size: 14rem;
}
.lower .commonNewsArticle01 .contentsArea > p + p,
.lower .commonNewsArticle01 .contentsArea > p + div {
  padding-top: 2em;
}
.lower .commonNewsArticle01 .contentsArea .wp-caption-text {
  padding-top: 10rem;
  line-height: 1.4;
  font-size: 12rem;
}
.lower .commonNewsArticle01 .contentsArea.imageRight .image {
  float: right;
  padding: 0 0 10rem 15rem;
  max-width: 350px;
}
.lower .commonNewsArticle01 .contentsArea.imageLeft .image {
  float: left;
  padding: 0 15rem 10rem 0;
  max-width: 350px;
}

/*==================================================================================
 about
==================================================================================*/
#about header.intro {
  padding-bottom: 100rem;
}
#about header.intro h1 {
  margin-bottom: 30rem;
}
#about header.intro .catch {
  padding-bottom: 30rem;
}
#about header.intro .lead {
  padding-bottom: 50rem;
}
#about header.intro .points {
  display: flex;
  justify-content: space-between;
  margin: auto;
  max-width: 1130px;
}
#about header.intro .points li {
  flex: 0 0 23.5%;
}
#about section.commitment {
  position: relative;
  margin-bottom: 130rem;
  padding: 90rem 12rem;
  z-index: 1;
}
#about section.commitment:after {
  content: '';
  display: block;
  position: absolute;
  top: 0;
  bottom: 0;
  left: calc(50% - 75vw);
  width: 150vw;
  background: #F7F7F7;
  z-index: -1;
}
#about section.commitment > header {
  padding-bottom: 70rem;
}
#about section.commitment h2 {
  margin-bottom: 30rem;
}
#about section.commitment .points {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 90rem 0;
}
#about section.commitment .points li {
  flex: 0 0 540rem;
}
#about section.commitment .points li .image {
  padding-bottom: 18rem;
}
#about section.commitment .points li dt {
  padding-bottom: 15rem;
  line-height: 1.4;
  font-size: 22rem;
}
#about section.service .services {
  display: flex;
  justify-content: space-between;
}
#about section.service .services li {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 60rem 0;
  flex: 0 0 584rem;
  box-sizing: border-box;
  padding-top: 40rem;
  height: 580rem;
  color: #fff;
  background: url("../img/top/service-img01.png") no-repeat center center;
  background-size: 100% 100%;
}
#about section.service .services li:last-child {
  background-image: url("../img/top/service-img02.png");
}
#about section.price > .catch {
  padding: 50rem 0;
}

/*==================================================================================
 gym
==================================================================================*/
#gym .resultArea .sections:nth-of-type(2n) {
  position: relative;
  padding: 80rem 12rem;
  z-index: 1;
}
#gym .resultArea .sections:nth-of-type(2n):not(:last-of-type) {
  margin-bottom: 100rem;
}
#gym .resultArea .sections:nth-of-type(2n):after {
  content: '';
  display: block;
  position: absolute;
  top: 0;
  bottom: 0;
  left: calc(50% - 75vw);
  width: 150vw;
  background: #F7F7F7;
  z-index: -1;
}
#gym .resultArea.osaka .sections {
  padding: 0;
  background: none;
}
#gym .resultArea.osaka .sections:after {
  display: none;
}
#gym .resultArea.osaka .sections:not(.osaka) {
  display: none;
}
#gym .resultArea.saitama .sections {
  padding: 0;
  background: none;
}
#gym .resultArea.saitama .sections:after {
  display: none;
}
#gym .resultArea.saitama .sections:not(.saitama) {
  display: none;
}
#gym .resultArea.tokyo .sections {
  padding: 0;
  background: none;
}
#gym .resultArea.tokyo .sections:after {
  display: none;
}
#gym .resultArea.tokyo .sections:not(.tokyo) {
  display: none;
}
#gym .resultArea.kanagawa .sections {
  padding: 0;
  background: none;
}
#gym .resultArea.kanagawa .sections:after {
  display: none;
}
#gym .resultArea.kanagawa .sections:not(.kanagawa) {
  display: none;
}
#gym .resultArea.machine .sections {
  padding: 0;
  background: none;
}
#gym .resultArea.machine .sections:after {
  display: none;
}
#gym .resultArea.machine .sections:not(.machine) {
  display: none;
}
#gym .resultArea.kickboxing .sections {
  padding: 0;
  background: none;
}
#gym .resultArea.kickboxing .sections:after {
  display: none;
}
#gym .resultArea.kickboxing .sections:not(.kickboxing) {
  display: none;
}
#gym .resultArea.area .sections.machine, #gym .resultArea.area .sections.kickboxing {
  display: none;
}
#gym .resultArea.category .sections.osaka, #gym .resultArea.category .sections.kyoto, #gym .resultArea.category .sections.tokyo, #gym .resultArea.category .sections.kanagawa {
  display: none;
}

/*==================================================================================
 gym detail
==================================================================================*/
#gym.detail header.intro {
  padding-bottom: 100rem;
}
#gym.detail header.intro h1 {
  margin-bottom: 16rem;
}
#gym.detail header.intro .categorys {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0 4rem;
  padding-bottom: 100rem;
}
#gym.detail header.intro .categorys .category {
  padding: 8rem;
  border-radius: 16rem;
  border: 1px solid #fff;
  letter-spacing: .1em;
  font-size: 13rem;
  color: #fff;
  background: #231815;
}
#gym.detail header.intro .categorys .category.color02 {
  background: #E4017C;
}
#gym.detail header.intro section.about h2 {
  padding-bottom: 30rem;
}
#gym.detail header.intro section.about .lead + .lead {
  padding-top: 1.5em;
}
#gym.detail header.intro section.about .points {
  display: flex;
  justify-content: space-between;
  gap: 0 40rem;
  padding-top: 70rem;
}
#gym.detail header.intro section.about .points li {
  flex: 1 1 auto;
}
#gym.detail .sections .informations {
  text-align: left;
}
#gym.detail .sections .informations dt,
#gym.detail .sections .informations dd {
  line-height: 1.4;
  font-size: 14rem;
}
#gym.detail .sections .informations dt {
  display: flex;
  align-items: center;
  gap: 0 4rem;
  font-weight: bold;
  color: #E4017C;
  letter-spacing: 1.5rem;
}
#gym.detail .sections .informations dt:before {
  content: '';
  display: block;
  width: 17rem;
  height: 15rem;
  background: url("../img/common/icon-arrow01.svg") no-repeat center center;
  background-size: 100% 100%;
}
#gym.detail section.schedule .scheduleImage img {
  width: 100%;
}
#gym.detail section.access {
  position: relative;
  margin-bottom: 100rem;
  padding: 100rem 0;
  z-index: 1;
}
#gym.detail section.access:after {
  content: '';
  display: block;
  position: absolute;
  top: 0;
  bottom: 0;
  left: calc(50% - 75vw);
  width: 150vw;
  background: #F5F5F5;
  z-index: -1;
}
#gym.detail section.access > header {
  padding-bottom: 40rem;
}
#gym.detail section.access .informationsArea {
  text-align: center;
}
#gym.detail section.access .informationsArea .informations {
  display: inline-flex;
  flex-direction: column;
  gap: 25rem 0;
}
#gym.detail section.access .informationsArea .informations dl {
  display: flex;
  gap: 0 20rem;
}
#gym.detail section.access .informationsArea .informations dl dt {
  flex: 0 0 90rem;
}
#gym.detail section.access .informationsArea .informations dl dd {
  flex: 0 0  auto;
}
#gym.detail section.access .googleMap {
  height: 600rem;
}
#gym.detail section.access .googleMap iframe {
  width: 100%;
  height: 100%;
}
#gym.detail section.introduction {
  padding-bottom: 100rem;
}
#gym.detail section.trainer {
  position: relative;
  margin-bottom: 100rem;
  padding: 120rem 0;
  color: #fff;
  z-index: 1;
}
#gym.detail section.trainer:after {
  content: '';
  display: block;
  position: absolute;
  top: 0;
  bottom: 0;
  left: calc(50% - 75vw);
  width: 150vw;
  background: #231815;
  z-index: -1;
}
#gym.detail section.trainer section.trainers {
  margin: auto;
  max-width: 850px;
}
#gym.detail section.trainer section.trainers:not(:last-of-type) {
  padding-bottom: 90rem;
}
#gym.detail section.trainer section.trainers > header {
  position: relative;
  margin-bottom: 40rem;
  padding-left: 280rem;
  min-height: 240rem;
}
#gym.detail section.trainer section.trainers > header h3 {
  display: flex;
  margin-bottom: 40rem;
  text-align: left;
}
#gym.detail section.trainer section.trainers > header h3 span {
  font-weight: bold;
}
#gym.detail section.trainer section.trainers > header h3 .en {
  font-size: 40rem;
}
#gym.detail section.trainer section.trainers > header .information01 {
  display: flex;
  flex-wrap: wrap;
  gap: 30rem 40rem;
  padding-left: 40rem;
  max-width: 500rem;
}
#gym.detail section.trainer section.trainers > header .information01 dl {
  flex: 0 0 340rem;
}
#gym.detail section.trainer section.trainers > header .information01 dl:first-of-type, #gym.detail section.trainer section.trainers > header .information01 dl:nth-of-type(3) {
  flex: 0 0 120rem;
}
#gym.detail section.trainer section.trainers > header .photo {
  position: absolute;
  top: 0;
  left: 0;
  width: 240rem;
  height: 240rem;
}
#gym.detail section.trainer section.trainers > header .photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
#gym.detail section.trainer section.trainers .information02 {
  display: flex;
  flex-direction: column;
  gap: 50rem 0;
  padding: 0 24rem;
}
#gym.detail section.trainer section.trainers .information02 dl {
  display: flex;
  align-items: center;
  gap: 0 24rem;
}
#gym.detail section.trainer section.trainers .information02 dt {
  flex: 0 0 130rem;
}
#gym.detail section.trainer section.trainers .information02 dd {
  line-height: 1.7;
}
#gym.detail section.price .catch {
  padding: 25rem 0;
}

/*==================================================================================
 machine, kickboxing
==================================================================================*/
#machine header.intro, #kickboxing header.intro {
  padding-bottom: 100rem;
}
#machine header.intro .lead, #kickboxing header.intro .lead {
  padding-bottom: 50rem;
}
#machine header.intro .points, #kickboxing header.intro .points {
  display: flex;
  justify-content: space-between;
  margin: auto;
  padding-bottom: 100rem;
  max-width: 1130px;
}
#machine header.intro .points li, #kickboxing header.intro .points li {
  flex: 0 0 23.5%;
}
#machine header.intro .manga, #kickboxing header.intro .manga {
  display: flex;
  justify-content: space-between;
  box-sizing: border-box;
  margin: auto;
  padding: 50rem 60rem;
  width: 90%;
  max-width: 780px;
  background: #F7F7F7;
}
#machine header.intro .manga img, #kickboxing header.intro .manga img {
  width: 49%;
}
#machine section.scene, #kickboxing section.scene {
  position: relative;
  margin-bottom: 130rem;
  padding: 120rem 12rem;
  color: #fff;
  z-index: 1;
}
#machine section.scene:after, #kickboxing section.scene:after {
  content: '';
  display: block;
  position: absolute;
  top: 0;
  bottom: 0;
  left: calc(50% - 75vw);
  width: 150vw;
  background: #231815;
  z-index: -1;
}
#machine section.scene .slideArea01, #kickboxing section.scene .slideArea01 {
  margin-bottom: 30rem;
}
#machine section.menu > header, #kickboxing section.menu > header {
  padding-bottom: 80rem;
}
#machine section.menu .menus, #kickboxing section.menu .menus {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 60rem 78rem;
}
#machine section.menu .menus li, #kickboxing section.menu .menus li {
  flex: 0 0 348rem;
  text-align: left;
}
#machine section.menu .menus li .image, #kickboxing section.menu .menus li .image {
  padding-bottom: 15rem;
}
#machine section.menu .menus li dt, #kickboxing section.menu .menus li dt {
  padding-bottom: 15rem;
  text-align: center;
  font-size: 18rem;
  font-weight: bold;
  color: #E4017C;
}
#machine section.menu .menus li dd, #kickboxing section.menu .menus li dd {
  line-height: 1.7;
}
#machine section.price > .catch, #kickboxing section.price > .catch {
  padding: 50rem 0;
}

/*==================================================================================
 kickboxing
==================================================================================*/
/*==================================================================================
 about
==================================================================================*/
/*==================================================================================
 price
==================================================================================*/
#price header.intro .attentions {
  box-sizing: border-box;
  margin: 0 auto 90rem;
  padding: 40rem 20rem;
  width: 720rem;
  background: #F5F5F5;
}
#price header.intro .attentions dt {
  padding-bottom: 10rem;
}
#price header.intro .attentions dd {
  line-height: 2.1;
}
#price header.intro .anchorLinks {
  margin-bottom: 0 !important;
}
#price section.allGym .prices {
  display: flex;
  justify-content: space-between;
  padding-bottom: 15rem;
}
#price section.allGym .prices li {
  flex: 0 0 30%;
}
#price article.options {
  margin: 160rem 0 -145rem;
  margin-top: 0 !important;
  padding: 100rem 0 145rem;
  background: #F9F9F9;
}
#price article.options h2 {
  padding-bottom: 100rem;
}
#price article.options h3 {
  margin-bottom: 40rem;
}
#price article.options .image {
  margin-bottom: 15rem;
}
#price section.kickboxing .image,
#price section.kickboxing .annotation {
  margin-right: auto;
  margin-left: auto;
  max-width: 760px;
}

/*==================================================================================
 faq
==================================================================================*/
/*==================================================================================
 recruit
==================================================================================*/
/*==================================================================================
 terms
==================================================================================*/
/*==================================================================================
 privacy
==================================================================================*/
/*==================================================================================
 law
==================================================================================*/
/*==================================================================================
 error
==================================================================================*/
#error .contents {
  padding-top: 50rem;
}
#error .contents .catch {
  padding-bottom: 40rem;
}

/*==================================================================================
 howToJoin
==================================================================================*/
#howToJoin .steps {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 40rem 40rem;
  padding-top: 60rem;
  padding-bottom: 100rem;
}
#howToJoin .steps li {
  flex: 0 0 373rem;
}

/*==================================================================================
 page
==================================================================================*/

/*# sourceMappingURL=style.css.map */
