﻿@import url('https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@200&display=swap');
/*--------------------------------------------
 色 ・　文字
----------------------------------------------*/
:root{
    --color1: #005379;
    --color2: #f1fbff;
    --color3: #f57f40;
    --color4: #ffcebd;
	--text: #555;
    --base: #ffffff;
    
    --font1: 16px;
    --fontB1: 36px;
    --font-title: 'Noto Serif JP', serif;
    
    --radi1: 15px;
}
/* スマホ */
@media screen and (max-width: 667px){
    :root{
        --fontB1: 22px;
    }
}
#cms_2-g .box_txt2 {
    padding: 20px 5%;
    background-color: var(--color2);
    border-radius: 10px;
    margin-top: 10px;
}

.v_type3 .box_img img{
    margin: 0 auto;
    display: block;
}
.menu_stick{cursor: pointer;}

/* --------------------------------------------
 メインイメージ 
---------------------------------------------*/
#main_img{
    height: calc(100vw * 0.556)!important;
    overflow: hidden;
}
#video{
    height: calc(100vw * 0.56)!important;
}
#main_img::before{
    background: url(./Dup/img/catch_copy.png) no-repeat;
    opacity: 1;
    background-size: contain;
    background-position: left;
}
/* タブレット */
@media screen and (max-width: 768px){
    #main_img{
        height: calc(100vw * 0.56)!important;
        margin-top: 91px;
    }
}
/* スマホ */
@media screen and (max-width: 667px){
    #main_img{
        margin-top: 65px;
    }
    #main_img::before{
        background: url(./Dup/img/catch_copy_sp.png) no-repeat;
        background-size: contain;
    }
}

/*--------------------------------------------
 下層ページ共通
----------------------------------------------*/
#page_title::before{
    background: rgb(191, 227, 245, 0.4);
}
#page_title .txt_white{
    color: var(--color1);
}

/*--------------------------------------------
 TOP
----------------------------------------------*/
#header{
    max-width: 100vw!important;
    box-sizing: border-box!important;
}
#header.head_fix #pc_nav ul{
    height: 90px;
}
#header #logo{ max-width: 240px;}
/*#loader,main,#header,#bottom_menu,#footer,#copyright{*/
/*    max-width: 100vw!important;*/
/*    overflow: hidden!important;*/
/*    box-sizing: border-box!important;*/
/*}*/
/*#footer{*/
/*    margin: 0;*/
/*}*/
header .inner{
    max-width: 90vw!important;
    margin: 0 auto;
}

#pc_nav ul li.pd_r-30px {
    padding-right: 15px;
}
#pc_nav ul li{
    letter-spacing: 0em;
}

#intro h2, #contents1 h2, #contents2 h2, #top_cms h2,.title_text,#page_title h2{
    font-family: var(--font-title);
    font-size: var(--fontB1);
}

#intro .intro_bg{
    background-color: rgb(231, 247, 255, 0.72);
}
#intro .bg_box{
    background-position-x: 65%!important;
}
#intro .pd_r-50px{
    padding-right: 11vw;
}
#intro figure, #contents2 .cate_box{
    border-radius: var(--radi1);
    box-shadow: 2px 20px 40px rgb(32, 116, 155, 0.4);
}
#intro h2{
    letter-spacing: 0em;
}

#contents1 .txt_box{
    padding: 0 12vw;
}

#contents2 .contents2_bg::before{
        /*background-color: #ffebcb;*/
        background-color:#fff;
}

/* タブレット */
@media screen and (max-width: 768px){
    #header #logo{max-width: 200px;}
    header .inner{max-width: 100vw!important;}
    #intro .pd_r-50px{
        padding-right: 0px;
    }
    #intro .bg_box{
        background-position-x: 53%!important;
    }
    #contents1 .txt_box{
        padding: 0;
    }
    #contents1 .contents1_img{
        border-radius: var(--radi1);
    }
    
    #f_contact .inner{
        padding: 40px 20px 60px;
    }
}
/* スマホ */
@media screen and (max-width: 667px){
    #header #logo{max-width: 160px;}
    #intro .bg_box{
        background-position-x: 60%!important;
    }
    #copyright{padding-bottom: 80px;}
}
/*--------------------------------------------
 TOPmo-daru
----------------------------------------------*/
.modal_bt{
    cursor: pointer;
    border-radius: 10px;
    margin-top: 30px;
    margin-bottom: 20px;
    margin-left: 20%;
    border: 2px solid;
    color: var(--text);
    background-color: var(--base);
}
.modal_bt:hover{
    opacity: 0.7!important;
    background-color: var(--color2);
    color: var(--color1);
}
/*.modal_bt::before{*/
/*    font-family: "FontAwesome";*/
/*    content: '\f061';*/
/*    padding-right: 10px;*/
/*}*/

.modal_box{
    top: 0;
    left: 0;
    background-color: rgba(245,255,255,0.9);
    z-index: 101;
    overflow-y: scroll;
}
.modal_box .close{
    top: -15px;
    right: -15px;
    width: 50px;
    height: 50px;
    cursor: pointer;
}

/* タブレット */
@media screen and (max-width: 768px){
    .modal_bt{
        margin: 20px auto;
    }
    .modal_wrap .modal_item{
        padding-top: 130px;
    }
}

/* スマホ */
@media screen and (max-width: 667px){
    .modal_bt{}
}





/*--------------------------------------------
 TOPスタッフ
----------------------------------------------*/
.topcms_about_type1 {counter-reset: box 0;padding-top: 35px;}
.topcms_about_type1 .cate_box {
	width: 31%!important;
	padding: 55px 25px 25px;
	/*background-color: #f5f5f5;*/
	border-radius: 10px;
	box-sizing: border-box;
}

.topcms_about_type1 .cate_box .box_title1{font-size: 18px;line-height: 1.6;z-index: 1}

/* ---------- タブレット ---------- */
@media screen and (max-width: 768px){
.topcms_about_type1 .cate_box {
	margin: 0 auto 80px;
	width: 80%!important;
}
.topcms_about_type1 .cate_box:last-of-type {
	margin-bottom: 0;
}
}
/* ---------- スマートフォン ---------- */
@media screen and (max-width: 667px){
.topcms_about_type1 .cate_box {
	width: 90%!important;
	padding: 50px 25px 25px;
}
.topcms_about_type1 .number::before{
	font-size: 59px;
	top: -34px;
}
.topcms_about_type1 .number::after{
	width: 72%;
}
}



/*--------------------------------------------
 お知らせ
----------------------------------------------*/
.topcms_news_type2 .cate_box {
	width: 46.33333%!important;
	margin-right: 1.5%;
	margin-left: 1.5%;
	cursor: pointer;
	border-bottom: 1px solid #ddd;
	margin-bottom: 30px;
	box-shadow: 0 6px 12px rgb(0 0 0 / 0);
	/* padding: 20px; */
	/* border-radius: 20px; */
	/* background-color: #f5f5f5; */
}
.topcms_news_type2 .cate_box:hover {
	transform: translateY(-5px);
}
.topcms_news_type2 .cate_box .box_item {
	cursor: pointer;
}
.topcms_news_type2 .txt_height {
	height: 5em
}
.topcms_news_type2 .box_img1 {
	border-radius: 10px;
}

/* ---------- タブレット ---------- */
@media screen and (max-width: 768px){
.topcms_news_type2 .cate_box {width: 100%!important;}
.topcms_news_type2 .txt_height {height: 3em}
}




/*--------------------------------------------
 Q&A
----------------------------------------------*/
.qa_type1 .cate_box {
	border-radius: 10px;
	border: 1px solid var(--color1);
}
.qa_type1 .cate_box .arrow {
	position: absolute;
	left: 2px;
	top: 50%;
	margin-top: 0px;
	transform: translateY(-50%);
}
.qa_type1 .cate_box .open_bt{
	position: relative;
	width: 100%;
	cursor: pointer;
	padding: 20px 0
}
.qa_type1 .cate_box .open_bt .arrow::before, .qa_type1 .cate_box .open_bt .arrow::after {
	position: absolute;
	content: '';
	width: 15px;
	height: 1px;
	background-color: var(--color3);
}
.qa_type1 .cate_box .open_bt .arrow::before {
	top: 48%;
	left: 15px;
	transform: rotate(0deg);
	transition: all 0.5s;
}
.qa_type1 .cate_box .open_bt .arrow::after {
	top: 48%;
	left: 15px;
	transform: rotate(90deg);
	transition: all 0.5s;
}
.qa_type1 .cate_box .open_bt .arrow.arrow_be::before {
	transform: rotate(-135deg);
	transition: all 0.5s;
}
.qa_type1 .cate_box .open_bt .arrow.arrow_be::after {
	transform: rotate(135deg);
	transition: all 0.5s;
}
.qa_type1 .cate_box .open_bt .box_title1 {
	display: inline-block;
	position: relative;
	letter-spacing: 1px;
	cursor: pointer;
	margin-left: 87px;
}
.qa_type1 .cate_box .open_bt .box_title1::before {
	content: "Q.";
	position: absolute;
	left: -32px;
	top: 0px;
	display: inline-block;
	vertical-align: baseline;
	color: #f57f40;
}
.qa_type1 .cate_box .box_item {
	display: none;
	padding: 0px 30px 0px;
}
.qa_type1 .cate_box .box_txt1 {
	padding: 1em;
	background-color: #f5f5f5;
	border-radius: 5px;
}

@media screen and (max-width: 768px){
.qa_type1 .cate_box .open_bt .box_title1 {
	padding-right: 20px;
}
}
@media screen and (max-width: 667px){
.qa_type1 .cate_box .open_bt {
	padding: 5px 0 7px;
}
.qa_type1 .cate_box .open_bt .box_title1 {
	margin-left: 73px;
}
.qa_type1 .cate_box .box_txt1 {
	padding: 0.2em 1.2em;
}
}

/*--------------------------------------------
 プライバシーポリシー
----------------------------------------------*/



/*--------------------------------------------
 お問い合わせ
----------------------------------------------*/



/*--------------------------------------------
 バナー
----------------------------------------------*/
/* 閉じるボタン付き追従バナー */
.fix_banner{
	max-width: 300px;
	position: fixed;
	bottom: 10px;
	right: 110px;
	z-index: 10;
	transition: 0.8s;
	box-shadow: 0px 3px 5px rgba(0,0,0,0.6);
	border-radius: 7px;
}
.fix_banner .close_bt{
	position: absolute;
	bottom: 73px;
    right: -15px;
	display: block;
	width: 30px;
	height: 30px;
	border-radius: 50%;
	transition: 0.8s;
	background-color: rgba(255,255,255,1);
	border: solid 1px #006faf;
	z-index: 11;
	cursor: pointer;
}
.fix_banner .close_bt:hover{opacity: 0.7;}
.fix_banner .close_bt span{
	position: relative;
	display: block;
	width: 30px;
	height: 30px;
}
.fix_banner .close_bt span:before,.fix_banner .close_bt span:after{
	content: "";
	display: block;
	background-color: #607d8b;
	height: 2px;
	width: 20px;
	position: absolute;
	top:50%;
	left: 50%;
}
.fix_banner .close_bt span:before{
	-ms-transform: translate(-50%,-50%) rotate(-45deg);
	-webkit-transform: translate(-50%,-50%) rotate(-45deg);
	transform: translate(-50%,-50%) rotate(-45deg);
}
.fix_banner .close_bt span:after{
	-ms-transform: translate(-50%,-50%) rotate(45deg);
	-webkit-transform: translate(-50%,-50%) rotate(45deg);
	transform: translate(-50%,-50%) rotate(45deg);
}
.fix_banner.close {opacity: 0;z-index: -1; filter: blur(10px);}
.fix_banner.close2{opacity: 0;z-index: -1;filter: blur(10px);}

@media  screen and (max-width: 768px){
.fix_banner{}
.fix_banner .close_bt{
    bottom: 73px;
}
}

@media  screen and (max-width: 667px){
.fix_banner{max-width: 230px;width:80%; right: auto; left: 50%; transform: translateX(-50%); bottom: 10px;}
.fix_banner .close_bt{
	width: 25px;
	height: 25px;
	bottom: 56px;
	right: -12px;
}
.fix_banner .close_bt span{
	width: 25px;
	height: 25px;
}
}
/* 閉じるボタン付き追従バナー end */
/* --------------------------------------------
 リンクボタン 
---------------------------------------------*/
.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);
    /*background: linear-gradient(90deg, var(--color3)5%, var(--color1)95%);*/
    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(--color3);
    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));}






/* タブレット */
@media screen and (max-width: 768px){}
/* スマホ */
@media screen and (max-width: 667px){}


/* 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)}