@charset "UTF-8";

/* CSS Document */
html {
	font-size: 62.5%;
}

body {
	  font-family: "Noto Sans JP", "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
	font-weight: 700;
	font-style: normal;
	line-height: 1.5;
	letter-spacing: 0.05em;
	background: #1b0035;
	color: #fff;
	font-size: 1.6rem;
	margin: 0;
	padding: 0;
	background-image: url('https://kamifurano.info/wp-content/themes/kamifurano/images/lighting-up/bg.webp');
	background-size: cover;
	background-attachment: fixed;
	background-position: center;
	background-repeat: no-repeat;
	overflow-x: hidden;
}

h1 {
font-size: 4rem;
font-weight: 700;
}

h2 {
font-size: 3.6rem;
font-weight: 700;
}

h3 {
font-size: 2.7rem;
font-weight: 700;
}

h4 {
font-size: 2rem;
font-weight: 700;
}

small {
font-size: 1.2rem;

}

.small {
font-size: 1.2rem;
}
.pcOnly{display: block;}
.spOnly{display: none;}

.fontColor01{color: #f6d62d;}

.li0{line-height: 0;}

.fix{position: fixed;
	width: 100%;
	overflow-x:hidden;
}

.content-wrapper{
	position: relative;
	margin: 0 auto;
	background: #1b0035;
	max-width: 500px;
	width: 100%;
	height: 100svh;
	overflow-y: auto;
	overflow-x: hidden;
	z-index: 20;
	-ms-overflow-style: none;  /* IE, Edge */
	scrollbar-width: none;     /* Firefox */
	scroll-behavior: smooth;
	-ms-overflow-style: none;
}

.content{
	position: relative;
	min-height: 100%;
	background: #1b0035;
}

.menu{position: relative;width: calc((100% - 500px) / 2); height: 100svh;}

.logo{max-width: 550px; width: 90%; position: absolute; top:3%; left: 50%; transform: translateX(-50%);}
.map{max-width: 600px; width: 90%;position: absolute; bottom:0%; left: 50%; transform: translateX(-50%);}

.menu nav{position: absolute; top: 3%; left: 10%; z-index: 10;}
.menu nav ul li{background: #f6d62d ; border-radius: 50px; padding: 5px 20px; text-align: center; margin-bottom: 20px; width: 300px;}
.menu nav ul li a{color: #000; font-size: 3.4rem;}
.labeton{position: absolute; bottom: 0%; left: 0%; z-index: 10;max-width: 400px; width: 90%;}
.labetonsp{max-width: 500px; width: 90%;}

@media screen and (max-width: 1360px) {
.labeton{max-width: 300px;}
}

@media screen and (max-width: 1200px) {
.menu nav ul li{width: 200px;}
.menu nav ul li a{font-size: 2.4rem;}
}

.ma0auto{margin: 0 auto;}
.inner{width: 90%; margin: 0 auto;}

a {
transition: all ease 0.5s;
}

a:hover {
opacity: 0.5;
transition: all ease 0.5s;
}

figure img {
display: block;
margin: 0 auto;
max-width: 100%;
width: 100%;
}


h2.line{position: relative; padding-bottom: 20px; text-align: center; margin: 0 auto 40px;}
h2.line::after{  content: ""; position: absolute; left: 50%; bottom: 0; transform: translateX(-50%); width: 50%; height: 3px; background-color: #f6d62d;}

.time-card {
    position: relative;
    padding-bottom: 2em;
	padding-left: 1em;
	min-height: 100px;
    border-left: 2px solid #fff;}

.time-card.last{
min-height: auto;}

.time-card::before {
    display: inline-block;
    width: 10px;
    height: 10px;
    content: '';
    border-radius: 100%;
    background-color: #fff;
    position: absolute;
    left: -6px;
    top: 1.2em;
    transform: translateY(-50%);}
.time-card:first-of-type::before {top: 0%;}
.time-card:last-of-type::before {top: 0%; left: -4px;}
.time-card:last-of-type{border-left: none;}

iframe{width: 100%; aspect-ratio: 16 / 9; height: auto;}
.banner{width: 48%;}

.footer{color: #fff; background: #554e51;}



/*SPメニュー*/
.globalmenu{display: none;}

@media screen and (max-width: 1024px) {
body {
background-color: #1b0035;
}
.content{max-width: 100%;}
.content-wrapper{flex: 0 0 100%;}
.pcOnly{display: none;}
.spOnly{display: block;}
/*メニュー*/
.globalmenu{display: block;}
.hamburger {
	display: block;
	position: fixed;
	z-index: 999;
	right: 10px;
	top: 10px;
	width: 45px;
	height: 45px;
	cursor: pointer;
	text-align: center;
	background-color: #fff;
	border-radius: 10px;
}

.hamburger span {
	display: block;
	position: absolute;
	width: 20px;
	height: 2px;
	left: 13px;
	background: #554e51;
	-webkit-transition: 0.3s ease-in-out;
	-moz-transition: 0.3s ease-in-out;
	transition: 0.3s ease-in-out;
}

.hamburger span:nth-child(1) {
	top: 15px;
}

.hamburger span:nth-child(2) {
	top: 23px;
}

.hamburger span:nth-child(3) {
	top: 31px;
}

/* ナビ開いてる時のボタン */
.hamburger.active span:nth-child(1) {
	top: 23px;
	left: px;
	-webkit-transform: rotate(-45deg);
	-moz-transform: rotate(-45deg);
	transform: rotate(-45deg);
}

.hamburger.active span:nth-child(2),
.hamburger.active span:nth-child(3) {
	top: 23px;
	-webkit-transform: rotate(45deg);
	-moz-transform: rotate(45deg);
	transform: rotate(45deg);
}

nav.globalmenu {
	position: fixed;
	z-index: 998;
	top: 0;
	left: 0;
background: #9d81b8;
	text-align: center;
	transform: translateX(100%);
	transition: all 0.6s;
	width: 100%;
	height: 100svh;
}

nav.globalmenu ul {
	position: relative;
	background: #9d81b8;
	margin: 0 auto;
	padding: 0;
	width: 100%;
	display: flex;
    flex-direction: column;
    height: 100svh;
    justify-content: space-evenly;
	font-size: 2.4rem;
}

nav.globalmenu ul li {
	list-style-type: none;
	padding: 0;
	width: 100%;
}


nav.globalmenu ul li:hover {
	background: #9d81b8;
}

nav.globalmenu ul li a {
	display: block;
	color: #000;
	padding: 1em 0;
}


/* このクラスを、jQueryで付与・削除する */
nav.globalmenu.active {
	transform: translateX(0%);
}

}
@media screen and (max-width: 480px) {
h3 {
font-size: 2.3rem;
}
small{font-size: 1rem;}
h4 {
font-size: 1.6rem;
}
small{font-size: 1rem;}

nav.globalmenu ul {
font-size: 1.6rem;
}

}

/*アニメーション*/
.backTrigger {
	opacity: 0;
}

.titleTrigger {
	transition-duration: 0.5s;
	clip-path: inset(100% 0 0 0);
	transition: clip-path 2s cubic-bezier(0.19, 1, 0.22, 1);
	transform: translateY(100%);
}


.titleIn {
	transition-duration: 0.5s;
	clip-path: inset(0 0 0 0);
	transition: clip-path 2s cubic-bezier(0.19, 1, 0.22, 1);
	transform: translateY(0);
}

.blurTrigger {
	filter: blur(10px);
}

.blurClear {
	transition-duration: 0.5s;
	filter: blur(0px);
	transition: all 3s cubic-bezier(0.19, 1, 0.22, 1);
}
.slideIn {
	animation-name: slideInAnime;
	animation-duration: 0.5s;
	animation-fill-mode: forwards;
	opacity: 0;
}

.slideIn2 {
	animation-name: slideInAnime2;
	animation-duration: 0.5s;
	animation-delay: 0.1s;
	animation-fill-mode: forwards;
	opacity: 0;
}


@keyframes slideInAnime {
	from {
		opacity: 0;
		transform: translateX(-100px);
	}

	to {
		opacity: 1;
		transform: translateX(0);
	}
}

@keyframes slideInAnime2 {
	from {
		opacity: 0;
		transform: translateX(200px);
	}

	to {
		opacity: 1;
		transform: translateX(0);
	}
}

.slideInTrigger {
	opacity: 0;
}

.slideInTrigger2 {
	opacity: 0;
}