﻿/* font -----------------------------------------------------------------------------*/

:root {
    --font-jp: 'Noto Sans JP', "游ゴシック Medium", "游ゴシック体", "Yu Gothic Medium", YuGothic, "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
    --font-en: "Barlow Condensed", "游ゴシック Medium", "游ゴシック体", "Yu Gothic Medium", YuGothic, "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}

body{
	font-family:  var(--font-jp) !important;
}

input, .catch h2,.catch .font_4up{
	font-family:  var(--font-jp) !important;
}
h1, h2, h3, h4, h5, h6 ,#topCms .cmstitle p, .pagetitle .title_box p,.pc_nav li .page_title,#sp_nav .sp_nav_inner .l-menu .l-menu_cms, .sub_title, #content .swiper-button-next p, #content .swiper-button-prev p, .font_mo, .modal-open span,.title_en_item,.more a,#bottom_tel a{
	font-family:  var(--font-en) !important;
	font-weight: 500;
}

#top_contents1 h2,#top_contents2 h2,#top_cms h2,.title_box h2,.gyoumu_box h2{
        font-size: calc(1rem + 11px);
}

#top_contents1 h2 {
    font-size: calc(1rem + 16px);
}

.font_2dw {
    font-size: calc(1rem + 1px) !important;
    letter-spacing: 0px;
}
/* font -----------------------------------------------------------------------------*/



#top_contents1 h2,#top_contents2 h2,#top_cms h2,.title_box h2,.gyoumu_box h2{
        font-size: calc(1rem + 11px);
        font-weight: 800;
}

#top_contents1 h2 {
    font-size: calc(1rem + 16px);
}

.font_2dw {
    font-size: calc(1rem + 1px) !important;
    letter-spacing: 0px;
}


h1, h2, h3, h4, h5, h6 ,.catch ,#topCms .cmstitle p, .pagetitle .title_box p,.pc_nav li .page_title,#sp_nav .sp_nav_inner .l-menu .l-menu_cms, .f_contact_btn a{
	font-family:  "Noto Sans JP","Hiragino Kaku Gothic ProN", "游ゴシック体", YuGothic, "YuGothic M", meiryo, sans-serif;
}
/* color -----------------------------------------------------------------------------*/
:root{
    --color1: #4e9f3d;
    --color2: #D8E9A8;
    --color3: #1E5128;
    --color4: #ededed;
    --color5:#EBECF1;
    --white:#ffffff;
    --black:#1b1c25;
    --gray:#ccc;
}

body,.txt_color_nomal,.hvr_txt_color_nomal:hover{color: var(--black);}
.txt_white,.hvr_txt_white:hover{color: var(--white);}
.txt_color1,.hvr_txt_color1:hover{color: var(--color1);} /* メインカラー */
.txt_color2,.hvr_txt_color2:hover{color: var(--color2);} /* サブカラー */
.txt_color3,.hvr_txt_color3:hover{color: var(--color3);} /* アクセントカラー1 */
.txt_color4,.hvr_txt_color4:hover{color: var(--color4);} /* アクセントカラー2 */
.txt_color5,.hvr_txt_color5:hover{color: var(--color5);} /* アクセントカラー2 */
/* background-color */
.bg_white,.hvr_bg_white:hover{background-color: var(--white)} /* 白背景 */
.bg_black,.hvr_bg_black:hover{background-color: var(--black);} /* 黒背景 */
.bg_color1,.hvr_bg_color1:hover{background-color: var(--color1);} /* メインカラー */
.bg_color2,.hvr_bg_color2:hover{background-color: var(--color2);} /* サブカラー */
.bg_color3,.hvr_bg_color3:hover{background-color: var(--color3);} /* アクセントカラー1 */
.bg_color4,.hvr_bg_color4:hover{background-color: var(--color4);} /* アクセントカラー2 */
.bg_color5,.hvr_bg_color5:hover{background-color: var(--color5);} /* アクセントカラー2 */
.bg_color_clear,.hvr_bg_color_clear:hover{background-color: transparent!important;}
/* border-color ※!important */
.border_white,.hvr_border_white:hover{border-color: var(--white);}
.hvr_border_black:hover{border-color: var(--black);}
.border_black{border-color: var(--gray);}
.border_color1,.hvr_border_color1:hover{border-color: var(--color1);}
.border_color2,.hvr_border_color2:hover{border-color: var(--color2);}
.border_color3,.hvr_border_color3:hover{border-color: var(--color3);}
.border_color4,.hvr_border_color4:hover{border-color: var(--color4);}
.border_color5,.hvr_border_color5:hover{border-color: var(--color5);}

.linkStyle{
    color: var(--color1);
    border-bottom:solid 1px;
}

.linkStyle:hover{
	color: var(--color3);
	opacity: 0.7;
	transition: all 0.5s;
}

body#body {
    background: var(--white);
}
/* color -----------------------------------------------------------------------------*/


/* ----------　all　---------- */
.linkStyle{
	color:var(--color1);
}

.linkStyle:hover{
	color:var(--color1);
	opacity: 0.7;
	transition: all 0.5s;
}

#sp_nav .sp_nav_inner .l-menu ul li a span {
    display: none;
}

#sp_nav .sp_nav_inner .l-menu ul li a:hover {
    color: var(--color2);
}

#sp_nav .sp_nav_inner .l-menu ul li a {
    font-weight: 400;
}

#bottom_tel a {
    height: 92px;
    border-right: 1px solid;
    box-sizing: border-box;
    transition: .3s;
    background: var(--color1);
    color: #fff;
}

#bottom_tel a:hover {
    background: var(--color3);
    color: var(--color5);
}

#bottom_tel a span .tel_another {
    font-size: calc(1rem + 0px) !important;
    letter-spacing: 0px;
}

#bottom_tel a span i, .f_contact_btn a span i,.contact_tel a i{
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    font-style: initial;
}

.f_con_bgcolor {
    background: #000;
    opacity: 0.3;
}

.pc_nav .page_title {
    font-weight: 800 !IMPORTANT;
}
/* ----------------------------------------------------------------------------------------------　top　----------------------------------------------------------------------------------------------------------------- */
#main_img .swiper-slide:before,#main_img .swiper-slide:after{
    content: "";
    background: var(--color1);
    position: absolute;
}

#main_img {
    background-color: var(--color5);
    height: auto !important;
    padding-bottom: 20vh;
}

#main_img::before {
    pointer-events: none;
}

.slider1 {
    transform: rotate(-3deg);
}

#main_img:after {
    height: 30%;
    background: linear-gradient(0deg, #fff 14%, transparent);
    opacity: 1;
    z-index: 0;
}

#content .box_img img {
    height: auto !important;
    width: 100% !important;
}

#content {
    background-color: linear-gradient(180deg, var(--color4), transparent);
    background-image: url(/Files/img/content_bg.png);
    background-size: cover;
    background-position: bottom;
    background-repeat: no-repeat;
}

.footer .footertxt {
    color: var(--black);
}

.copy {
    background-color: var(--color1);
    color: var(--white);
}



/* ---------------------------------------　topCms　▼--------------------------- */

#topCms .cmstitle p, .pagetitle .title_box p {
    font-weight: 200;
}

/* ---------------------------------------　topCms　▲--------------------------- */



/* -----------------------------------------------------------------------------------------------　下層ページ　--------------------------------------------------------------------------------------------------------- */
.pagetitle {
    background-color: linear-gradient(180deg, var(--color4), transparent);
    background-image: url(/Files/img/page_bg.png);
    background-size: cover;
    background-position: bottom;
    background-repeat: no-repeat;
}

#cms_2-g .cate_title {
    line-height: 1;
    font-size: 2.2em;
}

#page2 .footer_contact:before,#page3 .footer_contact:before,#page4 .footer_contact:before,#page5 .footer_contact:before,#page6 .footer_contact:before,#page7 .footer_contact:before,#page8 .footer_contact:before,#page9 .footer_contact:before,#page10 .footer_contact:before {
    content: "";
    position: absolute;
    width: 100px;
    height: 20px;
    top: -2px;
    left: 50%;
    transform: translateX(-50%);
    clip-path: polygon(0 0, 50% 100%, 100% 0);
    background-color: var(--white);
    z-index: 1;
}

.contact__tel h3 {
    font-family: var(--font-jp) !important;
}

/* サイトマップ */
#page10 .sitemap li .sub {
    font-weight: 300;
}

/*-----------------------------------------------------------------------------------------------------------1000----------------------------------------------------------------------------------------------------------*/
@media screen and (max-width: 1000px){
}

/*---------------------------------------------------------------------------------------------------------タブレット------------------------------------------------------------------------------------------------------*/
@media screen and (max-width: 768px){

/* ----------　all　---------- */
#bottom_tel a {
    height: 50px;
}
/* ----------　TOP　---------- */
#main_img {
    padding-bottom: 14vh;
}

.catch.slide_ver {
    padding-right: 30px;
    max-width: 97%;
}

#main_img::before {
    top: 65%;
    height: 195px;
    background-size: auto 35%;
    animation: loop 50s linear infinite;
}

#content .box_img {
    max-height: 350px;
    overflow: hidden;
  }

#content .cate_item {
    padding: 30px 15px 40px 35px;
}
}

/*---------------------------------------------------------------------------------------------------------スマホ----------------------------------------------------------------------------------------------------------*/
@media screen and (max-width: 667px){
.header .logo1{padding-right: 0px;max-width: 120px;padding: 20px 0;}

#video video {
    padding-top: 70px;
}
/* ----------　all　---------- */
#fakeloader .fl {
    width: 70% !important;
}
.copy {
    padding-top: 10px;
    padding-bottom: 60px;
}
/* ----------　TOP　---------- */
#main_img {
    padding-bottom: 22vh;
    padding-top: 20px;
}

#main_img::before {
    top: 67%;
    height: 115px;
}

#main_img:after {
    height: 40%;
    background: linear-gradient(0deg, #fff 34%, transparent);
    opacity: 1;
    z-index: 1;
}

.catch:after {
    display: none;
}

.catch.slide_ver {
    right: 25px;
    max-width: 100%;
    padding-top: 0px;
    padding-right: 0px;
    bottom: 20px;
    padding-left: 5px;
    padding-bottom: 10px;
}

.intro_title_en {
    top: 50px;
    left: 5px;
    font-size: calc(1rem + 9px);
}

.intro_inner {
    width: 85%!important;
}

.intro_inner h2 {
    line-height: 1.4;
    font-size: -webkit-calc(1rem + 3px);
    font-size: calc(1rem + 6px);
}

.pagetitle .title_box p {
    bottom: -20px;
}

#cms_2-g .cate_title {
    font-size: 1.8em;
}

#content {
    position: relative;
    top: -2px;
    background-position: top;
}

#content .box_img {
    max-height: 280px;
}

#content .box_img img {
    height: 100% !important;
    width: auto !important;
}

.modal_title1 {
    padding-top: 0px;
    text-indent: 0.8em;
}

.intro_inner h2 {
    font-size: -webkit-calc(1rem + 3px);
    font-size: calc(1rem + 4px);
    letter-spacing: 0;
}

#content .box_title{
    font-size: -webkit-calc(1rem + 2px);
    font-size: calc(1rem + 2px);
    letter-spacing: 0;
}

.modal_title1 {
    padding-top: 0px;
    font-size: -webkit-calc(1rem + 2px);
    font-size: calc(1rem + 1px);
    letter-spacing: 0;
}

}