@charset "utf-8";

body,div,dl,dt,dd,ul,ol,li,h1,h2,h3,h4,h5,h6,pre,form,fieldset,p,blockquote,th,td,main,figure{margin:0;padding:0}table{font-size:100%;font-family:inherit}fieldset,img{border:0}img,svg,video{vertical-align:middle}address,caption,cite,code,dfn,em,th,var{font-style:normal;font-weight:400}ol,ul{list-style:none}caption,th{text-align:left}h1,h2,h3,h4,h5,h6{font-size:100%}

html {
	font-size: 62.5%;
	/* scroll-padding-top: 70px; */
	scroll-behavior: smooth;
}
body {
	background-color: #fff;
	font-size: 1rem;
	line-height: 1.8;
	color: #000;
	word-wrap: break-word;
	overflow-wrap: break-word;
	font-family: "游ゴシック", YuGothic, "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "メイリオ", "Meiryo", Verdana, Arial, Helvetica, sans-serif;
	font-weight: 400;
	text-size-adjust: none;
}
*,
*::before,
*::after {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
}
img {
	width: 100%;
	height: auto;
	image-rendering: -webkit-optimize-contrast;
}
table {
	border-collapse: collapse;
	border-spacing: 0;
	line-height: 1.8;
}
a{
	display: block;
}
a[href] {
	color: #000;
	text-decoration: underline;
	outline: none;
}

button {
	cursor: pointer;
}
iframe {
	max-width: 100%;
	vertical-align: middle;
}

.hidden {
	display: none;
}
.slick-slider * {
	outline: none;
}

/* --
============================================================================================================ */
:root {
	--px: 1px;
	/* --px: calc((500px / 375) + 0px); */
}
@media screen and (max-width: 767px) {
	:root {
		--px: calc((100vw / 375) + 0px);
	}
}


/* pc / sp
============================================================================================================ */
@media screen and (min-width: 768px), print {
	.sp {
		display: none !important;
	}
}
@media screen and (max-width: 767px) {
	.pc {
		display: none !important;
	}
}

/* object-fit
============================================================================================================ */
img.of {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
}
img.of.bg {
	pointer-events: none;
	user-select: none;
	z-index: -1;
}

/* target
============================================================================================================ */
.target {
	display: block;
	position: relative;
	width: 1px;
	top: calc(-65 * var(--px));
}
.target.pt {
	top: calc(-85 * var(--px));
}

/* page
============================================================================================================ */
@media screen and (min-width: 768px), print {
	body {
		background: url(../img/bg.webp);
		background-attachment: fixed;
		background-size: 135%;
		background-position: top center;
	}
	#page {
		position: relative;
		width: calc(375 * var(--px));
		margin: 0 auto;
		background-color: #fff;
		/* border-left: 1px solid #000;
		border-right: 1px solid #000; */
		box-sizing: content-box;
		z-index: 3;
		box-shadow: 0px 0px 23px -1px #777777;
	}
	.flag_logo {
		position: fixed;
		top: 22px;
		left: 30px;
		left: min(30px, calc(30px - (1000px - 100vw) * .1));
		width: 220px;
		max-width: calc((100vw - (375 * var(--px))) / 2 - min(30px, calc(30px - (1000px - 100vw) * .1)) * 2);
		z-index: 2;
	}
	.r_logo{
		position: fixed;
		top: 22px;
		right: 30px;
		right: min(30px, calc(30px - (1000px - 100vw) * .1));
		width: 300px;
		max-width: calc((100vw - (375 * var(--px))) / 2 - min(30px, calc(30px - (1000px - 100vw) * .1)) * 2);
		display: flex;
		align-items: center;
    justify-content: space-between;
	}
	.r_logo div:last-child{
		max-width: 397px;
	}

	.bg_imgs li {
		position: fixed;
		top: 50%;
		width: calc((100vw - (375 * var(--px))) / 2);
		padding: 0 20px;
		text-align: center;
		transform: translateY(-50%);
		z-index: 2;
	}
	.bg_imgs li.l {
		left: 0;
	}
	.bg_imgs li.r {
		right: 0;
	}
	.bg_imgs li img {
		max-width: 300px;
	}
}

/* header
============================================================================================================ */
#header {
	position: sticky;
	top: 0;
	height: calc(65 * var(--px));
	display: flex;
	align-items: center;
	background-color: #fff;
	padding: 0 calc(15 * var(--px)) 0 calc(35 * var(--px));
	z-index: 100;
}
#header::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background-color: #fff;
	z-index: 9;
}
#header .logo {
	position: relative;
	width: calc(180 * var(--px));
	z-index: 10;
}
#header .nav_btn {
	position: relative;
	margin-left: auto;
	z-index: 10;
}
#header .nav_btn a {
	position: relative;
	display: block;
	width: calc(65 * var(--px));
	height: calc(65 * var(--px));
	color: #000;
	padding-top: calc(50% + 3 * var(--px));
	text-align: center;
}
#header .nav_btn::before,
#header .nav_btn a::before,
#header .nav_btn a::after {
	content: "";
	position: absolute;
	left: 50%;
	top: calc(50% - 5 * var(--px));
	width: calc(28 * var(--px));
	margin-top: calc(-2 * var(--px));
	margin-left: calc(-14 * var(--px));
	border-top: calc(4 * var(--px)) solid;
	transition: transform .3s ease-in-out, opacity .3s ease-in-out;
}
#header .nav_btn a::before {
	transform: translateY(calc(-6 * var(--px)));
}
#header .nav_btn a::after {
	transform: translateY(calc(6 * var(--px)));
}
#header .nav_btn a img {
	width: calc(30 * var(--px));
}
@media print {
	#header {
		position: relative;
	}
}
#header nav {
	position: absolute;
	top: 0;
	height: 100vh;
	left: -9999em;
	width: 100%;
	background-color: #e3c6a6;
	border-top: 4vh solid #c4715c;
	border-bottom: 4vh solid #f5a347;
	transition: transform .3s ease-in-out, opacity .3s ease-in-out;
	opacity: 0;
	pointer-events: none;
	z-index: 20;
}
#header.opend nav {
	left: 0;
}
#header.open nav {
	transform: scale(1);
	pointer-events: auto;
	opacity: 1;
}
#header nav .gnav {
	padding: calc(20 * var(--px)) 0;
	max-height: calc(100vh - 4vh * 2);
	overflow-y: auto;
	overscroll-behavior-y: contain;
}
#header nav .gnav .insta {
	margin-top: calc(20 * var(--px));
}
#header nav .gnav a {
	display: block;
	padding: calc(8 * var(--px)) calc(35 * var(--px));
}
#header nav .close {
	position: absolute;
	top: calc(12 * var(--px));
	right: calc(12 * var(--px));
	width: calc(50 * var(--px));
	height: calc(50 * var(--px));
	cursor: pointer;
	z-index: 10;
}
#header nav .close::before,
#header nav .close::after {
	content: "";
	position: absolute;
	top: 50%;
	left: 10px;
	right: 10px;
	border-top: 4px solid #000;
	margin-top: -2px;
	transform: rotate(45deg);
}
#header nav .close::after {
	transform: rotate(-45deg);
}
@media screen and (min-width: 768px), print {
	#header nav .gnav {
		scrollbar-width: thin;
		scrollbar-color: #aaa #eee;
	}
	#header nav .gnav::-webkit-scrollbar {
		width: 10px;
	}
	#header nav .gnav::-webkit-scrollbar-track {
		background-color: #eee;
	}
	#header nav .gnav::-webkit-scrollbar-thumb {
		background-color: #aaa;
	}
}

/* fv下navi----------------------- */
.page_nav{
	margin:20px 0;
}
.page_nav ul{
	display: flex;
	flex-direction: column;
	justify-content: center;
	gap:7px;
}
.page_nav ul li a{
	transition: transform .3s ease-in-out, opacity .3s ease-in-out;
	display: block;
}
.page_nav ul li a:hover{
	opacity: 0.6;
}

/* main
============================================================================================================ */
#main {
	position: relative;
}
.main_contents{
	min-height: 100vh;
}
@media screen and (max-width: 767px) {
}



.background-container {
    width: 200%;
    height: 100%;
    position: fixed;
    top: 0;
    left: 0;
    animation: scrollBackground 10s linear infinite;
}

.background {
    width: 50%;
    height: 100%;
    float: left;
    background-size: cover;
}

/* .background-1 {
    background-image: url('../img/bg.webp'); 1つ目の背景画像のURLを指定
}

.background-2 {
    background-image: url('../img/bg_2.jpg'); 2つ目の背景画像のURLを指定
} */

.content {
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 1;
    background-color: rgba(255, 255, 255, 0.8); /* コンテンツ背景の色を設定 */
}

@keyframes scrollBackground {
    0% {
        transform: translateX(0);
    }
    50% {
        transform: translateX(-50%);
    }
    100% {
        transform: translateX(0);
    }
}


/* fix_bnr
============================================================================================================ */
/* .fix_bnr {
	height: calc(45 * var(--px));
} */
.fix_bnr a {
	position: fixed;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 50;
}
@media screen and (min-width: 768px), print {
	.fix_bnr,
	.fix_bnr a {
		width: calc(375 * var(--px));
		margin: 0 auto;
	}
}

/* modal
============================================================================================================ */
.modal {
	position: fixed;
	left: 0;
	right: 0;
	top: 10000vh;
	height: 100vh;
	display: flex;
	visibility: hidden;
	justify-content: center;
	align-items: center;
	pointer-events: none;
	opacity: 0;
	z-index: 200;
}
.modal.showed {
	top: 0;
	visibility: visible;
	transition: opacity .3s;
}
.modal.show {
	opacity: 1;
}
.modal_in {
	position: relative;
	width: 100%;
	max-height: 100vh;
	background-color: #fff;
}
.modal.show .modal_in {
	pointer-events: auto;
}
.modal .close {
	position: absolute;
	right: 0;
	top: 0;
	width: calc(60 * var(--px));
	height: calc(60 * var(--px));
	cursor: pointer;
	z-index: 10;
}
.modal .close::before,
.modal .close::after {
	content: "";
	position: absolute;
	top: 50%;
	right: 10%;
	left: 10%;
	border-top: 1px solid #000;
	transform: rotate(45deg);
}
.modal .close::after {
	transform: rotate(-45deg);
}
.modal .contents {
	position: relative;
	overflow-y: auto;
	overscroll-behavior-y: contain;
	max-height: 100vh;
	padding: calc(60 * var(--px)) 0 calc(50 * var(--px));
}
@media screen and (min-width: 768px), print {
	.modal {
		width: calc(375 * var(--px));
		margin: 0 auto;
	}
	.modal .contents {
		scrollbar-width: thin;
		scrollbar-color: #ccc #eee;
	}
	.modal .contents::-webkit-scrollbar {
		width: 10px;
	}
	.modal .contents::-webkit-scrollbar-track {
		background-color: #eee;
	}
	.modal .contents::-webkit-scrollbar-thumb {
		background-color: #ccc;
	}
}
@media screen and (max-width: 767px) {
}

#overlay {
	position: fixed;
	left: 0;
	right: 0;
	top: 10000vh;
	height: 100vh;
	visibility: hidden;
	background-color: rgba(0, 0, 0, .3);
	pointer-events: none;
	opacity: 0;
	z-index: 199;
}
#overlay.showed {
	top: 0;
	left: 0;
	visibility: visible;
	transition: opacity .3s;
}
#overlay.show {
	opacity: 1;
	pointer-events: auto;
}
@media screen and (min-width: 768px), print {
	#overlay {
		width: calc(375 * var(--px));
		margin: 0 auto;
	}
}
#overlay::after {
	content: "";
	position: absolute;
	left: 50%;
	top: 50%;
	width: 40px;
	height: 40px;
	margin: -20px 0 0 -20px;
	border-top: 6px solid rgba(255, 255, 255, 0.4);
	border-right: 6px solid rgba(255, 255, 255, 0.4);
	border-bottom: 6px solid rgba(255, 255, 255, 0.4);
	border-left: 6px solid rgba(255, 255, 255, 1);
	border-radius: 100%;
	transform: translateZ(0);
	animation: loading 1.1s infinite linear;
	z-index: 1;
}
@keyframes loading {
	0% {transform: rotate(0deg);}
	100% {transform: rotate(360deg);}
}

/* アニメーション ----------------------------*/
.mov_show{
	position: Z;
	opacity: 0;
}
/* 下から上にフワッと出る */
.fade_up{
	transform: translate(0, 30px);
  -webkit-transform: translate(0, 30px);
}
.mov_show.showed{
	opacity: 1;
  -webkit-transform: translate(0, 0);
  transform: translate(0, 0);
  -webkit-transition: all 1.5s ease;
  transition: all 1.5s ease;
}
.ov_h{overflow: hidden;}


/* フォント------------------------------------ */
.zen_kaku{
	font-family: 'Zen Kaku Gothic New', sans-serif;
}
.kosugi-maru-regular {
	font-family: "Kosugi Maru", sans-serif;
	font-weight: 400;
	font-style: normal;
  }

.zen_old{	
	font-family: 'Zen Old Mincho', serif;
}




/* footer */
.footer{
    position: relative;
    width:100%;
    margin: 0 auto;
    background-color: #FFF;
    padding:20px;
    box-sizing: border-box;
	display: flex;
    align-items: center;
  }
  .footer .foot_logo {
    display: block;
    width: 50px;
    margin: 0 auto;
}


/* top_up----- */
.top_up {
    position: fixed;
    bottom: 30px;
    right: 30px;
    width: 50px;
    height: 50px;
    background-color: #FFF;
    border-radius: 40px;
    border: solid 1px #000;
    box-shadow: 0px 0px 18px -1px #777777;
	transition: .2s;
}

.top_up::before {
    content: "";
    margin: auto;
    position: absolute;
    top: 5px;
    bottom: 0;
    left: 17px;
    width: 13px;
    height: 13px;
    border-top: 3px solid #000;
    border-right: 3px solid #000;
    transform: rotate(-45deg);
}

.top_up:hover{
	scale: 120%;
}

@media screen and (max-width: 768px), print {
	.top_up{
		position: fixed;
		bottom: 15px;
		right: 15px;
		width: 30px;
		height: 30px;
		background-color: #FFF;
		border-radius: 40px;
		border: solid 1px #000;
		box-shadow: none;
	}
	
	.top_up::before {
		content: "";
		margin: auto;
		position: absolute;
		top: 4px;
		bottom: 0;
		left: 9px;
		width: 10px;
		height: 10px;
		border-top: 1px solid #000;
		border-right: 1px solid #000;
		transform: rotate(-45deg);
	}
}
