﻿:root{
    --fontColor1: #F067A6;
}

.tel_box a{color: #ffd6da;}

/* ▼ メインイメージ１画面に ▼ */
#main_img #left{
    height: 100vh;
    width: 100%!important;
}
#main_img #right,#left_b,#right_b{
    display: none;
    height: 0vh;
    width: 0!important;
}
/* タブレット */
@media screen and (max-width: 768px){
    #main_img #left{height: calc(100vw * 0.8)!important;}
}
/* ▲ メインイメージ１画面 ▲ */

#info_contact .con_img:before{background-color: rgba(255, 255, 255, 0.7);}
#info_contact .con_box .con_title .txt_white{color: #d6ac24;}
.more_btn:hover:after{background-color: rgba(203, 153, 0, 0.2)!important;}
/* CMS・下層ページ ----------------------------------*/
.back1.cms.cms5:before{
    display: none;
}
main.back1.cms3{position: relative;}
main.back1.cms3::before{
    content: "";
    width: 100%;
    height: 100%;
    position: absolute;
    z-index: -1;
    top: -100px;
    left: 0;
    background: url( "./Dup/img/bg_230111_1.png" );
    background-size: 100%;
    background-repeat: repeat-y;
    opacity: 0.3;
}
main.back1.cms4::before{
    content: "";
    width: 100%;
    height: 100%;
    position: absolute;
    z-index: -1;
    top: -100px;
    left: 0;
    background: url( "./Dup/img/bg_230111_2.png" );
    background-size: 100%;
    background-repeat: repeat-y;
    opacity: 0.3;
}

.cms5_bg{
     content: "";
     display: block;
     position: fixed;
     top: 0;
     left: 0;
     z-index: -1;
     width: 100vw;
     height: 100vh;
     background: url( "./Dup/img/cms5_bg.jpg" ) no-repeat;
     background-size: cover;
     background-position: center;
}
.cms5 .con_box{background-color: transparent;}
.v_type3 .box_title1{
    position: relative;
    padding-left: 105px;
    color: #ebbf39;
}
.v_type3 .box_title1::before{
    content: "";
    background-image: url(./Dup/img/cms5_dec.png);
    width: 100px;
    height: 44px;
    background-size: cover;
    background-repeat: no-repeat;
    position: absolute;
    top: -4px;
    left: 0;
}
/* タブレット */
@media screen and (max-width: 768px){
    .cms5_bg{
        background: url( "./Dup/img/cms5_bg_tb.jpg" ) no-repeat;
        background-size: cover;
        background-position: center;
    }
    
    .v_type3 .box_title1{
        text-align: center;
        padding-left: 0px;
        padding-top: 50px;
    }
    .v_type3 .box_title1::before{
        top: 2px;
        left: 50%;
        transform: translateX(-50%);
    }
}
/* スマホ */
@media screen and (max-width: 667px){
    .cms5_bg{
        background: url( "./Dup/img/cms5_bg_sp.jpg" )no-repeat;
        background-size: cover;
        background-position: center;
    }
}
/* cms_5-f -----------------------------------*/
#cms_5-f .cate_box .box_txt1::before, .cms_5-f .cate_box .box_txt1::before{
    content: "A.";
    position: absolute;
    left: 20px;
}
#cms_5-f .cate_box .box_txt1, .cms_5-f .cate_box .box_txt1{
    padding-left: 40px;
    position: relative;
}

#page8 .tel_box{max-width: 400px;}
/* タブレット */
@media screen and (max-width: 768px){}
/* スマホ */
@media screen and (max-width: 667px){
    #page8 .tel_box{max-width: 300px;}
    #page8 .tel_box a{font-size: 22px; line-height: 1.3; padding: 10px 0;}
    #page9 .con_box{padding: 5% 3%;}
    #page9 .box_wrap h3{letter-spacing:0;}
}

/* メインイメージ -----------------------------------*/
#top_pc_nav li a{
    /*text-shadow: 0px 0px 2px #fff2cf, 0px 0px 5px #fff2cf;*/
    /*color: #ffe0a9;*/
    text-shadow: 0px 0px 2px #fff, 0px 0px 5px #fff2cf;
    /*color: #ffd6da;*/
    color: var(--fontColor1);
}

#main_img .menu{
    top: 68%;
}
#main_img .menu_logo{
    height: 260px!important;
}

#top_pc_nav{
    background-color: rgba(255,250,225,0.7);
    /*background-color: #fbd97d;*/
    /*background-color: #d1a109;*/
    padding: 15px 0;
    width: 70%;
    max-width: 900px;
    margin: 10px auto 0;
        border-radius: 30px;
}
.catch{
    width: 50%;
    max-width: 1000px;
    /*margin: 0 auto;*/
    position: absolute;
    top: -250%;
    left: 50%;
    transform: translate(-50%,-50%);
animation-name: fadeInAnime;
animation-duration:1s; /* アニメーション時間 */
animation-delay: 3.5s; /* 〇秒後に変化 */
animation-fill-mode:forwards;
opacity: 0;
}

@keyframes fadeInAnime{
    0% {opacity: 0;}
    100% {opacity: 1;}
}

@media screen and (max-width: 1280px){
    #main_img .menu{
        top: 50%;
    }
    .catch{
        top: 50%;
        transform: translate(-50%, -50%);
    }
}
/* タブレット */
@media screen and (max-width: 768px){
    #main_img .menu_logo{
        max-width: 300px;
        height: 300px!important;
    }
    #main_img .menu_logo a{max-width: 200px;}
    .catch{
        top: 50%;
        width: 65%;
        transform: translate(-50%, -50%);
    }
}
/* スマホ */
@media screen and (max-width: 667px){
    #main_img #left{
        height: 40vh!important;
    }
    #main_img .menu_logo{
        max-width: 180px;
        height: 150px!important;
    }
    #main_img .menu_logo a{max-width: 150px;}
    .catch{
        top: 50%;
        transform: translate(-50%, -50%);
        max-width: 420px;
        /*width: 80%;*/
        width: 65%;
    }
}

/* トップページ -------------------------------------*/
/* ▼ 右上にロゴ ▼ */
.top header{z-index: 5;opacity: 1;}
#main_img .menu_logo{display: none;}
/* ▲ 右上にロゴ ▲ */

.top header{min-height:80px;}
.top header #logo{
    /*display: none;*/
}
.top header.scr_header #logo{
    display: block;
    max-width: 120px;
}
.back1:before,.back2:before{
    z-index: -1;
    width: 100%;
    height: 100%;
    
    content: "";
    width: 100%;
    height: 100%;
    position: absolute;
    z-index: -1;
    top: -100px;
    left: 0;
    background: url( "./Dup/img/bg_230111_3.png" );
    background-size: 100%;
    background-repeat: repeat-y;
    opacity: 0.3;
}
.back2:before{
    top: 0px;
    right: 0;
    left: 0;
}

.back1{padding-top: 0;}

#intro{padding: 200px 15%;}
#intro .bg{
    position: absolute;
    z-index: -1;
    width: 100%;
    height: calc(100% + 200px);
    bottom: -100px;
    left: 0;
     background-image: url(./Dup/img/img_bg_01.jpg);
    background-size: cover;
}

#intro .img_dec1{
    bottom: 0px;
    right: 80px;
    width: 30%;
    z-index: 0;
}
#intro .img_dec2{
    top: 0px;
    left: 50px;
    width: 30%;
    z-index: 0;
}
.intro_title, .con_title{color: #ffdb77;}
#intro .num,#contents1 .num,#contents2 .num,#contents3 .num{
    opacity: 1;
    color: #ffdb77;
}

#contents1_wrap, #contents2_wrap{padding-top: 50px;}
#contents1 .con_box{margin-top: 50px;}

#contents3_wrap:after{background-color: transparent!important;}

#top_cms.back1,.back1.cms{opacity:1;}
/*
#top_cms.back1:before,.back1.cms:before{
    width: 70%;
    background-color:transparent!important;
    background-image: url(./Dup/img/img_tate.png);
    background-size: 700px;
    background-position: left top;
    background-repeat: repeat-y;
}
*/
.cms_title,.cms_title h3{position:relative;z-index:2;}
.cms_title::before{
    content: "";
    width: 500px;
    height: 80px;
    background: linear-gradient(90deg, rgba(255,255,255,1) 0%, rgba(255,255,255,1) 50%, rgba(255,255,255,0) 100%);
    background-size: cover;
    background-repeat: no-repeat;
    position: absolute;
    top: 0;
    left: -10%;
    z-index: 0;
}

.more_btn{text-shadow: 0px 0px 3px #fff;background-color:rgba(255,255,255,0.8);}

/* タブレット */
@media screen and (max-width: 768px){
    #intro{padding: 100px 10%;}
    #intro_wrap{padding: 60px 5%;}
    #intro .img_dec1{bottom: 0px; right: 0px;}
    #intro .img_dec2{top: 0px; left: 0px;}
    #intro .bg{height: calc(100% + 60px); top: -50px; bottom: auto;}
    
    #contents1 .con_img{margin-bottom: 5%;}
    #contents1 .num,#contents2 .num{left: 50%; top: -30px;}
    #contents1 .num{top: -40px;}
    #contents2 .con_box{margin-top: 0px;}
    
    .cms_title::before{
        height: 65px;
        left: -40px;
    }
    #contents3_wrap:before{
        background-image: url(./Dup/img/con04bg.jpg)!important;
        background-position: center bottom;
    }
    
    /*#top_cms.back1:before,.back1.cms:before{background-size: 350px;}*/
}
/* スマホ */
@media screen and (max-width: 667px){
    #intro{padding: 100px 5% 70px;}
    #intro .img_dec1{bottom: 0px; right: -30px; width: 50%;}
    #intro .img_dec2{top: 0px; left: -10px; width: 50%;}
    .top header.scr_header #logo{
        max-width: 75px;
    }
    #logo{
        max-width: 75px;
    }
    /*#top_cms.back1:before,.back1.cms:before{*/
    /*    width: 100%;*/
    /*    background-size: 300px;*/
    /*}*/

    .cms_title::before{
        width: 170px;
        left: -16px;
    }
    #footer_con h2{
        letter-spacing: 0em;
        font-size: 1.6rem;
    }
}

/* 全体 ---------------------------------------------*/
#fakeloader{animation: bgchange 3.3s ease infinite;}
@keyframes bgchange{
      0%   {background: #ffe3a3;}
      /*30%   {background:#304c71;}*/
      /*50%  {background:#d98060;}*/
      /*90% {background:#ffe3a3;}*/
      100% {background: #fff5dd;}
}
.button_container span{
    background: #6e483d;
}
.button_container span:nth-of-type(1){
    color: #6e483d;
    letter-spacing: 0em;
    font-size: 12px;
    text-shadow: 0px 0px 3px #fff,0px 0px 5px #fff;
}
#pc_nav li a{
    color: #6e483d;
    text-shadow: 0px 0px 3px #fff,0px 0px 5px #fff,0px 0px 10px #fff;
}

header.scr_header{background-color: rgba(255,250,225,0.9)!important;}
header.scr_header .button_container span{
    /*background: #ffd6da;*/
    background: var(--fontColor1);
}
header.scr_header .button_container span:nth-of-type(1){
    background:transparent!important;
    /*color: #ffd6da;*/
    color: var(--fontColor1);
    text-shadow:none;
}
header.scr_header #pc_nav li a{
    /*color: #fff;*/
    /*color: #ffe0a9;*/
    /*text-shadow:none;*/
    text-shadow: 0px 0px 2px #fff, 0px 0px 5px #fff2cf;
    color: #ffd6da;
    color: var(--fontColor1);
}

#page_title .page_title_box{background-color: #ffe7e4;}

.overlay{
    /*background: linear-gradient(135deg, #283c56 10% ,#d98060 50% , #ffe3a3 90% )!important;*/
    background:linear-gradient(135deg, #c4d9f5 10% ,#f5cabb 50% , #fff0ce 90% )!important;
}
.nav_menu_more a{
    background-color: #f1f1f1;
    color: #ebd9eb;
}
.nav_menu_more a:hover{opacity: 0.7;}

.cate_list li a,.pager li a{
    background-color: #e7dd98!important;
    color: #fff;
}
.cate_list li a:before{
    color: rgba(255,255,255,0.7)!important;
}
.cate_list li a:hover,.pager li a:hover{
    background-color: #e0ae94!important;
 }
.linkStyle{
	color:#e9bc00;
	text-decoration: underline;
	transition: all 0.5s;
}
.linkStyle:hover{
	color:#e9bc00;
	opacity: 0.7;
	text-decoration: none;
}
#footer #logo2 a{
    max-width: 220px;
}
#footer_nav{
    background: linear-gradient(0deg, rgb(255 255 255 / 80%) 50%, transparent 100%);
    position: relative;
    padding-top: 50px;
}
footer.bg_color2{background-color: #fffae1;}
.return a{text-shadow: 0px 0px 3px #fff, 0px 0px 3px #fff, 0px 0px 3px #fff;}

/* タブレット */
@media screen and (max-width: 768px){
    .page_title_box{width: 350px;}
}
/* スマホ */
@media screen and (max-width: 667px){
    	#page_title .page_title_box{
	    padding: 11px 0 17px;
	    width: 310px;
	    top: 65%;
	}
	#footer #logo2 a{
        max-width: 160px;
    }
}

/* 配色 ----------------------------------------------*/

.txt_color1,.hvr_txt_color1:hover{color: #b58500;} 
/*.txt_color2,.hvr_txt_color2:hover{color: #f9ebe0;} */
.txt_color3,.hvr_txt_color3:hover{color: #8f6c00;} 
/*.txt_color4,.hvr_txt_color4:hover{color: #eae4df;} */
/*.txt_color5,.hvr_txt_color5:hover{color: #f2ede7;}*/ 
/*header.scr_header,*/
.bg_color1,.hvr_bg_color1:hover{background-color: #a88000;}
.bg_color2,.hvr_bg_color2:hover{background-color: #f2e8c3;}
.bg_color3,.hvr_bg_color3:hover{background-color: #d1bb7a;} 
/*.bg_color4,.hvr_bg_color4:hover{background-color: #eae4df;} */
/*.bg_color5,.hvr_bg_color5:hover{background-color: #f2ede7;}*/ 

.border_color1,.hvr_border_color1:hover{border-color: #b58500;}
/*.border_color2,.hvr_border_color2:hover{border-color: #f9ebe0;}*/
.border_color3,.hvr_border_color3:hover{border-color: #d1bb7a;}
/*.border_color4,.hvr_border_color4:hover{border-color: #eae4df;}*/
/*.border_color5,.hvr_border_color5:hover{border-color: #f2ede7;}*/

/*テンプレート  -------------------------------------*/
#page10 span.en,#page10 span.jp{text-transform:none;}
body,.font_14,.font_12,.font_100per,.font_2dw,.font_2dw_tb,.font_2dw_sp{
    font-size: 18px;
    letter-spacing: 0.05em;
    font-family: 'Noto Serif JP', serif;
/*font-family: 'Shippori Mincho B1', serif;*/
}
.font_14_sp{
    font-size: 16px;
}
.font_2up{
    font-size: 20px;
    
}
.font_4up{
    font-size: 22px;
}

/* スマホ */
@media screen and (max-width: 667px){
    body,.font_14,.font_12,.font_100per,.font_2dw,.font_2dw_tb,.font_2dw_sp{
    font-size: 16px;
    letter-spacing: 0.05em;
    font-family: 'Noto Serif JP', serif;
}
}

/*問い合わせメールマークを吹き出しへ*/
.nav_menu_more:first-of-type a .icon:before{
    content: "\f086";
}

/*背景いじるとき追加*/
.top_cms_box{
    position: relative;
    z-index: 2;
}
/* news type4 -------------------------------*/
.topcms_news_type4 .cate_box{
	width: 30.33333%!important;
	margin-right: 1%;
	margin-left: 1%;
	/*border-radius: 15px;*/
	background-color: #fff;
	padding: 0;
	border: 1px solid #d4bf83;
	/*box-shadow: 10px 25px 30px rgb(0 0 0 / 8%);*/
}
.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;
}
}
/*v_type3-------------------------*/
.v_type3 .cate_box{
    background-color: rgba(255,255,255,1);
    border: 1px solid #d4bf83;
}

/*cms_5-f-------------------------*/
.cms_5-f .box_wrap{
    border: 1px solid #d4bf83;
}

/* 閉じるボタン付き追従バナー */
.fix_banner{
	max-width: 200px;
	position: fixed;
	bottom: 10px;
	right: 60px;
	z-index: 4;
	transition: 0.5s;
}
.fix_banner .close_bt{
	position: absolute;
	bottom: 115px;
    right: 180px;
	display: block;
	width: 30px;
	height: 30px;
	border-radius: 50%;
	transition: 0.5s;
	background-color: rgba(255,255,255,0.8);
	/*border: solid 2px #004b9b;*/
	z-index: 5;
	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: #c5aa54;
	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;
}
.fix_banner.close2{opacity: 0;z-index: -1;}

@media  screen and (max-width: 768px){
.fix_banner{max-width: 200px;}
.fix_banner .close_bt{bottom: 110px;right: 180px;}
}

@media  screen and (max-width: 667px){
.fix_banner{
    max-width: 150px;
    right: 30px;
}
.fix_banner .close_bt{
	width: 25px;
	height: 25px;
	bottom: 87px;
	right: 135px;
}
.fix_banner .close_bt span{
	width: 25px;
	height: 25px;
}
}
/* 閉じるボタン付き追従バナー end */