@charset 'UTF-8';

/* ■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■

	トップページ

■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■ */



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

	レイアウト

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

/* PC設定
----------------------------------------------- */
@media (min-width: 768px) {
	#wrapper {
	}

	main.outer_wrap {
		position: relative;
		max-width: none;
		/* max-width: 1920px; 固定幅レイアウト時 */
		width: 100%;
		min-height: 50vh;
		display: block;
		margin: 0 auto;
	}

	.inner_wrap {
		position: relative;
	}
}




/* SP設定
----------------------------------------------- */
@media (max-width: 767px) {
	#wrapper {
	}

	main.outer_wrap {
		position: relative;
		width: 100%;
	}

	.inner_wrap {
		position: relative;
	}

	.pc_head .h_logo {
		position: absolute;
		z-index: 10;
		padding: 1vw 2vw;
	}
	.pc_head .h_logo img {
		width: 32vw;
	}
}





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

	見出し

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

/* PC設定
----------------------------------------------- */
@media (min-width: 768px) {
	.h2_top h2 {
	  position: relative;
	  display: inline-block;
		font-size: 2.1vw;
		letter-spacing: 0.1em;
		padding: 0 0 0.8vw !important;
		margin: 0 0 3vw !important;
	}
	.h2_top h2:before {
	  content: '';
	  position: absolute;
	  bottom: -1vw;
	  display: inline-block;
	  width: 16vw;
	  height: 5px;
	  left: 50%;
	  -webkit-transform: translateX(-50%);
	  transform: translateX(-50%);
	  background-color: #f39800;
	}
}


/* SP設定
----------------------------------------------- */
@media (max-width: 767px) {
	.h2_top h2 {
		position: relative;
		display: inline-block;
		font-size: 6vw;
		letter-spacing: 0.1em;
		padding: 0 0 4vw !important;
		margin: 0 0 6vw !important;
	}
	.h2_top h2:before {
		content: '';
		position: absolute;
		bottom: -1vw;
		display: inline-block;
		width: 16vw;
		height: 1vw;
		left: 50%;
		-webkit-transform: translateX(-50%);
		transform: translateX(-50%);
		background-color: #f39800;
	}
}





/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★

	ここからコンテンツ内容

★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */


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

	ティッカー

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


/* PC設定
----------------------------------------------- */
@media (min-width: 768px) {

}


/* SP設定
----------------------------------------------- */
@media (max-width: 767px) {
	.ticker_wrap {
		display: none;
	}
}





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

	ようこそ文　col_01

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


/* PC設定
----------------------------------------------- */
@media (min-width: 768px) {
	.col_01 {
		text-align: center;
		background: url(../img/yume_bg.jpg) center center no-repeat;
		background-size: 22%;
		padding: 7vw 0;
		margin: -1vw 0 0 0;
	}
	.col_01 h2 {
		font-size: 1.8vw;
		line-height: 1.6 !important;
		letter-spacing: 0.1em;
		padding: 0 0 2vw !important;
	}
	.col_01 h2 span {
		color: #eb6100;
	}
	.col_01 p {
		font-size: 1.1vw;
		line-height: 2.2 !important;
		letter-spacing: 0.1em;
	}
	.col_01 .banner_01 a img {
		width: 26vw;
	}
	.col_01 .banner_02 {
 	}
	.col_01 .banner_02 a img {
		width: 27vw;
	}
	.col_01_sub {
		padding: 3vw 0 0;
	}
}


/* SP設定
----------------------------------------------- */
@media (max-width: 767px) {
	.col_01 {
		text-align: center;
		background: url(../img/yume_bg.jpg) center 26vw no-repeat;
		background-size: 60%;
		padding: 12vw 4vw;
	}
	.col_01 h2 {
		font-size: 5vw;
		line-height: 1.6 !important;
		padding: 0 0 4vw !important;
	}
	.col_01 h2 span {
		color: #eb6100;
	}
	.col_01 p {
		font-size: 3.6vw;
		line-height: 2.2 !important;
	}
	.col_01 .banner_01 {
		margin: 3vw 0 2vw !important;
	}
	.col_01 .banner_01 a img {
		width: 82vw;
	}
	.col_01 .banner_02 {
		margin-left: -0.9vw;
	}
	.col_01 .banner_02 a img {
		width: 84vw;
	}
	.col_01_sub {
		padding: 3vw 0 0;
	}
}





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

	施工実績　col_02

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


/* PC設定
----------------------------------------------- */
@media (min-width: 768px) {
	.col_02 {
		background: url(../img/top_bg_02.jpg) center top no-repeat;
		background-size: cover;
		padding: 7vw 0;
	}
	.col_02 .post_wrap {
	}
	.col_02 .post_wrap ul {
		margin: 0 auto;
		width: 65vw;
		text-align: center;
		font-size: 0;
	}
	.col_02 .post_wrap ul li {
		display: inline-block;
		vertical-align: top;
		width: 18.2vw;
		margin: 0 0 3.1vw;
	}
	.col_02 .post_wrap ul li:nth-of-type(2),
	.col_02 .post_wrap ul li:nth-of-type(5) {
		margin: 0 3.1vw;
	}
	.col_02 .post_thumb {
		background-position: center top;
		background-repeat: repeat;
		width: 18.2vw;
		height: 12vw;
		background-color: #fff;
	}
	.col_02 .post_wrap .post_thumb img {
		width: 18.2vw;
		height: 12vw;
		object-fit: cover;
		font-family: 'object-fit: cover;';  /* IE対策 */
	}
	.col_02 .post_box {
		background-color: #fff;
		padding: 0.6vw 0.6vw 0.3vw 0.6vw;
	}
	.col_02 .post_icon_box {
		padding: 0 0 0.3vw;
	}
	.col_02 .blog_icon {
		display: inline;
		font-size: 0.7vw;
		background-color: #fff799;
		padding: 0.3vw 0.6vw;
		border-radius: 1vw;
		margin: 0 0.3vw 0 0;
	}
	.col_02 .post_date {
		display: none;
	}
	.col_02 .post_title {
		overflow: hidden;
		text-overflow: ellipsis;
		white-space: nowrap;
	}
	.col_02 .post_title a {
		font-size: 1vw;
		font-weight: 700;
	}
	.col_02 .post_excerpt {
		display: none;
	}

	.col_02 .gr_btn {
		margin: 0 auto;
		text-align: center;
	}
}


/* SP設定
----------------------------------------------- */
@media (max-width: 767px) {
	.col_02 {
		background: url(../img/top_bg_02.jpg) center top no-repeat;
		background-size: cover;
		padding: 12vw 4vw;
	}
	.col_02 .post_wrap {
    margin: 0 auto;
		overflow-x: hidden;
  }
  .col_02 .post_thumb {
    margin: 0 auto;
    background-position: center top;
    background-repeat: repeat;
    width: 80vw;
    height: 53vw;
  }
  .col_02 .post_wrap ul {
    margin: 0 auto;
    overflow: auto;
  }
  .col_02 .post_wrap ul li {
    margin: 0 auto;
    width: 80vw;
		padding: 1vw 0 11vw 0 !important;
  }
  .col_02 .post_wrap .post_thumb img {
		width: 80vw;
    height: 53vw;
    object-fit: cover;
    font-family: 'object-fit: cover;';  /* IE対策 */
		border: 1px solid #ebe5df;
  }
	.col_02 .post_box {
		background-color: #fff;
		padding: 2vw 2vw 1vw !important;
	}
	.col_02 .post_icon_box {
	}
	.col_02 .blog_icon {
		display: inline;
		font-size: 3vw;
		background-color: #fff799;
		padding: 1vw 2vw;
		border-radius: 3vw;
		margin: 0 1vw 0 0;
	}
  .col_02 .post_date {
		display: none;
  }
  .col_02 .post_title {
		overflow: hidden;
		text-overflow: ellipsis;
		white-space: nowrap;
  }
  .col_02 .post_title a {
		font-size: 4.2vw;
		font-weight: 700;
  }
	.col_02 .post_excerpt {
		display: none;
	}

	.col_02 .gr_btn {
		margin: 0 auto;
		text-align: center;
	}
}





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

	対応エリア　col_03

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


/* PC設定
----------------------------------------------- */
@media (min-width: 768px) {
	.col_03 {
		padding: 7vw 0 0;
	}
	.col_03 .map img {
		width: 21vw;
	}
	.col_03 .map img {
		width: 21vw;
	}
	.col_03 p {
		font-size: 1.1vw;
	}
	.col_03 .area p {
		font-size: 1.8vw;
		font-weight: 700;
		letter-spacing: 0.1em;
		padding: 0 0 1.3vw;
	}
	.col_03 .area p span {
		color: #eb6100;
	}
	.col_03 .gr_btn {
		padding: 1.6vw 0 0;
	}
}


/* SP設定
----------------------------------------------- */
@media (max-width: 767px) {
	.col_03 {
		padding: 12vw 4vw 0;
	}
	.col_03 .map {
		padding: 0 0 3vw;
	}
	.col_03 .map img {
		width: 72vw;
	}
	.col_03 p {
		text-align: center;
		font-size: 3.6vw;
	}
	.col_03 .area p {
		text-align: center;
		font-size: 4.6vw;
		font-weight: 700;
		padding: 0 0 2vw;
	}
	.col_03 .area p span {
		color: #eb6100;
	}
	.col_03 .gr_btn {
		text-align: center;
		padding: 1.6vw 0 0;
	}
}





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

	お支払方法　col_04

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


/* PC設定
----------------------------------------------- */
@media (min-width: 768px) {
	.col_04 {
		background-color: #fff;
		padding: 7vw 0;
	}
	.col_04 .box {
		background-color: #fff;
		padding: 3vw;
		border: 10px solid #eac78e;
	}
	.col_04 p {
		text-align: center;
		font-size: 1.1vw;
		padding: 0 0 1.6vw;
	}
	.col_04 .left,
	.col_04 .right {
		background-color: #fff799;
	}
	.col_04 .left h3,
	.col_04 .right h3 {
		font-size: 1.1vw;
		padding: 0 0 0.7vw !important;
		border-bottom: 1px solid #000;
	}
	.col_04 .left img {
		width: 9vw;
		margin: 0.5vw 0 0;
	}
	.col_04 .right img {
		width: 6vw;
		margin: 0.1vw 0 0;
	}
}


/* SP設定
----------------------------------------------- */
@media (max-width: 767px) {
	.col_04 {
		background-color: #fff;
		padding: 12vw 4vw;
	}
	.col_04 .box {
		background-color: #fff;
		padding: 6vw;
		border: 1.6vw solid #eac78e;
	}
	.col_04 p {
		text-align: center;
		font-size: 3.6vw;
		padding: 0 0 6vw;
	}
	.col_04 .left {
		margin: 0 0 3vw;
	}
	.col_04 .left,
	.col_04 .right {
		background-color: #fff799;
	}
	.col_04 .left h3,
	.col_04 .right h3 {
		font-size: 4vw;
		padding: 0 0 1.6vw !important;
		margin: 0 0 1.6vw;
		border-bottom: 1px solid #000;
	}
	.col_04 .left img {
		width: 30vw;
		margin: 0.5vw 0 0;
	}
	.col_04 .right img {
		width: 20vw;
		margin: 0.1vw 0 0;
	}
}





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

	お問い合わせ　col_05

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


/* PC設定
----------------------------------------------- */
@media (min-width: 768px) {
	.col_05 {
		background: url(../img/top_bg_03.jpg) center top no-repeat;
		padding: 5vw 0;
	}
	.col_05 .box {
		background-color: #fff;
		padding: 3vw 4vw;
	}
	.col_05 .box h2 {
		height: 2.8vw;
		text-align: center;
		font-size: 1.7vw;
		letter-spacing: 0.1em;
		background: url(../img/h2_bg_01.png) 8vw center no-repeat;
		background-size: contain;
		padding: 0.3vw 0 0;
		margin: 0 0 2vw;
	}
	.col_05 .box h2 span {
		color: #eb6100;
	}
	.col_05 .box .tel {
		float: left;
		height: 4vw;
		padding: 0 4vw 0 0 !important;
		border-right: 2px solid #dcdcdc;
		margin: -0.6vw 0 0 !important;
	}
	.col_05 .box .tel a {
		display: block;
		pointer-events: none;
	}
	.col_05 .box .tel img {
		width: 23vw;
	}

	.col_05 .box .mail {
		float: left;
		margin: 0 0 0 4vw !important;
	}
	.col_05 .box .mail a {
		display: block;
		color: #fff;
		font-size: 1.3vw;
		font-weight: 700;
		letter-spacing: 0.06em;
		background-color: #eb6100;
		padding: 0.7vw 3vw;
	}
}


/* SP設定
----------------------------------------------- */
@media (max-width: 767px) {
	.col_05 {
		background: url(../img/top_bg_03.jpg) center top no-repeat;
		padding: 12vw 4vw;
	}
	.col_05 .box {
		background-color: #fff;
		padding: 6vw;
	}
	.col_05 .box h2 {
		text-align: center;
		font-size: 6vw;
		line-height: 1.3;
		background: url(../img/h2_bg_01.png) top center no-repeat;
		background-size: 10%;
		padding: 12vw 0 0;
		margin: 0 0 6vw;
	}
	.col_05 .box h2 span {
		color: #eb6100;
	}
	.col_05 .box .tel {
		text-align: center;
		padding: 0 0 3vw;
	}
	.col_05 .box .tel img {
		width: 100%;
	}

	.col_05 .box .mail {
	}
	.col_05 .box .mail a {
		text-align: center;
		display: block;
		color: #fff;
		font-size: 4.8vw !important;
		font-weight: 700;
		letter-spacing: 0.06em;
		background-color: #eb6100;
		padding: 3vw;
	}
}





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

	新着情報　col_06

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


/* PC設定
----------------------------------------------- */
@media (min-width: 768px) {
	.col_06 {
		padding: 7vw 0;
	}


	/* 新着情報 */
	.col_06 .post_wrap {
		height: 9vw;
		overflow: hidden;
		font-weight: 400;
	}
	.col_06 .post_thumb {
		display: none;
	}
	.col_06 .post_icon_box {
		display: none;
	}
	.col_06 .post_date {
		float: left;
		width: 6vw;
		font-size: 0.9vw;
		padding: 0.25vw 0 0 0 !important;
	}
	.col_06 .post_title {
		max-width: 54vw;
		overflow: hidden;
		text-overflow: ellipsis;
		white-space: nowrap;
	}
	.col_06 .post_title a {
		font-size: 1.1vw;
	}
	.col_06 .post_excerpt {
		display: none;
	}
	.col_06 .post_wrap ul li {
		border-bottom: 1px solid #dcdcdc;
		padding: 0.6vw;
	}
}


/* SP設定
----------------------------------------------- */
@media (max-width: 767px) {
	.col_06 {
		padding: 12vw 4vw;
	}

	/* 新着情報 */
	.col_06 .post_wrap {
		height: 40vw;
		overflow: hidden;
		font-weight: 400;
	}
	.col_06 .post_thumb {
		display: none;
	}
	.col_06 .post_icon_box {
		display: none;
	}
	.col_06 .post_date {
		font-size: 3vw;
		padding: 0.2vw 0 0 0;
	}
	.col_06 .post_title {
		overflow: hidden;
		text-overflow: ellipsis;
		white-space: nowrap;
	}
	.col_06 .post_title a {
		font-size: 3.8vw;
	}
	.col_06 .post_excerpt {
		display: none;
	}
	.col_06 .post_wrap ul li {
		border-bottom: 1px solid #dcdcdc;
		padding: 0.6vw;
	}
}
