@charset "utf-8";


@charset "utf-8";
:root {
	--font-bs-family: "Noto Sans JP", sans-serif;
	--font-en-family: "Montserrat", sans-serif;
	
	
	--bs-black: #000000;
	--bs-white: #ffffff;
	--bs-dark: #333333;
	--text-color:#333333;
	
	--bs-gray-light: #e2e6e8;
	--bs-gray: #7a96a3;
	--bs-gray-dark: #36464e;
	
	
	--bs-gray-100: #f3f5f6;
	--bs-gray-200: #d4dde2;
	--bs-gray-300: #b6c6cd;
	--bs-gray-400: #98aeb8;
	--bs-gray-500: #7a96a3;
	--bs-gray-600: #607d8a;
	--bs-gray-700: #4b626c;
	--bs-gray-800: #36464e;
	
	--bs-main-light: #F2F2F2;

	
	
	--bs-primary: #0082d8;
	--bs-primary-rgb: 0, 130, 216;
	--bs-primary-light: #d9e2ef;
	--bs-primary-light-02: #339be0;
	--bs-primary-dark: #0062a2;
/*	--bs-primary-dark: #1A7143;
	--bs-primary-dark-rgb: 26, 113, 67;
	
	--bs-secondary-light-rgb: 167, 213, 189;*/
	
	--bs-secondary: #ea8a3c;
	--bs-secondary-rgb: 234, 138, 60;
	--bs-secondary-light : #daf5ff;
/*	--bs-secondary-rgb: 0, 149, 217;
	--bs-secondary-dark: #0070A3;
	--bs-secondary-dark-rgb: 0, 112, 163;
	--bs-secondary-light: #99D5F0;
	--bs-secondary-light-rgb: 153, 213, 240;*/
	
	--bs-tertiary: #00548b;
	
	--bs-success: #8CC63F;
	--bs-info: #009FE8;
	--bs-warning: #F7931E;
	--bs-danger: #e52d0b;
	--bs-danger-light: #fce6e2;

	--bs-red: #FC0E14;
	--bs-red-dark: #BD0B0F;
	--bs-red-light: #FE9FA1;
	
	--bs-gradient-primary : linear-gradient(100deg, #bfe0f5, #e5f2fb);
	--bs-gradient-primary-02 : linear-gradient(280deg, #bfe0f5, #e5f2fb);

	--bs-gradient-orange : linear-gradient(90deg, #F17C24, #ED1C24);

	--bs-gradient-blue : linear-gradient(180deg, #02ADBF, #0275A9 25%,#024195);
	
	--filter-box-shadow: drop-shadow(1px 1px 10px rgba(0 , 130 , 216, 0.2));

	--text-shadow: 1px 1px 15px rgba(0 , 130 , 216, 0.5);

	--max-width: 1360px;
	--max-width-02: 1580px;
	--def-width: 94%;


	--sec-padding-xs: 40px;
	--sec-padding-sm: 60px;
	--sec-padding-bs: 80px;
	--sec-padding-lg: 120px;

	--button-line-height-mini:28px;
 
	--border-radius-bs: 100px;

	--border-radius-img-bs: 40px;

	--font-size--bs: 16px;
	--font-size--sm: 14px;
	--font-size--md: 26px;
	--font-size--lg: 36px;
	--font-size--xl: 48px;
	--font-size--xxl: 54px;
	--font-size--xxxl: 62px;
	 
}


@media (max-width: 1400px) {
	:root {
		--font-size--bs: 16px;
		--font-size--sm: 14px;
		--font-size--md: 24px;
		--font-size--lg: 36px;
		--font-size--xl: 46px;
		--font-size--xxl: 50px;
		--font-size--xxxl:58px;
	}
}

/* X-Large devices (large desktops, 1200px and up) */
@media (max-width: 1200px) {
	:root {
		--border-radius-bs : 80px;
		--border-radius-img-bs: 30px;

		--font-size--bs: 16px;
		--font-size--sm: 14px;
		--font-size--md: 20px;
		--font-size--lg: 32px;
		--font-size--xl: 42px;
		--font-size--xxl: 48px;
		--font-size--xxxl:52px;
	}
}

/* Large devices (desktops, 992px and up) */
@media (max-width: 992px) {
	:root {
		--border-radius-bs : 60px;
		--border-radius-img-bs: 20px;

		--sec-padding-xs: 20px;
		--sec-padding-sm: 40px;
		--sec-padding-bs: 60px;
		--sec-padding-lg: 70px;
	}
}

/* Medium devices (tablets, 768px and up) */
@media (max-width: 768px) {
	:root {
		--border-radius-bs : 30px;
		--border-radius-img-bs: 15px;

		

		--font-size--bs: 16px;
		--font-size--sm: 14px;
		--font-size--md: 20px;
		--font-size--lg: 26px;
		--font-size--xl: 32px;
		--font-size--xxl: 36px;
		--font-size--xxxl:42px;
	}
}
/* Small devices (landscape phones, 576px and up) */
@media (max-width: 576px) {
	:root {
		--border-radius-bs : 25px;
		--border-radius-img-bs: 10px;

		--sec-padding-xs: 10px;
		--sec-padding-sm: 20px;
		--sec-padding-bs: 40px;
		--sec-padding-lg: 50px;

		--font-size--bs: 14px;
		--font-size--sm: 10px;
		--font-size--md: 18px;
		--font-size--lg: 20px;
		--font-size--xl: 24px;
		--font-size--xxl: 28px;
		--font-size--xxxl:34px;
	}
}

@media (max-width: 479px) {	
}












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

	スタイルの設定

=================================================================== */
html {
	font-size: var(--font-size--bs);
	scroll-behavior: smooth;
	font-feature-settings: "palt";
	letter-spacing: 0.02em;
}
body{
	color:var(--text-color);
	margin:0;
	background:var(--bs-white) url(../img/bk.png) no-repeat center top;
	background-size: 100% auto;
	font-family: var(--font-bs-family);
	font-weight: 500;
/*	font-feature-settings: "palt";*/
	font-size: var(--font-size--bs);
}
img {
/*	max-width: 100%;
	height: auto;*/
}

.bg {
	width: 100%;
	height: 100%;
	position: fixed;
	top: 0;
	left: 0;
	z-index: 999;
	background-color: rgba(51,51,51,0.7);
	display: none;
}

/* ===================================================================
	通常のリンク
=================================================================== */
a {
	transition: all .3s ease;
}
a:link {
	color: var(--text-color);
	text-decoration: none;
}
a:visited {
	color: var(--text-color);
	text-decoration:none;
}
a:hover {
	color: var(--text-color);
	text-decoration:none;
/*	opacity: 0.7;*/
}
a:active {
	color: var(--text-color);
	text-decoration:none;
}
/* メインエリアはリンクにアンダーライン */
/*#main a{
	text-decoration:underline;
}*/

/* ===================================================================
	#header
	ヘッダー
=================================================================== */

header {
	position: relative;
	position: fixed;
	width: 100%;
	height: 120px;
	top: 0;
	left: 0;
	background: rgba(255,255,255,0.7);
	backdrop-filter: blur(20px);
	
	z-index: 999;
}
.header_inner {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin: 0 20px;
	height: 120px;
}
.logo {
	margin: 0 10px 0 0;
}
.logo a {
	display: block;
}
.logo img {
	height: auto;
}
/* スマホメニュー */
.sp_menu_btn {
	display: none;
}

/* ヘッダーメニュー ------------- */
.header_menu {
	display: flex;
	align-items: center;
}
.gmenu {
}
.gmenu ul,
.gmenu li {
	list-style-type: none;
}
.gmenu ul {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin: 0;
	padding: 0;
}
.gmenu ul > li {
	margin: 0;
	position: relative;
}
.gmenu ul > li > a {
	display: block;
	padding: 1em 0.7em;
	font-weight: 500;
	text-align: center;
}
.gmenu ul > li > a:hover {
	color: var(--bs-primary);
}
.gmenu ul li.menu-item-has-children ul.sub-menu {
	display: block;
	background: var(--bs-white);
	position: absolute;
	left: 50%;
	transform: translateX(-50%);
	width: 10em;
	margin: 0;
	padding: 0.8em 1em;
	border-radius: 20px;
	opacity: 0;
	visibility: hidden;
	transition: all 0.3s ease-in;
	z-index: 1000;
	filter: var(--filter-box-shadow);
}
.gmenu li.menu-item-has-children:hover .sub-menu {
	display: block;
	opacity: 1;
	visibility: visible;
}
.gmenu li.menu-item-has-children .sub-menu li {
}
.gmenu li.menu-item-has-children .sub-menu li a {
	display: block;
	text-align: left;
	padding: .3em 0.3em;
	font-weight: 500;
	position: relative;
}
.gmenu li.menu-item-has-children .sub-menu li a:hover {
	color: var(--bs-primary);
}

.sp_header_menu,
.sp_gnav {
	display: none;
}

.header_contact {
	margin-left: 1em;
}
.header_contact a {
	display: flex;
	justify-content: center;
	align-items: center;
	padding: 0.7em 1em;
	background: var(--bs-primary);
	color: var(--bs-white);
	font-weight: 600;
	border-radius: 2em;
	position: relative;
}
.header_contact a img {
	margin-right: 10px;
}
.header_contact a:hover {
}


/* XX-Large devices (larger desktops, 1400px and up) */
@media (max-width: 1440px) {
	header,
	.header_inner {
		height: 100px;
	}
	.logo img {
		width: 180px;
	}
	.gmenu ul > li > a {
		font-size: var(--font-size--sm);
	}
	.header_contact a {
		font-size: var(--font-size--sm);
	}
	.header_contact a img {
		margin-right: 8px;
		height: var(--font-size--sm);
	}
}

/* X-Large devices (large desktops, 1200px and up) */
@media (max-width: 1200px) {
	header,
	.header_inner {
		height: auto;
	}
	.header_inner {
		margin: 0 0 0 3%;
	}
	.logo img {
		width: auto;
		height: 24px;
	}
	.header_menu {
		display: none;
	}
	.sp_header_menu {
		display: flex;
	}
	
	a.sp_btn_contact {
		display: flex;
		flex-direction: column;
		justify-content: center;
		align-items: center;
		padding: 0 10px;
		background: var(--bs-primary);
		color: var(--bs-white);
		font-size: 10px;
	}
	a.sp_btn_contact img {
		height: 18px;
		margin-bottom: 5px;
	}
	.sp_menu_btn {
		display: flex;
		justify-content: center;
		align-items: center;
		width: 60px;
		height: 60px;
		padding: 0;
		background: var(--text-color);
		color: var(--bs-white);
		line-height: 1;
		cursor: pointer;
		position: relative;
		z-index: 100;
	}
	.sp_menu_line {
		width: 24px;
		position: absolute;
		top: 50%;
		transform: translateY(50%);
		left: 18px;
	}
	.sp_menu_line span,
	.sp_menu_line::before,
	.sp_menu_line::after {
		content: "";
		display: inline-block;
		position: absolute;
		left: 0;
		background-color: var(--bs-white);
		width:  24px;
		height: 2px;
		border-radius: 1px;
		transition: 0.3s;
	}
	.sp_menu_line::before {
		top: -8px;
	}
	.sp_menu_line::after {
		top: 8px;
	}
	.sp_menu_btn.active .sp_menu_line span {
		display: none;
	}
	.sp_menu_btn.active .sp_menu_line::before {
		top: 0;
		transform:rotate(45deg);
		height: 2px;
	}
	.sp_menu_btn.active .sp_menu_line::after {
		top: 0;
		transform:rotate(-45deg);
		height: 2px;
	}

	/* メニュー */
	.sp_gnav {
		background: rgba(255,255,255,0.7);
		backdrop-filter: blur(20px);

		display: none;
		width: 100%;
		height: 100%;
		padding: 20px 3%;
		position: fixed;
		top: 60px;
		left: 0;
		bottom: 0;
		z-index: 9999;
/*		overflow: auto;
		overflow: hidden;*/
		overflow-y: auto;
	}
	.header_sp_menu > li {
		border-bottom: 1px solid rgba(var(--bs-primary-rgb),0.5);
	}
	.header_sp_menu > li:last-of-type {
		border-bottom: none;
	}
	.header_sp_menu > li > a {
		display: block;
		padding: 1.5rem 0.5rem;
		font-size: var(--font-size--md);
		font-weight: 700;
		color: var(--text-color);
	}
	.header_sp_menu  li  a:hover {
		color: var(--bs-primary);
	}
	.header_sp_menu .sub-menu {
		display: flex;
		margin: 0 0 1rem;
		padding: 0 0.5rem;
	}
	.header_sp_menu .sub-menu > li {
		margin: 0;
		width: 50%;
	}
	.header_sp_menu .sub-menu > li a {
		display: block;
		font-size: var(--font-size--bs);
		font-weight: 500;
		position: relative;
		padding: 0.5em 0.5em 0.5em 1em;
	}
	.header_sp_menu .sub-menu > li a::before {
		content: "";
		display: block;
		width: 0.5em;
		height: 0.5em;
		position: absolute;
		left: 0;
		top: 1em;
		background: var(--bs-primary);
		border-radius: 50%;
	}
}

/* Large devices (desktops, 992px and up) */
@media (max-width: 992px) {
	
}

/* Medium devices (tablets, 768px and up) */
@media (max-width: 768px) {
	
	

	

	
}
/* Small devices (landscape phones, 576px and up) */
@media (max-width: 576px) {
}

@media (max-width: 479px) {	
}


/* ===================================================================
	#footer
	フッター
=================================================================== */

footer {
	padding: 250px 0 50px;
	background: var(--bs-gradient-primary);
	position: relative;
	z-index:0;
}
footer::before {
	content: '';
	position: absolute;
	width: 100%;
	top: 0;
	left: 0;
	bottom: 0;
	mix-blend-mode: color-burn;
	background: url(../img/bk_cover.png) repeat top center;
	z-index: 1;
}
.footer_inner {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	width: var(--def-width);
	max-width: var(--max-width);
	margin: 0 auto;
	position: relative;
	z-index: 10;
}

.footer_info {
	width: 28%;
	max-width: 300px;
	margin-right: 40px;
}
.footer_btm {
	width: 100%;
}

.footer_logo {
	margin-bottom: 40px;
}
.footer_logo img {
}
.footer_info p {
	font-size: calc(var(--font-size--sm)*0.9);
}


.footer_menu_areas {
	max-width: 870px;
	width: 60%;
	flex-grow: 1;
	display: flex;
	justify-content: space-between;
}

.footer_nav {
}
.footer_menu,
.footer_menu li {
	list-style-type: none;
	margin: 0;
	padding: 0;
}
.footer_menu {
}
.footer_menu li {
	margin-bottom: 0.8em;
}
.footer_menu li a {
	font-weight: 700;
}
.footer_menu li a:hover {
	color: var(--bs-primary);
}
.footer_menu li a:hover {
	color: var(--bs-primary);
}
.sub-menu {
	margin-top: 0.8em;
	margin-left: 1em;
}
.sub-menu li {
	font-size: 90%;
	margin-bottom: 0.5em;
}
.sub-menu li a {
	font-weight: 400;
	
}
.footer_bn_list {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	margin: 80px 0;
}
.footer_bn_list li {
	width: 48.5%;
	max-width: 660px;
}
.footer_bn_list li a {
	display: inline-block;
}
.footer_bn_list li a:hover {
	opacity: 0.8;
}
.footer_bn_list li a img {
	filter: var(--filter-box-shadow);
}
    

address {
	width: 100%;
	margin: 0;
	font-style: normal;
	font-weight: 500;
	font-size: calc(var(--font-size--sm)*0.9);
	font-family: var(--font-en-family);
	text-align: center;
}

/* XX-Large devices (larger desktops, 1400px and up) */
@media (max-width: 1440px) {
}

/* X-Large devices (large desktops, 1200px and up) */
@media (max-width: 1200px) {
}

/* Large devices (desktops, 992px and up) */
@media (max-width: 992px) {
	.footer_info,
	.footer_menu_areas {
		width: 100%;
		max-width: inherit;
		margin: 0 0 40px;
	}

	.footer_logo {
		margin-bottom: 20px;
	}
	.footer_bn_list {
		margin: 0 0 40px;
	}
}

/* Medium devices (tablets, 768px and up) */
@media (max-width: 768px) {
	.footer_logo img {
		height: 20px;
	}
	.footer_bn_list {
		margin: 60px 0;
	}
}
/* Small devices (landscape phones, 576px and up) */
@media (max-width: 576px) {
	footer {
		padding: 200px 0 20px;
	}
	.footer_info p {
		font-size: var(--font-size--sm);
	}
	.footer_menu_areas {
		display: block;
		margin: 0;
	}
	.footer_bn_list {
		margin: 40px 0;
	}
}

@media (max-width: 479px) {
	.footer_bn_list {
		gap: 15px;
	}
	.footer_bn_list li {
		width: 100%;
	}
}



/* ===================================================================
	#footer_contact
	フッター　お問い合わせ
=================================================================== */

.footer_contact {
	display: flex;
	justify-content: space-between;
	width: var(--def-width);
	max-width: var(--max-width);
	margin: 0 auto -170px;
	padding: 60px 80px;
	background: var(--bs-primary);
	border-radius: var(--border-radius-bs);
	z-index: 10;
	position: relative;
	filter: var(--filter-box-shadow);
}
.footer_contact_left {
	margin-right: 20px;
}
.footer_contact_title {
	margin-bottom: 40px;
	font-size: var(--font-size--xxl);
	font-weight: 700;
	color: var(--bs-white);
	line-height: 1.2;
}
.footer_contact_title .title_en {
	display: block;
	font-family: var(--font-en-family);
	font-size: var(--font-size--lg);
	font-weight: 700;
}
.footer_contact_business_days {
	font-size: var(--font-size--sm);
	color: var(--bs-white);
}

.footer_contact_link {
	width: 60%;
	max-width: 600px;
}

.footer_contact_tel {
	margin-bottom: 40px;
}
.footer_contact_tel a,
.footer_contact_mail a {
	display: flex;
	align-items: center;
	height: 140px;
	padding: 0 70px;
	background: var(--bs-white);
	border-radius: 70px;
	filter: var(--filter-box-shadow);
}

.footer_contact_link_icon {
	margin-right: 20px;
}
.footer_contact_link_txt {
}
.footer_contact_link_ex {
	font-weight: 700;
	font-size: var(--font-size--bs);
}
.footer_contact_link_txt .tel_number {
	font-family: var(--font-en-family);
	font-size: 40px;
	font-weight: 600;
	color: var(--bs-secondary);
	letter-spacing: 0.05em;
}

.footer_contact_link_txt .mail_txt {
	font-size: 30px;
	font-weight: 600;
	color: var(--bs-secondary);
}



/* XX-Large devices (larger desktops, 1400px and up) */
@media (max-width: 1440px) {
}

/* X-Large devices (large desktops, 1200px and up) */
@media (max-width: 1200px) {
	.footer_contact {
		padding: 40px 60px;
	}
	.footer_contact_tel a,
	.footer_contact_mail a {
		padding: 0 60px;
	}
	.footer_contact_link_txt .tel_number {
		font-size: 35px;
	}
	.footer_contact_link_txt .mail_txt {
		font-size: 26px;
	}
}

/* Large devices (desktops, 992px and up) */
@media (max-width: 992px) {
	.footer_contact {
		display: block;
	}
	.footer_contact_left {
		margin: 0 0 40px;
	}
	.footer_contact_link {
		width: 100%;
		margin: 0 auto;
	}
	.footer_contact_link_icon {
		width: 50px;
	}
}

/* Medium devices (tablets, 768px and up) */
@media (max-width: 768px) {
	.footer_contact {
		padding: 30px 40px;
	}
	.footer_contact_title {
		margin-bottom: 20px;
	}
	.footer_contact_tel {
		margin-bottom: 20px;
	}
	.footer_contact_tel a,
	.footer_contact_mail a {
		height: 100px;
		padding: 0 40px;
		border-radius: 50px;
	}
}
/* Small devices (landscape phones, 576px and up) */
@media (max-width: 576px) {
	.footer_contact {
		padding: 15px 20px;
	}
	.footer_contact_tel {
		margin-bottom: 10px;
	}
	.footer_contact_tel a,
	.footer_contact_mail a {
		height: 80px;
		padding: 0 20px;
		border-radius: 40px;
	}
	.footer_contact_link_icon {
		width: 40px;
		margin-right: 10px;
	}
	.footer_contact_link_txt .tel_number {
		font-size: 28px;
	}
	.footer_contact_link_txt .mail_txt {
		font-size: 20px;
	}
}

@media (max-width: 479px) {	
}



/* ===================================================================
	共通CSS
=================================================================== */
#contents {
	position: relative;
}
.one_clm {
	width: var(--def-width);
	max-width: var(--max-width);
	margin: 0 auto;
}

#main{
	position: relative;
	padding-top: 120px;
	overflow-x: clip;
}
p {
	line-height: 1.7;
}

.sec_inner {
	width: var(--def-width);
	max-width: var(--max-width);
	margin: 0 auto;
}

br.pc {
}
br.sp {
	display: none;
}


h2.wp-block-heading {
	margin: 2em 0 0.5em;
	font-size: var(--font-size--lg);
	font-weight: 700;
	color: var(--bs-primary);
}

h3.wp-block-heading {
	margin: 1em 0 0.5em;
	font-size: var(--font-size--md);
	font-weight: 700;
}



/* XX-Large devices (larger desktops, 1400px and up) */
@media (max-width: 1400px) {
	#main{
		padding-top: 100px;
	}
}

/* X-Large devices (large desktops, 1200px and up) */
@media (max-width: 1200px) {
	#main{
		padding-top: 60px;
	}
}
/* Large devices (desktops, 992px and up) */
@media (max-width: 992px) {
}
/* Medium devices (tablets, 768px and up) */
@media (max-width: 768px) {
	br.pc {
		display: none;
	}
	br.sp {
		display: inline-block;
	}
}
/* Small devices (landscape phones, 576px and up) */
@media (max-width: 576px) {	
}
@media (max-width: 479px) {
}




/* ===================================================================
	トップページ
=================================================================== */
.home_h2 {
	font-size: var(--font-size--xl);
	font-weight: 700;
	line-height: 1.4;
}

.home_h2 .en {
	display: block;
	font-size: var(--font-size--bs);
	font-family: var(--font-en-family);
	font-weight: 600;
	color: var(--bs-secondary);
}




/* 設備工事事業
-------------------------------------------- */






/* XX-Large devices (larger desktops, 1400px and up) */
@media (max-width: 1400px) {
}

/* X-Large devices (large desktops, 1200px and up) */
@media (max-width: 1200px) {
}
/* Large devices (desktops, 992px and up) */
@media (max-width: 992px) {
}
/* Medium devices (tablets, 768px and up) */
@media (max-width: 768px) {
}
/* Small devices (landscape phones, 576px and up) */
@media (max-width: 576px) {
}
@media (max-width: 479px) {
}



/* ===================================================================
	共通：ページ
=================================================================== */
#main_content {
	margin-bottom: var(--sec-padding-lg);
	overflow-x: clip;
}


.page_title_area {
	position: relative;
/*	width: 97%;
	max-width: 1750px;
	overflow: hidden;
	margin: 0 0 0 auto;*/
}
.page_title_area .page_title {
	position: absolute;
	z-index: 10;
	width: 100%;
	top: 0;
	bottom: 0;
	display: flex;
	flex-direction: column;
	justify-content: center;
	
}
.page_title_area .page_title h1 {
	width: 90%;
	max-width: var(--max-width);
	margin: 0 auto;
	color: var(--bs-white);
	position: relative;
	text-shadow: var(--text-shadow);
}
.page_title_area .page_title h1 .page_title_ja {
	font-size: var(--font-size--xxxl);
	font-weight: 700;
	letter-spacing: 0.08em;
	line-height: 1.4;
}
.page_title_area .page_title h1 .page_title_en {
	display: block;
	font-family: var(--font-en-family);
	font-size: calc(var(--font-size--md) * 0.9 );
	font-weight: 500;
}

.page_title_area .page_title h1 .notfound_404 {
	font-family: var(--font-en-family);
	font-size: var(--font-size--xxxl);
	font-weight: 700;
	line-height: 1.4;
}

.page_title_reform_logo {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	right: 3%;
	width: min(20vw,292px);
}


.page_title_bk_img {
	position: relative;
	font-size: var(--font-size--xxxl);
	height: 5.4em;
	border-radius: 0 0 0 var(--border-radius-bs);
	overflow: hidden;

	width: 97%;
	max-width: 1750px;
	overflow: hidden;
	margin: 0 0 0 auto;
}
.page_title_bk_img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

/* パンくず */
#breadcrumb {
	width: var(--def-width);
	max-width: var(--max-width);
	margin: 40px auto var(--sec-padding-bs);
	z-index: 100;
}
#breadcrumb ul,
#breadcrumb ul li {
	list-style-type: none;
	margin: 0;
	padding: 0;
}
#breadcrumb ul {
	display: flex;
	flex-wrap: wrap;
}
#breadcrumb ul li {
	display: flex;
	align-items: center;
}
#breadcrumb ul li::after {
	content: '●';
	display: inline;
	margin: 0 1.6em;
	font-size: 40%;
	color: var(--bs-primary);
}
#breadcrumb ul li:last-child::after {
	display: none;
}
#breadcrumb ul li a:hover {
	color: var(--bs-primary);
}
#breadcrumb ul li > span {
	color: var(--bs-primary);
}


.page-template-tmptweclm #content {
	display: flex;
    justify-content: space-between;
    width: var(--def-width);
    max-width: var(--max-width);
    margin: 0 auto;
}


.page-template-tmptweclm #content #mainarea {
	order: 2;
	width: 73.6%;
	max-width: 1000px;
}
.page-template-tmptweclm #content #sidearea {
	order: 1;
	width: 22%;
	max-width: 300px;
/*	background: #ccc;*/
	height: auto;
}

/* サイドエリア */
.page-template-tmptweclm #content #sidearea {
/*	position: sticky;
	top: 50px;*/
}
.page-template-tmptweclm #content #sidearea .my-widget {
	height: 100%;
}
.side_menu {
	position: sticky;
	top: 140px;
	height: auto;
	margin-bottom: var(--sec-padding-xs);
}
.side_menu li {
	margin-bottom: 1em;
}
.side_menu li a {
	color: #7a7b7d;
}
.side_menu > li > a {
	display: inline-block;
	font-size: calc(var(--font-size--bs) * 1.1);
	position: relative;
	padding-left: 20px;
}
.side_menu > li > a::before {
	content: '';
	display: block;
	width: 11px;
	height: 7px;
	background: url(../img/submenu_arrow.svg) no-repeat center center;
	background-size: contain;
	position: absolute;
	left: 0;
	top: 0.6em;
}
.side_menu > li > a:hover::before,
.side_menu > li > a.current::before {
	background: url(../img/submenu_arrow_current.svg) no-repeat center center;
}
.side_menu li ul {
	margin-top: 0.5em;
	margin-left: 20px;
}
.side_menu li ul li {
	margin-bottom: 0.2em;
}
.side_menu li ul li a {
	font-size: var(--font-size--sm);
}
.side_menu li a:hover {
	color: var(--bs-primary);
}

.side_menu li a.current {
	color: var(--bs-primary);
}




/* セクション */
.sec_base {
	margin-bottom: var(--sec-padding-lg);
}
.sec_base:last-of-type {
	margin-bottom: 0;
}

/* 見出し */
.title_h2 {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: 1.25em;
	padding: 0.5em 0 0;
	font-size: var(--font-size--xl);
	font-weight: 700;
	color: var(--bs-primary);
	position: relative;
	border-top: 2px solid #d8dbdd;
}
.title_h2::before {
	content: '';
	display: block;
	width: 1em;
	height: 2px;
	background: var(--bs-secondary);
	position: absolute;
	top: -2px;
	left: 0;
}
.title_h2_en {
	font-family: var(--font-en-family);
	font-size: var(--font-size--sm);
	font-weight: 600;
	color: #515253;
}


/* ページのイントロ */
.page_intro {
	margin-bottom: var(--sec-padding-bs);
}
.page_intro p {
	font-size: calc(var(--font-size--bs) * 1.5);
}


/* 共通のボタン */
a.btn_primary {
	display: flex;
	justify-content: space-between;
	align-items: center;
	width: 100%;
	max-width: 300px;
	height: 3.6em;
	padding: 0 0.5em 0 1em;
	border: 2px solid var(--bs-primary);
	background: var(--bs-white);
	font-family: var(--font-en-family);
	font-size: calc(var(--font-size--bs)*1.4);
	color: var(--bs-primary);
	font-weight: 600;
	line-height: 1.2;
	border-radius: 1.8em;
}
a.btn_primary:hover {
	background: var(--bs-primary-light);
}
a.btn_primary::after {
	content: '';
	display: block;
	width: 2em;
	height: 2em;
	margin-left: 1em;
	background: url(../img/btn_more_arrow.svg) no-repeat center center;
	background-size: contain;
	transition: all .3s ease;
}


.big_txt_darkblue {
	font-size: var(--font-size--lg);
	font-weight: 700;
	color: var(--bs-tertiary);
}


/* XX-Large devices (larger desktops, 1400px and up) */
@media (max-width: 1400px) {
}

/* X-Large devices (large desktops, 1200px and up) */
@media (max-width: 1200px) {


	.page-template-tmptweclm #content #mainarea {
		width: 100%;
		margin: 0 auto;
	}
	.page-template-tmptweclm #content #sidearea {
		display: none;
	}

	
}
/* Large devices (desktops, 992px and up) */
@media (max-width: 992px) {
	a.btn_primary {
		max-width: 13em;
		height: 3em;
		border-radius: 1.5em;
		font-size: calc(var(--font-size--bs) * 1.1 );
	}
	a.btn_primary::after {
		width: 1.8em;
		height: 1.8em;
	}


}
/* Medium devices (tablets, 768px and up) */
@media (max-width: 768px) {
	.page_title_bk_img {
		height: 4em;
	}

	.page_title_area .page_title h1 .page_title_ja,
	.page_title_area .page_title h1 .notfound_404 {
		font-size: var(--font-size--xxl);
	}
	.page_title_area .page_title h1 .page_title_en {
		font-size: var(--font-size--sm);
	}

	
}
/* Small devices (landscape phones, 576px and up) */
@media (max-width: 576px) {
	.page_intro p {
		font-size: calc(var(--font-size--bs) * 1.2);
	}

	a.btn_primary {
/*		max-width: 200px;*/
		max-width: 12em;
		font-size: var(--font-size--bs);
	}
}
@media (max-width: 479px) {
}


/* ===================================================================
	トップページ
=================================================================== */

p.home_sec_txt {
	margin-top: var(--sec-padding-sm);
	line-height: 2;
}
.link_more_btn {
	margin-top: var(--sec-padding-sm);
}

.home_title_area {
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
	flex-wrap: wrap;
	gap: 15px var(--sec-padding-sm);
	margin-bottom: var(--sec-padding-sm);
}
.home_title_area02 {
}
.home_title_area p {
	flex-shrink: 1;
	flex-grow: 1;
}
.home_title_btn {
	flex-shrink: 1;
	flex-grow: 1;
}



/* スライダー */
.home_hero {
	height: 50vw;
/*	background: #ccc;*/
	position: relative;
}
.home_hero_txt_wrap {
	position: absolute;
	left: 0;
	right: 0;
	top: 0;
	bottom: 0;
/*	padding-left: 3%;*/
	display: flex;
	align-items: center;
	z-index: 100;
}
.home_hero_txt {
	display: flex;
	flex-direction: column;
	width: fit-content;
	padding: 0 0 0 3vw;
	font-size: var(--font-size--xxl);
	font-weight: 700;
	color: var(--bs-primary);
/*	filter: drop-shadow(0px 0px 5px rgba(255, 255, 255, 0.9));*/
}
.home_hero_txt span {
	display: inline-block;
	width: fit-content;
	margin: 0.1em 0;
	padding: 0.2em 0.4em;
	line-height: 1.2;
	background: rgba(255,255,255,0.7);
	border-radius: 0.5em;
	backdrop-filter: blur(10px);
}
.home_hero_txt .sp_02 {
	display: none;
}
.home_hero_img {
	width: 80%;
	width: 80vw;
	height: 50vw;
	max-width: 1540px;
	margin-left: auto;
	z-index: 10;
	position: absolute;
	top: 0;
	right: 0;
}
.swiper-slide {
}
.slide_img {
	height: 50vw;
	border-radius: 0 0 0 var(--border-radius-bs);
	overflow: hidden;
}
.slide_img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}



.p-index-hero__clip {
	position: relative;
    z-index: 200;
	margin-left: auto;
	width: 80vw;
    height: 50vw;
    max-width: 1540px;
	height: 50vw;
    border-radius: 0 0 0 var(--border-radius-bs);
    overflow: hidden;
}
.p-index-hero__clip .p-index-hero__clip-content {
    z-index: 2;
	position: relative;
	color: #fff;
	left: -19.1vw;
}
.p-index-hero__content {
    display: flex;
    z-index: 1;
    position: relative;
    flex-direction: column;
    justify-content: center;
    height: 50vw;
}
.p-index-hero__ja {
	width: fit-content;
    padding: 0;
    font-size: var(--font-size--xxl);
    font-weight: 700;
	padding-left: 3vw;
	text-shadow: var(--text-shadow);
	white-space:nowrap;
}



.hero_scroll {
	position: absolute;
	left: 10px;
	bottom: 0;
	padding-bottom: min(6.5vw,160px);
}
.hero_scroll_txt {
	writing-mode: vertical-rl;
	font-family: var(--font-en-family);
	font-size: var(--font-size--md);
	font-weight: 600;
	line-height: 1;
}
.hero_scroll_line {
    position: absolute;
    width: 2px;
	height: 6vw;
    max-height: 160px;
    bottom: 0;
	left: 49%;
}
.hero_scroll_line::after {
    content: "";
    display: block;
    width: 100%;
	height: 6vw;
    max-height: 160px;
    background: var(--text-color);
    animation: mv_line 1.5s infinite ease;
    position: absolute;
    left: 0;
}
@keyframes mv_line {
	0% {
		top: unset;
		bottom: 0;
		height: 6vw;
	}
	34% {
		top: unset;
		bottom: 0;
		height: 0;
	}
	35% {
		top: 0;
		bottom: unset;
		height: 0;
	}
	70% {
		top: 0;
		bottom: unset;
		height: 6vw;
	}
}

/* 設備工事事業 */
.home_mpc {
	margin: var(--sec-padding-bs) 0;
	position: relative;
}
.home_mpc .sec_inner {
	padding-right: 50%;
}
.home_mpc_img {
	width: 50%;
	position: absolute;
	top: 0;
    right: 0;
}
.home_mpc_img_big {
	width: 50vw;
	max-width: 740px;
	margin-left: auto;
	border-radius: var(--border-radius-bs) 0 0 var(--border-radius-bs);
	overflow: hidden;
	filter: var(--filter-box-shadow);
}
.home_mpc_img_small {
	width: 20vw;
	max-width: 400px;
	border-radius: var(--border-radius-img-bs);
	overflow: hidden;
	filter: var(--filter-box-shadow);
	margin: -180px auto 0 -13vw;
}
.home_mpc_img_big img,
.home_mpc_img_small img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.home_recruit_img {
/*    width: 50%;
    height: 100%;
    max-height: 750px;
    position: absolute;
    right: 0;
    top: calc(var(--sec-padding-bs) * -1);
    border-radius: var(--border-radius-bs) 0 0 var(--border-radius-bs);
    overflow: hidden;
    filter: var(--filter-box-shadow);
	*/
}

/* 設備設計・施工事業 */
.home_bsdc {
	margin: var(--sec-padding-bs) 0;
	position: relative;
}
.home_bsdc_txt {
	width: 50vw;
	max-width: 500px;
	margin-left: auto;
}

.home_bsdc_img {
	width: 60vw;
	display: flex;
	gap: 20px;
	position: absolute;
	top: 0;
	right: 50%;
}
.home_bsdc_img > div {
	width: 35%;
	border-radius: var(--border-radius-img-bs);
	filter: var(--filter-box-shadow);
	overflow: hidden;
}
.home_bsdc_img > div img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

/* 大きい文字スクロール */
.home_scroll_txt {
	font-family: var(--font-en-family);
	font-size: 160px;
	font-weight: 900;
	position: relative;
	z-index: 1;
	display: flex;
	width: 100%;
	overflow: hidden;
	white-space: nowrap;
	height: auto;
	padding: 0;
	margin: var(--sec-padding-bs) 0;
	pointer-events: none;
	user-select: none
}
.home_scroll_txt_anim {
    will-change: transform;
    animation: loopmt 40s linear infinite;

background-image: url(../img/big_txt_color.png);
	background-repeat: repeat;
	-webkit-background-clip: text;
	color: transparent;
}
@keyframes loopmt {
	0% {
		transform: translateZ(0)
	}

	to {
		transform: translate3d(calc(-50% - 30px),0,0)
	}
}

/* XX-Large devices (larger desktops, 1400px and up) */
@media (max-width: 1400px) {
	.home_mpc_img {
		width: 45%;
	}
	.home_mpc_img_big {
		width: 45vw;
	}
	.home_mpc_img_small {
		margin-top: -10vw;
	}
}

/* X-Large devices (large desktops, 1200px and up) */
@media (max-width: 1200px) {
	.home_mpc_img_big {
		width: 40vw;
		height: 30vw;
	}
	.home_mpc_img_small {
		margin-left: -5vw;
	}
	.hero_scroll_txt {
		font-size: var(--font-size--bs);
	}
	.home_scroll_txt {
		font-size: 15vw;
	}
}
/* Large devices (desktops, 992px and up) */
@media (max-width: 992px) {
	.home_hero,
	.home_hero_img,
	.slide_img {
		height: 60vw;
	}
	.home_hero_txt_wrap {
		display: block;
		padding-top: 8vw;
	}
	.home_hero_txt {
		font-size: var(--font-size--xl);
	}
	.p-index-hero__ja {
		font-size: var(--font-size--xl);
	}
	.p-index-hero__content {
		height: 60vw;
		padding-top: 8vw;
		display: block;
	}


	.home_title_area02 {
		gap: 15px;
	}
	.home_title_area p {
		margin: 0;
		font-size: var(--font-size--sm);
	}
	.home_title_btn {
		flex-grow: 1;
		display: flex;
		justify-content: flex-end;
	}
	.home_title_btn a.btn_primary {
	
	}

}
/* Medium devices (tablets, 768px and up) */
@media (max-width: 768px) {
	.home_mpc .sec_inner {
		padding: 0;
	}
	.home_mpc_img {
		position: relative;
		top: inherit;
		right: inherit;
		width: 80%;
		margin: var(--sec-padding-sm) 0 0 auto
	}
	.home_mpc_img_big {
		width: 100%;
		height: 35vw;
	}
	.home_mpc_img_small {
		width: 40%;
		margin: -8vw 0 0 -10vw;
	}

	.home_bsdc_txt {
		width: 100%;
		max-width: inherit;
	}
	.home_bsdc_img {
		width: 80%;
		position: relative;
		right: inherit;
		left: -2%;
		margin: var(--sec-padding-sm) 0 0 0;
	}
}
/* Small devices (landscape phones, 576px and up) */
@media (max-width: 576px) {
	.home_hero,
	.home_hero_img,
	.slide_img {
		height: 80vw;
	}
	.home_hero_txt .sp_02 {
		display: inline;
	}
}
@media (max-width: 479px) {
}


/* 施工事例 */
.cases {
	margin-top: var(--sec-padding-bs);
	padding: var(--sec-padding-bs) 0;
	background: var(--bs-gradient-primary);
	position: relative;
}
.cases::before {
	content: "";
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	    mix-blend-mode: color-burn;
    background: url(../img/bk_cover.png) repeat top center;
    z-index: -1;
}
.cases .home_h2 .en {
	color: var(--bs-primary);
}

.cases_slider {
	margin-right: -20vw;
}
.cases_slider_item {
	width: 30vw;
	max-width: 400px;
	margin-right: min(2vw,20px);
}

.cases_slider_img {
	width: 100%;
	border-radius: var(--border-radius-img-bs);
	filter: var(--filter-box-shadow);
	overflow: hidden;
}
.cases_slider_img img {
	width: 100%;
	height: 100%;
	aspect-ratio: 16 / 9;
	object-fit: cover;
}
.cases_slider_cate {
	margin: 10px 0;
	display: flex;
	flex-wrap: wrap;
	gap: 0.5em;
}
.cases_slider_cate span {
	display: inline-block;
	padding: 0.2em 0.5em;
	background: var(--bs-white);
	border-radius: 1em;
	font-size: var(--font-size--sm);
	color: var(--bs-primary);
}
.cases_slider_title {
	margin: 10px 0 0;
	font-size: calc(var(--font-size--bs) * 1.2);
	font-weight: 700;
}




/* 住宅設備・リフォーム */
.home_home_systems {
	margin: var(--sec-padding-bs) 0;
}




/* アシスト */
.home_assist {
	margin: calc(var(--sec-padding-bs)* 2) 0 var(--sec-padding-bs);
	position: relative;
}
.home_assist .sec_inner {
	position: relative;
	padding: var(--sec-padding-bs) 0;
}
.home_assist .sec_inner::before,
.home_assist .sec_inner::after {
	content: "";
	width: 100vw;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	border-radius: var(--border-radius-bs) 0 0 var(--border-radius-bs);
}
.home_assist .sec_inner::before {
	background: var(--bs-gradient-primary);
	z-index: -2;
}
.home_assist .sec_inner::after {
	mix-blend-mode: color-burn;
	background: url(../img/bk_cover.png) repeat top center;
	z-index: -1;
}

.home_assist_inner {
	width: 48.6%;
	max-width: 660px;
	margin-left: auto;
}
.home_assist .home_h2 .en {
	color: var(--bs-primary);
}

.home_assist_img {
	width: 45%;
	height: 100%;
	position: absolute;
	left: 0;
	top: calc(var(--sec-padding-bs) * -1);
	border-radius: 0 var(--border-radius-bs) var(--border-radius-bs) 0;
	overflow: hidden;
	filter: var(--filter-box-shadow);
}
.home_assist_img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: right center;
}

/* XX-Large devices (larger desktops, 1400px and up) */
@media (max-width: 1400px) {
	.home_assist_img {
		height: 36vw;
	}
}

/* X-Large devices (large desktops, 1200px and up) */
@media (max-width: 1200px) {
	.home_assist_inner {
		width: 50%;
	}
}
/* Large devices (desktops, 992px and up) */
@media (max-width: 992px) {
	.cases_slider_item {
		width: 34vw;
	}
}
/* Medium devices (tablets, 768px and up) */
@media (max-width: 768px) {
	.home_assist {
		margin: var(--sec-padding-bs) 0;
	}
	.home_assist_inner {
		width: 100%;
	}
	.home_assist .sec_inner {
		padding: calc(var(--sec-padding-bs) * 0.5) 0 var(--sec-padding-bs) var(--sec-padding-sm);
	}
	.home_assist_img {
		width: 80%;
		height: 40vw;
		position: relative;
		top: inherit;
		margin-top: calc(var(--sec-padding-bs) * -0.5);
	}
}
/* Small devices (landscape phones, 576px and up) */
@media (max-width: 576px) {
	.cases_slider_item {
		width: 40vw;
		margin-right: 3vw;
	}
}
@media (max-width: 479px) {
}


/* 会社概要 */
.mask_company {
	-webkit-clip-path: url(#svgPathCompany);
	clip-path: url(#svgPathCompany);
	overflow: hidden;
}
.home_company_link {
	display: flex;
	justify-content: space-between;
	margin-bottom: var(--sec-padding-sm);
}
.home_company_link_item {
	width: 30%;
	max-width: 450px;
}
.company_btn {
	position: relative;
	display: block;
	max-width: 450px;
}
.company_btn:hover {
	opacity: 0.8;
}
.company_btn_arrow {
	display: block;
	width: 50px;
	height: 50px;
	position: absolute;
	bottom: 15px;
	right: 15px;
	z-index: 5;
}
.company_btn_img {
	filter: var(--filter-box-shadow);
	z-index: 1;
}
.home_company_link_name {
	position: absolute;
	bottom: 0;
	left: 0;
	padding: 0 10px;
	filter: none;
	font-size: var(--font-size--lg);
	font-weight: 600;
	z-index: 5;
}
.home_company_link_name .en {
	display: block;
	font-family: var(--font-en-family);
	font-size: var(--font-size--sm);
	font-weight: 500;
	color: var(--bs-secondary);
	line-height: 1;
}

.home_company_other {
	display: flex;
	justify-content: space-between;
}
.home_company_other > div {
	width: 48%;
	max-width: 660px;
}
.home_company_other a {
	display: flex;
	justify-content: space-between;
	align-items: center;
	width: 100%;
	height: 240px;
	padding: 0 40px;
	border-radius:var(--border-radius-img-bs);
	overflow: hidden;
	font-weight: 700;
	color: var(--bs-white);
	text-shadow: var(--text-shadow);
}
.home_company_other a:hover {
	opacity: 0.8;
}
.home_company_other a::after {
	content: '';
	display: block;
	width: 50px;
	height: 50px;
	background: url(../img/icon_arrow_blue.png) no-repeat center center;
	background-size: contain;
}
.home_company_other_sdgs a {
	font-size: var(--font-size--lg);
	background: url(../img/btn_sdgs.png) no-repeat center center;
	background-size: cover;
}
.home_company_other_909 a {
	font-family: var(--font-en-family);
	font-size: var(--font-size--xl);
	background: url(../img/btn_909.png) no-repeat center center;
	background-size: cover;
}

/* XX-Large devices (larger desktops, 1400px and up) */
@media (max-width: 1400px) {
	.home_company_link_name {
        font-size: min(2.5vw, 30px);
    }
	.home_company_link_name .en {
		font-size: max(1vw, 12px);
	}
	.home_company_other a {
		height: 16vw;
		line-height: 1.4;
	}

	.company_btn_arrow {
        width: min(4vw, 40px);
        height: min(4vw, 40px);
        bottom: min(1.5vw, 20px);
        right: min(1.5vw, 20px);
    }
	.home_company_other a::after {
		width: min(4vw, 40px);
        height: min(4vw, 40px);
	}
	.home_company_other a {
		padding: 0 min(2vw, 30px);
	}
}

/* X-Large devices (large desktops, 1200px and up) */
@media (max-width: 1200px) {
	.home_company_link_item {
		width: 31.5%;
	}
	
}
/* Large devices (desktops, 992px and up) */
@media (max-width: 992px) {
	.home_company_other_sdgs a {
    	font-size: min(4.2vw, 22px);
	}
	.home_company_other_909 a {
    	font-size: min(5.3vw, 30px);
	}

}
/* Medium devices (tablets, 768px and up) */
@media (max-width: 768px) {
	.home_company_link {
		flex-wrap: wrap;
		gap: 4vw 4%;
	}
	.home_company_link_item {
		width: 48%;
	}
}
/* Small devices (landscape phones, 576px and up) */
@media (max-width: 576px) {
	.home_company_other {
		flex-direction: column;
		gap: 15px;
	}
	.home_company_other > div {
		width: 100%;
	}
	.home_company_other a {
		height: 24vw;
		padding: 0 15px;
	}
}
@media (max-width: 479px) {
}


/* 採用 */
.home_recruit {
	margin: calc(var(--sec-padding-bs)* 2) 0 var(--sec-padding-lg);
	position: relative;
}
.home_recruit .sec_inner {
	position: relative;
	padding: var(--sec-padding-bs) 0;
}
.home_recruit .sec_inner::before,
.home_recruit .sec_inner::after {
	content: "";
	width: 100vw;
	height: 100%;
	position: absolute;
	top: 0;
	right: 0;
	border-radius: 0 var(--border-radius-bs) var(--border-radius-bs) 0;
}
.home_recruit .sec_inner::before {
	background: var(--bs-gradient-primary);
	z-index: -2;
}
.home_recruit .sec_inner::after {
	mix-blend-mode: color-burn;
	background: url(../img/bk_cover.png) repeat top center;
	z-index: -1;
}

.home_recruit_inner {
	width: 48%;
	max-width: 600px;
	margin-right: auto;
}
.home_recruit .home_h2 .en {
	color: var(--bs-primary);
}
.home_recruit_txt {
	margin-top: var(--sec-padding-sm);
	font-size: var(--font-size--xl);
	font-weight: 700;
}
.home_recruit_img {
	width: 50%;
	height: 100%;
	max-height: 750px;
	position: absolute;
	right: 0;
	top: calc(var(--sec-padding-bs) * -1);
	border-radius: var(--border-radius-bs) 0 0 var(--border-radius-bs);
	overflow: hidden;
	filter: var(--filter-box-shadow);
}
.home_recruit_img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: left center;
}
.home_recruit .link_more_btn a.btn_primary {
	max-width: 500px;
	margin: 20px 0;
	font-size: var(--font-size--md);
}

/* XX-Large devices (larger desktops, 1400px and up) */
@media (max-width: 1400px) {
}

/* X-Large devices (large desktops, 1200px and up) */
@media (max-width: 1200px) {
	.home_recruit_img {
		height: 55vw;
	}
	.home_recruit_txt {
		font-size: calc(var(--font-size--lg) * 1.2);
	}
}
/* Large devices (desktops, 992px and up) */
@media (max-width: 992px) {
	.home_h2 {
		font-size: var(--font-size--lg);
	}

	.home_recruit_txt {
		font-size: var(--font-size--lg);
	}
}
/* Medium devices (tablets, 768px and up) */
@media (max-width: 768px) {
	
}
/* Small devices (landscape phones, 576px and up) */
@media (max-width: 576px) {
	.home_h2 {
		font-size: var(--font-size--xl);
	}
	.home_recruit {
/*		display: flex;*/
/*		flex-direction: column-reverse;*/
	}
	.home_recruit .sec_inner {
		padding: calc(var(--sec-padding-bs) * 0.5) var(--sec-padding-sm) var(--sec-padding-bs) 0;
    }
	.home_recruit_inner {
		width: 100%;
	}
	.home_recruit_inner .link_more_btn {
		display: flex;
		gap: 10px;
	}
	.home_recruit .link_more_btn a.btn_primary {
		font-size: var(--font-size--bs);
		margin: 0;
	}
	.home_recruit_img {
		width: 80%;
		height: 50vw;
		position: relative;
		top: inherit;
		left: inherit;
		margin: 0 0 0 auto;
		margin-top: calc(var(--sec-padding-bs) * -0.5);
	}
	.home_recruit_txt .sp_02 {
		display: none;
	}
}
@media (max-width: 479px) {
}

/* ===================================================================
	設備工事事業
=================================================================== */
.mpc_box {
	display: flex;
	justify-content: space-between;
	margin-bottom: var(--sec-padding-lg);
	align-items: flex-start;
}
.mpc_box:last-child {
	margin-bottom: 0;
}
.mpc_txt {
	width: 45%;
	max-width: 450px;
}
.mpc_title_area {
	position: relative;
	margin-bottom: 40px;
}
.mpc_title_area .num {
	margin-left: -0.1em;
	font-family: var(--font-en-family);
	font-weight: 600;
	font-size: calc(var(--font-size--xl) * 3.75);
	line-height: 1;
	color: #cce6f7;
	z-index: -1;
}
.mpc_title_area h2 {
	font-size: var(--font-size--xl);
	font-weight: 700;
	color: var(--bs-primary);
	position: absolute;
	bottom: 0;
	left: 0;
}
.mpc_txt p {
	line-height: 2;
}
.mpc_img {
	width: 50%;
	max-width: 500px;
	height: auto;
	margin-right: -5%;
	border-radius: var(--border-radius-img-bs);
	overflow: hidden;
	filter: var(--filter-box-shadow);
}
.mpc_img img {
	width: 100%;
	object-fit: cover;
}


.mpc_box:nth-child(odd) {
}
.mpc_box:nth-child(odd) .mpc_txt {
	order: 2;
}
.mpc_box:nth-child(odd) .mpc_img {
	order: 1;
	margin-right: auto;
	margin-left: -5%;
}


/* XX-Large devices (larger desktops, 1400px and up) */
@media (max-width: 1400px) {
}

/* X-Large devices (large desktops, 1200px and up) */
@media (max-width: 1200px) {
	.mpc_img {
		margin-right: -1%;
	}
	.mpc_box:nth-child(odd) .mpc_img {
		margin-left: -1%;
	}
	
}
/* Large devices (desktops, 992px and up) */
@media (max-width: 992px) {

}
/* Medium devices (tablets, 768px and up) */
@media (max-width: 768px) {
	.mpc_title_area {
		margin-bottom: 20px;
	}

	.mpc_txt {
		width: 55%;
	}
	.mpc_img {
		width: 40%;
	}
	.mpc_title_area .num {
		font-size: calc(var(--font-size--xl) * 3);
	}
}
/* Small devices (landscape phones, 576px and up) */
@media (max-width: 576px) {
	.mpc_box {
		display: block;
	}
	.mpc_txt {
		width: 100%;
		margin-bottom: 20px;
	}
	.mpc_img {
		width: 100%;
		height: 50vw;
		margin: 0 auto;
	}
	.mpc_img img {
		height: 50vw;
		object-position: center;
	}

}
@media (max-width: 479px) {
}





/* ===================================================================
	設備設計・施工事業
=================================================================== */
.bsdc_intro {
	margin-bottom: var(--sec-padding-lg);
}
.bsdc_intro h2 {
	margin-bottom: var(--sec-padding-bs);
	font-size: var(--font-size--xl);
	font-weight: 700;
	color:var(--bs-primary);
	text-align: center;
}

.bsdc_box {
	position: relative;
	margin: 15vw 0;
/*	width: var(--def-width);
	max-width: var(--max-width);
	margin: 0 auto;*/
}
.bsdc_box_inner {
	width: var(--def-width);
	max-width: var(--max-width);
	margin: 0 auto;
}
.bsdc_box_txt {
	width: 52%;
	max-width: 700px;
	margin-left: auto;
}
.bsdc_box_point {
	font-family: var(--font-en-family);
	font-size: calc(var(--font-size--lg) * 0.8);
	font-weight: 500;
	color: var(--bs-secondary);
	line-height: 1;
}
.bsdc_box_txt h2 {
	margin: 20px 0 30px;
	font-size: var(--font-size--lg);
	font-weight: 700;
}
.bsdc_box_txt p {
	line-height: 2;
}
.bsdc_box_img {
	width: calc(50vw - 100px);
	height: 28vw;
	border-radius: 0 var(--border-radius-img-bs) var(--border-radius-img-bs) 0;
	overflow: hidden;
	filter: var(--filter-box-shadow);
	position: absolute;
	left: 0;
	right: auto;
	top: 50%;
	transform: translateY(-50%);
}
.bsdc_box_img img {
	width: 100%;
	height: 28vw;
	object-fit: cover;
	object-position: center;
}
.bsdc_box:nth-child(odd) .bsdc_box_txt {
	margin-left: 0;
	margin-right: auto;
}
.bsdc_box:nth-child(odd) .bsdc_box_img {
	border-radius: var(--border-radius-img-bs) 0 0 var(--border-radius-img-bs) ;
	left: auto;
	right: 0;
}



.bsdc_flow {
	padding: var(--sec-padding-bs) 0;
	position: relative;
	background: #f2fafe;
	z-index: 0;
}
.bsdc_flow::before {
    content: '';
    position: absolute;
    width: 100%;
    top: 0;
    left: 0;
    bottom: 0;
    mix-blend-mode: color-burn;
    background: url(../img/bk_cover.png) repeat top center;
    z-index: 1;
}
.bsdc_flow_inner {
	position: relative;
	z-index: 10;
}
.bsdc_flow_inner h2 {
	width: var(--def-width);
	max-width: var(--max-width);
	margin:0 auto 40px;
	font-size: var(--font-size--xl);
	font-weight: 700;
	color: var(--bs-primary);
}

.bsdc_flow_intro {
	font-size: var(--font-size--xl);
	height: 11em;
	margin-bottom: var(--sec-padding-bs);
}
.bsdc_flow_intro_img {
	width: 58%;
	height: 11em;
	border-radius: 0 var(--border-radius-img-bs) var(--border-radius-img-bs) 0;
	filter: var(--filter-box-shadow);
	overflow: hidden;
	position: absolute;
	left: 0;
	z-index: 1;
}
.bsdc_flow_intro_img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
}
.bsdc_flow_intro_txt {
	height: 100%;
	display: flex;
	justify-content: flex-end;
	align-items: center;
	width: var(--def-width);
	max-width: var(--max-width);
	margin: 0 auto;
/*	font-size: var(--font-size--xl);*/
	font-weight: 700;
	position: relative;
	z-index: 20;
}
.bsdc_flow_intro_txt p {
	width: fit-content;
}
.bsdc_flow_img {
	width: var(--def-width);
	max-width: var(--max-width);
	margin: 0 auto;
	text-align: center;
	filter: var(--filter-box-shadow);
}


.bsdc_example {
	padding: var(--sec-padding-bs) 0;
}
.bsdc_example_title  {
	width: var(--def-width);
	max-width: var(--max-width);
	margin: 0 auto 40px;
	display: flex;
	align-items: center;
}
.bsdc_example_title h2 {
	font-size: var(--font-size--xl);
	font-weight: 700;
	color: var(--bs-primary);
}
.bsdc_example_title p {
	margin-left: 60px;
}

#splider_exmple ul li {
	width: 35%;
	max-width: 600px;
}
#splider_exmple ul li img {
	border-radius: var(--border-radius-img-bs);
	filter: var(--filter-box-shadow);
}

/* XX-Large devices (larger desktops, 1400px and up) */
@media (max-width: 1400px) {
}

/* X-Large devices (large desktops, 1200px and up) */
@media (max-width: 1200px) {
	.bsdc_box {
		margin: var(--sec-padding-bs) 0;
	}
	.bsdc_box_img {
		height: 34vw;
	}
	.bsdc_box_img img {
		height: 34vw;
	}

	.bsdc_flow_intro {
		font-size: var(--font-size--lg);
	}

}
/* Large devices (desktops, 992px and up) */
@media (max-width: 992px) {

	

}
/* Medium devices (tablets, 768px and up) */
@media (max-width: 768px) {
	.bsdc_box_txt {
		width: 100%;
	}
	.bsdc_box_txt h2 {
		margin: 10px 0 20px;
	}
	.bsdc_box_img {
		width: 90%;
		height: 40vw;
		margin-top: 20px;
		margin-right: auto;
		position: relative;
		left: inherit;
		top: inherit;
		transform: inherit;
	}
	.bsdc_box_img img {
		height: 40vw;
	}
	.bsdc_box:nth-child(odd) .bsdc_box_img {
		left: inherit;
		right: inherit;
		margin-left: auto;
		margin-right: 0;
	}

	.bsdc_flow_intro_img {
		width: 65%;
	}

	.bsdc_example_title {
		display: block;
	}
	.bsdc_example_title h2 {
		margin-bottom: 10px;
	}
	.bsdc_example_title p {
		margin: 0;
	}

	#splider_exmple ul li {
	width: 50%;
	max-width: 600px;
}
}
/* Small devices (landscape phones, 576px and up) */
@media (max-width: 576px) {
	.bsdc_flow_inner h2 {
		margin-bottom: 20px;
	}
	.bsdc_flow_intro {
		height: auto;
	}
	.bsdc_flow_intro_img {
		width: 90%;
		height: 45vw;
		position: relative;
		margin-right: auto;
	}
	.bsdc_flow_intro_txt {
		margin-top: 20px;
		justify-content: center;
	}
}
@media (max-width: 479px) {
}


/* ===================================================================
	施工事例 case
=================================================================== */
.case_area {
	width: var(--def-width);
	max-width: var(--max-width);
	margin: 0 auto;
}

.cate_title {
	margin: 0 0 0.8rem;
	font-family: var(--font-en-family);
	font-size: var(--font-size--md);
	font-weight: 500;
	color: var(--bs-primary);
}
.cate_list {
	display: flex;
	flex-wrap: wrap;
	gap: 1em 0.5em;
	margin: 0 0 var(--sec-padding-bs);
}
.cate_list li a {
	display: block;
	padding: 0.4em 2em;
	border-radius: 1.5em;
	border: 1px solid var(--bs-primary);
	font-weight: 700;
	color: var(--bs-primary);
}
.cate_list li.current-cat a {
	background: var(--bs-primary);
	color: var(--bs-white);
}
.cate_list li a:hover {
	background: var(--bs-primary-light);
}

.case_item_list {
	display: flex;
	flex-wrap: wrap;
	gap: var(--sec-padding-sm) 5.8%;
}
.case_item {
	width: calc((100% - 11.6%) / 3);
	max-width: 400px;
}

.case_item h2 {
	font-size: var(--font-size--md);
	font-weight: 700;
}
.case_item_img {
	width: 100%;
/*	height: 320px;*/
	border-radius: var(--border-radius-img-bs);
	overflow: hidden;
	filter: var(--filter-box-shadow);
	margin-bottom: 20px;
}
.case_item_img img {
	width: 100%;
	height: 100%;
	aspect-ratio: 5/4;
	object-fit: cover;
}
.case_item_cate {
	display: flex;
	flex-wrap: wrap;
	gap: 5px;
	margin-bottom: 10px;
}
.case_item_cate span {
    display: inline-block;
    padding: 0.2em 0.8em;
    background: #e0f0fa;
    border-radius: 1em;
    font-size: var(--font-size--sm);
    color: var(--bs-primary);
}


/* ページャー */
.wp-pagenavi {
	display: flex;
	justify-content: center;
	align-items: center;
	flex-wrap: wrap;
	gap: 5px;
	margin-top: var(--sec-padding-sm);
}
.wp-pagenavi a,
.wp-pagenavi span {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 2.5em;
	height: 2.5em;
	padding: 0;
	border-radius: 50%;
	text-decoration: none;
	border: 1px solid var(--bs-primary);
	font-family: var(--font-en-family);
	font-weight: 600;
	font-size: 1.2rem;
	color: var(--bs-primary);
}
.wp-pagenavi a:hover,
.wp-pagenavi span.current {
	background:var(--bs-primary);
	color: var(--bs-white);
}
.wp-pagenavi span.current {
	font-weight: bold;
}
.previouspostslink {}
.nextpostslink {}


/* 詳細画面 */
.case_detail_main {
	max-width: 1000px;
	margin: 0 auto;
}

.case_detail_title {
	margin-bottom: 0.5em;
	font-size: var(--font-size--lg);
	font-weight: 700;
}
.case_detail_cate {
	margin-bottom: var(--sec-padding-xs);
}
.case_detail_cate span {
	display: inline-block;
	padding: 0.2em 1em;
	background: #e0f0fa;
	border-radius: 1em;
	color: var(--bs-primary);
}

.case_detail_img {
/*	background: #ccc;*/
}
.case_detail_img > div {
	margin: 10px;
}
.case_detail_img img {
	border-radius: var(--border-radius-img-bs);
}

.slick-arrow {
	display: block;
	width: 60px;
	height: 60px;
	position: absolute;
	top: calc(50% - 40px);
	border-radius: 50%;
	background-color: var(--bs-white);
	border: 2px solid var(--bs-primary);
	z-index: 20;
	cursor: pointer;
}
.slick-arrow:hover {
	background-color: var(--bs-primary-light);
}
.prev-arrow {
	left: -20px;
	background-image: url(../img/btn_prev.svg);
	background-repeat: no-repeat;
	background-position: center center;
	background-size: contain;
}
.next-arrow {
	right: -20px;
	background-image: url(../img/btn_next.svg);
	background-repeat: no-repeat;
	background-position: center center;
	background-size: contain;
}

.slick-dots {
	display: flex;
	justify-content: center;
	width: 100%;
	position: absolute;
	bottom: calc(var(--font-size--sm) * -2);
}
.slick-dots li {
  list-style-type: none;
}
.slick-dots li button {
	display: block;
	width: var(--font-size--sm);
	height: var(--font-size--sm);
	margin: 0 calc(var(--font-size--sm) / 2);
	padding: 0;
	border-radius: 50%;
	border: 2px solid var(--bs-primary);
	background-color: var(--bs-white);
	font-size: 0!important;
	color: transparent;
}
.slick-dots li.slick-active button {
	background: var(--bs-primary);
}
.slick-dots li button:hover {
	background: var(--bs-primary-light);
}
.slick-dots li:hover,
.slick-dots li button:hover {
	cursor: pointer;
}





/* 説明 */
.case_explanation {
	margin: var(--sec-padding-bs) auto;
}
.case_explanation p {
	line-height: 2;
}

.case_detail {
	margin: 0 auto var(--sec-padding-bs);
}

.case_detail_tbl {
	width: 100%;
}
.case_detail_tbl th,
.case_detail_tbl td {
	padding: 1.5rem 0;
	border-bottom: 1px solid #d8dbdd;
	vertical-align: top;
	line-height: 1.7;
}
.case_detail_tbl tr:first-of-type th,
.case_detail_tbl tr:first-of-type td {
	border-top: 1px solid #d8dbdd;
}
.case_detail_tbl th {
	width: 10em;
	color: var(--bs-primary);
}

.case_detail_tbl a {
	text-decoration: underline;
}


/* XX-Large devices (larger desktops, 1400px and up) */
@media (max-width: 1400px) {
}

/* X-Large devices (large desktops, 1200px and up) */
@media (max-width: 1200px) {
}
/* Large devices (desktops, 992px and up) */
@media (max-width: 992px) {
	.slick-arrow {
		width: 40px;
		height: 40px;
		top: calc(50% - 25px);
	}
	.prev-arrow {
		left: -10px;
	}
	.next-arrow {
		right: -10px;
	}
}
/* Medium devices (tablets, 768px and up) */
@media (max-width: 768px) {
	.cate_list {
		gap: 0.5em;
	}
	.cate_list li a {
		padding: 0.4em 1em;
	}
	.case_item {
		width: 47.1%;
	}
	
}
/* Small devices (landscape phones, 576px and up) */
@media (max-width: 576px) {
	.slick-arrow {
		width: 30px;
		height: 30px;
		top: calc(50% - 15px);
		border-width: 1px;
	}
	.prev-arrow {
		left: -5px;
	}
	.next-arrow {
		right: -5px;
	}

	.case_detail_tbl tr,
	.case_detail_tbl th,
	.case_detail_tbl td {
		display: block;
		width: 100%;
		border: none;
		padding: 0;
	}
	.case_detail_tbl tr:first-of-type th,
	.case_detail_tbl tr:first-of-type td {
		border: none;
	}
	.case_detail_tbl tr {
		padding: 1rem 0;
		border-bottom: 1px solid #d8dbdd;
	}
	.case_detail_tbl tr:first-of-type {
		border-top: 1px solid #d8dbdd;
	}
	.case_detail_tbl th {
		margin-bottom: 0.5rem;
	}
	.case_detail_tbl td {
	}
}
@media (max-width: 479px) {
}



/* ===================================================================
	会社概要 company
=================================================================== */

/* 代表あいさつ */
.message_img {
	width: 100%;
	width: fit-content;
	margin: 0 auto;
	padding: 40px;
	border-radius: var(--border-radius-img-bs);
	background: var(--bs-white);
	overflow: hidden;
	filter: var(--filter-box-shadow);
	text-align: center;
}

.company_history_img {
	margin-bottom: 40px;
}
.company_history_img img {
	border-radius: var(--border-radius-img-bs);
	filter: var(--filter-box-shadow);
	
}

.company_table {
	width: 100%;
}
.company_table th,
.company_table td {
	padding: 1.5rem 0;
	border-bottom: 1px solid #d8dbdd;
	vertical-align: top;
	line-height: 1.7;
}
.company_table tr:first-of-type th,
.company_table tr:first-of-type td {
	border-top: 1px solid #d8dbdd;
}
.company_table th {
	width: 10em;
	color: var(--bs-primary);
}

.company_table th.company_tbl_title {
	width: auto;
	padding-top: 3rem;
	color: var(--bs-primary);
	font-size: 140%;
}
.company_table th.company_tbl_title.company_tbl_honsya {
	padding-top: 1.5rem;
	border-top: none;
}


.qualified_list {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5em 2em;
}
.qualified_list li {
	position: relative;
	font-weight: 700;
	padding-left: 1em;
}
.qualified_list li::before {
	content: "";
	display: block;
	width: 0.4em;
	height: 0.4em;
	position: absolute;
	left: 0;
	top: 0.55em;
	background: var(--bs-primary);
	border-radius: 50%;
}




.bs_imgtxt {
	display: flex;
	justify-content: space-between;
	margin-bottom: 40px;
}
.bs_imgtxt_txt {
	width: 45%;
	max-width: 450px;
	margin-right: max(50px,5%);
}
.bs_imgtxt_img {
	width: 55%;
	max-width: 550px;
	margin-right: -4%;
	border-radius: var(--border-radius-img-bs);
	overflow:hidden;
	filter: var(--filter-box-shadow);
}
.bs_imgtxt_img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
}
.sdgs_intro {
	margin-bottom: var(--sec-padding-sm);
}

.h3_sdgs {
	margin: 1em 0 0.25em;
	padding-left: 1em;
	font-size: calc(var(--font-size--bs) * 1.25);
	font-weight: 700;
	position: relative;
}
.h3_sdgs:first-of-type {
	margin-top: 0;
}
.h3_sdgs::before {
	content: "";
    display: block;
    width: 0.5em;
    height: 0.5em;
    position: absolute;
    left: 0;
    top: 0.5em;
    background: var(--bs-primary);
    border-radius: 50%;
}

.sdgs_list {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 40px;
	margin: var(--sec-padding-sm) auto;
}
.cafe_909coffee .sdgs_list  {
	margin-bottom: 0;
}
.sdgs_list li {
	max-width: 200px;
	width: 20%;
}

.cafe_instagram {
	margin: 40px 0;
}
.cafe_instagram a {
	max-width: 300px;
	display: flex;
	justify-content: space-between;
	align-items: center;
	border: 1px solid var(--bs-primary);
	width: 100%;
	height: 4em;
	padding: 0 1.5em;
	border-radius: 2em;
	font-family: var(--font-en-family);
	font-size: calc(var(--font-size--md) * 0.8);
	font-weight: 600;
	color: var(--bs-primary);
}
.cafe_instagram a:hover {
	background: var(--bs-primary-light);
}
.cafe_instagram a::after {
	content: '';
	display: block;
	width: 40px;
	height: 40px;
	background: url(../img/icon_instagram.png) no-repeat center center;
	background-size: contain;
}

.cafe_txt {
	margin-bottom: var(--sec-padding-sm);
}
.cafe_torikumi {
	margin-bottom: var(--sec-padding-sm);
}
.cafe_torikumi h3 {
	margin-bottom: 20px;
}

/* XX-Large devices (larger desktops, 1400px and up) */
@media (max-width: 1400px) {
}

/* X-Large devices (large desktops, 1200px and up) */
@media (max-width: 1200px) {
	

	.bs_imgtxt_img {
		height: 35vw;
	}
}
/* Large devices (desktops, 992px and up) */
@media (max-width: 992px) {
	.bs_imgtxt_img {
		width: 50%;
		margin-right: -1%;
	}
}
/* Medium devices (tablets, 768px and up) */
@media (max-width: 768px) {
	.bs_imgtxt {
		flex-direction: column-reverse;
	}
	.bs_imgtxt_txt {
		width: 100%;
		max-width: inherit;
		margin: 20px 0 0;
	}
	.bs_imgtxt_img {
		width: 100%;
		height: 60vw;
		margin: 0 auto;
	}
	.sdgs_list {
		gap: 20px;
	}
}
/* Small devices (landscape phones, 576px and up) */
@media (max-width: 576px) {
	.company_table tr,
	.company_table th,
	.company_table td {
		display: block;
		width: 100%;
		border: none;
		padding: 0;
	}
	.company_table tr:first-of-type th,
	.company_table tr:first-of-type td {
		border: none;
	}
	.company_table tr {
		padding: 1rem 0;
		border-bottom: 1px solid #d8dbdd;
	}
	.company_table tr:first-of-type {
		border-top: 1px solid #d8dbdd;
	}
	.company_table th {
		margin-bottom: 0.5rem;
	}
	.company_table td {
		
	}

	.company_table th.company_tbl_title {
		margin-bottom: 0;
		padding-top: 1rem;
	}
	.company_table th.company_tbl_title.company_tbl_honsya {
		padding-top: 0;
		border-top: none;
	}
	.company_table tr:has(th.company_tbl_title.company_tbl_honsya) {
		border-top: none;
	}
}
@media (max-width: 479px) {
	
}








/* ===================================================================
	住宅設備・リフォーム
=================================================================== */
.mask {
  -webkit-clip-path: url(#svgPath);
  clip-path: url(#svgPath);
  overflow: hidden;
}

.home_systems_reform_link {
	display: flex;
	justify-content: space-between;
}
.home_systems_reform_link_item {
	width: 48.5294%;
	max-width: 660px;
}

.reform_btn {
	position: relative;
	display: block;
	max-width: 660px;
}
.reform_btn:hover {
	opacity: 0.8;
}
.reform_btn_arrow {
	display: block;
	width: 50px;
	height: 50px;
	position: absolute;
	bottom: 20px;
	right: 20px;
	z-index: 5;
}
.reform_btn_img {
	filter: var(--filter-box-shadow);
	z-index: 1;
}
.home_systems_reform_link_name {
	position: absolute;
	bottom: 0;
	left: 0;
	padding: 0 10px;
	filter: none;
	font-size: var(--font-size--lg);
	font-weight: 600;
	z-index: 5;
}
.home_systems_reform_link_name .en {
	display: block;
	font-family: var(--font-en-family);
	font-size: var(--font-size--sm);
	font-weight: 500;
	color: var(--bs-secondary);
}

.home_systems_reform_link_txt {
	margin-top: 40px;
}


/* XX-Large devices (larger desktops, 1400px and up) */
@media (max-width: 1400px) {
	.reform_btn_arrow {
		width: min(4vw, 40px);
		height: min(4vw, 40px);
		bottom: min(1.5vw, 20px);
   		right: min(1.5vw, 20px);
	}
	
	.home_systems_reform_link_name {
		font-size: min(2.5vw, 30px);
	}
	.home_systems_reform_link_name .en {
		font-size: max(1vw,12px);
	}
}

/* X-Large devices (large desktops, 1200px and up) */
@media (max-width: 1200px) {
	
}
/* Large devices (desktops, 992px and up) */
@media (max-width: 992px) {
}
/* Medium devices (tablets, 768px and up) */
@media (max-width: 768px) {
	.home_systems_reform_link {
		display: block;
	}
	.home_systems_reform_link_item {
		width: 100%;
		max-width: 500px;
		margin: 0 auto 40px;
	}
	.home_systems_reform_link_item:last-of-type {
		margin-bottom: 0;
	}
	.reform_btn_arrow {
		width: min(5.5vw, 40px);
		height: min(5.5vw, 40px);
		bottom: min(3vw, 15px);
   		right: min(3vw, 15px);
	}
	
	.home_systems_reform_link_name {
		font-size: min(5vw, 26px);
	}
	.home_systems_reform_link_name .en {
		font-size: max(1vw,10px);
	}
	.home_systems_reform_link_txt {
		margin-top: 20px;
	}
}
/* Small devices (landscape phones, 576px and up) */
@media (max-width: 576px) {
}
@media (max-width: 479px) {
	
}



/* 住宅設備 */

.hs_example_box {
	display: flex;
	justify-content: space-between;
	margin-bottom: var(--sec-padding-sm);
}
.hs_example_txt {
	width: 45%;
}
.hs_example_txt p {
	line-height: 2;
}
.hs_example_txt h3 {
	margin-bottom: 20px;
	font-size: var(--font-size--lg);
	font-weight: 700;
	color: var(--bs-tertiary);
}

.hs_example_img {
	width: 50%;
	max-width: 500px;
}
.hs_example_img img {
	border-radius: var(--border-radius-img-bs);
	filter: var(--filter-box-shadow);
}
.hs_example_img_sp {
	display: none;
}


#gas_equipment {
	position: relative;
	padding: var(--sec-padding-lg) 0;
}
#gas_equipment::before,
#gas_equipment::after {
	content: "";
	width: 150vw;
	height: 100%;
	position: absolute;
	top: 0;
	left: -50vw;
}
#gas_equipment::before {
    background-color: #f2fafe;
    z-index: -2;
}
#gas_equipment::after {
    mix-blend-mode: color-burn;
    background: url(../img/bk_cover.png) repeat top center;
    z-index: -1;
}

#built_in_stove,
#gas_range,
#water_heater,
#gas_oven {
	margin-bottom:var(--sec-padding-bs)
}

.gas_equipment_txt h3 {
	color: var(--bs-primary);
}
.hs_example_txt p.gas_equipment_intro {
	margin-bottom: 20px;
	font-size: calc(var(--font-size--md) * 0.9);
	font-weight: 700;
	line-height: 1.6;
}


.built_in_stove_sekou {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 20px;
	border-radius: var(--border-radius-img-bs);
	background: var(--bs-white);
	filter: var(--filter-box-shadow);
	overflow: hidden;
}
.built_in_stove_sekou_img {
	width: 51%;
	max-width: 490px;
	margin-right: 20px;
}


.features_box {
	display: flex;
	margin-bottom: 40px;
}
.features_box:last-of-type {
	margin-bottom: 0;
}
.features_img {
	width: 30%;
	max-width: 300px;
	margin-right: var(--sec-padding-xs);
	flex-shrink: 0;
	flex-grow: 0;
}
.features_img img {
	width: 100%;
	border-radius: var(--border-radius-img-bs);
	filter: var(--filter-box-shadow);
}
.features_txt h4 {
	margin: 0.5em 0;
	font-size: var(--font-size--md);
	font-weight: 700;
	color: var(--bs-tertiary);
}
.features_txt h4 span {
	margin-left: 1em;
	font-size: var(--font-size--bs);
	color: var(--text-color);
	font-weight: 500;
}

.gas_oven_hikaku {
	padding: 20px;
	background: var(--bs-white);
	border-radius: 20px;
/*	filter: var(--filter-box-shadow);*/
	overflow: hidden;
}

.water_heater_kinou {
	display: flex;
	justify-content: space-between;
	margin-top: 20px;
}
.water_heater_kinou li {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 24%;
	height: 5em;
	border-radius: 2.5em;
	border: 1px solid var(--bs-primary);
	color: var(--bs-primary);
	background: var(--bs-white);
	text-align: center;
	font-weight: 600;
}

/* XX-Large devices (larger desktops, 1400px and up) */
@media (max-width: 1400px) {
}

/* X-Large devices (large desktops, 1200px and up) */
@media (max-width: 1200px) {
}
/* Large devices (desktops, 992px and up) */
@media (max-width: 992px) {
}
/* Medium devices (tablets, 768px and up) */
@media (max-width: 768px) {
	.hs_example_box {
		display: block;
	}
	.hs_example_txt {
		width: 100%;
	}
	.hs_example_img {
		display: none;
		width: 100%;
		margin: 20px auto 0;
	}
	.hs_example_img_sp {
		display: block;
		width: 100%;
		height: 40vw;
		margin: 20px auto;
	}
	.hs_example_img_sp img {
		width: 100%;
		height: 100%;
		object-fit: cover;
		object-position: center;
		border-radius: var(--border-radius-img-bs);
		filter: var(--filter-box-shadow);
	}

	#gas_equipment .hs_example_img_sp {
		height: 30vw;
	}
	.built_in_stove_sekou {
		display: block;
	}
	.built_in_stove_sekou_img {
		width: auto;
		margin: 0 auto 20px;
	}

	.features_box {
		margin-bottom: 20px;
	}
	.features_txt h4 {
		margin: 0 0 0.5em;
	}

	.water_heater_kinou li {
		font-size: var(--font-size--sm);
	}
}
/* Small devices (landscape phones, 576px and up) */
@media (max-width: 576px) {
	.hs_example_box {
		margin-bottom: 40px;
	}
	.features_box {
		display: block;
		width: 90%;
		margin: 0 auto 20px;
	}
	.features_img {
		width: 100%;
		max-width: inherit;
		margin: 0;
	}
	.features_txt h4 {
		margin: 0.7em 0 0.5em;
	}

}
@media (max-width: 479px) {
	
}




/* リフォーム */
.strengths_box {
	display: flex;
	justify-content: space-between;
}

.strengths_txt {
	width: 50%;
	max-width: 500px;
}
.strengths_txt h3 {
	margin: var(--sec-padding-xs) 0 20px;
	font-size: var(--font-size--lg);
	font-weight: 700;
	color: var(--bs-tertiary);
}
.strengths_txt h3:first-of-type {
	margin-top: 0;
}
.strengths_txt p {
	line-height: 2;
}
.strengths_img {
	width: 47%;
	margin-right: -1%;
}


.cando_list {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-around;
	gap: var(--sec-padding-xs) 5%;
}
.cando_list li {
	width: 26%;
	max-width: 260px;
	text-align: center;
	position: relative;
}
.cando_img {}
.cando_num {
	display: block;
	margin-top: -0.5em;
	font-family: var(--font-en-family);
	font-size: var(--font-size--xxxl);
	font-weight: 600;
	color: var(--bs-primary);
	line-height: 1;
	text-align: center;
}
.cando_txt {
	margin-top: 0.2em;
	font-size: var(--font-size--md);
	font-weight: 600;
	text-align: center;
	line-height: 1.4;
}

.reform_flow_list li {
	display: flex;
	position: relative;
	margin-bottom: var(--sec-padding-sm);
}
.reform_flow_list li::before,
.reform_flow_list li::after {
	content: "";
	display: block;
	width: 6px;
	height: 100%;
	position: absolute;
	top: 70px;
	left: 67px;
}
.reform_flow_list li::before {
	background: var(--bs-gradient-primary);
	z-index: -2;
}
.reform_flow_list li::after {
	mix-blend-mode: color-burn;
    background: url(../img/bk_cover.png) repeat top center;
    z-index: -1;
}
.reform_flow_list li:last-of-type::before,
.reform_flow_list li:last-of-type::after {
	display: none;
}
.reform_flow_step {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	flex-shrink: 0;
	flex-grow: 0;
	width: 140px;
	height: 140px;
	margin-right: var(--sec-padding-sm);
	border-radius: 50%;
	color: var(--bs-primary);
	background: var(--bs-gradient-primary);
	position: relative;
	font-size: 20px;
	font-weight: 600;
	font-family: var(--font-en-family);
	line-height: 1;
}
.reform_flow_step::before {
    content: '';
    position: absolute;
    width: 100%;
    top: 0;
    left: 0;
    bottom: 0;
    mix-blend-mode: color-burn;
    background: url(../img/bk_cover.png) repeat top center;
    z-index: 1;
}
.reform_flow_step span {
	z-index: 2;
}
.reform_flow_step .step_num {
	font-size: 60px;
}
.reform_flow_txt {
	margin-top: 35px;
}
.reform_flow_txt h3 {
	margin-bottom: 20px;
	font-size: var(--font-size--lg);
	color: var(--bs-tertiary);
}
.reform_flow_txt p {
	line-height: 2;
}
.reform_flow_img {
	flex-shrink: 0;
	flex-grow: 0;
	width: 32%;
	max-width: 320px;
	margin-top: 35px;
	margin-left: var(--sec-padding-sm);
}
.reform_flow_img img {
	border-radius: var(--border-radius-img-bs);
	filter: var(--filter-box-shadow);
}



.reform_example_box {
	display: flex;
	justify-content: space-between;
	margin-bottom: var(--sec-padding-bs);
}
.reform_example_txt {
	width: 45%;
}
.reform_example_txt p {
	line-height: 2;
}
.reform_example_txt h3 {
	margin-bottom: 20px;
	font-size: var(--font-size--lg);
	font-weight: 700;
	color: var(--bs-primary);
}
.reform_example_txt h4 {
	margin-bottom: 20px;
	font-size: var(--font-size--md);
	font-weight: 700;
}
.reform_example_txt h5 {
	font-size: calc(var(--font-size--bs)*1.1);
	font-weight: 700;
	margin: 1em 0 0.2em;
    padding-left: 1em;
    font-weight: 700;
    position: relative;
}
.reform_example_txt h5::before {
    content: "";
    display: block;
    width: 0.5em;
    height: 0.5em;
    position: absolute;
    left: 0;
    top: 0.5em;
    background: var(--bs-primary);
    border-radius: 50%;
}
.reform_example_txt h5:first-of-type {
	margin-top: 20px;
}
.reform_example_img {
	width: 50%;
	max-width: 500px;
}
.reform_example_img img {
	border-radius: var(--border-radius-img-bs);
	filter: var(--filter-box-shadow);
}
.reform_example_img_sp {
	display: none;
}
/* XX-Large devices (larger desktops, 1400px and up) */
@media (max-width: 1400px) {
}
/* X-Large devices (large desktops, 1200px and up) */
@media (max-width: 1200px) {
}
/* Large devices (desktops, 992px and up) */
@media (max-width: 992px) {

	.reform_flow_step {
		width: 100px;
		height: 100px;
		font-size: 16px;
		margin-right:var(--sec-padding-xs);
	}
	.reform_flow_step .step_num {
		font-size: 42px;
	}
	.reform_flow_list li::before,
	.reform_flow_list li::after {
		left: 47px;
	}
	.reform_flow_txt,
	.reform_flow_img {
		margin-top: 25px;
	}

	.reform_example_txt {
		width: 55%;
	}
	.reform_example_img {
		width: 40%;
	}
}
/* Medium devices (tablets, 768px and up) */
@media (max-width: 768px) {
	.strengths_box {
		flex-direction: column-reverse;
	}
	.strengths_img {
		width: 100%;
		max-width: inherit;
		margin-bottom: var(--sec-padding-sm);
		text-align: center;
	}
	.strengths_txt {
		width: 100%;
		max-width: inherit;
	}


	.cando_list {
		gap: 20px 5%;
	}
	.cando_list li {
		width: 45%;
	}

	.reform_example_box {
		display: block;
	}
	.reform_example_txt {
		width: 100%;
	}
	.reform_example_img {
		display: none;
		width: 100%;
		margin: 20px auto 0;
	}
	.reform_example_img_sp {
		display: block;
		width: 100%;
		height: 30vw;
		margin: 20px auto;
	}
	.reform_example_img_sp img {
		width: 100%;
		height: 100%;
		object-fit: cover;
		object-position: center;
		border-radius: var(--border-radius-img-bs);
		filter: var(--filter-box-shadow);
	}
}
/* Small devices (landscape phones, 576px and up) */
@media (max-width: 576px) {

	.reform_flow_step {
		width: 70px;
		height: 70px;
		font-size: 12px;
		margin-right:15px;
	}
	.reform_flow_step .step_num {
		font-size: 30px;
	}
	.reform_flow_list li {
		flex-wrap: wrap;
	}
	.reform_flow_list li::before,
	.reform_flow_list li::after {
		left: 32px;
	}
	.reform_flow_txt,
	.reform_flow_img {
		width: calc(100% - 100px);
		max-width: inherit;
		margin-top: 20px;
		margin-left: auto
	}
	.reform_flow_txt h3 {
		margin-bottom: 10px;
	}
}
@media (max-width: 479px) {
	
}























/* XX-Large devices (larger desktops, 1400px and up) */
@media (max-width: 1400px) {
}

/* X-Large devices (large desktops, 1200px and up) */
@media (max-width: 1200px) {
}
/* Large devices (desktops, 992px and up) */
@media (max-width: 992px) {
}
/* Medium devices (tablets, 768px and up) */
@media (max-width: 768px) {
}
/* Small devices (landscape phones, 576px and up) */
@media (max-width: 576px) {
}
@media (max-width: 479px) {
	
}






/* ===================================================================
	採用案内
=================================================================== */
.job_description {
	margin-bottom: var(--sec-padding-lg);
}
.job_table {
	max-width: 1000px;
	margin: 0 auto;
}
.job_table th {
	width: 14em;
}


.recruit_a_day_intro {
	margin-bottom: var(--sec-padding-sm);
	font-size: var(--font-size--md);
}

.recruit_a_day_list {
	display: flex;
	justify-content: center;
	gap: 5%;
}
.recruit_a_day_list_item {
	width: 45%;
	max-width: 430px;
	font-weight: 500;
}

.recruit_a_day_list_item .item_img {
	border-radius: var(--border-radius-img-bs);
	filter: var(--filter-box-shadow);
	overflow: hidden;
	position: relative;
}
.recruit_a_day_list_item .item_img img {	
	transition: all .5s ease;
}
.recruit_a_day_list_item a:hover .item_img img {
	transform: scale(1.08);
}
.recruit_a_day_list_item .item_img::after {
	content: '';
	display: block;
	width: 40px;
	height: 40px;
	background: url(../img/icon_arrow_orange.png) no-repeat center center;
	background-size: contain;
	position: absolute;
	right: 20px;
	bottom: 20px;
	filter: var(--filter-box-shadow);
}
.recruit_a_day_list_item .item_title {
	margin: 20px 0;
	font-size: calc(var(--font-size--md) * 0.9);
}
.recruit_a_day_list_item .in_charge {
	color: #7a7b7d;
}
.recruit_a_day_list_item .name {
	font-size: var(--font-size--md);
}
.recruit_a_day_list_item a:hover,
.recruit_a_day_list_item a:hover .in_charge {
	color: var(--bs-primary)!important;
}


/* XX-Large devices (larger desktops, 1400px and up) */
@media (max-width: 1400px) {
}

/* X-Large devices (large desktops, 1200px and up) */
@media (max-width: 1200px) {
}
/* Large devices (desktops, 992px and up) */
@media (max-width: 992px) {
	
}
/* Medium devices (tablets, 768px and up) */
@media (max-width: 768px) {
	.recruit_a_day_list_item .item_img::after {
		width: 30px;
		height: 30px;
	}
}
/* Small devices (landscape phones, 576px and up) */
@media (max-width: 576px) {
	.job_table th {
		width: 100%;
	}

	.recruit_a_day_list {
		flex-direction: column;
		align-items: center;
	}
	.recruit_a_day_list_item {
		width: 100%;
		max-width: 300px;
		margin: 0 0 30px;
	}
	.recruit_a_day_list_item .item_img {
		/*height: 55vw;*/
	}
	.recruit_a_day_list_item .item_img::after {
		right: 15px;
		bottom: 15px;
	}
	.recruit_a_day_list_item .item_img img {
		width: 100%;
		height: 100%;
		object-fit: cover;
		object-position: center;
	}
}
@media (max-width: 479px) {
}



/* ===================================================================
	社員のある一日
=================================================================== */

.employee_prof {
	width: var(--def-width);
	max-width: var(--max-width);
	margin: 140px auto 0;
	padding: var(--sec-padding-bs)  0;
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	position: relative;
}
.employee_prof::before,
.employee_prof::after {
	content: "";
	width: 150vw;
	height: 100%;
	position: absolute;
	top: 0;
	left: -50vw;
}
.employee_prof::before {
    background-color: #f2fafe;
	background: var(--bs-gradient-primary-02);
    z-index: -2;
}
.employee_prof::after {
    mix-blend-mode: color-burn;
    background: url(../img/bk_cover.png) repeat top center;
    z-index: -1;
}

.employee_prof_txt {
/*	margin-bottom: var(--sec-padding-bs);*/
}
.employee_prof_txt h2 {
	font-size: var(--font-size--xl);
	font-weight: 700;
	color: var(--bs-tertiary);
}
.employee_prof_detail {
	margin-top: 40px;
	padding: 10px 0 0 20px;
	border-left: 1px solid var(--bs-primary);
}
.employee_prof_txt .in_charge {

}
.employee_prof_txt .name {
	font-size: calc(var(--font-size--md) * 0.9);
	font-weight: 500;
}
.employee_prof_img {
	width: 60%;
	max-width: 600px;
	margin: -220px 0 -40px;
	border-radius: var(--border-radius-img-bs);
	overflow: hidden;
	filter: var(--filter-box-shadow);
}
.employee_prof_img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}


.employee_day {
	width: var(--def-width);
	max-width: 1000px;
	margin: var(--sec-padding-bs) auto;
}

.employee_day_list {
}
.employee_day_list li {
	display: flex;
	align-items: flex-start;
	position: relative;
	padding-bottom: var(--sec-padding-bs);
}
.employee_day_list li:last-of-type {
	padding-bottom: 0;
}
.employee_day_list li::before {
	content: "";
	display: block;
	width: 3px;
	height: 100%;
	position: absolute;
	top: calc(var(--font-size--lg) * 0.5);
	left: calc(var(--font-size--lg) * 2.5);
}
.employee_day_list li::before {
	background: var(--bs-primary);
	z-index: -2;
}
.employee_day_list li:last-of-type::before {
	display: none;
}
.day_time {
	flex-shrink: 0;
	flex-grow: 0;
	width: 5em;
	margin-right: 1.8em;
	padding: 0.09em 0;
	background: var(--bs-primary);
	font-family: var(--font-en-family);
	font-size: var(--font-size--lg);
	font-weight: 600;
	color: var(--bs-white);
	border-radius: 1em;
	text-align: center;
}
.day_txt h3 {
	margin-bottom: 0.5em;
	font-size: var(--font-size--lg);
	font-weight: 700;
	color: var(--bs-tertiary);
}
.day_txt p {
	line-height: 2;
}
.day_img {
	max-width: 600px;
	margin-top: 40px;
	border-radius: var(--border-radius-img-bs);
	filter: var(--filter-box-shadow);
	overflow: hidden;
}
.day_img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.a_day_message {
	width: var(--def-width);
	max-width: 1000px;
	margin: var(--sec-padding-bs) auto;
	padding: 0;
	background: #f2fafe;
	border-radius: var(--border-radius-img-bs);
	position: relative;
	overflow: hidden;
	z-index: 0;
}
.a_day_message::before {
	content: '';
	position: absolute;
	width: 100%;
	top: 0;
	left: 0;
	bottom: 0;
	mix-blend-mode: color-burn;
	background: url(../img/bk_cover.png) repeat top center;
	z-index: 1;
}
.a_day_message_inner {
	position: relative;
	z-index: 10;
}
.a_day_message h3 {
	width: fit-content;
	padding: 0.5em 2em;
	border-radius: 0 0 20px 0;
	background: var(--bs-white);
	font-family: var(--font-en-family);
	font-size: var(--font-size--md);
	color: var(--bs-primary);
}
.a_day_message p {
	max-width: calc(800px + 5em);
	margin: 0 auto;
	padding: 1.5em 2.5em 2.5em;
	line-height: 2;
	font-size: calc(var(--font-size--bs)* 1.2);
}

/* XX-Large devices (larger desktops, 1400px and up) */
@media (max-width: 1400px) {
	.employee_prof_img {
		width: 50%;
	}
}

/* X-Large devices (large desktops, 1200px and up) */
@media (max-width: 1200px) {
	.employee_prof {
		margin-top: 12vw;
	}
	.employee_prof_img {
		margin-top: -14vw;
		width: 45%;
		height: auto;
	}
	.employee_prof_txt h2 {
		font-size: var(--font-size--lg);
	}
	.employee_prof_txt .name {
		font-size: var(--font-size--md);
	}
}
/* Large devices (desktops, 992px and up) */
@media (max-width: 992px) {
	.employee_prof {
		padding: var(--sec-padding-sm) 0;
	}
	.employee_prof_detail {
		margin-top: 20px;
	}
}
/* Medium devices (tablets, 768px and up) */
@media (max-width: 768px) {
	.employee_prof {
		display: block;
		position: relative;
	}
	.employee_prof_img {
		width: 39%;
		position: absolute;
		right: 0;
		bottom: -40px;
		margin: 0;
	}
	.employee_prof_txt {
		z-index: 10;
		position: relative;
	}

}
/* Small devices (landscape phones, 576px and up) */
@media (max-width: 576px) {
	.employee_prof {
		margin-bottom: 120px;
	}
	.employee_prof_img {
		width: 45%;
		bottom: -80px;
	}
	.employee_prof_detail {
		padding-left: 10px;
	}

	.day_time {
		width: 4.5em;
		margin-right: 1em;
		font-size: var(--font-size--md);
	}
	.employee_day_list li::before {
		left: calc(var(--font-size--lg) * 2.1);
	}
	.day_img {
		margin-top: 20px;
	}

	.a_day_message h3 {
		border-radius: 0 0 10px 0;
	}
	.a_day_message p {
		margin: 0 auto;
		padding: 1.5em 1.5em 1.5em;
		line-height: 2;
		font-size: var(--font-size--bs);
	}

}
@media (max-width: 479px) {
}






/* ===================================================================
	お問い合わせ
=================================================================== */

.contact_intro {
	width: var(--def-width);
	max-width: 1000px;
	margin: 0 auto var(--sec-padding-bs);
}
.contact_intro h2 {
	margin-bottom: 1em;
	font-size: var(--font-size--xl);
	font-weight: 700;
	color: var(--bs-primary);
	text-align: center;
}
.contact_intro p {
	font-size: calc(var(--font-size--md) * 0.9);
	text-align: center;
	line-height: 2;
}


.contact_page_tel {
	width: fit-content;
	max-width: 700px;
	margin: 0 auto var(--sec-padding-bs);
	padding: var(--sec-padding-xs);
	background: var(--bs-white);
	border-radius: var(--border-radius-img-bs);
	filter: var(--filter-box-shadow);
}
.contact_page_tel h2 {
	font-size: var(--font-size--md);
	font-weight: 700;
	text-align: center;
}
.contact_page_tel .uketsuke {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 0 2em;
}

.contact_page_tel .link_tel {
	display: flex;
	justify-content: center;
	align-items: center;
	margin: 0.4em auto 0;
	font-family: var(--font-en-family);
	font-size: var(--font-size--xxl);
	font-weight: 600;
	color: var(--bs-secondary);
}
.contact_page_tel .link_tel::before {
	content: '';
	display: block;
	width: 1.2em;
	height: 1.2em;
	margin-right: 0.3em;
	background: url(../img/icon_footer_tel.svg) no-repeat center center;
	background-size: contain;
}



.form_area {
	width: var(--def-width);
	max-width: 1000px;
	margin: 0 auto;
	border-radius: var(--border-radius-img-bs);
	background: #e0f0fa;
	position: relative;
	overflow: hidden;
	z-index: 0;
}

.form_area::before {
	content: '';
	position: absolute;
	width: 100%;
	top: 0;
	left: 0;
	bottom: 0;
	mix-blend-mode: color-burn;
	background: url(../img/bk_cover.png) repeat top center;
	z-index: 1;
}
.form_area_inner {
	position: relative;
	z-index: 10;
	padding: var(--sec-padding-xs) var(--sec-padding-sm);
}

.tbl_form {
	width: 100%;
	border-collapse: collapse;
	border-spacing: 0;	
}
.tbl_form th,
.tbl_form td {
	padding: 1em 0;
	border: none;
}
.tbl_form th {
	width: 15em;
	padding-top: 1.5em;
	padding-right: 1em;
	font-weight: 700;
	text-align: left;
	vertical-align: top;
	white-space: nowrap;
	font-size: calc(var(--font-size--bs) * 1.1);
}
.icon_hissu {
	display: inline-block;
	margin-right: 1rem;
	padding: 0.2em 0.8em;
	border-radius: 1em;
	color: var(--bs-white);
	background: #e52d0b;
	font-size: var(--font-size--sm);
	line-height: 1.2;
}

/* フォーム -------------------- */
input,button,textarea,select {
	outline: none;
	font-size:var(--font-size--bs);
	font-family: var(--def-font-family);
	font-weight: 400;
}

.form_control {
	display: block;
	width: 100%;
	padding: 0.7em 0.8em;
	font-weight: 400;
	line-height: 1.5;
	color: var(--text-color);
	background-color: var(--bs-white);
	background-clip: padding-box;
	border: 1px solid #c0d0da;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
/*	border-radius: 0.25em;*/
}
.form_control.wpcf7-not-valid {
	border: 1px solid var(--bs-danger);
	background: var(--bs-danger-light);
}
/*
.form_control:focus {
	border: 1px solid rgba(var(--bs-primary-rgb),0.5);
	box-shadow:0px 0px 5px rgba(var(--bs-primary-rgb),0.4);
}*/
textarea.form_control {
	height: 10em;
}
.form_control_inline {
	display: inline-block;
	width: auto;
}
.input_inline {
	display: flex;
	align-items: center;
}
.form_num {
	width: 5em;
}

/* checkbox チェックボックス */
.checkbox {
	margin: .2em 0;
	line-height: 1.5;
}
.checkbox label {
/*	background: #eee;*/
	cursor: pointer;
	line-height: 1.5;
}
input[type="checkbox"] {
	position: relative;
/*	width: 1.2em;
	height: 1.2em;
	border:none;*/
	margin: -0.3em 1em 0 0;
	line-height: 1.5;
}
input[type="checkbox"]::before,
input[type="checkbox"]::after {
	content: "";
	display: block; 
	position: absolute;
}
input[type="checkbox"]::before {
	background-color: var(--bs-white);
	border-radius: 5px;
	border: 1px solid #c0d0da;
	width: 1.4em;
	height: 1.4em;
	transform: translateY(-50%);
	top: 50%;
	left: 0;
}
input[type="checkbox"]::after {
	border-bottom: 3px solid var(--bs-white);
	border-left: 3px solid var(--bs-white);
	opacity: 0;
	height: .4em;
	width: .8em;
	transform: rotate(-45deg);
	top: 0.1em;
	left: .3em;
}
input[type="checkbox"]:checked::before {
	background: var(--bs-primary);
}
input[type="checkbox"]:checked::after {
	opacity: 1;
}


/* radio ラジオボタン */
.radio-group label {
	cursor: pointer;
	line-height: 1.5;
	margin-right: 1em;
}
input[type="radio"] {
	position: relative;
	margin: -0.3em 1em 0 0;
	line-height: 1.5;
}
input[type="radio"]::before,
input[type="radio"]::after {
	content: "";
	display: block; 
	position: absolute;
}
input[type="radio"]::before {
	background-color: var(--bs-white);
	border-radius: 0.6em;
	border: 1px solid var(--text-color);
	width: 1.2em;
	height: 1.2em;
	transform: translateY(-50%);
	top: 50%;
	left: 0;
}
input[type="radio"]::after {
	background-color: var(--bs-primary);
	border-radius: 0.4em;
	width: 0.8em;
	height: 0.8em;
	top: calc(50% - 0.4em);
	left: 0.2em;
	opacity: 0;
}
input[type="radio"]:checked::after {
	opacity: 1;
}


/* エラー */
.mw_wp_form .error {
	margin-top: 0.3em;
	font-weight: 700;
}



.form_agree {
	width: fit-content;
	margin: var(--sec-padding-sm) auto;
	font-size: var(--font-size--bs);
}
.form_agree a {
	text-decoration: underline;
	color: var(--bs-primary);
}
.form_agree .icon_hissu {
	margin-right: 0;
	margin-left: 1em;
}


.btn_area {
/*	display: flex;
	justify-content: center;
	gap: 1em;*/
	margin-top: var(--sec-padding-sm);
}
.btn_send {
	width: 100%;
	max-width: 300px;
	margin: 0 auto;
	position: relative;
	font-size: calc(var(--font-size--bs) * 1.4);
	font-weight: 600;
	z-index: 0;
	background: var(--bs-primary);
	border-radius: 1.8em;
	transition: all .3s ease;
}
.btn_send:hover {
	background: var(--bs-primary-light-02);
}
.btn_send::after {
	content: '';
	display: block;
	width: 2em;
	height: 2em;
	background: url(../img/btn_arrow_send.svg) no-repeat center center;
    background-size: contain;
	position: absolute;
	right: 0.5em;
	top: 50%;
	transform: translateY(-50%);
	z-index: 1;
}
.btn_send input {
	display: flex;
	justify-content: space-between;
	align-items: center;
	width: 100%;
	height: 3.6em;
	margin: 0 auto;
	padding: 0 0.5em 0 1em;
/*	background: var(--bs-primary);*/
	color: var(--bs-white);
	border: 2px solid var(--bs-primary);
	font-size: calc(var(--font-size--bs) * 1.4);
	font-weight: 600;
	line-height: 1.2;
	border-radius: 1.8em;
	transition: all .3s ease;
	z-index: 10;
	position: relative;
}

/*
.btn_send,
.btn_back {
	display: flex;
	justify-content: space-between;
	align-items: center;
	width: 100%;
	max-width: 300px;
	height: 3.6em;
	margin: 0 auto;
	padding: 0 0.5em 0 1em;
	border: 2px solid var(--bs-primary);
	font-family: var(--font-en-family);
	font-size: calc(var(--font-size--bs) * 1.4);
	font-weight: 600;
	line-height: 1.2;
	border-radius: 1.8em;
	transition: all .3s ease;
}
.btn_send {
	background: var(--bs-primary);
	color: var(--bs-white);
}
.btn_back {
	background: var(--bs-white);
	color: var(--bs-primary);
}
.btn_send::after,
.btn_back::before {
	content: '';
	display: block;
	width: 2em;
	height: 2em;
	transition: all .3s ease;
}
.btn_send::after {
	margin-left: 1em;
	background: url(../img/btn_arrow_send.svg) no-repeat center center;
    background-size: contain;
}
.btn_back::before {
	margin-right: 1em;
	background: url(../img/btn_arrow_back.svg) no-repeat center center;
    background-size: contain;
}
.btn_send:hover {
	background: var(--bs-primary-light-02);
}
.btn_back:hover {
	background: var(--bs-primary-light);
}
*/


.wpcf7-spinner {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	margin:  auto auto!important;
}

.wpcf7-not-valid-tip {
	font-weight: 600;
}
.wpcf7 form .wpcf7-response-output {
	width: var(--def-width);
	max-width: 1000px;
	margin: var(--sec-padding-xs) auto 0;
	padding: 1em;
}

/* XX-Large devices (larger desktops, 1400px and up) */
@media (max-width: 1400px) {
}

/* X-Large devices (large desktops, 1200px and up) */
@media (max-width: 1200px) {
}
/* Large devices (desktops, 992px and up) */
@media (max-width: 992px) {
}
/* Medium devices (tablets, 768px and up) */
@media (max-width: 768px) {
	.form_area_inner {
		padding: var(--sec-padding-xs) var(--sec-padding-sm) var(--sec-padding-bs);
	}
	.tbl_form tr,
	.tbl_form th,
	.tbl_form td {
		display: block;
		width: 100%;
	}
	.tbl_form th {
		padding: 1em 0 0;
		border: none;
	}
	.tbl_form td {
		padding: 1em 0;
	}

	.form_sub {
		display: block;
	}
}
/* Small devices (landscape phones, 576px and up) */
@media (max-width: 576px) {
	.contact_page_tel {
		width: 80%;
		padding: var(--sec-padding-sm) var(--sec-padding-xs);
	}
	.contact_page_tel .uketsuke {
		width: fit-content;
		display: block;
		margin: 5px auto 0;
	}
	.contact_page_tel .uketsuke span {
		display: block;
		width: auto;
	}
}
@media (max-width: 479px) {
}





/* ===================================================================
	404
=================================================================== */
.notfound_title {
	margin-bottom: 1em;
	font-size: var(--font-size--xl);
	font-weight: 700;
	color: var(--bs-primary);
	text-align: center;
}
.notfound_txt {
	font-size: var(--font-size--md);
	text-align: center;
}

.notfound_back {
	margin-top: var(--sec-padding-sm);
}
.notfound_back a.btn_primary {
	margin: 0 auto;
	max-width: 14em;
}



/* ===================================================================
	single
=================================================================== */

#single_content {
	width: var(--def-width);
	max-width: var(--max-width);
	margin: 0 auto;
}

