@charset "utf-8";

/*******************************************

-------------------------------------------
空き家管理（管理代行事業者）
********************************************/

#about {
}
#about h2 + p {
	margin-top: 40px;
	text-align: center;
	font-weight: 700;
	font-size: 38px;
}
#about h2 + p + p {
	font-size: 23px;
	text-align: center;
	font-weight: 300;
	margin-top: 40px;
}
#about .request {
	margin-top: 80px;
	position: relative;
	padding-left: 220px;
}
#about .request > img {
	position: absolute;
	top: 0;
	left: -35px;
}
#about .request h3 {
	font-size: 42px;
	color: #363480;
}
#about .request ul {
	display: flex;
	flex-wrap: wrap;
	gap: 13px;
	margin-top: 30px;
}
#about .request ul li {
	font-size: 27px;
	font-weight: 700;
	line-height: 1.2;
	color: #fff;
	text-align: center;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
	align-content: center;
	width: calc((100% - 13px) / 2);
	height: 100px;
	background-color: #363480;
}
#about .request ul li:nth-of-type(2),
#about .request ul li:nth-of-type(3) {
	background-color: #5e5d99;
}
#about .request ul li span {
	font-size: 40px;
	font-weight: 700;
	color: #ffe100;
}
@media only screen and (max-width: 767px) {
	#about h2 + p {
		font-size: 24px;
		text-align: left;
	}
	#about h2 + p + p {
		margin-top: 30px;
		font-size: 18px;
		text-align: left;
	}
	#about .request {
		margin-top: 50px;
		padding-left: 100px;
	}
	#about .request > img {
		width: 90px;
		top: -20px;
		left: 0;
	}
	#about .request h3 {
		font-size: 28px;
	}
	#about .request ul {
		margin-left: -100px;
	}
	#about .request ul li {
		width: 100%;
		height: auto;
		min-height: 80px;
		font-size: 20px;
		padding: 10px;
	}
	#about .request ul li:nth-of-type(3) {
		background-color: #363480;
	}
	#about .request ul li:nth-of-type(4) {
		background-color: #5e5d99;
	}
	#about .request ul li span {
		font-size: 24px;
	}
}

/*******************************************

-------------------------------------------
プラン
********************************************/

#plan {
	background-color: #efefef;
	padding-top: 50px;
	padding-bottom: 70px;
}
#plan h3 {
	text-align: center;
	font-size: 40px;
	color: #363480;
}
#plan h3 + p {
	text-align: center;
	font-size: 25px;
}
#plan h3 + p span {
	display: inline-block;
	font-size: 35px;
	font-weight: 500;
	text-decoration-color: #ffe100;
	text-decoration-line: underline;
	text-decoration-thickness: 10px;
	text-underline-offset: -3px;
	text-decoration-skip-ink: none;
}
#plan h4 {
	font-size: 25px;
	margin-top: 40px;
}
#plan .planMenu {
	width: 100%;
}
#plan table {
	width: 100%;
	border: 4px solid #231815;
	background-color: #fff;
	line-height: 1.4;
}
#plan table.tbl_plan {
	margin-top: 50px;
}
#plan table.tbl_plan tbody tr th,
#plan table.tbl_plan tbody tr td {
	vertical-align: middle;
}
#plan table.tbl_plan tbody tr th {
	background-color: #363480;
	width: 320px;
	text-align: center;
	color: #fff;
	font-size: 50px;
	font-weight: 700;
	line-height: 1.2;
	padding: 20px 15px;
}
#plan table.tbl_plan tbody tr:nth-of-type(even) th {
	background-color: #5e5d99;
}
#plan table.tbl_plan tbody tr:last-of-type th {
	font-size: 44px;
	padding: 15px;
}
#plan table.tbl_plan tbody tr + tr th {
	border-top: 3px dotted #fff;
}
#plan table.tbl_plan tbody tr th span {
	font-size: 25px;
	font-weight: 500;
	color: #ffe100;
	display: block;
	text-align: center;
}
#plan table.tbl_plan tbody tr td {
	font-size: 21px;
	padding: 15px;
}
#plan table.tbl_plan tbody tr + tr td {
	border-top: 3px dotted #b5b5b6;
}
#plan table.tbl_menu {
	margin-top: 10px;
}
#plan table.tbl_menu th,
#plan table.tbl_menu td {
	padding: 15px 20px;
	vertical-align: middle;
}
#plan table.tbl_menu thead tr th {
	background-color: #363480;
	color: #fff;
	text-align: center;
	font-size: 25px;
	font-weight: 700;
	line-height: 1.2;
}
#plan table.tbl_menu thead tr:first-of-type th {
	padding-left: 0px;
	padding-right: 0px;
}
#plan table.tbl_menu thead tr td {
	padding-left: 0px;
	padding-right: 0px;
}
#plan table.tbl_menu thead tr th + th {
	border-left: 2px solid #fff;
}
#plan table.tbl_menu thead tr + tr th,
#plan table.tbl_menu thead tr + tr td {
	padding-top: 10px;
	padding-bottom: 10px;
}
#plan table.tbl_menu thead tr + tr th {
	background-color: #5e5d99;
	border-top: 2px solid #fff;
	font-weight: 500;
	text-align: right;
}
#plan table.tbl_menu thead tr + tr td {
	background-color: #efefef;
	font-size: 20px;
	text-align: center;
	border-top: 2px solid #efefef;
}
#plan table.tbl_menu thead tr + tr + tr td {
	border-top-color: #231815;
}
#plan table.tbl_menu thead tr + tr td + td {
	border-left: 2px solid #231815;
}
#plan table.tbl_menu tbody tr th,
#plan table.tbl_menu tbody tr td {
	font-size: 20px;
}
#plan table.tbl_menu tbody tr + tr th,
#plan table.tbl_menu tbody tr + tr td {
	border-top: 3px dotted #b5b5b6;
}
#plan table.tbl_menu tbody tr th {
	color: #363480;
	width: 155px;
	padding-right: 0px;
}
#plan table.tbl_menu tbody tr td {
	border-left: 2px solid #231815;
	text-align: center;
	width: 100px;
}
#plan table.tbl_menu tbody tr th + td {
	font-weight: 300;
	text-align: left;
	width: auto;
}
#plan table.tbl_menu tbody tr td:last-of-type {
	width: 150px;
}
#plan table.tbl_menu tfoot th,
#plan table.tbl_menu tfoot td {
	border-top: 2px solid #231815;
	padding-top: 10px;
	padding-bottom: 10px;
}
#plan table.tbl_menu tfoot th {
	text-align: right;
	font-size: 23px;
}
#plan table.tbl_menu tfoot td {
	border-left: 2px solid #231815;
	text-align: center;
	font-size: 20px;
	padding-left: 0px;
	padding-right: 0px;
	line-height: 1.4;
}
#plan .option {
	margin-top: 15px;
	font-size: 20px;
}
#plan .option h5 {
	font-weight: 500;
}
#plan .option dl {
}
#plan .option dl dt {
	position: relative;
	padding-left: 1em;
	margin-top: 5px;
	font-weight: 500;
}
#plan .option dl dt::before {
	content: "";
	display: block;
	position: absolute;
	top: 14px;
	left: 6px;
	width: 5px;
	height: 5px;
	background-color: #333;
	border-radius: 50%;
}
#plan .option dl dd {
	margin-top: 5px;
}
@media only screen and (max-width: 767px) {
	#plan {
		padding-bottom: 50px;
	}
	#plan h3 {
		font-size: 24px;
	}
	#plan h3 + p {
		font-size: 18px;
		margin-top: 20px;
	}
	#plan h3 + p span {
		font-size: 22px;
	}
	#plan h4 {
		font-size: 20px;
	}
	#plan table.tbl_plan tbody tr th,
	#plan table.tbl_plan tbody tr td {
		display: block;
		width: 100%;
		border: none!important;
	}
	#plan table.tbl_plan tbody tr th {
		font-size: 28px!important;
		padding: 10px 15px!important;
	}
	#plan table.tbl_plan tbody tr th span {
		font-size: 20px;
	}
	#plan table.tbl_plan tbody tr td {
		font-size: 18px;
	}
	#plan table.tbl_menu {
		min-width: 900px;
	}
	#plan table.tbl_menu thead tr th,
	#plan table.tbl_menu thead tr + tr td,
	#plan table.tbl_menu tbody tr th,
	#plan table.tbl_menu tbody tr td {
		font-size: 17px;
	}
	#plan table.tbl_menu tfoot th {
		font-size: 20px;
	}
	#plan table.tbl_menu tfoot td {
		font-size: 17px;
	}
	#plan table.tbl_menu tbody tr td {
		width: 85px;
	}
	#plan table.tbl_menu tbody tr td:last-of-type {
		width: 110px;
	}
	#plan .option {
		font-size: 17px;
	}
}

/*******************************************

-------------------------------------------
解決事例
********************************************/

#case {
}
#case h3 {
	font-size: 42px;
	font-weight: 700;
	text-align: center;
	line-height: 1.2;
}
#case h3 span {
	display: block;
	text-align: center;
	font-size: 38px;
	color: #363480;
	margin-bottom: 10px;
}
#case h3 + p {
	font-size: 25px;
	font-weight: 300;
	margin-top: 40px;
}
#case h4 {
	font-size: 25px;
	margin-top: 50px;
}
#case .case_photo {
	text-align: center;
	margin-top: 40px;
}
#case .area {
	text-align: center;
	margin-top: 20px;
}
@media only screen and (max-width: 767px) {
	#case h3 {
		font-size: 28px;
	}
	#case h3 span {
		font-size: 24px;
	}
	#case h3 + p {
		font-size: 18px;
		margin-top: 20px;
	}
	#case h4 {
		font-size: 20px;
		margin-top: 40px;
	}
}

/*******************************************

-------------------------------------------
リスク
********************************************/

#risk {
	background-color: #efefef;
	padding-top: 50px;
	padding-bottom: 60px;
}
#risk h3 {
	font-size: 30px;
	text-align: center;
}
#risk ul {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 65px;
	margin-top: 70px;
	padding-bottom: 20px;
}
#risk ul li {
	width: 220px;
	background-color: #fff;
	border-radius: 50%;
}
#risk ul li .risk_item {
	position: relative;
	padding-top: 100%;
	height: 0;
}
#risk ul li .risk_item > img {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
}
#risk ul li .risk_item p {
	position: absolute;
	bottom: -15px;
	left: 0;
	text-align: center;
	width: 100%;
}
#risk ul + p {
	font-size: 25px;
	font-weight: 300;
	margin-top: 60px;
}
@media only screen and (max-width: 767px) {
	#risk {
		padding-bottom: 50px;
	}
	#risk h3 {
		font-size: 24px;
	}
	#risk ul {
		gap: 60px 40px;
	}
	#risk ul + p {
		font-size: 18px;
		margin-top: 20px;
	}
}
@media only screen and (max-width: 550px) {
	#risk ul {
		margin-top: 50px;
		gap: 50px 15px;
	}
	#risk ul li {
		width: calc((100% - 15px) / 2);
	}
	#risk ul li .risk_item > img {
		width: 60%;
	}
	#risk ul li .risk_item p img {
		height: 30px;
	}
}

/*******************************************

-------------------------------------------
空き家住宅診断
********************************************/

#checkup {
}
#checkup h3 {
	font-size: 38px;
	text-align: center;
	font-weight: 500;
	line-height: 1.2;
}
#checkup h3 span {
	display: block;
	font-weight: 700;
	text-align: center;
	font-size: 42px;
}
#checkup h3 + p {
	font-size: 29px;
	text-align: center;
	margin-top: 40px;
}
#checkup h3 + p + p {
	font-size: 25px;
	font-weight: 300;
	margin-top: 40px;
}
#checkup figure {
	text-align: center;
	margin-top: 40px;
}
#checkup figure figcaption {
	font-size: 20px;
	text-align: right;
	margin-top: 10px;
}
#checkup a.btn_contact {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 85%;
	max-width: 340px;
	height: 50px;
	background-color: #393782;
	color: #fff;
	font-size: 26px;
	font-weight: 500;
	margin: 70px auto 0;
}
@media only screen and (max-width: 767px) {
	#checkup h3 {
		font-size: 22px;
		line-height: 1.4;
	}
	#checkup h3 span {
		font-size: 26px;
		display: inline;
	}
	#checkup h3 + p {
		font-size: 20px;
		margin-top: 20px;
		text-align: left;
	}
	#checkup h3 + p + p {
		font-size: 18px;
		margin-top: 20px;
	}
	#checkup figure figcaption {
		font-size: 16px;
	}
	#checkup a.btn_contact {
		font-size: 22px;
		margin-top: 50px;
		border-radius: 5px;
	}
}
