@charset "utf-8";

/*
Theme Name: Olive Co.
Description: Olive Co. Original theme.
Theme URI: https://saitasaita.co.jp/
Author: Saita Corp.
Author URI: https://saitasaita.co.jp/
Description: Original Wordpress theme for Olive Co.
Version: 1.0.0
*/

@import url('https://fonts.googleapis.com/css2?family=Figtree:ital,wght@0,300..900;1,300..900&family=Noto+Sans+JP:wght@100..900&display=swap');


/*
.noto-sans-jp-<uniquifier> {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-weight: <weight>;
  font-style: normal;
}

.figtree-<uniquifier> {
  font-family: "Figtree", sans-serif;
  font-optical-sizing: auto;
  font-weight: <weight>;
  font-style: normal;
}
*/


li {
  list-style: none;
}
img {
  border: 0;
  -webkit-backface-visibility: hidden;
  width: 100%;
}
a {
color: #000;
  outline: none;
  text-decoration: none;
}
h1, h2, h3, h4, p,figure {
  margin: 0;
  padding: 0;
}
ul {
  margin: 0;
  padding: 0;
}
html {
 height:100%;
	overflow-y: scroll;
}

.orik {
  display: inline-block;
}
.clearfix:after {
  content: "";
  clear: both;
  display: block;
}
img {
  max-width: 100%;
  height: auto;
  image-rendering: -webkit-optimize-contrast;
}



body {
  margin: 0;
  padding: 0;
  color: #000;
  line-height: 180%;
  font-family: 'Figtree','Noto Sans JP', "游ゴシック", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", MS UI Gothic, Osaka, sans-serif;
  font-size: 15px;
  overflow-x: hidden;
  font-smoothing: antialiased;
  -webkit-font-smoothing: antialiased;
  font-weight: 400;
	position: relative;
	max-width: 100%;
}


/*----------------loading------------------*/
/*--最初に出すカバー---*/

#white {
width: 100vw;
height: 100vh;
background-color: #fff;
position: fixed;
left: 0;
top: 0;
z-index: 999999;
}


/*----LUXYプリンタ対応----*/
#luxy {position: fixed !important;}	
@media print {
#luxy {position: static !important;}	
}

/*----Ios初期化-----*/
input, textarea {
  box-sizing: border-box;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  -webkit-appearance: none;
  max-width: 100%;
}


/*----tel イベント-------------*/
a.tel {
  cursor: default;
  pointer-events: none;
  text-decoration: none;
}
@media screen and (max-width: 855px) {
  a.tel {
    pointer-events: auto;
  }
}


/*-----------------------------------------------------
ヘッダー
--------------------------------------------------------*/

.header {
  	width: 100%;
	height: 179px;
	box-sizing: border-box;
	margin: 0 auto;
	position: relative;
	padding: 22px 35px;	
}

/*--段組み---*/
.header .left {
  	float: left;
	margin: 33px 0 0 17px;
  	padding: 0;
  	width: 460px;
}
.header .right {
  float: right;
  width: calc(100% - 460px - 17px);
}

/*--left---*/

.header .left a {
	display: flex;
	align-items: center;
}

.header .left img {
	display: block;
	width: 253px;
	height: auto;
	float: left;
	margin-right: 18px;
}

.header .left h1,
.header .left h4 {
	font-size: 15px;
	font-weight: 400;
	margin: 30px 0 0 0;
}

.header .left span {display: inline-block;}

/*--right---*/

.header .right .sodan {
	width: auto;
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-end;
}

.header .right .sodan a {
	padding: 0 20px;
	line-height: 44px;
	border: 1px solid #000;
}

.header .right .sodan a.blk {
	font-size: 16px;
	font-weight: 500;
	background-color: #000;
	color: #fff;
	}


.header .right .sodan a.tlo {
	font-family: "Figtree", sans-serif;
	font-size: 22px;
	font-weight: 500;
	}


/*---gmenu-----*/

.header .right .gmenu {
	width: auto;
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-end; 
	margin: 30px 0 0 0;
}

.header .right .gmenu a {
	padding: 15px 25px;
	display: block;
	position: relative;
}

.header .right .gmenu a span {
	position: absolute;
	width: 0;
	height: 2px;
	background-color: #d6d6d6;
	transition: 0.5s;
	bottom: 0;
	left: 10px;
}

.header .right .gmenu a:hover span {
	width: calc(100% - 20px);
}

.header .right .gmenu a.current span {
	width: calc(100% - 20px);
	background-color: #333;
}


@media screen and (max-width: 1250px) {
.header .right .gmenu a {padding: 15px 15px;}
}
@media screen and (max-width: 1180px) {
.header .right .gmenu a {padding: 15px 10px; font-size: 14px;}
}
@media screen and (max-width: 1080px) {
.header .right .gmenu {display: none;}
	
.header {
  	width: 100%;
	height: auto;
	padding: 22px 35px;	
}
.header .left {	margin: 0;}	
.header .right .sodan {margin-right: 45px;}
}
@media screen and (max-width: 980px) {
.header .right .sodan a.blk,
.header .right .sodan a.tlo {width: 160px; text-align: center;}
}

@media screen and (max-width: 800px) {
	
.header {padding: 22px 20px;}
.header .right {display: none;}
.header .left h1,
.header .left h4 {
	position: absolute;
	text-align: right;
	bottom: 15px;
	right: 25px;
	margin: 0;
	z-index: 101;
	line-height: 140%;
	font-size: 14px;
}
.header .left h1 span,
.header .left h4 span {display: block;}
}

@media screen and (max-width: 520px) {
.header .left {	width: calc(100% - 160px - 20px);}
.header .left img {	width: 100%;}
.header .left h1,
.header .left h4 {line-height: 130%;font-size: 13px;}
}

@media screen and (max-width: 470px) {
.header {height: 130px;}
.header .left a img {
	position: absolute; 
	bottom: 15px; 
	left: 20px;
	width: calc(100% - 220px);
	}	
}

@media screen and (max-width: 410px) {
.header {padding: 20px 15px 10px 15px;}
.header .left h1,
.header .left h4 {display: none;
}	
	
.header .left {width: calc(100% - 100px);}
.header {height: auto;}
.header .left a img {
	position: static; 
	width: 100%;
	}	
}


/*-----------------------------------------------------
フッタ
--------------------------------------------------------*/

.footer {
  	width: 100%;
	box-sizing: border-box;
	margin: 0 auto;
	padding: 40px 35px;	
}

/*--段組み---*/
.footer .left {
  	float: left;
	margin: 0 0 0 17px;
  	padding: 0;
  	width: calc(100% - 400px - 17px);
}
.footer .right {
  float: right;
  width: 400px;
}

/*--left---*/

.footer .left img {
	display: block;
	width: 60%;
	max-width: 253px;
	height: auto;
	float: left;
	margin-right: 20px;
}

.footer .left .txt {
	width: calc(100% - 253px - 20px);
	float: right;
}

.footer .left h1,
.footer .left h4 {
	font-size: 15px;
	font-weight: 400;
	margin: 0;
}

.footer .left .txt span {display: block;}

/*--right---*/

.footer .right .sodan {
	width: auto;
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-end;
}

.footer .right .sodan a {
	padding: 0 20px;
	line-height: 44px;
	border: 1px solid #000;
}

.footer .right .sodan a.blk {
	font-size: 16px;
	font-weight: 500;
	background-color: #000;
	color: #fff;
	}


.footer .right .sodan a.tlo {
	font-family: "Figtree", sans-serif;
	font-size: 22px;
	font-weight: 500;
	}

@media screen and (max-width: 1040px) {
.footer .left img {float: none;}
.footer .left .txt {width: 100%;float: none;margin-top: 30px;}	
}
@media screen and (max-width: 800px) {
.footer {padding: 0 0 40px 0;}
.footer .left {float: none;margin: 0;width: 100%; padding: 40px 40px 0 40px; box-sizing: border-box;}
.footer .right {float: none;margin: 0;width: 100%;}

.footer .right .sodan {
	width: 100%;
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-start;
	border-top: 1px solid #000;
	border-bottom: 1px solid #000;
}
.footer .right .sodan a {
	padding: 0 20px;
	line-height: 44px;
	border: none;
}
}

#cpr {
	padding: 0 50px 35px 50px;
	font-size: 14px;
	color: #292929;
}


@media screen and (max-width: 500px) {
.footer .left img {margin: 0 auto;}
.footer .left {padding: 40px 20px 0 20px; text-align: center;}	
#cpr {padding: 0 20px 35px 20px;text-align: center;}
.footer .right .sodan a.blk,
.footer .right .sodan a.tlo {width: 50%; box-sizing: border-box;text-align: center;}
}
@media screen and (max-width: 380px) {
.footer .right .sodan a.blk{font-size: 14px;}
.footer .right .sodan a.tlo {font-size: 16px;}
}

@media screen and (max-width: 344px) {
.footer .right .sodan a.blk,
.footer .right .sodan a.tlo {width: 100%;}
}


/*--------------------------------------------------------
ハンバーガーメニュー
----------------------------------------------------------*/
#nav-drawer {display: none}
@media screen and (max-width: 1080px) {


#nav-drawer {display: block; top: 20px;}	

/*----------ハンバーガー-----------*/
/*Media Queries*/

#nav-drawer {
  display: block;
  z-index: 100;
  width: 80px;
  height: 80px;
  position: fixed;
  top: 0;
  right: 0;
}
	
}
/*チェックボックス等は非表示に*/
#nav-drawer .nav-unshown {
  display: none;
}
/*アイコンのスペースハンバーガー*/
#nav-open {
  display: inline-block;
  width: 80px;
  height: 80px;
  box-sizing: border-box;
  line-height: 40px;
  position: fixed;
  text-align: left;
  padding: 0;
  right: 0;
  top: 0;
  cursor: pointer;
  z-index: 100;
	background-color: #fff;
/*	border-radius: 50%;*/
	transition: 0.5s;
}

/*ハンバーガー*/
#nav-open:hover {background-color: #fff;}

#nav-open span {
  display: block;
  transition: all .2s;
  box-sizing: border-box;
}
#nav-open span {
  position: absolute;
  width: 32px;
  height: 1px;
	border-bottom: 2px solid #333;
  background-color: transparent;
	left:20px;
}
#nav-open span:nth-of-type(1) {top: 34px;}
#nav-open span:nth-of-type(2) {top: 44px;}

#nav-input:checked ~ #nav-open span:nth-of-type(1) {
  -webkit-transform: translateX(0px) translateY(10px) rotate(-45deg);
  transform: translateX(0px) translateY(10px) rotate(-45deg);
	border-bottom: 2px solid #fff;
}

#nav-input:checked ~ #nav-open span:nth-of-type(2) {
  -webkit-transform: translateX(0px) translateY(0px) rotate(45deg);
  transform: translateX(0px) translateY(0px) rotate(45deg);
	border-bottom: 2px solid #fff;
}
#nav-input:checked ~ #nav-open {
background-color: #333;
}

/*閉じる用の薄黒カバー*/
#nav-close {
  display: none; /*はじめは隠しておく*/
  position: fixed;
  z-index: 2;
  top: 0; /*全体に広がるように*/
  left: 0;
  width: 100%;
  height: 100%;
  /*background-color: rgba(0,0,0,0.3);*/
}

/*中身*/
#nav-content {
  overflow: auto;
  position: fixed;
  top: 0;
  right: 0;
  z-index: 99; /*最前面に*/
  width: 100%; /*右側に隙間を作る（閉じるカバーを表示）*/
  max-width: 480px; /*最大幅（調整してください）*/
  height: 100%;
  transition: 0.3s ease-in-out; /*滑らかに表示*/
  -webkit-transform: translateX(105vw);
  transform: translateX(105vw); /*左に隠しておく*/
  box-sizing: border-box;
  text-align: left;
/*  background-color: #b6d0d5;*/
background-color: #333;
}

/*チェックが入ったらもろもろ表示*/
#nav-input:checked ~ #nav-close {
  display: block; /*カバーを表示*/
}
#nav-input:checked ~ #nav-content {
  -webkit-transform: translateX(calc(100vw - 100vw));
  transform: translateX(calc(100vw - 100vw));
}
@media screen and (max-width: 650px) {

#nav-drawer {
/*  right: 20px;*/
}
}
/*------PC版・スマホ版共通　ハンバーガーの中身----------*/
#nav-content {
  text-align: left;
  box-sizing: border-box;
/*  padding-top: 10vw;*/
}

#nav-content .inner {
	padding: 80px 40px 40px 40px;
}

#nav-content .inner h3 {
	font-size: 15px;
	color: #8fc655;
	line-height: 160%;
	margin: 20px 0 10px 0;
	font-weight: 400;
}



#nav-content .inner a {
	display: block;
	color: #fff;
	padding: 10px 0px;
	font-size: 15px;
	margin: 10px 0;
	transition: 0.5s;
	position: relative;
	border-bottom: 1px solid rgba(255,255,255,0.3);
}

#nav-content .inner a.slc {background-color: #000;}

#nav-content .inner a.sm {
	display: block;
	color: #fff;
	padding: 5px 0px;
	font-size: 15px;
	margin: 5px 0;
	transition: 0.5s;
	border-bottom: none;
}

#nav-content .inner a.sm::before {
	content: "-　";
}


/*------------------------------------------
トップページスライダー
-----------------------------------------*/

#slide01 .slick-list {padding: 0 20% 0 0 !important;}
#slide01 .slick-slide {margin-right: 10px;}
#slide01 .slick-list img {
	height: calc(100vh - 179px - 60px);
  	width: 100%;
	object-fit: cover;
}

@media screen and (max-width: 1020px) {	
#slide01 .slick-list { padding: 0 !important;}
}


@media screen and (max-width: 650px) {
#slide01 .slick-list img {height: 90vw;}
}


/*----スライド↓コピー-------------------*/

.dgm {
	position: relative;
	margin: 0 40px;
	width: calc(100% - 80px);
	padding: 70px 0px 0 0px;
	box-sizing: border-box;
}

.dgm .txt {
	position: absolute;
	top: -1vw;
	left: 0;	
	display: flex;
	align-items: baseline;
	column-gap: 20px;
}
.dgm h4 {
	font-family: "Figtree", sans-serif;
	font-size: 7.5vw;
	font-weight: 300;
	white-space: nowrap;
}

.dgm p.cp {
	font-family: "Figtree", sans-serif;
	font-size: 2vw;
	font-weight: 300;
	white-space: nowrap;
}

.dgm p.bg {
	font-size: 31px;
	font-weight: 400;
	margin: 0;
	padding: 0;
}

.dgm p.bg span {display: inline-block;}
.dgm p.cp.sm {display: none;}

@media screen and (max-width: 1280px) {
.dgm {padding: 50px 0px 0 0px;}

.dgm h4 {font-size: 100px; display: inline-block;}
.dgm p.cp.pc {display: none;}
	
.dgm p.cp.sm,
.dgm p.bg {
	font-size: 27px; 
	display: block;
	margin: 0 40px;
	}
	
.dgm p.cp.sm {font-size: 18px; margin-bottom: 10px;}

.dgm {
  margin     : auto;
  width      : 100%;
  text-align : left;
  color      : #000000;
}
.dgm .txt {
  display     : inline-block;
  padding-left: 100%;
  white-space : nowrap;
  line-height : 1em;
  animation   : scrollAnime 10s linear infinite;
}
}

@keyframes scrollAnime{
    0% { transform: translateX(0)}
  100% { transform: translateX(-100%)}
}	

	
@media screen and (max-width: 670px) {
.dgm p.cp.sm,
.dgm p.bg {margin: 0 30px;}	
}
	
@media screen and (max-width: 500px) {
.dgm p.bg {
	font-size: 24px; 
	}
}
	
@media screen and (max-width: 450px) {
.dgm p.bg {font-size: 20px; }
	}
@media screen and (max-width: 380px) {
.dgm p.bg {font-size: 18px; }
}
	
	
	
/*------------------------------------------
トップページ・ニューススライダー
-----------------------------------------*/

#pick {
	padding: 40px 0 40px 40px;
	width: 100%;
	box-sizing: border-box;
	position: relative;
}	
	
#pick p.ttl {
	font-family: "Figtree", sans-serif;
	font-size: 16px;
	font-weight: 700;
	margin-bottom: 20px;
}
	

#slide02 .slick-slide {
	margin-right: 3vw;
}

#slide02 .slick-list figure {
	height: 50vw;
	max-height: 228px;
	width: 100%;
	position: relative;
}

#slide02 .slick-list img {
	height: 100%;
  	width: 100%;
	object-fit: cover;
}

/*--日付---*/
#slide02 .slick-list figure p.dt {
	bottom: 0;
	left: 0;
	position: absolute;
	background-color: #fff;
	padding: 0 10px;
	display: inline-block;
	font-size: 13px;
}
/*--ターム---*/
#slide02 .slick-list figure p.pn,
.catdate p.pn,
.edi p.pn,
#newsacv .inner .box p.pn {
	top: 0;
	right: 0;
	position: absolute;
	background-color: #000;
	color: #fff;
	padding: 3px 10px;
	display: inline-block;
	font-size: 14px;
	min-width: 88px;
	box-sizing: border-box;
	text-align: right;
}

#slide02 .slick-list figure p.pn.works,
.catdate p.pn.works {background-color: #8fc655;}
#slide02 .slick-list figure p.pn.service,
.catdate p.pn.service {background-color: #1b4395;}
#slide02 .slick-list figure p.pn.news,
.catdate p.pn.news,
.edi p.pn.news,
#newsacv .inner .box p.pn.news {background-color: #ffb400;}

#slide02 .slick-list .txt {padding: 8px 10px;}
#slide02 .slick-list .txt h4 {
	font-weight: 500;
	line-height: 160%;
	margin: 10px 0;
	padding: 0;
	font-size: 16px;
}
#slide02 .slick-list .txt p {
	font-size: 14px;
	line-height: 160%;
}


button.slick-prev.slick-arrow[aria-disabled="true"] {display: none !important;}


button.slick-next.slick-arrow,
button.slick-prev.slick-arrow {
	position: absolute;
	top: calc(50% - 50px);
	border: none;
	background-color: #fff;
	box-shadow: 0 0 10px 0px rgba(0,0,0,0.3);
	cursor: pointer;
	width: 50px;
	height: 50px;
	border-radius: 50%;
	overflow: hidden;
	transition: 0.5s;
}
button.slick-next.slick-arrow {right: 20px;}
button.slick-prev.slick-arrow {left: 20px; z-index: 99;}


button.slick-next.slick-arrow:hover,
button.slick-prev.slick-arrow:hover {background-color: #666; color: #fff;}

button.slick-next.slick-arrow::before,
button.slick-prev.slick-arrow::before {
	font-size: 20px;
	font-weight: 900;
	padding: 0 30px 0 12px;
	position: relative;
	top: -2px;
}

button.slick-next.slick-arrow::before {content:"→"; }
button.slick-prev.slick-arrow::before {content:"←"; }

@media screen and (max-width: 670px) {
#pick {padding: 40px 0 30px 30px;}
button.slick-next.slick-arrow,
button.slick-prev.slick-arrow {display: none !important;}
}
	
	
	
/*----------------------------------------
コンセプト
--------------------------------------------*/
.concept {
	background-color: #453837;
	width: calc(100% - 57px);
	margin-right: 57px;
	border-radius: 0 20px 20px 0;
	color: #fff;
	padding: 109px 20px;
	box-sizing: border-box;
}

.concept .inner {
	display: flex;
	align-items: center;
	justify-content: center;
	padding-left: 57px;
	column-gap: 68px;
}

.concept .inner h2 {
	font-size: 49px;
	line-height: 140%;
}

.concept .inner p {
	font-size: 17px;
	line-height: 200%;
}

.concept .inner p span {display: inline-block;}
	
@media screen and (max-width: 1080px) {	

.concept {width: calc(100% - 30px);	margin-right: 30px;}
.concept .inner {padding-left: 30px;}
}	

@media screen and (max-width: 1010px) {	
.concept .inner {column-gap: 30px;}	
}

@media screen and (max-width: 925px) {
.concept {padding: 60px 20px;}
.concept .inner {display: block;}
.concept .inner h2 {margin-bottom: 30px;}
}

@media screen and (max-width: 600px) {	
.concept .inner {padding-left: 5px;}
.concept .inner h2 {font-size: 30px;}
}

@media screen and (max-width: 500px) {	
.concept {width: calc(100% - 10px);	margin-right:10px;}
}	

@media screen and (max-width: 370px) {	
.concept .inner p {font-size: 15px;}
}

/*---トップサービス・施工事例---*/

.s-w {
	max-width: 1288px;
	margin: 0 auto;
	padding: 0 30px;
}

/*-タイトル部--*/
.s-w p.bttl {
	font-size: 34px;
	font-weight: 300;
	margin: 50px 20px;
}

.s-w p.bttl span {
	margin-left: 15px;
	font-size: 16px;
	font-weight: 500;
}

@media screen and (max-width: 553px) {
	
.s-w p.bttl {text-align: center;}
.s-w p.bttl span {
	margin: 15px 0 0 0;
	display: block;
}
}


/*--はこ---*/
.s-w .inner {
	display: flex;
	justify-content: space-between;
	margin-bottom: 63px;
	flex-wrap: wrap;
}

.s-w .inner a.side {
	display: block;
	width: 45%;
	border-radius:20px 0 0 0 ;
	overflow: hidden;
}

.s-w .inner a.side img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: 0.5s;
}

.s-w .inner a.side img:hover {
	transform: scale(1.1);
}

/*--→右--*/

.s-w .inner .txt {
	border-top: 1px solid #000;
	position: relative;
	width: 50%;
}

.s-w .inner .txt hr {
	border: none;
	background-color: transparent;
	margin: 0;
	width: 194px;
	height: 1px;
	border-bottom:4px solid #000;
	position: absolute;
	left: 0;
	top: -2px;
}

.s-w .inner .txt h3 {
	font-size: 30px;
	margin: 60px 0 40px 0;
	font-weight: 600;
}

.s-w .inner .txt p {
	font-size: 17px;
	margin: 0 0 30px 0;
	line-height: 220%;
}

.s-w .inner .txt p span {display: inline-block;}

.s-w .inner .txt a.btn {
	font-size: 30px;
	font-weight: 300;
	position: relative;
	line-height: 89px;
	padding: 0 110px 0 0;
	float: right;
}

.s-w .inner .txt a.btn::after {
	content: "→";
	border: 1px solid #d6d6d6;
	width: 89px;
	height: 89px;
	border-radius: 50%;
	position: absolute;
	right: 0;
	top: 0px;
	transition: 0.5s;
	text-align: center;
}

.s-w .inner .txt a.btn:hover {text-indent: 20px;}

@media screen and (max-width: 925px) {
.s-w .inner .txt h3 {font-size: 26px;}
.s-w .inner .txt p {font-size: 15px;}	
}

@media screen and (max-width: 780px) {	
.s-w .inner a.side,
.s-w .inner .txt {width: 100%;}
.s-w .inner .txt {
	margin-top: 20px;
	padding: 0 5px; 
	box-sizing: border-box;
}
.s-w .inner .txt h3 {
	margin: 40px 0 20px 0;
}
.s-w .inner .txt p {
	margin: 0 0 20px 0;
	line-height: 200%;
}
}

@media screen and (max-width: 487px) {
.s-w .inner .txt a.btn {
	font-size: 26px;
	line-height: 50px;
	padding: 0 70px 0 0;
	float: right;
}
.s-w .inner .txt a.btn::after {
	width: 50px;
	height: 50px;
	font-size: 20px;
}
.s-w .inner .txt a.btn:hover {text-indent: 20px;}	
}

@media screen and (max-width: 433px) {
.s-w .inner .txt h3 {font-size: 22px;}
}


/*---トップサービス・施工事例---*/

.swgray {
	background-color: #e1e0e0;
	padding: 50px 30px;
	width: 100%;
	box-sizing: border-box;
}

.swgray .inner1 {
	max-width: 1288px;
	margin: 0 auto;
	display: flex;
	column-gap: 47px;
	justify-content: flex-start;
	flex-wrap: wrap;
	margin-bottom: 50px;
}

.swgray .inner1 .box {
	width: calc((100% - ( 47px * 3 ))/4);
	background-color: #fff;
	border-radius: 20px 0 0 0;
	overflow: hidden;
	margin-bottom: 40px;
}

.swgray .inner1 .box a {display: block;}

.swgray .inner1 .box figure {
	width: 100%;
	height: 15vw;
	max-height: 200px;
	overflow: hidden;
}

.swgray .inner1 .box figure img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.swgray .inner1 .box p {
	padding: 5px 10px;
}

@media screen and (max-width: 1120px) {
.swgray .inner1 {column-gap: 30px;}
.swgray .inner1 .box {width: calc((100% - ( 30px * 3 ))/4);}	
}

@media screen and (max-width: 760px) {
.swgray .inner1 .box {
	width: calc((100% - 30px)/2);
	margin-bottom: 20px;
}	
.swgray .inner1 .box figure {height: 30vw;}
}

@media screen and (max-width: 500px) {
.swgray {padding: 30px 20px;}
.swgray .inner1 {column-gap: 20px;}
.swgray .inner1 .box {width: calc((100% - 20px)/2);}	
}

/*--カテゴリ別一覧---*/

.swgray .inner2 {
	max-width: 1288px;
	margin: 20px auto 40px auto;
	display: flex;
	column-gap: 47px;
	justify-content: space-between;
	flex-wrap: wrap;
	align-items: flex-start;
}

.swgray .inner2 .box {
	width: calc((100% - 47px) / 2);
	display: flex;
}

.swgray .inner2 .box h5 {
	font-size: 34px;
	font-weight: 300;
	line-height: 100%;
	margin: 0;
	padding: 0 30px 0 0;
	height: 100%;
}



.swgray .inner2 .box .list {
	padding: 0 30px;
	border-left: 1px solid #666;
}

.swgray .inner2 .box .list a {
	display: block;
	margin: 0 0 5px 0;
	transition: 0.5s;
}

.swgray .inner2 .box .list a:hover {
	color: #666;
}

@media screen and (max-width: 1050px) {
.swgray .inner2 {
	justify-content: center;
	column-gap: 30px;
}	
.swgray .inner2 .box {
	flex-wrap: wrap;
	width: calc((100% - 30px) / 2);
}

.swgray .inner2 .box h5 {
	width: 100%;
	box-sizing: border-box;
	padding: 0 0 20px 0;
}
	
.swgray .inner2 .box .list {padding: 0 0 0 30px;}
}

@media screen and (max-width: 730px) {
.swgray .inner2 {
	column-gap: 0;
	padding: 0 30px;
}	
.swgray .inner2 .box {
	width: 100%;
}
.swgray .inner2 .box:first-child {margin-bottom: 30px;}
}

@media screen and (max-width: 500px) {
.swgray .inner2 {
	padding: 0 20px;
}	
}


/*------------------------------------------
会社概要
-----------------------------------------*/

#comp_vs {
	width: calc(100% - 60px);
	margin: 20px auto 0 auto;
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
	border-radius: 15px;
	overflow: hidden;
	height: calc(100vh - 250px);
	max-width: 1600px;
}

#comp_vs img {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	z-index: 0;
}

#comp_vs .fil {
	width: 100%;
	height: 100%;
	background-color: rgba(0,0,0,0.4);
	position: absolute;
	left: 0;
	top:0;
	z-index: 1;
}

#comp_vs div {
	z-index: 2;
	position: relative;
	color: #fff;
	text-align: center;
}

#comp_vs h1 {
	font-size: 70px;
	font-weight: 600;
	margin: 0 0 60px 0;
	text-indent: 0.5em;
}

#comp_vs p {
	font-size: 38px;
	font-weight: 400;
	margin: 0;
	letter-spacing: 0.5vw;
}

@media screen and (max-width: 882px) {
	
#comp_vs h1 {font-size: 9vw;margin: 0 0 7vw 0;}
#comp_vs p {font-size: 30px;}	
}

@media screen and (max-width: 500px) {
	
#comp_vs {
	width: calc(100% - 20px);
	margin: 20px auto 0 auto;
	height: 80vw;
}
	
#comp_vs h1 {
	font-size: 9vw;
	margin: 0 0 4vw 0;
}

#comp_vs p {font-size: 20px;}	
}

/*--どんなときも---*/

#don {
	width: 100%;
	display: flex;
	justify-content: center;
	align-items: center;
	padding: 126px 30px 83px 30px;
	position: relative;
	box-sizing: border-box;
}

#don .txt {
	width: auto;
	max-width: 700px;
	text-align: left;
}

#don .txt h3 {
	font-size: 60px;
	margin: 0 0 50px 0;
}

#don .txt p {
	font-size: 16px;
	line-height: 180%;
}

#don .txt p.kj {
	font-size: 17px;
	line-height: 250%;
	margin: 40px 0;
	font-weight: 500;
}

#don p.nen {
	position: absolute;
	left: calc(50% - 600px);
	top: -80px;
	z-index: 3;
	font-size: 292px;
	color: #b6b6b6;
	font-weight: 700;
	line-height: 100%;
}

@media screen and (max-width: 1220px) {
	
#don p.nen {
	left: calc(50% - 500px);
	font-size: 230px;
}	
}


@media screen and (max-width: 1030px) {
	
#don p.nen {
	left: 50px;
	top: -100px;
	font-size: 200px;
}	
}

@media screen and (max-width: 500px) {
	
#don {padding-bottom: 40px;}	
#don p.nen {left: 20px; top: -80px;}	
#don .txt h3 {font-size: 40px;}
}
@media screen and (max-width: 355px) {
	
#don .txt h3 {font-size: 36px;margin: 0 0 40px 0;}
}
	
/*---インスタ-----*/
.instaif {
	width: 100%;
	height: 25vw;
	padding: 0 20px;
	box-sizing: border-box;
	overflow: hidden;
	scroll-y:none;
}

@media screen and (max-width: 1539px) {
.instaif {height: 37vw;}
}
@media screen and (max-width: 939px) {
.instaif {height: 70vw;}
}


/*---ロゴと由来部----*/

#ry {
	margin: 50px auto;
	width: 100%;
	max-width: 810px;
	padding: 0 30px;
	display: flex;
	align-items: center;
	justify-content: center;
	box-sizing: border-box;
}

#ry img {
	display: block;
	width: 40%;
	height: auto;
}

#ry p {
	padding-left: 30px;
}

@media screen and (max-width: 770px) {
	
#ry {flex-wrap: wrap; max-width: 500px}	
#ry img {width: 80%; margin: 0 auto;}
#ry p { padding: 30px 0 0 0;}

}
@media screen and (max-width: 459px) {
#ry {padding: 0 20px;}	
}


/*---会社概要----------*/

#coal {
	margin: 0 auto 50px auto;
	width: 100%;
	max-width: 700px;
	padding: 0 20px;
	box-sizing: border-box;
}

#coal .tbl {
	display: flex;
	border-top: 1px solid #666;
	align-items: flex-start;
	flex-wrap: wrap;
}

#coal .tbl p:nth-child(1) {
	width: 150px;
	padding: 20px 10px;
	box-sizing: border-box;
}

#coal .tbl p:nth-child(2) {
	width: calc(100% - 150px);
	padding: 20px 10px;
	box-sizing: border-box;
}

@media screen and (max-width: 500px) {
	
#coal .tbl p:nth-child(1) {
	width: 100%;
	padding: 20px 10px 0 10px;
}

#coal .tbl p:nth-child(2) {
	width: 100%;
	padding: 20px 10px;
	box-sizing: border-box;
}	
}


/*---------------------------------------------
サービス・施工事例
---------------------------------------------*/
#sv .gray {
	width: 100%;
	padding: 0 30px;
	background: linear-gradient(to bottom, #fff 6%, #e7e6e2 6%, #e7e6e2 90%, #fff 90%);
	margin: 30px 0;
	box-sizing: border-box;
}

#sv .gray .inner {
	max-width: 1211px;
	margin: 0 auto 50px auto;;
	position: relative;
	box-sizing: border-box;
}

#sv .gray .inner:nth-child(even) {text-align: right;}

#sv .gray .inner a figure {
	display: inline-block;
	width: 62%;
	height: auto;
	z-index: 0;
	margin: 0 0 70px 0;
	overflow: hidden;
}

#sv .gray .inner a img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: 0.5s;
}

#sv .gray .inner a:hover img {
	transform: scale(1.1);
}

#sv .gray .inner .txt {
	position: absolute;
	bottom: 0;
	right: 0px;
	z-index: 1;
	background-color: #fff;
	padding: 62px 53px;
	margin-top: 163px;
	max-width: 530px;
	box-sizing: border-box;
	text-align: left;
}

#sv .gray .inner:nth-child(even) .txt {right: inherit; left: 0px;}

#sv .gray .inner .txt h2 {
	font-size: 23px;
	font-weight: 600;
	margin: 0 0 20px;
}

#sv .gray .inner .txt p {
	font-size: 16px;
	line-height: 180%;
	margin-bottom: 20px;
}

#sv .gray .inner .txt p.kj {
	font-size: 14px;
	margin: 0 0 20px 0;
	padding: 0 5px;	
}

#sv .gray .inner .txt a.btn {
}

#sv .gray .inner .txt a.btn img {
	width: 22px;
	height: auto;
	margin: 0 8px 0 0;
}

@media screen and (max-width: 1169px) {
#sv .gray .inner .txt {
	padding: 40px 45px;
	max-width: 50%;
}	
}

@media screen and (max-width: 1020px) {
#sv .gray .inner a figure {
	width: 100%;
	margin: 0;
}	
#sv .gray .inner .txt {
	position: static;
	padding: 40px 45px;
	margin-top: 0;
	max-width: inherit;
}
}

@media screen and (max-width: 550px) {
#sv .gray {padding: 0 20px;	background: none; margin-bottom: 0;}
#sv .gray .inner .txt h2 {font-size: 18px;}
#sv .gray .inner .txt {	padding: 20px 10px;}	
}

/*--サブ---------*/

.inner_sub {
	max-width: 1360px;
	margin: 0 auto;
	display: flex;
	flex-wrap: wrap;
}

.inner_sub .box {
	width: calc(100% / 3);
	padding: 0 32px 5px 32px;
	box-sizing: border-box;
	border-right: 1px solid #666;
	margin-bottom: 60px;
}

.inner_sub .box figure {
	overflow: hidden;
	width: 100%;
	height: 20vw;
	max-height: 280px;
}

.inner_sub .box figure img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: 0.5s;
}

.inner_sub .box figure img:hover {transform: scale(1.1);}

.inner_sub .box:nth-of-type(3n) {border-right: none;}

.inner_sub .box .txt {padding: 10px;}
.inner_sub .box h3 {
	font-size: 18px;
	font-weight: 600;
	margin: 15px 0;
}

.inner_sub .box p {
	font-size: 16px;
	line-height: 180%;
	margin-bottom: 20px;
}

.inner_sub .box p.kj {
	font-size: 14px;
	margin: 0 0 20px 0;
	padding: 0 5px;	
}

.inner_sub .box a.btn {
}

.inner_sub .box a.btn img {
	width: 22px;
	height: auto;
	margin: 0 8px 0 0;
}


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

.inner_sub .box {
	width: calc(100% / 2);
	padding: 0 32px 5px 32px;
	box-sizing: border-box;
	border-right: 1px solid #666;
	margin-bottom: 60px;
}
.inner_sub .box:nth-of-type(2n) {border-right: none;}
.inner_sub .box:nth-of-type(3n) {border-right: 1px solid #666;}

.inner_sub .box figure {
	height: 28vw;
	max-height: inherit;
}
}

@media screen and (max-width: 710px) {
.inner_sub .box:nth-of-type(2n) {border-right: 1px solid #666;}
.inner_sub .box:nth-of-type(3n) {border-right: 1px solid #666;}
.inner_sub .box {
	width: 100%;
	padding: 10px 10px;
	border-right: none;
	border: 1px solid #666;
	margin: 15px 30px;
}

.inner_sub .box figure {height: 70vw;}
}


/*---WORKS 住まいづくりの実例集-------*/

.jitsurei {
	background-color: #e7e6e2;
	padding: 0 0 100px 0;
}

.jitsurei .inner {
	display: flex;
	max-width: 1112px;
	padding: 0 30px;
	box-sizing: border-box;
	column-gap: 60px;
	margin: 30px auto 0 auto;
}

.jitsurei .inner .box {
	width: calc((100% - 120px)/3)
}

.jitsurei .inner .box figure {
	overflow: hidden;
	width: 100%;
	height: 30vw;
	max-height: 370px;
	position: relative;
}

.jitsurei .inner .box figure p {
	position: absolute;
	width: 33px;
	height: 31px;
	line-height: 31px;
	background-color: #000;
	color: #fff;
	font-size: 16px;
	right: 0;
	bottom: 0;
	margin: 0;
	text-align: center;
}

.jitsurei .inner .box figure img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: 0.5s;
}

.jitsurei .inner .box figure img:hover {transform: scale(1.1);}


.jitsurei .inner .box .txt {padding: 10px;}
.jitsurei .inner .box h3 {
	font-size: 18px;
	font-weight: 600;
	margin: 15px 0;
}

.jitsurei .inner .box p {
	font-size: 16px;
	line-height: 180%;
	margin-bottom: 20px;
}

.jitsurei .inner .box p.kj {
	font-size: 14px;
	margin: 0 0 20px 0;
	padding: 0 5px;	
}

.jitsurei .inner .box a.btn {
}

.jitsurei .inner .box a.btn img {
	width: 22px;
	height: auto;
	margin: 0 8px 0 0;
}

@media screen and (max-width: 1000px) {
	
.jitsurei .inner {
	padding: 0 30px;
	column-gap: 30px;
}

.jitsurei .inner .box {
	width: calc((100% - 60px)/3)
}	
}

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

.jitsurei .inner {
	padding: 0 30px;
	column-gap: 0px;
	flex-wrap: wrap;
}
.jitsurei .inner .box {
	width: 100%;
	position: relative;
	border-top: 1px solid #666;
}	
	
.jitsurei .inner .box figure {
	width: 40%;
	height: 35vw;
	float: right;
	margin: 0 0 5px 10px;
}
	
.jitsurei .inner .box .txt {padding: 10px 0 15px 0;}
}

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

.jitsurei .inner {
	padding: 0 20px;
}
	
.jitsurei .inner .box h3 {
	font-size: 16px;
	margin: 5px 0;
}

.jitsurei .inner .box p {
	font-size: 15px;
	line-height: 180%;
	margin-bottom: 20px;
}	
}

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

.jitsurei .inner {
	padding: 0 30px;
	column-gap: 0px;
	flex-wrap: wrap;
}
.jitsurei .inner .box {
	width: 100%;
	position: relative;
	border-top: 1px solid #666;
}	
	
.jitsurei .inner .box figure {
	width: 35%;
	height: 30vw;
	float: right;
	margin: 0 0 5px 10px;
}
	
.jitsurei .inner .box .txt {padding: 10px 0 15px 0;}
}

/*---------------------------------------------
サービス・施工事例（詳細ページ）
----------------------------------------------*/

/*--詳細のメイン部分（画像からボディコピーまで）---*/
#svmv {
	position: relative;
	text-align: center;
}

#svmv figure {
	width: 100%;
	height: calc(100vh - 170px);
	position: relative;
	z-index: 0;
}

#svmv figure img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

#svmv p.pkz {}
#svmv p.pkz {
	font-size: 13px;
	background-color: #fff;
	padding: 10px 20px;
	color: #9acc66;
	text-align: left;
}

#svmv p.pkz.gon {
	display: inline-block;
	position: absolute;
	left: 0;
	top: 0;
	z-index: 1;
}

#svmv p.pkz a,
#svmv p.pkz strong {color: #000; padding: 0 5px; font-weight: normal;}

#svmv p.ttl {
	font-size: 18px;
	text-align: center;
	color: #8dc552;
	margin: 58px 0 32px 0;
}

#svmv h1 {
	font-size: 44px;
	margin: 0 0 54px 0;
	font-weight: 600;
	padding: 0 30px;
	line-height: 120%;
}

#svmv p.htxt {
	text-align: left;
	display: inline-block;
	max-width: 654px;
	padding: 0 30px 54px 30px;
	font-size: 17px;
	line-height: 180%;
}

@media screen and (max-width: 900px) {
#svmv figure {
	width: 100%;
	height: 50vh;
	position: relative;
	z-index: 0;
}
}

@media screen and (max-width: 660px) {
#svmv h1 {
	font-size: 30px;
	margin: 0 0 30px 0;
}	
}

/*--6つの特長-------------------*/

#tk6 {background-color: #453837;margin-bottom: 40px;}

#tk6 img.main {
	width: 100%;
	height: 40vw;
	max-height: 598px;
	object-fit: cover;
}

#tk6 h2 {
	text-align: center;
	position: relative;
	top: -50px;
}
#tk6 h2 span {
	display: inline-block;
	padding: 20px 60px 1px 60px;
	font-size: 23px;
	line-height: 30px;
	background-color: #453837;
	color: #fff;
	font-weight: 500;
}

#tk6 .inner {
	max-width: 1319px;
	display: flex;
	flex-wrap: wrap;
	column-gap: 55px;
	margin: 0 auto;
	color: #fff;
	padding: 30px 30px;
	box-sizing: border-box;
	justify-content: center;
}

#tk6 .inner .box {
	width: calc((100% - 110px)/3);
	margin-bottom: 50px;
}

#tk6 .inner .box h4 {
	font-size: 19px;
	font-weight: 500;
	text-align: center;
	margin: 0 0 10px 0;
	border: 1px solid rgba(255,255,255,0.5);
	padding: 5px 10px;
}

#tk6 .inner .box img {
	width: 100%;
	height: 23vw;
	max-height: 260px;
	object-fit: cover;
}

#tk6 .inner .box p {
	margin: 0;
	padding: 5px;
}

@media screen and (max-width: 1350px) {
	
#tk6 .inner {
	column-gap: 30px;
	padding: 30px 30px;
}

#tk6 .inner .box {
	width: calc((100% - 60px)/3);
}	
}

@media screen and (max-width: 1100px) {
	
#tk6 .inner {
	column-gap: 40px;
	padding: 30px 40px;
}

#tk6 .inner .box {
	width: calc((100% - 40px)/2);
}	
}

@media screen and (max-width: 780px) {
#tk6 .inner {
	column-gap: 0px;
	padding: 0px 40px 30px 40px;
}

#tk6 .inner .box {
	width: 100%;
}	
	
#tk6 .inner .box img {
	height: 50vw;
	max-height: inherit;
}
}

/*---------施工事例部----------------------------*/

.sjirei {
	margin: 50px auto 0 auto;
	max-width: 1413px;
	width: 100%;
	display: flex;
	align-items: flex-end;
}

.sjirei .side {
	width: 380px;
	box-sizing: border-box;
	padding: 0 55px;
}

.sjirei .pixa {width: calc(100% - 380px);}

/*--2段目用---*/

.sjirei.sec .side {order: 2;}
.sjirei.sec .pixa {order:1;}

/*--*/
.sjirei .side h1,
.sjirei .side h2 {
	font-size: 33px;
	line-height: 160%;
	margin-bottom: 50px;
	font-weight: 400;
}

.sjirei .side h6 {
	font-size: 15px;
	margin-bottom: 10px;
}

.sjirei .side p {margin-bottom: 20px;}
.sjirei .side p.kj {
	font-size: 14px;
	line-height: 180%;
}

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

.sjirei {flex-wrap: wrap; margin-top: 20px}
.sjirei .side {
	width: 100%;
	padding: 55px 55px 0 55px;
	order: 2;
}
.sjirei .pixa {
	width: 100%;
	order: 1;
}
}
@media screen and (max-width: 600px) {
.sjirei .side {padding: 55px 40px 0 40px;}
}

@media screen and (max-width: 500px) {
.sjirei .side {padding: 30px 30px 0 30px;}
.sjirei .side h1,
.sjirei .side h2 {
	font-size: 26px;
	margin-bottom: 30px;
}
}

/*--ギャラリー---*/

.sjgall {
	max-width: 1185px;
	display: flex;
	column-gap: 35px;
	justify-content: center;
	margin: 85px auto 0 auto;
	padding: 0 35px;
	flex-wrap: wrap;
	box-sizing: border-box;
}

.sjgall figure {
	display: block;
	width: calc((100% - 70px) / 3);
	padding-bottom: 35px;
}

.sjgall figure img {
	width: 100%;
	height: 40vw;
	max-height: 430px;
	object-fit: cover;
}

.sjgall figure figcaption {
	font-size: 14px;
	color: #525252;
}

@media screen and (max-width: 900px) {
	
.sjgall {
	margin: 50px auto 0 auto;
}
	
.sjgall figure {
	width: calc((100% - 35px) / 2);
	max-height: inherit;
}
	
.sjgall figure img {
	height: 60vw;
}
}

@media screen and (max-width: 600px) {
.sjgall {
	column-gap: 20px;
	margin: 40px auto 0 auto;
	padding: 0 20px;
}
	
.sjgall figure {
	width: 100%;
	height: auto;
	padding-bottom: 10px;
}	
	
.sjgall figure img {
	height: auto;
}
}



/*---設計力---------*/

.ryoku {
	margin: 90px auto 115px auto;
	max-width: 810px;
	display: flex;
	padding: 0 30px;
	box-sizing: border-box;
	column-gap: 30px;
}
.ryoku h3 {
	font-size: 31px;
	font-weight: 500;
	line-height: 160%;
}

.ryoku p {
	font-size: 16px;
	line-height: 180%;
}

@media screen and (max-width: 1121px) {
	
.ryoku {
	margin: 50px auto 120px auto;
}	
}
@media screen and (max-width: 840px) {

.ryoku {
	display: block;
	margin: 10px auto 50px auto;
	padding: 0 40px;
}
	
.ryoku h3 {margin-bottom: 20px;}
}

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

.ryoku {
	padding: 0 30px;
}
}
	
/*---コンテンツ区切り------*/
	
.kugiri {
	width: 100%;
	height: 70vw;
	max-height: 595px;
	position: relative;
	margin: 160px 0 100px 0;
	color: #fff;
}
	
	.kugiri .fil {
		width: 100%;
		height: 100%;
		position: absolute;
		left: 0;
		top: 0;
		z-index: 1;
		background-color: rgba(0,0,0,0.3);
	}
	
.kugiri img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	position: absolute;
	z-index: 0;
	top: 0;
	left: 0;
}

.kugiri .inner {
	width: 100%;
	height: 100%;
	display: flex;
	align-items: center;
	position: relative;
	justify-content: center;
	z-index: 2;
}

.kugiri .inner div {
	width: 100%;
	padding: 0 10vw;
	box-sizing: border-box;
}

.kugiri .inner h4 {
	font-size: 27px;
	margin: 0 0 40px 0;
}

@media screen and (max-width: 850px) {
.kugiri {margin: 50px 0 0 0;}
.kugiri .inner div {padding: 0 30px;}
}
	
/*---事例者商品価格など------------*/

.jplist {
	text-align: center;
	padding: 50px 40px 0 40px;
}

.jplist h2 {
	font-size: 27px;
	font-weight: 600;
	margin-bottom: 40px;
	line-height: 140%;
}

.jplist p.htxt {
	font-size: 16px;
	line-height: 180%;
	margin-bottom: 80px;
}

.jplist .inner {
	display: flex;
	justify-content: center;
	column-gap: 35px;
	flex-wrap: wrap;
	max-width: 1380px;
	margin: 0 auto;
}

.jplist .inner .box {
	width: calc((100% - 35px*3)/4);
	text-align: left;
	margin-bottom: 50px;
}

.jplist .inner .box p {padding: 5px; margin: 0 0 15px 0}

.jplist .inner .box p.num {
	font-size: 24px;
	color: #fff;
	background-color: #000;
	padding: 3px 8px;
	display: inline-block;
	margin: 0;
}



.jplist .inner .box p.data {
	border: 1px solid #d6d6d6;
	padding: 15px;
	font-size: 14px;
	margin: 0;
	line-height: 160%;
}
.jplist .inner .box h4 {
	font-size: 17px;
	margin: 10px 5px;
	font-weight: 500;
}

.jplist .inner .box img {
	width: 100%;
	height: 20vw;
	object-fit: cover;
	max-height: 300px;
}

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

.jplist .inner .box {
	width: calc((100% - 35px*3)/3);
}
}

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

.jplist .inner .box {
	width: calc((100% - 35px)/2);
}
	
.jplist .inner .box img {
	height: 26vw;
	max-height: inherit;
}
}

@media screen and (max-width: 820px) {
.jplist {
	padding: 50px 40px 0 40px;
}
.jplist p.htxt {
	margin-bottom: 50px;
}
}

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

.jplist {
	padding: 50px 30px 0 30px;
}
.jplist .inner .box {
	width: 100%;
}
	
.jplist .inner .box img {
	height: 60vw;
}
}



/*---関連コンテンツ----*/

.kancon {
	text-align: center;
	padding: 80px 60px 70px 60px;
	background-color: #e1e0e0;
	margin: 50px auto 0 auto;
	border-bottom: 1px solid #666;
}

.kancon h3 {
	font-size: 27px;
	font-weight: 600;
	margin-bottom: 40px;
}

.kancon p.htxt {
	font-size: 16px;
	line-height: 180%;
	margin-bottom: 80px;
}

.kancon .inner {
	max-width: 1360px;
	margin: 0 auto;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	column-gap: 60px;
}

.kancon .inner .box {
	width: calc((100% - 120px)/3);
	box-sizing: border-box;
	background-color: #fff;
	text-align: left;
}

.kancon .inner .box figure {
	overflow: hidden;
	width: 100%;
	height: 20vw;
	max-height: 280px;
}

.kancon .inner .box figure img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: 0.5s;
}

.kancon .inner .box figure img:hover {transform: scale(1.1);}

.kancon .inner .box .txt {padding: 15px 30px;}
.kancon .inner .box h3 {
	font-size: 18px;
	font-weight: 600;
	margin: 15px 0;
}

.kancon .inner .box p {
	font-size: 16px;
	line-height: 180%;
	margin-bottom: 20px;
}

.kancon .inner .box p.kj {
	font-size: 14px;
	margin: 0 0 20px 0;
	padding: 0 5px;	
}

.kancon .inner .box a.btn {
}

.kancon .inner .box a.btn img {
	width: 22px;
	height: auto;
	margin: 0 8px 0 0;
}

@media screen and (max-width: 1200px) {
.kancon {
	padding: 80px 40px 70px 40px;
}	
.kancon .inner {
	column-gap: 40px;
}
}

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

.kancon {
	padding: 80px 30px 70px 30px;
}	
.kancon .inner {
	column-gap: 0px;
}
.kancon .inner .box {
	width: 100%;
	margin-bottom: 20px;
}
	
.kancon .inner .box a.btn {display: none;}

.kancon .inner .box figure {
	overflow: hidden;
	width: 20vw;
	height: 20vw;
	max-height: 280px;
	float: right;
	margin: 0 0 0 20px;
}
}

@media screen and (max-width: 760px) {
.kancon .inner .box figure {
	width: 30vw;
	height: 30vw;
	max-height: 280px;
}
}
@media screen and (max-width: 550px) {

.kancon p.htxt {
	margin-bottom: 30px;
}
	
}

/*----------------------------------------
コンテンツ共通

文字のタイトル
--------------------------------------------*/

.cttl_area {
	padding: 110px 20px 50px 20px;
	text-align: center;
}

.cttl_area h1,
.cttl_area h4 {
	font-size:21px;
	font-weight: 400;
}

.cttl_area p {
	font-size:44px;
	margin: 0 0 30px 0;
}

.cttl_area p.ctc {
	font-size:40px;
	margin: 0 0 30px 0;
	font-weight: 500;
}


@media screen and (max-width: 920px) {
	
.cttl_area h1,
.cttl_area h4 {
	font-size:16px;
}

.cttl_area p {
	font-size:30px;
	margin: 0 0 20px 0;
}	
}

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

.cttl_area p.ctc {
	font-size:30px;
	line-height: 160%;
	margin: 0 0 10px 0;
}
}



/*--------------------------------------------
ブログアーカイブ
--------------------------------------------*/

#newsacv .inner {
	max-width: 1432px;
	margin: 0 auto;
	display: flex;
	flex-wrap: wrap;
	width: calc(100% - 60px);
	column-gap: 40px;
}

#newsacv .inner .box {
	width: calc((100% - 80px)/ 3);
	margin-bottom: 50px;
}

#newsacv .inner .box figure {
	width: 100%;
	height: 26vw;
	max-height: 300px;
	position: relative;
}

#newsacv .inner .box figure img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

#newsacv .inner .box figure p.dt {
	position: absolute;
	left: 0;
	bottom: 0;
	background-color: #fff;
	padding: 5px 10px;
}

#newsacv .inner .box a .txt {
	padding: 15px;
}

#newsacv .inner .box a .txt h3 {
	font-size: 16px;
	font-weight: 500;
	margin-bottom: 10px;
}

#newsacv .inner .box a .txt p {
	color: #525252;
}

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

#newsacv .inner {column-gap: 40px;}
#newsacv .inner .box {
	width: calc((100% - 40px)/ 2);
}
}

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

#newsacv .inner {column-gap: 0px;}
#newsacv .inner .box {width: 100%;}
#newsacv .inner .box figure {
	width: 100%;
	height: 70vw;
	max-height: 300px;
	position: relative;
}
}

/*------------------------------------
ブログ記事
---------------------------------------*/

.blog_kiji .inner {
	max-width: 1432px;
	margin: 0 auto;
	display: flex;
	flex-wrap: wrap;
	width: calc(100% - 60px);
}

/*--段組み---*/

.blog_kiji .inner .cont {
	width: 70%;
	padding: 70px 66px 30px 66px;
	box-sizing: border-box;
	border: 1px solid #b8b8b8;
}

.blog_kiji .inner .side {
	width: 30%;
	background-color: #e7e6e2;
	box-sizing: border-box;
	padding: 30px;
}



/*---サイドバー-----*/

.blog_kiji .inner .side .sidettl {
	font-size: 16px;
	font-weight: 600;
	margin-bottom: 10px;
}

/*--PICKUP---*/

.blog_kiji .inner .side .pick1 a {
	background-color: #fff;
	display: block;
	margin-bottom: 15px;
}

.blog_kiji .inner .side .pick1 a .catdate p {display: inline-block;}
.blog_kiji .inner .side .pick1 a .catdate p.pn {
	position: static;
	text-align: left;
}

.blog_kiji .inner .side .pick1 a .catdate p.st {
	font-size: 14px;
	color: #666;
	padding-left: 10px;
}

.blog_kiji .inner .side .pick1 a figure {
	width: 128px;
	max-width: 45%;
	height: 128px;
	float: right;
	border: 8px solid #fff;
	margin-left: 10px;
	box-sizing: border-box;
	overflow: hidden;
}

.blog_kiji .inner .side .pick1 a figure img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: 0.3s;
}

.blog_kiji .inner .side .pick1 a:hover figure img {
	transform: scale(1.1);
}

.blog_kiji .inner .side .pick1 a .txt {padding: 15px 20px 15px 15px;}
.blog_kiji .inner .side .pick1 a .txt p {
	margin: 10px 0 0 0;
	line-height: 160%;
	font-size: 13.5px;
	color: #444;
}

/*--BLOG の　Latestentry---*/

.blog_kiji .inner .side .pick2 a {
	border-top: 1px solid #d6d6d6;
	padding: 10px 5px;
	display: block;
	transition: 0.3s;
}

.blog_kiji .inner .side .pick2 a:hover {background-color: rgba(255,255,255,0.3);}

.blog_kiji .inner .side .pick2 a p.tmh {
	font-size: 14px;
	color: #666;
}

@media screen and (max-width: 1088px) {
	
.blog_kiji .inner .cont {width: 100%;}
.blog_kiji .inner .side {width: 100%;}
}

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

.blog_kiji .inner {
	max-width: 1432px;
	margin: 0 auto;
	display: flex;
	flex-wrap: wrap;
	width: 100%;
}
	
.blog_kiji .inner .cont {
	width: 100%;
	padding: 40px 30px 30px 30px;
	border: none;
	border-top: 1px solid #b8b8b8;
}
}


/*------------------------------------
記事（エディタ共通）
---------------------------------------*/

/*--施工事例サービス用幅--*/

.skosv {
	max-width: 1300px;
	margin: 0 auto;
	padding: 50px 30px;
}

.edi {
	font-size: 16px;
	line-height: 180%;
}

.edi h1 {
	font-size: 26px;
	font-weight: 600;
	margin: 0 0 10px 0;
	line-height: 170%;
}

.edi h2 {
	font-size: 24px;
	font-weight: 500;
	margin: 0 0 20px 0;
	line-height: 170%;
}

.edi p.timeh {
	font-size: 13px;
	margin: 0 0 20px 0;
	color: #333;
}

.edi figure {margin: 20px 0;}

.edi p {margin-bottom: 20px;}

@media screen and (max-width: 920px) {
	
.edi h1 {font-size: 22px;}
.edi h2 {font-size: 20px;}	
}

/*---ブログたーむぶ----*/
.edi p.pn {
	position: static;
	text-align: left;
}



/*------------------------------------------------------
ページングのスタイル
-----------------------------------------------------------*/
.newer-older {
	margin: 30px auto 30px auto;
	letter-spacing: -0.4em;
	display:flex;
	-js-display: flex;
	flex-direction:row;
	flex-wrap:wrap;
	width: 100%;
	max-width: 1200px;
	font-size: 14px;
	font-weight: 500;
	border-top: 1px solid #d6d6d6;
}
.newer-older p {margin: 0; padding: 0;}

.newer-older p.newer {text-align: right; border-left: 1px solid #d6d6d6;}
.newer-older p.older {text-align: left; }
.newer-older p.blog {
	text-align: center; 
	background-color: #f6f6f6;
}

.newer-older p.older,
.newer-older p.newer {
	letter-spacing: normal;
	box-sizing: border-box;
	vertical-align: middle;
}

.newer-older p.older{width: calc(50%)}
.newer-older p.newer{width: calc(50%)}


.newer-older p.older a,
.newer-older p.newer a {
	height: 100%;
	display: block;
	text-decoration: none;
	transition: 0.5s;
	box-sizing: border-box;
	position: relative;
}

.newer-older p.newer a::after {
	content: "→";
	position: absolute;
	right: 5px;
	top: calc(50% - 16px);
}
.newer-older p.older a::after {
	content: "←";
	position: absolute;
	left: 5px;
	top: calc(50% - 16px);
}


.newer-older p.older a {padding: 20px 20px 20px 30px;}
.newer-older p.newer a {padding: 20px 30px 20px 20px;}


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

.newer-older p.older a {padding: 20px 0;}
.newer-older p.newer a {padding: 20px 0;}

	
.newer-older p.older{width: 50%}
.newer-older p.newer{width: 50%; }
.newer-older p.blog { display: none;}
.newer-older {
	margin: 0px auto ;
}
}

.bgred{
    background-color: #e60012;
    color: white;
    text-align: center;
    margin: 0 0% 10px 0%;
    padding: 2px 15px;
    display: inline-block;
}

/*------------------------------------**/




/*----------------------------------------------------------------------------
ページングカスタマイズ
-----------------------------------------------------------------------------*/

nav.pagination {
	letter-spacing: normal; 
	text-align: center;
	font-size: 16px;
	color:#000;
	margin: 60px 0 ;
	position: relative;
	z-index: 999;
}

nav.pagination h2 {display: none;}
nav.pagination a{
	display: inline-block;
	color:#000;
	margin: 0 2px;
	text-decoration: none;
	width: 30px;
	height: 30px;
	border-radius: 30px;
	transition: 0.5s;
}

nav.pagination a:hover {background-color: #d6d6d6;}

nav.pagination span.page-numbers {
	background-color: #333;
	display: inline-block;
	padding: 0;
	width: 30px;
	height: 30px;
	color: #fff;
	text-decoration: none;
}

nav.pagination span.dots{
	background: none;
	color:#000;
}
/*--nav.pagination span.page-numbers {background-color: #d6d6d6;}--*/


/*----------------------------------------------------------------------------
フォーム用のボタン・入力
-----------------------------------------------------------------------------*/

.entry_form  {
	width: 100%;
	max-width: 715px;
	margin: 30px auto 50px auto;
	padding: 0 30px;
	box-sizing: border-box;
	text-align: center;
}

.entry_form p.ult {
	margin: 0 0 20px 0;	
	display: flex;
	align-items: center;
}
.entry_form p.ult.lsp {margin: 0 0 10px 30px;}
.entry_form p.ult.lspl {margin: 0 0 30px 30px;}

/*--番号付き文字----*/

.entry_form p.ult span.num {
	display: block;
	background-color: #8fc655;
	border-radius: 100px;
	width: 56px;
	height: 56px;
	color: #fff;
	font-size: 42px;
	line-height: 56px;
	text-align: center;
	margin-right: 10px;
}

.entry_form p.ult span.txt {
	border-bottom: 2px solid #8fc655;
	padding: 10px;
	box-sizing: border-box;
	font-size: 19px;
	width: calc(100% - 66px);
}

/*--個人情報欄--------*/

.entry_form p.ult span.ttl {
	display: block;
	width: 65px;
}

.entry_form p.ult span.ttl b {float: none;}

.entry_form p.ult span.ran {
	width: calc(100% - 65px);
}



/*---任意・必須----*/

.entry_form p.ult b.need {
	background-color: #946774;
	color: #fff;
	font-size: 16px;
	padding: 3px 8px;
	border-radius: 5px;
	float: right;
}

.entry_form p.ult b.nin {
	background-color: #b8b8b8;
	color: #fff;
	font-size: 16px;
	padding: 3px 8px;
	border-radius: 5px;
	float: right;
}





/*---選択肢-------*/
.entry_form .inner {
	text-align: left;
	letter-spacing: -0.4em;
	margin-bottom: 30px;
}

.entry_form .inner .box {
	display: inline-block;
	letter-spacing: normal;
	width: calc(50% - 4px);
	margin: 0 2px 5px 2px;
	font-size: 17px;
	font-weight: 500;
}

.entry_form .inner .box label span:after {font-size: 14px; display: block; margin-left: 45px; font-weight: 400;}
.entry_form .inner .box:nth-child(1) label span:after {content: "家の外側の工事のこと"; }
.entry_form .inner .box:nth-child(2) label span:after {content: "家を建てたい！"; }
.entry_form .inner .box:nth-child(3) label span:after {content: "建物の外壁・屋根など"; }
.entry_form .inner .box:nth-child(4) label span:after {content: "間取りや家の内側のリフォーム"; }
.entry_form .inner .box:nth-child(5) label span:after {content: "トイレ・浴室・キッチンなど"; }
.entry_form .inner .box:nth-child(6) label span:after {content: "太陽光パネル・蓄電池"; }

.entry_form .inner .box label {
	display: block;
	background-color: #dff2ca;
	padding: 20px;
	box-sizing: border-box;
	border-radius: 10px;
	margin: 0 2px 5px 2px;
	cursor: pointer;
}

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

.entry_form .inner .box {
	display: inline-block;
	letter-spacing: normal;
	width: calc(100% - 4px);
	margin: 0 2px 5px 2px;
	font-size: 17px;
	font-weight: 500;
}
}


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

.entry_form p.ult span.num {
	width: 40px;
	height: 40px;
	font-size: 34px;
	line-height: 40px;
	margin-right: 5px;
}

.entry_form p.ult span.txt {
	padding: 8px;
	font-size: 19px;
	width: calc(100% - 45px);
}
	
.entry_form p.ult.lsp {margin: 0 0 10px 10px;}
.entry_form p.ult.lspl {margin: 0 0 30px 10px;}

}



.aa {
	font-size: 18px;
	line-height: 180%;
}

@media screen and (max-width: 467px) {
	
.entry_form p.ult span.txt {
	font-size: 16px;
}
	
.aa {
	font-size: 16px;
	line-height: 180%;
}	
}



	.a1 {
		height: auto;
		padding:15px 20px;
		border:2px solid #b8b8b8;
		border-radius: 10px;
		font-size:16px;
		font-family: 'Figtree','Noto Sans JP', "游ゴシック", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", MS UI Gothic, Osaka, sans-serif;
		background:#fff;
		width:calc(100% - 30px);
		box-sizing:border-box;
		outline: none;
		margin: 0 10px 5px 20px;
	}

.a1t {
		height: 200px;
		padding:15px 20px;
		border:2px solid #b8b8b8;
		border-radius: 10px;
		font-size:16px;
		font-family: 'Figtree','Noto Sans JP', "游ゴシック", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", MS UI Gothic, Osaka, sans-serif;
		background:#fff;
		width:calc(100% - 30px);
		box-sizing:border-box;
		outline: none;
		margin: 0 10px 30px 20px;
	}

	.a2 {
		padding:10px 20px;
		border:1px solid #acacaa;
		font-size:15px;
		font-family: 'Figtree','Noto Sans JP', "游ゴシック", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", MS UI Gothic, Osaka, sans-serif;
		background:#fff;
		width:100%;
		box-sizing:border-box;
		outline: none;
		margin-top: 2px;
	}

	.a3 {
		padding:10px 20px;
		border:1px solid #acacaa;
		font-size:15px;
		font-family: 'Figtree','Noto Sans JP', "游ゴシック", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", MS UI Gothic, Osaka, sans-serif;
		background:#fff;
		width:100px;
		box-sizing:border-box;
		outline: none;
		margin-top: 2px;
	}

	
.a1:focus,
.a2:focus{
	border-color:#333;
	outline: none;
}

/*送信ボタン*/
	.sendb,
	.sendb:focus {
		width: 251px;
		height: 57px;
		margin: 40px auto 0 auto;
		background-color: #8fc655;
		color:#fff;
		border: none;
		border-radius: 7px;
		font-size: 19px;
		font-weight: 400;
		cursor:pointer;
		display: grid;
		place-items:center;
		position: relative;
		transition: 0.3s;
		font-family: 'Figtree','Noto Sans JP', "游ゴシック", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", MS UI Gothic, Osaka, sans-serif;
}
	
	.sendb:hover {
		top: 2px;
		left: 2px;
		background-color:#000;
		cursor:pointer;
		transition: 0.3s;
	}



.entry_form input[type="checkbox"]:focus {
  outline: none;
}
/* チェックボックス */
input[type=checkbox] {
    -webkit-appearance: none;
    -moz-appearance: none;
    -ms-appearance: none;
    appearance: none;
    position: relative;
    top: 3px;
    margin: 3px 0 0 -16px;
    width: 18px;
    height: 18px;
    cursor: pointer;
    background-color: #fff;
    border: 1px solid #acacaa;
    outline: none;
    transition: background-color 0.2s, border-color 0.2s;
}

input[type=checkbox]:checked {
    background-color: #2d6ab3;
    border-color: #2d6ab3;
}

/* チェックマーク */
input[type=checkbox]:checked::before {
    content: '';
    position: absolute;
    top: 1px;
    left: 6px;
    width: 3px;
    height: 10px;
    border: solid #fff;
    border-width: 0 2px 2px 0;
    transform: rotate(45deg);
}

input[type=checkbox]:hover {
    border-color: #2d6ab3;
}


.personal .wpcf7-not-valid-tip{
	margin-top: 40px;
    margin-left: -277px;
}

.wpcf7-mail-sent-ok {border-color: #333;}


	
 input[type=checkbox]
 {

  -webkit-appearance: none;
  -moz-appearance: none;
  -ms-appearance: none;
  appearance: none;

}
input[type=checkbox] {
	margin: 0;
	margin-left: 0;
	line-height: 0;
	width:0px;
	height: 0px;
	border: 0;

}

#formw {text-align: left;}
#formw label input {
	position: relative;
	margin: 0 1rem 0 0;
	cursor: pointer;
	
}
#formw label input:before {
	position: absolute;
	z-index: 1;
    top: -11px;
    left: 0.15rem;
    width: 0.75rem;
	height: 0.375rem;
	content: '';
	-webkit-transition: -webkit-transform 0.4s cubic-bezier(0.45, 1.8, 0.5, 0.75);
	        transition:         transform 0.4s cubic-bezier(0.45, 1.8, 0.5, 0.75);
	-webkit-transform: rotate(-45deg) scale(0, 0);
	        transform: rotate(-45deg) scale(0, 0);
	border: 2px solid #da3c41;
	border-top-style: none;
	border-right-style: none;
	
}
#formw label input:checked:before {
	-webkit-transform: rotate(-45deg) scale(1, 1);
	        transform: rotate(-45deg) scale(1, 1);
}
#formw label input:after {
	position: absolute;
	top: -13px;
	left: 0;
	width: 1rem;
	height: 1rem;
	content: '';
	cursor: pointer;
	border: 1px solid #ccc;
	background:#f6f6f6;

}

#formw input[type="checkbox"]:focus {
  outline: none;
  border: 0;
}


#formw .wpcf7-list-item{
	display: block;
}

#formw .wpcf7-list-item-label{
	margin-left: 25px;
}

.wpcf7-response-output {border-color: #8fc655 !important; background-color: #8fc655 !important; color:#fff !important;}




