﻿/*--------------------------------------------
 色 ・　文字
----------------------------------------------*/
:root{
    --color1: #006ae4;
    --color2: #f4fcff;
    --color3: #99badf;
    --color4: #FED428;
	--text: #2e3033;
    --base: #ffffff;
    
    --font1: 16px;
    --fontB1: 42px;
    --fontB2: 40px;
    --font-jp: 'Noto Sans JP', "游ゴシック Medium", sans-serif;
}
/* スマホ */
@media screen and (max-width: 667px){
    :root{
        --fontB1: 28px;
        --fontB2: 24px;
    }
}
/* --------------------------------------------
 電話バナー、問い合わせ
---------------------------------------------*/
#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;
}

/* スマホ */
@media screen and (max-width: 667px){
    .tel2 a span{
        font-size: 16px;
    }
}
@media screen and (max-width: 380px){
    .d_block_ss{display: block;}
    #contact_tel2 a span{
        font-size: 18px;
    }
    footer #footer .tel a{
        padding: 20px;
    }
}
/* --------------------------------------------
 シャランと出る文字 
---------------------------------------------*/
.txt_anim1 span{
	position: relative;
	right: 20px;
	opacity: 0;
	transition: all .8s;
}
.txt_anim1 span.start{
	right: 0;
	opacity: 1;
}
/* --------------------------------------------
 ループする文字
---------------------------------------------*/
#contents1{margin-bottom: 0;}
#contents2{
    position: relative;
    padding-top: 100px;
    padding-bottom: 80px;
    margin-bottom: 0;
}

#contents2::after {
	   position: absolute;
    content: "";
    right: 0;
    top: 0;
    opacity: 0.3;
    z-index: -1;
    width: 200px;
    height: 100%;
    background-image: url(../dup/img/dec02.png);
    background-size: 100% auto;
    background-position-y: 0;
    background-position-x: 0;
    background-repeat: repeat-y;
    animation: loop2 35s linear infinite both;
}
@keyframes loop2 {
	0% {background-position-y: 0px;}
	100% {background-position-y: -3580px;}
}
/* タブレット */
@media screen and (max-width: 768px){
    #contents2::after {
        opacity: 0.1;
    }
}
/* スマホ */
@media screen and (max-width: 667px){
    #contents2{padding: 80px 0;}
    #contents2::after {
        width: 50px;
        animation: loop2 25s linear infinite both;
    }
    @keyframes loop2 {
	0% {background-position-y: 0px;}
	100% {background-position-y: -895px;}
    }
}

/* --------------------------------------------
 メインイメージ 
---------------------------------------------*/
#main_img{
    padding: 0;
    height: calc(100vw * 0.56);
    width: 90%;
    margin: 0 auto 100px;
    border-radius: 20px;
}
#main_img::before{
    content: "";
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    background-color: rgba(108, 184, 238, 0.3);
    z-index: 2;
}
.catch {
    z-index: 3;
    position: absolute;
    top: 25%;
    left: 50%;
    transform: translate(-50%, 0%);/* X横 Y縦 始点が要素の中心になる */
    width: 55%;
}

/* タブレット */
@media screen and (max-width: 768px){
    #main_img{
        height: calc(100vw * 0.56);
    }
}
/* スマホ */
@media screen and (max-width: 667px){
    #main_img{
        margin: 0 auto 30px;
    }
    .catch {
        top: 28%;
        width: 80%;
    }
}


/*--------------------------------------------
 事業内容
----------------------------------------------*/
.link_type1 .link_top .link_title {
    margin-bottom: 20px;
    text-align: center;
	margin-bottom: 30px;
    color: var(--text);
        font-size: 1.4rem;
}
.link_type1 .link_top a{
	padding-top: 80px;
    padding-bottom: 60px;
    box-shadow: 0 0 15px rgba(0,0,0,0.15);
    border: none;
    border-radius: 20px;
}
.link_type1 .link_top a:hover{
    background-color: var(--color3);
}
.link_type1 .link_top a:hover .link_img1{
    transform: translate(-50%, -50%) scale(1.1,1.1);
    opacity: 0.1;
}
.link_type1 .link_top a p{
    color: var(--color1);
    font-weight: bold;
    border-color: var(--text);
}
@media screen and (max-width: 667px){}




/*--------------------------------------------
 よくある質問
----------------------------------------------*/
.cms_5-f .box_wrap{
    border-radius: 20px;
}
#cms_5-f .cate_box .box_txt1, .cms_5-f .cate_box .box_txt1{
    border-radius: 10px;
}
#cms_5-f .cate_box .open_bt .arrow::before, #cms_5-f .cate_box .open_bt .arrow::after, .cms_5-f .cate_box .open_bt .arrow::before, .cms_5-f .cate_box .open_bt .arrow::after{
    background-color: var(--color1);
}

/*--------------------------------------------
 コンテンツ１へ背景をつける
----------------------------------------------*/
#contents1,#contents1 .d_flex{position: relative;}
#contents1 .d_flex{z-index: 3;}
#contents1::before{
    content: "";
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    background-image: url(./Dup/img/con1bg.jpg);
    background-size: cover;
    opacity: 0.15;
    z-index: 2;
}

/* --------------------------------------------
 リンクボタン 
---------------------------------------------*/
.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){}
/*--------------------------------------------
 ロゴ
----------------------------------------------*/
#loader > div figure{width: 40%;}
.logo img,footer h2 a{width: 130px!important;}
#header h1 a img{width: 180px!important;}
#header h1 a{
    margin-right: calc(100% - 180px);
}

/* タブレット */
@media screen and (max-width: 768px){
    #header h1 a img{width: 130px!important;}
}
/* スマホ */
@media screen and (max-width: 667px){
    #loader > div figure{width: 50%;}
    #header h1 a img{width: 100px!important;}
    #header h1{padding: 17px 0 ;}
}

/*--------------------------------------------
 色 ・　文字
----------------------------------------------*/
h1, h2, h3, h4, h5, h6{
    font-weight: bold;
    color: var(--color1);
}
p{font-weight: normal;}
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));}

#intro #intro_txt{margin-top: 50px;}

#contents1 h3,#contents2_box_wrap .con_txt_title{
    font-size: var(--fontB2);
}

#contents2_box_wrap p{
    font-weight: normal;
}



.top_cms_title p{
    color: var(--color1)!important;
}
.top_cms_title h3.txt_color1{
    color: var(--text);
}
#main_nav.bg_color3{
    background-color: var(--color2);
}
#main_nav .nav li a.txt_white{
    color: var(--text);
}

#footer.bg_color1,#copyright.bg_color1{
    background-color: var(--color3);
}

#page_title.bg_color1{background-color: var(--color2);}
#page_title h2{color: var(--text);}
#page_title p{color: var(--color1);}

#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);
}
#page08_link a p span{
    text-align: left;
    width: 100%;
}
/* タブレット */
@media screen and (max-width: 768px){}
/* スマホ */
@media screen and (max-width: 667px){
    #loader > div p,#loader > div figure{
        right: 0;
        top: 45%;
        transform: translate(50%,-50%);
    }
    
    header.sc_nav .nav_bt{top: 50%;}
    #contents2 .pd_10px_sp{padding: 10px 7%;}
    #contents2 .box2{margin-bottom: 50px;}
    
    #page08_link a figure{padding: 0 0 0 35px;}
    #page08_link a p{width: calc(100% - 135px);}
}


/* 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)}