﻿/*--------------------------------------------
 色 ・　文字
----------------------------------------------*/
:root{
    --color1: #4266b8;
    --color2: #f3f9ff;
    --color3: #65cdff;
    --color4: #e5f9ff;
	--text: #333;
    --base: #ffffff;
    
    --font1: 16px;
    --fontB1: 48px;
    --fontB2: 40px;
    --font-jp: 'Noto Sans JP', "游ゴシック Medium", sans-serif;
}
/* タブレット */
@media screen and (max-width: 768px){
    :root{
        --fontB1: 32px;
    }
}
/* スマホ */
@media screen and (max-width: 667px){
    :root{
        --fontB1: 26px;
        --fontB2: 24px;
    }
}
/*--------------------------------------------
 装飾
----------------------------------------------*/
#intro{position: relative;}
#intro #intro_txt{
    position: relative;
    z-index: 2;
}
#intro::before {
	position: absolute;
	opacity: 0.3;
	z-index: 0;
	content: "";
	right: 0;
	bottom: -150px;
	width: 100%;
	height: 227px;
	background-image: url("../dup/img/dec_01.png");
	background-size: auto 100%;
	background-position-y: 0;
	background-position-x: 0;
	background-repeat: repeat-x;
	animation: loop 50s linear infinite;
}
@keyframes loop {
	0% {background-position-x: 0;}
	100% {background-position-x: -2000px;}
}
/* タブレット */
@media screen and (max-width: 768px){
    #intro::before {
        height: calc(227px * 0.6);
    }
    @keyframes loop {
    	0% {background-position-x: 0;}
    	100% {background-position-x: calc(-2000px * 0.6);}
    }
}

/* タブレット */
@media screen and (max-width: 667px){
    #intro::before {
        bottom: -90px;
        height: calc(227px * 0.5);
        animation: loop 30s linear infinite;
    }
    @keyframes loop {
    	0% {background-position-x: 0;}
    	100% {background-position-x: calc(-2000px * 0.5);}
    }
}
/* --------------------------------------------
 メインイメージ 
---------------------------------------------*/
#main_img{}
.main_img_box{}
.catch {
    box-shadow: none!important;
    border-radius: 0!important;
    z-index: 3;
    position: absolute;
    top: 38%;
    left: 5%;
    transform: translate(0%, -50%);/* X横 Y縦 始点が要素の中心になる */
    width: 40%;
}

/* タブレット */
@media screen and (max-width: 768px){
    #main_img{
        margin-bottom: 70px;
    }
    .catch {
        top: 45%;
    }
}
/* スマホ */
@media screen and (max-width: 667px){
    #main_img {
        padding: 0 20px;
    }
    #main_img .main_img_box {
        height: 80vh!important;
        max-height: 530px!important;
    }
    #main_img .main_img_box img{
        height: auto!important;
        width: 100%!important;
    }
    .catch {
        top: 25%;
        right: auto;
        left: 50%;
        transform: translate(-50%, -50%);
        width: 70%;
    }
}



/*--------------------------------------------
 ロゴ
----------------------------------------------*/
#loader figure{
    max-width: 330px;
}

#header{justify-content: space-between;}
#header h1{max-width: 330px;}

footer h2 a{max-width: 270px;}

/* タブレット */
@media screen and (max-width: 768px){}
/* スマートフォン */
@media screen and (max-width: 667px){}

/*--------------------------------------------
 プライバシーポリシー
----------------------------------------------*/


/*--------------------------------------------
 TOPお知らせ
----------------------------------------------*/
.topcms_news_type4 .cate_box {transition: all 0.3s;}
.topcms_news_type4 .cate_box:hover{
    transform: translate(0px, -10px);
    /*box-shadow: 0 10px 10px #ccc;*/
    /*border: 1px solid #fff;*/
}
.topcms_news_type4 .cate_box{
	width: 30.33333%!important;
	margin-right: 1.5%;
	margin-left: 1.5%;
	border-radius: 15px;
	background-color: var(--base);
	padding: 0;
	box-sizing:border-box;
	/*border: 2px solid var(--color3);*/
	/*box-shadow: 0px 0px 3px rgba(0, 0, 0, 0.2);*/
}
.topcms_news_type4 .cate_box .box_img1{
    border-radius: 15px 15px 0 0;

}
.topcms_news_type4 .txt_height{
	height: 3em
}
.topcms_news_type4 .box_title1:empty{
	display: block!important;
}
/* タブレット */
@media screen and (max-width: 768px){
}
/* スマートフォン */
@media screen and (max-width: 667px){
.topcms_news_type4 .cate_box {
    width: 100%!important;
    margin-bottom: 15px;
}
}


/* --------------------------------------------
 電話バナー、問い合わせ
---------------------------------------------*/
#contact_tel{border-radius:15px;}
#contact_tel2 a span{
    font-size: 20px;
    letter-spacing: 0em;
    line-height: 1.3;
}

footer #footer .tel a{
    text-align: center;
}
.tel2 a span{
    display: block;
    margin-bottom: 8px;
    text-align: center;
    letter-spacing: 0em;
    font-size: 22px;
}
#page08_link a{
    transform: translateX(0px);
    background: linear-gradient(45deg, var(--color1), var(--color3));
}
#page08_link a figure{
    width: 60px;
    padding: 0 0 0 25px;
}
#page08_link a p{
    width: calc(100% - 95px);
}
#page08_link a p span{
    text-align: left;
    width: 100%;
}

/* スマホ */
@media screen and (max-width: 667px){
    .tel2 a span{
        font-size: 16px;
    }
    #page08_link a figure{
        padding: 0 0 0 20px;
    }
    #page08_link a p span{
        width: 95%;
        margin-right: 5%;
        text-align: center;
    }
}
@media screen and (max-width: 380px){
    .d_block_ss{display: block;}
}



/* --------------------------------------------
 リンクボタン 
---------------------------------------------*/
.linkStyle,a{
	color: var(--color1);
	text-decoration: underline;
	transition: all 0.5s;
}
a{
    text-decoration: none;
}
.linkStyle:hover,a:hover{
	opacity: 0.7;
	text-decoration: none;
}

.cate_list li a,#page10 ul li a,.more a{
    background-color: var(--color1);
    color: var(--base);
    font-weight: bold;
    padding: 10px 20px;
    transition: all 0.8s;
}
#page10 ul li a{
    padding-top: 15px;
    padding-bottom: 15px;
}
.cate_list li a:hover,#page10 ul li a:hover,.more a:hover{
    background-color:var(--color1);
    opacity: 0.7;
}

/* タブレット */
@media screen and (max-width: 768px){}
/* スマホ */
@media screen and (max-width: 667px){}
/*--------------------------------------------
 色 ・　文字
----------------------------------------------*/
html,body,.font_10,.font_11,.font_12,.font_13,.font_14,.font_15{font-size: var(--font1);}
.font_2up{font-size: max(calc(var(--font1) + 2px), calc(1rem  + 2px));}
.font_4up{font-size: max(calc(var(--font1) + 4px), calc(1rem  + 4px));}
.font_2dw{font-size: max(calc(var(--font1) - 2px), calc(1rem  - 2px));}
.font_4dw{font-size: max(calc(var(--font1) - 4px), calc(1rem  - 4px));}
.font_6dw{font-size: max(calc(var(--font1) - 6px), calc(1rem  - 6px));}

.cate_img1{
    border-radius: 15px;
}

#main_nav{
    background: linear-gradient(340deg, var(--color1), var(--color3));
}

#intro #intro_txt{margin-top: 50px;}
#intro #intro_title{color: var(--color1);}
#intro #intro_title h2{
    font-size: var(--fontB1);
    line-height: 1.5;
}

#contents1 h3,#contents2_box_wrap .con_txt_title{
    font-size: var(--fontB2);
    line-height: 1.7;
}

#contents2_box_wrap p{
    font-weight: normal;
}
#contents2 .con_box .number{
    text-shadow: 0 0 15px rgba(255,255,255,0.2);
}
#contents1 img, #contents2 img,.topcms_news_type4 .cate_box{
    box-shadow: 0 0 15px var(--color4);
}

#google_privacy{
    background-color: var(--color2);
}
#page08_link a figure{
    width: 60px;
    padding: 0 0 0 25px;
}
#page08_link a p{
    width: calc(100% - 95px);
}


/* タブレット */
@media screen and (max-width: 768px){}
/* スマホ */
@media screen and (max-width: 667px){
    
    #loader > div figure,#loader > div p{
        top: 45%;
    }
    #wrap{
        padding-top: 90px;
    }
    #intro{
        margin-bottom: 50px;
    }
    #contents1,#contents2 > div{
        padding: 50px 7%;
    }
}


/* color */
body, .txt_color_nomal, .hvr_txt_color_nomal:hover{color: var(--text);}
.linkStyle{transition: 0.5s;color: var(--text)}
.linkStyle:hover{opacity: 0.7}

.txt_white, .hvr_txt_white:hover{color: white;}
.txt_red, .hvr_txt_red:hover{color: var(--red);}
.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 */

/* background-color */
.bg_white, .hvr_bg_white:hover{background-color: 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_color_clear, .hvr_bg_color_clear:hover{background-color: transparent!important}


/* border-color ※!important */
.border_white, .hvr_border_white:hover{border-color: white}
.border_black, .hvr_border_black:hover{border-color: var(--black)}
.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)}