﻿
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;700&display=swap');
@font-face {
font-family: "utsukushi";
  src: url("./Dup/img/utsukushi.otf") format("otf"),url("./Dup/img/utsukushi.woff") format("woff"),url("./Dup/img/utsukushi.woff2") format("woff2");
}
body,.font1{font-family: 'Noto Sans JP', sans-serif;font-weight: 400;}
.font2,.liana,.patrima,.hgs,.overlay .overlay-nav .top .en,#contents_modal .modal_title2{font-family: 'Noto Sans JP', sans-serif;font-weight: 700;}

/*--------------------------------
疑似要素にオブジェクト
--------------------------------*/
#intro .intro_title,#contents .con_box_item,#contents .con_title,
#cms_2-c .cate_title,#cms_3-e .cate_title,#cms_3-e .sub_cate_box,#cms_3-e .sub_cate_title,#cms_4-a .cate_title{position: relative;}

/*リピートなし*/
#main_img .catch,#intro .intro_title:before,#contents .con_box_item:before,#contents .con_title:before,
#cms_2-c .cate_title:before,#cms_3-e .cate_title:before,#cms_3-e .sub_cate_box:before,#cms_3-e .sub_cate_title:before,#cms_4-a .cate_title:before{
content: "";
display: block;
background-size: cover;
background-repeat: no-repeat;
position: absolute;
}

#main_img .catch_wrap{
background-size: 100%;
width: 41vw;
height: 36vw;
position: absolute;
top:50%;
left: 50%;
-ms-transform: translate(-50%,-50%);
-webkit-transform: translate(-50%,-50%);
transform: translate(-50%,-50%);
}
#main_img .catch_wrap,#main_img .catch{
width: 41vw;
height: 36vw;
}
#main_img .catch{
background-image: url(./Dup/img/catch.png);
background-size: 100%;
top: 0;
left: 0;
}
#main_img .menu_banner{
width: 13vw;
height: 13vw;
position: absolute;
bottom: 20px;
left: 35px;
transform: rotate(-15deg);
}

#intro .intro_title:before{
background-image: url(./Dup/img/line.png);
width: 200px;
height: 15px;
bottom: -30px;
left: 50%;
-ms-transform: translate(-50%,0);
-webkit-transform: translate(-50%,0);
transform: translate(-50%,0);
}

#contents .con_box_item:before{
width: 100px;
height: 100px;
top: -110px;
left: 50%;
-ms-transform: translate(-50%,0);
-webkit-transform: translate(-50%,0);
transform: translate(-50%,0);
}

#contents .box1 .con_box_item:before{background-image: url(./Dup/img/icon1.png);left: 45%;}
#contents .box2 .con_box_item:before{background-image: url(./Dup/img/icon2.png);left: 55%;}
#contents .box3 .con_box_item:before{background-image: url(./Dup/img/icon3.png);left: 45%;}

#contents .con_title:before,
#cms_2-c .cate_title:before,
#cms_3-e .cate_title:before,
#cms_4-a .cate_title:before{
background-image: url(./Dup/img/line2.png);
width: 150px;
height: 20px;
bottom:0;
left: 50%;
-ms-transform: translate(-50%,0);
-webkit-transform: translate(-50%,0);
transform: translate(-50%,0);
}

#cms_3-e .sub_cate_box:before{
background-image: url(./Dup/img/line.png);
width: 200px;
height: 15px;
bottom: 0;
left: 50%;
-ms-transform: translate(-50%,0);
-webkit-transform: translate(-50%,0);
transform: translate(-50%,0);
}
#cms_3-e .sub_cate_box:last-of-type:before{display: none;}
#cms_3-e .sub_cate_title{padding-left: 60px;}
#cms_3-e .sub_cate_title:before{
background-image: url(./Dup/img/icon2.png);
width: 50px;
height: 50px;
top: 7px;
left: 0;
}
/*--------------------------------
全体
--------------------------------*/
body{letter-spacing: 2px;line-height: 2;}
.overlay div.overlay-nav{line-height: 1.5;}
#page_title .en{line-height: 1;}
#logo img.width_300-max{max-width: 200px;}

.overlay div.overlay-nav{padding-top: 50px;}

.more .more_item{background: #ddc226;border-color: #ddc226;}
.more .more_item:before{display: none;}
.more .more_item:after{
height: 100%;
left: -5%;
top: 0;
height: 100%;
background: #BE1E00;
}
.more .more_item:hover{border-color: #BE1E00;}
.more .more_item:hover:after{
left: 0;
width: 100%;
}

#footer_info.bg_color3{background-color: #262626;}

/* 円形追従バナー */
.circle_banner{
position: fixed;
bottom: 10px;
left: 10px;
width: 200px;
z-index: 4;
transition: bottom 0.5s;
}

@media  screen and (max-width: 667px){

.circle_banner{width: 100px;}

}
/*--------------------------------
TOP
--------------------------------*/
#main_img{
background-image: url(./Dup/img/main_img.jpg);
background-size: cover;
background-position: center center;
background-repeat: no-repeat;
}


.modal-box .inner{scrollbar-width: none;}
.modal_title1:before{left: 6px;}

#contents .con_title{font-size: 44px;}


/* TOPメニュー */
.link_type2 .cate_box a {
    color: #fff;
}
.link_type2 .cate_box a:before, .link_type2 .cate_box a:after {
    content: "";
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    background-color: rgba(0,0,0,0.5);
    z-index: 1;
}
.link_type2 .cate_box a:after {
    top: 100%;
    background-color: #c52e3d;
    transition: 0.5s;
	z-index: 3;
}
.link_type2 .cate_box a:hover:after {
    top: 0;
}
.link_type2 .cate_box .txt_wrap {
    z-index: 2;
}
.link_type2 .more {
	letter-spacing: 3px;
    box-sizing: border-box;
	opacity: 0;
	transition: opacity .8s;
	z-index: 4;
}
.link_type2 .cate_box a:hover .more {
    opacity: 1;
}
/*--------------------------------
下層
--------------------------------*/
#page_title{padding-left: 30px;}
#page_title .page_title_box,#page_title .en:before{left: 0;}
#page_title .page_title_box,#page_title .en{display: block;}

#page_title .en{
font-size: 70px;
top: 30px;
left: 30px;
padding-left: 25px;
}
#page_title .en:before{
background-color: #ffffff;
width: 3px;
height: 170px;
top: -100px;
}
#page_title .jp{
color: #ffffff;
top: 90px;
left: -2px;
}
#page_title.txt_white{color: #ffffff;}

/* メニュー */
#cms_3-e .cate_box:first-of-type .box_title3{margin-top: 0;}
#cms_3-e .cate_box .box_description3.bg_black{background-color: rgba(0,0,0,0.5);}

/* 口コミ */
.v_type3 .cate_box{border: 1px solid #c9baa9;}
.v_type3 .box_title1{color: #ebd764;}

@media  screen and (max-width: 1400px){

.map{height: 600px;}

}

@media  screen and (max-width: 1280px){

#main_img .catch_wrap, #main_img .catch {
width: 51vw;
height: 45vw;
}
#main_img .menu_banner{
width: 15vw;
height: 15vw;
}
.top_title h2.right{right: 30px;}
.top_title h2.left{left: 30px;}

}

/*タブレット用（768px以下）*/
@media  screen and (max-width: 768px){

#loading_logo{top: 45%;}
#loading #loading_text .progressbar-text{top: 65%;}

.overlay div.overlay-nav{padding-top: 0;padding-bottom: 0;}

.circle_banner{width: 150px;}
.map{height: 300px;}

#main_img .catch_wrap, #main_img .catch {
/*
width: 65vw;
height: 57vw;
*/
width: 40vw;
height: 35vw;
}
#main_img .menu_banner{
/*
width: 19vw;
height: 19vw;
*/
width: 15vw;
height: 15vw;
bottom: -10px;
left: 10px;
}
.top_title h2.right{right: 5px;}
.top_title h2.left{left: 5px;}
.top_title h2 > span{z-index: 2;}

#contents .con_box_item:before{
width: 70px;
height: 70px;
top: -75px;
}
#contents .con_title{font-size: 24px;}
#contents .con_title:before{
width: 100px;
height: 13px;
}
#cms_2-c .cate_title:before, #cms_3-e .cate_title:before, #cms_4-a .cate_title:before{
width: 120px;
height: 15px;
}

#page_title .en{
font-size: 50px;
}

#page4 .page_container.pd_l-r10per{
padding-left: 5%;
padding-right: 5%;
}

}

/*スマホ用（667px以下）*/
@media  screen and (max-width: 667px){

#loading_logo{max-width: 250px;}
#loading #loading_text .progressbar-text{top: 70%;}

#logo{opacity: 0;transition: opacity 0.5s;}
.scr_header #logo{opacity: 1;}

.info_btn_wrap{margin-bottom: 60px;}
.circle_banner{width: 120px;}

#main_img .catch_wrap, #main_img .catch{
/*
width: 80vw;
height: 70vw;
*/
width: 50vw;
height: 44vw;
}
#main_img .menu_banner{
/*
width: 25vw;
height: 25vw;
bottom: 5px;
left: 20px;
*/
width: 18vw;
height: 18vw;
bottom: 5px;
left: 8px;
}

.top_title h2.right{right: 0;}
.top_title h2.left{left: 0;}

#contents .con_box .con_photo.mg_b-10px_sp{margin-bottom: 80px;}
#contents .con_box_item:before{
width: 50px;
height: 50px;
top: -60px;
}
#contents .box1 .con_box_item:before,
#contents .box2 .con_box_item:before,
#contents .box3 .con_box_item:before{left: 50%;}

#page_title .en{
font-size: 24px;
top: 10px;
left: 10px;
padding-left: 20px;
}
#page_title .en:before{
height: 100px;
top: -65px;
}
#page_title .jp span{line-height: 2;}
#page_title .jp{top: 55px;left: -10px;}

#page4 .sub_cate_txt2{background-color: rgba(190,30,0,0.6);}

.cate_list li:nth-of-type(4n){margin-right: 0;}

#cms_2-c .cate_title:before, #cms_3-e .cate_title:before, #cms_4-a .cate_title:before{
width: 100px;
height: 13px;
}

#cms_3-e .sub_cate_title {padding-left: 40px;}
#cms_3-e .sub_cate_title:before{
width: 30px;
height: 30px;
top: 7px;
}

}

/*IE*/
@media all and (-ms-high-contrast: none) {

#cms_1-e .date{padding-top: 10px!important;padding-bottom: 10px!important;}
#cms_3-e .sub_cate_title::before{top: 20px;}

}




/*--------------------------------
自動リンク
--------------------------------*/
/* color */
.linkStyle{color: #333; text-decoration: underline;}
.txt_color_nomal .linkStyle{color: #333;}
.txt_white .linkStyle{color: white;}
.txt_red .linkStyle{color: red;}
.bg_color1 .linkStyle{color: #fff;}
.bg_color2 .linkStyle{color: #333;}
.bg_color3 .linkStyle{color: #fff;}
.bg_color4 .linkStyle{color: #333;}

/*IEのみ*/
@media all and (-ms-high-contrast: none) {
.linkStyle{display: inline-block;}
}

/*--------------------------------
カラー
--------------------------------*/
body,.txt_color_nomal,.hvr_txt_color_nomal:hover{color: #333333;}
.txt_black,.hvr_txt_black:hover{color: #333333;}
.txt_white,.hvr_txt_white:hover{color: white;}
.txt_red,.hvr_txt_red:hover{color: red;}
.txt_color1,.hvr_txt_color1:hover{color: #dcc314;} /* メインカラー */
.txt_color2,.hvr_txt_color2:hover{color: #ffffff;} /* サブカラー */
.txt_color3,.hvr_txt_color3:hover{color: #ff5050;} /* アクセントカラー1 */
.txt_color4,.hvr_txt_color4:hover{color: #e3e0cf;} /* アクセントカラー2 */

/* background-color */
.bg_white,.hvr_bg_white:hover{background-color: white;} /* 白背景 */
.bg_black,.hvr_bg_black:hover{background-color: black;} /* 黒背景 */
.bg_color1,.hvr_bg_color1:hover{background-color: #dcc314;} /* メインカラー */
.bg_color2,.hvr_bg_color2:hover{background-color: #ffffff;} /* サブカラー */
.bg_color3,.hvr_bg_color3:hover{background-color: #BE1E00;} /* アクセントカラー1 */
.bg_color4,.hvr_bg_color4:hover{background-color: #e3e0cf;} /* アクセントカラー2 */
.bg_color_clear,.hvr_bg_color_clear:hover{background-color: transparent!important;}

/* border-color */
.border_white,.hvr_border_white:hover{border-color: white;}
.border_black,.hvr_border_black:hover{border-color: black;}
.border_color1,.hvr_border_color1:hover{border-color: #dcc314;}
.border_color2,.hvr_border_color2:hover{border-color: #ffffff;}
.border_color3,.hvr_border_color3:hover{border-color: #BE1E00;}
.border_color4,.hvr_border_color4:hover{border-color: #e3e0cf;}