@import "base.css";
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&family=EB+Garamond:ital,wght@0,400..800;1,400..800&family=Noto+Sans+JP:wght@100..900&family=Noto+Serif+JP:wght@200..900&family=Zen+Old+Mincho&display=swap');

/* 
------------------------------------------------------------ */
a {
	color:#0078ff;
	text-decoration:underline;
	cursor:pointer;
    outline: none;
    -webkit-tap-highlight-color: transparent;
}
a:focus {
  outline: none;
  -webkit-tap-highlight-color: transparent;
}


a img {
	/*firefox*/
	-webkit-backface-visibility:hidden;
	backface-visibility:hidden;
	overflow:hidden;
	box-shadow: #000 0 0 0;
	/*background-color:#ffffff;*/
}

/*画像をウインドウサイズに合わせて可変*/
img{
    vertical-align: bottom;
	max-width: 100%;
    height: auto;
    width /***/:auto;/*IE8のみ適用*/
	 backface-visibility: hidden;
	-webkit-backface-visibility: hidden;
}

/*edge画像ホバーメニュー非表示*/
img {
    pointer-events: none;
}


body {
	color:#333;
	margin:0;
	padding:0;
	font-size:15px;
	font-family: "EB Garamond","Noto Serif JP", serif;
	/*font-family: -apple-system, BlinkMacSystemFont , '游ゴシック体' , 'Yu Gothic', YuGothic , 'ヒラギノ角ゴ ProN' , 'Hiragino Kaku Gothic ProN' , 'メイリオ', 'Meiryo', Osaka, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;*/
	/*font-family: 游明朝, 'Yu Mincho', YuMincho, 'Hiragino Mincho ProN', HGS明朝E, メイリオ, Meiryo, serif;*/
	/*font-family:'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', 'メイリオ', Meiryo, 'ＭＳ Ｐゴシック', sans-serif;*/
	line-height:180%;
	background-color:#f4f4f4;
	text-align:center;
	position:relative;
}






#main-wrapper{
	position:relative;
	margin-top: 90px;
}

.home #main-wrapper{
	margin-top: 0px;
}

/* ヘッダー
------------------------------------------------------------ */
	
#header	{
	position:fixed;
	top:0;
	left:0;
	z-index:1020;
	width:100%;
	height:90px;
	background-color:transparent;
   min-width:1280px;

    
   /**/
	-webkit-transition: 0.6s ease-in-out;
	   -moz-transition: 0.6s ease-in-out;
		 -o-transition: 0.6s ease-in-out;
			transition: 0.6s ease-in-out;
}




#header .logo{
    display: block;
    width: 260px;
    padding: 10px 0 0 20px;
    margin-left: 0px;
    

    /**/
	-webkit-transition: 0.3s ease-in-out;
	   -moz-transition: 0.3s ease-in-out;
		 -o-transition: 0.3s ease-in-out;
			transition: 0.3s ease-in-out;
    
    
}
#header .logo a{
    display: block;
}



.home #header{
	display: none;
}



/* ナビ部分 
------------------------------------------------------------ */
#menuBtn{
	display:block;
}
#menuClose,
#shadows{
	display:none;
}

#menuBtn{
	position:fixed;
	top:0px;
	right:0;
	width:110px;
	height:90px;
	z-index:1050;
    cursor: pointer;
    
    
    /*1P時*/
    display: none !important;
    
}


#panel-btn{
  display: block;
  position: relative;
  width: 110px;
  height: 90px;
  
  
}

#panel-btn-icon{
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  width: 36px;
  height: 1px;
  margin: -1px 0 0 -15px;
  background: #000;
  transition: .2s;
}
#panel-btn-icon:before, #panel-btn-icon:after{
  display: block;
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  width: 100%;
  height: 1px;
  background: #000;
  transition: .3s;
}
#panel-btn-icon:before{
  margin-top: -16px;
}
#panel-btn-icon:after{
  margin-top: 14px;
}


#menuBtn.open #panel-btn-icon{
  background: transparent;
}
#menuBtn.open #panel-btn-icon:before, #menuBtn.open #panel-btn-icon:after{
  margin-top: 0;
 
}
#menuBtn.open #panel-btn-icon:before{
  transform: rotate(-45deg);
  -webkit-transform: rotate(-45deg);

}
#menuBtn.open #panel-btn-icon:after{
  transform: rotate(-135deg);
  -webkit-transform: rotate(-135deg);

}





#menuClose{
	position:relative;
	z-index:1010;
}
#shadows{
	position:fixed;
	width:100%;
	height:120%;
	top:0;
	left:0;
	background-color:#000;
	opacity: 0.8;
	filter: alpha(opacity=80);
	z-index:1001;
}

#navi{
	display:none;
	position:absolute;
	top:81px;
	left:0;
	width:100%;
	background-color:#f8f8f8;
}

/* フッター
------------------------------------------------------------ */
#footer{
    background-color: #000;
    padding: 35px 0;
    text-align: center;
    position: relative;
    z-index: 100;
}
#footer address{
    text-align: center;
    color: #aaa;
    font-size: 13px;
    letter-spacing: 0.1em;
}


/* ボタン 
--------------------------------------------*/
.btn-link{
	/**/
	border-radius: 6px;
	-webkit-border-radius: 6px;
	-moz-border-radius: 6px;
	
	/**/
  	box-shadow: 2px 2px 4px rgba(0,0,0,0.20);

}



/* お問い合わせ
--------------------------------------------*/
.contact-page-area{
	padding: 40px 0 80px 0;
}
.contact-page-area h1{
	font-weight: 400;
	font-size: 30px;
	text-align: center;
	border-bottom: solid #dcdcdc 1px;
	padding: 40px 0 20px 0;
	margin-bottom: 40px;
}

.contact-page-area .wpforms-submit{
	display: block;
	width: 50%;
	margin: 40px auto 0 auto;
}



/* top 
--------------------------------------------*/
.main-area{
    position: relative;
    background-color: #000;
    z-index: 1;
}


@media screen and (min-width: 641px){

    /*スクロール画面固定コンテンツ基本
    -------------------------------------------------------------------------*/
    /*スクロールラッパー要素*/
    .scroll-contents-wrapper{
        position: relative;
        color: #fff;
        padding: 0 !important;
    }

    /*スクロール　ブロック01*/
    .scroll-contents-wrapper .scroll-contents{
        width: 100%;
        position: relative;
        z-index: 10;
        padding-top: 0px !important;
    }
    .scroll-contents-wrapper .scroll-contents div { 
        min-height: 70vh;
        height: auto;
    }
    .scroll-contents-wrapper .scroll-contents div:first-child{
       min-height: 60vh;
        background-color: transparent !important;
    }
    .scroll-contents-wrapper .scroll-contents div:last-child{
        padding-top: 80vh;
        padding-bottom: 10vh;
        
        
    }

    /*固定ブロック01の内包divクリア*/
    .scroll-contents-wrapper .scroll-contents div div{
        padding-top: 0!important;
        height: auto!important;
        min-height: auto!important;
    }
    .scroll-contents-wrapper .scroll-contents div:last-child div{
        padding-top: 0 !important;
        padding-bottom: 0!important;
        min-height: auto!important;
        padding-left: 25% !important;
        padding-right: 5% !important;
    }


    /*スクロール　ブロック02*/
    .scroll-contents-wrapper .scroll-contents-fixed{
        width: 100% !important;
        height: 100vh;
        display: block;
        position: fixed;
        align-items: center;
        top:0;
        left: 0;
        display: table;
        z-index: 1;
    }
    .scroll-contents-wrapper .scroll-contents-fixed div {
        width: 100%;
        height: 100vh;
        margin: 0;
        display: table;
        visibility: hidden;
        position: fixed;
        top: 0;
        bottom: 0;
        left: 0;
        text-align: center;
        
        /* フェード速度 */
        transition: .8s;
        opacity: 0;
    }
    .scroll-contents-wrapper .scroll-contents-fixed div:first-child,
    .scroll-contents-wrapper .scroll-contents-fixed div.active {
        visibility: visible;
        opacity: 1;
    }


    .scroll-contents-wrapper .scroll-contents-fixed div .inner{
       width: 100%;
       display: table-cell;
        vertical-align: middle;
        text-align: center;
        position: relative;
    }
    /*固定ブロック02の内包divクリア*/
    .scroll-contents-wrapper .scroll-contents-fixed div .inner div{
        width: 100%;
        text-align: center;
        height: auto;
        padding-bottom: 10vh;
        display: block;
        margin: 0 auto;
        background: none;
        position: relative;
        top:inherit;
        bottom: inherit;
        left: inherit;
        opacity: 1;
        visibility: inherit;
    }


    /*レイアウト*/
    .scroll-contents-wrapper .scroll-contents div .inner{
        text-align: left;
        padding: 0 15% 0 5%;
        background-color: #000;
        font-size: 15px;
    }


    /**/
    .scroll-contents-wrapper .scroll-contents-fixed div .inner{
        position: relative;
        left: 0%;
        background: none;
       
        background-size: cover;
        text-align: left;
        padding: 0 0 0 0;
        font-size: 16px;
    }
    .scroll-contents-wrapper .scroll-contents-fixed div:last-child .inner{
        background-color: transparent;
    }



    /**/
    .scroll-contents-wrapper .scroll-contents .scroll-box1{
        width: 100%;
        margin: auto;
        display: table;
        opacity: 1;
        height: 35vh;
    }
    .scroll-contents-wrapper .scroll-contents .scroll-box1 .inner{
        display: table-cell;
        vertical-align: bottom;
        text-align: center;
        position: relative;
    }
    
    

    .scroll-contents-wrapper .scroll-contents-fixed .scroll-box1{
        
    
        background: #000 url("../../images/bg.jpg") left center no-repeat;/*背景01*/
        background-size: cover;
    }
    .scroll-contents-wrapper .scroll-contents-fixed .scroll-box2{
        background: #000 url("../../images/bg.jpg") left center no-repeat;/*背景01*/
        background-size: cover;
    }

    
    .scroll-contents-wrapper .scroll-contents-fixed .scroll-box3{
        background: #000 url("../../images/bg.jpg") left center no-repeat;/*背景01*/
        background-size: cover;
    }
    .scroll-contents-wrapper .scroll-contents-fixed .scroll-box4{
        /* 画像が透過pngの時は背景色が必要です */
        background: #000 url("../../images/main_bg.webp") left center no-repeat;
        background-size: auto 100%;
    }

 


    /**/
    .scroll-contents-wrapper .tagline{
        margin-bottom: 0;
        position: relative;
    }

    .scroll-contents-wrapper .tagline:after{
        content: '';
        position: absolute;
        left: 7.5%;
        top:50%;
        margin: -345px auto 0 auto;
        width: 100%;
        height: 650px;
        background: url("../../images/bg_enn.png") center center no-repeat;
        background-size: 650px 650px;
        opacity: 0.3;
    }

    .scroll-contents-wrapper .tagline h2{
        font-size: 45px;
        text-align: center;
        line-height: 130%;
        font-family: "Quattrocento", serif;
        font-weight: 400;
        margin-left: -9%;
        letter-spacing: 0.1em;
        
        color: #f1f1f1;
    }
    .scroll-contents-wrapper .tagline h2 span{
        display: block;
        font-size: 16px;
        letter-spacing: 0.1em;
        color: #aaa;
        
        width: 200px;
        margin: 0 auto;
        padding-top: 60px;
        
        /* フェード速度 */
        transition: .8s;
        position: relative;
    }
    .scroll-contents-wrapper .active .tagline h2 span{
        margin-bottom: 0;
    }
    
    
    .scroll-contents-wrapper .tagline h2 em{
        font-style: normal;
        font-weight: 200;
        display: inline-block;
        margin-left: 1em;
    }
    


    .scroll-contents-wrapper .message{
        /* フェード速度 */
        transition: 1s;
        opacity: 1 !important;
    }
    .scroll-contents-wrapper .message.hide{
        opacity: 0 !important;
    }


    /**/
    .scroll-contents-wrapper .message{
        width: 60% !important;
        margin: 0 auto;
        position: relative;
        padding-left: 1%;
        
    }
    .scroll-contents-wrapper .message h2{
        font-size: 30px;
        font-weight: 700;
        padding-bottom: 50px;
        font-family: "Quattrocento", serif;
        font-weight: 400;
        /* フェード速度 */
        transition: 1s;
        position: relative;
        margin-bottom: -100px;
        opacity: 0;
    }
    .scroll-contents-wrapper .active .message h2{
        margin-bottom: 0;
        opacity: 0.6;
    }

    .scroll-contents-wrapper .message p{
        /* フェード速度 */
        transition: 1s;
        position: relative;
        margin-bottom: -150px;
        opacity: 0;
        line-height: 3.5vh;
    }

    .scroll-contents-wrapper .active .message p{
        margin-bottom: 0;
        opacity: 1;
    }

    .scroll-contents-wrapper .message strong.lf{
        font-size: 25px;
        font-family: "Quattrocento", serif;
        font-weight: 400;
        line-height: 140%;
        display: block;
        padding-bottom: 20px;
    }


    /**/
    .scroll-contents-wrapper .profile h2{
        font-family: "EB Garamond","Zen Old Mincho", serif;
        font-weight: 200;
        font-size: 25px;
        padding-bottom: 15px;
    }
    .scroll-contents-wrapper .profile .sf{
        font-size: 14px;
        padding: 0 !important;
        padding-bottom: 40px !important;
        display: block;
    }
    .scroll-contents-wrapper .profile{
        line-height: 160%;
        /* フェード速度 */
        transition: 1s;
        position: relative;
        opacity: 0;
    }

    .scroll-contents-wrapper .active .profile{
        opacity: 1;
    }

    .scroll-contents-wrapper .profile .profile-logo{
        width: 50%;
		min-width: 400px !important;
        margin-top:140px;
        margin-bottom: 50px;
        
    }
    .scroll-contents-wrapper .profile .profile-logo strong{
        opacity: 0.7;
    }
    .scroll-contents-wrapper .profile .profile-logo span{
        width: 55%;
        margin: 0 auto;
        display: block;
        margin-top: 50px;
        opacity: 1;
    }


}


.scroll-contents-wrapper .profile table{
    width: 100%;
    margin-top: 20px;
    margin-bottom: 40px;
}
.scroll-contents-wrapper .profile table th{
    font-weight: 200;
    width: 10%;
    padding: 5px 0;
}
.scroll-contents-wrapper .profile table td{
    font-weight: 200;
    padding: 5px 0;
}


/* 
------------------------------------------------------------ */
.top-info{
    position: fixed;

    width: 100%;
    background-color: #fff;
    bottom:0;
    left: 0;
    z-index: 10;
    text-align: left;
}
.top-info-box{
    display: table;
    width: 100%;
    height: 60px;
}
.top-info-box .inner{
    display: table-cell;
    vertical-align: middle;
}


/**/

.contact-btn-area{
	background-color: #000;
	padding: 60px 0 40px 0;
}
.contact-btn-area .contact-btn-area-inner{
	text-align: center;
}

.contact-btn-area .btn-link{
	display: inline-block;
	width: 50%;
}
.contact-btn-area .btn-link a{
	display: block;
	background-color: #c40e18;
	color: #fff;
	font-size: 18px;
	list-style: 120%;
	padding: 20px 40px;
	text-decoration: none;
	border-radius: 6px;
}

/**/
.top-contents{
    background-color: #fff;
    position: relative;
    z-index: 20;
}



/**/
.section-block{
    padding: 110px 0 0 0;
}
.section-block .title{
    font-family: "Quattrocento","Zen Old Mincho", serif;
    font-weight: 200;
    font-size: 45px;
    text-align: center;
    padding-bottom: 40px;
    letter-spacing: 0.1em;
    line-height: 150%;
}
.section-block .title span{
    display: block;
    font-size: 16px;
    line-height: 140%;
    color: #aaa;
}



/* 一覧
------------------------------------------------------------ */

.icon-cat{
    display: inline-block;
    line-height: 100%;
    font-size: 14px;
    color: #767676;
    padding: 5px 20px;
    min-width: 80px;
    background-color: #e4e4e4;
}



/**/

.item-list-wrapp{
    overflow: hidden;
    border-top: solid #dcdcdc 1px;
    border-bottom: solid #dcdcdc 1px;
    padding-bottom: 70px;
}

.item-wrapp ul li .item-box{
    padding: 0 10%;
}
.item-wrapp ul li .item-box a{
    text-decoration: none;
    color: #333;
    line-height: 150%;
    display: block;
}

.item-wrapp ul li .item-box .item-box-inner{
    padding: 15px 4%;
    position: relative;
}
.item-wrapp ul li .item-box .item-box-inner .imgbox{
    padding: 0px 10% 0 10%;
    display: table;
    width: 80%;
    height: 400px;
}
.item-wrapp ul li .item-box .item-box-inner .imgbox .imgbox-inner{
    vertical-align: middle;
    display: table-cell;
    text-align: center;
}


.item-wrapp ul li .item-box .item-box-inner .txtbox{
    padding-top: 10px;
}
.item-wrapp ul li .item-box .item-box-inner .txtbox h2{
    font-size: 15px;
    word-wrap: break-word;
    overflow-wrap: break-word;
    font-weight: 500;
    line-height: 150%;
}
.item-wrapp ul li .item-box .item-box-inner .txtbox p{
    margin-top: 5px;
    font-size: 14px;
    color: #767676;
    word-wrap: break-word;
    overflow-wrap: break-word;
    font-weight: 200;
    line-height: 140%;
}
.item-wrapp ul li .item-box .item-box-inner .txtbox .icon-cat{ 
    margin-top: 18px;
}




/* スライダー基本
--------------------------------------------*/

.item-list-inner{
    margin: 0 auto;
    width: auto;
    padding-left: 8%;
    padding-right: 8%;
}           
.item-wrapp{
    position: relative;
}    
.item-wrapp .slick-list{
    overflow: visible;
}



/* ドットcss*/

.slick-dots{
    text-align: center !important;
    width: 100% !important;
    bottom:-40px !important;
}
.slick-dots ul{
    text-align: center !important;
    width: 100% !important;
}
.slick-dots li {
    display: inline-block;
    width: auto !important;
    float: none !important;
    margin: 0 10px !important;
    list-style: none !important;
}
.slide-dots li button {
  position: relative;
  text-indent: -99999px;
  background: none !important;
}
.slick-dots li button:before{
    background: url("../../images/dot.png") no-repeat center center !important;
    background-size: 9px 9px !important;
    opacity: 1 !important;
    width: 9px;
    height: 9px;
}

.slick-dots li.slick-active button:before{
  background: url("../../images/dot_active.png") no-repeat center center !important;
  background-size: 9px 9px !important;
  opacity: 1 !important;
}
button {
  background: none;
  border: none;
  outline: none;
}


/*infinite: false　の時、最初と最後の矢印消す*/
.slick-next.slick-disabled,
.slick-prev.slick-disabled{
    display:none !important;
}




			

/* スライダー基本通常ここから
--------------------------------------------*/

.slick-next {
	position: absolute;
    right: -5%;
	top:50%;
	margin-top: -25px;
    z-index: 99;
	display: block;
	text-indent: -9999px;
	width:50px;
	height:50px;
	background: #000 url(../../images/btn_next.png) no-repeat center center !important;
	background-size: 70% auto!important;
	cursor:pointer;
	border: none;
}
.slick-prev {
	position: absolute;
    left: -5%;
	top:50%;
	margin-top: -25px;
    z-index: 100;
	display: block;
	text-indent: -9999px;
	width:50px;
	height:50px;
	background: #000 url(../../images/btn_prev.png) no-repeat center center !important;
	background-size: 70% auto!important;
	cursor:pointer;
	border: none;
}



/**/
/* Slider */
.slick-slider
{
    position: relative;

    display: block;
    box-sizing: border-box;

    -webkit-user-select: none;
       -moz-user-select: none;
        -ms-user-select: none;
            user-select: none;

    -webkit-touch-callout: none;
    -khtml-user-select: none;
    -ms-touch-action: pan-y;
        touch-action: pan-y;
    -webkit-tap-highlight-color: transparent;
}

.slick-list
{
    position: relative;

    display: block;
    overflow: hidden;

    margin: 0;
    padding: 0;
}
.slick-list:focus
{
    outline: none;
}
.slick-list.dragging
{
    cursor: pointer;
    cursor: hand;
}

.slick-slider .slick-track,
.slick-slider .slick-list
{
    -webkit-transform: translate3d(0, 0, 0);
       -moz-transform: translate3d(0, 0, 0);
        -ms-transform: translate3d(0, 0, 0);
         -o-transform: translate3d(0, 0, 0);
            transform: translate3d(0, 0, 0);
}

.slick-track
{
    position: relative;
    top: 0;
    left: 0;

    display: block;
    margin-left: auto;
    margin-right: auto;
}
.slick-track:before,
.slick-track:after
{
    display: table;

    content: '';
}
.slick-track:after
{
    clear: both;
}
.slick-loading .slick-track
{
    visibility: hidden;
}

.slick-slide
{
    display: none;
    float: left;

    height: 100%;
    min-height: 1px;
}
[dir='rtl'] .slick-slide
{
    float: right;
}
.slick-slide img
{
    display: block;
}
.slick-slide.slick-loading img
{
    display: none;
}
.slick-slide.dragging img
{
    pointer-events: none;
}
.slick-initialized .slick-slide
{
    display: block;
}
.slick-loading .slick-slide
{
    visibility: hidden;
}
.slick-vertical .slick-slide
{
    display: block;

    height: auto;

    border: 1px solid transparent;
}
.slick-arrow.slick-hidden {
    display: none;
}	

/**/
.slick-dots{
  position: absolute;
  bottom: -25px;
  display: block;
  width: 100%;
  padding: 0;
  margin: 0;
  list-style: none;
  text-align: center;
}
.slick-dots li{
  position: relative;
  display: inline-block;
  width: 20px;
  height: 20px;
  margin: 0 5px;
  padding: 0;
  cursor: pointer;
}
.slick-dots li button{
  font-size: 0;
  line-height: 0;
  display: block;
  width: 20px;
  height: 20px;
  padding: 5px;
  cursor: pointer;
  color: transparent;
  border: 0;
  outline: none;
  background: transparent;
}
.slick-dots li button:hover,
.slick-dots li button:focus{
  outline: none;
}
.slick-dots li button:hover:before,
.slick-dots li button:focus:before{
  opacity: 1;
}
.slick-dots li button:before{
  font-size: 0px;
  line-height: 20px;
  position: absolute;
  top: 0;
  left: 0;
  width: 20px;
  height: 20px;
  content: '•';
  text-align: center;
  opacity: .25;
  color: black;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
.slick-dots li.slick-active button:before{
  opacity: .75;
}				