@charset "UTF-8";


/*
#h-header {
  transition: all 0.1s;
}
body.scroll #h-header{
	top: -100%;
}
body.upfixed #h-header{
	top:0%;
}
body.scroll .h-header__logo,
body.scroll .h-header__gnav-link,
body.scroll .h-header__menu{
	display: flex;
}

body.scroll .h-header__gnav-link {
  display: none;
}
*/

.htb-pagetop {
  bottom:2rem;
}

nav >.nav__dialog {
  display: none!important;
}

.htb-pagetop {
  bottom: 6rem;
}

@media screen and (max-width: 768px) {
	/*
	body.scroll .h-header__logo img {
		max-width: 130px;
		min-width: 100%;
	}
	*/
	.h-header__cta {
	  display: none;
	}

}




/************************************************

dialog

*************************************************/


/* ダイアログ開時に背景のスクロールを防ぐ */
html:has(dialog[open]) {
  overflow: hidden;
}

/* ダイアログにCSSトランジションを設定 */
dialog{
  transition: 0.4s cubic-bezier(0.33, 1, 0.68, 1);
}
/* ダイアログ開時の背景 */
dialog::backdrop {
	background: rgba(0, 0, 0, 0.3);
}

/* ダイアログメニュー */
dialog.js-dialog-menu{
	height: 100%;
	max-width: 100%;
	max-height: 100%;
	width: 50%;
	left: auto;
	margin: 0;
	border: 0;
	outline: 0;
	padding: 0;
}
/* ダイアログメニューの表示前*/
dialog.js-dialog-menu.show-from,
dialog.js-dialog-menu.hide-to{
  translate: 100% 0%;
}
/* ダイアログメニューの表示前、非表示後は背景を透明にする */
dialog.js-dialog-menu.show-from::backdrop,
dialog.js-dialog-menu.hide-to::backdrop{
  opacity: 0;
}

/* ダイアログモーダル
dialog.js-dialog-modal{
  opacity: 1;
}
/* モーダルの表示前、非表示後は下に移動 */
dialog.js-dialog-modal.show-from,
dialog.js-dialog-modal.hide-to {
  opacity: 0;
  translate: 0% 10%;
}

/* モーダルの表示前、非表示後は背景を透明にする */
dialog.js-dialog-modal.show-from::backdrop,
dialog.js-dialog-modal.hide-to::backdrop {
  opacity: 0;
}


.dialog-menu-btn {
	position: relative;
	width: 32px;
	height: 20px;
	cursor: pointer;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	align-items: center;
}
.dialog-menu-btn span {
  position: relative;
  width: 32px;
  height: 1px;
  background-color: #000;
  transition: transform .2s cubic-bezier(.27,1.2,.6,1);
}


.dialog_btn {
  display: grid;
  grid-template-columns: 1fr;
  gap: 15px;
  margin-top: 30px;
}

.dialog_btn .btn{
	background: transparent;
	border: 1px #644839 solid;
	color: #644839;
}
.dialog_btn .btn:after {
  background-color: #644839;
}

@media (any-hover: hover) {
  .dialog-menu-btn:hover span:nth-child(1) {
	  transform: translateY(3px)
  }
  .dialog-menu-btn:hover span:nth-child(3) {
	  transform: translateY(-3px)
  }
}

.dialog-menu-btn.js-dialog-menu-close{
	background:#000;
	padding: 10px;
	height: 56px;
	width: 56px;
	margin: 0 0 0 auto;
	align-items: center;
}
.dialog-menu-btn.js-dialog-menu-close span {
  position: absolute;
  background-color: #fff;
}
.dialog-menu-btn.js-dialog-menu-close span:nth-child(1) {
   transform: translateY(18px) rotate(-45deg);
}
.dialog-menu-btn.js-dialog-menu-close span:nth-child(2) {
  opacity: 0;
}
.dialog-menu-btn.js-dialog-menu-close span:nth-child(3) {
    transform: translateY(18px) rotate(45deg);
}


.js-dialog-modal {
	padding: 30px 20px;
	border-radius: 20px;
	max-width: 780px;
	background:#fff;
	margin:auto;
	width: 96%;
}
.js-dialog-modal .js-dialog-inner {
	display: grid;
	gap: 22px;
	justify-content: center;
	justify-items: center;
	grid-template-columns: 1fr;
}

.js-dialog-modal .js-dialog-inner .head{
	font-weight: 500;
	font-size: 16px;
	line-height: 160%;
	text-align: center;
	background:#D9D9D9;
	padding:6px;
	  width: 100%;
}

.js-dialog-modal .js-dialog-inner ul{
  list-style: disc;
  margin-left: 25px;
  font-weight: 400;
  font-size: 14px;
  line-height: 170%;
}

.js-dialog-modal .js-dialog-inner ul b{
  font-weight: 700;
  font-size: 15px;
}


.js-dialog-modal .js-dialog-inner a{
  text-align: center;
  color: #000;
  /* display: inline-block; */
  border-bottom: 1px #000 solid;
  text-decoration: none;
}
.js-dialog-inner .js-dialog-close {
	font-weight: 500;
	font-size: 14px;
	line-height: 160%;
	letter-spacing: 10%;
	text-align: center;
	background:var(--color-black);
	color: #fff;
	padding: 8px 40px;
	border-radius: 5px;
	margin: 20px auto 0;
}


/****************************************
js-dialog カスタマイズ
****************************************/


nav >.nav__dialog {
  position: absolute;
  top: 10px;
  right: 5px;
  z-index: 1;
  background: #fff;
  border-radius: 999px;
  padding:10px;
}


.js-dialog-menu-open{
	width: 26px;
	height:26px;
	overflow: hidden;
	justify-content: space-evenly;
}
.dialog-menu-btn.js-dialog-menu-close {
  background:transparent;
}


.js-dialog-menu {
  width: 100%;
}
.dialog-menu-btn span {
  background-color: var(--color-dialog-menu-btn);
}
.dialog-menu-btn.js-dialog-menu-close span {
  background-color: var(--color-dialog-menu-btn);
}

.js-dialog-menu {
background:var(--color-dialog-menu-bg);
}

.js-dialog-menu .body {
  padding: 0 24px;
  width: 100%;
}

.js-dialog-menu .body > ul{
	margin:30px 0 60px;
	padding: 0;
	list-style: none;
	display: flex;
	flex-direction: column;
	gap: 20px;
}

.js-dialog-menu .body > ul > li{
	border-bottom: 1px #CBE6E4 solid;
	display: flex;
	flex-direction: column;
	justify-content: flex-start;
}
.js-dialog-menu .body > ul li a,
.js-dialog-menu .body > ul li dt{
	font-weight: 700;
	font-size: 18px;
	line-height: 100%;
	vertical-align: middle;
	color: var(--color-dialog-menu-link);
	text-decoration: none;
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	height: 100%;
	background: transparent;
	padding: 0;
	padding-bottom: 24px;
	cursor: pointer;
}

.js-dialog-menu .body > ul > li > ul a,
.js-dialog-menu .body > ul > li > dl dd a{
	font-weight: 500;
	font-size: 13px;
	line-height: 100%;
	vertical-align: middle;
	color: var(--color-black);
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	height: 100%;
}

.js-dialog-menu .body ul > li a:after {
	content: "";
	mask-repeat: no-repeat;
	mask-position: center;
	mask-size: contain;
	background-color: currentColor;
	background-repeat: no-repeat;
	background-position: center;
	width: 16px;
	height: 16px;
	display: block;
	mask-image: url(data:image/svg+xml;charset=utf8,%3C%3Fxml%20version%3D%221.0%22%20encoding%3D%22UTF-8%22%3F%3E%3Csvg%20id%3D%22_%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_2%22%20data-name%3D%22%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC%202%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%20123.93%20123.93%22%3E%20%3Cg%20id%3D%22_%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_1-2%22%20data-name%3D%22%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC%201%22%3E%20%3Cpath%20d%3D%22M61.97%2C0C27.74%2C0%2C0%2C27.74%2C0%2C61.97s27.74%2C61.97%2C61.97%2C61.97%2C61.97-27.74%2C61.97-61.97S96.19%2C0%2C61.97%2C0ZM81.11%2C65.62l-23.24%2C23.24c-1.01%2C1.01-2.33%2C1.51-3.65%2C1.51s-2.64-.5-3.65-1.51c-2.02-2.02-2.02-5.29%2C0-7.3l19.59-19.59-19.59-19.59c-2.02-2.02-2.02-5.29%2C0-7.3s5.29-2.02%2C7.3%2C0l23.24%2C23.24c2.02%2C2.02%2C2.02%2C5.29%2C0%2C7.3Z%22%2F%3E%20%3C%2Fg%3E%3C%2Fsvg%3E);
}

.js-dialog-menu .body > ul li dt:after {
	content: "";
	mask-repeat: no-repeat;
	mask-position: center;
	mask-size: contain;
	background-color: currentColor;
	background-repeat: no-repeat;
	background-position: center;
	width: 16px;
	height: 16px;
	display: block;
	mask-image: url('data:image/svg+xml;charset=utf8,%3C%3Fxml%20version%3D%221.0%22%20encoding%3D%22UTF-8%22%3F%3E%3Csvg%20id%3D%22_%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_2%22%20data-name%3D%22%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC%202%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2015.5%2015.5%22%3E%20%3Cdefs%3E%20%3Cstyle%3E%20.cls-1%20%7B%20fill%3A%20none%3B%20stroke%3A%20%23fff%3B%20stroke-linecap%3A%20round%3B%20stroke-linejoin%3A%20round%3B%20stroke-width%3A%201.5px%3B%20%7D%20%3C%2Fstyle%3E%20%3C%2Fdefs%3E%20%3Cg%20id%3D%22_%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_1-2%22%20data-name%3D%22%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC%201%22%3E%20%3Cpath%20class%3D%22cls-1%22%20d%3D%22M7.75.75v14%22%2F%3E%20%3Cpath%20class%3D%22cls-1%22%20d%3D%22M.75%2C7.75h14%22%2F%3E%20%3C%2Fg%3E%3C%2Fsvg%3E');
	color: var(--color-dialog-menu-link);
	position: relative;
	top: 0;
	right:0;
	transform: unset;
}

.js-dialog-menu .body > ul li dt.active:after {
	mask-image:  url('data:image/svg+xml;charset=utf8,%3C%3Fxml%20version%3D%221.0%22%20encoding%3D%22UTF-8%22%3F%3E%3Csvg%20id%3D%22_%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_2%22%20data-name%3D%22%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC%202%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2015.5%201.5%22%3E%20%3Cdefs%3E%20%3Cstyle%3E%20.cls-1%20%7B%20fill%3A%20none%3B%20stroke%3A%20%23281815%3B%20stroke-linecap%3A%20round%3B%20stroke-linejoin%3A%20round%3B%20stroke-width%3A%201.5px%3B%20%7D%20%3C%2Fstyle%3E%20%3C%2Fdefs%3E%20%3Cg%20id%3D%22_%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_1-2%22%20data-name%3D%22%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC%201%22%3E%20%3Cpath%20class%3D%22cls-1%22%20d%3D%22M.75.75h14%22%2F%3E%20%3C%2Fg%3E%3C%2Fsvg%3E');
}
.js-dialog-menu .body > ul li dd {
  padding: 0;
  background: transparent;
  border: 0;
}



.js-dialog-menu  .dialog-menu__cta{
  display: grid;
  margin: 0 24px;
  gap: 4px;
  grid-template-columns: 1fr 1fr;
}

nav  {
  position: sticky;
  left: 0px;
  top: 0px;
  z-index: 2;
  opacity: 0;
  transition: all 0.4s;
}
.scroll nav  {
  top: 70px;
  opacity: 1;
  
}
 #princess-anio.upfixed nav  {
  top: 120px;
  opacity:1;
}

nav > .nav__cta{
	display:none;
}

.scroll nav > .nav__cta {
  position: fixed;
  right: 0;
  top: auto;
  bottom: 0;
  width: 100%;
	display:block;
}

nav > .nav__cta div{
text-align: left;
}
nav > .nav__cta .cta{
	height: auto;
	padding: 1.8rem 1rem;
	background: var(--color-primary-gd);
	border: 0px #d1a537 solid;
	border-right: 0;
	border-radius:9999px;
	color: #fff;
	display: block;
	margin: 0.8rem 2.4rem;
	text-align: center;
}

nav > .nav__cta .cta span{
	letter-spacing: 0.3rem;
	font-weight: 500;
	justify-content: center;
}
#wakuwakupass nav .balloon {
  position: relative;
  display: inline-block;
  margin: 0 0 -2rem 4rem;
  padding: 0 5px;
  width: 40px;
  height: 40px;
  background: #FFEB3B;
  border-radius: 50%;
  box-sizing: border-box;
  text-align: center;
  z-index: 1;
}


@media screen and (min-width: 768px) {

	.scroll nav {
	}
	.scroll nav > .nav__cta {
	bottom: 2rem;
	}
	nav > .nav__cta div {
      max-width: 480px;
      margin:0 auto;
	}
	.js-dialog-menu-open {
	  width: 36px;
	  height: 36px;
	}
	nav > .nav__cta .cta {
	  padding: 18px 25px;
	}
	.js-dialog-menu {
	width: 450px;
	}
	nav > .nav__cta {
	}
	nav > .nav__cta .cta {
	  color: #fff;
	  display: block;
	      margin: 0 auto;
	          max-width: 480px;
	}
	.scroll  nav > .nav__cta .cta {
    display: flex;
    padding: 22px 25px;
    border: 4px #fff solid;
	  }
	nav > .nav__cta .cta span{
	}
	#wakuwakupass nav .balloon {
	}
}




/************************************************

.mercisbv

*************************************************/

img.mercisbv {
  margin: 0px 0 0px auto;
  position: absolute !important;
  bottom: 0;
  right: 0;
  aspect-ratio: auto !important;
  width: 76px !important;
  height: auto !important;
  z-index: 1;
  height: auto;
  top: auto;
  padding: 3px;
}

/************************************************

ol li

*************************************************/

ul.asterisk{
	text-align: left;
	font-weight: 400;
	font-size: 13px;
	line-height: 150%;
	letter-spacing: 0;
	gap: 2px;

}
ul.asterisk li:before{
	content: "※";
	display: block;
	left: 0;
	margin: auto;
	padding: 0;
	position: absolute;
	top: 0;
}
ul.asterisk.midpoint li:before{
	content: "・";
}
ul.asterisk.circle li:before{
	content: "●";
}
ul.asterisk li{
	list-style-type: none;
	margin: 0;
	padding: 0 0 0 15px;
	position: relative;
}

dl.table{
	display: grid;
	justify-content: flex-start;
	align-items: start;
	margin: 10px auto;
	position: relative;
	gap: 10px;
	grid-template-columns:auto 1fr;
	width: 100%;
}
dl.table dt{
	width: 100px;
	display: block;
	background:#484747;
	color: #fff;
	border-radius: 5px;
	margin-right: 10px;
	padding: 3px 10px;
	line-height: 1.2;
	text-align: center;
}

/************************************************

.btn 

*************************************************/

.btn {
  background-color: var(--color-orange);
  display: block;
  color: #fff;
  text-decoration: none;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 4rem;
    padding: 1.8rem 2rem;
  font-family: YakuHanJP,"Zen Kaku Gothic New", sans-serif;
  border-radius: 9999px;
}

.btn span {
  line-height: 100%;
  text-align: center;
  display: flex;
  align-items: center;
  gap: 6px;
}

.btn span:after {
  content: "";
  mask-repeat: no-repeat;
  mask-position: center;
  mask-size: contain;
  background-color: currentColor;
  background-repeat: no-repeat;
  background-position: center;
  width: 14px;
  height: 14px;
  display: block;
  mask-image: url(data:image/svg+xml;charset=utf8,%3C%3Fxml%20version%3D%221.0%22%20encoding%3D%22UTF-8%22%3F%3E%3Csvg%20id%3D%22_%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_2%22%20data-name%3D%22%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC%202%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%20123.93%20123.93%22%3E%20%3Cg%20id%3D%22_%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_1-2%22%20data-name%3D%22%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC%201%22%3E%20%3Cpath%20d%3D%22M61.97%2C0C27.74%2C0%2C0%2C27.74%2C0%2C61.97s27.74%2C61.97%2C61.97%2C61.97%2C61.97-27.74%2C61.97-61.97S96.19%2C0%2C61.97%2C0ZM81.11%2C65.62l-23.24%2C23.24c-1.01%2C1.01-2.33%2C1.51-3.65%2C1.51s-2.64-.5-3.65-1.51c-2.02-2.02-2.02-5.29%2C0-7.3l19.59-19.59-19.59-19.59c-2.02-2.02-2.02-5.29%2C0-7.3s5.29-2.02%2C7.3%2C0l23.24%2C23.24c2.02%2C2.02%2C2.02%2C5.29%2C0%2C7.3Z%22%2F%3E%20%3C%2Fg%3E%3C%2Fsvg%3E);
}

/******* common ********/


.section{
	max-width: 100%;
	position: relative;
	overflow: hidden;
	padding:2.4rem 0 4.8rem;
}

.section__inner{
	position: relative;
	padding:0 2.4rem;
}
.section__inner.wide{
	position: relative;
	padding:0;
}

.inner__grid{
  display: grid;
  gap: 4.5rem;
}
.grid__body{
}

.txy{
  display: grid;
  gap: 1rem;
}

.link {
	display: grid;
	gap: 2rem;
	position: relative;
	margin: 0 auto;
	justify-content: center;
	align-items: start;
}
.link .bubble{
	color: var(--color-primary);
}


@media screen and (min-width: 1024px) {
	.section{
		padding:10rem 0 10rem;
	}


}


#wakuwakupass main a:hover{
	opacity:0.7!important;
}

#wakuwakupass .link .btn{
	background: var(--color-primary-gd);
	min-width: 320px;
	max-width: 480px;
}
#wakuwakupass .link .btn span{
	font-size: var(--font-size-18-22);
	font-weight: 500;
}


/******* #fv ********/



#wakuwakupass #fv {}

#wakuwakupass #fv .img{
  max-width: 1440px;
  border-radius: 2rem;
  overflow: hidden;
  margin: 0 auto
}

#wakuwakupass #fv .img img{
  aspect-ratio: 110 / 141;
}

#wakuwakupass #fv h1{
	font-family: var(--font-family-LINE-bold);
	font-size: var(--font-size-38-54);
	text-align: center;
	line-height: 120%;
	color: #ffd158;
	text-shadow: 0px 1px 2px #000;
}

#wakuwakupass #fv .txt{
	display: grid;
	gap: 1rem;
	background:var(--color-primary);
	padding: 8rem 0 4rem;
	border-radius: 2rem;
	margin: -8rem auto 0;
	color: #fff;
	max-width: 1440px;
}

#wakuwakupass #fv .date{
	font-family: var(--font-family-LINE-regular);
	font-size: var(--font-size-26-34);
	text-align: center;
	line-height: 100%;
	text-align: center;
	display: grid;
	grid-template-columns: auto 30px auto;
	align-items: center;
	justify-content: center;
	gap: 1rem;
	border: 2px #fff dotted;
	border-left: 0;
	border-right: 0;
	width: max-content;
	margin: 0 auto;
	padding: 1rem 1rem 0.5rem;
}
#wakuwakupass #fv .date small{
	font-size:60%;
}

#wakuwakupass .svg_line {
  fill: none;
  stroke: #fff;
  stroke-miterlimit: 10;
  stroke-width: 1px;
  max-width: 40px;
}

@media screen and (min-width: 1024px) {
	#wakuwakupass #fv.section{
		padding:5rem 0 15rem;
	}
	#wakuwakupass #fv .img {
	  margin: 0 auto;
	}
	#wakuwakupass #fv .img img{
	 aspect-ratio: 250 / 107;
	}

}



#wakuwakupass #message{
	background: #f0eccd;
	padding: 4.8rem 0 4.8rem;
}
#wakuwakupass #message:before{
	content: "";
	background:var(--color-primary-gd);
	position: absolute;
	top: 0;
	left: 0;
	width: 25%;
	height:15%;
clip-path: polygon(55% 0, 100% 0, 0 100%, 0 55%);
}
#wakuwakupass #message:after{
	content: "";
	background:var(--color-primary-gd);
	position: absolute;
	bottom: 0;
	right: 0;
	width: 25%;
	height:15%;
	clip-path: polygon(100% 0, 100% 45%, 45% 100%, 0 100%);
}
#wakuwakupass #message .section__inner:before{
	content: "Invitation";
	position: absolute;
	top: 0;
	right: 0;
	font-size: 4rem;
	color: #fcc5c5;
	opacity: 0.6;
	line-height:100%;
	font-family: var(--font-family-LINE-thin);
	writing-mode: vertical-rl;
}

#wakuwakupass #message .txt{
  display: grid;
  justify-content: center;
}
#wakuwakupass #message h2{
	font-family: var(--font-family-LINE-bold);
	font-family: var(--font-family-Zen-Mi);
	font-size: var(--font-size-38-54);
	line-height: 140%;
	  font-weight: 500;
}



#wakuwakupass #message p{
	font-size: var(--font-size-14-18);
	font-size: var(--font-size-16-20);
	line-height: 220%;
	text-align: center;
	font-weight: 500;
}

html[lang=ja] #wakuwakupass #message h2{
	writing-mode: vertical-rl;
}

@media screen and (min-width: 1024px) {

	#wakuwakupass #message:before,
	#wakuwakupass #message:after {
	  width: 200px;
	  height: 200px;
	}
	#wakuwakupass #message .section__inner:before{
		font-size: 12rem;
		writing-mode: unset;
	}

	#wakuwakupass #message .inner__grid {
		grid-template-columns: 1fr 2fr;
		align-items: center;
		max-width:1000px;
		margin: 0 auto;
	}
	#wakuwakupass #message p {
	  text-align: left;
	}
}

#wakuwakupass #price{}

#wakuwakupass #price{
}

#wakuwakupass #price h3{
	font-family: var(--font-family-LINE-bold);
	font-size: var(--font-size-26-34);
	line-height: 180%;
	  text-align: center;
}
#wakuwakupass #price h3 span{
	font-size: 180%;
	color:var(--color-secondary);
	  position: relative;
}

#wakuwakupass #price h3 span:after{
	content: "";
	mask-image: url(data:image/svg+xml;charset=utf8,%3Csvg%20id%3D%22uuid-74bd5e77-e813-4fa7-a03a-4e169a880f72%22%20data-name%3D%22%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC%202%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%22145.05%22%20height%3D%2220.2%22%20viewBox%3D%220%200%20145.05%2020.2%22%3E%20%3Cdefs%3E%20%3Cstyle%3E%20.uuid-a9d4e122-6e18-4210-b71d-a41d994356b4%20%7B%20fill%3A%20none%3B%20stroke%3A%20%23ff5611%3B%20stroke-miterlimit%3A%2010%3B%20%7D%20%3C%2Fstyle%3E%20%3C%2Fdefs%3E%20%3Cg%20id%3D%22uuid-ac4f0fe3-9e71-4fc9-9711-795a6884dda6%22%20data-name%3D%22%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC%201%22%3E%20%3Cpolyline%20class%3D%22uuid-a9d4e122-6e18-4210-b71d-a41d994356b4%22%20points%3D%220%20.5%2060.15%20.5%2084.41%2018.89%2079.1%20.5%20145.05%20.5%22%2F%3E%20%3C%2Fg%3E%3C%2Fsvg%3E);
	mask-repeat: no-repeat;
	mask-size: contain;
	background-color: currentColor;
	display: block;
	width: 100%;
	height: 3rem;
	position: absolute;
	bottom: -2.5rem;
	left: 0;
}

#wakuwakupass .bubble {
	font-family: var(--font-family-LINE-bold);
	font-size: var(--font-size-26-34);
	line-height: 120%;
	letter-spacing: 0%;
	text-align: center;
	position: relative;
	padding: 0 1.5rem;
	display: table;
	margin: 0 auto;
}
#wakuwakupass .bubble::before,
#wakuwakupass .bubble::after {
  position: absolute;
  bottom: 2px;
  height: 80%;
  content: '';
}
#wakuwakupass .bubble:before {
  border-left: solid 1px;
  left: 0;
  transform: rotate(-20deg);
}
#wakuwakupass .bubble:after {
  border-right: solid 1px;
  right: 0;
  transform: rotate(20deg);
}

#wakuwakupass .balloon {
	position: relative;
	display: inline-block;
	margin: 0 auto;
	padding: 0 5px;
	width: 40px;
	height:40px;
	background:  #FFEB3B;;
	border-radius: 50%;
	box-sizing: border-box;
	text-align: center;
	z-index: 1;
}
#wakuwakupass .balloon span{
  text-align: center;
  color: #000;
  font-size: 1.2rem;
  font-weight: bold;
  line-height: 100%;
    position: relative;
  top: 25%;
}

#wakuwakupass  .balloon:before {
content: "";
  position: absolute;
  bottom: -13px;
  left: 50%;
  margin-left: -5px;
  border: 5px solid transparent;
  border-top: 15px solid #FFEB3B;
  z-index:1;
}
#wakuwakupass .ticket-title{
  font-family: var(--font-family-LINE-bold);
  font-size: var(--font-size-20-32);
  text-align: center;
  display: table;
  margin: 0 auto;
  background: #000;
  color: #fff;
  padding: 0.5rem 1.5rem;
  border-radius: 2rem 2rem 0 0;
  background: var(--color-primary);
}

.price-box {
	display: grid;
	gap: 2rem;
	margin: 0rem auto;
	background: var(--color-primary);
	border-radius: 2rem;
	padding: 2rem;
	margin-top: -2px;
	position: relative;
}
.price-box:before {
  content: "";
  background: var(--color-secondary);
  position: absolute;
  top: 0;
  left: 0;
  width: 20%;
  height: 10%;
  clip-path: polygon(55% 0, 100% 0, 0 100%, 0 55%);
}
.price-box:after {
  content: "";
  background: var(--color-secondary);
  position: absolute;
  bottom: 0;
  right: 0;
  width: 20%;
  height: 10%;
  clip-path: polygon(100% 0, 100% 45%, 45% 100%, 0 100%);
}


dl.price {
	display: grid;
	grid-template-columns: 1fr 1.4fr;
	font-size: var(--font-size-24-34);
	line-height: 120%;
	font-weight: 500;
	align-items: end;
	background: #fff;
	border-radius: 1rem;
	padding: 1rem
}

dl.price dt{
  text-align: center;
  border-bottom: 0px var(--color-black) solid;
}
dl.price dd{
white-space: nowrap;
	font-size:180%;
  border-bottom: 0px var(--color-primary) solid;
}

dl.price span{
	font-family: var(--font-family-Jost);
	line-height: 100%;
	 font-optical-sizing: auto;
}
dl.price em{
	font-size:70%;
}
dl.price small{
	font-size:60%;
}
dl.price dd{
	color:var(--color-primary);
}
dl.price dd > div{
  font-size: 50%;
  color: var(--color-primary);
  color: var(--color-secondary);
  text-align: center;
  display: table;
  padding: 0.2rem 1rem;
  border-radius: 0;
  line-height: 100%;
  border: 1px var(--color-secondary) solid;
  border-left: 0;
  border-right: 0;
  border-top: 0;
  font-style: italic;
}
dl.price dd span:before{
	content:"";
	display: inline-block;
	vertical-align: middle;
	color: var(--color-primary);
	line-height: 1;
	width: 0;
	height: 0;
	border-style: solid;
	border-color: transparent;
	border-width: 10px 15px;
	border-left-color: currentColor;
	border-right: 0;
}
dl.price dd > div span:before{
  display: none;
}

#wakuwakupass #price .grid__body {
  gap: 4rem;
  display: grid;
  justify-content: center;
}

#wakuwakupass #price .overview{
  background: #f0eccd;
  border-radius: 2rem;
  overflow: hidden;
}


#wakuwakupass #price .overview .title{
	font-size: var(--font-size-20-26);
	text-align: center;
	display: block;
	margin: 0 auto;
	color: #fff;
	padding: 0.5rem 1.5rem;
	border-radius: 0;
	background:#484747;
}
#wakuwakupass #price .overview .inner{
  padding:1.6rem;
  font-size: var(--font-size-14-16);
}

#wakuwakupass #price .overview .inner ul.asterisk {
  font-size: initial;
}


#wakuwakupass .link .balloon {
  position: absolute;
  display: inline-block;
  margin: 0 auto;
  padding: 0 5px;
  width: 50px;
  height: 50px;
  background: #FFEB3B;
  border-radius: 50%;
  box-sizing: border-box;
  text-align: center;
  z-index: 1;
  transform: rotate(-20deg);
  top: -2rem;
  left: -1.5rem;
}
#wakuwakupass .link .balloon span {
	font-size: 1.3rem !important;
	top: 25%;
	display: block;
	font-weight: 700 !important;
}
#wakuwakupass .link .balloon span:after {
   display:none!important;
}



#wakuwakupass .price_apass.txt {
	margin-top: 3rem;
	padding: 2rem 1rem 1rem;
	border: 2px var(--color-green) solid;
	border-radius: 2rem;
	display: table;
	  margin: 0 auto;
}

#wakuwakupass .price_apass h3{
	font-family: var(--font-family-LINE-bold);
	font-size: var(--font-size-20-32);
	line-height: 140%;
	  text-align: center;
	color: var(--color-green);
}
#wakuwakupass .price_apass p{
	font-family: var(--font-family-LINE-regular);
	font-size: var(--font-size-16-20);
	line-height: 160%;
	  text-align: center;
	padding: 1rem;
}
#wakuwakupass .price_apass p span{
	font-family: var(--font-family-LINE-bold);
	font-size:140%;
	line-height: 160%;
	color: var(--color-green);

}

@media screen and (min-width: 1024px) {

	.price-box {
	  grid-template-columns: 1fr 1fr;
	  max-width: 960px;
	      margin-top: -1rem;

	}
	#wakuwakupass #price .overview .inner {
	  padding: 1.6rem 3rem;
	  font-size: var(--font-size-14-16);
	}
	#wakuwakupass #price .overview{
	  max-width: 960px;
	  margin:0 auto;
	}
	#wakuwakupass .balloon {
	  transform: scale(1.5);
	  top: -5px;
	}
	.price-box:before,
	.price-box:after {
	  width:80px;
	  height:80px;
	}
	#wakuwakupass .link .balloon {
		transform: scale(1.2) rotate(-20deg);
	}
	#wakuwakupass #price .link {
	  /*
	  grid-template-columns: 1fr 1fr;
	  */
	}
	.link .bubble{
	  /*
	  grid-column: 1 / 3;
		*/
	}
}


#wakuwakupass #collection{
  background: #f0eccd;
}
#wakuwakupass #collection h3 {
  font-family: var(--font-family-LINE-bold);
  font-size: var(--font-size-24-34);
  line-height: 140%;
  text-align: center;
}

#wakuwakupass #collection h3 span{
  font-size: 120%;
  display: block;
  color: var(--color-orange);
}

#wakuwakupass #collection .img{
  border: 6px #000 solid;
  border-radius: 2rem;
  overflow: hidden;
}
#wakuwakupass #collection .img.miffy{
  border-color:var(--color-miffy);
}
#wakuwakupass #collection .img.green{
  border-color:var(--color-green);
}
#wakuwakupass #collection .img.summer{
  border-color:var(--color-summer);
}
#wakuwakupass #collection .img.night{
  border-color:var(--color-night);
}
#wakuwakupass #collection .img img{
aspect-ratio: 5 / 3;
}



#wakuwakupass #event{
}

#wakuwakupass #event h3 {
	font-family: var(--font-family-LINE-bold);
	font-size: var(--font-size-20-32);
	line-height: 140%;
	text-align: center;
	position: relative;
  display: table;
  margin: 0 auto;
}

#wakuwakupass #event h3 span{
	font-size: 75%;
	display: block;
	color: var(--color-orange);
	text-align: left;
	line-height: 110%;
	position: relative;
	display: table;
	transform: rotate(-12deg);
	  left: -1.5rem;
}
#wakuwakupass #event h3 span:after{
  content: "";
  clip-path: polygon(5% 29%, 0 55%, 100% 28%);
  background:var(--color-orange);
  width: 100%;
  height: 20px;
  display: block;
  margin: 0 auto;
}

#wakuwakupass #event .event{
  border-radius: 4rem;
  overflow: hidden;
  padding:0.8rem;
  background:var(--color-black);
  display: grid;
  gap: 0.8rem;
  text-decoration: none;
}
#wakuwakupass #event .event img{
	border-radius: 3rem;
	aspect-ratio: 4 / 3;
}

#wakuwakupass #event .event.miffy{
 background:var(--color-miffy);
}
#wakuwakupass #event .event.green{
  background:var(--color-green);
}
#wakuwakupass #event .event.summer{
  background:var(--color-summer);
}
#wakuwakupass #event .event.night{
  background:var(--color-night);
}


#wakuwakupass #event .event .txt{
	font-size: var(--font-size-12-15);
	line-height: 140%;
	font-weight: 500;
	color:var(--color-white);
	text-align: center;
	position: relative;
	display: table;
	margin: 0 auto;
}


#wakuwakupass #event .event .txt .title{
	font-size:130%;
}


#wakuwakupass #event .large {
	padding: 0 2.4rem;
	display: grid;
	gap: 2.4rem;
}
#wakuwakupass #event .large .event{
  padding:1.2rem;
}
#wakuwakupass #event .large .event:before{
	content: "NEW";
	position: absolute;
	right: 0;
	top: 0;
	width: 70px;
	height: 70px;
	border-radius: 99999px;
	 background:var(--color-night);
	z-index: 1;
	color: #fff;
	line-height: 70px;
	text-align: center;
	font-weight: 900;
	font-size: 2rem;
}
#wakuwakupass #event .large .event.miffy:before{
	 background:var(--color-miffy);
}

#wakuwakupass #event .large .event img{
	aspect-ratio: 50 / 63;
}

#wakuwakupass #event .large .event .txt{
	font-size: var(--font-size-14-16);
}


#wakuwakupass #event .link .btn{
	 background:var(--color-orange);
}


@media screen and (min-width: 1024px) {

	#wakuwakupass #event .inner__grid{
	align-items: center;
	  grid-template-columns: 1fr 2fr;
	  max-width: 1200px;
	  margin: 0 auto;
	}
	#wakuwakupass #event .inner__grid .grid__body.last-child{
		grid-column: 1 / 3;
		width: 90%;
		margin: 0 auto;
	}
	#wakuwakupass #event .large {
	  padding: 0;
	  gap: 2.4rem;
	  grid-template-columns: 1fr 1fr;
	}
	#wakuwakupass #event .link {
	   grid-column: 1 / 3;
	}

}


#wakuwakupass #hotel{
	background: #f0eccd;
	overflow: visible;
}
#wakuwakupass #hotel .headding {
	position: relative;
	margin-bottom: 3rem;
}
#wakuwakupass #hotel .headding:before {
content: "";
}
#wakuwakupass #hotel .headding h2{
	font-family: var(--font-family-LINE-bold);
	font-size: var(--font-size-24-34);
	line-height: 120%;
	letter-spacing: 0%;
	text-align: center;
	position: relative;
	padding: 0 1.5rem;
	display: table;
	margin: 0 auto;
}
#wakuwakupass #hotel .headding h2 span{
	font-size:60%;
	display:block;
}

#wakuwakupass #hotel .headding h2:before {
  content: "";
  mask-repeat: no-repeat;
  mask-position: center;
  mask-size: contain;
  background-color: currentColor;
  width: 100%;
  height: 40px;
  display: block;
  transition: all 0.4s;
  mask-image: url(data:image/svg+xml;charset=utf8,%3C%3Fxml%20version%3D%221.0%22%20encoding%3D%22UTF-8%22%3F%3E%3Csvg%20id%3D%22_%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_1%22%20data-name%3D%22%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC%201%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2041%2033%22%3E%20%3Cdefs%3E%20%3Cstyle%3E%20.cls-1%2C%20.cls-2%20%7B%20stroke-width%3A%200px%3B%20%7D%20.cls-2%20%7B%20fill%3A%20none%3B%20%7D%20%3C%2Fstyle%3E%20%3C%2Fdefs%3E%20%3Cg%20id%3D%22_%E3%82%B0%E3%83%AB%E3%83%BC%E3%83%97_2603-2%22%20data-name%3D%22%E3%82%B0%E3%83%AB%E3%83%BC%E3%83%97%202603-2%22%3E%20%3Crect%20class%3D%22cls-2%22%20x%3D%225.63%22%20y%3D%224.85%22%20width%3D%2230%22%20height%3D%2223.34%22%2F%3E%20%3Cg%20id%3D%22_%E3%82%B0%E3%83%AB%E3%83%BC%E3%83%97_2602-2%22%20data-name%3D%22%E3%82%B0%E3%83%AB%E3%83%BC%E3%83%97%202602-2%22%3E%20%3Cpath%20id%3D%22_%E3%83%91%E3%82%B9_18717-2%22%20data-name%3D%22%E3%83%91%E3%82%B9%2018717-2%22%20class%3D%22cls-1%22%20d%3D%22m12.38%2C8.87c.01-.75.63-1.35%2C1.39-1.34h0s3.83%2C0%2C3.83%2C0c.75-.01%2C1.37.59%2C1.39%2C1.34v1.68h3.29v-1.68c.01-.75.63-1.35%2C1.39-1.34h3.83c.75-.01%2C1.37.59%2C1.39%2C1.34v1.68h4.15v-5.7H10.81c-1.4-.02-2.56%2C1.1-2.58%2C2.5%2C0%2C0%2C0%2C0%2C0%2C0v3.2h4.15v-1.68Z%22%2F%3E%20%3Cpath%20id%3D%22_%E3%83%91%E3%82%B9_18718-2%22%20data-name%3D%22%E3%83%91%E3%82%B9%2018718-2%22%20class%3D%22cls-1%22%20d%3D%22m32.59%2C17.88c1.01%2C0%2C1.98.4%2C2.69%2C1.11l-2.25-7.11H8.23l-2.24%2C7.11c.71-.72%2C1.68-1.12%2C2.69-1.11h23.91Z%22%2F%3E%20%3Cpath%20id%3D%22_%E3%83%91%E3%82%B9_18719-2%22%20data-name%3D%22%E3%83%91%E3%82%B9%2018719-2%22%20class%3D%22cls-1%22%20d%3D%22m33.13%2C26.16v.82c.02.69.6%2C1.24%2C1.29%2C1.22.66-.02%2C1.2-.55%2C1.22-1.22v-2.44c-.6.84-1.49%2C1.42-2.51%2C1.63%22%2F%3E%20%3Cpath%20id%3D%22_%E3%83%91%E3%82%B9_18720-2%22%20data-name%3D%22%E3%83%91%E3%82%B9%2018720-2%22%20class%3D%22cls-1%22%20d%3D%22m35.22%2C23.51c.27-.47.41-1%2C.41-1.54%2C0-.1%2C0-.2-.01-.29-.18-1.53-1.49-2.67-3.03-2.65H8.67c-1.54-.02-2.84%2C1.12-3.03%2C2.65-.01.1-.02.2-.01.29v3.22h0v1.8c.01.68.57%2C1.22%2C1.25%2C1.21.68.01%2C1.24-.53%2C1.25-1.21v-1.8h24.17c.27%2C0%2C.55-.03.82-.1.89-.21%2C1.65-.78%2C2.1-1.57%22%2F%3E%20%3C%2Fg%3E%20%3C%2Fg%3E%3C%2Fsvg%3E);

}


#wakuwakupass #hotel h3 {
	font-family: var(--font-family-LINE-bold);
	font-size: var(--font-size-20-32);
	line-height: 140%;
	text-align: center;
	position: relative;
  display: table;
  margin: 0 auto;
}

#wakuwakupass #hotel h3 span{
	font-size: 75%;
	display: block;
	color: var(--color-orange);
	text-align: left;
	line-height: 110%;
	position: relative;
	display: table;
	transform: rotate(-12deg);
	margin-bottom: 1.5rem;
	left: -1.5rem;
}
#wakuwakupass #hotel h3 span:after{
  content: "";
  clip-path: polygon(5% 29%, 0 55%, 100% 28%);
  background:var(--color-orange);
  width: 100%;
  height: 20px;
  display: block;
  margin: 0 auto;
}

#wakuwakupass #hotel .plan {
	border-radius: 4rem;
	overflow: hidden;
	padding: 1.2rem 1.2rem 1.8rem 1.2rem;
	background: var(--color-miffy);
	display: grid;
	gap: 1.6rem;
	margin: 0 2.4rem;
	margin-top:-1rem;
}
#wakuwakupass .pickup-title {
	font-family: var(--font-family-LINE-bold);
	font-size: var(--font-size-18-22);
	text-align: center;
	display: table;
	margin: 0 auto;
	color: #000;
	padding: 0.5rem 1.5rem 0;
	border-radius: 2rem 2rem 0 0;
	background: var(--color-miffy);
}

#wakuwakupass #hotel .plan img {
  border-radius: 3rem;
  aspect-ratio: 50 / 31;
}
#wakuwakupass #hotel .plan .txt {
	font-size: var(--font-size-14-16);
	line-height: 140%;
	font-weight: 500;
	color: var(--color-black);
	text-align: center;
	position: relative;
	display: grid;
	gap: 0.5rem;
	margin: 0 auto;
}
#wakuwakupass #hotel .plan .txt .title {
  font-size: var(--font-size-18-24);
  font-weight: 700;
	line-height: 150%;
}

#wakuwakupass #hotel .link .btn{
  line-height: 140%;
  font-weight: 700;
  color: var(--color-white);
  text-align: center;
  position: relative;
  display: table;
  margin: 0 auto;
  min-width: auto;
  background:var(--color-navy);
}
#wakuwakupass #hotel .plan .link .btn{
  color: var(--color-black);
  background: #fff;
}
#wakuwakupass #hotel .link .btn span {
  font-size: var(--font-size-14-16);
  font-weight: 600;
}


#wakuwakupass #hotel .table {
  display: table;
  margin: 2rem auto;
}


#wakuwakupass #hotel .hotels{
  display: grid;
  gap:1.6rem;
  padding:0 0 2rem;
}

#wakuwakupass #hotel .hotels img{
  aspect-ratio: 4 / 3;
}
#wakuwakupass #hotel .hotels .txt {
  font-size: var(--font-size-13-15);
  line-height: 140%;
  font-weight: 500;
  color: var(--color-black);
  text-align: center;
  position: relative;
  display: grid;
  gap: 1rem;
  margin: 0 auto;
}
#wakuwakupass #hotel .hotels .txt .title {
  font-size: 150%;
  font-family: var(--font-family-Zen-Mi);
}

#wakuwakupass #hotel  ul.asterisk {
  max-width: 500px;
  margin: 0 auto;
  padding: 0 2.4rem;
}

dl.rackrate {
	display: grid;
	grid-template-columns: 1fr;
	font-size: var(--font-size-12-15);
	line-height: 120%;
	font-weight: 500;
	align-items: center;
	background: #fff;
	border-radius: 1rem;
	gap:0.5rem;
	padding: 1rem;
	width: auto;
	margin: 0 auto;
	justify-content: center;
	position: relative;
}
dl.rackrate.low{
	padding-left:4rem;
	border-radius:0 1rem 1rem 0;
}
dl.rackrate.low:before {
  content: "最安値";
  position: absolute;
  width: 5rem;
  height: 5rem;
  background: #0b2e5e;
  border-radius: 9999px;
  line-height: 5rem;
  text-align: center;
  color: #fff;
  left:-2rem;
}

dl.rackrate dt{
  text-align: center;
  border-bottom: 0px var(--color-black) solid;
}
dl.rackrate dd{
	font-size:180%;
  border-bottom: 0px var(--color-primary) solid;
  text-align: center;
}

dl.rackrate span{
	font-family: var(--font-family-Jost);
	line-height: 100%;
	 font-optical-sizing: auto;
}
dl.rackrate em{
	font-size:70%;
}
dl.rackrate small{
	font-size:60%;
}
#wakuwakupass #hotel .section__inner .inner__grid:first-child {
	max-width:1100px;
	margin: 0 auto 5rem;
}

@media screen and (min-width: 1024px) {

	#wakuwakupass #hotel .section__inner .inner__grid:first-child {
		align-items: center;
		grid-template-columns: 1.2fr 1fr;
		max-width:1100px;
		margin: 0 auto 5rem;
		gap: 5rem;
	}
	#wakuwakupass #hotel .headding {
	  margin-bottom:5rem;
	}
	#wakuwakupass #hotel .headding:before {
	}
}

#wakuwakupass #apass{
  padding: 4.5rem 0 4.8rem;
}

#wakuwakupass #apass .banner {
  background: var(--color-green);
  border-radius: 2rem;
  overflow: hidden;
  padding: 2.4rem 1.6rem;
  display: grid;
  gap: 1.6rem;
  color: #fff;
  max-width: 900px;
  margin: 0 auto;
}

#wakuwakupass #apass .banner .bubble {
  font-family: var(--font-family-LINE-bold);
  font-size: var(--font-size-20-32);
}
#wakuwakupass #apass .banner h3 {
  font-family: var(--font-family-LINE-bold);
  font-size: var(--font-size-38-54);
  line-height: 120%;
  letter-spacing: 0%;
  text-align: center;
  position: relative;
  padding: 0rem;
  display: table;
  margin: 0 auto;
    white-space: nowrap;
}

#wakuwakupass #apass .banner .txt {
	background: var(--color-white);
	color: var(--color-green);
	border-radius: 2rem;
	padding: 1rem 1.6rem;
	display: grid;
	gap: 1rem;
}
#wakuwakupass #apass .banner .txt p {
  font-size: var(--font-size-14-18);
  font-weight:700;
  text-align: center;
  line-height: 120%;
}

#wakuwakupass #apass .banner .apass{
  display: grid;
  grid-template-columns: max-content auto auto auto auto;
  line-height: 110%;
  text-align: center;
  justify-content: space-around;
  align-items: center;
}
#wakuwakupass #apass .banner .apass span {
  font-family: var(--font-family-Jost);
  font-size:150%;
  line-height: 100%;
  font-optical-sizing: auto;
    font-weight: 600;
}
#wakuwakupass #apass .banner .apass small {
  font-size:90%;
}
#wakuwakupass #apass .banner .apass > div:first-child {
  white-space: nowrap;
}
#wakuwakupass #apass .banner .apass > div:nth-child(2),
#wakuwakupass #apass .banner .apass > div:nth-child(4) {
  font-size:160%;
  font-weight: 700;
}
#wakuwakupass #apass .banner .apass > div:nth-child(3) {
  font-size:70%;
  font-weight:500;
  line-height:120%;
}
#wakuwakupass #apass .banner .apass > div:nth-child(3) em{
	background: var(--color-green);
	color: #fff;
	display: block;
	padding:0.5rem 0.2rem;
	border-radius: 0.5rem;
	white-space: nowrap;
}

#wakuwakupass #apass .banner .apass > div:last-child {
  line-height:110%;
  font-weight:700;
  font-size:140%;
  white-space: nowrap;
}
#wakuwakupass #apass .banner .link .btn {
  margin-top: 1.6rem;
}

#wakuwakupass #apass .banner .link .btn {
  background: var(--color-black);
  min-width: 300px;
  max-width: 480px;
}
#wakuwakupass .link .btn span {
	font-size: var(--font-size-18-22);
	font-weight: 500;
}

@media screen and (min-width: 1024px) {

	#wakuwakupass #apass .banner {
	  grid-template-columns: 1.3fr 1fr;
	  align-items: center;
	}
	#wakuwakupass #apass .banner .apass span {
	  font-size: 180%;
	}
	#wakuwakupass #apass .banner .apass > div:nth-child(3) {
	  font-size: 80%;
	}

}


#wakuwakupass #apassbanner {
  padding: 0rem 0 4.8rem;
}


#wakuwakupass #faq {
  padding: 4.5rem 0 4.8rem;
    background: #f0eccd;
}

#wakuwakupass #faq .headding {
  position: relative;
}
#wakuwakupass #faq .headding h2 {
  font-size: var(--font-size-24-34);
    font-weight: 700;
  letter-spacing: 0%;
  text-align: center;
  position: relative;
  padding: 0 1.5rem;
  display: table;
  margin: 0 auto;
}
#wakuwakupass #faq .headding h2:before {
	content: "";
	mask-repeat: no-repeat;
	mask-position: center;
	mask-size: contain;
	background-color: currentColor;
	width: 100%;
	height: 50px;
	display: block;
	transition: all 0.4s;
	mask-image: url('data:image/svg+xml;charset=utf8,%3Csvg%20id%3D%22uuid-647e68da-fa7f-47ff-971e-7d31f778a5f1%22%20data-name%3D%22%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC%202%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%22125.91%22%20height%3D%22112.52%22%20viewBox%3D%220%200%20125.91%20112.52%22%3E%20%3Cdefs%3E%20%3Cstyle%3E%20.uuid-b4326595-9faf-4204-a627-520789b70ecf%20%7B%20fill%3A%20none%3B%20%7D%20%3C%2Fstyle%3E%20%3C%2Fdefs%3E%20%3Cg%20id%3D%22uuid-39929194-42fd-448e-85e5-fd655bb7d94a%22%20data-name%3D%22%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC%201%22%3E%20%3Cg%3E%20%3Cpath%20d%3D%22M43.09%2C16.7c-1.94%2C0-3.47.71-4.63%2C2.15-1.14%2C1.44-1.72%2C3.38-1.72%2C5.82s.56%2C4.42%2C1.71%2C5.88c1.14%2C1.46%2C2.67%2C2.19%2C4.61%2C2.19.79%2C0%2C1.53-.15%2C2.25-.46l-2.35-2.02%2C2.4-2.56%2C2.54%2C2.29c1.05-1.25%2C1.59-3.04%2C1.59-5.38s-.56-4.36-1.71-5.79c-1.14-1.42-2.69-2.11-4.67-2.11l-.02-.02Z%22%2F%3E%20%3Cpath%20d%3D%22M76.02%2C0H10.23C4.59%2C0%2C0%2C4.56%2C0%2C10.15v33.27c0%2C5.61%2C4.59%2C10.15%2C10.23%2C10.15h7.02l-2%2C11.53v.02c-.31%2C1.75%2C1.88%2C2.84%2C3.12%2C1.56l12.73-13.11h8.69c.68-4.96%2C4.9-8.8%2C10.1-8.8h36.23c.06-.44.14-.88.14-1.35V10.15c0-5.61-4.59-10.15-10.23-10.15ZM54.49%2C36l-2.4%2C2.58-3.45-3.11c-1.42.88-3.3%2C1.35-5.66%2C1.35-3.41%2C0-6.16-1.11-8.26-3.33-2.09-2.23-3.14-5.15-3.14-8.78s1.09-6.53%2C3.24-8.8c2.17-2.27%2C4.96-3.42%2C8.39-3.42s6.11%2C1.13%2C8.24%2C3.38c2.13%2C2.25%2C3.2%2C5.15%2C3.2%2C8.71%2C0%2C1.81-.27%2C3.48-.83%2C5-.54%2C1.52-1.34%2C2.75-2.35%2C3.69l3.02%2C2.75Z%22%2F%3E%20%3Cpath%20d%3D%22M85.17%2C57.01h-5.29l-8.94%2C23.3h5.41l1.84-5.19h8.72l1.92%2C5.19h5.27l-8.94-23.3ZM79.44%2C71.38l3.1-8.65%2C3.12%2C8.65h-6.22Z%22%2F%3E%20%3Cpath%20d%3D%22M115.68%2C48.61c3.51%2C0%2C6.36%2C2.83%2C6.36%2C6.3v31.35c0%2C3.48-2.85%2C6.3-6.36%2C6.3h-20.76c-1.18%2C0-2.29.54-3.02%2C1.44-.74.92-1.01%2C2.11-.74%2C3.25l2.54%2C10.94c-3.51-2.5-19.71-14.72-19.89-14.86-.68-.5-1.49-.79-2.35-.79h-21.53c-3.51%2C0-6.36-2.83-6.36-6.3v-31.35c0-3.48%2C2.85-6.3%2C6.36-6.3h65.77M115.68%2C44.76H49.9c-5.66%2C0-10.23%2C4.56-10.23%2C10.15v31.35c0%2C5.61%2C4.59%2C10.15%2C10.23%2C10.15h21.53s17.33%2C13.07%2C20.26%2C15.13c.95.67%2C2.02.96%2C2.98.96%2C2.02%2C0%2C3.66-1.25%2C3.26-3.02-.6-2.61-3.02-13.07-3.02-13.07h20.76c5.66%2C0%2C10.23-4.56%2C10.23-10.15v-31.35c0-5.61-4.59-10.15-10.23-10.15h.02Z%22%2F%3E%20%3Crect%20class%3D%22uuid-b4326595-9faf-4204-a627-520789b70ecf%22%20x%3D%220%22%20y%3D%220%22%20width%3D%22125.91%22%20height%3D%22112.52%22%2F%3E%20%3C%2Fg%3E%20%3C%2Fg%3E%3C%2Fsvg%3E');
	margin: 0 auto 1rem;
}

#wakuwakupass #faq .f_toggle{
  display: grid;
  gap: 1rem;
  margin: 3rem auto 0;
  max-width: 960px;
  font-size: var(--font-size-14-16);
}

#wakuwakupass #faq .f_toggle.inner {
  margin: 0 auto !important;
}
#wakuwakupass #faq .f_toggle.inner dt.inner {
  text-align: center;
  grid-template-columns: 1fr;
  background: transparent;
}
#wakuwakupass #faq .f_toggle.inner dd.inner {
  border-radius:0px;
    gap: 00;
      padding: 0;
}
#wakuwakupass #faq .f_toggle.inner > dt.inner:before,
#wakuwakupass #faq .f_toggle.inner > dd.inner:before{
	display:none;
}
#wakuwakupass #faq .f_toggle.inner dd.inner .f_toggle {
	margin-top:0;
}

#wakuwakupass #faq .f_toggle dt{
	display: grid;
	grid-template-columns: auto 1fr;
	gap: 1rem;
	background: #fff;
	border-radius:1rem;
	padding: 0.5rem 4rem 0.5rem 1rem;
	font-weight: 500;
	cursor: pointer;
	position: relative;
}
#wakuwakupass #faq .f_toggle dt:before{
	content:"Q";
	color:var(--color-navy);
}

#wakuwakupass #faq .f_toggle dt:after {
  content: "";
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-position: center;
  mask-position: center;
  -webkit-mask-size: contain;
  mask-size: contain;
  background-color: currentColor;
  background-repeat: no-repeat;
  background-position: center;
  width: 16px;
  height: 16px;
  display: block;
  mask-image: url(data:image/svg+xml;charset=utf8,%3C%3Fxml%20version%3D%221.0%22%20encoding%3D%22UTF-8%22%3F%3E%3Csvg%20id%3D%22_%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_2%22%20data-name%3D%22%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC%202%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2015.5%2015.5%22%3E%20%3Cdefs%3E%20%3Cstyle%3E%20.cls-1%20%7B%20fill%3A%20none%3B%20stroke%3A%20%23fff%3B%20stroke-linecap%3A%20round%3B%20stroke-linejoin%3A%20round%3B%20stroke-width%3A%201.5px%3B%20%7D%20%3C%2Fstyle%3E%20%3C%2Fdefs%3E%20%3Cg%20id%3D%22_%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_1-2%22%20data-name%3D%22%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC%201%22%3E%20%3Cpath%20class%3D%22cls-1%22%20d%3D%22M7.75.75v14%22%2F%3E%20%3Cpath%20class%3D%22cls-1%22%20d%3D%22M.75%2C7.75h14%22%2F%3E%20%3C%2Fg%3E%3C%2Fsvg%3E);
  color: var(--color-black);
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: 15px;
}
#wakuwakupass #faq .f_toggle dt.active:after {
  mask-image: url(data:image/svg+xml;charset=utf8,%3C%3Fxml%20version%3D%221.0%22%20encoding%3D%22UTF-8%22%3F%3E%3Csvg%20id%3D%22_%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_2%22%20data-name%3D%22%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC%202%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2015.5%201.5%22%3E%20%3Cdefs%3E%20%3Cstyle%3E%20.cls-1%20%7B%20fill%3A%20none%3B%20stroke%3A%20%23281815%3B%20stroke-linecap%3A%20round%3B%20stroke-linejoin%3A%20round%3B%20stroke-width%3A%201.5px%3B%20%7D%20%3C%2Fstyle%3E%20%3C%2Fdefs%3E%20%3Cg%20id%3D%22_%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_1-2%22%20data-name%3D%22%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC%201%22%3E%20%3Cpath%20class%3D%22cls-1%22%20d%3D%22M.75.75h14%22%2F%3E%20%3C%2Fg%3E%3C%2Fsvg%3E);
}

#wakuwakupass #faq .f_toggle dd{
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 1rem;
  border-radius: 999px;
  padding: 0.5rem 1rem;
  font-weight: 500;
}
#wakuwakupass #faq .f_toggle dd:before{
	content:"A";
	color:var(--color-navy);
}


@media screen and (min-width: 1024px) {

#wakuwakupass #apass {
  padding: 8.5rem 0 8.8rem;
}


}


.js-swiper-loop .swiper-wrapper {
    transition-timing-function: linear;
}

.js-swiper-carousel,
.js-swiper-hotels {
  padding-left: 1.6rem;
  padding-right:1.6rem;
}


.swiper-pagination {
	position: relative;
	margin: 2.5rem auto 0;
}
.swiper-pagination-bullet {
  width: 30px;
  height: 3px;
  display: inline-block;
  border-radius: 0;
}
.swiper-pagination-bullet-active {
  opacity:1;
  background: var(--color-orange);
}


@media screen and (min-width: 1024px) {

	.js-swiper-carousel {
	  padding-left: 0rem;
	  padding-right:0rem;
	}
	.js-swiper-hotels {
	}


}