@charset "utf-8";
@import url(http://fonts.googleapis.com/earlyaccess/notosansjapanese.css);

html,body{
    overflow-x: hidden;
}

/*======================================================================*/
/*Module
/*======================================================================*/
.clearfix:after {
    content: " ";
    display: table;
    clear: both
}

.inner {
    width: 100%;
    max-width: 1000px;
    margin: 0 auto;
    padding: 0 20px;
    overflow: hidden;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}

.inner-wide {
    width: 100%;
    max-width: 1400px;
    padding: 0 20px;
    margin: 0 auto;
    overflow: hidden;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}

img {
    width: 100%;
    height: auto;
    display: block;
}

.sp {
    display: none;
}

.ocher {
    color: #b57f18;
}

.Noto-Sans-CJK-JP {
    font-family: "Noto Sans", "Noto Sans CJK JP", sans-serif;
}

.Source-Sans-Pro {
    font-family: 'Source Sans Pro', sans-serif;
}

.serif {
    font-family: Georgia, 游明朝, "Yu Mincho", YuMincho, "Hiragino Mincho ProN", HGS明朝E, メイリオ, Meiryo, serif;
}

/*------------------------------------------*/
/*js
/*------------------------------------------*/
.fade-in {
    opacity: 0;
    -webkit-transition: .8s;
    transition: .8s;
    transform: translate(0, 0);
    -webkit-transform: translate(0, 0);
}

.slide-left {
    opacity: 0;
    -webkit-transition: .8s;
    transition: .8s;
    transform: translate(-200px, 0);
    -webkit-transform: translate(-200px, 0);
}

.slide-right {
    opacity: 0;
    -webkit-transition: .8s;
    transition: .8s;
    transform: translate(200px, 0);
    -webkit-transform: translate(200px, 0);
}

.slide-up {
    opacity: 1.0;
    -webkit-transition: .8s;
    transition: .8s;
    transform: translate(0, 200px);
    -webkit-transform: translate(0, 200px);
}

.slide-in {
    opacity: 1.0;
    -webkit-transition: .8s;
    transition: .8s;
    transform: translate(0, 0);
    -webkit-transform: translate(0, 0);
}

/*======================================================================*/
/*index.html
/*======================================================================*/
/*------------------------------------------*/
/*contents-common
/*------------------------------------------*/
.contents {
    width: 100%;
}

section {
    width: 100%;
    padding: 5vw 0 0;
    overflow: hidden;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}

section:first-child {
    padding-top: 0;
}

section:last-child {
    margin-bottom: 10vw;
}

.sub_ttl {
    color: #000;
    text-align: center;
    font-size: 6rem;
    font-weight: bold;
    padding: 50px 0;
    margin-bottom: 40px;
}

.annotation {
    margin: 0 auto;
    padding: 12px 45px;
    background-color: #fff;
    font-size: 14px;
    letter-spacing: -0.015rem;
    margin: 35px 0 10px;
}

.right {
    float: right;
}

.left {
    float: left;
}

.right::after {
    content: '';
    clear: both;
}

/*------------------------------------------*/
/*header
/*------------------------------------------*/
header {
    width: 100%;
}

.l_header_name-inner {
    width: 90%;
    max-width: 1200px;
    padding: 15px 0;
}

.l_header_name {
    z-index: 10;
    text-align: left;
}

.l_header_logo {
    display: inline-block;
    vertical-align: middle;
    padding: 0 20px 0 0;
    margin: 5px auto 5px 0;
    max-width: 400px;
}

.l_header_name h2 {
    display: block;
    color: #c21732;
    font-size: 2.8rem;
    line-height: 1;
}

/*------------------------------------------*/
/*kv(hotstudio)
/*------------------------------------------*/
/*.kv_bg {
    height: 800px;
    position: relative;
    background: url(../img/01_firstview/hotstudio/main_visual_1600.jpg) no-repeat top center;
    background-size: cover;
}

.kv_bg_shopname {
    width: 800px;
    position: absolute;
    bottom: 0;
    left: 50;
    right: 20px;
}

@media screen and (max-width: 1200px) {
    .kv_bg {
        background: url(../img/01_firstview/hotstudio/main_visual_pc.jpg) no-repeat;
        background-position: center 5%;
        background-size: cover;
    }

    .kv_bg_shopname {
        width: 600px;
        position: absolute;
        bottom: 0;
        left: 50;
        right: 20px;
    }

}

@media screen and (max-width: 800px) {
    .kv_bg {
        background: url(../img/01_firstview/hotstudio/main_visual_sp.jpg) no-repeat;
        background-position: center 5%;
        background-size: cover;
    }

}

@media screen and (max-width: 640px) {
    .kv_bg {
        background: url(../img/01_firstview/hotstudio/main-visual_640.jpg) no-repeat center;
        background-size: cover;
    }

    .kv_bg_shopname {
        width: calc(600 / 640 * 100vw);
        position: absolute;
        bottom: 50%;
        left: 50;
        right: 10px;
    }
}*/
.kv_bg {
    background: url(../img/01_firstview/main_visual_pc_2410.jpg) no-repeat center 5%;
    background-size: cover;
    /*padding-top: 200px;*/
    height: 600px;
    position: relative;

}

.kv-logo{
    position: absolute;
    bottom: 40px;
    left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    max-width: 740px;
    width: 90%;
}

/*.kv-logo h1 {
    width: 600px;
    max-width: 70%;
    margin: 200px auto 50px;
}*/
/*.kv-logo h2 {
    width: 80%;
    max-width: 980px;
    margin: -5vw 0 150px;
}*/
@media screen and (min-width:520px) and ( max-width:960px) {
    .kv_bg {
        background: url(../img/01_firstview/main_visual_sp_2410.jpg) no-repeat top center;
        background-size: cover;
    }

    .kv-logo h1 {
        width: 100%;
        max-width: 560px;
        margin: 24vw auto 2vw;
    }
}

/*------------------------------------------*/
/*cvbtn
/*------------------------------------------*/
.cvbtn_wrap {
    position: relative;
    overflow: hidden;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    display: block;
    width: 100%;
    max-width: 680px;
    height: 130px;
    margin: 50px auto;
    padding: 10px;
    border-radius: 5px;
    text-align: center;
}

.cvbtn {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    width: 100%;
    height: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    font-size: 4rem;
    font-weight: bold;
    text-decoration: none;
    color: #fff;
    border-radius: 6px;
    background: #c21732;
}

.cvbtn:hover {
    background: rgba(194, 23, 50, 0.7);
    -webkit-transition: 0.5s;
    transition: 0.5s;
}

.cvbtn_arrow {
    padding: 0 50px 0 0;
    background: url(../img/02_cpn/arrow_right.svg) no-repeat right center;
    background-size: 20px;
}

/*------------------------------------------*/
/*cvtel
/*------------------------------------------*/
.cvtel_area {
    width: 100%;
}

.cvtel_area p {
    font-size: 28px;
    font-weight: bold;
    color: #000;
    text-align: center;
}

.cvtel {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    width: 100%;
    height: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    font-size: 34px;
    font-weight: bold;
    text-decoration: none;
    color: #c21732;
}

.cvtel_icon {
    padding-left: 40px;
    max-height: 34px;
    background: url(../img/02_cpn/tel_icon.svg) no-repeat left center;
}

a[href^="tel:"] {
    pointer-events: none;
}

a[href^="tel:"] {
    text-decoration: none;
}

.tel-area > a {
    max-width: 400px;
    width: 100%;
    margin: 0 auto;
    display: block;
    text-align: center;
    text-decoration: none;
    color: #c21732;
    font-size: 3.5rem;
    font-weight: bold;
    pointer-events: none;
}

.cv_tel_tel {
    display: block;
    width: 7em;
    margin: 10px auto 0;
    padding-left: .7em;
    font-family: "Roboto";
    font-size: 4vw;
    font-weight: bold;
    color: #c21732;
    text-align: center;
    background: url(../img/02_cpn/tel_icon.svg) no-repeat left center;
    background-size: 2.6vw;
    white-space: nowrap;
}

.cv_tel_tel2 {
    display: block;
    padding-left: 38px;
    font-family: "Roboto";
    font-size: 3.2vw;
    font-weight: bold;
    color: #c21732;
    background: url(../img/02_cpn/tel_icon.svg) no-repeat left center;
    background-size: 2vw;
    white-space: nowrap;
}

/*------------------------------------------*/
/*campaign
/*------------------------------------------*/
.campaign {
    width: 100%;
    padding: 0;
    overflow: hidden;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    margin-top: -1px;
}

.campaign-bg {
    /*padding: 0 0 100px;*/
    padding: 0 0 10px;
    background: #c21732;
}

.ttl_01 {
    display: block;
    width: 90%;
    max-width: 1000px;
    margin: 0 auto;
    padding: 80px 0 30px;
}

.campaign_sub_ttl {
    display: block;
    color: #000;
    text-align: center;
    font-size: 6rem;
    font-weight: bold;
    padding: 50px 0;
}

.campaign-down {
    margin: -2px auto 0;
    width: 20%;
    max-width: 134px;
}

/*------------------------------------------*/
/*free（studio)
/*------------------------------------------*/
#free {
    padding: 90px 0 0;
}

.freeStudio-bg {
    width: 100%;
    padding: 50px 0 0;
    background-color: #f0f0f0;
    background-size: cover;
}

.freeStudio_inner {
    margin: 80px auto 100px;
}

.freeStudio_solve {}

.freeStudio_solve_box {
    position: relative;
    margin: 0;
}

.freeStudio_solve_box:last-child {
    margin-bottom: 100px;
}

.freeStudio_machine {
    width: 50%;
    max-width: 700px;
    padding-left: 0;
}

.freeStudio_machine_r .pc_only {
    width: 50%;
    max-width: 700px;
    margin: 0 0 0 auto;
}

.freeStudio_cap {
    position: absolute;
    top: 0;
    left: 50%;
    width: 36%;
    max-width: 500px;
    padding-left: 7%;
}

.freeStudio_cap_r {
    position: absolute;
    top: 0;
    left: 0;
    width: 36%;
    max-width: 500px;
    padding-left: 7%;
}

/* .freeStudio_cap .freeStudio_headline {
  margin: 0;
} */
.freeStudio_cap p,
.freeStudio_cap_r p {
    margin: 25px 0;
    font-size: 1.5rem;
}

.freeStudio_cap .balloon {
    max-width: 480px;
    margin: 0 auto 0 0;
}

.freeStudio_cap_r .balloon {
    max-width: 480px;
    margin: 0 auto 0 0;
}

.freeStudio_solve_line,
.freeStudio_solve_line_r {
    width: 17%;
    max-width: 240px;
    margin: 20px auto;
}

.oneArea {
    background: linear-gradient(110deg, #e7e9eb 0%, #e7e9eb 60%, #c21732 40%, #c21732 100%);
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    width: 100%;
    height: 268px;
    margin-bottom: 100px;
}

.upArea {
    width: 100%;
    max-width: 1000px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
}

.leftArea {
    width: 100%;
    max-width: 500px;
    padding-left: 20px;
}

.rightArea {
    width: 100%;
    max-width: 240px;
    padding-right: 20px;
}

.rightArea p {
    color: #fff;
    font-size: 0.85em;
    margin: 5px 0 0 0
}


/*------------------------------------------*/
/*covid
/*------------------------------------------*/
#covid {
    padding: 0 0 5vw 0;

}

.covid-bg {
    padding: 75px 0 10px;
    background: #f8ebe5;
    background-size: cover;
}

.covid-inner {
    padding: 0 40px;
}

.covid_box ul {
    width: 100%;
    height: auto;
    margin: 0 auto;
    text-align: justify;
}

ul:after {
    content: "";
    display: inline-block;
    width: 100%;
    line-height: 0;
    height: 0;
}

.covid_box li {
    display: inline-block;
    width: 100%;
    vertical-align: top;
    padding-bottom: 50px;
}

.covid_box_left {
    width: 50px;
    max-width: 603px;
}

.covid_box_right {
    width: 50px;
    max-width: 440px;
}

.covid_down {
    margin: -1px auto 0;
    max-width: 134px;
}

.covid_measures-inner {
    width: 96%;
    max-width: 1400px;
    margin: 75px auto 0;
    padding: 0 20px;
    overflow: hidden;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}

.covid_block {
    margin: 0px 25px 100px;
    display: table;
}

.covid_block_point {
    width: 800px;
    max-width: 80%;
    display: table-cell;
}

.covid_block_point:nth-child(2n) {
    padding-left: 50px;
}

.covid_block_point:nth-child(2n+1) {
    padding-right: 50px;
}

/*------------------------------------------*/
/*title
/*------------------------------------------*/
.title_bg {
    /*background: url(../img/10_title/bg_title.png) no-repeat;
  background-size: cover;*/
    background: url(../img/10_title/bg_title.png);
    height: 262px;
    position: relative;
}

.title_logo_l,
.title_logo_r {
    width: 90%;
    max-width: 416px;
    position: absolute;
    top: 30%;
    left: 0;
    right: 0;
    margin: 0 auto;
    text-align: center;
}

#feature .title_text {
    width: auto;
    position: absolute;
    top: 45%;
    left: 0;
    right: 0;
    margin: 0 auto;
}

.title_text {
    width: auto;
    position: absolute;
    top: 55%;
    left: 0;
    right: 0;
    margin: 0 auto;
}

.title_text_r {
    width: auto;
    position: absolute;
    top: 55%;
    left: 0;
    right: 0;
    margin: 0 auto;
}

.title_bg h2 {
    font-size: 58px;
    color: #fbdf00;
    font-weight: bold;
    text-align: center;
    margin-top: 10px;
}

.title_bg h2 span {
    font-size: 70px;
}

h2.ttl_02 {
    margin: 0 auto;
    color: #000;
    text-align: center;
    font-size: 48px;
    font-family: "Noto Sans CJK JP", sans-serif !important;
    font-weight: bold;
    padding: 45px 0 15px;
}

.ttl_line {
    border: solid 2px #c21732;
    width: 150px;
    margin: 0 auto;
}

h3.sub_ttl_02 {
    margin: 0 auto;
    color: #000;
    text-align: center;
    font-size: 16px;
    font-family: "Noto Sans CJK JP", sans-serif !important;
    font-weight: bold;
    padding: 15px 0 90px;
    opacity: 0.4;
}

/*------------------------------------------*/
/*feature
/*------------------------------------------*/
#feature {
    /*margin: 20px 0 0;*/
    /*padding: 8vw 0 0;*/
    padding: 0;
    overflow: visible;
}

.feature_title_hero {
    width: 90%;
    max-width: 520px;
    position: absolute;
    bottom: 0;
    left: 20%;
}

.feature_bg {
    background-color: #ffeef2;
    padding: 75px 0 100px;
}

.bg_img {
    padding: 0 0 220px;
    overflow: hidden;
}

.bg_img:last-child {
    padding: 0 0 100px;
    overflow: hidden;
}

#feature .pink {
    color: #ff1b29;
}

#feature .pink .sm {
    font-size: 28px;
}

#feature .orange {
    color: #ed5929;
    ;
}

#feature .green {
    color: #166d6d;
}

#feature .red {
    color: #c21732;
}

#feature .blue {
    color: #0f348d;
}

.f_bg1 {
    display: block;
    background: url(../img/04_feature/bg_feature_01.png) no-repeat;
    background-size: 100%;
}

.feature_box-inner {
    width: 100%;
    max-width: 1400px;
    padding: 0 20px;
    margin: 0 auto;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}

.feature_box {
    position: relative;
    padding-top: 500px;
    text-align: right;
}

.feature_box_no_left {
    width: 100%;
    max-width: 1400px;
    position: absolute;
    top: 0;
    margin-left: 3%;
    z-index: 999999;
}

.feature_box_no_left p {
    font-size: 72px;
    font-weight: 900;
    font-family: "Noto Sans CJK JP", sans-serif !important;
}

.feature_box_no_right p {
    font-size: 72px;
    font-weight: 900;
    font-family: "Noto Sans CJK JP", sans-serif !important;
    text-align: right;
    padding-right: 4%;
}

.feature_text_left {
    width: 44vw;
    max-width: 580px;
    height: auto;
    background-color: #fff;
    padding: 30px;
    position: absolute;
    top: 70px;
    z-index: 200;
}

.headline1 {
    font-size: 32px;
    font-weight: bold;
    padding-bottom: 10px;
    line-height: 1.2;
}

.feature_pic_left {
    position: inherit;
    margin: -370px 0 0 auto;
    width: 60%;
    height: auto;
    z-index: 100;
}

.feature_pic_right {
    position: inherit;
    margin: -370px auto 0 0;
    width: 60%;
    height: auto;
    z-index: 100;
}

.feature_deco {
    margin-top: -60px;
}

.feature_deco p {
    font-size: 80px;
    font-family: "Noto Sans CJK JP", sans-serif !important;
    font-weight: 900;
}

.deco_pink {
    position: absolute;
    color: #ffbbbf;
    text-align: right;
    right: 55%;
    z-index: 1;
}

.deco_orange {
    position: absolute;
    color: #facebd;
    text-align: left;
    left: 55%;
    z-index: 1;
}

.deco_green {
    position: absolute;
    color: #bdd5d6;
    text-align: right;
    right: 55%;
    z-index: 1;
}

.deco_red {
    position: absolute;
    color: #eaa0ae;
    text-align: left;
    left: 55%;
    z-index: 1;
}

.deco_blue {
    position: absolute;
    color: #b7c0de;
    text-align: right;
    right: 55%;
    z-index: 1;
}

.f_bg2 {
    display: block;
    background: url(../img/04_feature/bg_feature_02.png) no-repeat;
    background-size: 100%;
}

.feature_box_no_right {
    width: 100%;
    max-width: 1400px;
    position: absolute;
    top: 0;
    z-index: 999999;
}

.feature_text_right {
    width: 44vw;
    max-width: 580px;
    height: auto;
    background-color: #fff;
    padding: 30px 50px;
    position: absolute;
    top: 70px;
    z-index: 200;
    right: 0;
}

.headline2 {
    font-size: 32px;
    font-weight: bold;
    padding-bottom: 10px;
    line-height: 1.2;
}

.f_bg3 {
    display: block;
    background: url(../img/04_feature/bg_feature_03.png) no-repeat;
    background-size: 100%;
}

.f_bg4 {
    display: block;
    background: url(../img/04_feature/bg_feature_04.png) no-repeat;
    background-size: 100%;
}

.f_bg5 {
    display: block;
    background: url(../img/04_feature/bg_feature_05.png) no-repeat;
    background-size: 100%;
}

.feature_studio_btn_wrap {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    width: 80%;
    background: #166d6d;
    padding: 10px 5px;
    margin: 20px auto;
    border-radius: 10px;
    text-align: center;
}

.feature_studio_btn_wrap:hover {
    background: rgba(22, 109, 109, 0.7);
    -webkit-transition: 0.5s;
    transition: 0.5s;
}

.feature_studio_btn_wrap a {
    font-size: 16px;
    text-decoration: none;
    color: #fff;
}

.feature_text_left .text,
.feature_text_right .text {
    font-size: 16px;
}

/*------------------------------------------*/
/*gym
/*------------------------------------------*/
#gym {
    margin: 0;
    /*padding: 10vw 0 0;*/
    padding: 0;
    overflow: visible;
}

.gym_title_hero {
    width: 90%;
    max-width: 628px;
    position: absolute;
    bottom: 0;
    right: 15%;
}

.gym_bg {
    background-color: #f4f4f4;
    padding: 70px 0 30px;
}

.gym_bg_inner {
    width: 100%;
    max-width: 1200px;
    margin: 100px auto;
}

.gym_inner_r,
.gym_inner_l {
    width: 70vw;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    margin: 50px auto 0;
    background-color: #fff;
    padding: 0 0 2.2% 0;
}

.gym_official_img {
    width: 45vw;
    margin-top: -3%;
    margin-left: -6vw;
}

.gym_official_img_l {
    width: 45vw;
    margin-top: -3%;
    margin-right: -6vw;
}

.gym_official_img_ex {
    width: 45vw;
    margin-top: -3%;
    margin-left: -6vw;
}

.gym_official_img img {
    width: 100%;
    vertical-align: bottom;
}

.gym_official_img_l img {
    width: 100%;
    vertical-align: bottom;
}

.gym_cap_r {
    width: 23vw;
    background-color: #fff;
    padding-top: 2%;
    padding-left: 3.4vw;
}

.gym_cap_l {
    width: 23vw;
    background-color: #fff;
    padding-top: 2%;
    padding-right: 3.4vw;
}

.gym_ttl_1 {
    width: 23vw;
    margin: 0;
    padding: 10px 0 0;
    font-size: 2.2vw;
    font-weight: bold;
    text-align: left;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    background: url(../img/05_gym/img_gym_cardio_icon.png) no-repeat right 20px;
    background-size: 2.9vw;
}

.gym_ttl_2 {
    width: 23vw;
    margin: 0;
    padding: 10px 0 0;
    font-size: 2.2vw;
    font-weight: bold;
    text-align: left;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    background: url(../img/05_gym/img_gym_strength_icon.png) no-repeat right 20px;
    background-size: 2.9vw;
}

.gym_ttl_3 {
    width: 23vw;
    margin: 0;
    padding: 10px 0 0;
    font-size: 2.2vw;
    font-weight: bold;
    text-align: left;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    background: url(../img/05_gym/img_gym_freew_icon.png) no-repeat right 20px;
    background-size: 2.9vw;
}

.gym_detail,
.gym_detail_l {
    min-height: 3.6vw;
    margin: 5.2% 0;
    font-size: 16px;
    line-height: 1.2;
}

.machine_pic_l {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    margin-top: auto;
}

.machine_pic_r {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    margin-top: auto;
}

.machine_pic img {
    display: block;
    width: 80%;
    height: auto;
}

.gym_bg-spacer{
    height: 60px;
}

/*------------------------------------------*/
/*studio
/*------------------------------------------*/
#studio {
    margin: 0;
    /*padding: 0 0 8vw 0;*/
    padding: 0;
    overflow: visible;
}

.studio_title_hero {
    width: 90%;
    max-width: 611px;
    position: absolute;
    bottom: 0;
    left: 10%;
}

.studio_bg {
    background-color: #fff3f5;
    padding: 0 0 8vw 0;
}

.studio-title_shop {
    background: url(../img/10_title/bg_title.png) -24px repeat;
    height: 24px;
    text-align: center;
    padding-bottom: 16px;
    color: #fff;
    font-size: 18px;
}

.studio-shop {
    color: #C21732;
    font-weight: bold;
    display: inline-block;
    margin-top: 12px;
    font-size: 16px;
}

.studio_program-inner {
    position: relative;
    z-index: 999999;
    text-align: center;
}

.program {
    display: inline-block;
    border-radius: 125px;
    background-color: #c21732;
    color: #fff;
    font-size: 30px;
    font-weight: bold;
    text-align: center;
    margin: 90px auto 0;
    padding: 10px 30px;
}

.program_detail {
    color: #000;
    font-size: 16px;
    text-align: center;
    margin: 30px auto;
}

.studio_dego_bg {
    margin: -100px auto 0;
    padding: 40px 0 0;
    height: 180px;
}

.yoga_bg {
    background-color: #e86931;
}

.bodycombat_bg {
    background-color: #407278;
}

.aero_bg {
    background-color: #306c8e;
}

.pilates_bg {
    background-color: #baa850;
}

.studio_deco p {
    text-align: center;
    color: #fff;
    font-size: 150px;
    font-weight: 900;
    opacity: 0.2;
    font-family: "Noto Sans CJK JP", sans-serif !important;
}

/*------------------------------------------*/
/*other
/*------------------------------------------*/
#other {
    /*   margin: -20px; */
    /*padding: 15vw 0 0;*/
    padding: 0 0 8vw 0;
    overflow: visible;
}

.other_title_hero {
    width: 90%;
    max-width: 580px;
    position: absolute;
    bottom: 0;
    right: 10%;
}

.other-inner img {
    margin: 80px auto;
}

.optionPrice_month_list {
    margin: 0 0 40px;
}

.table_list table {
    width: 100%;
    border: solid 1px #707070;
}

.table_list th {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    border-right: solid 1px #707070;
    border-bottom: solid 1px #707070;
    font-size: 1.8rem;
    line-height: 1.4;
    font-weight: bold;
    vertical-align: middle;
    padding: 1rem;
    width: 50%;
}

.table_list td {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    border-right: solid 1px #707070;
    border-bottom: solid 1px #707070;
    font-size: 1.8rem;
    line-height: 1.4;
    font-weight: bold;
    text-align: center;
    padding: 1rem;
}

.scbox {
    padding: 0 20px;
    width: 100%;
    max-width: 1000px;
    margin: 0 auto 20px;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}

.schedule_link_box {
    max-width: 1100px;
    width: 100%;
    margin: 0 0 60px;
}

.schedule_link_box ul {
    border-left: solid 1px #707070;
    border-top: solid 1px #707070;
}

.schedule_link li {
    display: block;
    float: left;
    width: 50%;
    text-align: center;
    border: none;
}

.schedule_link li p {
    display: inline-block;
    position: relative;
    width: 100%;
    border-right: solid 1px #707070;
    border-bottom: solid 1px #707070;
    font-size: 1.25rem;
    color: #c21732;
    font-weight: bold;
    padding: 10px;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}

.ri {
    float: right;
    color: #000;
}

.spt {
    display: none;
}

/*------------------------------------------*/
/*member
/*------------------------------------------*/
#member{
    padding: 0;
}

.member_bg {
    background-color: #DBDBDB;
    padding-bottom: 80px;
}

.fee {
    width: 100%;
    text-align: center;
    font-size: 2rem;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    border: solid #B51B32 3px;
}

.fee th {
    color: #fff;
    background-color: #B51B32;
    padding: 25px 0;
    border-right: solid #fff 2px;
}

.fee td {
    color: #000;
    padding: 25px 0;
    background-color: #fff;
    border-right: solid #B51B32 2px;
}

.bring {
    margin: 30px auto;
    background-color: #444444;
}

.bring h3 {
    text-align: center;
    font-size: 2.4rem;
    color: #fff;
    padding: 10px 0;
}

.bring_list ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin: 30px 0;
}

.bring_list li {
    width: 30%;
    max-width: 330px;
    /*margin-right: auto;*/
  margin: 10px auto;
    padding: 50px 0;
    background-color: #fff;
    border-radius: 10px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
}

.bring_list li:last-child {
    /*margin-right: 0;*/
}

.bring_list li p {
    text-align: center;
    font-size: 2rem;
    font-weight: bold;
    margin: 0 auto;
}

.bring_annotation {
    margin: 0 40px;
}

/*------------------------------------------*/
/*shop
/*------------------------------------------*/
#shop_info {
    width: 100%;
    padding: 0;
    overflow: hidden;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}

.shop_info-inner {
    width: 100%;
    max-width: 1000px;
    margin: 0 auto;
}

.shop_block {
    margin-top: 0;
}

.shop_block-inner {
    overflow: hidden;
    text-align: center;
    padding-bottom: 60px;
}

.shop_number {
    height: auto;
    text-align: left;
}

.shop_box {
    width: 100%;
    max-width: 480px;
    margin: 0 auto;
    padding: 10px;
    display: inline-block;
    vertical-align: top;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}

.shop-overview {
    height: auto;
    text-align: left;
}

.shop-ttl {
    display: table;
}

.shop-ttl img {
    max-width: 50px;
    margin-right: 20px;
    display: table-cell;
    vertical-align: middle;
}

.shop-ttl h3 {
    display: table-cell;
    font-size: 34px;
    vertical-align: middle;
}

.shop-overview .address {
    margin-bottom: 15px;
    font-size: 21px;
}

.shop-overview .notes_bold {
    text-align: left;
    font-size: 17px;
    font-weight: bold;
    margin-top: 15px;
}

.shop-overview .notes {
    text-align: left;
    font-size: 17px;
}

.shop-overview .notes span {
    padding-left: 86px;
}

.shop-overview .tel {
    font-weight: bold;
    font-size: 2.8rem;
    color: #c21732;
    text-decoration: none;
    pointer-events: none;
    cursor: text;
}

.shop-overview .tel span {
    font-size: 1.8rem;
    color: #000;
}

.shop_tel {}

.shop_tel_icon {
    max-height: 34px;
    background: url(../img/02_cpn/tel_icon.svg) no-repeat left;
    padding-left: 40px;
}

.g_map {
    width: 90%;
    max-width: 1000px;
    height: auto;
    margin: 0 auto 40px;
}

.g_map iframe.map {
    border: 0;
    width: 100%;
    filter: saturate(150%);
    -webkit-filter: saturate(150%);
}

.g_map iframe {
    width: 100%;
    height: 400px;
}

/*------------------------------------------*/
/*text_link
/*------------------------------------------*/
.text_link {
    width: 100%;
    background-color: #002059;
    padding: 20px 0;
}

.text_link ul {
    text-align: center;
}

.text_link ul li {
    display: inline-block;
    color: #fff;
}

.text_link ul li::after {
    content: "｜";
}

.text_link ul li:last-child::after {
    content: "";
}

.text_link ul li a {
    color: #fff;
    text-align: center;
    text-decoration: none;
    font-size: 1.4rem;
    -webkit-transition: 0.3s;
    transition: 0.3s;
}

.text_link ul li a:hover {
    color: #b57f18;
}

/*------------------------------------------*/
/*footer
/*------------------------------------------*/
footer {
    width: 100%;
}

footer .copyright {
    padding: 5px 0;
    color: #fff;
    background: #c21732;
    text-align: center;
    font-size: 1.2rem
}

/*------------------------------------------*/
/*page_top_button
/*------------------------------------------*/
#page-top {
    position: fixed;
    bottom: 20px;
    right: 20px;
    font-size: 70%;
    font-weight: 800;
    bottom: -100px;
    -webkit-transition: .3s;
    transition: .3s;
}

#page-top.show {
    bottom: 20px;
    -webkit-transition: .3s;
    transition: .3s;
}

#page-top a {
    background: #fff;
    opacity: 0.5;
    text-decoration: none;
    color: #333;
    width: 80px;
    padding: 20px 0;
    text-align: center;
    display: block;
    border: solid 1px #777;
    border-radius: 5px;
    -webkit-border-radius: 5px;
    -moz-border-radius: 5px;
}

#page-top a:hover {
    text-decoration: none;
    opacity: 0.3;
}

/*------------------------------------------*/
/*side_btn
/*------------------------------------------*/
.side_btn {
    top: 150px;
    position: fixed;
    right: 0;
    z-index: 999999;
}

.side_btn_single {
    background: #c21732;
    font-size: 18px;
    line-height: 1.8;
    font-weight: bold;
    color: #FFFF00;
    letter-spacing: 5px;
    text-decoration: none;
    width: 40px;
    height: auto;
    margin: 20px auto;
    padding: 20px 10px 20px 0;
    text-align: center;
    display: block;
    border: solid 1px #fff;
    border-radius:10px 0 0 10px;
    -ms-writing-mode: tb-rl;
    -webkit-writing-mode: vertical-rl;
    writing-mode: vertical-rl;
    box-shadow: 0px 5px 15px 0px rgba(0, 0, 0, 0.5);
}

.side_btn a:hover {
    background: #921226;
}

/*======================================================================*/
/*width:641~1119px
/*======================================================================*/
@media screen and (min-width:641px) and (max-width:1119px) {


    /*------------------------------------------*/
    /*title
/*------------------------------------------*/
    .gym_title_hero {
        right: 5%;
    }

    .studio_title_hero {
        left: 2%;
    }

    .other_title_hero {
        right: 5%;
    }

    /*------------------------------------------*/
    /*feature
/*------------------------------------------*/
    .feature_title_hero {
        left: 5%;
    }

    .feature_text_left .text,
    .feature_text_left .right {
        line-height: 1.4;
    }

    .headline1,
    .headline2 {
        font-size: 20px;
    }

    #feature .pink .sm {
        font-size: 18px;
    }

    .feature_studio_btn_wrap {
        width: 100%;
    }

    .feature_studio_btn_wrap a {
        font-size: 14px;
    }

    .feature_deco p {
        font-size: 5rem;
    }

    /*------------------------------------------*/
    /*covid
/*------------------------------------------*/
    .covid_box li {
        display: block;
        width: 100%;
        margin: 0 auto;
    }

    .covid_measures-inner {
        margin: 0 auto 120px;
    }

    .covid_block {
        margin: 0 auto;
    }

    .covid_block_point {
        width: 100%;
        max-width: 500px;
        display: block;
        margin: 60px auto 0;
    }

    .covid_block_point:nth-child(2n) {
        padding-left: 0;
    }

    .covid_block_point:nth-child(2n+1) {
        padding-right: 0;
    }

    /*------------------------------------------*/
    /*gym
/*------------------------------------------*/
    .gym_inner_r,
    .gym_inner_l {
        width: 90%;
    }

    .gym_official_img,
    .gym_official_img_l,
    .gym_official_img_ex {
        width: 62%;
    }

    .gym_cap_r,
    .gym_cap_l {
        width: 34%;
    }

    .gym_ttl_1 {
        width: 30vw;
        padding: 0 0 0;
        font-size: 2rem;
        background: url(../img/05_gym/img_gym_cardio_icon.png) no-repeat right;
        background-size: 4vw;
    }

    .gym_ttl_2 {
        width: 30vw;
        padding: 0 0 0;
        font-size: 2rem;
        background: url(../img/05_gym/img_gym_strength_icon.png) no-repeat right;
        background-size: 4vw;
    }

    .gym_ttl_3 {
        width: 30vw;
        padding: 0 0 0;
        font-size: 2rem;
        background: url(../img/05_gym/img_gym_freew_icon.png) no-repeat right;
        background-size: 4vw;
    }

    .cv_tel_tel2 {
        padding-left: 30px;
        font-size: 4.5vw;
        background-size: 3vw;
    }
}

/*======================================================================*/
/*width:~1119x
/*======================================================================*/
@media screen and (min-width:901px) and (max-width:1119px) {

    /*------------------------------------------*/
    /*kv(studio)
/*------------------------------------------*/
    /*------------------------------------------*/
    /*feature
/*------------------------------------------*/
    .deco_pink {
        text-align: right;
        right: 10;
        top: 90;
    }

    .deco_orange {
        text-align: left;
        left: 10;
        top: 90;
    }

    .deco_green {
        text-align: right;
        right: 10;
        top: 90;
    }

    .deco_red {
        text-align: left;
        left: 10;
        top: 90;
    }

    .deco_blue {
        text-align: right;
        right: 10;
        top: 90;
    }
}

/*======================================================================*/
/*width:641~900px
/*======================================================================*/
@media screen and (min-width:641px) and (max-width:900px) {

    /*------------------------------------------*/
    /*kv(studio)
/*------------------------------------------*/
    /*------------------------------------------*/
    /*free（studio)
/*------------------------------------------*/
    .freeStudio_solve_box:last-child {
        margin-bottom: 150px;
    }

    .freeStudio_headline {
        width: 90%;
    }

    .freeStudio_cap {
        width: 48%;
        padding-left: 2%;
    }

    .freeStudio_cap_r {
        width: 48%;
        padding-left: 0;
    }

    .freeStudio_cap p,
    .freeStudio_cap_r p {
        margin: 10px 0;
        line-height: 1.3;
    }

    .freeStudio_solve_line {
        margin: 30px 50% 30px auto;
    }

    .freeStudio_solve_line_r {
        margin: 30px auto 30px 50%;
    }

    .leftArea {
        max-width: 366px;
        padding-left: 20px;
    }

    .rightArea {
        width: 100%;
        max-width: 200px;
        padding-right: 20px;
    }

    /*------------------------------------------*/
    /*feature
/*------------------------------------------*/
    .feature_text_right,
    .feature_text_left {
        padding: 5vw;
    }

    .feature_pic_right {
        margin: -49vw auto 0 0;
    }

    .feature_deco {
        margin-top: 0;
    }

    .deco_pink {
        text-align: left;
        right: 0;
        top: 0;
    }

    .deco_orange {
        text-align: right;
        left: 0;
        top: 0;
    }

    .deco_green {
        text-align: left;
        right: 0;
        top: 0;
    }

    .deco_red {
        text-align: right;
        left: 0;
        top: 1vw;
    }

    .deco_blue {
        text-align: left;
        right: 0;
        top: 0;
    }

    .feature_studio_btn_wrap {
        letter-spacing: -0.1vw;
    }
}

/*-----------*\
$animation
\*-----------*/
/*----- fadeIn -----*/
.js-fadeIn {
    opacity: 0;
    -webkit-transition: 1s;
    transition: 1s;
    -webkit-transition-delay: .1s;
    transition-delay: .1s;
}

.fadeIn {
    opacity: 1.0;
}

/*----- Up slide -----*/
.js-Up {
    transform: translate(0, 40px);
    -webkit-transform: translate(0, 40px);
    -webkit-transition: .8s;
    transition: .8s;
}

.Up {
    transform: translate(0, 0);
    -webkit-transform: translate(0, 0);
}

/*----- zoomIn -----*/
.js-zoomIn {
    opacity: 0.5;
    transform: scale(0.8, 0.8);
    -webkit-transform: scale(0.8, 0.8);
    -webkit-transition: 0.5s cubic-bezier(0.29, 1.14, 0.72, 1.275);
    transition: 0.5s cubic-bezier(0.29, 1.14, 0.72, 1.275);
}

.zoomIn {
    opacity: 1;
    transform: scale(1, 1);
    -webkit-transform: scale(1, 1);
    -webkit-transition: 0.5s cubic-bezier(0.175, 0.885, 0.32, 1.275);
    transition: 0.5s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}

/*----- zoomIn fancy -----*/
.js-zoomIn_fancy {
    opacity: 0.5;
    transform: scale(0.7, 0.7);
    -webkit-transform: scale(0.8, 0.8);
    -webkit-transition: 0.5s cubic-bezier(0.68, -0.55, 0.265, 1.55);
    transition: 0.5s cubic-bezier(0.68, -0.55, 0.265, 1.55);
}

.zoomIn_fancy {
    opacity: 1;
    transform: scale(1, 1);
    -webkit-transform: scale(1, 1);
    -webkit-transition: 0.5s cubic-bezier(0.68, -0.55, 0.265, 1.55);
    transition: 0.5s cubic-bezier(0.68, -0.55, 0.265, 1.55);
}

/* js-fadeIn_delay */
.js-fadeIn_delay li {
    opacity: 0;
    transform: translate(0, 60px);
    -webkit-transform: translate(0, 60px);
    -webkit-transition: .8s;
    transition: .8s;
}

.js-fadeIn_delay li.fadeIn {
    opacity: 1.0;
    transform: translate(0, 0);
    -webkit-transform: translate(0, 0);
}

/*----- fadeInLeft -----*/
.btnflash {
    -webkit-animation: move-btnflash .5s ease 1 alternate;
    animation: move-btnflash .5s ease 1 alternate;
}

@-webkit-keyframes move-btnflash {
    0% {
        opacity: 1;
    }

    25% {
        opacity: .7;
    }

    50% {
        opacity: 1;
    }

    75% {
        opacity: .7;
    }

    100% {
        opacity: 1;
    }
}

@keyframes move-btnflash {
    0% {
        opacity: 1;
    }

    25% {
        opacity: .7;
    }

    50% {
        opacity: 1;
    }

    75% {
        opacity: .7;
    }

    100% {
        opacity: 1;
    }
}

/*------------------------------------------*/
/*cvtel
/*------------------------------------------*/
.campain_tel_container {
    width: 100%;
    margin-bottom: 80px;
    padding: 0;
}

.campain_tel_container p {
    font-size: 1.4em;
    color: #fff;
    text-align: center;
    margin: auto;
}

.campain_tel {
    display: block;
    margin: auto;
    font-family: "Roboto";
    font-size: 2.5em;
    font-weight: bold;
    color: #fff;
    text-align: center;
    white-space: nowrap;
    padding: 0;

}

.campain_tel i {
    margin: 0 12px 0 0;
}

.campain_btn_container {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    display: block;
    width: 100%;
    max-width: 680px;
    height: 130px;
    margin: 50px auto 100px auto;
    text-align: center;
}

.campain_btn {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    width: 100%;
    height: 100%;
    display: block;
    font-weight: bold;
    text-decoration: none;
    background: #FFFF00;
    -webkit-transition: 0.5s;
    transition: 0.2s;
    vertical-align: middle;
    border-radius: 6px;
    padding: 0;
    margin: 16px auto;
}

.campain_cvbtn {
    color: #C21732;
    width: 100%;
    height: 100%;
    text-decoration: none;
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 3em;
}

.campain_cvbtn:hover {
    background: #ffff66;
    border-radius: 6px;
}

.campain_btn_copy{
    font-size: 1.5em;
    color: #fff;
    display: block;
    text-align: center;
    padding: 0;
}


.cvbtn_wrap_copy {
    font-weight: bold;
    display: block;
    text-align: center;
    margin: 36px auto -20px;
    font-size: 2em;
}

#shop_info .cta {
    width: 100%;
    margin: 0 auto;
    padding: 20px;
    background-color: #c21732;
    display: table;
    text-decoration: none;
    -webkit-border-radius: 10px;
    -moz-border-radius: 10px;
    border-radius: 10px;
    -webkit-transition: 0.3s;
    -moz-transition: 0.3s;
    transition: 0.3s;
    position: relative;
    box-sizing: border-box;
}

#shop_info .cta:hover {
    background-color: #000;
    -webkit-transition: 0.3s;
    -moz-transition: 0.3s;
    transition: 0.3s;
}

#shop_info .cta p {
    text-align: center;
    color: #fff;
    font-size: 2rem;
    font-weight: bold;
}

#shop_info .cta img {
    max-width: 13px;
    margin-left: 20px;
    position: absolute;
    top: 35%;
    right: 5%;
}

.padding-top-zelo{
    padding-top: 0 !important;
}


/*2022.4.1 子供用モーダル*/
.modal_banner_aria{
    padding: 40px 0;
    max-width: 1000px;
    width: 100%;
    margin: auto;
}

@media screen and (max-width:640px){
    .modal_banner_aria{
        width: 95%;
        margin: auto;
    }
}

.modal_banner a:hover img{
    opacity: 0.75;
}

#kids{
    display: none;
}

.kids_content{
    width: 100%;
    margin: auto;
}

.kids_content img{
    width: 100%;
    height: auto;
    display: block;
}

.modaal-wrapper{
    z-index: 1000001;
}

.modaal-overlay{
    z-index: 1000000;
}

.modaal-inner-wrapper{
    padding: 20px 10px;
}

.modaal-container{
    width: 100%;
    max-width: 1300px;
}

.modaal-content-container{
    padding: 0;
}

.modaal-wrapper img{
    width: 100%;
    height: auto;
    display: block;
}

.modaal-close{
    background: #fff !important;
    border: 1px solid #000 !important;
}

.modaal-close:after,
.modaal-close:before{
    background:#999;
}

.modaal-close:focus:after,
.modaal-close:focus:before,
.modaal-close:hover:after,
.modaal-close:hover:before{
    background:#666;
}
