html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed, 
figure, figcaption, footer, header, hgroup, 
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  font: inherit;
  vertical-align: baseline;
}

body{
  font-family: "Helvetica Neue",
  Arial,
  "Hiragino Kaku Gothic ProN",
  "Hiragino Sans",
  Meiryo,
  sans-serif;
}

a{
  transition : all 0.3s ease 0s;
}

:root {
  --color-yellow: #ffba00;
  --color-green: #54b502;
  --color-orange: #ff574b;
  --color-blue: #10182b;
}

input[type="text"],
input[type="radio"],
input[type="date"],
button,
select,
textarea {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background: transparent;
  border: none;
  border-radius: 0;
  font: inherit;
  outline: none;
}

/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝
#共通パーツ
＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
.linkbtn{
  background: var(--color-green);
  border-left: none;
  border-right: none;
  border-left: none;
  border-bottom: solid #457c01 5px;
  border-radius: 5px;
  color: #fff;
  display: block;
  font-size: 20px;
  font-weight: bold;
  height: 70px;
  line-height: 70px;
  margin: 0 auto;
  padding: 0;
  text-align: center;
  text-decoration: none;
  width: 500px;
}

.linkbtn:hover{
  background: var(--color-orange);
  border-bottom: solid #ae1308 5px;
}

.marulist{
  list-style-type: none;
}

.marulist li{
  background: #fff;
  border: solid var(--color-yellow) 5px;
  border-radius: 50%;
  display: inline-block;
  font-weight: bold;
  text-align: center;
  vertical-align: top;
}

.marulist li:last-of-type{
  margin-right: 0;
}

.marulist li p:first-of-type{
  background: var(--color-yellow);
}

.h2bg{
  background-image:url(img/h2bg_pc.png);
  background-position: center top;
  background-size: cover;
  color: #fff;
  font-size: 40px;
  font-weight: bold;
  height: 100px;
  line-height: 100px;
  text-align: center;
}

@media screen and (max-width: 800px) {
.linkbtn{
  width: 80%;
}

.h2bg{
  background-image:url(img/h2bg_sp.png);
  font-size: 20px;
  height: 50px;
  line-height: 50px;
}
}


/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝
#topimage　トップイメージ
＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
#topimage .background{
  background-color: #10182b;
  background-image: url( img/topimage_bg.jpg);
  background-position: right top;
  background-repeat: no-repeat;
  background-size: auto 840px;
  height: 840px;
  position: relative;
}

@media screen and (max-width: 1900px) {
#topimage .background{
  background-position: center top;
}
}

#topimage .background-line{
  background-image: url( img/topimage_line.png);
  background-position: center top;
  background-repeat: no-repeat;
  background-size: auto 840px;
  content: "";
  height: 840px;
  left: 0;
  position: absolute;
  top: 0;
  width: 100%;
}

@media screen and (min-width: 1900px) {
#topimage .background-line{
  background-position: left top;
}
}

/*キャンペーン*/
#topimage .cp_mar{
  display: block;
}

#topimage .cp_mar_sp{
  display: none;
}

@media screen and (max-width: 800px) {
#topimage .cp_mar{
  display: none;
}

#topimage .cp_mar_sp{
  display: block;
  width: 100%;
}
}

header{
  padding: 20px 40px;
  position: relative;
  width: 100%;
}

header .spnav-toggle{
  display: none;
}

header h1 .logo01{
  width: 200px;
}

header nav ul{
  list-style-type: none;
  margin: 20px 0;
}

header nav ul li{
  display: inline-block;
  margin-right: 30px;
}

header nav ul li a{
  color: #000;
  font-weight: bold;
  text-decoration: none;
}

header nav ul li a:hover{
  color: var(--color-yellow);
  text-decoration: underline;
}

header .fixbox{
  position: fixed;
  right: 20px;
  top: 20px;
  z-index: 1000;
}

header .fixbox .tel{
  display: inline-block;
  height: 63px;
  vertical-align: top;
  width: 240px;
}

header .fixbox .tel img{
  width: 100%;
}

header .fixbox .linkbtn{
  border-bottom-width: 3px;
  display: inline-block;
  font-size: 18px;
  height: 63px;
  line-height: 63px;
  width: 240px;
}

header .fixbox .linkbtn:hover{
  border-bottom-width: 3px;
}

/*スマホ表示ヘッダーバナー*/
.sp_headerbnr{
  display: none;
}

@media screen and (max-width: 600px) {
.sp_headerbnr{
  display: block;
  margin: -30px 0 30px;
  width: 100%;
}
}

#topimage .info{
  display: inline-block;
  margin-left: 100px;
  position: relative;
  height: calc(100% - 200px);
}

#topimage .info h2{
  font-size: 50px;
  margin-bottom: 30px;
}

#topimage .info h2 p:first-of-type{
  font-size: 50%;
  font-weight: bold;
}

#topimage .info h2 p:first-of-type span{
  display: inline-block;
  padding-left: 30px;
}

#topimage .info h2 p:nth-of-type(2){
  font-weight: bold;
}

#topimage .info h2 p:nth-of-type(2) span{
  font-size: 50%;
  font-weight: normal!important;
}

#topimage .info h2 p:last-of-type{
  font-size: 30%;
}

#topimage .info img.price{
  width: 500px;
}

#topimage .info .top_strongpoint{
  position: absolute;
  left: 0;
  bottom: 0;
}

#topimage .info .marulist li{
  height: 170px;
  margin-right: 20px;
  width: 170px;
}

#topimage .info .marulist li p:first-of-type{
  line-height: 35px;
  margin: -5px 0 20px;
}

#topimage .info .marulist li:first-of-type p:first-of-type{
  margin: -5px 0 10px;
}

#topimage .info .marulist li:last-of-type p:first-of-type{
  line-height: 16px;
}

#topimage .info .marulist li:last-of-type p:first-of-type span{
  font-size: 12px;
  margin: 0;
}

#topimage .info .marulist li p:last-of-type{
  font-size: 25px;
  line-height: 1.2em;
}

#topimage .info .marulist li p:last-of-type span{
  display: block;
  font-size: 12px;
  line-height: 1.2em;
}

#topimage .counseling{
  background: var(--color-yellow);
  padding: 20px 0 40px;
  text-align: center;
}

#topimage .counseling p{
  background: #fff;
  border: solid #f0653b 2px;
  border-radius: 1em;
  color: #f0653b;
  display: inline-block;
  font-weight: bold;
  line-height: 2em;
  margin-bottom: 5px;
  padding: 0 40px;
  position: relative;
}

#topimage .counseling p:before,
#topimage .counseling p:after{
  border: solid transparent 10px;
  border-bottom: none;
  content: "";
  display: block;
  height: 0;
  left: 50%;
  margin-left: -10px;
  position: absolute;
  width: 0;
}

#topimage .counseling p:before{
  border-top: solid var(--color-orange) 10px;
  bottom: -12px;
}

#topimage .counseling p:after{
  border-top: solid #fff 10px;
  bottom: -10px;
}

@media screen and (max-width: 800px) {
header .fixbox{
  display: none;
}

#topimage{
  border-top: solid #fff 60px;
}

#topimage .background{
  background-image: url( img/topimage_spbg.jpg);
  background-position: right 0;
  background-size: cover;
  height: 80vh;
  padding: 0 0 30px;
  position: relative; 
}

#topimage .background-line{
  background-image: none;
  height: auto;
  position: relative;
}

header{
  background: #fff;
  box-sizing: border-box;
  box-shadow: 2px 2px 10px rgba(0,0,0,0.1);
  height: 60px;
  margin: 0 0 30px;
  overflow: hidden;
  top: 0;
  padding: 5px 20px;
  position: fixed;
  z-index: 2000;
}

header h1 .logo01{
  height: 50px;
  width: auto;
}

header .spnav-toggle{
  box-sizing: border-box;
  height: 30px;
  display: block;
  position: absolute;
  right: 15px;
  top: 15px;
  width: 30px;
  z-index: 3000;
}

header .spnav-toggle:before,
header .spnav-toggle:after,
header .spnav-toggle span{
  background: var(--color-yellow);
  content: "";
  display: block;
  height: 2px;
  left: 50%;
  margin-left: -35%;
  position: absolute;
  transition : all 0.3s ease 0s;
  width: 70%;
}

header .spnav-toggle span{
  margin-top: -1px;
  top: 50%;
}

header .spnav-toggle:before{
  top: 5px;
}

header .spnav-toggle:after{
  bottom: 5px;
}

header .spnav-toggle.open{
  position: fixed;
}

header .spnav-toggle.open span{
  opacity: 0;
}

header .spnav-toggle.open:before{
  top: 14px;
  transform: rotate(45deg);
}

header .spnav-toggle.open:after{
  bottom: 14px;
  transform: rotate(-45deg);
}

header nav{
  background: #fff;
  box-shadow: 0px 0px 10px 10px rgba(0,0,0,0.4);
  position: absolute;
  right: -1000px;
  top: 0;
  height: 100%;
  padding: 20px 0;
  position: fixed;
  transition : all 0.3s ease 0s;
  width: 70%;
  z-index: 2500;
}

header nav.open{
  right: 0;
}

header nav ul{
  margin: 0 auto;
  padding: 80px 0 20px;
  width: 80%;
}

header nav ul li{
  display: block;
  line-height: 3em;
  margin-right: 0;
}

header .linkbtn{
  position: relative;
  right: initial;
  top: initial;
  width: 80%;
}

#topimage header .linkbtn:after{
  font-size: 12px;
}

#topimage .info{
  display: block;
  height: 77vh;
  margin: 0 auto;
  padding-top: 20px;
  width: 100%;
}

#topimage .info h2{
  font-size: 26px;
  margin: 0 5%;
  text-align: left;
}

#topimage .info h2 p:first-of-type{
  font-size: 70%;
}

#topimage .info h2 p:first-of-type span{
  display: block;
  padding-left: 0;
}

#topimage .info img.price{
  margin: 15px 5%;
  width: 65%;
}

#topimage .info .top_strongpoint{
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
}

#topimage .info .marulist{
  margin: 0 auto;
  width: 95%;
}
#topimage .info .marulist li{
  height: auto;
  margin-right: 2%;
  padding-top: 30%;
  position: relative;
  width: 32%;
}

#topimage .info .marulist li:last-of-type{
  margin-right: 0;
}

#topimage .info .marulist li p{
  position: absolute;
}

#topimage .info .marulist li p:first-of-type{
  font-size: 14px;
  line-height: 35px;
  margin: 0;
  top: -5px;
  width: 100%;
}

#topimage .info .marulist li:first-of-type p:first-of-type{
  margin: 0;
}

#topimage .info .marulist li:last-of-type p:first-of-type{
  line-height: 16px;
}

#topimage .info .marulist li:last-of-type p:first-of-type span{
  font-size: 10px;
  margin: 0;
}

#topimage .info .marulist li p:last-of-type{
  font-size: 30px;
  line-height: 1.2em;
  margin-top: -30px;
  top: 50%;
  width: 100%;
}

#topimage .info .marulist li:first-of-type p:last-of-type{
  margin-top: -50px;
}

#topimage .info .marulist li p:last-of-type span{
  display: block;
  font-size: 14px;
  line-height: 1.2em;
}
}

@media screen and (max-width: 700px) {
#topimage .background{
  padding: 0 0 10px;
}

#topimage .info .marulist li p:first-of-type{
  font-size: 14px;
  line-height: 30px;
}

#topimage .info .marulist li:last-of-type p:first-of-type{
  line-height: 14px;
}

#topimage .info .marulist li p:last-of-type{
  font-size: 25px;
  margin-top: -25px;
}

#topimage .info .marulist li:first-of-type p:last-of-type{
  margin-top: -40px;
}

#topimage .info .marulist li p:last-of-type span{
  font-size: 12px;
}
}

@media screen and (max-width: 600px) {
#topimage .info .marulist li p:first-of-type{
  font-size: 10px;
  line-height: 25px;
}

#topimage .info .marulist li:last-of-type p:first-of-type{
  line-height: 12px;
}

#topimage .info .marulist li:last-of-type p:first-of-type span{
  font-size: 10px;
}

#topimage .info .marulist li p:last-of-type{
  font-size: 15px;
  margin-top: -15px;
}

#topimage .info .marulist li:first-of-type p:last-of-type{
  margin-top: -20px;
}

#topimage .info .marulist li p:last-of-type span{
  font-size: 8px;
}
}


/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝
#reason　こんな理由でトレーニングを諦めていませんか？
＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
#reason .wrapper{
  background-color: var(--color-blue);
  background-image: url(img/reason_pc.jpg);
  background-position: center top;
  background-repeat: no-repeat;
  background-size: auto 500px;
  height: 500px;
}

#reason .wrapper ul{
  list-style-type: none;
  margin: 0 auto;
  padding: 80px 0;
  width: 1000px;
}

#reason .wrapper li{
  color: #fff;
  font-size: 26px;
  font-weight: bold;
  line-height: 3em;
  position: relative;
  padding-left: 60px;
}

#reason .wrapper li:before {
  background: #fff;
  box-sizing: border-box;
  content: "";
  position: absolute;
  top: 20px;
  left: 0;
  width: 40px;
  height: 40px;
  border: 2px solid #aaa;
}

#reason .wrapper li:after {
  content: "";
  position: absolute;
  width: 10px;
  height: 20px;
  top: 25px;
  left: 12px;
  -webkit-transform: rotate(50deg);
  -ms-transform: rotate(50deg);
  transform: rotate(50deg);
  border-right: 5px solid var(--color-yellow);
  border-bottom: 5px solid var(--color-yellow);
}

#reason .four-reason h2{
  height: 150px;
  width: 100%;
  padding: 20px 0;
  position: relative;
}

#reason .four-reason h2:before{
content: "";
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 150px 50vw 0 50vw;
  border-color: var(--color-yellow) transparent transparent transparent;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  z-index: -1;
}

#reason .four-reason h2 span{
  background-image: url(img/reason_title01_pc.png);
  background-size: cover;
  color: transparent;
  display: block;
  height: 110px;
  margin: 0 auto;
  width: 800px;
}

#reason .four-reason .flex{
  display: flex;
  margin: 0 auto;
  width: 1000px;
}

#reason .four-reason .flex div{
  padding: 50px 0 50px 50px;
  position: relative;
  vertical-align: middle;
}

#reason .four-reason .flex .txtarea{
  font-weight: bold;
  text-align: left;
}

#reason .four-reason .flex:nth-of-type(even) .txtarea{
  padding: 50px 0;
}

#reason .four-reason .txtarea h3{
  color: var(--color-yellow);
  font-size: 32px;
  line-height: 1.2em;
  margin: 0 0 10px;
}

#reason .four-reason .txtarea h3 span{
  color: var(--color-orange);
}

#reason .four-reason .txtarea h3 span.big{
  color: var(--color-yellow);
  display: inline-block;
  font-size: 180%;
  margin-top: 10px;
}

#reason .four-reason .txtarea p{
  line-height: 2em;
}

#reason .four-reason .txtarea ul{
  margin: 10px 0 30px;
  padding-left: 1.3em;
}

#reason .four-reason .imgarea span{
  background: #fff;
  display: block;
  font-size: 70px;
  font-style: italic;
  font-weight: bold;
  height: 100px;
  left: 10px;
  line-height: 100px;
  position: absolute;
  text-align: center;
  top: 10px;
  width: 130px;
}

#reason .four-reason .imgarea span:before,
#reason .four-reason .imgarea span:after{
  border: solid var(--color-yellow) 3px;
  box-sizing: border-box;
  content: "";
  display: block;
  height: 115px;
  position: absolute;
  width: 145px;
}

#reason .four-reason .imgarea span:before{
  left: 0;
  top: -15px;
}

#reason .four-reason .imgarea span:after{
  left: -15px;
  top: 0;
}

#reason .four-reason .imgarea span i{
  display: inline-block;
  font-size: 120%;
  margin-left: 5px;
}

#reason .four-reason .flex .imgarea img{
  width: 450px;
}

@media screen and (max-width: 800px) {
#reason .h2bg{
  height: auto;
  line-height: 1.2em;
  padding: 10px 0;
}

#reason .h2bg span{
  display: block;
}

#reason .wrapper{
  background-image: url(img/reason_sp.jpg);
  background-size: cover;
  height: auto;
  padding-top: 100%;
}

#reason .wrapper ul{
  padding: 50px 0;
  width: 90%;
}

#reason .wrapper li{
  font-size: 18px;
  line-height: 1.5em;
  margin: 0 0 20px;
  padding-left: 40px;
}

#reason .wrapper li:before{
  top: 0;
  width: 24px;
  height: 24px;
}

#reason .wrapper li:after {
  width: 6px;
  height: 10px;
  top: 4px;
  left: 7px;
  border-right: 3px solid var(--color-yellow);
  border-bottom: 3px solid var(--color-yellow);
}

#reason .four-reason h2 span{
  background-image: url(img/reason_title01_sp.png);
  background-repeat: no-repeat;
  background-size: contain;
  height: auto;
  padding-top: calc( 90% * 0.275);
  width: 90%;
}

#reason .four-reason .flex{
  width: 90%;
}

#reason .four-reason .flex:first-of-type{
  padding-top: 40px;
}

#reason .four-reason .flex div{
  padding: 0;
}

#reason .four-reason .flex .imgarea{
  padding: 40px 0 20px;
}

#reason .four-reason .flex .txtarea,
#reason .four-reason .flex:nth-of-type(even) .txtarea{
  padding: 0 0 60px;
}

#reason .four-reason .txtarea h3{
  font-size: 28px;
}

#reason .four-reason .flex:nth-of-type(odd){
  flex-direction: column;
}

#reason .four-reason .flex:nth-of-type(even){
  flex-direction: column-reverse;
}

#reason .four-reason .imgarea span{
  font-size: 50px;
  height: 70px;
  left: -5px;
  line-height: 70px;
  top: 10px;
  width: 90px;
}

#reason .four-reason .imgarea span:before,
#reason .four-reason .imgarea span:after{
  height: 77px;
  width: 97px;
}

#reason .four-reason .imgarea span:before{
  left: 0;
  top: -7px;
}

#reason .four-reason .imgarea span:after{
  left: -7px;
  top: 0;
}

#reason .four-reason .imgarea span i{
  display: inline-block;
  font-size: 120%;
  margin-left: 5px;
}


#reason .four-reason .flex .imgarea img{
  width: 100%;
}
}


/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝
#outcome　たった30分のトレーニングでこれだけの成果を獲得
＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
#outcome{
  background: #ffba00;
  padding: 60px 0;
}

#outcome h2{
  font-size: 60px;
  font-weight: bold;
  margin-bottom: 20px;
  text-align: center;
}

#outcome h2 span{
  color: #fff;
  display: block;
  font-size: 40px;
}

#outcome .wrapper{
  margin: 0 auto;
  width: 1000px;
}

#outcome .wrapper img{
  width: 49%;
}

#outcome .wrapper img:last-of-type{
  margin-left: 2%;
}

@media screen and (max-width: 1000px) {
#outcome .wrapper{
  width: 90%;
}
}

@media screen and (max-width: 800px) {
#outcome h2{
  font-size: 40px;
  margin-bottom: 20px;
}

#outcome h2 span{
  font-size: 30px;
}

#outcome .wrapper img{
  width: 100%;
}

#outcome .wrapper img:last-of-type{
  margin-left: 0;
  margin-top: 20px;
}
}

@media screen and (max-width: 600px) {
#outcome h2{
  font-size: 26px;
  margin-bottom: 20px;
}

#outcome h2 span{
  font-size: 20px;
}
}


/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝
#price　料金
＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
#price .wrapper{
  background-image: url(img/pricebg_pc.jpg);
  background-size: cover;
  padding: 50px 0 70px;
}

#price .wrapper .pricetable{
  list-style-type: none;
  margin: 0 auto;
  width: 1000px;
}

#price .wrapper .pricetable li{
  display: inline-block;
  width: 32%;
}

#price .wrapper .pricetable li:nth-of-type(2){
  margin: 0 2%;
}

#price .wrapper .fulltime{
  color: #fff;
  font-size: 30px;
  font-weight: bold;
  margin-bottom: 20px;
  text-align: center;
}

#price .wrapper .fulltime + .pricetable{
  width: 1000px;
}

#price .wrapper .fulltime + .pricetable li{
  display: inline-block;
  width: 49%;
}

#price .wrapper .fulltime + .pricetable li:nth-of-type(2){
  margin: 0 0 0 2%;
}

#price .wrapper table{
  border-collapse: collapse;
  box-sizing: border-box;
  margin: 0 auto 50px;
  width: 100%;
}

#price .wrapper th,
#price .wrapper td{
  text-align: center;
}

#price .wrapper th{
  background: var(--color-yellow);
  font-size: 24px;
  font-weight: bold;
  line-height: 60px;
}

#price .wrapper td{
  background: #fff;
}

#price .wrapper .price td{
  padding: 20px 0 0;
}

#price .wrapper .price td p:first-of-type{
  font-size: 20px;
  font-weight: bold;
}

#price .wrapper .price td p:first-of-type span{
  font-size: 280%;
  position: relative;
  z-index: 10;
}

#price .wrapper .price td p:first-of-type span:before{
  content: "";
  border-bottom: solid var(--color-yellow) 10px;
  bottom: 5px;
  display: block;
  left: 0;
  position: absolute;
  width: 100%;
  z-index: -1;
}

#price .wrapper .price td p:last-of-type{
  color: #666;
  margin: 0;
}

#price .wrapper .about td{
  padding: 0 20px;
}

#price .wrapper .about td p{
  border-bottom: solid #aaa 1px;
  font-size: 20px;
  padding: 20px 0;
}

#price .wrapper .time td{
  font-size: 20px;
  font-weight: bold;
  padding: 20px 0;
}

#price .wrapper .others{
  margin: 0 auto;
  width: 1000px;
}

#price .wrapper .others p{
  color: #fff;
  font-size: 22px;
  font-weight: bold;
}

#price .wrapper .fulltime + .pricetable li .about p{
  background: var(--color-orange);
  border-radius: 6px;
  color: #fff;
  font-size: 30px;
  font-weight: bold;
  margin: 20px 0;
  position: relative;
}

#price .wrapper .fulltime + .pricetable li .about p:after{
  border: solid transparent 16px;
  border-bottom: solid var(--color-orange) 10px;
  border-top: none;
  content: "";
  display: block;
  height: 0;
  left: 50%;
  margin-left: -16px;
  position: absolute;
  top: -10px;
  width: 0;
}

#price .wrapper .others ul{
  background: rgba(255,255,255,0.75);
  box-sizing: border-box;
  font-size: 18px;
  line-height: 2em;
  padding: 30px 50px;
}

@media screen and (max-width: 1000px) {
#price .wrapper{
  background-image: url(img/pricebg_sp.jpg);
}

#price .wrapper .pricetable,
#price .wrapper .fulltime + .pricetable{
  width: 90%;
}

#price .wrapper .pricetable li{
  width: 100%;
}

#price .wrapper .pricetable li:nth-of-type(2){
  margin: 0;
}

#price .wrapper .others{
  width: 90%;
}

#price .wrapper .others p{
  font-size: 18px;
}

#price .wrapper .others ul{
  font-size: 14px;
  line-height: 1.5em;
  padding: 10px 10px 10px 25px;
}
}

@media screen and (max-width: 700px) {
#price .wrapper .fulltime span{
  display: block;
}

#price .wrapper .fulltime + .pricetable li{
  display: inline-block;
  width: 100%;
}

#price .wrapper .fulltime + .pricetable li:nth-of-type(2){
  margin: 0;
}
}


/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝
#service　他社と比較してもわかるトレーニングジムごとの違い
＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
#service{
  background: var(--color-blue);
  padding: 50px 0;
}

#service h2{
  color: #fff;
  font-size: 40px;
  font-weight: bold;
  text-align: center;
}

#service h2 span{
  display: block;
  font-size: 80%;
}

#service .table{
  background-image: url(img/serviceimg_pc.png);
  background-size: cover;
  height: 645px;
  margin: 40px auto;
  width: 1000px;
}

#service p{
  color: #fff;
  display: block;
  margin: 0 auto;
  width: 1000px;
}

@media screen and (max-width: 800px) {
#service h2{
  font-size: 26px;
}

#service .table{
  background-image: url(img/serviceimg_sp.png);
  background-size: contain;
  height: auto;
  padding-top: calc(90% * 1.07);
  margin: 40px auto;
  width: 90%;
}

#service p{
  font-size: 12px;
  width: 90%;
}
}


/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝
#campaign　キャンペーン
＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
#campaign{
  background-image: url(img/campaignbg_pc.jpg);
  background-position: 40% top;
  background-size: cover;
  padding: 50px 0;
}

#campaign h2{
  background: #fff;
  box-shadow: 5px 5px 0 0 #000;
  font-size: 30px;
  font-weight: bold;
  height: 100px;
  line-height: 100px;
  margin: 0 auto 50px;
  position: relative;
  text-align: center;
  width: 500px;
}

#campaign h2 span{
  font-size: 130%;
}

#campaign h2 span:last-of-type{
  font-size: 150%;
}

#campaign h2:before{
  border: solid transparent 12px;
  border-top: solid #000 20px;
  bottom: -34px;
  content: "";
  height: 0;
  left: 50%;
  margin-left: -7px;
  position: absolute;
  width: 0;
}

#campaign h2:after{
  border: solid transparent 12px;
  border-top: solid #fff 20px;
  bottom: -32px;
  content: "";
  height: 0;
  left: 50%;
  margin-left: -12px;
  position: absolute;
  width: 0;
}

#campaign img{
  display: block;
  margin: 0 auto;
  width: 900px;
}

#campaign .marulist{
  margin: 30px auto;
  text-align: center;
}

#campaign .marulist li{
  height: 230px;
  margin-right: 20px;
  width: 230px;
}

#campaign .marulist li p:first-of-type{
  font-size: 20px;
  line-height: 50px;
  margin: -5px 0 20px;
}

#campaign .marulist li:last-of-type p:first-of-type{
  line-height: 24px;
}

#campaign .marulist li:last-of-type p:first-of-type span{
  font-size: 14px;
  margin: 0;
}

#campaign .marulist li p:last-of-type{
  font-size: 35px;
  line-height: 1.2em;
}

#campaign .marulist li p:last-of-type span{
  display: inline-block;
  font-size: 16px;
  line-height: 1.2em;
}

#campaign .marulist li:nth-of-type(3) p:last-of-type,
#campaign .marulist li:nth-of-type(4) p:last-of-type{
  padding-top: 10px;
}

#campaign .linkbtn + p{
  color: #fff;
  font-size: 20px;
  font-weight: bold;
  margin-top: 10px;
  text-align: center;
}

#campaign .kome{
  color: #fff;
  padding-right: 40px;
  text-align: right;
}

@media screen and (max-width: 1000px) {
#campaign{
  background-image: url(img/campaignbg_sp.jpg);
  background-position: center top;
  padding: 30px 0;
}

#campaign h2{
  font-size: 18px;
  height: 80px;
  line-height: 80px;
  margin: 0 auto 50px;
  width: 90%;
}

#campaign img{
  width: 100%;
}

#campaign .marulist{
  width: 90%;
}

#campaign .marulist li{
  height: auto;
  margin-right: 2%;
  padding-top: 46%;
  position: relative;
  width: 49%;
}

#campaign .marulist li:nth-of-type(1),
#campaign .marulist li:nth-of-type(2){
  margin-bottom: 30px;
}

#campaign .marulist li:nth-of-type(even){
  margin-right: 0;
}

#campaign .marulist li p{
  position: absolute;
}

#campaign .marulist li p:first-of-type{
  font-size: 14px;
  line-height: 30px;
  margin: 0;
  top: -5px;
  width: 100%;
}

#campaign .marulist li:last-of-type p:first-of-type{
  line-height: 14px;
}

#campaign .marulist li:last-of-type p:first-of-type span{
  font-size: 10px;
  margin: 0;
}

#campaign .marulist li p:last-of-type{
  font-size: 24px;
  line-height: 1.2em;
  margin-top: -34px;
  top: 50%;
  width: 100%;
}

#campaign .marulist li:first-of-type p:last-of-type{
  margin-top: -30px;
}

#campaign .marulist li p:last-of-type span{
  display: block;
  font-size: 12px;
  line-height: 1.2em;
}

#campaign .kome{
  padding-right: 5%;
  padding-top: 40px;
  text-align: right;
}
}


/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝
#trainer　神楽坂飯田橋店のトレーナー
＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
#trainer{
  padding: 50px 0;
}

#trainer h2{
  border-bottom: solid var(--color-yellow) 5px;
  font-size: 40px;
  font-weight: bold;
  margin: 0 auto 40px;
  max-width: 1000px;
  text-align: center;
  width: 90%;
}

#trainer .wrapper{
  margin: 0 auto;
  width: 1000px;
}

#trainer p{
  margin-bottom: 1em;
}

#trainer h3{
  font-size: 30px;
  font-weight: bold;
  margin: 0 0 20px;
}

#trainer h3 span{
  background: var(--color-orange);
  border-radius: 6px;
  color: #fff;
  display: block;
  font-size: 70%;
  padding: 5px 0;
}

#trainer .twoshot{
  float: left;
  width: 30%;
}

#trainer .box02{
  clear: both;
  margin: 60px auto 0;
  width: 60%;
}

#trainer .box02 ul{
  margin: 2em 0;
  padding-left: 1.3em;
}

#trainer .box02 ul li{
  margin-bottom: 0.5em;
}

#trainer .box02 h3{
  text-align: center;
}

#trainer .box02 h3:last-of-type{
  margin-top: 40px;
}

#trainer .box02 img{
  display: block;
  margin: 0 auto 40px;
  width: 100%;
}

@media screen and (max-width: 1000px) {
#trainer .wrapper{
  margin: 0 auto;
  width: 90%;
}

#trainer h2{
  font-size: 26px;
}

#trainer .twoshot{
  float: initial;
  margin-bottom: 20px;
  width: 100%;
}

#trainer h3{
  font-size: 20px;
}

#trainer .box01{
  padding-left: 0%;
}

#trainer .box02{
  width: 100%;
}
}


/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝
#shopinfo　店舗情報
＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
#shopinfo{
  padding: 50px 0;
}

#shopinfo .wrapper{
  margin: 0 auto;
  max-width: 1000px;
  padding: 50px 0;
  width: 90%;
}

#shopinfo .wrapper ul{
  list-style: none;
  margin: 0 0 60px;
  padding: 0;
}

#shopinfo .wrapper ul li{
  display: inline-block;
  vertical-align: top;
  width: 50%;
}

#shopinfo .wrapper ul li p{
  font-size: 26px;
  font-weight: bold;
  margin: 0 0 20px;
}

#shopinfo .wrapper ul li .other{
  color: #000;
}

#shopinfo .wrapper ul li table{
  font-size: 14px;
}

#shopinfo .wrapper ul li table th{
  font-weight: bold;
  padding-bottom: 15px;
  padding-right: 15px;
  white-space: nowrap;
}

#shopinfo .wrapper ul li table td{
  padding-bottom: 15px;
  padding-right: 40px;
}

#shopinfo h3{
  border-bottom: solid var(--color-yellow) 5px;
  font-size: 30px;
  font-weight: bold;
  margin: 0 0 40px;
  text-align: center;
}

#shopinfo .movie_wrapper{
  height: auto;
  margin: 0 auto 60px;
  padding-top: 56.25%;
  position: relative;
  width: 100%;
}

#shopinfo .movie_wrapper iframe{
  height: 100%;
  position: absolute;
  top: 0;
  width: 100%;
}

#shopinfo .interior li{
  background: #fff;
  box-shadow: 1px 1px 10px 5px #ddd;
  width: 48%!important;
}

#shopinfo .interior li:nth-of-type(odd){
  margin-right: 4%;
}

#shopinfo .interior li:nth-of-type(1),
#shopinfo .interior li:nth-of-type(2){
  margin-bottom: 40px;
}

#shopinfo .interior img{
  margin: 0 0 20px;
  width: 100%;
}

#shopinfo .interior h4{
  font-size: 16px;
  font-weight: bold;
  margin: 0 0 15px;
  text-align: center;
}

#shopinfo .interior p{
  display: block;
  font-size: 14px!important;
  font-weight: normal!important;
  height: 5em;
  padding: 0 20px;
}

@media screen and (max-width: 1000px) {
#shopinfo{
  padding:  0;
}

#shopinfo .wrapper{
  padding: 30px 0 50px;
}

#shopinfo .wrapper ul li{
  display: block;
  width: 100%;
}

#shopinfo .wrapper ul li table td{
  padding-right: 0;
}

#shopinfo .interior li{
  box-shadow: 1px 1px 10px 5px #ddd;
  margin-bottom: 40px;
  width: 100%!important;
}

#shopinfo .interior li:nth-of-type(odd){
  margin-right: 0;
}

#shopinfo .interior p{
  height: auto;
  padding-bottom: 40px;
}
}


/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝
#allstores　ELEMENT全店舗
＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
#allstores{
  padding: 50px 0;
}

#allstores .wrapper{
  margin: 0 auto;
  max-width: 1000px;
  padding: 50px 0;
  width: 90%;
}

#allstores .wrapper .caption{
  color: var(--color-orange);
  font-size: 40px;
  font-weight: bold;
  text-align: center;
}

#allstores .wrapper .caption+p{
  margin: 0 0 40px;
  text-align: center;
}

#allstores h3{
  font-size: 30px;
  font-weight: bold;
  margin: 0 0 20px;
  text-align: center;
}

#allstores .wrapper ul{
  list-style: none;
  margin: 0 0 40px;
}

#allstores .wrapper ul li{
  background: #ffbb02;
  display: inline-block;
  font-size: 14px;
  font-weight: bold;
  height: 60px;
  line-height: 60px;
  margin-right: 2%;
  margin-bottom: 2%;
  text-align: center;
  vertical-align: top;
  width: 23.5%;
}

#allstores .wrapper ul li.indention{
  line-height: 45px;
}

#allstores .wrapper ul li span{
  display: block;
  font-size: 10px;
  line-height: 0px;
}

#allstores .wrapper ul li:nth-of-type(4n){
  margin-right: 0;
}

#allstores .wrapper .pit{
  text-align: right;
}

@media screen and (max-width: 1000px) {
#allstores{
  padding: 0;
}

#allstores .wrapper{
  padding: 30px 0 50px;
}

#allstores .wrapper .caption{
  font-size: 30px;
  text-align: center;
}

#allstores .wrapper .caption+p{
  text-align: left;
}
}

@media screen and (max-width: 800px) {
#allstores .wrapper .caption{
  margin: 0 0 10px;
}

#allstores .wrapper .caption span{
  display: block;
}

#allstores .wrapper .caption+p{
  font-size: 14px;
}

#allstores .wrapper ul li{
  width: 32%;
}

#allstores .wrapper ul li:nth-of-type(4n){
  margin-right: 2%;
}

#allstores .wrapper ul li:nth-of-type(3n){
  margin-right: 0;
}
}

@media screen and (max-width: 650px) {
#allstores .wrapper .caption+p{
  margin: 0 0 20px;
}

#allstores .wrapper ul li{
  font-size: 13px;
  width: 49%;
}

#allstores .wrapper ul li:nth-of-type(4n){
  margin-right: 0;
}

#allstores .wrapper ul li:nth-of-type(3n){
  margin-right: 2%;
}

#allstores .wrapper ul li:nth-of-type(even){
  margin-right: 0;
}
}

@media screen and (max-width: 500px) {
#allstores .wrapper .caption{
  font-size: 24px;
}
}


/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝
#media　今、注目の通い放題パーソナルジムELEMENT
＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
#media{
  padding: 50px 0;
}

#media h2{
  background: #fff;
  box-shadow: 5px 5px 0 0 #000;
  font-size: 30px;
  font-weight: bold;
  height: 100px;
  line-height: 100px;
  margin: 0 auto 50px;
  position: relative;
  text-align: center;
  width: 800px;
}

#media h2:before{
  border: solid transparent 12px;
  border-top: solid #000 20px;
  bottom: -34px;
  content: "";
  height: 0;
  left: 50%;
  margin-left: -7px;
  position: absolute;
  width: 0;
}

#media h2:after{
  border: solid transparent 12px;
  border-top: solid #fff 20px;
  bottom: -32px;
  content: "";
  height: 0;
  left: 50%;
  margin-left: -12px;
  position: absolute;
  width: 0;
}

#media ul{
  list-style-type: none;
  margin: 0 auto;
  width: 1000px;
}

#media li{
  display: inline-block;
  position: relative;
  vertical-align: top;
  width: 48%;
}

#media li .image{
  width: 100%;
}

#media li .icon{
  left: -50px;
  position: absolute;
  top: -40px;
  width: 140px;
}

#media li:first-of-type{
  margin-right: 4%;
}

#media li p{
  font-size: 20px;
  font-weight: bold;
  text-align: center;
}

@media screen and (max-width: 1000px) {
#media h2{
  font-size: 18px;
  height: 80px;
  line-height: auto;
  margin: 0 auto 50px;
  width: 90%;
}

#media h2 p{
  display: table;
  height: 100%;
  width: 100%;
}

#media h2 span{
  display: table-cell;
  line-height: 1.5em;
  vertical-align: middle;
}

#media h2 span span{
  display: block;
}

#media ul{
  width: 90%;
}

#media li{
  width: 100%;
}

#media li .icon{
  left: -30px;
  top: -40px;
  width: 100px;
}

#media li:first-of-type{
  margin-bottom: 40px;
  margin-right: 0;
}

#media li p{
  font-size: 14px;
}
}


/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝
#voice　ELEMENTの体験者の声
＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
#voice{
  background: #ffeac1;
  padding: 0 0 50px;
}

#voice .wrapper{
  margin: 50px auto 0;
  width: 1000px;
}

#voice .movie{
  margin: 0 auto;
  padding-top: 56.25%;
  position: relative;
  width: 100%;
}

#voice .movie iframe{
  height: 100%;
  left: 0;
  position: absolute;
  top: 0;
  width: 100%;
}

#voice img{
  display: block;
  margin: 0 auto;
  max-width: 100%;
}

#voice ul{
  list-style-type: none;
  margin: 50px auto 0;
}

#voice li{
  background: #fff;
  border: solid var(--color-yellow) 4px;
  border-radius: 15px;
  display: block;
  font-weight: bold;
  margin-bottom: 2%;
  margin-right: 30%;
  padding: 20px;
  position: relative;
  transform: rotate(-1deg);
  width: 70%;
}

#voice li:before,
#voice li:after{
  border: solid transparent 20px;
  border-bottom: none;
  border-right: solid transparent 5px;
  content:"";
  display: block;
  position: absolute;
}

#voice li:before{
  border-top: solid var(--color-yellow) 30px;
  bottom: -30px;
  left: 100px;
}

#voice li:after{
  border-top: solid #fff 30px;
  bottom: -22px;
  left: 98px;
}

#voice li:nth-of-type(even){
  margin-left: 30%;
  margin-right: 0;
  transform: rotate(1deg);
}

#voice li:nth-of-type(even):before,
#voice li:nth-of-type(even):after{
  border-left: solid transparent 5px;
  border-right: solid transparent 20px;
  transform: rotate(1deg);
}

#voice li:nth-of-type(even):before{
  border-top: solid var(--color-yellow) 30px;
  left: initial;
  right: 100px;
}

#voice li:nth-of-type(even):after{
  border-top: solid #fff 30px;
  left: initial;
  right: 98px;
}

#voice li span{
  color: var(--color-orange);
  font-size: 120%;
}

#voice li img{
  width: 100%;
}

@media screen and (max-width: 1000px) {
#voice .wrapper{
  margin: 30px auto 0;
  width: 90%;
}

#voice ul{
  list-style-type: none;
  margin: 30px auto 60px;
}

#voice li{
  margin-bottom: 40px;
  margin-right: 0;
  padding: 10px;
  width: 90%;
}

#voice li:nth-of-type(even){
  margin-left: 0;
}
}

@media screen and (max-width: 600px) {
#voice li{
  margin-right: 0;
  width: 100%;
}
}


/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝
#faq　よくあるご質問
＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
#faq{
  background: #eee;
  padding: 0 0 70px;
}

#faq ul{
  list-style-type: none;
  margin: 50px auto 0;
  width: 1000px;
}

#faq ul input[type="checkbox"]{
  display: none;
}

#faq ul li{
  background: #fff;
  box-shadow: 0 3px 10px 0 #ccc;
  margin: 0 0 10px;
  padding: 0 40px;
}

#faq ul .question{
  cursor: pointer;
  font-size: 20px;
  font-weight: bold;
  height: 80px;
  line-height: 80px;
  position: relative;
}

#faq ul .question span{
  color: var(--color-yellow);
  display: inline-block;
  font-size: 180%;
  margin-right: 30px;
  vertical-align: middle;
}

#faq ul .question:before,
#faq ul .question:after{
  background: #ccc;
  content: "";
  display: block;
  height: 2px;
  position: absolute;
  right: 0;
  top: 39px;
  transition : all 0.3s ease 0s;
  width: 30px;
}

#faq ul .question:after{
  transform: rotate(90deg);
}

#faq ul input[type="checkbox"]:checked +label .question:after{
  transform: rotate(0deg);
}

#faq ul .answer{
  border-top: solid #fff 1px;
  line-height: 1.7em;
  max-height: 0;
  overflow: hidden;
  padding: 0;
  transition : all 0.3s ease 0s;
}

#faq ul input[type="checkbox"]:checked +label + .answer{
  border-top: solid #333 1px;
  max-height: 200px;
  padding: 30px 0;
}

@media screen and (max-width: 1000px) {
#faq ul{
  margin: 30px auto 0;
  width: 95%;
}

#faq ul li{
  padding: 0;
}

#faq ul li label{
  display: table;
  height: 80px;
  position: relative;
  vertical-align: middle;
  width: 100%;
}

#faq ul .question{
  display: table-cell;
  font-size: 16px;
  height: auto;
  line-height: 1.5em;
  padding: 0 45px;
  vertical-align: middle;
}

#faq ul .question span{
  left: 10px;
  position: absolute;
  top: 26px;
}

#faq ul .question:before,
#faq ul .question:after{
  right: 10px;
  top: 39px;
  width: 16px;
}

#faq ul .answer{
  margin: 0 20px;
  padding: 0;
}

#faq ul input[type="checkbox"]:checked +label + .answer{
  border-top: solid #333 1px;
  max-height: 200px;
  padding: 20px 0;
}
}


/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝
#footer　フッター
＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
footer .reserve{
  background: var(--color-yellow);
  padding: 50px 0 70px;
  text-align: center;
}

footer .reserve h2{
  color: #fff;
  font-size: 40px;
  font-weight: bold;
  margin-bottom: 40px;
}

footer .reserve p:first-of-type{
  background: #fff;
  border: solid var(--color-orange) 2px;
  border-radius: 1em;
  color: var(--color-orange);
  display: inline-block;
  font-weight: bold;
  line-height: 2em;
  margin-bottom: 5px;
  padding: 0 40px;
  position: relative;
}

footer .reserve p:first-of-type:before,
footer .reserve p:first-of-type:after{
  border: solid transparent 10px;
  border-bottom: none;
  content: "";
  display: block;
  height: 0;
  left: 50%;
  margin-left: -10px;
  position: absolute;
  width: 0;
}

footer .reserve p:first-of-type:before{
  border-top: solid #f0653b 10px;
  bottom: -12px;
}

footer .reserve p:first-of-type:after{
  border-top: solid #fff 10px;
  bottom: -10px;
}

footer .copyright{
  background: var(--color-blue);
  color: #fff;
  font-size: 12px;
  line-height: 60px;
  text-align: center;
}

.bottom_fixbox{
  background: rgba(0,0,0,0.7);
  bottom: 0;
  display: none;
  left: 0;
  padding: 15px 0;
  position: fixed;
  text-align: center;
  width: 100%;
  z-index: 1000;
}

.bottom_fixbox a{
  display: inline-block;
  vertical-align: top;
  width: 45%;
}

.bottom_fixbox a:first-of-type{
  margin-right: 5px;
}

.bottom_fixbox a img{
  width: 100%;
}

@media screen and (max-width: 800px) {
footer .reserve h2{
  font-size: 34px;
}

footer .reserve h2 span{
  display: block;
}

footer .copyright{
  padding-bottom: 20%;
}

.bottom_fixbox{
  display: block;
}
}


/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝
#mailform　フッターフォーム
＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
#mailform{
  background: #ededed;
  padding: 50px 0;
}

#mailform .wrapper{
  background: #fff;
  box-shadow: 0 3px 10px 0 #ccc;
  margin: 0 auto;
  padding: 30px 100px;
  width: 1000px;
}

footer #mailform .wrapper table{
  width: 100%;
}

footer #mailform .wrapper th,
footer #mailform .wrapper td{
  display: block;
}

footer #mailform .wrapper th{
  font-weight: bold;
  line-height: 20px;
  padding: 20px 0 10px;
  text-align: left;
}

footer #mailform .wrapper th span{
  background: #444;
  color: #fff;
  display: inline-block;
  font-size: 80%;
  font-weight: normal;
  margin-left: 10px;
  padding: 0 10px;
  vertical-align: top;
}

footer #mailform .wrapper th span:nth-of-type(2){
  background: none;
  color: #444;
  margin-left: 5px;
  padding: 0;
}

footer #mailform input[type="text"]{
  background: #f6f6f6;
  box-sizing: border-box;
  display: block;
  line-height: 70px;
  padding: 0 20px;
  width: 100%;
}

footer #mailform .taiken label{
  background: #f6f6f6;
  border-radius: 5px;
  color: #ccc;
  cursor: pointer;
  display: inline-block;
  font-weight: bold;
  line-height: 70px;
  margin-right: 10px;
  padding: 0 0 0 20px;
  position: relative;
  width: 35%;
}

footer #mailform .taiken label:before{
  background: #ccc;
  box-sizing: border-box;
  border-radius: 17px;
  content: "";
  position: absolute;
  top: 18px;
  right: 10px;
  width: 34px;
  height: 34px;
}

footer #mailform .taiken label:after {
  content: "";
  position: absolute;
  width: 7px;
  height: 16px;
  top: 23px;
  right: 21px;
  -webkit-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  transform: rotate(45deg);
  border-right: 4px solid #fff;
  border-bottom: 4px solid #fff;
}

footer #mailform .taiken input[type="radio"]:checked + label{
  background: var(--color-yellow);
  color: #fff;
}

footer #mailform .taiken input[type="radio"]:checked + label:before{
  background: #fff;
}

footer #mailform .taiken input[type="radio"]:checked + label:after{
  border-right: 5px solid var(--color-yellow);
  border-bottom: 5px solid var(--color-yellow);
}

footer #mailform .taikenzero{
  color: #999;
  font-size: 12px;
  margin: 10px 0;
}

footer #mailform .date input,
footer #mailform .date select{
  background: #f6f6f6;
  border: solid #eee 2px;
  box-sizing: border-box;
  color: #000;
  cursor: pointer;
  display: inline-block;
  height: 70px;
  line-height: 70px;
  padding: 0 20px;
  text-align: left;
  vertical-align: top;
  width: 40%;
}

input[type=date]::-webkit-date-and-time-value {
    text-align: left;
}

footer #mailform textarea{
  background: #f6f6f6;
  box-sizing: border-box;
  margin: 0 0 40px;
  padding: 10px;
  width: 100%;
}

footer #mailform p.privacy{
  font-weight: bold;
  text-align: center;
}

footer #mailform .privacy-wrapper{
  border: solid #aaa 1px;
  font-size: 12px;
  height: 150px;
  overflow: scroll;
  padding: 10px;
}

footer #mailform .privacy-wrapper p{
  margin: 0 0 1em;
}

footer #mailform label.agree{
  display: block;
  font-weight: bold;
  margin: 30px 0 50px;
  text-align: center;
}

#mailform input[type="submit"],
body.mailform input[type="button"]{
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  border-top: none;
  border-bottom: solid #457c01 5px;
  outline: none;
}

#mailform input[type="submit"]:hover,
body.mailform input[type="button"]:hover{
  border-bottom: solid #ae1308 5px;
}

body.mailform h2{
  background: var(--color-yellow);
  color: #fff;
  font-size: 40px;
  font-weight: bold;
  padding: 50px 0;
  text-align: center;
}

body.mailform h3{
  font-size: 24px;
  font-weight: bold;
  margin: 0 0 40px;
  text-align: center;
}

body.mailform h4{
  font-size: 18px;
  font-weight: bold;
  margin: 0 0 20px;
  text-align: center;
}

body.mailform .errlist{
  margin: 0 0 40px;
}

body.mailform .errlist p{
  background: #eee;
  line-height: 3em;
  margin: 0 0 10px;
  text-align: center;
}

footer #mailform .date td ul{
  border: solid #999 1px;
  margin: 0 0 20px;
  padding: 15px 15px 15px 30px;
}

@media screen and (max-width: 1000px) {
#mailform .wrapper{
  padding: 20px;
  width: 95%;
}

footer #mailform .taiken label{
  display: block!important;
  padding: 0 0 0 20px;
  width: 50%;
}
}

@media screen and (max-width: 800px) {
#mailform .wrapper{
  padding: 20px 10px;
}

footer #mailform .taiken label{
  width: 100%;
}

footer #mailform .date input,
footer #mailform .date select{
  margin-bottom: 10px;
  width: 100%;
}

body.mailform h2{
  font-size: 34px;
}

body.mailform h2 span{
  display: block;
}

footer #mailform .date td ul{
  font-size: 14px;
}
}


/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝
フォーム確認画面
＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
#mailform .formTable{
  border-collapse: collapse;
  margin: 0 0 20px;
  width: 100%;
}

#mailform .formTable th{
  border: solid #ddd 2px;
  background: #f6f6f6;
  padding: 5px;
  white-space: nowrap;
}

#mailform .formTable td{
  border: solid #ddd 2px;
  padding: 5px;
}

#mailform .back{
  border: none;
  border-radius: 6px;
  font-size: 1rem;
  margin: 20px 0;
  padding: 10px 20px;
}

/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝
#cp-banner　キャンペーンバナー
＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
#cp-banner{
  padding: 60px 0;
}

.cp-banner,
#cp-banner img{
  display: block;
  margin: 0 auto;
  width: 90%;
  max-width: 800px;
}

@media screen and (max-width: 800px) {
#cp-banner{
  padding: 30px 0;
}
}


/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝
#diagnose_form　無料体験からだの状態を診断
＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
#diagnose_form{
  background: #ffe9ad;
  padding: 0;
}

#diagnose_form .cp-banner{
  margin: 0 auto;
}

#diagnose_form .wrapper{
  background: #fff;
  border-radius: 10px;
  border: solid var(--color-yellow) 8px;
  height: 450px;
  margin: 0 auto;
  max-width: 1000px;
  overflow: hidden;
  padding: 30px;
  position: relative;
  width: 90%;
  
  display: none;
}

#diagnose_form .question_wrapper{
  align-items: center;
  color: #333;
  display: grid;
  height: calc(100% - 120px);
  position: absolute;
  text-align: center;
  transition : all 0.3s ease 0s;
  vertical-align: middle;
  width: calc(100% - 60px);
}

#diagnose_form .question_wrapper.display{
  left: 30px;
}

#diagnose_form .question_wrapper.left{
  right: 100%;
}

#diagnose_form .question_wrapper.right{
  left: 100%;
}

#diagnose_form .question_wrapper .caption{
  font-size: 30px;
  font-weight: bold;
  margin: 0 0 1em;
}

#diagnose_form .question_wrapper .caption span{
  color: var(--color-yellow);
  font-size: 150%;
}

#diagnose_form .question_wrapper .question_txt{
  font-size: 30px;
  font-weight: bold;
  margin: 0 0 1em;
}

#diagnose_form .question_wrapper .question_txt:after{
  background: #444;
  content:"必須" ;
  color: #fff;
  display: inline-block;
  font-size: 20px;
  height: 30px;
  line-height: 30px;
  margin-left: 10px;
  padding: 0 10px;
}

#diagnose_form #q03.question_wrapper .question_txt{
  margin: 0;
}

#diagnose_form #q03 #mail,
#diagnose_form #q03 #tel{
  margin: 0 0 40px;
}

#diagnose_form .question_wrapper .question_txt span{
  position: relative;

  z-index: 100;
}

#diagnose_form .question_wrapper .question_txt span:before{
  background: #fe0;
  bottom: 0;
  content: "";
  display: inline-block;
  height: 10px;
  left: 0;
  position: absolute;
  width: 100%;
  z-index: -1;
}

#diagnose_form .question_wrapper .catch{
  color: var(--color-yellow);
  font-weight: bold;
}

#diagnose_form .question_wrapper label{
  background: #eee;
  border-radius: 5px;
  cursor: pointer;
  display: inline-block;
  color: #999;
  font-size: 22px;
  font-weight: bold;
  height: 80px;
  line-height: 80px;
  width: 350px;
}

#diagnose_form .question_wrapper input[type="radio"]:checked+label{
  background: var(--color-yellow);
  color: #fff;
}

#diagnose_form .question_wrapper input[type="text"]{
  background: #fafafa;
  border: solid #ddd 1px;
  border-radius: 5px;
  font-size: 24px;
  height: 50px;
  line-height: 50px;
  padding: 0 10px;
  width: 460px;
}

#diagnose_form .question_wrapper ul{
  list-style: none;
}

#diagnose_form .question_wrapper ul li{
  display: inline-block;
}

#diagnose_form .question_wrapper ul li:nth-of-type(even){
  padding: 0 20px;
}

#diagnose_form .question_wrapper ul li input,
#diagnose_form .question_wrapper ul li select{
  border: solid #ddd 1px;
  box-sizing: border-box;
  display: block;
  height: 50px;
  line-height: 50px;
  padding: 0 10px;
  width: 100%;
}

#diagnose_form .question_wrapper ul li input{
  margin: 0 0 20px;
}

#diagnose_form .btn_wrapper{
  bottom: 30px;
  position: absolute;
  text-align: center;
  width: calc(100% - 60px);
  height: 60px;
}

#diagnose_form .btn_wrapper > div{
  opacity: 0;
  position: absolute;
  transition : all 0.3s ease 0s;
  top: 0;
  width: 100%;
  z-index: -10;
}

#diagnose_form .btn_wrapper > div.display{
  opacity: 1;
  z-index: 10;
}

#diagnose_form .btn_wrapper button,
#diagnose_form .btn_wrapper #send{
  background: var(--color-yellow);
  border: none;
  border-radius: 6px;
  color: #fff;
  cursor: pointer;
  display: inline-block;
  font-size: 18px;
  font-weight: bold;
  height: 60px;
  line-height: 60px;
  text-align: center;
  width: 200px;
}

#diagnose_form .btn_wrapper button:disabled,
#diagnose_form .btn_wrapper #send:disabled{
  background: #eee;
}

#diagnose_form input[type="text"]:disabled{
  background: #ddd;
}

#diagnose_form .btn_wrapper button.back{
  margin-right: 80px;
}

#diagnose_form .btn_wrapper button:hover{
  opacity: 0.8;
}

@media screen and (max-width: 800px) {
#diagnose_form .wrapper{
  height: 650px;
}

#diagnose_form .question_wrapper .caption span{
  display: block;
}

#diagnose_form .question_wrapper .question_txt{
  font-size: 18px;
}

#diagnose_form .question_wrapper .question_txt:after{
  font-size: 14px;
  height: 18px;
  line-height: 18px;
}

#diagnose_form .question_wrapper label{
  display: block;
  margin: 0 auto 15px;
}

#diagnose_form .question_wrapper ul li,
#diagnose_form .question_wrapper ul li:nth-of-type(even){
  display: block;
  padding: 0 0 15px;
}

#diagnose_form .question_wrapper ul li input,
#diagnose_form .question_wrapper ul li select{
  height: 40px;
  line-height: 40px;
}

#diagnose_form .question_wrapper ul li input{
  margin: 0 0 5px;
}
}

@media screen and (max-width: 600px) {
#diagnose_form .wrapper{
  height: 600px;
  padding: 20px 10px;
}

#diagnose_form .question_wrapper{
  height: calc(100% - 120px);
  width: calc(100% - 20px);
}

#diagnose_form .question_wrapper.display{
  left: 10px;
}

#diagnose_form .question_wrapper .caption{
  font-size: 24px;
}

#diagnose_form .question_wrapper .caption span{
  display: block;
}

#diagnose_form .question_wrapper .question_txt{
  font-size: 16px;
}

#diagnose_form .question_wrapper .question_txt:after{
  font-size: 12px;
  height: 16px;
  line-height: 16px;
}

#diagnose_form .question_wrapper label{
  display: block;
  margin: 0 auto 15px;
  height: 60px;
  line-height: 60px;
  width: 90%;
}

#diagnose_form .question_wrapper ul li,
#diagnose_form .question_wrapper ul li:nth-of-type(even){
  display: block;
  padding: 0 0 15px;
}

#diagnose_form .question_wrapper ul li input,
#diagnose_form .question_wrapper ul li select{
  font-size: 14px;
  height: 30px;
  line-height: 30px;
}


#diagnose_form .question_wrapper ul li input{
  margin: 0 0 5px;
}

#diagnose_form .question_wrapper input[type="text"]{
  box-sizing: border-box;
  font-size: 20px;
  width: 100%;
}

#diagnose_form .btn_wrapper{
  bottom: 30px;
  width: calc(100% - 20px);
}

#diagnose_form .btn_wrapper button,
#diagnose_form .btn_wrapper #send{
  font-size: 16px;
  height: 50px;
  line-height: 50px;
  width: 140px;
}

#diagnose_form .btn_wrapper button.back{
  margin-right: 10px;
}
}


/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝
#back-top　TOPへ戻るボタン
＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
#back-top{
  display:block;
  width:80px;
  height:80px;
  position:fixed;
  bottom:60px;
  right: 20px;
  z-index: 3000;
}

#back-top a{
  display:block;
  width:80px;
  height:80px;
  border-radius:40px;
  background: rgba( 255,255,255,0.4);
  border:solid rgba(0,0,0,0.2) 1px;
  position:relative;
}

#back-top a:hover{
  background:#fff;
}

#back-top a span{
  display:block;
  width: 20px;
  height: 20px;
  border-top: 3px solid #333;
  border-left: 3px solid #333;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  margin:35px auto;
}

@media screen and (max-width:800px) {
#back-top{
  width: 60px;
  height: 60px;
  bottom: 100px;
  right:10px;
}

#back-top a{
  width: 60px;
  height: 60px;
  border-radius:30px;
}

#back-top a span{
  border-top: 3px solid #333;
  border-left: 3px solid #333;
  margin: 25px auto;
}
}