.h1_left .headding_wrap,.h1_left .headding{font-size:3.5rem}.h1_left .subtitle_wrap{letter-spacing:0.15em;margin-top:.5rem}.h1_left .subtitle{font-size:inherit}.h1_left .editable_wrap{margin-top:2rem}
.title_text .text-side{max-width:850px;margin:auto;text-align:center}.title_text .text-side .text{text-align:left}@media only screen and (min-width:768px){.title_text .text-side .text{text-align:center}}
@charset "UTF-8";#footer-section {z-index: 3;} @media only screen and (max-width:768px) {.jobs #footer-section .detail-side {display: none;}}.footer-block .footer_menu .detail-side{bottom:0;transition:bottom .5s}.footer_menu{font-size:1.4rem}.footer_menu .logo-side{padding:4rem 0;text-align:center}.footer_menu .logo{width:200px;margin:0 auto 2rem}.footer_menu .logo img{width:auto;max-width:100%}.footer_menu .logo div{display:inline}.footer_menu .menu-side{display:none}.footer_menu .detail-side{text-align:center;font-size:1.4rem;display:-ms-flexbox;display:flex;-ms-flex-direction:row-reverse;flex-direction:row-reverse;background-color:#fff;position:fixed;bottom:-100%;left:0;width:100%;transition:bottom .8s .2s}.footer_menu .detail-side_first{width:80px;display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center;position:relative}.footer_menu .detail-side_first .tel{line-height:1.4;letter-spacing:0}.footer_menu .detail-side_first .tel a{position:absolute;width:100%;height:100%;top:0;left:0}.footer_menu .detail-side_first .tel:after{content:"phone";font-family:"Material Icons";font-size:3.6rem;font-weight:400;font-style:normal;display:inline-block;line-height:1;text-transform:none;letter-spacing:normal;word-wrap:normal;white-space:nowrap;direction:ltr;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;-moz-osx-font-smoothing:grayscale;-webkit-font-feature-settings:"liga";font-feature-settings:"liga"}.footer_menu .detail-side_first .hour{font-size:1.2rem;display:none}.footer_menu .detail-side_second{-ms-flex-positive:1;flex-grow:1}.footer_menu .letter{letter-spacing:.1em}.footer_menu .copy{border-top:1px solid #ccc;font-size:1.2rem;padding:2rem 0;text-align:center}.footer_menu .sns-side{margin-bottom:2rem}.footer_menu .sns-side .duplicatable-container{display:-ms-flexbox;display:flex;-ms-flex-pack:center;justify-content:center}.footer_menu .sns-side .duplicatable-content{max-width:70px;padding:0 1rem}.footer_menu .section_btn a{white-space:nowrap}.footer_menu .back-top{cursor:pointer;width:40px;height:40px;border-radius:20px;border:1px solid #f44336;position:absolute;bottom:10px;right:10px;display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center}.footer_menu .back-top .arrow:before{content:"▲";color:#f44336}@media only screen and (min-width:768px){.footer_menu .footer-company{padding:3.5rem 0 5.5rem}.footer_menu .logo-side{padding:0;display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;-ms-flex-pack:justify;justify-content:space-between;margin-bottom:4rem}.footer_menu .logo{margin:0 2rem 0 0}.footer_menu .menu-side{width:80%;display:block}.footer_menu .menu-side .duplicatable-container{display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap;text-align:center;-ms-flex-pack:end;justify-content:flex-end}.footer_menu .menu-side .duplicatable-content{width:auto;padding:0 0 0 4rem;font-size:1.4rem}.footer_menu .detail-side{-ms-flex-direction:row;flex-direction:row;-ms-flex-pack:justify;justify-content:space-between;text-align:left;width:50%;margin:auto 0 auto auto;position:static;background-color:transparent}.footer_menu .detail-side_first{margin-bottom:4rem;font-size:1.8rem;display:block}.footer_menu .detail-side_first .tel{font-size:2.2rem}.footer_menu .detail-side_first .tel:after{content:none}.footer_menu .detail-side_first .tel a{position:relative;pointer-events:none}.footer_menu .detail-side_first .hour{display:block}.footer_menu .detail-side_second{margin-bottom:3rem}.footer_menu .detail-side>div{margin-bottom:0;width:100%}.footer_menu .copy{padding:1.5rem 0;display:-ms-flexbox;display:flex;-ms-flex-pack:justify;justify-content:space-between;-ms-flex-align:center;align-items:center}.footer_menu .sns-side{margin-bottom:0}.footer_menu .sns-side .duplicatable-content{width:60px}.footer_menu .section_btn{margin:auto 0 auto auto}.footer_menu .back-top{bottom:80px}}@media only screen and (max-width:768px){.footer_menu .detail-side_first .tel{font-size:0!important}.footer_menu .detail-side_second .section_btn{max-width:none}.footer_menu .detail-side_second .section_btn a{border-radius:0}}@media only screen and (max-width: 768px){_::-webkit-full-page-media,_:future,:root .detail-side_first{text-align:center}_::-webkit-full-page-media,_:future,:root .tel.letter.editable{display:grid}}
@charset "UTF-8";#section-wrapper{background-color:#fff}#section-wrapper .headding{    font-family: YakuHanMP, 'Noto Serif', 'Hiragino Mincho ProN', eatYuM, 'Sawarabi Mincho', Meiryo, serif;
    line-height: ;
    letter-spacing: em;
}#section-wrapper .subtitle{    font-family: YakuHanMP, 'Noto Serif', 'Hiragino Mincho ProN', eatYuM, 'Sawarabi Mincho', Meiryo, serif;
    line-height: ;
    letter-spacing: em;
}#section-wrapper .letter{    font-family: YakuHanMP, 'Noto Serif', 'Hiragino Mincho ProN', eatYuM, 'Sawarabi Mincho', Meiryo, serif;
    line-height: ;
    letter-spacing: em;
}@media only screen and (min-width:769px){}#loading{position:fixed;top:0;width:100%;height:100%;background:rgba(0,0,0,0.5);z-index:9999;display:none}#loading .loading_inner{width:100%;height:90px;position:absolute;top:50%}#loading .loading_inner .loader_animation,#loading .loading_inner .loader_animation:before,#loading .loading_inner .loader_animation:after{border-radius:50%;width:2.4rem;height:2.4rem;-webkit-animation-fill-mode:both;animation-fill-mode:both;-webkit-animation:load7 1.3s infinite ease-in-out;animation:load7 1.3s infinite ease-in-out}#loading .loading_inner .loader_animation{color:#fff;font-size:12px;margin:10px auto;position:relative;top:-30px;text-indent:-9999rem;-webkit-transform:translateZ(0);transform:translateZ(0);-webkit-animation-delay:-0.16s;animation-delay:-0.16s}#loading .loading_inner .loader_animation:before,#loading .loading_inner .loader_animation:after{content:'';position:absolute;top:0}#loading .loading_inner .loader_animation:before{left:-3.4rem;-webkit-animation-delay:-0.32s;animation-delay:-0.32s}#loading .loading_inner .loader_animation:after{left:3.4rem}@-webkit-keyframes load7{0%,80%,100%{box-shadow:0 2.45rem 0 -1.25rem}40%{box-shadow:0 2.45rem 0 0}}@keyframes load7{0%,80%,100%{box-shadow:0 2.45rem 0 -1.25rem}40%{box-shadow:0 2.45rem 0 0}}#loading .circle{position:fixed;top:50%;left:50%;width:50px;height:50px;margin:-25px 0 0 -25px;border-radius:50%;border:8px solid #f00;border-right-color:transparent;-webkit-animation:spin .8s linear infinite;animation:spin .8s linear infinite}@-webkit-keyframes spin{0%{-webkit-transform:rotate(0deg);transform:rotate(0deg);opacity:.2}50%{-webkit-transform:rotate(180deg);transform:rotate(180deg);opacity:1.0}100%{-webkit-transform:rotate(360deg);transform:rotate(360deg);opacity:.2}}@keyframes spin{0%{-webkit-transform:rotate(0deg);transform:rotate(0deg);opacity:.2}50%{-webkit-transform:rotate(180deg);transform:rotate(180deg);opacity:1.0}100%{-webkit-transform:rotate(360deg);transform:rotate(360deg);opacity:.2}}

/* フォント設定 */
/* テキスト--ゴシック */
#section-wrapper .letter,
#section-wrapper  .subtitle {
    font-family:"Hiragino Kaku Gothic Pro","ヒラギノ角ゴ Pro W3","メイリオ","Meiryo","ＭＳ Ｐゴシック","Helvetica Neue","Helvetica","Arial",sans-serif;
    font-size: 1.5rem;
}

/* タイトル--ゴシック */
    #section-wrapper .headding{
        font-family: YakuHanMP, 'Noto Serif', 'Hiragino Mincho ProN', eatYuM, 'Sawarabi Mincho', Meiryo, serif;
    }

@media only screen and (max-width: 767px){ 
    .mainvisual_crossfade_slider .text-side .headding,
    .title_all .section_h3,
    .h2_section .section_h2,
    .h2_bgfix .headding,
    .h1_left .headding{
        font-size: 2.5rem !important;
    }  
}

@media only screen and (min-width: 1025px){
/*グローバルナビゲーション--hover--アンダーバー*/
    .gnav_items li a{
        position: relative;
    }

    .gnav_items li a::before {
        content: "";
        width: 0;
        height: 1px;
        background: #fff;
        transition: all 0.3s ease 0s;
        position: absolute;
        bottom: -2px;
        display: inline-block;
    }

    .gnav_items .active a,
    .gnav_items li a:hover{
        opacity: 1;
    }

    .gnav_items .active a::before,
    .gnav_items li a:hover::before {
        width: calc(100% - 20px);
    }

}

@media only screen and (max-width: 1024px){
    .gnav-wrap .gnav_sp .drawer-toggle span{
        background-color: #fff !important;
    }
    .gnav-wrap .gnav_sp .drawer-nav li a{
        color: #fff;
    }
}

@media only screen and (max-width: 767px){
.gnav-wrap .gnav_sp .drawer-nav li a{
    padding: 12px 10px;
}
}

/*電話番号調整*/
.footer_menu .detail-side_first .tel a{
    pointer-events: auto;
}

/*施工事例・ブログアーカイブの崩れ修正*/
.showcase_chart .showcase_chart_popnews_item_title_wrap, .blog_posts .blog_chart_popnews_item_title_wrap{
    display:block !important;
}

.showcase_chart .showcase_chart_popnews_item_day, .blog_posts .post_popnews_data{
    text-align: left !important;
}

.blog_text_list .blog-side .category,
.showcase_group_info a.showcase_tag_link{
    background-color: #666;
}

/*blog_リンク色*/
.blog_posts .banner_text ._color_,
.showcase_chart .banner_text ._color_,
.banner_text ._color_{
    color: #666 !important;
}
.blog_posts .blog_post .notice, .blog_posts .post_item .notice,
.category_attention,
.elation_posts_section .category_attention,
.showcase_chart .showcase_chart_item .notice{
	background-color: #666 !important;
}

/*送信ボタン*/
.banner_text .banner_link,
.formapps .section_btn input{
    background-color: #fff !important;
    color:#333 !important;
    border:solid 1px #333;
}
.banner_text .banner_link:hover,
.formapps .section_btn input:hover{
    background-color: #333 !important;
    color:#fff !important;
}

/*サイトマップ*/
#section_246855 .editable a{
    line-height: 4rem;
    text-decoration: underline;
}
#section_246855 .editable a:hover{
    text-decoration: none;
}

/*footer_矢印色*/
#footer-section .back-top{border-color: #fff !important;}
#footer-section .back-top .arrow:before{color: #fff !important;}
#footer-section .footer-company::before{display: none;}

/*ブログカテゴリー*/
.showcase_group_info a.showcase_tag_link{
    background-color: #333 !important;
}

/*ボタン一括01*/
.section_btn a{
    position: relative;
}

@media only screen and (min-width: 768px){
    .section_btn a::before, .section_btn a::after {
        position: absolute;
        display: block;
        content: '';
        height: 1px;
        background-color: #fff;
        transition: all .3s;
    }

    .section_btn a::before {
        width: 24px;
        top: 50%;
        left: calc(100% - 48px);
    }

    .section_btn a::after {
        width: 8px;
        top: calc(50% - 2.4px);
        left: calc(100% - 30.8px);
        transform: rotate(
    40deg
    );
    }

    .section_btn a:hover {
        background-color: #fff !important;
        color: #333 !important;
        opacity: 1;
    }

    .section_btn a:hover::before {
        width: 29px;
        background-color: #333 !important;
    }

    .section_btn a:hover::after {
        left: calc(100% - 25.8px);
        background-color: #333 !important;
    }

}


/*SP調整*/
@media only screen and (max-width: 767px){
	/*120pxの余白を60pxに変更*/
	.spaceable-top[style*="120px"]{padding-bottom: 60px !important;}
	.spaceable-bottom[style*="120px"]{padding-bottom: 60px !important;}
	/*100pxの余白を40pxに変更*/
	.spaceable-top[style*="100px"]{padding-bottom: 40px !important;}
	.spaceable-bottom[style*="100px"]{padding-bottom: 40px !important;}
	/*60pxの余白を20pxに変更*/
	.spaceable-top[style*="60px"]{padding-bottom: 20px !important;}
	.spaceable-bottom[style*="60px"]{padding-bottom: 20px !important;}

	/*blog系余白調整*/
	.blog_coloroverlay > .spaceable-top{padding-bottom: 0 !important;}
	.blog_coloroverlay > .spaceable-bottom{padding-bottom: 0 !important;}
	.portfolio_standerd > .spaceable-top{padding-bottom: 0 !important;}
	.portfolio_standerd > .spaceable-bottom{padding-bottom: 0 !important;}

	/*table font-size 調整*/
	.table_wrap .tr{font-size: 1.5rem;}
	.table_wrap .duplicatable-content:nth-child(n+2){padding-top: 0 !important;}
	.table_wrap .tr .th{font-weight: bold;}
    .table_wrap .tr .td{padding-top: 1rem !important;}
}
@media only screen and (max-width: 1024px){    
    /*施工事例調整*/
        .showcase_chart{
        padding: 0 !important;
    }
    }
    .new_catchcopy_simple .text-wrap{
        padding: 3rem 4rem;
    }
    
@media only screen and (min-width: 768px){
    .footer_menu .detail-side{
        width: 70%;
    }
    /*infomation_allのボタン位置調整*/
    .infomation_all .info-side_text{
        margin-top:8px;
    }
}

@media only screen and (max-width: 767px){
    /*half_wide_limited_height*/
    .half_wide_limited_height .text-side_innerr{
        max-width: 100%;
        padding: 0 2rem;
    }
}
@media only screen and (min-width: 768px){
    .half_wide_limited_height .image-side {
        max-height: 100%;
    }
    .half_wide_limited_height .duplicatable-content:not(:last-child){
        padding-bottom: 80px;
    }
    }

.formapps_border_light .form_area .form-item:not(.send_btn) div{
    padding: 0;
}

.fit_card_one .text-side_inner,
.card_one .text-side_inner,
.half_fit_card .text-side_inner {
    max-width: 100%;
}

.new_list_box .image-side{
    display: none;
}

#section_246805 .fit_card_one .image-side .frame-image{
    background-attachment: fixed;
}

/*.mainvisual_crossfade_slider .image-side {
    background-color: #afa39d;
}

.mainvisual_crossfade_slider .image-side .flamingo-slider-wrapper{
    margin-left: 20vw;
}*/

@media only screen and (min-width: 768px) {
.carousel_section .carousel-item {
    margin: 0 5px!important;
}
}


@media only screen and (min-width: 1025px) {
.width-limit .section_inner {
    max-width: unset;
    margin: 0 5%;
}
}
#section_246851 .image-side .frame-image {
	background-size: contain;
}

@media only screen and (min-width: 768px){
.footer_menu .menu-side {
width: 100%!important;
}
.footer_menu .footer-company {
    padding: 3.5rem 0 2.5rem;
}
.footer_menu .menu-side .duplicatable-content {
    padding: 0 0 0 3rem;
}

.links_sns .image-frame {
width: 60px;
}

.block_vertical_two {
   padding: 3% 0 6%;
}

.block_vertical_two .image-side_inner .image-frame_wrap {
    padding-top: 65%;
}

}

/*20210513修正*/

.block_vertical_two .image-side_inner .image-frame_wrap:nth-child(1) {
    margin-top: 10%;
}

.block_vertical_two .image-side_inner .image-frame_wrap:nth-child(2) {
    margin-bottom: 10%;
}


@media only screen and (min-width: 768px){
#section_254480 .half_limited_height .image-side {
    max-height: none;
}
}


#section_254479 .duplicatable-content_inner {
    position: relative;
}

.half_fit_card .text-side {
    opacity: 0;
    -webkit-transition: all 4s;
    -moz-transition: all 4s;
    -o-transition: all 4s;
    -ms-transition: all 4s;
    transition: all 4s;
transform: translateY(20px);
z-index: 2;
}
 
.half_fit_card .text-side.fade_on {
    opacity: 1;
transform: translateY(0);
}

.half_fit_card .section_btn a {
    background-color: transparent;
}

/*
#section_254479 .new_standard_content_two .image-side .image-frame {
    padding-top: 40%;
}
*/

#section_254479 .new_standard_content_two .text-side .section_btn {
    margin-top: unset;
}

#section_254479 .new_standard_content_two .duplicatable-content {
    position: relative;
}

#section_254479 .new_standard_content_two .text-side {
    right: 0;
    color: #fff;
    bottom: 0;
    position: relative;
    padding: unset;
    position: absolute;
    width: 100%;
    z-index: 1;
}

#section_254479 .new_standard_content_two .text-side .subtitle_wrap {
    margin-top: unset;
}

#section_254479 .new_standard_content_two .text-side .editable_wrap {
    margin: .5rem 0;
}

#section_254479 .new_standard_content_two .section_h3 {
    color: #fff;
    font-weight: bold;
}

#section_254479 .new_standard_content_two .image-side {
    overflow: hidden;
}

#section_254479 .new_standard_content_two .image-side::before {
    content: "";
    width: 100%;
    height: 100%;
    background-color: #000000;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 1;
    pointer-events: none;
    opacity: .3;
}

#section_254479 .new_standard_content_two .text-side_inner {
    padding-right: 2rem;
    text-align: right;
    display: inline-block;
position: absolute;
    right: 0;
    bottom: 0;
}

#section_254479 .new_standard_content_two .image-side a::after {
    content: "";
    height: 0;
    width: 0px;
border-bottom: 37em solid #222;
    border-left: 13em solid transparent;
    position: absolute;
    right: 0;
    top: 0;
    transition: .3s ease;
}

#section_254479 .new_standard_content_two .image-side a:hover::after {
    width: 300px;
    opacity: 1;
}

#section_254479 .new_standard_content_two .image-side a:hover {
    opacity: 1;
}


#section_254479 .new_standard_content_two .text-side .editable_wrap .letter {
    font-size: 1.2rem;
}

@media (min-width:768px) {

#section_254479 .new_standard_content_two .duplicatable-content:nth-child(1) {
    margin-bottom: 5%;
}

#section_254479 .new_standard_content_two .duplicatable-content:nth-child(2) {
    margin-top: 5%;
}

.footer_menu .detail-side_first .tel a {
    color: #fff;
}

}

@media (max-width:767.9px){
#section_254474 .half_fit_card .text-side, 
#section_254473 .half_fit_card .text-side {
    margin: -109% auto 0;
}

#section_254474 .half_fit_card .image-side .image-frame-bg, 
#section_254473 .half_fit_card .image-side .image-frame-bg {
    padding-top: 120%;
}
}

@media (min-width: 769px){
.flamingo-slider-wrapper .flamingo-slider-slide img {
width:90%;
}
}

.mainvisual_right_slider .catch,
.half_out_of_position .frame-image{
background-color:#cccccc99;
}

.new_drawer_dropdown .header_logo img {
width:100%;
}

.width-limit .section_inner{
max-width:100%;
}


#global-nav:not(.__settings):not(.__settings) .new_drawer_dropdown .header_logo, #global-nav:not(.__settings):not(.__settings) .new_drawer_slidein .header_logo {
    max-width: 160px!important;
height: auto;
}

#global-nav:not(.__settings):not(.__settings) .new_drawer_dropdown .header_logo img, #global-nav:not(.__settings):not(.__settings) .new_drawer_slidein .header_logo img {
    height: 100%!important;
}

@media (max-width:767.9px) {
.mainvisual_right_slider {
    height: 100vw;
}

.mainvisual_right_slider .section_inner {
    height: 100vw;
    width: 100%;
}

.mainvisual_right_slider .catch {
    padding: 1.5em;
    width: 100%;
    left: 0%;
}

}