@import url('https://fonts.googleapis.com/css2?family=Jost:wght@200;300;400;500;600&family=Noto+Sans+JP:wght@300;400;500;700;900&display=swap');

/*------------------------------------------------------------
	margin padding
------------------------------------------------------------*/
.mt5{margin-top:5px;}
.mt10{margin-top:10px;}
.mt15{margin-top:15px;}
.mt20{margin-top:20px;}
.mt25{margin-top:25px;}
.mt30{margin-top:30px;}
.mt35{margin-top:35px;}
.mt40{margin-top:40px;}
.mt45{margin-top:45px;}
.mt50{margin-top:50px;}

.mb5{margin-bottom:5px;}
.mb10{margin-bottom:10px;}
.mb15{margin-bottom:15px;}
.mb20{margin-bottom:20px;}
.mb25{margin-bottom:25px;}
.mb30{margin-bottom:30px;}
.mb35{margin-bottom:35px;}
.mb40{margin-bottom:40px;}
.mb50{margin-bottom:50px;}
.mb100{margin-bottom:100px;}

.ml5{margin-left:5px;}
.ml10{margin-left:10px;}
.ml20{margin-left:20px;}

.mr10{margin-right:10px;}
.mr20{margin-right:20px;}

.pt5{padding-top:5px;}
.pt10{padding-top:10px;}
.pt15{padding-top:15px;}
.pt20{padding-top:20px;}
.pt25{padding-top:25px;}
.pt30{padding-top:30px;}

.pl10{padding-left:10px;}
.pl15{padding-left:15px;}
.pl20{padding-left:20px;}

.pr15{padding-right:15px;}
.pr20{padding-right:20px;}

.float_0{float:left;}
.float_mr5{float:left;margin-right:5px;}
.float_mr10{float:left;margin-right:10px;}
.float_mr20{float:left;margin-right:20px;}
.float_mr30{float:left;margin-right:30px;}

.float_r{float:right;}

/*クリアフィックス*/
.clearfix:after{content:"."; display:block; clear:both; height:0; visibility:hidden;}
.clearfix{min-height:1px;}
.clear{clear:both;}

/*------------------------------------------------------------
	汎用スタイル
------------------------------------------------------------*/

a{
	color:#fff;
	text-decoration:none;
}

a:hover{
	color:#f00;
}

p.attention {
	font-family: '游明朝', 'YuMincho', 'ヒラギノ明朝 ProN W3', 'Hiragino Mincho ProN', serif;
	font-size: 16px;
	text-align: center;
	letter-spacing: 4px;
	width: 100%;
	margin: 10px 0;
}

html, body{
	font:12px/160% "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	color:#fff;
	background-color:#000;
	margin: 0;
	padding: 0;	
	height: 100%;
	width: 100%;
}

#fks_bg01{
	background:url(../images/fks_back1.png) repeat-y center top;
}

#fks_bg02{
	background:url(../images/fks_back2.png) repeat-y center top;
}

#fks_bg03{
	background:url(../images/fks_back3.png) repeat-y center top;
	display:none;
}

#fks_top{
	background:url(../images/fks_main02.jpg) no-repeat left top;
}

#fks_stage{
	height: 5600px;
}

#gn{
	background:rgba(0,0,0,.8);
	padding:10px;
	height:85px;
	width:100%;
	display:none;
	position:fixed;
	top: 0;
    left: 0;
	z-index:100000;
}

#gn_fks{
	height:85px;
	display:none;
	position:relative;
}

#logo{
	position:absolute;
	top:0;
	left:30px;
}

#gn_wrap{
	width:684px;
	margin:0 auto;
}

#gn_wrap li{
	float:left;
	height:85px;
}

#gn_wrap li#menu01 a{
	background:url(../images/navi/fks_01.png) no-repeat;
	width:94px;
	height:85px;
	display:block;
}

#gn_wrap li#menu01 a.active{
	background:url(../images/navi/fks_01on.png) no-repeat;
	width:94px;
	height:85px;
	display:block;
}

#gn_wrap li#menu02 a{
	background:url(../images/navi/fks_02.png) no-repeat;
	width:124px;
	height:85px;
	display:block;
}

#gn_wrap li#menu02 a.active{
	background:url(../images/navi/fks_02on.png) no-repeat;
	width:124px;
	height:85px;
	display:block;
}

#gn_wrap li#menu03 a{
	background:url(../images/navi/fks_03.png) no-repeat;
	width:94px;
	height:85px;
	display:block;
}

#gn_wrap li#menu03 a.active{
	background:url(../images/navi/fks_03on.png) no-repeat;
	width:94px;
	height:85px;
	display:block;
}

#gn_wrap li#menu04 a{
	background:url(../images/navi/fks_04.png) no-repeat;
	width:131px;
	height:85px;
	display:block;
}

#gn_wrap li#menu04 a.active{
	background:url(../images/navi/fks_04on.png) no-repeat;
	width:131px;
	height:85px;
	display:block;
}

#gn_wrap li#menu05 a{
	background:url(../images/navi/fks_05.png) no-repeat;
	width:103px;
	height:85px;
	display:block;
}

#gn_wrap li#menu05 a.active{
	background:url(../images/navi/fks_05on.png) no-repeat;
	width:103px;
	height:85px;
	display:block;
}

#gn_wrap li#menu06 a{
	background:url(../images/navi/fks_06.png) no-repeat;
	width:88px;
	height:85px;
	display:block;
}

#gn_wrap li#menu06 a.active{
	background:url(../images/navi/fks_06on.png) no-repeat;
	width:88px;
	height:85px;
	display:block;
}

#gn_wrap li#menu07 a{
	background:url(../images/navi/fks_07.png) no-repeat;
	width:138px;
	height:85px;
	display:block;
}

#gn_wrap li#menu07 a.active{
	background:url(../images/navi/fks_07on.png) no-repeat;
	width:138px;
	height:85px;
	display:block;
}

#kitashinchi{
	display:none;
}

.fks_logo{
	position:absolute;
	bottom:60px;
	left:20px;
}

.fks_tit{
	position:absolute;
	top:115px;
	right:20px;
}

.godown{
	background:rgba(0,0,0,.8);
	position:absolute;
	top:590px;
	text-align:center;
	width:100%;
	display:none;
}

#lower_stage{
	width:1200px;
	margin:0 auto;
}

.contents-block{
	width:1200px;
	margin:0 auto;
}

.fks_gallery{
	display:none;
}

/************* コンセプト **************/

#fks_concept{
	position:absolute;
	top:1100px;
	height:850px;
}

#fks_concept_wrap >div{
	padding-left:105px;	
}

#fks_concept_btn{
	position:relative;
	width:267px;
	margin:20px 0 0 15px;
}

ul.gallery {
	display: flex;
	justify-content: center;
	align-items: center;
	flex-wrap: wrap;
}

ul.gallery li,
ul.gallery li img {
	width: 200px;
}


/************* メニュー **************/

#fks_menu {
	position: absolute;
	top: 1900px;
	padding-top: 120px;
	height: 850px;
}

#fks_menu_wrap{
	position:relative;
}

#fks_menu_tit{
	background:url(../images/fks_menu_bg.png) no-repeat;
	width:388px;
	height:208px;
	padding-top:180px;
	text-align:center;
	position:absolute;
	left:204px;
}

#fks_menu_btn01{
	position:absolute;
	top:204px;
}

#fks_menu_btn02{
	position:absolute;
	top:204px;
	left:408px;
}

#fks_menu_btn03{
	position:absolute;
	left:612px;
}

#fks_menu_btn04{
	background:url(../images/fks_menu_bg.png) no-repeat;
	width:388px;
	height:213px;
	padding-top:175px;
	text-align:center;
	position:absolute;
	top:204px;
	left:816px;
}

#fks_menu_btn04 #fks_menu_tabelog{
	position:relative;
	width:268px;
	margin:0 auto;
}

/************* ケータリング **************/

#fks_catering{
	position:absolute;
	top:2800px;
	padding-top:110px;
	height:850px;
	width:1200px;
	text-align:center;
}

#fks_catering_btn{
	position:relative;
	width:267px;
	margin:20px auto 0;
}

/************* ブライダルプラン **************/

#fks_bridal{
	position:absolute;
	top:3850px;
	padding-top:100px;
	height:850px;
	width:1200px;
	text-align:center;
}

#fks_bridal_txtwrap{
	text-align:left;
	font-size:14px;
	line-height:180%;
	margin-bottom:30px;
}

#fks_bridal_plan01{
	background:url(../images/fks_bridal_bg.png) no-repeat;
	width:365px;
	height:305px;
	color:#333;
	padding-top:60px;
	margin-right:53px;
	float:left;
}

#fks_bridal_plan02{
	background:url(../images/fks_bridal_bg.png) no-repeat;
	width:365px;
	height:305px;
	color:#333;
	padding-top:60px;
	margin-right:52px;
	float:left;
}

#fks_bridal_plan03{
	background:url(../images/fks_bridal_bg.png) no-repeat;
	width:365px;
	height:305px;
	color:#333;
	padding-top:60px;
	float:left;
}

#fks_bridal_btn_wrap{
	width:270px;
	margin:40px auto 0; 
}

#fks_bridal_btn01{
	position:relative;
	width:270px;
	margin-right:50px;
	float:left;
	z-index: 100;
}

#fks_bridal_btn02{
	position:relative;
	width:270px;
	float:left;
	z-index: 100;
}

/************* スタッフ **************/

#fks_staff{
	position:absolute;
	top:4750px;
	padding-top:100px;
	height:750px;
	width:1200px;
	text-align:center;
}

#fks_staff_bg{
	background:url(../images/fks_staff_bg.png) no-repeat center 84%;
	z-index:-1;
}

#fks_staff_box1{
	float:left;
}

#fks_staff_box2{
	float:left;
}

#fks_staff_box3{
	float:left;
}

#fks_staff_box4{
	float:left;
}

#fks_staff_box5{
	float:left;
}

#fks_staff_box6{
	float:left;
}

/************* 店舗情報 **************/

#fks_shop{
	width:100%;
	height:950px;
	position:absolute;
	top:4820px;
}

#fks_shop_stage{
	position:relative;
}

#fks_shop_bg{
	background:url(../images/fks_shop_bg.jpg) no-repeat bottom center;
	width:100%;
	height:1000px;
	position:absolute;
	top:-220px;
}

#fks_shop_wrap {
	width: 1270px;
	padding-top: 300px;
	margin: 0 auto;
}

#fks_shop_left{
	float:left;
	width:625px;
	margin-right:30px;
}

#fks_shop_right{
	float:left;
}

#fks_access_btn{
	position:relative;
	width:270px;
	margin-top:30px;
}

#fks_shop_name{
	font-size:16px;
	font-weight:bold;
	color:#bbb;
	margin-bottom:10px;
}

.fks_shop_sub{
	font-size:14px;
	width:110px;
	padding:3px 0;
	margin-right:20px;
	float:left;
	text-align:center;
	border:solid 1px #bbb;
	color:#bbb;
}

.fks_shop_data {
	font-size: 14px;
	line-height: 160%;
	width: 470px;
	float: left;
	color: #bbb;
	text-shadow: 0 0 5px #000,0 0 5px #000,0 0 5px #000,0 0 5px #000;
}

/************* フッター **************/

.company-btn {
    display: block;
    border: solid 1px #747474;
    width: 200px;
    margin: 10px auto 20px;
    text-align: center;
    padding: 12px 0;
    font-size: 12px;
    color: #fff;
}

.company-btn:hover {
    color: #fff;
	text-decoration: underline;
}

footer{
	background-color:#050505;
	width:100%;
	height: auto;
	padding-top:30px;
	color:#fff;
}

footer aside.banner{
	width: 58%;
	max-width: 300px;
	margin: 10px auto 0;
	padding-top: 10px;
	padding-bottom:50px;

	.ban{
		margin-top: 10px;
		display: block;
		
		>em{
			color: #fff;
			font-size: 14px;
			text-align: center;
			display: block;
			line-height: 1.4em;
			text-decoration:underline;
			margin-top: 0.5em;
		}

		img{
			width: 196px;
			margin: 0 auto;
			display: block;
		}
	}
}

#footer_wrap{
	position:relative;
}

#footer_left{
	position:absolute;
	top:20px;
	left:40px;
}

#footer_center{
	width: 340px;
	text-align: center;
	margin: 0 auto;
}

#footer_right{
	position:absolute;
	top:40px;
	right:40px;
}

#footer_left{
	font-size: 16px;
	letter-spacing: 8px;
	text-align: center;
	width: 180px;
	height: 36px;
	line-height: 36px;
	position:absolute;
	top:40px;
	left:40px;
    border: 2px solid #333;
    content: '';
    -webkit-transition: -webkit-transform 0.3s, opacity 0.3s;
    -moz-transition: -moz-transform 0.3s, opacity 0.3s;
    transition: transform 0.3s, opacity 0.3s;
}

#footer_left:hover{
	opacity: 0.6;
}

#footer_left a{
	color: #c8c8c8;
	display: block;
}

/*==============================
 マウスオーバー用 */
#fks_concept_btn a::before,#fks_catering_btn a::before,#fks_bridal_btn01 a::before,#fks_bridal_btn02 a::before,#fks_access_btn a::before,
#fks_concept_btn a::after,#fks_catering_btn a::after,#fks_bridal_btn01 a::after,#fks_bridal_btn02 a::after,#fks_access_btn a::after {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	border: 2px solid #333;
	content: '';
	-webkit-transition: -webkit-transform 0.3s, opacity 0.3s;
	-moz-transition: -moz-transform 0.3s, opacity 0.3s;
	transition: transform 0.3s, opacity 0.3s;
}

#fks_concept_btn a::after ,#fks_catering_btn a::after ,#fks_bridal_btn01 a::after ,#fks_bridal_btn02 a::after,#fks_access_btn a::after {
	border-color: #fff;
	opacity: 0;
	-webkit-transform: translateY(-7px) translateX(6px);
	-moz-transform: translateY(-7px) translateX(6px);
	transform: translateY(-7px) translateX(6px);
}

#fks_concept_btn a:hover::before,#fks_catering_btn a:hover::before,#fks_bridal_btn01 a:hover::before,#fks_bridal_btn02 a:hover::before,#fks_access_btn a:hover::before,
#fks_concept_btn a:hover::focus,#fks_catering_btn a:hover::focus,#fks_bridal_btn01 a:focus::before,#fks_bridal_btn02 a:focus::before,#fks_access_btn a:focus::before {
	opacity: 0;
	-webkit-transform: translateY(5px) translateX(-5px);
	-moz-transform: translateY(5px) translateX(-5px);
	transform: translateY(5px) translateX(-5px);
}

#fks_concept_btn a:hover::after,#fks_catering_btn a:hover::after,#fks_bridal_btn01 a:hover::after,#fks_bridal_btn02 a:hover::after,#fks_access_btn a:hover::after,
#fks_concept_btn a:focus::after,#fks_catering_btn a:focus::after,#fks_bridal_btn01 a:focus::after,#fks_bridal_btn02 a:focus::after,#fks_access_btn a:focus::after  {
	opacity: 1;
	-webkit-transform: translateY(0px) translateX(0px);
	-moz-transform: translateY(0px) translateX(0px);
	transform: translateY(0px) translateX(0px);
}

#fks_menu_tabelog a {
	-webkit-transition: color 0.3s;
	-moz-transition: color 0.3s;
	transition: color 0.3s;
}

#fks_menu_tabelog a::before,
#fks_menu_tabelog a::after {
	position: absolute;
	left: 0;
	width: 100%;
	height: 2px;
	background: #fff;
	content: '';
	opacity: 0;
	-webkit-transition: opacity 0.3s, -webkit-transform 0.3s;
	-moz-transition: opacity 0.3s, -moz-transform 0.3s;
	transition: opacity 0.3s, transform 0.3s;
	-webkit-transform: translateY(-10px);
	-moz-transform: translateY(-10px);
	transform: translateY(-10px);
}

#fks_menu_tabelog a::before {
	top: 0;
	-webkit-transform: translateY(-10px);
	-moz-transform: translateY(-10px);
	transform: translateY(-10px);
}

#fks_menu_tabelog a::after {
	bottom: 0;
	-webkit-transform: translateY(10px);
	-moz-transform: translateY(10px);
	transform: translateY(10px);
}

#fks_menu_tabelog a:hover,
#fks_menu_tabelog a:focus {
	color: #fff;
}

#fks_menu_tabelog a:hover::before,
#fks_menu_tabelog a:focus::before,
#fks_menu_tabelog a:hover::after,
#fks_menu_tabelog a:focus::after {
	opacity: 1;
	-webkit-transform: translateY(0px);
	-moz-transform: translateY(0px);
	transform: translateY(0px);
}

/* マウスオーバー用
============================== */

.special-ban{
	width: 440px;
	display: block;
	position: absolute;
	bottom: -770px;
	left: 0;
	right: 0;
	margin: auto;

	img{
		width: 100%;
	}
}

/* オリジナルブランド
============================== */
#brand{
	h2 {
		font-family: 'Cinzel', serif;
		text-align: center;
		margin: 50px 0 30px;
		font-size: 26px;
		line-height: 1.4;

		span {
			display: block;
			font-size: 16px;
		}
	}

	ul#project-list {
		width: 100%;
	}

	ul#project-list li {
		text-align: center;
	}

	ul#project-list li figcaption {
		letter-spacing: 4px;
		padding: 16px 0 40px;
		color: #fff;
		background-color: #171717;
		position: relative;
		z-index: 10;
	}

	ul#project-list li h3 {
		font-family: 'Cinzel', serif;
		font-size: 1.8em;
		line-height: 150%;
		margin-bottom: 20px;
		display: flex;
		justify-content: center;
		align-items: center;
		flex-wrap: wrap;
	}

	ul#project-list li h3 span {
		font-size: 14px;
	}

	ul#project-list li span.en {
		font-family: 'Cinzel', serif;
		font-size: 14px;
		font-weight: 300;
	}

	.col {
		overflow: hidden;
		position: relative;
	}

	.slide {
		position: absolute;
		top: 0;
		right: 0;
		bottom: 0;
		left: 0;
		transition: all 0.275s ease-in-out, visibility 0s 0.275s;
		visibility: hidden;
		will-change: transform;
		transform: translateY(100%);
		display: flex;
		justify-content: center;
		align-items: center;
	}

	.slide p {
		font-family: 'Cinzel', serif;
		font-size: 28px;
		line-height: 120%;
		letter-spacing: 3px;
		text-align: center;
		color: #fff;
		z-index: 10;
	}

	.slide p span {
		font-size: 16px;
	}

	.row {
		display: flex;
		justify-content: center;
		flex-wrap: wrap;
		gap: 30px;
	}

	.row:hover ~ .row .slide {
		transform: translateY(-100%);
	}

	.row:hover .slide {
		transform: translateX(100%);
	}

	.row:hover .col:hover ~ .col .slide {
		transform: translateX(-100%);
	}

	.row:hover .col:hover .slide {
		transform: none;
		visibility: visible;
		transition-delay: 0s;
	}

	.fixed {
		background: rgba(0, 0, 0, 0.75);
		padding: 0 1.5rem;
		position: absolute;
		top: 0;
		right: 0;
		bottom: 0;
		left: 0;
		display: flex;
		justify-content: center;
		align-items: center;
	}

	.fixed p {
		font-size: 28px;
		font-weight: 800;
		line-height: 120%;
		letter-spacing: 3px;
		text-align: center;
		color: #fff;
		z-index: 10;
	}

	.fixed p span {
		font-size: 16px;
	}

	.col {
		color: #fff;
		width: calc(100% / 3);
		min-height: 260px;
		position: relative;
	}
	.col h2 {
		font-weight: 300;
		font-size: 1.33333rem;
		line-height: 1.25;
		color: #000;
		background-color: #fff;
		margin: 0;
		position: relative;
		bottom: 1.5rem;
		right: 1.5rem;
		z-index: 0;
	}
	
	.photo-container {
		background: #0f0523 50% 50%/cover;
		position: relative;
		top: 0;
		right: 0;
		bottom: 0;
		left: 0;
		transition: 1s;
	}
	
	.col:hover .photo-container {
		transform: scale(1.15);
	}
	
	.photo-container  img {
		width: 100%;
	}
	
	.slide {
		background: rgba(0, 0, 0, 0.75);
		padding: 0 1.5rem;
	}
	
}

/* 会社概要
============================== */
#company{
	padding: 50px 0;

	h2 {
		font-family: 'Cinzel', serif;
		text-align: center;
		margin: 50px 0 30px;
		font-size: 26px;
		line-height: 1.4;

		span {
			display: block;
			font-size: 16px;
		}
	}

	dl {
		font-size: 16px;
		letter-spacing: 2px;
		line-height: 1.6;
		width: 90%;
		max-width: 980px;
		margin: 0 auto;
		display: flex;
		justify-content: center;
	}

	dl > dt ,
	dl > dd {
		padding: 0 20px;
		display: flex;
		font-size: 14px;
	}

	dl > dt {
		margin: 0 6px 10px 0;
		text-align: right;
		justify-content: end;
		width: 330px;
		color: #bbb;

	}

	dl > dd {
		width: calc(100% - 400px);
		margin-bottom: 10px;
	}

	dl > dd.business-box {
		display: block;

		span{
			display: block;
		}
	}

	dl > dd.shop-box {
		flex-direction: column;
	}

	dl > dd .shop-name {
		display: block;
		border-left: solid 1px #ccc;
		padding-left: 0.5em;
		line-height: 1;
		margin-bottom: 0.4em;
	}

	dl > dt:nth-of-type(6), dl > dd:nth-of-type(6) {
		height: 230px;
		flex-wrap: wrap;
		align-content: space-evenly;
	}
	
	dl > dt:nth-of-type(7), dl > dd:nth-of-type(7) {
		height: 130px;
		flex-wrap: wrap;
		align-content: space-evenly;
	}
	
	dl > dd:nth-of-type(6)  {
		flex-direction: column;
		align-content: start;
		justify-content: center;
		align-items: start;
	}
}