@charset "utf-8";

/* =======================================

	CommonElements

======================================= */
html {
	scroll-behavior: smooth;
}
body{
	width: 100%;
	margin: 0 auto 10% auto;
	font-size: 14px;
	font-family: "游明朝", YuMincho, "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
	font-weight: 400;
	display:none;
  color: #000000;
}
.cf_sp {
	display:none;
}
.cf_pc{
	width: 100%;
}
.wrap{
	margin: 0 auto 0 auto;
	text-align:center;
}
a:link {
	color: #000000;
	text-decoration: none;
	font-size: 0.8em;
	font-family: 'Libre Baskerville', serif;
}
a:hover {
	color: #000;
	text-decoration: underline;
}
a:visited {
	color: #000000;
}
img{
	vertical-align:top;
}

/* ========MARGIN======== */
.bm10{
    margin:0 0 1em 0;
}
.bm20{
    margin:0 0 2em 0;
}
.bm30{
    margin:0 0 3em 0;
}
.bm40{
    margin:0 0 4em 0;
}
.bm50{
    margin:0 0 7em 0;
}
.bm60{
    margin:0 0 10em 0;
}
.bm70{
    margin:0 0 12em 0;
}
.bm100{
    margin:0 0 15em 0;
}

.bm100a{
    margin:0 0 15em 0;
	border-bottom: #9f9f9f solid 1px;
	width: 4%;
	margin-left: auto;
	margin-right: auto;
}

.bm200{
    margin:0 0 25em 0;
}

.bm-10{
    margin:0 0 -1em 0;
}
.bm-20{
    margin:0 0 -2em 0;
}
.bm-30{
    margin:0 0 -3em 0;
}
.bm-40{
    margin:0 0 -4em 0;
}
.bm-50{
    margin:0 0 -7em 0;
}
.bm-60{
    margin:0 0 -10em 0;
}
.bm-70{
    margin:0 0 -12em 0;
}
.bm-100{
    margin:0 0 -15em 0;
}
.bm-200{
    margin:0 0 -25em 0;
}
.bm-300{
    margin:0 0 -30em 0;
}

/* =======================================

	sample追加オリジナルcss

======================================= */

.gallery{
	columns: 3;/*段組みの数*/
	padding:0 385px;/*ギャラリー左右に余白をつける*/
	margin:0;
	}
	
	.gallery li {
		margin-bottom: 30px;/*各画像下に余白をつける*/
	list-style:none;
	}
	
	/*ギャラリー内のイメージは横幅100%にする*/
	.gallery img{
		width:98%;
		height:auto;
		vertical-align: bottom;/*画像の下にできる余白を削除*/}
	
	/*　横幅900px以下の段組み設定　*/
	@media only screen and (max-width: 900px) {
		.gallery{
		columns:3;
		}	
	}
	
	@media only screen and (max-width: 768px) {
		.gallery{
		columns: 3;
		}	
	}



	.vertical {
		writing-mode: vertical-rl;
		text-orientation: upright;
		height: 60%;
	}



	
	
	
	.parallax {
		position: fixed;
		inset: 0;
		background-position: center;
		background-repeat: no-repeat;
		background-size: contain;
	}
	
	.parallax01{
		position: fixed;
		inset: 0;
		background-position: center;
		background-repeat: no-repeat;
		background-size: cover;
	}
	
	.parallaxsp01{
		position: fixed;
		inset: 0;
		background-position: center;
		background-repeat: no-repeat;
		background-size: cover;
	}
	
	




		.sample-img {
			cursor: pointer;
			max-width: 500px;
			position: relative;
			width: 100%;
		  }
		  .sample-img img {
			height: auto;
			width: 100%;
		  }
		  .hover-mask {
			align-items: center; /* テキストの中央揃え */
			background: rgba(0, 0, 0, .5); /* マスクの色(黒の50%) */
			bottom: 0;
			color: #fff; /* テキストの色 */
			font-size: 1.1em;
			display: flex; /* テキストの中央揃え */
			height: auto;
			justify-content: center; /* テキストの中央揃え */
			left: 0;
			opacity: 0; /* 最初は透明(非表示) */
			position: absolute;
			right: 0;
			top: 0;
			transition: opacity .6s ease; /* ゆっくりopacityのみへ変化させる */
			width: 100%;
		  }
		  .hover-mask:hover {
			opacity: 1; /* hoverしたら透過しない(表示させる) */
		  }
		  .hover-mask p {
			width: 80%; /* テキストを横幅いっぱいにならないようにする */
		  }




		
		#page-top {
			position: fixed;
			right: 5px;
			bottom: 95px;
			height: 50px;
			text-decoration: none;
			font-weight: bold;
			transform: rotate(90deg);
			font-size: 90%;
			line-height: 1.5rem;
			color: #737373;
			padding: 0 0 0 35px;
			border-top: solid 1px;
		}
		#page-top::before {
			content: "";
			display: block;
			position: absolute;
			top: -1px;
			left: 0px;
			width: 15px;
			border-top: solid 1px;
			transform: rotate(35deg);
			transform-origin: left top;
		}


		.section {
			position: relative;
			width: 100vw;
			height: 100vh;
		}
		
		.section-layer {
			position: absolute;
			inset: 0;
			clip-path: inset(0);
			/* 要素全体をクリップ */
		}
		
		.content {
			display: grid;
			place-content: center;
			height: 100vh;
			background-color: #efefef;
			color: #353535;
			font-size: 26px;
			text-align: center;
		}
		
		.parallax {
			position: fixed;
			inset: 0;
			background-position: center;
			background-repeat: no-repeat;
			background-size: contain;
		}
		

		
/* ヘッダーメニュー */
.fixed-header {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 1000;
}
.header-content {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 30px;
}

.logo {
    margin-right: 10px;
}

nav ul {
    display: flex;
    list-style-type: none;
    padding: 0;
    margin: 0;
}

nav ul li {
    margin-right: 10px;
}

nav ul li a {
    color: #333;
    text-decoration: none;
    transition: color 0.3s ease;
    font-size: 14px; /* アイコンサイズを小さく */
}

nav ul li a:hover {
    color: #000000;
}

.language-switcher {
    position: relative;
}

.lang-btn {
    display: inline-block;
    padding: 5px 15px;
  background-color: rgba(240, 240, 240, 0.8);
    border: none;
    border-radius: 5px;
    cursor: pointer;
    transition: background-color 0.3s ease;
    font-size: 14px; /* ボタン文字サイズを小さく */
	font-family: "游明朝", YuMincho, "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
}

.lang-btn.active {
    background-color: #000000;
		opacity: 0.8;
    color: white;
}

.lang-btn:hover {
    background-color: #000000;
		opacity: 0.8;
}



.lang-content ul {
    list-style-type: none;
    padding: 0;
    margin: 0;
}

.lang-content li {
    margin: 0;
}

.lang-content a {
    display: block;
    padding: 5px 10px;
    text-decoration: none;
    color: #333;
    transition: background-color 0.3s ease;
    font-size: 14px; /* メニュー項目の文字サイズを小さく */
}

.lang-content a:hover {
    background-color: #f0f0f0;
}



 @media screen and (max-width: 750px) {
.fixed-header {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 1000;
}
.header-content {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 35px;
}

.logo {
    margin-right: 10px;
}

nav ul {
    display: flex;
    list-style-type: none;
    padding: 0;
    margin: 0;
}

nav ul li {
    margin-right: 10px;
}

nav ul li a {
    color: #333;
    text-decoration: none;
    transition: color 0.3s ease;
    font-size: 20px; /* アイコンサイズを小さく */
}

nav ul li a:hover {
    color: #000000;
}

.language-switcher {
    position: relative;
}

.lang-btn {
    display: inline-block;
    padding: 5px 22px;
  background-color: rgba(240, 240, 240, 0.8);
    border: none;
    border-radius: 5px;
    cursor: pointer;
    transition: background-color 0.3s ease;
    font-size: 25px; /* ボタン文字サイズを小さく */
	font-family: "游明朝", YuMincho, "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
}

.lang-btn.active {
    background-color: #000000;
		opacity: 0.8;
    color: white;
}

.lang-btn:hover {
    background-color: #000000;
		opacity: 0.8;
}



.lang-content ul {
    list-style-type: none;
    padding: 0;
    margin: 0;
}

.lang-content li {
    margin: 0;
}

.lang-content a {
    display: block;
    padding: 5px 10px;
    text-decoration: none;
    color: #333;
    transition: background-color 0.3s ease;
    font-size: 14px; /* メニュー項目の文字サイズを小さく */
}

.lang-content a:hover {
    background-color: #f0f0f0;
}
 }
		
/* フェードイン */
.fadein {
  opacity: 0;
  transition: opacity 0.6s ease-in-out;
}

.fadein.active {
  opacity: 1;
}


  /* =======================================

	card

======================================= */

.btn{
	width: 255px;
	padding: 16px 0 16px 0;
	font-size: 20px;
	position: relative;
	text-align: center;
	text-decoration: none;
	display: block;
	margin: 0 auto;
	color: #000;
	border: solid #000000 1px;
	line-height: 1;
	transition: all .2s;
	opacity: 0.8;
  }

  .btn:hover{
	background-color: #000000;
	opacity: 0.6;
	color: #ffffff;
  }
  
  .shadow-img {
	box-shadow: 9px 9px 9px rgba(0, 0, 0, 0.5);
  }

  .boxs{
	width: 255px;
	height: auto;
	background-color: rgb(255, 255, 255);
	box-shadow: 4px 4px 2px #a6a6a6;
  }
  


/* =======================================

	NAVIGATION

======================================= */
.nav_r{
	position: relative;
	z-index: 9999 !important;
}
.pagetop_r {
    position: fixed;
    top: 40px;
    right: 40px;
}
.pagetop_r img{
	width:100px;
}
.top_logo{
	position: relative;
	z-index: 9999 !important;
}
.pagetop_b {
    position: fixed;
    top: 40px;
    left: 40px;
}
.menu_logo{
	position: relative;
	z-index: 9999 !important;
}
.pagetop {
    position: fixed;
    top: 40px;
    left: 40px;
}
.navilogo{
	margin:0 0 0 0;
}
.navilogo h2{
	margin:0;
	padding:0;
}
.navilogo img{
	height:25px !important;
}
.pagetop h3{
	margin: 1em 0 1em 0.4em;
	font-size: 1.2em;
	text-align:left;
	letter-spacing: 0.1em;
}
.pagetop h4{
	margin: 1em 0 1em 0.4em;
	font-size: 1em;
	font-weight: 700;
	text-align:left;
	letter-spacing: 0.3em;
}
.pagetop h3 img{
	width:25px;
}
.pagetop li span{
	display: block;	
	font-size: 0.8em;
}
.pagetop ul{
	margin:5.5em 0 0 0em;
	color: #fff;
	font-size: 1em;
	text-align:left;
	font-weight: 500;
}
.pagetop li{
	list-style:none;
	margin: 1em 0 0 1em;
	letter-spacing:0.1em;
	font-family: 'Libre Baskerville', serif;
}
#header #gnav li a {
	color: #666666;
	text-decoration: none;
}
#header #gnav li a.current {
	color: #000000;
	text-decoration: underline;
}
h6 {
	color: #000;
	width: 100%;
	margin-left: auto;
	margin-right: auto;
	font-family: 'Libre Baskerville', serif;
  }

  @media screen and (max-width: 750px) {
h6 {
	color: #000;
	width: 95%;
	margin-left: auto;
	margin-right: auto;
	font-family: 'Libre Baskerville', serif;
  }
}


.head-border {
	display: flex;
	align-items: center;
	width: 75%;
}

@media screen and (max-width: 750px) {
	.head-border {
		display: flex;
		align-items: center;
		width: 60%;
	}
	}

.head-border:before,
.head-border:after {
	content: "";
	height: 1px;
	flex-grow: 1;
	background-color: #666;
}

.head-border:before {
	margin-right: 1rem;
}

.head-border:after {
	margin-left: 1rem;
}



/* =======================================

	OUR PARTNER

======================================= */
#partner{
	margin:0 auto 0px;
	padding:0 0 1em 0;
    width:42%;
}
#partner_x{
	margin:0 auto 0px;
	padding:0 0 1em 0;
    width:55%;
}
#partner10{
	margin:0 auto 0px;
	padding:0 0 1em 0;
    width:80%;
}
#partner2{
	margin:0 auto 0px;
	padding:0 0 1em 0;
    width:56%;
}
#partner3{
	margin:0 auto 0px;
	padding:0 0 1em 0;
    width:70%;
}
#partner h2{
	font-size:2em;
	margin:5em 0 2em 0;
	padding:0 0 0 0;
	color: #000;
	font-weight: bold;
	line-height:1.3em;
	letter-spacing:0.1em;
}
#partner h2 span{
	display:block;
	font-size:0.6em;
	letter-spacing:0.1em;
	margin:0 0 0 0;
	padding:0 0 0 0;
	font-weight: normal;
}
#partner p{
	margin:0 auto 2.5em auto;
	font-size: 1em;
	letter-spacing: 0.1em;
	line-height:2em;
}
[class^="ban-flex-"] {
	margin: 0 auto 0 auto;
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: space-between;
	justify-content: space-between;
	width: 90%;
}
.ban-flex-2 img { width: 100%; }
.ban-flex-2 a:link {
width: 50%; 
}
.ban-flex-5 img { width: 95%; }
.ban-flex-5 a:link {
width: 48%; 
}
.ban-flex-2 img:hover {
	opacity: 0.5 ;
}
.ban-flex-5 img:hover {
	opacity: 0.8 ;
	transform:scale(1.1);
	transition:0.5s;
}
#contact{
	margin:5em 0 0em 0;
	font-weight: 400;
	letter-spacing:0.1em;
}
#contact p{
	margin:0 auto 0.5em auto;
	font-size: 1em;
	letter-spacing: 0.1em;
	line-height:2em;
}

.ban-flex-6 img { width: 95%;}
.ban-flex-6 a:link {
width: 31%; 
}
.ban-flex-6 img:hover {
	opacity: 0.8 ;
	transform:scale(1.06);
	transition:0.5s;
}



@media screen and (max-width: 750px) {
	#partner{
		margin:0 auto 0em auto;
		padding:0 0 0 0;
    	width:99%;
    	max-width:750px;
	}
	#partner2{
		margin:0 auto 0em auto;
		padding:0 0 0 0;
    	width:100%;
    	max-width:750px;
	}
	#partner h2{
		font-size:2em;
		margin:5em 0 2em 0;
		padding:0 0 0 0;
		color: #000;
		font-weight: bold;
		line-height:1.3em;
		letter-spacing:0.1em;
	}
	#partner h2 span{
		display:block;
		font-size:0.6em;
		letter-spacing:0.1em;
		margin:0 0 0 0;
		padding:0 0 0 0;
		font-weight: normal;
	}
	#partner p{
		margin:0 auto 2.5em auto;
		font-size: 1.2em;
		letter-spacing: 0.1em;
		line-height:2em;
	}
	[class^="ban-flex-"] {
		margin: 0 auto 0 auto;
		display: -webkit-flex;
		display: block;
		-webkit-justify-content: space-between;
		justify-content: space-between;
		width: 100%;
	}
	.ban-flex-2 img {
		width: 98%; 
		padding: 0 0 2em 0;
	}
	.ban-flex-2 a:link {
	width: 49%; 
	}
	.ban-flex-2 img:hover {
		opacity: 0.5 ;
	}
	#contact{
		margin:5em 0 3em 0;
		font-weight: 400;
		letter-spacing:0.1em;
	}
	#contact p{
		margin:0 auto 0.5em auto;
		font-size: 1em;
		letter-spacing: 0.1em;
		line-height:2em;
	}


}






/* =======================================

	SPECIAL

======================================= */
#special{
	margin:0 auto 5em auto;
	padding:0 0 10em 0;
    width:100%;
    max-width:1200px;
}
#special h2{
	font-size:2em;
	margin:5em 0 2em 0;
	padding:0 0 0 0;
	color: #000;
	font-weight: bold !important;
	line-height:1.3em;
	letter-spacing:0.1em;
}
#special h2 span{
	display:block;
	font-size:0.6em;
	letter-spacing:0.1em;
	margin:0 0 0 0;
	padding:0 0 0 0;
	font-weight: normal;
}
#special p{
	margin:0 auto 2.5em auto;
	font-size: 1em;
	letter-spacing: 0.1em;
	line-height:2em;
}
.special_main100 img{
	width:100%;
	max-width:100%;
}
.special_main img{
	width:70%;
	max-width:100%;
}
.special_main3 img{
	width:53%;
	max-width:100%;
}

.special_main4 img{
	width:90%;
	max-width:100%;
}
.special_main5 img{
	width:57%;
	max-width:100%;
}
.cf_image_square img{
	width:48%;
	max-width:100%;
}
.cf_image_tate img{
	width:57%;
	max-width:100%;
}
.special_main6 img{
	width:45%;
	max-width:100%;
}
.cf_image_yoko img{
	width:50%;
	max-width:100%;
}
.cf_image_square img{
	width:48%;
	max-width:100%;
}
.special_main12 img{
	width:32%;
	max-width:100%;
}
.special_main12a img{
	width:45%;
	max-width:100%;
}
.special_main10 img{
	margin-right: calc(50% - 50vw);
	margin-left: calc(50% - 50vw);
}

.special_main img:hover {
		opacity: 1 ;
	}
	.speciallogo_main img{
		width:22%;
		max-width:100%;
		margin: 0 0 -89px 0;
	}

ul.special_link {
	display:-webkit-flex;
	display:flex;
	width:100%;
	list-style-type:none;
	margin:0;
	padding:0;
	justify-content:space-between;
}
ul.special_link a {
	display:block;
	text-align:center;;
	text-decoration:none;
}
.special_link img{
	width:95%;
}
.special_mainitem img{
	width:20%;
	max-width:100%;
}

.titlesample {
	max-width: 500px;
	text-align: center;
	margin: 0 auto;
  }

@media screen and (max-width: 750px) {
	#special{
		margin:0 auto 0 auto;
		padding:0 0 0em 0;
    	width:100%;
    	max-width:750px;
    	border-bottom:none;
	}
	#special h2{
		font-size:2em;
		margin:5em 0 2em 0;
		padding:0 0 0 0;
		color: #000;
		font-weight: bold;
		line-height:1.3em;
		letter-spacing:0.1em;
		font-family: 'Libre Baskerville', serif;
	}
	#special h2 span{
		display:block;
		font-size:0.6em;
		letter-spacing:0.1em;
		margin:0 0 0 0;
		padding:0 0 0 0;
		font-weight: normal;
	}
	#special p{
		margin:0 auto 2.5em auto;
		font-size: 1.2em;
		letter-spacing: 0.1em;
		line-height:2em;
	}
	.specialtxt{
		margin:0 auto 2.5em auto;
		padding:0;
		font-size: 1.2em;
		letter-spacing: 0.1em;
		line-height:2em;
		text-align:left !important;
		width:90%;
	}
	.special_main img{
	width:94%;
	max-width:100%;
	}
	.special_main5 img{
		width:70%;
		max-width:100%;
		}
	.special_main2 {
	padding: 0 0 7em 0;
	width:90%;
	}
	.special_main2 img{
	width:100%;
	max-width:100%;
	}
	[class^="ban-flex-"] {
		margin: 0 auto 0 auto;
		display: -webkit-flex;
		display: block;
		-webkit-justify-content: flex-start;
		justify-content: flex-start;
		width: 100%;
	}
	.spspecial_link img {
		width: 90%;
		padding: 0 0.5em 1em 0.5em;
	}
	.spspecial_link a:link {
		width: 100%; 
	}
	.spspecial_link img:hover {
		opacity: 0.5 ;
	}

	.special_main3 img{
		width:70%;
		max-width:100%;
	}

	.special_main4 img{
		width:55%;
		max-width:100%;
		margin: 0 -0 0 0;
		text-align: right;
	}

	.special_main5 img{
		width:55%;
		max-width:100%;
		margin: 0 0 0 0;
		text-align: right;
	}
	.special_main5a img{
		width:67%;
		max-width:100%;
		margin: 0 0 0 0;
		text-align: right;
	}

	.special_main6 img{
		width:55%;
		max-width:100%;
		margin: 0 0 0 0;
		text-align: right;
	}

	.special_main7 img{
		width:70%;
		max-width:100%;
		margin: 0 0 0 0;
		text-align: right;
	}

	.special_main8 img{
		width:90%;
		max-width:100%;
		margin: 0 0 0 0;
	}

	.special_main9 img{
		width:85%;
		max-width:100%;
		margin: 0 0 0 0;
	}

		.cf_image_square img{
	width:90%;
	max-width:100%;
}

.cf_image_tate img{
	width:100%;
	max-width:100%;
}

.cf_image_yoko img{
	width:100%;
	max-width:100%;
}


}



/* 大事なのはここだけ
-----------------------------------
*/
li:has(:checked) + li [for^="slide"]:after,
li:not(li:has(:checked), li:has(:checked) ~ li) [for^="slide"]:before {
  content: "";
}

#confect_a p{
	margin:0 auto 0 auto;
	font-size: 1em;
	letter-spacing: 0.1em;
	line-height:2em;
	font-family: 'Libre Baskerville', serif;
}

.nolink{
    pointer-events: none;
}

@media screen and (max-width: 750px) {
	#special2{
		margin:0 auto 0 auto;
		padding:0 0 0 0;
    	width:100%;
    	max-width:750px;
    	border-bottom:none;
	}
	#special2 h2{
		font-size:1.65em;
		margin:2.5em 0 1em 0;
		padding:0 0 0 0;
		color: #000000;
		font-weight: bold;
		line-height:1.3em;
		font-family: 'Libre Baskerville', serif;
	}
	#special2 h2 span{
		display:block;
		font-size:0.6em;
		letter-spacing:0.1em;
		margin:0 0 0 0;
		padding:0 0 0 0;
		font-weight: normal;
	}
	#special2 p{
		margin:0 auto 2em auto;
		font-size: 1.2em;
		letter-spacing: 0.1em;
		line-height:2em;
		width:100%;
	}
	.special2txt{
		margin:0 auto 2.5em auto;
		padding:0;
		font-size: 1.2em;
		letter-spacing: 0.1em;
		line-height:2em;
		text-align:left !important;
		width: 90%;
	}
	#special10 p{
		margin:0 auto 0 auto;
		font-size: 1em;
		letter-spacing: 0.1em;
		line-height:2em;
		font-family: 'Libre Baskerville', serif;
	}
	.special2_main{
	width:100%;
	max-width:100%;
	}
	.special2_main2 {
		padding: 0 0 7em 0;
	border-bottom:1px solid #CCC;
	}
	.special2_main2 img{
	width:100%;
	max-width:100%;
	}
	[class^="ban-flex-"] {
		margin: 0 auto 0 auto;
		display: -webkit-flex;
		display: block;
		-webkit-justify-content: flex-start;
		justify-content: flex-start;
		width: 100%;
	}
	.spspecial2_link img {
		width: 90%;
		padding: 0 0 1em 0;
	}
	.spspecial2_link a:link {
		width: 100%; 
	}
	.spspecial2_link img:hover {
		opacity: 0.5 ;
	}
}





/* ------------------ */
/* 全体 */
/* ------------------ */
/* footer用にレイアウト調整 */

  
  .main-title{
	position: fixed;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
  }
  
  /* ------------------ */
  /* フッター */
  /* ------------------ */
  /* メニューをページ下部に固定 */
  #fixed-footer-menu {
	position: fixed;
	width: 100%;
	bottom: 0px;
	opacity: 1;
	z-index: 100;
  }
  
  /* メニューを横並びにする */
  #fixed-footer-menu ul {
	display: flex;
	list-style: none;
	padding: 0;
	margin: 0;
	width: 100%;
	background-color: rgba(40, 39, 39, 0.9);
  }

  #fixed-footer-menu ul :hover{
	background-color: rgba(39, 39, 39, 0.9);
  }
  
  /* メニューの要素 */
  #fixed-footer-menu li {
	justify-content: center;
	align-items: center;
	width: 20%; /* 要素が5つの場合（100/5） */
	padding: 0;
	margin: 0;
  }
  
  /* メニューのボタン */
  #fixed-footer-menu li a {
	color: #b6b6b6;
	text-align: center;
	display: block;
	width: 100%;
	padding: 12px 0px 12px 0px;
	font-size: 8px;
	text-decoration: none;
  }

  #fixed-footer-menu li a :hover {
	color: #fff;
  }

  #fixed-footer-menu li a :hover{
	color: #fff;
  }
  
  
  /* メニュータイトル */
  #fixed-footer-menu li p {
	font-size: 0.6em; /* メニュータイトルのフォントサイズ */
	font-family: 'Libre Baskerville', serif;
	padding: 0 0 0 0;
  }
  
  /* アイコンのサイズを調整 */
  .footer-icon {
	font-size: 8px;
  }

.textbig::first-letter {
	font-size: 190%;
}

#hanger p{
	margin:0 auto 2.5em auto;
	font-size: 1em;
	letter-spacing: 0.1em;
	line-height:2em;
}
[class^="ban-flex-"] {
	margin: 0 auto 0 auto;
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: space-between;
	width: 100%;
	justify-content: space-evenly;
}
.ban-flex-3 img {
	width: 100%;
	margin:0 0 1.5em 0;
}
.ban-flex-4 img {
	width: 58%;
	margin:0 0 1.5em 0;
}
.ban-flex-3 a:link {
	width: 32%;
}

@media screen and (max-width: 750px) {

	[class^="ban-flex-"] {
		margin: 0 auto 0 auto;
		display: -webkit-flex;
		-webkit-justify-content: space-between;
		justify-content: space-evenly;
		width: 96%;
	}
	.ban-flex-3 img {
		width: 95%;
		padding: 0 0.5em 0 0.5em;
	}
	.ban-flex-3 a:link {
		width: 100%; 
	}

	#fixed-footer-menu li a {
		color: #9f9f9f;
		text-align: center;
		display: block;
		width: 100%;
		padding: 20px 0px 20px 0px;
		font-size: 8px;
		text-decoration: none;
	  }
	  .footer-icon {
		font-size: 10px;
	  }
}


/* =======================================

	FOOTER

======================================= */
footer{
    width:100%;
    max-width:1200px;
	margin:0 auto 0 auto;
}
.wrap_footer{
	margin:0 auto 10em auto;
	padding:5em 0 0 0;
	border-top:1px #CCC solid;
}


.wrap_footer ul{
    margin:0 0 1em 0;
    padding:0;
    list-style-type:none;
}
.wrap_footer li{
    margin:0 auto;
    padding:1em 0 0 0;
    font-size: 1em;
	font-family: 'Libre Baskerville', serif;
}
.igicon img{
	width:20px;
}
#copyright h4{
	margin:2em auto 30px auto;
	padding: 0 0 10px 0;
	width: 50%;
	text-align: center;	
	letter-spacing: 0.1em;
	font-weight: normal;
	font-size: 1em;
	position: relative;
	display: inline-block;
	font-family: 'Libre Baskerville', serif;
}
#copyright h4:before {
  content: '';
  position: absolute;
  left: 50%;
  bottom: 3em;/*線の上下位置*/
  display: inline-block;
  width: 20px;/*線の長さ*/
  height: 1px;/*線の太さ*/
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);/*位置調整*/
  background-color: #808080;/*線の色*/
  border-radius: 2px;/*線の丸み*/
}



@media screen and (max-width: 750px) {
.wrap_footer{
	margin:0 auto 10em auto;
	padding:0 0 0 0;
    width:100%;
    max-width:750px;
}

.wrap_footer ul{
    margin:0 0 1em 0;
    padding:0;
    list-style-type:none;
}
.wrap_footer li{
    margin:0 auto;
    padding:1em 0 0 0;
    font-size: 1em;
}
.igicon img{
	width:25px;
}
#copyright h4{
	margin:2em auto 30px auto;
	padding: 0 0 10px 0;
	width: 50%;
	text-align: center;	
	letter-spacing: 0.1em;
	font-weight: normal;
	font-size: 1em;
	position: relative;
	display: inline-block;
}
#copyright h4:before {
  content: '';
  position: absolute;
  left: 50%;
  bottom: 3em;/*線の上下位置*/
  display: inline-block;
  width: 20px;/*線の長さ*/
  height: 1px;/*線の太さ*/
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);/*位置調整*/
  background-color: #808080;/*線の色*/
  border-radius: 2px;/*線の丸み*/
}


}



 /* ===========================================
	スマートフォン系 748 - 
=========================================== */
@media screen and (max-width: 750px) {

body{
	width:750px;
	margin: 0 auto 0 auto;
	padding:0 0 0 0 ;
	font-family: 'Libre Baskerville', 'Noto Sans JP';
  	text-align:center;
  	font-size:18px;
	display:none;
}

.cf_sp {
	display:block;
}
.cf_pc {
	display:none;		
}

a:link {
	color: #000000;
	text-decoration: none;
}
a:hover {
	color: #959595;
	text-decoration: underline;
}




/* =======================================

	HEADER

======================================= */
header{ 
	z-index: 9999;
	padding:0 0 0 0;
	margin:0 auto 0 auto;
	text-align:center;
	width:100%;
}
header h1{
	font-size:2em;
	margin:0 0 1.5em 0;
	padding:0 0 0 0;
	color: #000;
	font-weight: bold;
	line-height:1.3em;
	letter-spacing:0.05em;
	position: relative;
}
header span{
	font-size:0.9em;
	display:block;
	letter-spacing:0.1em;
	margin:0;
	padding:0;
}
header p{
	font-size:1.3em;
	letter-spacing:0.1em;
	line-height:1.9em;
	margin:0;
	padding:0;
}
main{
	margin:0 auto;
	width:90%;
}







/* =======================================

	NAVIGATION

======================================= */




  
  .fat-nav {
	  top: 0;
	  left: 0;
	  z-index: 9954;
	  position: fixed;
	  display: none;
	  width: 100%;
	  height: 100%;
	  background-image: url(../images/bg_sp.jpg);
	  overflow-y: auto;
	  overflow-x: hidden;
	   -webkit-overflow-scrolling: touch;
	  background-position: center top;
	  background-repeat: no-repeat;
	  background-size: cover;
  }
  .fat-nav__wrapper {
	width: 100%;
	height: auto;
	display: table;
	table-layout: fixed;
	margin:0 0 0 0;
   }
  
  .fat-nav.active {
	-moz-transform: scale(1);
	-ms-transform: scale(1);
	-webkit-transform: scale(1);
	transform: scale(1);
  }
  
  .fat-nav__wrapper h2{
	  font-size:1.5em;
	  padding-top:2em;
	  letter-spacing:0em;
	  margin:0 0 1em 0;
  }
  .fat-nav__wrapper span{
	  font-size:0.7em;
  }
  #w_logo{
	  display:block;
	  position:absolute !important;
	  margin:119px 0 0 35px;
	  padding:0;
	  top:0;
	  left:0;
  }
  #w_logo img{
	  width:260px;
  }
  .fat-nav ul {
	display: table-cell;
	vertical-align:middle;
	padding: 0;
  }
  .fat-nav li {
	  list-style-type: none;
	  text-align: center;
	  padding: 10px 0 10px 0;
	  font-size: 1.7em;
	  font-weight:bold;
	  letter-spacing: 0.1em;
	  line-height:1.7em;
  }
  .fat-nav li img{
	  width:400px;
  }
  .fat-nav li, .fat-nav li a {
	color: #000;
  }
  .fat-nav li a {
	text-decoration: none;
  }

  .igimg img{
	  width:50px !important;
  }
  
  #sp_gnav ul{
	  margin:0;
	  padding: 8.5em 0 0 2.7em;
	  color: #000;
	  font-size: 2.0em;
	  text-align:left !important;
  }
  #sp_gnav li{
	  list-style:none;
	  font-size: 1em;
	  margin: 0.5em 0 0 1em;
	  letter-spacing:0.1em;
	  font-weight:normal !important;
	  text-align:left !important;
	  font-family: 'Libre Baskerville', serif;
  }
  #sp_gnav li span{
	  display: block;	
	  font-size: 0.8em;
  }
  #sp_gnav h3{
	  margin: 1em 0 1em 0.4em;
	  font-size: 0.9em;
	  font-weight:bold;
	  text-align:left;
	  letter-spacing: 0.1em;
  }
  #sp_gnav h4{
	margin: 1em 0 1em 0.4em;
	font-size: 1.1em;
	font-weight:bold;
	text-align:left;
	letter-spacing: 0.2em;
}
.navilogo3{
	z-index:10000 !important;
	display:block;
	position:absolute !important;
	margin:-10px 0 0 500px;
	padding:0;
	top:0;
	left:0;
	width:260px;
	font-size: 1.5em;
	font-family: 'Libre Baskerville', serif;
}
  .navilogo{
	  z-index:10000 !important;
	  display:block;
	  position:absolute !important;
	  margin:10px 0 0 -72px;
	  padding:0;
	  top:0;
	  left:0;
	  width:260px;
  }
  .navilogo img{
	  width:260px;
	  height:30px !important;
  }
  .gmark img{
	  margin:3em 0 0 0;
	  width:100px;
  }


/* =======================================

	FOOTER

======================================= */
footer{
	width:100%;
	margin:0 auto 0 auto;
}
footer h4{
	margin:2em auto 1em auto;
	font-weight: normal;
	font-size: 1em;
}
footer p{
	margin:0 0 0.7em 0;
}

#notice{
	margin:2.5em 0 0 0;
	padding:6em 0 0 0;
	font-weight: 400;
	letter-spacing:0.1em;
	border-top:1px #CCC solid;
}
#igicon{
	margin: 2em 0 2em 0;
}

#copyright h5{
	margin:0 auto 30px auto;
	padding: 0 0 10px 0;
	width: 50%;
	text-align: center;	
	letter-spacing: 0.1em;
	font-weight: normal;
	font-size: 1em;
	position: relative;
	display: inline-block;
}
h5:before {
  content: '';
  position: absolute;
  left: 50%;
  bottom: 3em;/*線の上下位置*/
  display: inline-block;
  width: 20px;/*線の長さ*/
  height: 1px;/*線の太さ*/
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);/*位置調整*/
  background-color: #808080;/*線の色*/
  border-radius: 2px;/*線の丸み*/
}


.wrap_footer{
	margin:0 auto;
	padding:5em 0 0 0;
    text-align:center;
    width:90%;
}
.wrap_footer img{
	width:32px;
	padding:0 0 0em 0;
}
.wrap_footer ul{
    margin:0;
    padding:0;
    list-style-type:none;
    color:#555;
}
.wrap_footer li{
    margin:0 auto;
    padding:0 0 1.5em 0;
    font-size: 1.3em;
}
.bm200{
    margin:0 0 12em 0;
}

.fat-nav_btm div{
	padding:2em;
	position: absolute;
	font-size:1.5em;	
	bottom:3em;
	letter-spacing: 0.1em;
	bottom:0;
}
.privacy_link {
	display:inline-block;
	margin:0 0 0 3em;
	padding:0 0 12em 2em;
	position: absolute;
	left:0;
	bottom:0;
}
.copyright_btm {
	display:inline-block;
	padding:0 3em 12em 0;
	position: absolute;
	right:0;	
	bottom:0;
}

}

