@charset "utf-8";
/* CSS Document */

/* Ryoetsu denki
   faq
-----------------------------------------------------*/


/* ==============================================
    faq-catch
============================================== */
.faq-catch h2 {
	font-size: 2.000em;
	font-weight: 900;
	line-height: 100px;
	color: #fff;
	background: #2d2d2d;
	padding: 0 10px 0 5%;
	margin-right: 34%;
	margin-bottom: 80px;
}
.faq-archive {
	padding-bottom: 50px;
}
.faq-archive dt {
	font-size: 1.875em;
	font-weight: 900;
	line-height: 1.4;
	margin-bottom: 35px;
	padding-left: 100px;
	position: relative;
}
.faq-archive dt::before {
	content: "";
	display: inline-block;
	background: url("image/icon_q.svg") no-repeat 0 0 / contain;
	width: 90px;
	height: 90px;
	position: absolute;
	top: -20px;
	left: 0;
}

.faq-archive dd {
	background: #e4e4e4;
	position: relative;
	margin-left: 100px;
	margin-bottom: 90px;
}
.faq-archive dd:last-child {
	margin-bottom: 0;
}

.faq-archive dd::before {
	content: "";
	display: inline-block;
	background: url("image/icon_a.svg") no-repeat 0 0 / contain;
	width: 90px;
	height: 90px;
	position: absolute;
	top:0px;
	right: 20px;
}

.faq-archive dd .answer {
	padding: 30px 140px 30px 30px;
	font-size: 1.125em;
	display: none;
}
.faq-archive dd .answer p {
	margin-bottom: 20px;
}
.faq-archive dd .answer p:last-child {
	margin-bottom: 0px;
}

.faq-archive dd .more {
	cursor: pointer;
	border-top: 1px solid #fff;
	height: 90px;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 1.125em;
	font-weight: 700;
	color: #0958a5;
}
.faq-archive dd .more::before {
	content: "";
	display: inline-block;
	background: url("image/arrow3_b.svg") no-repeat 0 0 / contain;
	width: 36px;
	height: 36px;
	margin-right: 20px;
	transform: rotate(90deg);
}
.faq-archive dd .more.close::before {
	transform: rotate(-90deg);
}

@media screen and (max-width: 1200px) {
	.faq-catch h2 {
		font-size: 1.500em;
	}
}

@media screen and (max-width: 1000px) {
	.faq-catch h2 {
		line-height: 1.4;
		padding: 15px 20px;
		margin-right: 0;
		display: inline-block;
		margin-bottom: 50px;
	}
	.faq-archive dd {
		margin-left: 30px;
	}
}

@media screen and (max-width: 700px) {
	.faq-archive dt {
		font-size: 1.286em;
		padding-left: 70px;
		margin-bottom: 20px;
	}
	.faq-archive dd {
		margin-bottom: 50px;
		margin-left: 0px;
	}
	.faq-archive dt::before,
	.faq-archive dd::before {
		width: 60px;
		height: 60px;
	}
	.faq-archive dd .more {
		height: 60px;
	}
	
	.faq-archive dt::before {
		top: -15px;
	}
	.faq-archive dd::before {
		right: 5px;
	}
	.faq-archive dd .answer {
		padding: 20px 70px 20px 20px;
		font-size: 1.071em;
	}
}


/* ==============================================
    
============================================== */

@media screen and (max-width: 700px) {

}
