﻿@charset "utf-8";

/*スクショ用*/
/*#page-top{bottom:10px!important;}*/

/*■■ 色・文字 ■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■*/

:root{
    --color1: #353535;
    --color2: #e7e7e7;
    --color3: #c50c23;
    --color4: #f5f5f5;
    --black: #222222;
    --base: #FFF;
    --font1: 16px;
}

/* スマホ */
@media screen and (max-width: 667px){
    :root{
        --fontB1: 22px;
    }
}
html,body,.font_10,.font_11,.font_12,.font_13,.font_14,.font_15,
.font_10_tb,.font_11_tb,.font_12_tb,.font_13_tb,.font_14_tb,.font_15_tb,
.font_10_sp,.font_11_sp,.font_12_sp,.font_13_sp,.font_14_sp,.font_15_sp{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)), calc(1rem  - 2px));}
.font_4dw{font-size: max(calc(var(--font1)), calc(1rem  - 4px));}
.font_6dw{font-size: max(calc(var(--font1)), calc(1rem  - 6px));}


.base_color{background-color: var(--base);} /* ベースカラー　全体の背景色 */

.txt_white, .hvr_txt_white:hover{color: white;}
.txt_red, .hvr_txt_red:hover{color: #C12326;}
.txt_gray, .hvr_txt_gray:hover{color: #ccc}
.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_gray, .hvr_bg_gray:hover{background-color: #ccc}
.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_gray, .hvr_border_gray:hover{border-color: #ccc}
.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)}

/*.bg_color1{*/
/*    background-image: url(./Dup/img/bg.jpg);*/
/*    background-size: cover;*/
/*}*/

/*■■ テンプレート調整 ■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■*/


/*■■ top, all ■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■*/
#loader.bg_color1{
    background-color: var(--color2);
}

.more a:hover{opacity: 1;}

header .page_title_bg{
    background-color: #fff;
}
header .trans_logo{
    background-color: #fff;
    padding: 0 10px;
}
#header #logo,#logo span{
    background-color: var(--base);
}

#header {
    z-index: 10;
    background-color: var(--base);
}
#header.top{
    box-shadow: 0px 0 30px rgb(0,0,0,0.1);
    background-color: var(--color2);
    background-image: url(./Dup/img/bg2.jpg);
    background-size: cover;
}
#logo span{
    box-shadow: 10px 5px 10px rgb(0,0,0,0.05);
}
#footer #logo2{
    background-color: #fff;
}

.contents_wrap .contents_bg{
    background-color: var(--color2);
    background-image: url(./Dup/img/bg1.jpg);
    background-size: cover;
}
.con3_left.txt_white{
    color: var(--black);
}
.con3_left{
    background-color: rgba(255,255,255,0.8);
    padding: 30px 3%;
}

#top_cms .top_cms_bg{}

#page_title .page_title_box{
    color: var(--color1);
}
.info_left{
    background-image: url(./Dup/img/bg2.jpg);
    background-size: cover;
}

#page-top a{
    width: 65px;
    height: 65px;
}

/* タブレット */
@media screen and (max-width: 768px){
    #contents1 .con1_title h2{
        width: 330px;
        margin: 0 auto;
    }
    .con2_title , .con3_title{
        text-align: center;
    }
    .con2_title span, .con3_title span{
        margin: 0 auto;
    }
    .contents_wrap .contents_bg{
        background-image: url(./Dup/img/bg1_sp.jpg);
        background-size: cover;
    }
    .con3_left{background-color: transparent;}
    #contents3 .con3_wrap{
        background-color: rgba(255,255,255,0.8);
    }
    #page_title .page_title_box{
        text-align: left;
        padding: 150px 100px 90px;
    }
}
/* スマホ */
@media screen and (max-width: 667px){
    #contents1 .con1_title h2{
        width: auto;
        letter-spacing: 0em;
    }
    #contents2 .con2_wrap, #contents3 .con3_wrap{
        padding: 40px 7%;
    }
    #contents2 .con2_wrap .con2_title {
        width: 270px;
    }
    #contents3 .con3_wrap .con3_title {
        width: 250px;
    }
    #contents2 .con2_wrap .con2_title,#contents3 .con3_wrap .con3_title {
        margin: 0 auto 20px;
        line-height: 1.7;
    }
    #page_title{
        background-position-x: 80%;
    }
    #page_title .page_title_box{
        padding: 70px 20px 50px;
    }
    
    #page-top a{
        width: 62.5px;
        height: 62.5px;
    }
}


/*■■ ヘッダー,logo ■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■*/
header .trans_logo{
    position: absolute;
    height: 140px;
    padding: 0 10px;
}
header .trans_logo a img{
    max-width: 130px;
}
header .trans_header{
    top: -140px;
    height: 140px;
}
#header.top #logo{
    padding-left: 35%;
    padding-top: 0px;
    padding-bottom: 0px;
}
#header.top #logo img{
    max-width: 220px;
}

#footer #logo2{
    padding: 0;
}
.under_page #logo{
    padding: 0;
}

/* タブレット */
@media screen and (max-width: 768px){
    header .trans_header{
        top: 0;
    }
    #header #logo{padding-left: 10%;}
}
/* スマホ */
@media screen and (max-width: 667px){
    header .trans_logo{
        background-color: transparent;
            height: 100px;
    }
    header .trans_logo a img{
        max-width: 100px;
    }
    
}

/*■■ カテゴリデザイン統一 ■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■*/

/*■■ cms1 ■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■*/
.topcms_news_type4 .cate_box{
	width: 30.33333%!important;
	margin-right: 1.5%;
	margin-left: 1.5%;
}
.topcms_news_type4 .cate_box{
	background-color: #fff;
	padding: 0;
	box-shadow: 5px 10px 15px rgb(0 0 0 / 8%);
	/*border-top: 2px solid #c68080;*/
}
.topcms_news_type4 .txt_height{}
.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: 30px;
}
}

/*■■ cms2 ■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■*/
#cms_2-f .cate{
    border-top: 1px solid var(--color1);
    border-bottom: none;
    border-left: none;
    border-right: none;
    margin-bottom: 0;
}

#cms_2-f .box_title1{
    padding: 15px 0;
}
#cms_2-f .box_title1::after{
    display: none;
}
#cms_2-f .cate_box:last-child{
    border-bottom: none;
}

/* タブレット */
@media screen and (max-width: 768px){
    #cms_2-f .cate{
        padding: 30px 0;
    }
}

/* タブレット */
@media screen and (max-width: 768px){}
/* スマホ */
@media screen and (max-width: 667px){}

/*■■ cms3 ■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■*/


/* タブレット */
@media screen and (max-width: 768px){}
/* スマホ */
@media screen and (max-width: 667px){}

/*■■ cms4 ■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■*/


/* タブレット */
@media screen and (max-width: 768px){}
/* スマホ */
@media screen and (max-width: 667px){}

/*■■ cms5 ■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■*/

#cms_5-a .cate .cate_title{
    background-image: none;
}

#cms_5-a #cate1 .cate_box .box_title1,#cms_5-a #cate1 .cate_box p{
    padding-left: 25px;
    position: relative;
}
#cms_5-a #cate1 .cate_box .box_title1{
    padding-left: 30px;
}
#cms_5-a #cate1 .cate_box .box_title1::before,#cms_5-a #cate1 .cate_box p::before {
    content: "Q.";
    position: absolute;
    left: 0;
    top: 5px;
    font-weight: bold;
    color: var(--color3);
}
#cms_5-a #cate1 .cate_box p{}
#cms_5-a #cate1 .cate_box p::before {
    content: "A.";
    top: 6px;
    color: var(--black);
}

/* タブレット */
@media screen and (max-width: 768px){}
/* スマホ */
@media screen and (max-width: 667px){}

/*■■ プライバシーポリシー ■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■*/
.con_box{}

/* タブレット */
@media screen and (max-width: 768px){}
/* スマホ */
@media screen and (max-width: 667px){}

/*■■ お問い合わせ ■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■*/
.contact_box {}
.contact_box .contact_btn {
    width: 45%;
    margin-bottom: 30px;
    box-shadow: 0 5px 10px rgb(0 0 0 / 10%);
    border-radius: 11px;
}


/* タブレット */
@media screen and (max-width: 768px){}
/* スマホ */
@media screen and (max-width: 667px){
    .contact_box .contact_btn {
        width: 100%;
    }
}

/*■■ サイトマップ ■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■*/


/* タブレット */
@media screen and (max-width: 768px){}
/* スマホ */
@media screen and (max-width: 667px){}

/*■■ リンクボタン ■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■*/
.top_link{
    background-color: var(--base);
    border: 1px solid var(--color3);
    color: var(--color3);
    padding: 5px 5px;
    margin: 0 3px;
    box-shadow: 0 3px 8px rgba(0,0,0,0.07);
    transition: all 0.3s;
}
.top_link:hover{
    background-color: var(--color3);
    color: var(--base);
    border: 1px solid var(--color3);
}

.linkStyle{
	color: var(--color3);
	text-decoration: underline;
	transition: all 0.5s;
}
a{
    color: var(--color1);
}
a{
    text-decoration: none;
}
.linkStyle:hover,a:hover{
	opacity: 0.7;
	text-decoration: none;
}

/* タブレット */
@media screen and (max-width: 768px){}
/* スマホ */
@media screen and (max-width: 667px){}

/*■■ メインイメージ ■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■*/
#main_img,#video{ }
.catch {
    z-index: 3;
    position: absolute;
    top: 12%;
    left: 50%;
    transform: translateX(-50%);
    width: 65%;
}
.gla{
    position: absolute;
    z-index: 2;
    width: 100%;
    height: 45%;
    top: 0;
    left: 0;
    background: linear-gradient(180deg, rgba(255,255,255,0.8) 30%, transparent 100%);
}

#video, .video {
    height: 100% !important;
    width: auto!important;
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
}


/* タブレット */
@media screen and (max-width: 768px){
    #main_img {
        padding-top: 140px;
        height: 90vw !important;
        width: 100vw !important; /* 追加 */
        overflow: hidden; /* 修正 */
    }
    .catch {
        top: calc(4% + 140px);
    }
    .swiper-container {
        width: 100vw !important;
        height: 90vw !important; /* 追加 */
        overflow: hidden; /* 修正 */
    }
}
/* スマホ */
@media screen and (max-width: 667px){
    #main_img {
        padding-top: 105px;
        /*height: calc(100vw * 0.56) !important;*/
    }
    .catch {
        top: calc(4% + 100px);
        width: 75%;
    }
    #video, .video{
        height: calc(100vw * 0.56) !important;
        width: 100vw!important;
    }
    .swiper-container {
        height: calc(100vw * 0.56) !important;
    }
    .gla{height: 35%;}
}


/*--------------------------------------------
 モーダル 
----------------------------------------------*/
.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(--color3);
    color: var(--base);
}


.modal_box{
    top: 0;
    left: 0;
    background-color: rgba(53,53,53,0.7);
    z-index: 999;
    overflow-y: scroll;
}
.modal_box .close{
    top: -15px;
    right: -15px;
    width: 50px;
    height: 50px;
    cursor: pointer;
}
.modal_box .modal_con {
    border-radius: 0;
}


/* タブレット */
@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{}
    .modal_wrap .modal_title {
        text-align: left;
    }
}

/* 閉じるボタン付き追従バナー */
.fix_banner{
	max-width: 260px;
	position: fixed;
	bottom: 10px;
	right: 65px;
	z-index: 9;
	transition: 0.5s;
}
.fix_banner .close_bt{
	position: absolute;
	bottom: 48px;
    right: 243px;
	display: block;
	width: 30px;
	height: 30px;
	border-radius: 50%;
	transition: 0.5s;
	background-color: #fff;
	border: solid 1px var(--color3);
	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: var(--color3);
	height: 1px;
	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;
}
.fix_banner.close2{opacity: 0;z-index: -1;}

@media  screen and (max-width: 768px){
/*.fix_banner{max-width: 200px;}*/
/*.fix_banner .close_bt{bottom: 90px;right: 170px;}*/
}

@media  screen and (max-width: 667px){
.fix_banner{
    max-width: 250px;
    right: 62.5px;
}
.fix_banner .close_bt{
	width: 25px;
	height: 25px;
	bottom: 48px;
	right: 236px;
}
.fix_banner .close_bt span{
	width: 25px;
	height: 25px;
}
}
/* 閉じるボタン付き追従バナー end */
