@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@200..900&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Josefin+Sans:ital,wght@0,100..700;1,100..700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&display=swap');
/*
Theme Name:mrp-child
Template:mrp
Version: 1.0.0
*/
/*
DesignCode CSS: ver 0.01
*/
/*------------------------------------------------------
Theme Material
------------------------------------------------------*/


.fw_contents {
    margin-top: 0;
    margin-bottom: 0;
}
#content:has(.fw_contents), body:not(.home) #content:has(.fw_contents).wide {
    padding: 0;
}



/*------
 * h2タイトル
				
--------------------------------------------*/
.post h2 {
	color: #111;
	font-family: var(--font-family03);
	font-size: min(calc(11rem + (1vw - 1.92rem) * 4.2071), 11rem);
	font-weight: 700;
	/* font-family: var(--font-family02);
	font-size: var(--rem36);
	font-weight: 600;
	text-align: center;
    color: #111;
    line-height: 1.4;
	overflow-wrap: break-word;
	padding: 0;
	margin: var(--rem42) auto var(--rem30);
	border: none;
	background: transparent; */
}
.post h2::before {
	content: none;
}
.post h2::after {
	content: none;
}
.post .sub_ttl {
    display: block;
    font-size: 50%;
	color: var(--color-primary);
	font-weight: 600;
	padding: 0;
    margin: var(--rem30) 0 0;
	border: none;
	background: transparent;
}

/* リンクボタン */
.linkBtn, .post .linkBtn, a.linkBtn, .post .subimitarea .linkBtn input[type="submit"] {
    position: relative;
    display: inline-block;
    width: 100%;
    max-width: 340px;
    font-size: var(--rem16);
    color: #fff;
    line-height: 1.8;
    text-align: center;
    background: #111;
    font-weight: 600;
    padding: var(--rem20) 20px var(--rem16);
    margin: var(--px40) auto 0;
    border: none;
/*     border-radius: 50vh; */
    transition: all .3s;
	@media screen and (max-width: 768px) {
		padding-bottom: var(--rem12);
	}
}
.post .linkBtn::after, .linkBtn::after, a.linkBtn::after {
    border-color: #fff;
}
.post .linkBtn:hover, .linkBtn:hover, a.linkBtn:hover, .post .subimitarea .linkBtn input[type="submit"]:hover {
    color: #fff;
    background: var(--color-primary-tint);
}
.post .linkBtn:hover::after, .linkBtn:hover::after, a.linkBtn:hover::after {
    border-color: #fff;
}
.subimitarea > .linkBtn {
    background: transparent !important;
    padding: 0 !important;
    margin: 0 !important;
    border: none !important;
}
.post .subimitarea .linkBtn input[type="submit"] {
    margin-top: 0;
}
.linkBtn, .post .linkBtn, a.linkBtn, .post .subimitarea .linkBtn input[type="submit"] {
	&.linkBtn--round {
		max-width: 270px;
		color: #fff;
		font-family: "Bebas Neue", "Noto Sans JP", sans-serif;
		font-size: var(--rem18);
		font-weight: 400;
		letter-spacing: .2em;
		background-color: transparent;
		/* padding-right: 54px; */
		border: 1px solid #fff;
		border-radius: 50vw;
		&:hover {
			color: #111;
			background-color: #fff;
		}
		span:last-child {
			position: relative;
			top: -1px;
			font-size: min(calc(1.3rem + (1vw - 1.92rem) * 0.1294), 1.3rem);
			font-weight: 700;
			letter-spacing: .3em;
			margin-left: 10px;
		}
	}
	&.linkBtn--ico-arrow {
		display: flex;
		align-items: center;
		justify-content: center;
		min-height: 70px;
		&::before {
			display: none;
		}
		/* &:hover::before {
			background: #111;
		}
		&::before {
			position: absolute;
			top: 40px;
			right: 50px;
			content: "";
			width: 22px;
			height: 1px;
			background: #fff;
			border: none;
			transition: all .3s;
		} */
		&:hover::after {
			background: url(/wp-content/uploads/ico_arrow_01.png) no-repeat center / cover;
		}
		&::after {
			position: static;
			top: unset;
			width: 22px;
			height: 10px;
			margin-left: 20px;
			background: transparent url(/wp-content/uploads/ico_arrow_01_white.png) no-repeat center / cover;
			border: none;
			transform: none;
			/* top: 39px;
			right: 50px;
			content: "";
			width: 10px;
			height: 1px;
			background: #fff;
			border: none;
			transform: rotate(42deg);
			transition: all .3s; */
		}
		&.linkBtn--white {
			&:hover::after {
				background: url(/wp-content/uploads/ico_arrow_01_white.png) no-repeat center / cover;
			}
			&::after {
				background: url(/wp-content/uploads/ico_arrow_01.png) no-repeat center / cover;
			}
		}
	}
	&.linkBtn--white {
		color: #111;
		border: 1px solid #111;
		background: #f5f5f5;
		&:hover {
			color: #fff;
			background: #0168B7;
			border: 1px solid #0168B7;
		}
		/* &.linkBtn--ico-arrow {
			&:hover::before {
				background: #fff;
			}
			&::before {
				background: #111;
			}
			&:hover::after {
				background: #fff;
			}
			&::after {
				background: #111;
			}
		} */
	}
	&.linkBtn--width-fit {
			max-width: none;
			width: fit-content;
			padding-left: var(--px50);
			padding-right: var(--px50);
			padding-bottom: var(--px20);
			@media screen and (max-width: 768px) {
				padding-bottom: var(--px24);
			}
		}
}

/*----------------------------
テーブル
-----------------------------*/

table, .post table {
    width: 100%;
    margin: var(--px30w) auto;
}
table, table th, table td, .post table, .post table th, .post table td {
	border: none;
}
table th, table td, .post table th, .post table td {
  border-bottom: solid 1px var(--color-table-border);
	line-height: 2;
	padding: var(--px20) min(calc(15px + (1vw - 19.2px) * 0.4531), 15px);
	text-align: left;
}
table th, .post table th {
	width: 25%;
	color: var(--color-font);
	font-weight: bold;
	background: transparent;
  border-bottom: solid 1px var(--color-font);
}
table td, .post table td {
	color: var(--color-font);
	background: transparent;
}
table:first-child, .post table:first-child {
	margin-top: 0;
}
table:last-child, .post table:last-child {
	margin-bottom: 0;
}
body.home .linkBtn, .post .linkBtn, a.linkBtn, .post .subimitarea .linkBtn input[type="submit"] &.linkBtn--round {
	margin: 0
}
:root {
	
	/*------▼基本設定▼------*/
	--color-background: #FFF;
	--color-font: #111111;
	--color-primary: #0168B7;
	--color-primary-shade: #30B1AE;
	--color-primary-tint: #00A0DA;
	--color-secondary: #ED6A5A;
	--color-table-border: #DDD;
	--color-table-th: #f2f2f2;
	--body-font-family: 'Noto Sans JP', sans-serif;
	--content-max-width: 1240px;
	/*------▼ヘッダー設定▼------*/
	--header-background: #F5F5F5;
	--header-color-font: #111111;
	--header-color-primary: #0168B7;
	--header-color-primary-shade: #00A0DA;
	--header-color-primary-tint: #237DB0;
	/*------▼フッター設定▼------*/
	--footer-background: #fff;
	--footer-color-font: #111111;
	--footer-color-primary: #111111;
	/*------▼フォント設定▼------*/
	--font-family01: 'Noto Sans JP', sans-serif;
	--font-family02: "Noto Serif JP", serif;
	--font-family03: "Josefin Sans", sans-serif;
	--font-family04: "Bebas Neue", sans-serif;
}
/*--------------------------------------------------
	親CSS調整
--------------------------------------------------*/
.post {
	background: none;
}
@media screen and (max-width: 1023px) {
	body.home #content, #content.wide {
		width: 90%;
	}
}

/*--------------------------------------------------
	オリジナル設定
--------------------------------------------------*/
.fs { font-size: 85%; }
.fm { font-size: 115%; }
.fm2 { font-size: 130%; }
.red { color: #FC0000; }
.b { font-weight: bold; }
.pick { color: var(--color-primary); }
p.txt_ind { text-indent: -1em; margin-left: 1em; }
p.nm { padding-bottom: 0; }
.pb15 { padding-bottom: var(--px150) !important; }
.border-b {
	position: relative;
	&::after {
		position: absolute;
		left: 0;
		bottom: 0;
		display: block;
		content: "";
		width: 100vw;
		height: 1px;
		margin-left: calc(((100vw - 100%) / 2) * -1);
		margin-right: calc(((100vw - 100%) / 2) * -1);
		background: #ccc;
	}
}
.font-f-01 {
    font-family: var(--font-family01) !important;
	font-size: var(--rem14) !important;
	letter-spacing: 0.05em !important;
}
/**/
.cen { text-align: center; }
.lft { text-align: left; }
.rit { text-align: right; }
.pad_anchor { margin-top: -115px; padding-top: 115px; }
/* 非表示用 */
@media print, screen and (min-width: 641px){ /* PC用 */
	.dsp_smt { display: none; }
	.cen_pc { text-align: center; }
}
@media only screen and (max-width: 640px){ /* スマホ用 */
	.dsp_hp { display: none; }
}

/*--------------------------------------------------
	ヘッダ
--------------------------------------------------*/
@media only screen and (min-width: 1024px) {
	#header {
		height: 120px;
	}
	#header .inner {
		padding-left: 0;
		padding-right: 0;
	}
	#header a.head_btn {
		font-size: min(calc(2.3rem + (1vw - 1.92rem) * 0.5825), 2.3rem);
		font-weight: 700;
		padding: min(calc(10px + (1vw - 19.2px) * 0.2232), 10px) min(calc(83px + (1vw - 19.2px) * 1.2298), 83px);
	}
	#header a.head_btn.tel_btn::before {
		display: none;
	}
	#header a.head_btn.tel_btn {
		color: #fff;
	}
	#header a.head_btn.tel_btn b.telnum {
		padding-left: 30px;
		background: url(/wp-content/uploads/header_tel.png) no-repeat left center / 20px auto;
		font-size: 24px;
	}
	#header a.head_btn.tel_btn .note {
		font-size: 11px;
	}
	#header a.head_btn.mail_btn::before {
		display: none;
	}
	nav#mainNav {
		height: auto;
	}
	/* 特定のGメニューの色を変更した
	nav#mainNav ul li#menu-item-57 a {
		height: 80px;
		background: var(--header-color-primary);
		transition: all 0.3s ease-out;
	}
	nav#mainNav ul li#menu-item-57 a:hover {
		background: var(--header-color-primary-tint);
	}
	nav#mainNav ul li#menu-item-57 a b,
	nav#mainNav ul li#menu-item-57 a span {
		color: #fff !important;
	}
	*/
	/* フォントが「Zen Kaku Gothic New」で太さがmiddleの場合
	nav#mainNav ul li a b {
		font-weight: 500;
	}
	*/
	nav#mainNav ul li a {
		font-family: var(--font-family03);
		font-size: min(calc(1.6rem + (1vw - 19.2px) * 0.2232), 1.6rem);
		padding: var(--px20) var(--px30);
	}
	nav#mainNav ul li a b,
	nav#mainNav ul li a span {
		font-weight: 700;
	}
	nav#mainNav ul li a span {
		color: var(--header-color-primary) !important;
	}
	nav#mainNav ul li.current-menu-item a, nav#mainNav ul li a:hover, nav#mainNav ul li a:active, nav#mainNav ul li.current-menu-parent a, nav#mainNav ul li.current-menu-ancestor a {
		background: none;
	}
	nav#mainNav ul li li a:hover, nav#mainNav ul li li.current-menu-item a, nav#mainNav ul li li.current-menu-item li a:hover, nav#mainNav ul li.current-menu-item li a:hover, nav#mainNav ul li.current-menu-ancestor li.current-menu-item a, nav#mainNav ul li.current-menu-ancestor li a:hover {
		background: #f6f6f6;
	}
}
@media only screen and (max-width: 1300px) and (min-width: 1024px){
	#header .logo {
		width: 20%;
	}
	#header .logo img {
		width: auto;
		height: auto;
		max-width: 100%;
	}
	nav#mainNav ul li a {
		padding-left: 15px;
		padding-right: 15px;
	}
}
@media only screen and (max-width: 1023px) {
	body.mobile { margin-top: 60px; }
	body.mobile #breadcrumb { margin-top: 0; }
	body.mobile #header { z-index: 200; }
}
/*--------------------------------------------------
	フッタ
--------------------------------------------------*/
#footer {
	padding-top: 0;
	padding-bottom: 0;
}
#footer .inner {
	display: flex;
    align-items: center;
	column-gap: min(calc(4.4rem + (1vw - 1.92rem) * 1.4239), 4.4rem);
	max-width: unset;
	padding: min(calc(5.5rem + (1vw - 1.92rem) * 1.2945), 5.5rem) 0;
	margin-left: auto;
	margin-right: auto;
}
#footer .address {
	text-align: left;
}
#footer .footnav ul > li::before, #footer .footnav ul > li::after {
	background: none;
}
#footer .footnav ul > li::before {
	top: -1px;
	content: url(/wp-content/uploads/ico_circle-arrow_01.png);
}
#footer .footnav ul > li {
	padding-left: 22px;
	margin-bottom: 0;
}
#footer ul li a {
    font-family: var(--font-family03);
	font-size: min(calc(1.3rem + (1vw - 1.92rem) * 0.1294), 1.3rem);
	font-weight: 700;
	letter-spacing: .1em;
}
#footer .footer__logo:not(:last-child) {
    margin-bottom: 0;
}
/* ロゴの大きさ調整
#footer .footer__logo img {
	max-height: var(--px100);
}
*/
.copyright_wrapper {
	background: #0168B7;
}
#copyright {
	color: #fff;
	margin-left: auto;
	margin-right: auto;
	width: 95%;
	padding: min(calc(4.2rem + (1vw - 1.92rem) * 1.2945), 4.2rem) 0 min(calc(3.2rem + (1vw - 1.92rem) * 1.0356), 3.2rem);
	margin-top: 0;
	background: #0168B7;
	text-align: right;
}

/*--------------------------------------------------
	パンくず
--------------------------------------------------*/
#breadcrumb {
	background: #fff;
	padding: 0;
}
#breadcrumb ul {
	max-width: 1830px;
	padding: min(calc(11rem + (1vw - 1.92rem) * 2.5890), 11rem) 40px var(--rem72);
	margin: 0 auto;
}

/*--------------------------------------------------
	共通
--------------------------------------------------*/
.bg_wide { position: relative; }
.bg_wide::before,
.bg_wide.bg_after::after {
	position: absolute;
	top: 0;
	left: 0;
	display: block;
	width: 100vw;
	height: 100%;
	margin-left: calc(((100vw - 100%) / 2) * -1);
	margin-right: calc(((100vw - 100%) / 2) * -1);
	content: "";
	z-index: -1;
}
.box_w2_sp {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
.box_w2_sp.rev { flex-direction: row-reverse; }
.box_w2_sp.vtop { align-items: flex-start; }
.box_w2_sp.vcen { align-items: center; }
.box_w2_sp.vbtm { align-items: flex-end; }
.box_pad { padding: 20px; box-sizing: border-box; }
.box_w2 .column2_50:not(.cen) { text-align: left; }
@media print, screen and (min-width: 641px){ /* PC用 */
	.bg_fix::before { background-attachment: fixed !important; }
	.box_w2 {
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
	}
	.box_w2.rev { flex-direction: row-reverse; }
	.box_w2.vtop { align-items: flex-start; }
	.box_w2.vcen { align-items: center; }
	.box_w2.vbtm { align-items: flex-end; }
	.box_pad { padding: 30px; }
	.box_w2 .column3_33 { width: 32%; }
	.box_w2 .column2_50 { width: 48.5%; }
	.box_w2 .column2_60 { width: 57%; }
	.box_w2 .column2_70 { width: 67%; }
	.box_w2 .column2_80 { width: 77%; }
}
@media print, screen and (min-width:769px){ /* PCのみ */
	.box_pad { padding: 50px; }
}
/**/
.box_w2 .column3_33 img, .box_w2 .column2_30 img,
.box_w2 .column2_40 img, .box_w2 .column2_50 img {
	max-width: 100%;
}
/**/
.post p {
	font-size: min(calc(1.3rem + (1vw - 1.92rem) * 0.1294), 1.3rem);
	line-height: 1.8;
}
/**/
.w100 {
	width: 100vw;
	margin-left: calc(((100vw - 100%) / 2) * -1) !important;
	margin-right: calc(((100vw - 100%) / 2) * -1) !important;
}
.w600, .w800, .w900 {
	width: 600px;
	max-width: 100%;
	margin: auto;
}
.w800 { width: 800px; }
.w900 { width: 900px; }

/**/
.post .linkBtn {
	border-radius: 0;
	background: var(--color-primary);
}
/*--------------------------------------------------
	トップページ
--------------------------------------------------*/
#mainImg {
	display: none;
}
.home { background: #f5f5f5; }
.home #wrapper, .inner {
    max-width: 1830px;
	padding: 0 40px;
}
@media screen and (max-width: 768px) {
	.home #wrapper, .inner {
		padding: 0;
	}
}
.mv {
	position: absolute;
	top: min(calc(21.2rem + (1vw - 1.92rem) * 5.8900), 21.2rem);
}
@media screen and (max-width: 768px) {
	.mv {
		top: 18.4rem;
		width: 90%;
	}
}
/* SERVICE */
.card-block {
	position: relative;
    padding-top: min(calc(65.2rem + (1vw - 1.92rem) * 19.4175), 65.2rem);
    padding-bottom: min(calc(8.5rem + (1vw - 1.92rem) * 1.2945), 8.5rem);
	margin-top: min(calc(23rem + (1vw - 1.92rem) * 6.4725), 23rem);
	& + & {
		margin-top: var(--px20);
	}
	&::before {
		content: "";
		display: block;
		width: 100vw;
		height: 100%;
		margin-left: calc(((100vw - 100%) / 2)* -1);
    	margin-right: calc(((100vw - 100%) / 2)* -1);
		position: absolute;
		top: 0;
		left: 0;
		z-index: -1;
	}
	&.top-estate::before {
		background: url(/wp-content/uploads/top_content_01.png) no-repeat center / cover;
	}
	&.top-construction::before {
		background: url(/wp-content/uploads/top_content_02.png) no-repeat center / cover;
	}
	&.top-longing::before {
		background: url(/wp-content/uploads/top_content_03.png) no-repeat center / cover;
	}
	&.top-solarpower::before {
		background: url(/wp-content/uploads/top_content_04.png) no-repeat center / cover;
	}
	.card-block__header {
		h2 {
			color: #fff;
			font-family: var(--font-family04);
			font-size: min(calc(3.5rem + (1vw - 1.92rem) * 0.7120), 2.4rem);
			font-weight: 700;
			margin-bottom: 0;
			span:first-child {
				margin-right: min(calc(3.2rem + (1vw - 1.92rem) * 0.7767), 3.2rem);
				font-weight: 400;
				letter-spacing: .2em;
			}
			span:last-child {
				position: relative;
				top: -3px;
				font-family: var(--font-family01);
				font-size: min(calc(1.3rem + (1vw - 1.92rem) * 0.1294), 1.3rem);
				letter-spacing: .5em;
			}
		}
	}
	.card-block__body {
		display: flex;
		justify-content: space-between;
		align-items: flex-end;
		@media screen and (max-width: 768px) {
			align-items: flex-start;
			.linkBtn {
				align-self: flex-end;
			}
		}
		p {
			color: #fff;
			font-size: var(--rem14);
			line-height: 2;
		}
	}
}
@media screen and (max-width: 768px) {
	.card-block {
		.card-block__header {
			margin-bottom: var(--rem16);
		}
		.card-block__body {
			flex-direction: column;
			row-gap: var(--rem16);
		}
	}
}
/* ABOUT */
.post .top-about {
	h2, p { color: #fff; }
	p {
		font-size: min(calc(1.5rem + (1vw - 1.92rem) * 0.1294), 1.5rem);
		line-height: calc(47 / 15);
	}
}
.top-about {
	padding-top: var(--px160);
	&.bg_wide::before {
		background: linear-gradient(to bottom, #0168B7 72%, #fff 72%);
	}
	.top-about__figure {
		margin-top: min(calc(11.3rem + (1vw - 1.92rem) * 2.5890), 11.3rem);
	}
}
@media screen and (max-width: 768px) {
	.top-about {
		&.bg_wide::before {
			background: linear-gradient(to bottom, #0168B7 94%, #fff 94%);
		}
	}
}

/* INFOMATION */
post .top-about {
	h2 { margin-bottom: 7xp; }
}
.top-info {
	margin-top: min(calc(13rem + (1vw - 1.92rem) * 2.5890));
	margin-bottom: min(calc(12.6rem + (1vw - 1.92rem) * 2.5890), 12.6rem);
}
.postlist li:first-child {
    border-top: 1px solid #ccc;
}
.postlist li:last-child {
    border-bottom: 1px solid #ccc;
}
.postlist li + li {
	border-top: 1px solid #ccc;
}
.postlist .post_text {
    padding: 26px 0;
}

/* .home #content h1 b {
	display: block;
}
#front-sectionPost h1.title span,
#content h1 b {
	font-family: var(--font-family02);
	font-weight: 500;
}
#front-sectionPost h1.title span span,
#content h1 b+span {
	font-family: var(--body-font-family);
	display: block;
	font-size: var(--rem14);
	color: var(--color-primary-shade);
	font-weight: 500;
}*/

/**/
#top_business::before {
	background: url(/wp-content/uploads/top_business_bg.jpg) no-repeat center center / cover;
}
#top_business h1 {
	text-align: left;
}
#top_business .link li {
	padding: 0;
	margin: 0;
	margin-bottom: 2rem;
}
#top_business .link li a {
	position: relative;
}
#top_business .link li .btn {
	position: absolute;
    top: 50%;
    -moz-transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    transform: translateY(-50%);
	left: 10px;
	width: 70%;
	padding: 10px;
	color: #fff;
	border-bottom: solid 1px #fff;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
#top_business .link li .btn b {
	font-weight: normal;
	font-size: var(--rem18);
}
#top_business .link li .btn span img {
	width: 30px;
}
@media print, screen and (min-width: 641px){ /* PC用 */	
	#top_business .txt {
		box-sizing: border-box;
		width: 45%;
	}
	#top_business .link {
		box-sizing: border-box;
		width: 50%;
	}
	#top_business .link li .btn {
		width: 50%;
	}
}
@media only screen and (max-width: 640px){ /* スマホ用 */
	#top_business .txt {
		margin-bottom: 4rem;
	}
}
/**/
#contact_box::before {
	background: url(/wp-content/uploads/top_contact_bg.jpg) no-repeat center center / cover;
}
#contact_box .btn {
	width: 800px;
	max-width: 100%;
	margin: auto;
}
#contact_box .btn a {
	height: 100%;
	padding: 15px;
	background: var(--color-primary-shade);
	color: #fff;
	line-height: 1.5;
	transition: all 0.3s ease-in-out;
	/* 縦方向中央揃え */
	display: flex;
	align-items: center;
	justify-content: center;
	flex-direction: column;
}
#contact_box .btn a i {
	margin-right: 8px;
}
#contact_box .btn .tel a b {
	font-size: 150%;
}
#contact_box .btn a:hover,
#contact_box .btn .tel a {
	background: #F6F6F6;
	color: var(--color-primary-shade);
}
#contact_box .btn .tel a:hover {
	background: var(--color-primary-shade);
	color: #fff;
}
@media print, screen and (min-width: 641px){ /* PC用 */
	#contact_box .btn li {
		width: 50%;
	}
}
/**/
#front_top_content,
#front_bottom_content {
	background: none;
}
.post .time, .postlist .time, .post2b .time, .post4b .time {
	background: var(--color-primary);
}
#front-sectionPost .txt_c .linkBtn {
	background: none;
	border-radius: 0;
	border-bottom: solid 2px var(--color-primary-shade);
	color: var(--color-font);
	text-align: left;
	width: 230px;
	max-width: 100%;
}
#front-sectionPost .txt_c .linkBtn::after {
    border-color: var(--color-primary-shade);
}
#front-sectionPost .txt_c .linkBtn:hover:after {
    right: 1rem;
}

/*--------------------------------------------------
	CTA
--------------------------------------------------*/
body:not(.home) {
	.cta {
		margin-top: min(calc(18.8rem + (1vw - 1.92rem) * 3.8835), 18.8rem);
	}
}
.cta {
	.cta__items {
		display: flex;
		max-width: 1830px;
		padding: 0 40px;
		margin: 0 auto;
		@media screen and (max-width: 768px) {
			padding: 0 20px;
		}
	}
	.cta__item {
		position: relative;
		padding: min(calc(25.4rem + (1vw - 1.92rem) * 8.4142), 25.4rem) min(calc(7rem + (1vw - 1.92rem) * 2.2006), 7rem) var(--px80);
		&:first-child {
			padding-left: 0;
		}
		&::before {
			position: absolute;
			top: 0;
			left: 0;
			display: block;
			width: 50vw;
			height: 100%;
			margin-right: calc(((50vw - 100%) / 1) * -1);
			content: "";
			z-index: -1;
		}
		&:first-child::before {
			margin-left: calc((50vw - 100%) * -1);
			background: url(/wp-content/uploads/top_content_06.png) no-repeat center / cover;
		}
		&:last-child::before {
			margin-right: calc((50vw - 100%) * 1);
			background: url(/wp-content/uploads/top_content_07.png) no-repeat center / cover;
		}
	}
	.cta__ttl {
		color: #fff;
		font-family: "Josefin Sans", "Noto Sans JP", sans-serif;
		font-size: min(calc(7rem + (1vw - 1.92rem) * 1.9417), 7rem);
		font-weight: 700;
		margin-bottom: var(--px40);
		.cta__ttl--en { display: block; }
		.cta__ttl--ja {
			display: block;
			font-size: min(calc(1.5rem + (1vw - 1.92rem) * 0.1294), 1.5rem);
			letter-spacing: .5em;
		}
	}
	.cta__summary {
		color: #fff;
		font-size: var(--rem14);
		line-height: 2;
	}
}
@media screen and (max-width: 768px) {
	.cta {
		.cta__items {
			flex-direction: column;
		}
		.cta__item {
			margin-bottom: 0;
			&:first-child::before {
				margin-left: calc(((100vw - 100%) / 2) * -1);
			}
			&:last-child {
				padding-left: 0;
			}
			&::before {
				width: 100vw;
				margin-left: calc(((100vw - 100%) / 2) * -1);
				margin-right: calc(((100vw - 100%) / 2) * -1);
			}
		}
	}
}

/*--------------------------------------------------
	見出し
--------------------------------------------------*/
header#h1Header {
	background: transparent;
	overflow: unset;
	height: 109px;
	z-index: 1;
}
header#h1Header h1.title {
	position: relative;
    top: 26px;
	max-width: 1830px;
	padding: 0 40px 0;
	margin: 0 auto;
	color: #111;
    font-family: var(--font-family03);
    font-size: var(--rem120);
    font-weight: 700;
    text-align: left;
    letter-spacing: -.04em;
	transform: unset;
}
@media screen and (max-width: 768px) {
	header#h1Header h1.title{
		top: 68px;
	}
}
#thumbImg::before, header#h1Header::before {
	display: none;
}
h1.title, .post h1, .post h2, .post h3, .post h4 {
	color: var(--color-font);
}
.post h2.noline::after {
	display: none;
}
.post h3.noline {
	padding: 0;
	border: none;
}
.post h2 .sub_ttl {
	margin: var(--rem12) 0 0;
	color: var(--color-primary-shade);
}

body:not(.home) {
	.post h2 {
		font-family: "Josefin Sans", "Noto Sans JP", sans-serif;
		font-size: var(--rem60);
		margin-bottom: min(calc(2.8rem + (1vw - 1.92rem) * 0.6472), 2.8rem);
		.sub_ttl {
			color: #111;
			font-size: min(calc(1.7rem + (1vw - 1.92rem) * 0.1294), 1.7rem);
		}
	}
}

/*--------------------------------------------------
	下層ページ
--------------------------------------------------*/
body:not(.home) {
	background: #f5f5f5;
}
/**/
.post table {
	border-spacing: 10px;
	border-collapse: separate;
}
/**/
#service .page_contents_inner {
	padding: 0 40px;
	@media screen and (max-width: 768px) {
		padding: 0 20px;
	}
}
/* SERVICE */
.card-block-wrapper {
	.card-block {
		padding: 0;
		margin-top: var(--px120);
		&::before {
			display: none;
		}
		.card-block__page-figure {
			position: relative;
			aspect-ratio: 1920 / 600;
			@media screen and (max-width: 768px) {
				aspect-ratio: 375 / 500;
			}
			&::before {
				content: "";
				display: block;
				width: 100vw;
				height: 100%;
				margin-left: calc(((100vw - 100%) / 2)* -1);
				margin-right: calc(((100vw - 100%) / 2)* -1);
				position: absolute;
				top: 0;
				left: 0;
				z-index: -1;
			}
		}
		&.page-estate .card-block__page-figure::before {
			background: url(/wp-content/uploads/page_service_01.png) no-repeat center / cover;
		}
		&.page-construction .card-block__page-figure::before {
			background: url(/wp-content/uploads/page_service_02.png) no-repeat center / cover;
		}
		&.page-longing .card-block__page-figure::before {
			background: url(/wp-content/uploads/page_service_03.png) no-repeat center / cover;
		}
		&.page-solarpower .card-block__page-figure::before {
			background: url(/wp-content/uploads/page_service_04.png) no-repeat center / cover;
		}
		.card-block__num {
			position: absolute;
			left: 0;
			bottom: 0;
			/* color: #fff;
			font-family: var(--font-family03);
			font-size: min(calc(20rem + (1vw - 1.92rem) * 6.4725), 20rem);
			font-weight: 700; */
			@media screen and (max-width: 768px) {
				width: 35%;
			}
		}
		.card-block__header {
			h2 {
				color: #111;
				margin-top: min(calc(6.5rem + (1vw - 1.92rem) * 1.9417), 6.5rem);
				font-family: var(--font-family04);
				font-size: min(calc(3.5rem + (1vw - 1.92rem) * 0.7120), 2.4rem);
				font-weight: 700;
				@media screen and (max-width: 768px) {
					display: flex;
					flex-direction: column;
				}
				span {
					@media screen and (max-width: 768px) {
						margin-right: 0;
					}
				}
			}
		}
		.card-block__body {
			p {
				color: #111;
			}
		}
	}
}


/*--------------------------------------------------
	プライバシーポリシー その他
--------------------------------------------------*/
#breadcrumb ul li b,
#sitemap_list li a b {
	display: none;
}
/*--------------------------------------------------
	お問い合わせ
--------------------------------------------------*/
.wpcf7-form select {
	width: auto;
}
.wpcf7-form .must_fn {
	float: none;
}
.wpcf7-form .must {
	background: var(--color-primary);
}
.post form.wpcf7-form table,
.post form.wpcf7-form table td,
.post form.wpcf7-form table th {
	border: 0;
}
.post form.wpcf7-form table th {
	background: none;
	color: #474747;
}
.post form.wpcf7-form table tr {
	border-top: solid 1px #D9D9D9;
	border-bottom: solid 1px #D9D9D9;
}
/* ボタン */
.post form.wpcf7-form .linkBtn {
	width: 200px !important;
	padding: 0;
}
.post form.wpcf7-form .linkBtn .wpcf7-spinner {
	position: absolute;
	top: 50%;
	left: 0;
	-moz-transform: translate(-50%,-50%);
	-webkit-transform: translate(-50%,-50%);
	-ms-transform: translate(-50%,-50%);
	transform: translate(-50%,-50%);
}
.post form.wpcf7-form .linkBtn input[type="submit"] {
	padding: 15px 35px;
	background: var(--color-primary) !important;
}
.post form.wpcf7-form .linkBtn:hover input[type="submit"] {
	background: var(--color-primary-tint) !important;
}
body:not(.home) #content.wide {
	padding-bottom: 0 !important;
}