@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;
}

.container {
	max-width: 100%;
	height: auto;
}

.section {
	position: relative;
	width: 100%;
	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;
}

.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;
}







.vertical {
	writing-mode: vertical-rl;
	text-orientation: upright;
	height: 72%;
}

.vertical2 {
	writing-mode: vertical-rl;
	text-orientation: upright;
	height: 80%;
}

.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;
}


	/* ヘッダーメニューPC */
.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;
}



	/* ヘッダーメニューSP */
 @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: #f0f0f0;
    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;
    color: white;
}

.lang-btn:hover {
    background-color: #000000;
}

.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;
}
 }



/* マージンクラス */
.bm10 { margin-bottom: 1em; }
.bm20 { margin-bottom: 2em; }
.bm30 { margin-bottom: 3em; }
.bm40 { margin-bottom: 4em; }
.bm50 { margin-bottom: 7em; }
.bm60 { margin-bottom: 10em; }
.bm70 { margin-bottom: 12em; }
.bm100 { margin-bottom: 15em; }
.bm100a { margin-bottom: 15em; border-bottom: #989898 solid 0.5px; width: 75%; margin-left: auto; margin-right: auto; }
.bm200 { margin-bottom: 25em; }






/* フェードイン */
.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: #424242;
	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;
  }
}




/* =======================================

	OUR PARTNER

======================================= */

#partner {
	margin: 0 auto 0;
	padding: 0 0 0 ;
	width: 70%;
}

[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-6 img { width: 95%;}
.ban-flex-6 a:link {
width: 31%; 
}
.ban-flex-2 img:hover {
	opacity: 0.5 ;
}
.ban-flex-5 img:hover {
	opacity: 0.8 ;
	transform:scale(1.06);
	transition:0.5s;
}
.ban-flex-6 img:hover {
	opacity: 0.8 ;
	transform:scale(1.06);
	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-20 img { width: 95%;}
.ban-flex-20 a:link {
width: 50%; 
}

@media screen and (max-width: 750px) {

	[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;
	}
}


#page-top {
    position: fixed;
    right: 5px;
    bottom: 95px;
    height: 50px;
    text-decoration: none;
    font-weight: bold;
    transform: rotate(90deg);
    font-size: 120%;
    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;
}


@media screen and (max-width: 750px) {
	#page-top {
		position: fixed;
		right: 5px;
		bottom: 120px;
		height: 50px;
		text-decoration: none;
		font-weight: bold;
		transform: rotate(90deg);
		font-size: 150%;
		line-height: 1.5rem;
		color: #737373;
		padding: 0 0 0 35px;
		border-top: solid 1px;
	}

}


/* =======================================

	リンク無効

======================================= */
.nolink{
    pointer-events: none;
}


/* =======================================

	画像サイズ

======================================= */

  /* PC */
.cf_image_square img{
	width:55%;
	max-width:100%;
}
.cf_image_tate img{
	width:63%;
	max-width:100%;
}
.cf_image_yoko img{
	width:56%;
	max-width:100%;
}

.titlesample {
	max-width: 500px;
	text-align: center;
	margin: 0 auto;
  }

  #confect_a p{
	margin:0 auto 0 auto;
	font-size: 1em;
	letter-spacing: 0.1em;
	line-height:2em;
	font-family: 'Libre Baskerville', serif;
}

  /* SP */
@media screen and (max-width: 750px) {
	[class^="ban-flex-"] {
		margin: 0 auto 0 auto;
		display: -webkit-flex;
		display: block;
		-webkit-justify-content: flex-start;
		justify-content: flex-start;
		width: 100%;
	}

	.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: "";
}

  
  /* アイコンのサイズを調整 */
  .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.2em;
}

.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;
}

}

