@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[href] {
	color: #000;
	text-decoration: underline;
	outline: none;
	transition: transform .3s ease-in-out, opacity .3s ease-in-out;
}
a:hover{
	opacity: 0.7;
}

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
============================================================================================================ */
#page {
	background-color: rgb(244, 239, 236);
}
@media screen and (min-width: 768px), print {
	body {
		background: url(../img/main.jpg);
		background-attachment: fixed;
		background-size: 100%;
		background-position: top center;
	}
	#page {
		position: relative;
		width: calc(375 * var(--px));
		margin: 0 auto;
		/* background-color: #fff; */
		background-color: rgb(244, 239, 236);
		/* 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: 80px;
		left: 30px;
		left:min(9vw, calc(70px - (1000px - 100vw) * .1));
		width: 22vw;
		max-width: calc((100vw -(375* var(--px))) / 2 - min(30px, calc(30px -(1000px - 100vw)* .1))* 2);
		z-index: 2;
		display: flex;
		flex-direction: column;
		gap: 20px;
		justify-content: center;
	}
	.pc_left_logo{
		max-width: 267px;
    width: 100%;
    margin: 0 auto;
    text-align: center;
	}
	.flag_logo ul{
		display: flex;
		flex-direction: column;
		gap:10px;
	}
	.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;
	}
}

@media screen and (max-width: 821px) {
	.flag_logo{
		display: none;
	}
}

.inner_contents{
	padding: 0 25px;
}

/* header
============================================================================================================ */
#header {
	position: sticky;
	top: 0;
	height: calc(50 * var(--px));
	display: flex;
	align-items: center;
	background-color: #F4EFEC;
	padding:0 0 0 calc(15 * var(--px));
	z-index: 100;
}
#header::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background-color: #F4EFEC;
	z-index: 9;
}
#header .sns{
	z-index: 100;
}
#header .sns .sns_contents{
	display: flex;
	gap:20px;
	align-items: center;
	justify-content: left;
}
#header .sns .sns_contents li{
	width: 28px;
}
#header .nav_btn {
	position: relative;
	margin-left: auto;
	z-index: 10;
}
#header .nav_btn a {
	position: relative;
	display: block;
	width: calc(50 * var(--px));
	height: calc(50 * var(--px));
	color: #000;
}
#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::before{
	transform: translateY(calc(16* var(--px)));
}
#header .nav_btn a::after {
    transform: translateY(calc(5* 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: #F4EFEC;
	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;
	z-index: 99;
}
#header nav .gnav {
	margin:calc(50* var(--px)) 0 0;
}
#header nav .gnav li{
	font-size: 1.5rem;
	font-weight: bold;
	font-family: "Zen Maru Gothic", serif;
	background-color: #EA5504;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	height: 40px;
}
#header nav .gnav li a{
	text-decoration: none;
	color: #FFF;
}
#header nav .gnav li:nth-child(2){
	background-color: #FAC02C;
}
#header nav .gnav li:nth-child(3){
	background-color: #EC6D74;
}
#header nav .gnav li:nth-child(4){
	background-color: #3AB483;
}
#header nav .gnav li:nth-child(5){
	background-color: #2990D0;
}
#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(0* var(--px));
    right: calc(0* 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 ul li a{
	transition: transform .3s ease-in-out, opacity .3s ease-in-out;
}
.page_nav ul li a:hover{
	opacity: 0.6;
}

/* main
============================================================================================================ */
#main {
	position: relative;
	background-color:#F4EFEC;
}
.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, 50px);
  -webkit-transform: translate(0, 50px);
}
.mov_show.showed{
	opacity: 1;
  -webkit-transform: translate(0, 0);
  transform: translate(0, 0);
  -webkit-transition: all 2s ease;
  transition: all 2s ease;
}
.ov_h{overflow: hidden;}


/* フォント------------------------------------ */
.zen_kaku{
	font-family: 'Zen Kaku Gothic New', sans-serif;
}

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



/* footer */
.footer{
    position: relative;
    width: 100%;
    margin: 0 auto;
    background-color: #F4EFEC;
    padding: 20px 20px;
    box-sizing: border-box;
    display: flex;
    align-items: center;
    justify-content: 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: solid 1px #000; */
	border-radius: 40px;
    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;
		border-radius: 40px;
		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);
	} */
}