@charset "UTF-8";
:root{
	--var-color1:#000;


}
/****

ベース

****/
body{
	/*
	-webkit-text-size-adjust: 100%;
	background:rgba(54,194,186,0.5);

	background: #fff;
	/*↓ページフェードイン用 cpu_common.jsより*/
	/*firefoxのみのハックを一番下に入れてあります。*/
	/*display:none;
	-webkit-font-smoothing: antialiased;
	*/
}

div{
	max-height:inherit;
}



/****

ヘッダー

****/
header{
	margin:0;
	padding:0;
}

nav{
	margin:0;
	padding:0;
}

  .container header{
    width:100%;
    position: sticky;
    top:0;
    z-index:100;
  }

.header_bg{
	width:100%;
	height:auto;
  background:url("../img/hd_back.jpg") no-repeat center center;
  background-size: cover;
	position:relative;
	z-index:999;
}
/*   .header_bg::before{
    content: '';
    display:block;
    width:100%;
    height:100%;
    background: #545655;
    mix-blend-mode: multiply;
    position: absolute;
    top:0;
    left:0;
    z-index:0;
  } */


.header,.fotter-caption{
	width:92%;
	max-width:1000px;
	height:auto;
	background:none;
	padding:0 0 0;
	margin:0 auto;
  position: relative;
  z-index:1;
}

.fotter-caption{
	padding:60px 0 0;
}

.page-caption li{
	font-family: 'Noto Sans JP';
	text-indent: -1em;
	padding-left:1em ;
}

.header>p,.header>h1{
	width:calc(100% - 20px);
	padding: 10px;
	font-weight: normal;
	font-size: 1em;
}


/***

パンくずナビ
g_breadCrumb

***/
#maBlock2 {
	width: 100%;
	margin: 0 auto;
	padding-top: 8px;
	padding-bottom: 12px;

	/*background: rgba(90,182,53,1.00);*/
}
#g_breadCrumb2 {
	color: #4d4d44;
	font-size: 12px;
	font-family: "メイリオ", "meiryo", verdana, "ヒラギノ角ゴ Pro W3", hirakakupro-w3, "ＭＳ Ｐゴシック", "ms pgothic", sans-serif;
	line-height: 1.6em;
	letter-spacing: 0.03em;

	text-align: left;
}

#g_breadCrumb2 li {
	/*display: inline;*/
	padding: 0 3px;
	letter-spacing: 0.03em;
	font-size: 11px;
	display:inline-block;
	color:#fff;
	text-align: left;
}

#g_breadCrumb2 li a {
	padding:0 14px 0 0 ;
	color:#fff;
	background:url("../img/co_bg_01_grey.png") center right no-repeat;
}

#g_breadCrumb2 li a:hover {
	text-decoration:none;
}

/***

ロゴ

***/
.logo{
	/*
	width:9.5%;
	max-width:114px;
	*/
	width:50%;
	max-width:463px;
	height:auto;
	margin: 0;
	padding:5px 0 0;
	text-align: left;
}
.logo img{
	width:100%;
	height:auto;
}
.logo1{
	/*
	width:9.5%;
	max-width:114px;
	*/
	width:463px;
	height:auto;
/*	float:left;*/
	margin: 0 auto;
	padding:5px 0 0;
}
.logo1 img{
	width:100%;
	height:auto;
}
.logo .logo_caption {
	margin-top: 13px;
	color: #fff;
}

header .header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
}

header .header .breadCrumb {
	width: 100%;
}

.header-right {
	display: flex;
	justify-content: flex-end;
}
.header-right .btnlist {
	display: flex;
}
.header-right .btnlist>div:first-child {
	width: 98px;
	margin-right: 5px;
}
.header-right .btnlist>div:last-child {
	width: 168px;
}
.header-right .btnlist>div>div:first-child {
	margin-bottom: 5px;
}
.header-right .btnlist>div a {
	display: block;
	height: 30px;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: .7s;
}
.header-right .btnlist>div a:hover {
	opacity: .7;
}
.header-right .btnlist>div a img {
	height: 13px;
}
.header-right .btnlist .btn1 a,
.header-right .btnlist .header_btn a {
	background: #9fa0a0;
}
.header-right .btnlist .btn2 a {
	background: #8b8458;
}
.header-right .btnlist .btn3 a {
	background: #009944;
}

.smart_btn{
	display:none;
}


  .header_btn_bg{
    width: 55%;
    max-width: 600px;
    float: right;
    display:flex;
/*     justify-content: space-between;
    gap:2%; */
	justify-content: end;
    gap: 12px;
    flex-direction: row-reverse;
  }


@media (max-width: 750px) {
	.logo {
		max-width: calc(100% - 120px);
		width: calc(100% - 120px);
	}
	.header {
		padding: 20px 0 10px;
	}
}



/* グローバルナビ PC */
@media print, screen and (min-width: 751px) {
.header h1{
	font-family:"ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	font-size:10px;
	text-align: left;
}

.sp_nav{
	background: none;
}

.hd_box{
	display:none;
}
}

.corp_btn{
	display:block;
	width:100%;
	height:auto;
}

.corp_btn img{
	width:100%;
	height:auto;
}

.drawer-hamburger {
	position: relative;
	background: url(../img/common/txt_menu.svg) no-repeat;
	background-position: top center;
	width: 70px;
	height: 70px;
	padding: 0;
	margin-left: 20px;
}
.drawer-hamburger-icon,
.drawer-hamburger-icon:after,
.drawer-hamburger-icon:before {
	background-color: #fff;
}
.drawer--right.drawer-open .drawer-hamburger {
	right: 0;
}
.drawer-open .drawer-hamburger-icon:before {
  -webkit-transform: rotate(20deg);
  transform: rotate(20deg);
}
.drawer-open .drawer-hamburger-icon:after {
  -webkit-transform: rotate(-20deg);
  transform: rotate(-20deg);
}
.drawer-nav {
	background-color: rgba(0, 0, 0, .8);
	color: #fff;
	width: 30vw;
	margin-top: 70px;
	text-align: left;
	padding: 100px 15vw 2vw 2vw;
}
.drawer--right .drawer-nav {
	right: -47vw;
}
.drawer-menu-item {
  text-decoration: none !important;
  color: #fff;
  z-index: 99;
  position: relative;
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
	border-bottom: solid 1px #fff;
	transition: .7s;
	padding: 1rem .75rem .2rem;
}
.drawer-menu-item.nolink {
	pointer-events: none;
}
.drawer-menu-item.nolink .en,
.drawer-menu-item.nolink .jp {
	opacity: .5;
}
.drawer-menu-item.nolink:after {
	content: 'Coming Soon';
	background: #000;
	color: #fff;
	display: block;
	position: absolute;
	left: .75rem;
	top: 10px;
	font-size: 9px;
	letter-spacing: 2px;
	padding: 0 2px;
	display: inline-block;
	line-height: 1.2;
}
.drawer-menu-item:hover {
	color: #fff;
	opacity: .7;
}
.drawer-menu-item .en {
	font-size: 20px;
}
.drawer-menu-item .jp {
	font-size: 14px;
}
.drawer-open .drawer-overlay {
	display: none;
}
.drawer-menu {
	margin-bottom: 20px;
}
.header-right .drawer-nav .btnlist {
	width: 100%;
}
.header-right .drawer-nav .btnlist>div:first-child {
	width: 40%;
}
.header-right .drawer-nav .btnlist>div:last-child {
	width: 60%;
}
.header-right .drawer-nav .btnlist>div:first-child {
	margin-right: 10px;
}
.header-right .drawer-nav .btnlist>div>div:first-child {
	margin-bottom: 10px;
}
@media print, screen and (max-width: 750px) {
	.drawer-menu-item {
		padding: 20px .75rem 20px;
	}
	.drawer-menu-item .en{
		font-size: 28px;
	}
	.drawer-menu-item .jp{
		font-size: 18px;
	}
	.drawer-menu-item.nolink:after {
	font-size: 14px;
	}
}
/****

ヘッダー　資料請求　マップ　テキストcss

****/

.header_btn span.hd_menu_btn_txt1{
	width: 100%;
	height: auto;
	line-height: 120%;
	text-align: center;
	font-family:"Noto Sans JP","ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	text-decoration: none;
	font-weight:normal;

	letter-spacing: 4px;
	letter-spacing: 2px;
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	margin: 0 auto;
	padding-top: 6px;
	z-index: 999;
	color:#222;

}


/*****

グローバルナビ　上線

*****/
.hd_bar1{
	clear:both;
	width:100%;
	height:1px;
	background:#29b5b2;
	background:#66111f;
}
.hd_bar2{
	clear:both;
	width:100%;
	height:1px;
	background:#fff;
}
.hd_bar3{
	clear:both;
	width:100%;
	height:2px;
	background:#66111f;
}







/*** パンクズテキスト設定 ***/
.pan_txt1 a{
	font-size: 12px;
	line-height: 140%;
	color:#fff;
	font-family:"ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	text-align:right;
}
.pan_txt_cursor{
	font-size: 9px;
	line-height: 100%;
	color:#fff;
	font-family:"ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	text-align:right;
	margin:0 0 0 4px;
	position:relative;
	top:-2px;
	display:inline-block;
	transform: rotate(-90deg);
	-ms-transform: rotate(-90deg);
	-moz-transform: rotate(-90deg);
	-webkit-transform: rotate(-90deg);
	-o-transform: rotate(-90deg);
}






#nv_box{
	display:none;

}

#nv_box2{
	display:none;

}


/******************************************************
コンテンツ　タイトルPC
******************************************************/
.contents_title_bg{
	width:100%;
	height:70px;
}
.contents_title{
	width:100%;
	height:25px;
	font-size:22px;
	line-height: 110%;
	padding:30px 0 0;
}


/******************************************************
コンテンツ　サブタイトル
******************************************************/
.page_catchcopy{
	width:100%;
	height:auto;
	font-family:"ＭＳ Ｐ明朝", "MS PMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", serif;
	font-size:24px;
	line-height:200%;
	color:#222;
	text-align:center;
	margin:57px 0 0;
	letter-spacing:2px;
}

.page_readcopy{
	width:100%;
	height:auto;
	margin:0 auto;
	color:#222;
	font-size:15px;
	line-height:200%;
	font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	letter-spacing:2px;
	text-align: center;
	padding:40px 0 60px 0;
}


/******************************************************
コンテンツ　サブタイトル2
******************************************************/
.page_catchcopy2{

	font-size:20px;

}
.page_catchcopy2_space{
	height:30px;
}
.page_catchcopy2_space2{
	height:30px;
}



/******************************************************
コンテンツ　フッター上資料請求ボタン
ページ下バナーPC
******************************************************/
.ft_bnr_btn1{
	width:300px;
	height:60px;
	margin:0 auto;
	background:#881a1f;
	position:relative;
}

.ft_bnr_btn1 a{
	width: 100%;
	height: auto;
	font-size: 14px;
	line-height: 120%;
	color: #fff;
	text-align: center;
	font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	text-decoration: none;
	letter-spacing: 2px;
	font-weight: normal;
	position: absolute;
	top: 24px;
	left: 1px;
	right: 0;
	bottom: 0;
	margin: 0 auto;
	z-index: 999;
}
.ft_bnr_btn1 a span.ft_txt_cursor{
	width:15px;
	height:10px;
	font-size:13px;
	line-height:120%;
	color:#fff;
	text-align:right;
	font-family:"ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	text-decoration:none;
	letter-spacing:0;
	font-weight:normal;
	margin:0 0 0 4px;
	position:relative;
	top:2px;

	display:inline-block;
	transform: rotate(-90deg);
	-ms-transform: rotate(-90deg);
	-moz-transform: rotate(-90deg);
	-webkit-transform: rotate(-90deg);
	-o-transform: rotate(-90deg);
}







/******************************************************
ページ下バナー
******************************************************/
.btn_box{
	clear:both;
	width:100%;
	height:auto;
	margin:30px 0;
}
.btn_box img{
	width:100%;
	height:auto;
}


.btn_back {
	display:block;
	width:15%;
	height:auto;
	float:left;
}
.btn_back img {
	width:100%;
	height:auto;
}

.btn_next {
	display:block;
	width:15%;
	height:auto;
	float:right;
}
.btn_next img {
	width:100%;
	height:auto;
}



/******************************************************
キャプション
******************************************************/

.sp_width{
	width:98%;
	margin:0 auto;
}

.cap_right_pa_fff{
	font-family:"ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	font-size:11px;
	line-height:150%;
	color:#fff;
	text-align:right;

	position: absolute;
	bottom: 3px;
	right: 5px;
	text-shadow: 0 0 3px #000;
}
.cap_right_pa_000{
	font-family:"ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	font-size:11px;
	line-height:150%;
	color:#000;
	text-align:right;

	position: absolute;
	top: 102%;
	right: 8%;
/*	text-shadow: 0 0 3px #000;*/
}
.cap_right_pa_fff.to1{
	font-family:"ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	font-size:11px;
	line-height:150%;
	color:#fff;
	text-align:right;

	position: absolute;
	top: 3px;
	right: 5px;
	text-shadow:none;
}
.cap_right_pa_000.to2{
	font-family:"ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	font-size:11px;
	line-height:150%;
	color:#000;
	text-align:right;

	position: absolute;
	top: 101.5%;
	right: 0;
	text-shadow:none;
}


/******************************************************
改行
******************************************************/
.br_pc{
	display:block;
}

.br_none{
	display:none;

}

/************************************************
pcでは消す
************************************************/

@media (min-width:751px) {
.pc_on{
	display:block;
}
.sp-only{
	display:none;

}

.pc-only{
	display:block;
}

.smart_img{
	display:none;
}
}



/***

フッターナビ

***/
.footer_btn_bg{
	display: block;
	width: 92%;
	max-width: 980px;
  	height: auto;
	margin: 0 auto;
}



/***

フッターTEL

***/
.footer_tel{
	width: 92%;
	max-width: 776px;
  	height: auto;
	margin: 0 auto;
}

}





.ft_btn1{
	width: 22.222%;
	height: auto;
	margin: 0 3.704% 0 0;
	float: left;
  background: #B4B4B5;
  position: relative;
}
.ft_btn1.ft_req{background:#8A8358;}
.ft_btn1.ft_res{background:#894848;}
.ft_btn1:nth-child(4){
	width: 22.222%;
	height: auto;
	margin: 0;
	float: left;
}
.ft_btn1 img{
	width: 100%;
	height: auto;
}

.ft_btn1::after{
    content: '';
    display:block;
    width:100%;
    height: 100%;
    position: absolute;
    top:0;
    left:0;
    pointer-events: none;
    background: rgba(0,0,0,.3);
    opacity: 0;
    transition: opacity .4s;
  }

  .ft_btn1:hover::after{
    opacity: 1;
  }

  .ft_btn1.btn_off{
    pointer-events: none;
  }

  .ft_btn1.btn_off::after{
    background: rgba(0,0,0,.5);
    opacity: 1;
  }

@media print, screen and (min-width: 1001px) {
.ft_btn1{
	width: 180px;
	height: auto;
	margin: 0 30px 0 0;
	float: left;
}
.ft_btn1:nth-child(4){
	width: 180px;
	height: auto;
	margin: 0;
	float: left;
}
.ft_btn1 img{
	width: 100%;
	height: auto;
}
}













/* MENUボタン */
@media print, screen and (min-width: 751px) {
.menu_btn_box1{
	width:100%;
	max-width:960px;
	height:auto;
	margin:0 auto;
}
.menu_btn1{
	width:23.5%;
	height:auto;
	float:left;
	margin:0 2% 1.8% 0;
}
.menu_btn2{
	width:23.5%;
	height:auto;
	float:left;
	margin:0 2% 1.8% 0;
}
.menu_btn2.end{
	width:23.5%;
	height:auto;
	float:left;
	margin:0 0 1.8% 0;
}

.menu_btn1 img{
	width:100%;
	height:auto;
}
.menu_btn2 img{
	width:100%;
	height:auto;
}



.ft_req_btn{
	width:344px;
	height:auto;
	margin:60px auto 15px;
}


.menu_btn_txtbox2{
	width:100%;
	height:auto;
	position:absolute;
	top:41%;
	left:10px;
}
.menu_btn_txtbox2 span{
	color:#fff;
	text-align:left;
	line-height:150%;
	font-family: "ヒラギノ角ゴ Pro W6", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	letter-spacing:1px;
}
}








/***

グローバルナビPC

***/

.nv_new>a::before{
  content:'NEW';
	position: absolute;
	top: -17px;
	right: calc(50% - 15px );
	z-index: 100;
	padding: 2px 3px;
	background: #900;
	color: #fff;
	font-family: 'Noto Serif JP', "ＭＳ Ｐ明朝", "MS PMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", serif;
	font-size: 9px;
	font-size: 10px;
	line-height: 102%;
	font-weight: bold;
	letter-spacing: 1px;
  pointer-events: none;
}
.pc_gnv .nv_box.noLink a{
	pointer-events: none;
}
.pc_gnv .nv_box.noLink a img{
	opacity: .5;
}
.pc_gnv{
	clear: both;
	width: 100%;
	max-width: 980px;
	height: auto;
	margin: 40px auto 0;
	padding: 0;
  display:flex;
  justify-content: space-between;
  align-items: flex-end;
}
.pc_gnv img{
	width: 100%;
	height: auto;
}
.nv_box{
	position: relative;
	width: 11.12%;
	max-width: 108px;
	height: auto;
	margin: 0;
	padding: 0;
}
.nv_box img{
	width:100%;
	height: auto;
}
/* .nv_box>img{
  opacity: .5;
} */
.nv_box>a{
  display:block;
  position: relative;
}

.nv_box>a::after{
  content: '';
  width:0%;
  height: 4px;
  background: #000;
  position: absolute;
  bottom:0;
  left:50%;
  transition: .4s;
}

.container#index .nv_box:nth-child(1)>a::after,
.container#access .nv_box:nth-child(2)>a::after,
.container#location .nv_box:nth-child(3)>a::after,
.container#design .nv_box:nth-child(4)>a::after,
.container#plan .nv_box:nth-child(5)>a::after,
.container#excellent .nv_box:nth-child(6)>a::after,
.container#quality .nv_box:nth-child(7)>a::after,
.container#gallery .nv_box:nth-child(8)>a::after,
.nv_box>a:hover::after{
  width:100%;
  left:0%;
}

.nv_box .subnv{
  width:100%;
  position: absolute;
  left:0;
  top:100%;
  display:none;
}

.nv_box:hover .subnv{
  display:block;
}

.nv_box .subnv>li:not(:last-child){
  border-bottom:1px solid #FFF;
}

.nv_box .subnv a{
  display:block;
  background: #000;
}

.nv_box .subnv a:hover{
  background: #717071;
}
