@charset "utf-8";

figure.none img {
	box-shadow: none!important;
	background: none!important;
}

/*===============================================
●画面の横幅が769px以上
===============================================*/
@media screen and (min-width : 769px ){
#pc------------------------------------------- {
}
main .btn a {
	position: relative;
}
main .btn a span {
	position: absolute;
	right: 4.5vw;
	top: 1.4vw;
	display: block;
	width: 0.6vw;
	height: 1vw;
}
body {
	font-size: 0.9375vw;
}
main img {
	width: 100%;
	height: auto;
}
#helo {
	position: relative;
	height: 100vh;
}
#helo .inner {
	position: absolute;
	left: 0px;
	right: 0px;
	top: 5.20833333333vw;
	z-index: 999;
	width: 80%;
	margin-left: auto;
	margin-right: auto;
	text-align: left;
}
#helo .inner h2 {
color: #FFF;
text-shadow: 0 4px 8px rgba(0, 0, 0, 0.25);
font-family: "Noto Serif JP";
font-size: 3.64583333333vw;
font-style: 500;
font-weight: 300;
line-height: 1.2em; /* 114.286% */
}
#helo .inner h2 span {
font-size: 3.22916666667vw;
}
#helo .inner p {
color: #FFF;
text-shadow: 0 4px 8px rgba(0, 0, 0, 0.25);
font-family: "Noto Serif JP";
font-size: 1.77083333333vw;
font-style: normal;
font-weight: 400;
margin-top: 20px;
line-height: 1.8em; /* 176.471% */
}
#helo .slide {
	width: 100%;
	height: 90vh;
	position: relative;
	overflow: hidden;
}
#helo .slide .img {
	position: absolute;
	inset: 0;
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	opacity: 0;
	transform: scale(1.1);
	transition:
		opacity 3s ease,
		transform 5s linear;
	border-radius: 1vw;
}

#helo .slide .img.active {
	opacity: 1;
	transform: scale(1);
}

#helo .slide .img.fadeout {
	opacity: 0;
	transform: scale(1); /* ←拡大しない */
	transition:
		opacity 1.2s ease,
		transform 0s linear;
}
#helo .line {
	position: absolute;
	right: 3vw;
	bottom: 10vw;
	width: 30vw;
}






#group h2 {
	font-size: 2.0833vw;
	margin-bottom: 2.0833vw;
}











#concept {
	background-color: #FAFAFA;
	margin-top: 7.8125vw;
	padding-top: 7.8125vw;
	padding-bottom: 7.8125vw;
}
#concept .flex {
	display: flex;
	flex-direction: row-reverse;
}
#concept .flex figure {
	width: 50vw;
	margin-right: 5.20833333333vw;
}
#concept .flex figure img {
	width: 100%;
	height: auto;
	background: url(<path-to-image>) lightgray 50% / cover no-repeat;
box-shadow: 30px 30px 0 0 rgba(140, 140, 140, 0.25);
}

#concept .flex div {
	width: 47%;
}
#concept .flex div p {
	text-align: left;
	margin-top: 30px;
	margin-left: auto;
	margin-right: auto;
}





#grouplesson h2 {
	text-align: center;
	margin-top: 7.8125vw;
	margin-bottom: 2vw;
}

#grouplesson .flex {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-top: 2.6042vw;
	margin-bottom: 3.125vw;
}

#grouplesson .flex .box {
	width: 23.9583vw;
	margin-left: 18.5416666667vw;
}

#grouplesson .flex .box div {
	display: flex;
	align-items: center;
	text-align: left;
	margin-bottom: 2vw;
}

#grouplesson .flex .box figure {
	width: 4.8958vw;
	margin-right: 1.0417vw;
}

#grouplesson .flex .box dt {
	font-size: 1.5625vw;
	margin-bottom: 0.7813vw;
}

#grouplesson .flex .box dd {
	font-size: 0.9375vw;
}

#grouplesson .flex figure {
	width: 50vw;
}


#grouplesson.personal .flex .box {
	width: 28.9583vw;
	margin-left: 18.5416666667vw;
}
#grouplesson.personal .flex figure {
	width: 48vw;
}
#grouplesson.personal .flex .box figure {
	width: 4.0958vw;
	margin-right: 1.5417vw;
}





#method {
	margin-top: 7.8125vw;
	padding-top: 7.8125vw;
	padding-bottom: 7.8125vw;
	background-color: #FAFAFA;
}

#method h2 {
	text-align: center;
	margin-bottom: 2vw; /* 既にvwなのでそのまま */
}

#method .flex {
	display: flex;
	width: 49.4792vw;
	margin-left: auto;
	margin-right: auto;
	align-items: center;
	justify-content: space-between;
	text-align: left;
	margin-top: 2.6042vw;
}

#method .flex figure {
	width: 20.8333vw;
	background: url(<path-to-image>) lightgray 50% / cover no-repeat;
	box-shadow: 1.5625vw 1.5625vw 0 0 rgba(140, 140, 140, 0.25);
}

#method .flex2 {
	display: flex;
	justify-content: space-between;
	margin-left: auto;
	margin-right: auto;
	width: 57.2917vw;
	margin-top: 4.1667vw;
}

#method .flex2 div {
	width: 17.7083vw;
	background-color: #fff;
	border: 0.0521vw solid #DDDDDD;
	padding-top: 1.5625vw;
	padding-bottom: 1.0417vw;
}

#method .flex2 div h3 {
	font-size: 1.0417vw;
	line-height: 1.5em;
}

#method .flex2 div h3 span {
	font-family: Cardo;
	color: #C3B29C;
	display: block;
}

#method .flex2 div p {
	text-align: left;
	width: 88%;
	margin-left: 1.2vw;
	margin-top: 1.0417vw;
	font-size: 0.72916666666vw;
}





#session {
	padding-top: 7.8125vw;
}

#session h2 {
	text-align: center;
	margin-bottom: 2vw; /* 既にvw */
}

#session h2+p+h3 {
	font-size: 1.8vw;
	line-height: 1.4em;
	margin-top: 2.5vw;
	margin-bottom: 1.5vw;
}

#session .flex {
	display: flex;
	justify-content: space-between;
	width: 54.6875vw;
	margin-left: auto;
	margin-right: auto;
	margin-top: 1.5625vw;
	margin-bottom: 1.5625vw;
}

#session .flex div {
	width: 24.4792vw;
	padding: 1.0417vw;
}

#session .flex div h3 {
	font-size: 1.25vw;
	font-weight: 500;
	margin-bottom: 1.0417vw;
}

#session .flex div p {
	text-align: left;
	font-size: 0.8333vw;
	line-height: 1.8em;
	margin-top: 1.0417vw;
	padding-bottom: 1.0417vw;
	margin-bottom: 1.0417vw;
	border-bottom: 1px solid #C3B19D; /* ← これはpxのまま推奨 */
}

#session .flex div ul {
	line-height: 2.3em;
}

#session .flex div li {
	text-align: left;
	font-size: 0.8333vw;
}

#session .flex div li span {
	color: #C3B19D;
}





#training {
	background-color: #FAFAFA;
	margin-top: 7.8125vw;
	padding-top: 7.8125vw;
	padding-bottom: 7.8125vw;
}

#training h2 {
	text-align: left;
	margin-bottom: 2vw;
}

#training .flex {
	display: flex;
	justify-content: space-between;
	align-items: center;
	flex-direction: row-reverse;
	width: 100%;
}

#training .flex div {
	text-align: left;
	position: relative;
	left: -7vw;
}

#training .flex figure {
	width: 50vw;
}

#training .flex figure img {
	background: url(<path-to-image>) lightgray 50% / cover no-repeat;
	box-shadow: 1.5625vw 1.5625vw 0 0 rgba(140, 140, 140, 0.25);
}










#news {
	width: 50vw;
	margin-left: auto;
	margin-right: auto;
	background-color: #F7F6F4;
	margin-top: 7.8125vw;
	padding-top: 4.8125vw;
	padding-bottom: 4.8125vw;
}

#news .logo {
	color: #928370;
	font-size: 1.5625vw;
	font-family: "Noto Serif JP";
	margin-bottom: 1.5625vw;
}

#news h2 {
	color: #4E4535;
	font-size: 2.0833vw;
	font-family: "Noto Serif JP";
	line-height: 1.4em;
}

#news h2+p {
	color: #4E4535;
	font-size: 0.9375vw;
	margin-top: 1.3021vw;
	line-height: 1.8em;
}

#news .box {
	border-radius: 0.5208vw;
	border: 1px solid #A59989;
	background-color: #fff;
	width: 36.9792vw;
	margin-left: auto;
	margin-right: auto;
	text-align: left;
	margin-top: 1.5625vw;
}

#news .box h3 {
	background-color: #A5988A;
	text-align: center;
	font-family: "Noto Serif JP";
	color: #fff;
	font-size: 1.4063vw;
	height: 2.6042vw;
	line-height: 2.6042vw;
	border-top-left-radius: 0.3646vw;
	border-top-right-radius: 0.3646vw;
	font-weight: 500;
}

#news .box ul {
	margin-left: 0.7813vw;
	font-size: 1.1979vw;
	line-height: 2em;
	margin-top: 0.2604vw;
	margin-bottom: 0.2604vw;
}

#news .box ul li span {
	color: #C3B29C;
}

#news .box ul li em {
	color: #C3B29C;
	font-weight: 500;
}

#news .box+p {
	width: 36.4583vw;
	margin-left: auto;
	margin-right: auto;
	text-align: left;
	font-size: 0.7292vw;
	margin-top: 0.5208vw;
}

#news .box+p+p {
	width: 36.4583vw;
	text-align: left;
	margin-left: auto;
	margin-right: auto;
	margin-top: 1.5625vw;
}

#news h4 {
	color: #4E4535;
	font-size: 1.875vw;
	font-family: "Noto Serif JP";
	margin-top: 2.6042vw;
	margin-bottom: 1.5625vw;
	line-height: 1.4em;
}

#news .btn a {
	width: 22.7917vw;
	height: 3.6458vw;
	border-radius: 5.2083vw;
	background: #89BCA2;
	display: block;
	margin-left: auto;
	margin-right: auto;
	color: #fff;
	line-height: 3.6458vw;
	text-decoration: none;
	font-size: 1.0417vw;
	font-weight: 500;
	transition: 0.3s;
	margin-top: 1.5625vw;
}

#news .btn a:hover {
	opacity: 0.7;
	transition: 0.3s;
}





#reason {
	margin-top: 7.8125vw;
}

#reason h2 {
	text-align: center;
	margin-bottom: 2vw;
}

#reason .flex {
	display: flex;
	justify-content: center;;
	flex-wrap: wrap;
	width: 83.9583333333vw;
	margin-left: auto;
	margin-right: auto;
	margin-top: 3vw;
}

#reason .flex div {
	width: 26.9271vw;
	background-color: #D9D9D9;
	margin-bottom: 1.5625vw;
	padding-bottom: 2vw;
}
#reason .flex div+div {
	margin-left: 1.5625vw;
}

#reason .flex div h3 {
	font-size: 1.25vw;
	padding-top: 2.6042vw;
	margin-bottom: 0.7813vw;
}

#reason .flex div figure {
	width: 13.9583vw;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 1vw;
}

#reason .flex+p {
	padding-top: 1.5625vw;
}

#reason .btn a {
	width: 19.7917vw;
	height: 3.6458vw;
	border-radius: 5.2083vw;
	background: #89BCA2;
	display: block;
	margin-left: auto;
	margin-right: auto;
	color: #fff;
	line-height: 3.6458vw;
	text-decoration: none;
	font-size: 1.0417vw;
	font-weight: 500;
	transition: 0.3s;
	margin-top: 1.5625vw;
}

#reason .btn a span {
	margin-left: 0.2604vw;
	font-size: 0.9375vw;
}

#reason .btn a:hover {
	opacity: 0.7;
	transition: 0.3s;
}





#trainer {
	background-color: #FAFAFA;
	padding-top: 7.8125vw;
	margin-top: 7.8125vw;
	padding-bottom: 7.8125vw;
}

#trainer h2 {
	text-align: center;
	margin-bottom: 3.5vw;
}

#trainer .flex {
	display: flex;
	justify-content: space-between;
	text-align: left;
	width: 70.7083vw;
	align-items: center;
	margin-left: auto;
	margin-right: auto;
}

#trainer .flex div {
	width: 39.9792vw;
}

#trainer .flex div h3 {
	text-align: center;
	font-size: 1.6667vw;
}

#trainer .flex div h3+p {
	font-size: 1.1458vw;
	margin-top: 1.0417vw;
}

#trainer .flex div h4 {
	background-color: #4E4436;
	width: 32.0833vw;
	height: 2.6042vw;
	line-height: 2.6042vw;
	margin-left: auto;
	margin-right: auto;
	color: #fff;
	text-align: center;
	font-size: 1.1458vw;
	border-radius: 0.2604vw;
	margin-top: 1.5417vw;
	margin-bottom: 1.9625vw;
}

#trainer .flex figure {
	width: 28.4896vw;
}

#trainer .btn a {
	width: 19.7917vw;
	height: 3.6458vw;
	border-radius: 5.2083vw;
	background: #8F877F;
	display: block;
	margin-left: auto;
	margin-right: auto;
	color: #fff;
	line-height: 3.6458vw;
	text-decoration: none;
	font-size: 1.0417vw;
	font-weight: 500;
	transition: 0.3s;
	margin-top: 5.5625vw;
}

#trainer .btn a span {
	margin-left: 0.2604vw;
	font-size: 0.9375vw;
}

#trainer .btn a:hover {
	opacity: 0.7;
	transition: 0.3s;
}





#review {
	padding-top: 7.8125vw;
	margin-bottom: 7.8125vw;
}
#review h2 {
	text-align: center;
	margin-bottom: 2vw;
}





#flowtop {
	padding-bottom: 7.8125vw;
}

#flowtop h2 {
	text-align: center;
	padding-top: 7.8125vw;
	margin-bottom: 2.6042vw;
}

#flowtop .flex {
	background-color: #fff;
	width: 50vw;
	margin-left: auto;
	margin-right: auto;
	display: flex;
	justify-content: space-between;
	position: relative;
	margin-bottom: 5.2083vw;
	padding-bottom: 1.5625vw;
	padding-top: 1.5625vw;
	align-items: center;
}

#flowtop .flex::after {
	content: "";
	background-image: url("../images/pc/index/flow.png");
	width: 2.0313vw;
	height: 1.1458vw;
	background-size: cover;
	position: absolute;
	left: 0px;
	right: 0px;
	bottom: -3.125vw;
	margin-left: auto;
	margin-right: auto;
}

#flowtop .flex:nth-of-type(5)::after {
	width: 0px;
	height: 0px;
}

#flowtop .flex div {
	text-align: left;
	width: 35.2917vw;
}

#flowtop .flex div h3 {
	font-size: 1.3542vw;
}

#flowtop .flex div h3 span {
	font-size: 2.6042vw;
	font-family: Cardo;
	color: #C3B29C;
}

#flowtop .flex div p {
	font-size: 0.8333vw;
	margin-top: 1.0417vw;
}

#flowtop .flex figure {
	width: 10.4167vw;
	padding-left: 3.2083vw;
	text-align: center;
}

#flowtop .flex:nth-of-type(1) figure img { width: 3.1771vw; }
#flowtop .flex:nth-of-type(2) figure img { width: 7.3958vw; }
#flowtop .flex:nth-of-type(3) figure img { width: 5.4688vw; }
#flowtop .flex:nth-of-type(4) figure img { width: 7.3438vw; }
#flowtop .flex:nth-of-type(5) figure img { width: 8.9063vw; }

#flowtop .btn a {
	width: 19.7917vw;
	height: 3.6458vw;
	border-radius: 5.2083vw;
	background: #89BCA2;
	display: block;
	margin-left: auto;
	margin-right: auto;
	color: #fff;
	line-height: 3.6458vw;
	text-decoration: none;
	font-size: 1.0417vw;
	font-weight: 500;
	transition: 0.3s;
	margin-top: 1.5625vw;
}

#flowtop .btn a span {
	margin-left: 0.2604vw;
	font-size: 0.9375vw;
}

#flowtop .btn a:hover {
	opacity: 0.7;
	transition: 0.3s;
}





#access {
	padding-top: 7.8125vw;
	padding-bottom: 7.8125vw;
	background-color: #FAFAFA;
}

#access h2 {
	text-align: center;
	margin-bottom: 2.0833vw;
}

#access h3 {
	font-size: 1.25vw;
	margin-top: 1.5625vw;
	margin-bottom: 1.0417vw;
}

#access table {
	width: 41.6667vw;
	margin-left: auto;
	margin-right: auto;
	text-align: left;
	border-bottom: 1px solid #D9D9D9;
	margin-bottom: 1.5625vw;
}

#access table th {
	background-color: #EFEFEF;
	width: 14.9479vw;
	text-align: center;
	font-size: 0.8333vw;
	border-left: 1px solid #D9D9D9;
	border-top: 1px solid #D9D9D9;
}

#access table td {
	font-size: 0.8333vw;
	padding: 0.7813vw;
	border-right: 1px solid #D9D9D9;
	border-top: 1px solid #D9D9D9;
	background-color: #fff;
}

#access .btn a {
	width: 19.7917vw;
	height: 3.6458vw;
	border-radius: 5.2083vw;
	background: #8F877F;
	display: block;
	margin-left: auto;
	margin-right: auto;
	color: #fff;
	line-height: 3.6458vw;
	text-decoration: none;
	font-size: 1.0417vw;
	font-weight: 500;
	transition: 0.3s;
	margin-top: 1.5625vw;
}

#access .btn a span {
	margin-left: 0.2604vw;
	font-size: 0.9375vw;
}

#access .btn a:hover {
	opacity: 0.7;
	transition: 0.3s;
}






#brand {
	padding-top: 7.8125vw;
	padding-bottom: 7.8125vw;
}

#brand h2 {
	font-size: 2.0833vw;
	margin-bottom: 3.125vw;
}

#brand .flex {
	display: flex;
	justify-content: space-between;
	width: 46.875vw;
	margin-left: auto;
	margin-right: auto;
	text-align: left;
}

#brand .flex div {
	width: 20.8333vw;
	border: 1px solid #ddd;
	padding: 1.0417vw;
	position: relative;
}

#brand .flex div h3 {
	color: #C3B29C;
	font-size: 1.0417vw;
	margin-bottom: 0.5208vw;
}

#brand .flex div p {
	font-size: 0.9375vw;
}

#brand .flex div p span {
	font-size: 0.625vw;
	display: block;
}

#brand .flex div a {
	display: block;
	width: 100%;
	height: 100%;
	position: absolute;
	left: 0px;
	top: 0px;
}

}



/*===============================================
●画面の横幅が768pxまで
===============================================*/
@media screen and (max-width:768px){
	
/*===============================================
●sp-tablet
===============================================*/
#sptablet------------------------------------------- {
}
main .btn a {
	position: relative;
}
main .btn a span {
	position: absolute;
	right: 14vw;
	top: 5.7vw;
	display: block;
	width: 2.5vw;
	height: 4vw;
}



#helo {
	position: relative;
	height: 100vh;
}
#helo .inner {
	position: absolute;
	left: 0px;
	right: 0px;
	top: 5.20833333333vw;
	z-index: 999;
	width: 90%;
	margin-left: auto;
	margin-right: auto;
	text-align: left;
}
#helo .inner h2 {
color: #FFF;
text-shadow: 0 4px 8px rgba(0, 0, 0, 0.25),0 4px 8px rgba(0, 0, 0, 0.25);
font-family: "Noto Serif JP";
font-size: 10vw;
font-style: 500;
font-weight: 300;
line-height: 1.2em; /* 114.286% */
}
#helo .inner h2 span {
font-size: 8vw;
}
#helo .inner p {
color: #FFF;
text-shadow: 0 4px 8px rgba(0, 0, 0, 0.25),0 4px 8px rgba(0, 0, 0, 0.25),0 4px 8px rgba(0, 0, 0, 0.25);
font-family: "Noto Serif JP";
font-size: 5vw;
font-style: normal;
font-weight: 400;
margin-top: 20px;
line-height: 1.8em; /* 176.471% */
}
#helo .slide {
	width: 100%;
	height: 90vh;
	position: relative;
	overflow: hidden;
}
#helo .slide .img {
	position: absolute;
	inset: 0;
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	opacity: 0;
	transform: scale(1.1);
	transition:
		opacity 3s ease,
		transform 5s linear;
	border-radius: 1vw;
}

#helo .slide .img.active {
	opacity: 1;
	transform: scale(1);
}

#helo .slide .img.fadeout {
	opacity: 0;
	transform: scale(1); /* ←拡大しない */
	transition:
		opacity 1.2s ease,
		transform 0s linear;
}
#helo .line {
	position: absolute;
	right: 3vw;
	bottom: 30vw;
	width: 90vw;
}






#group h2 {
	font-size: 6vw;
	line-height: 1.6em;
	margin-bottom: 5vw;
}











#concept {
	background-color: #FAFAFA;
	margin-top: 15vw;
	padding-top: 15vw;
	padding-bottom: 15vw;
}
#concept .flex {
	width: 90%;
	margin-left: auto;
	margin-right: auto;
}
#concept .flex figure {
	margin-top: 5vw;
}
#concept .flex figure img {
	width: 100%;
	height: auto;
	background: url(<path-to-image>) lightgray 50% / cover no-repeat;
box-shadow: 3vw 3vw 0 0 rgba(140, 140, 140, 0.25);
}
#concept .flex div {
}
#concept .flex div p {
	text-align: left;
	margin-top: 30px;
	margin-left: auto;
	margin-right: auto;
}





#grouplesson h2 {
	text-align: center;
	margin-top: 15vw;
	margin-bottom: 5vw;
}

#grouplesson .flex {
	margin-top: 8vw;
	margin-bottom: 8vw;
}

#grouplesson .flex .box {

}

#grouplesson .flex .box div {
	text-align: left;
	margin-bottom: 5vw;
	display: flex;
	justify-content: center;
	align-items: center;
}

#grouplesson .flex .box figure {
	width: 20vw;
	margin-left: 5vw;
}
#grouplesson .flex .box dl {
	width: 70vw;
	margin-left: 3vw;
}
#grouplesson .flex .box dt {
	font-size: 5vw;
	margin-bottom: 0.7813vw;
}

#grouplesson .flex .box dd {
	font-size:4vw;
}

#grouplesson .flex figure {
	width: 90%;
	margin-left: auto;
	margin-right: auto;
	margin-top: 5vw;
}
#grouplesson.personal .flex .box figure {
	width: 15vw;
}





#method {
	margin-top: 15vw;
	padding-top: 15vw;
	padding-bottom: 10vw;
	background-color: #FAFAFA;
}

#method h2 {
	text-align: center;
	margin-bottom: 5vw; /* 既にvwなのでそのまま */
}

#method .flex {
	margin-left: 5vw;
	margin-right: 5vw;
	text-align: left;
	margin-top: 5vw;
}

#method .flex figure {
	background: url(<path-to-image>) lightgray 50% / cover no-repeat;
	box-shadow: 1.5625vw 1.5625vw 0 0 rgba(140, 140, 140, 0.25);
	margin-top: 5vw;
}

#method .flex2 {
	margin-left: 5vw;
	margin-right: 5vw;
	margin-top: 7vw;
}

#method .flex2 div {
	background-color: #fff;
	border: 1px solid #DDDDDD;
	padding-top: 5vw;
	padding-bottom: 5vw;
	margin-bottom: 5vw;
}

#method .flex2 div h3 {
	font-size: 5vw;
	line-height: 1.5em;
}

#method .flex2 div h3 span {
	font-family: Cardo;
	color: #C3B29C;
	display: block;
}

#method .flex2 div p {
	text-align: left;
	width: 90%;
	margin-left: auto;
	margin-right: auto;
	margin-top: 4vw;
}





#session {
	padding-top: 15vw;
}

#session h2 {
	text-align: center;
	margin-bottom: 5vw; /* 既にvw */
}

#session .flex {
	margin-left: 5vw;
	margin-right: 5vw;
	margin-top: 10vw;
	margin-bottom: 5vw;
}

#session .flex div+div {
	margin-top: 10vw;
}

#session .flex div h3 {
	font-size: 5vw;
	font-weight: 500;
	margin-bottom: 3vw;
}

#session .flex div p {
	text-align: left;
	line-height: 1.8em;
	margin-top: 5vw;
	padding-bottom: 5vw;
	margin-bottom: 5vw;
	border-bottom: 1px solid #C3B19D; /* ← これはpxのまま推奨 */
}

#session .flex div ul {
	line-height: 2.3em;
}

#session .flex div li {
	text-align: left;
}

#session .flex div li span {
	color: #C3B19D;
}





#training {
	background-color: #FAFAFA;
	margin-top: 15vw;
	padding-top: 15vw;
	padding-bottom: 15vw;
	padding-left: 5vw;
	padding-right: 5vw;
}

#training h2 {
	text-align: left;
	margin-bottom: 5vw;
}

#training .flex {
}

#training .flex div {
	text-align: left;
}

#training .flex figure {
	margin-top: 5vw;
}

#training .flex figure img {
	background: url(<path-to-image>) lightgray 50% / cover no-repeat;
	box-shadow: 1.5625vw 1.5625vw 0 0 rgba(140, 140, 140, 0.25);
}










#news {
	width: 90vw;
	margin-left: auto;
	margin-right: auto;
	background-color: #F7F6F4;
	margin-top: 15vw;
	padding-top: 10vw;
	padding-bottom: 10vw;
}

#news .logo {
	color: #928370;
	font-size: 4vw;
	font-family: "Noto Serif JP";
	margin-bottom: 3vw;
}

#news h2 {
	color: #4E4535;
	font-size: 6vw;
	line-height: 1.6em;
	font-family: "Noto Serif JP";
}

#news h2+p {
	color: #4E4535;
	margin-top: 5vw;
	line-height: 1.8em;
}

#news .box {
	border-radius: 0.5208vw;
	border: 1px solid #A59989;
	background-color: #fff;
	width: 84vw;
	margin-left: auto;
	margin-right: auto;
	text-align: left;
	margin-top: 5vw;
}

#news .box h3 {
	background-color: #A5988A;
	text-align: center;
	font-family: "Noto Serif JP";
	color: #fff;
	font-size: 5vw;
	border-top-left-radius: 0.3646vw;
	border-top-right-radius: 0.3646vw;
	font-weight: 500;
	padding-top: 2vw;
	padding-bottom: 2vw;
}

#news .box ul {
	line-height: 2em;
	margin-left: 2vw;
	padding-top: 3vw;
	padding-bottom: 3vw;
}

#news .box ul li span {
	color: #C3B29C;
}

#news .box ul li em {
	color: #C3B29C;
	font-weight: 500;
}

#news .box+p {
	width: 80vw;
	margin-left: auto;
	margin-right: auto;
	text-align: left;
	margin-top: 5vw;
}

#news .box+p+p {
	text-align: left;
	margin-left: auto;
	margin-right: auto;
	margin-top: 5vw;
	width: 80vw;
}

#news h4 {
	color: #4E4535;
	font-size: 5vw;
	font-family: "Noto Serif JP";
	margin-top: 8vw;
	margin-bottom: 5vw;
}

#news .btn a {
	width: 80vw;
	height: 15vw;
	border-radius: 100px;
	background: #89BCA2;
	display: block;
	margin-left: auto;
	margin-right: auto;
	color: #fff;
	line-height: 15vw;
	text-decoration: none;
	font-size: 4vw;
	font-weight: 500;
	transition: 0.3s;
	margin-top: 5vw;
}

#news .btn a span {
	margin-left: 0.2604vw;
	font-size: 4vw;
}

#news .btn a:hover {
	opacity: 0.7;
	transition: 0.3s;
}





#reason {
	margin-top: 15vw;
}

#reason h2 {
	text-align: center;
	margin-bottom: 5vw;
}

#reason .flex {
	width: 90vw;
	margin-left: auto;
	margin-right: auto;
	margin-top: 5vw;
}

#reason .flex div {
	background-color: #D9D9D9;
	margin-bottom: 5vw;
	padding-bottom: 5vw;
}

#reason .flex div h3 {
	font-size: 4vw;
	padding-top: 5vw;
	margin-bottom: 5vw;
}

#reason .flex div figure {
	width: 40vw;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 3vw;
}

#reason .flex+p {
	padding-top: 1.5625vw;
}

#reason .btn a {
	width: 80vw;
	height: 15vw;
	border-radius: 100px;
	background: #89BCA2;
	display: block;
	margin-left: auto;
	margin-right: auto;
	color: #fff;
	line-height: 15vw;
	text-decoration: none;
	font-size: 4vw;
	font-weight: 500;
	transition: 0.3s;
	margin-top: 5vw;
}

#reason .btn a span {
	margin-left: 0.2604vw;
	font-size: 3vw;
}

#reason .btn a:hover {
	opacity: 0.7;
	transition: 0.3s;
}





#trainer {
	background-color: #FAFAFA;
	padding-top: 15vw;
	margin-top: 15vw;
	padding-bottom: 15vw;
}

#trainer h2 {
	text-align: center;
	margin-bottom: 3.5vw;
}

#trainer .flex {
	text-align: left;
	width: 90vw;
	margin-left: auto;
	margin-right: auto;
}

#trainer .flex div {
}

#trainer .flex div h3 {
	text-align: center;
	font-size: 5vw;
}

#trainer .flex div h3+p {
	margin-top:5vw;
}

#trainer .flex div h4 {
	background-color: #4E4436;
	width: 90vw;
	margin-left: auto;
	margin-right: auto;
	color: #fff;
	text-align: center;
	font-size: 4vw;
	border-radius: 0.2604vw;
	margin-top: 5vw;
	margin-bottom: 5vw;
	padding-top: 3vw;
	padding-bottom: 3vw;
}

#trainer .flex figure {
	width: 90vw;
	margin-top: 5vw;
}

#trainer .btn a {
	width: 80vw;
	height: 15vw;
	border-radius: 100px;
	background: #8F877F;
	display: block;
	margin-left: auto;
	margin-right: auto;
	color: #fff;
	line-height: 15vw;
	text-decoration: none;
	font-size: 4vw;
	font-weight: 500;
	transition: 0.3s;
	margin-top: 10vw;
}

#trainer .btn a span {
	margin-left: 0.2604vw;
	font-size: 3vw;
}

#trainer .btn a:hover {
	opacity: 0.7;
	transition: 0.3s;
}





#review {
	padding-top: 15vw;
	margin-bottom: 15vw;
}
#review h2 {
	text-align: center;
}





#flowtop {
	padding-bottom: 15vw;
	background-color: #FAFAFA;
	padding-top: 15vw;
}

#flowtop h2 {
	text-align: center;
	margin-bottom: 8vw;
}

#flowtop .flex {
	background-color: #fff;
	width: 80vw;
	padding: 5vw;
	margin-left: auto;
	margin-right: auto;
	position: relative;
	margin-bottom: 15vw;
}

#flowtop .flex::after {
	content: "";
	background-image: url("../images/pc/index/flow.png");
	width: 10.0313vw;
	height: 5.51458vw;
	background-size: cover;
	position: absolute;
	left: 0px;
	right: 0px;
	bottom: -10vw;
	margin-left: auto;
	margin-right: auto;
}

#flowtop .flex:nth-of-type(5)::after {
	width: 0px;
	height: 0px;
}

#flowtop .flex div {
	text-align: left;
}

#flowtop .flex div h3 {
	font-size: 5vw;
	text-align: center;
}

#flowtop .flex div h3 span {
	font-size: 8vw;
	font-family: Cardo;
	color: #C3B29C;
}

#flowtop .flex div p {
	margin-top: 3vw;
}

#flowtop .flex figure {
	text-align: center;
	margin-bottom: 3vw;
}

#flowtop .flex:nth-of-type(1) figure img { width: 10vw; }
#flowtop .flex:nth-of-type(2) figure img { width: 25vw; }
#flowtop .flex:nth-of-type(3) figure img { width: 20vw; }
#flowtop .flex:nth-of-type(4) figure img { width:25vw; }
#flowtop .flex:nth-of-type(5) figure img { width: 25vw; }

#flowtop .btn a {
	width: 80vw;
	height: 15vw;
	border-radius: 100px;
	background: #89BCA2;
	display: block;
	margin-left: auto;
	margin-right: auto;
	color: #fff;
	line-height: 15vw;
	text-decoration: none;
	font-size: 4vw;
	font-weight: 500;
	transition: 0.3s;
	margin-top: 5vw;
}

#flowtop .btn a span {
	margin-left: 0.2604vw;
	font-size: 2.9375vw;
}

#flowtop .btn a:hover {
	opacity: 0.7;
	transition: 0.3s;
}





#access {
	padding-top: 15vw;
	padding-bottom: 15vw;
	background-color: #FAFAFA;
}
#access h2 {
	text-align: center;
	margin-bottom: 5vw;
}
#access iframe {
	width: 100%;
	height: 60vw;
}
#access h3 {
	font-size: 5vw;
	margin-top: 30px;
	margin-bottom: 20px;
}
#access table {
	width: 90%;
	margin-left: auto;
	margin-right: auto;
	text-align: left;
	border-bottom: 1px solid #D9D9D9;
	border-top: 1px solid #D9D9D9;
	margin-bottom: 5vw;
}
#access table th {
	background-color: #EFEFEF;
	width: 100%;
	display: block;
	text-align: center;
	border-right: 1px solid #D9D9D9;
	border-left: 1px solid #D9D9D9;
}
#access table td {
	width: 94.2%;
	padding: 3%;
	display: block;
	border-right: 1px solid #D9D9D9;
	border-left: 1px solid #D9D9D9;
	background-color: #fff;
}
#access .btn a {
	width: 80vw;
	height: 15vw;
	border-radius: 100px;
	background: #8F877F;
	display: block;
	margin-left: auto;
	margin-right: auto;
	color: #fff;
	line-height: 15vw;
	text-decoration: none;
	font-size: 4vw;
	font-weight: 500;
	transition: 0.3s;
	margin-top: 10vw;
}

#access .btn a span {
	margin-left: 0.2604vw;
	font-size: 2.9375vw;
}

#access .btn a:hover {
	opacity: 0.7;
	transition: 0.3s;
}





#brand {
	padding-top: 15vw;
	padding-bottom: 1vw;
}

#brand h2 {
	font-size: 6vw;
	margin-bottom: 5vw;
}

#brand .flex {
	margin-left: auto;
	margin-right: auto;
	width: 90%;
	text-align: left;
}

#brand .flex div {
	border: 1px solid #ddd;
	padding: 4vw;
	position: relative;
	margin-bottom: 5vw;
}

#brand .flex div h3 {
	color: #C3B29C;
	font-size: 4vw;
	margin-bottom: 2vw;
}

#brand .flex div p {
}

#brand .flex div p span {
	font-size: 3vw;
	display: block;
}

#brand .flex div a {
	display: block;
	width: 100%;
	height: 100%;
	position: absolute;
	left: 0px;
	top: 0px;
}

}



/*===============================================
●画面の横幅が400pxまで
===============================================*/
@media screen and (max-width:400px){
/*===============================================
●sp400
===============================================*/
#sp400------------------------------------------- {
}
}



/*===============================================
●画面の横幅が320pxまで
===============================================*/
@media screen and (max-width:320px){
/*===============================================
●sp320
===============================================*/
#sp320------------------------------------------- {
}
}



/*===============================================
●画面の横幅が481pxから768pxまで
===============================================*/
@media screen and (min-width:481px) and (max-width:768px) {
/*===============================================
●tablet
===============================================*/
#tab------------------------------------------- {
}
}