﻿.bg_color1 {
    background-color: #e87463;
}
.txt_color1 {
    color: #e87463;
}
.border_color4 {
    border-color: #e87463;
}
.hvr_txt_color1:hover {
    color: #e87463;
}

/*--------------------------------
■2px大きく
--------------------------------*/
html{font-size: 16px;}
body{-webkit-text-size-adjust: 120%;font-size: 16px;}

.font_12{font-size: 14px;}
.font_14{font-size: 16px;}
.font_15{font-size: 17px;}
.font_16{font-size: 18px;}
.font_18{font-size: 20px;}
.font_20{font-size: 22px;}
.font_22{font-size: 24px;}
.font_24{font-size: 26px;}
.font_26{font-size: 28px;}
.font_28{font-size: 30px;}
.font_30{font-size: 32px;}
.font_100per{
font-size: -webkit-calc(1rem + 2px);
font-size: calc(1rem + 2px);
}
.font_2up{
font-size: -webkit-calc(1rem + 4px);
font-size: calc(1rem + 4px);
}
.font_4up{
font-size: -webkit-calc(1rem + 6px);
font-size: calc(1rem + 6px);
}
.font_6up{
font-size: -webkit-calc(1rem + 8px);
font-size: calc(1rem + 8px);
}
.font_8up{
font-size: -webkit-calc(1rem + 10px);
font-size: calc(1rem + 10px);
}
.font_10up{
font-size: -webkit-calc(1rem + 12px);
font-size: calc(1rem + 12px);
}
.font_2dw{
font-size: -webkit-calc(1rem);
font-size: calc(1rem);
}
/* ----------　all　---------- */

body, .txt_color_nomal,a {
    color: #493823;
}
.bg_white {
    background-color: #fffffd;
}
.linkStyle{
	color:#e87463;
}
.linkStyle:hover{
	color:#e87463;
	opacity: 0.7;
	transition: all 0.5s;
}
#con_nav ul li {
    max-width: 20%;
}
#con_nav li .nav_sub_title,#top_news .cms_title p,#top_cms .cms_title p{
    opacity: 1;
    color: #b6a689;
}
#con_nav ul li .nav_title {
    font-weight: bold;
}
#footer #footer_info_logo{
    width: 30%!important;
}
#footer #footer_nav{
    width: 70%!important;
}
.fixbnr {
    width: 200px;
    bottom: 45px;
}
/* ----------　TOP　---------- */
.h_tel_txt{
    font-size: 15px;
    line-height: 1.5;
}
#main_img .swiper-container {
    margin: 0px auto;
}
section#main_img:before {
    content: "";
    position: absolute;
    width: 100%;
    height: 100%;
    background-color: rgba(255 ,255 ,255 ,0.35);
    z-index: 2;
}
#main_img .catch_img{
    position: absolute;
    width: 80%;
    max-width: 900px;
    top: 50%;
    left: 50%;
    transform: translate(-50%,-50%);
    z-index: 2;
}
#main_img .catch_img img{
    filter: drop-shadow(1px 4px 10px rgba(255,255,255,0.7));
}
.scroll {
    color: #493823;
}
.scroll::before {
    background: rgba(73 ,56 ,35 ,0.25);
}
.scroll::after {
    background: #493823;
}
.toppage header #sns_link{
    margin-top: 5px;
}
.toppage header .head_tel{
    margin-top: 25px;
}

#top_contents1 .intro_img{
    position: absolute;
    width: 50%;
    max-width: 300px;
    top: 50px;
    left: 80px;
}
#flow{
    background-color: #fffffd;
    padding: 100px 0 150px;
}
#flow .flow_wrap{
    width: 90%;
    max-width: 1200px;
}
#flow .flow_wrap .con_before {
    width: 25px;
    left: 0;
    bottom: 0;
}
#flow .con_title{
    margin-bottom: 35px;
    position: relative;
    padding-bottom: 20px;
}
#flow .flow_img2{
    position: absolute;
    bottom: 0;
    right: 0;
    width: 40%;
    max-width: 230px;
}
#flow .flow_con{
    margin: auto;
    text-align: center;
    margin-top: 80px;
    width: 50%;
    transition: 0.5s;
    transform: translateY(0px);
}
#flow .flow_con:hover{
    transform: translateY(-10px);
}
#flow .flow_con a{
    background-color: #f6f4eb;
    color: #e87463;
    padding: 10px;
    text-align: center;
    display: inline-block;
    width: 100%;
    font-size: 20px;
    border: 2px solid #d4baa1;
    border-radius: 100px;
}
#attach .attach_bg {
    background-color: #fbf2e9;
    opacity: 0.4;
}
#attach .attach_txt {
    color: #e87463;
    text-shadow: 1px 5px 10px #fbf2e9eb;
}
#attach .attach_txt span{
    color: #6ec778;
}
#top_contents3 .con3_wrap2{
    margin: 50px 0;
}
#top_contents3 .con_before {
    width: 25px;
    height: auto;
}
#top_contents3 img {
    border-radius: 0;
}
#top_cms .cms_box:last-of-type{
    padding-bottom: 0;
    margin-top: 50px;
}
.toppage #footer_info .t_footer_info{
    padding-top:50px;
}
/* ---------- loopSlider ---------- */
#topcms_gallery_type1 .loopSliderWrap{
    top: 0;
    left: 0;
    height: 450px;
}
#topcms_gallery_type1 .loopSlider {
    margin: 0 auto;
    height: 450px;
    text-align: left;
    position: relative;
    overflow: hidden;
}
#topcms_gallery_type1 .loopSlider .ul {
    height:450px;
    float: left;
    overflow: hidden;
}
#topcms_gallery_type1 .loopSlider .ul .li {
    width: 450px;
    height: 450px;
    float: left;
    display: inline;
    overflow: hidden;
	position: relative;
	box-sizing: border-box;
	padding: 0;
}
#topcms_gallery_type1 .loopSlider .ul .li img{
    border-radius: 0;
}
#topcms_gallery_type1 .loopSliderWrap:after {
    content: "";
    display: none;
    clear: none;
}

/*リンクボタン*/
#topcms_gallery_type1 .btn{z-index: 3;}
#topcms_gallery_type1 .btn a::before {
    content: '';
    position: absolute;
    bottom: 55px;
    right: 27%;
    width: 42%;
    height: 1px;
    background: #333;
    transition: all .3s;
}
#topcms_gallery_type1 .btn a::after {
    content: '';
    position: absolute;
    bottom: 60px;
    right: 27%;
    width: 15px;
    height: 1px;
    background: #333;
    transform: rotate(35deg);
    transition: all .3s;
}
#topcms_gallery_type1 .btn a:hover::before {
    right: 16%;
    background: #fff;
}
#topcms_gallery_type1 .btn a:hover::after {
    right: 15%;
    background: #fff;
}
#topcms_gallery_type1 .btn {
    display: block;
}
#topcms_gallery_type1 .btn a {
    background: #fff;
    color: #212121;
    width: 200px;
    height: 200px;
    display: flex;
    align-content: center;
    justify-content: center;
    border-radius: 50%;
    flex-wrap: wrap;
    transition: all 0.4s;
}
#topcms_gallery_type1 .btn a:hover {
    background: #e87463;
    color: #fff;
}
#topcms_gallery_type1 .btn a:hover span{
    color: #6ec778;
}
#topcms_gallery_type1 .btn a span, .btn a strong {
    text-align: center;
}
/* ----------　下層ページ　---------- */
#page_title .title_wrap h2{
        text-shadow: 1px 3px 10px rgba(73 ,56,35 ,0.5);
}
#page_title .title_wrap p{
    background-color: #e87463;
    display: inline-block;
    color: #fff;
    padding: 8px 30px;
    border-radius: 500px;
    min-width: 200px;
}

/* 施工事例 */
.g_type5 .slide_img figure{
	position: relative;
	overflow: hidden;
}
.g_type5 .slide_img figure img{
	position: relative;
	top: 50%;
	left: 50%;
	-ms-transform: translate(-50%,-50%);
	-webkit-transform: translate(-50%,-50%);
	transform: translate(-50%,-50%);
}
.g_type5 .swiper-slide{
    opacity: 1!important;
}
.g_type5 .slide_img .thumbnail .swiper-wrapper {
    margin-left: 0!important;
    transform: none!important;
}
.g_type5 .swiper-button-prev{
	background-image: url("../dup/img/swiper_prev.png")!important;
}
.g_type5 .swiper-button-next{
	background-image: url("../dup/img/swiper_next.png")!important;
}
/* お客様の声 */
#cms_6-d.cms_wrap{
    counter-reset: num;
    margin-top: 80px;
    width: 90%;
}
#cms_6-d .cate_box.noimg:after, .cms_6-d .cate_box.noimg:after {
    background-color: #f6f4eb;
}
#cms_6-d .cate_box:after, .cms_6-d .cate_box:after {
    counter-increment: num;
    color: #b6a689;
}
#cms_6-d .cate_box.noimg:after, .cms_6-d .cate_box.noimg:after {
    background-color: transparent;
}
/* よくある質問 */
#cms_5-d .box_title1,.cms_5-d .box_title1{
    padding-left: 55px;
}
#cms_5-d .box_title1:before, .cms_5-d .box_title1:before {

    border-color: #f6f4eb transparent;
}
#cms_5-d .Quest,.cms_5-d .Quest{
    position: absolute;
    left: 25px;
}
#cms_5-d .box_txt1,.cms_5-d .box_txt1{
    padding-left: 50px;
}
#cms_5-d .answer,.cms_5-d .answer{
    position: absolute;
    left: 25px;
}
/* 会社情報 */
/* お問い合わせ */
/* プライバシーポリシー */
/* サイトマップ */
#page10 li a{
    color: #493823;
}


/*-------------------------------------------------------
			          タブレット
-------------------------------------------------------*/
@media screen and (max-width: 768px){
.font_12_tb{font-size: 14px;}
.font_14_tb{font-size: 16px;}
.font_16_tb{font-size: 18px;}
.font_18_tb{font-size: 20px;}
.font_20_tb{font-size: 22px;}
.font_22_tb{font-size: 24px;}
.font_24_tb{font-size: 26px;}
.font_26_tb{font-size: 28px;}
.font_28_tb{font-size: 30px;}
.font_30_tb{font-size: 32px;}
.font_100per_tb{
font-size: -webkit-calc(1rem + 2px);
font-size: calc(1rem + 2px);
}
.font_2up_tb{
font-size: -webkit-calc(1rem + 4px);
font-size: calc(1rem + 4px);
}
.font_4up_tb{
font-size: -webkit-calc(1rem + 6px);
font-size: calc(1rem + 6px);
}
.font_6up_tb{
font-size: -webkit-calc(1rem + 8px);
font-size: calc(1rem + 8px);
}
.font_8up_tb{
font-size: -webkit-calc(1rem + 10px);
font-size: calc(1rem + 10px);
}
.font_10up_tb{
font-size: -webkit-calc(1rem + 12px);
font-size: calc(1rem + 12px);
}
.font_2dw_tb{
font-size: -webkit-calc(1rem);
font-size: calc(1rem);
}    
/* ----------　all　---------- */  
.mainwrap-r h1 {
    width: 130px;
} 
#sp_nav h3{
    color: #e87463;
    border-color: #e87463;
}
.loader_icon {
    width: 170px;
}
.fixbnr {
    bottom: 7px;
}
/* ----------　TOP　---------- */
#main_img .catch_img {
    top: 47%;
}
.interview_img{
    max-width: 400px;
    width: 100%;
    margin-top: 50px;
}
#top_contents1 .intro_img {
    max-width: 330px;
    top: -80px;
    left: 20px;
}
#top_contents1 .con_title{
    text-align: left;

}
#flow .con_title {
    text-align: left;
}
#flow .flow_img2 {
    max-width: 160px;
}
/* ---------- loopSlider ---------- */
#topcms_gallery_type1,#topcms_gallery_type1 .loopSliderWrap,#topcms_gallery_type1 .loopSlider,#topcms_gallery_type1 .loopSlider ul,#topcms_gallery_type1 .loopSlider .ul .li{
	height: 280px;
}
#topcms_gallery_type1 .loopSlider .ul .li{
    width: 280px;
}
#topcms_gallery_type1 {
    padding-bottom: 0;
    padding-top: 0;
}
/* ----------　下層ページ　---------- */
/* ホームウエストについて */
#cms_2-g .cate_box{
    margin-top: 30px;
    padding-bottom: 30px;
}

}
/*-------------------------------------------------------
		            	スマホ
-------------------------------------------------------*/
@media screen and (max-width: 667px){
.font_8up {
    font-size: -webkit-calc(1rem + 6px);
    font-size: calc(1rem + 6px);
}
.font_12_sp{font-size: 14px;}
.font_14_sp{font-size: 16px;}
.font_16_sp{font-size: 18px;}
.font_18_sp{font-size: 20px;}
.font_20_sp{font-size: 22px;}
.font_22_sp{font-size: 24px;}
.font_24_sp{font-size: 26px;}
.font_26_sp{font-size: 28px;}
.font_28_sp{font-size: 30px;}
.font_30_sp{font-size: 32px;}
.font_100per_sp{
font-size: -webkit-calc(1rem + 2px);
font-size: calc(1rem + 2px);
}
.font_2up_sp{
font-size: -webkit-calc(1rem + 4px);
font-size: calc(1rem + 4px);
}
.font_4up_sp{
font-size: -webkit-calc(1rem + 6px);
font-size: calc(1rem + 6px);
}
.font_6up_sp{
font-size: -webkit-calc(1rem + 8px);
font-size: calc(1rem + 8px);
}
.font_8up_sp{
font-size: -webkit-calc(1rem + 10px);
font-size: calc(1rem + 10px);
}
.font_10up_sp{
font-size: -webkit-calc(1rem + 12px);
font-size: calc(1rem + 12px);
}
.font_2dw_sp{
font-size: -webkit-calc(1rem);
font-size: calc(1rem);
}    
/* ----------　all　---------- */  
.fixbnr {
    width: 150px;
}
.mainwrap-r h1 {
    width: 100px;
}
footer{
    padding-bottom: 100px;
}
/* ----------　TOP　---------- */
#main_img .catch_img {
    top: 45%;
    width: 95%;
}
#top_contents1 .intro_img {
    width: 60%;
    top: -45px;
}
#flow {
    padding: 100px 0 160px;
}
#flow .flow_con {
    width: 100%;
}
#flow .flow_con a {
    padding: 10px 0;
    font-size: 16px;
}
#flow .flow_img2 {
    max-width: 140px;
    bottom: -20px;
}
#attach {
    height: 250px;
}
/* ---------- loopSlider ---------- */
#topcms_gallery_type1,.loopSliderWrap,.loopSlider,.loopSlider .ul,.loopSlider .ul .li{
	height: 179px!important;
}
#topcms_gallery_type1 .loopSlider .ul .li{
    width: 179px;
}
#topcms_gallery_type1 .btn a::after {
    bottom: 35px;
    right: 27%;
}
#topcms_gallery_type1 .btn a::before {
    bottom: 30px;
    right: 27%;
}
#topcms_gallery_type1 .btn a {
    width: 140px;
    height: 140px;
    line-height: 1.7;
}
/* ----------　下層ページ　---------- */
#page_title .title_wrap h2 {
    font-size: 22px;
}
}