@charset "utf-8";
/*------------------------------------------------------------
	トープページ
------------------------------------------------------------*/
#main {
	padding-top: 139px;
}

.methodTitle {
	margin-bottom: 24px;
}

.methodTitle h2 {
	position: relative;
	font-size: 38px;
	font-family: 'Libre Baskerville', serif;
	text-align: center;
	letter-spacing: 1px;
}

.methodTitle h2:after {
	width: 100px;
	height: 3px;
	position: absolute;
	left: 50%;
	bottom: -32px;
	transform: translateX(-50%);
	content: "";
	background: #000;
}

.sec {
	padding: 120px 0;
}

.secBg {
	background: #ebeff5;
}

.secH3 {
	margin-bottom: 34px;
	font-size: 28px;
	font-family: 'Libre Baskerville', serif;
	font-weight: normal;
}

.secInfo {
	margin: 0 auto;
	width: 800px;
}

.secCenter {
	display: flex;
	align-items: center;
}

.secCenter .secWord {
	margin-right: 45px;
}

.secReverse {
	flex-direction: row-reverse;
}

.secReverse .secWord {
	margin-right: 0;
	margin-left: 40px;
}

.methodP1 {
	margin-bottom: 22px;
	font-size: 13px;
	line-height: 1.8;
	letter-spacing: .7px;
}

.methodP1:last-child {
	margin-bottom: 0;
}

.secImg {
	height: 202px;
}

.secImg img {
	height: 100%;
}

.secPart02 .secImg {
	margin-right: -6px;
}

.secPart03 .secImg {
	margin-left: -47px;
	height: 211px;
}

.secImg p {
	margin-bottom: 11px;
	font-size: 12px;
	font-weight: bold;
	text-align: center;
	color: #053981;
}

.component {}

.component div {
	margin-bottom: 7px;
}

.component span {
	margin-top: -4px;
	width: 250px;
	display: inline-block;
	font-size: 16px;
	font-weight: bold;
	color: #053981;
	float: left;
}

.component p {
	margin-left: 250px;
	padding-left: 13px;
	font-size: 13px;
	text-indent: -13px;
	line-height: 1.2;
	letter-spacing: .7px;
}

.secPart04 {
	margin-bottom: 112px;
	padding-top: 115px;
	padding-bottom: 102px;
}

.secPart04 .methodP1 {
	margin-bottom: 13px;
}

.secPart04 .secImg {
	margin-right: 10px;
	height: auto;
}

.secPart04 .secImg img {
	height: 331px;
}

.highlight {
	margin-bottom: 139px;
}

.highlight .secH3 {
	margin-bottom: 27px;
	text-align: center;
}

.highlight .methodP1 {
	margin-bottom: 56px;
	text-align: center;
}

.hlInfo {
	margin: 0 auto;
	width: 601px;
	position: relative;
}

.hlWordP1 {
	margin-bottom: 12px;
	font-size: 15px;
	font-weight: bold;
	line-height: 1.35;
	color: #053981;
	letter-spacing: .1px;
}

.hlWordP2 {
	font-size: 13px;
	color: #040404;
	letter-spacing: .7px;
}

.hlWordLeft {
	width: 145px;
	position: absolute;
	left: -170px;
	top: 96px;
}

.hlWordRight {
	width: 145px;
	position: absolute;
	right: -175px;
	top: 96px;
}

.hlImg {
}

.hlImg img {
	width: 100%;
}

.stepList {
	margin: 0 auto 160px;
	width: 800px;
	position: relative;
}

.stepList:after {
	width: 1px;
	height: calc(100% - 14px);
	position: absolute;
	top: 7px;
	left: 164px;
	content: "";
	background: #b4c3d9;
}

.stepList li {
	margin-bottom: 33px;
}

.stepList li:last-child {
	margin-bottom: 0;
}

.stepLeft {
	width: 160px;
	float: left;
	font-weight: bold;
}

.stepNum {
	font-size: 14px;
	color: #053981;
}

.stepName {
	font-size: 18px;
}

.stepTime {
	font-size: 12px;
}

.stepRight {
	margin-left: 213px;
}

.stepRight h4 {
	margin-bottom: 13px;
	font-size: 18px;
	letter-spacing: .1px;
}

.stepRight p {
	margin-bottom: 5px;
	font-size: 13px;
	line-height: 1.4;
	letter-spacing: .7px;
}

.stepWord {
	padding-left: 14px;
	text-indent: -13px;
}

@media all and (min-width: 0) and (max-width: 767px) {
	#main {
		padding-top: 90px;
	}
	
	.methodTitle h2 {
		font-size: 33px;
	}
	
	.methodTitle h2::after {
		width: 90px;
		height: 2px;
		bottom: -23px;
	}
	
	.sec {
		padding: 97px 0 100px;
	}
	
	.secPart01 {
		padding-top: 41px;
		padding-bottom: 94px;
	}
	
	.secInfo {
		padding: 0 20px;
		width: auto;
	}
	
	.secH3 {
		margin-right: -5px;
		margin-bottom: 16px;
		font-size: 23px;
		line-height: 1.38;
	}
	
	.methodP1 {
		margin-bottom: 24px;
		line-height: 1.76;
		letter-spacing: .5px;
	}
	
	.secCenter {
		display: block;
	}
	
	.secImg {
		height: auto;
	}
	
	.secImg img {
		width: 100%;
		height: auto;
	}
	
	.secCenter .secWord {
		margin-bottom: 47px;
		margin-right: 0;
	}
	
	.secPart02 .secImg {
		padding: 0 41px;
		margin-right: 0;
	}
	
	.secReverse .secWord {
		margin-left: 0;
	}
	
	.secPart03 .secImg {
		margin: 0 -6px;
		height: auto;
	}
	
	.secPart04 .secH3 {
		margin-bottom: 21px;
	}
	
	.secPart04 .methodP1 {
		margin-bottom: 30px;
	}
	
	.component div {
		margin-bottom: 12px;
	}
	
	.component span {
		margin: 0 0 3px;
		width: auto;
		font-size: 15px;
		float: none;
	}
	
	.component p {
		margin-left: 0;
		line-height: 1.4;
		letter-spacing: .45px;
	}
	
	.secPart04 {
		margin-bottom: 95px;
	}
	
	.secPart04 .secImg {
		margin-right: 0;
		text-align: center;
	}
	
	.secPart04 .secImg img {
		width: 83.5%;
		height: auto;
	}
	
	.highlight {
		margin-bottom: 38px;
	}
	
	.highlight .secH3 {
		margin-right: 0;
		margin-bottom: 15px;
		padding: 0 20px;
		font-size: 23px;
		text-align: left;
	}
	
	.highlight .methodP1 {
		margin-bottom: 46px;
		padding: 0 20px;
		text-align: left;
	}
	
	.hlInfo {
		padding: 0 13px;
		width: auto;
	}
	
	.hlWord {
		margin: 10px 0 23px;
	}
	
	.hlWordLeft {
		padding-left: 8%;
		width: 50%;
		position: static;
		float: left;
		box-sizing: border-box;
	}
	
	.hlWordRight {
		padding-left: 7%;
		width: 50%;
		position: static;
		float: right;
		box-sizing: border-box;
	}
	
	.hlWordP1 {
		margin-bottom: 7px;
		font-size: 14px;
		line-height: 1.3;
	}
	
	.hlWordP2 {
		line-height: 1.55;
	}
	
	.stepList {
		margin-bottom: 56px;
		padding: 0 20px;
		width: auto;
	}
	
	.stepList::after {
		width: 0;
	}
	
	.stepList li {
		margin-bottom: 0;
		padding: 35px 0 34px;
		position: relative;
	}
	
	.stepList li:before {
		width: 100%;
		height: 1px;
		position: absolute;
		bottom: 0;
		left: 0;
		content: "";
		background: #b4c3d9;
	}
	
	.stepList li:last-child:before {
		width: 0;
	}
	
	.stepLeft {
		margin-bottom: 12px;
		width: auto;
		float: none;
	}
	
	.stepRight {
		margin-left: 0;
	}
	
	.stepLeft p {
		display: inline-block;
	}
	
	.stepNum {
		margin-right: 5px;
	}
	
	.stepName {
		margin-right: 2px;
		font-size: 15px;
	}
	
	.stepTime {
	}
	
	.stepRight h4 {
		margin-right: -5px;
		margin-bottom: 23px;
		font-size: 15px;
		line-height: 1.33;
		letter-spacing: .4px;
	}
	
	.stepRight p {
		margin-bottom: 0px;
		line-height: 1.76;
		letter-spacing: .5px;
	}
	
	.stepWord {
    	padding-left: 13px;
	}
}