html {
	color: #000;
	background: #FFF
}

body,
div,
dl,
dt,
dd,
ul,
ol,
li,
h1,
h2,
h3,
h4,
h5,
h6,
pre,
code,
form,
fieldset,
legend,
input,
textarea,
p,
blockquote,
th,
td {
	margin: 0;
	padding: 0
}

table {
	border-collapse: collapse;
	border-spacing: 0
}

fieldset,
img {
	border: 0
}

address,
caption,
cite,
code,
dfn,
em,
strong,
th,
var {
	font-style: normal;
	font-weight: normal
}

ol,
ul {
	list-style: none
}

caption,
th {
	text-align: left
}

h1,
h2,
h3,
h4,
h5,
h6 {
	font-size: 100%;
	font-weight: normal
}

q:before,
q:after {
	content: ''
}

abbr,
acronym {
	border: 0;
	font-variant: normal
}

sup {
	vertical-align: text-top
}

sub {
	vertical-align: text-bottom
}

input,
textarea,
select {
	font-family: inherit;
	font-size: inherit;
	font-weight: inherit;
	*font-size: 100%
}

legend {
	color: #000
}

#yui3-css-stamp.cssreset {
	display: none
}

html {
	background-color: transparent;
	background-image: none
}

figure {
	margin: 0;
	padding: 0;
	-webkit-margin-before: 0;
	-webkit-margin-after: 0;
	-webkit-margin-start: 0;
	-webkit-margin-end: 0
}

figure img {
	vertical-align: top
}

@font-face {
	font-family: 'Oswald';
	font-style: normal;
	font-weight: 400;
	font-display: swap;
	src: "fonts/oswald-v35-latin-regular.eot");
	src: local(""), url("fonts/oswald-v35-latin-regular.eot?#iefix") format("embedded-opentype"), url("fonts/oswald-v35-latin-regular.woff2") format("woff2"), url("fonts/oswald-v35-latin-regular.woff") format("woff"), url("fonts/oswald-v35-latin-regular.ttf") format("truetype"), url("fonts/oswald-v35-latin-regular.svg#Oswald") format("svg")
}

@font-face {
	font-family: 'Oswald';
	font-style: normal;
	font-weight: 700;
	font-display: swap;
	src: url("fonts/oswald-v35-latin-700.eot");
	src: local(""), url("fonts/oswald-v35-latin-700.eot?#iefix") format("embedded-opentype"), url("fonts/oswald-v35-latin-700.woff2") format("woff2"), url("fonts/oswald-v35-latin-700.woff") format("woff"), url("fonts/oswald-v35-latin-700.ttf") format("truetype"), url("fonts/oswald-v35-latin-700.svg#Oswald") format("svg")
}

@font-face {
	font-family: 'Lexend Tera';
	font-style: normal;
	font-weight: 400;
	font-display: swap;
	src: url("fonts/lexend-tera-v4-latin-regular.eot");
	src: local(""), url("fonts/lexend-tera-v4-latin-regular.eot?#iefix") format("embedded-opentype"), url("fonts/lexend-tera-v4-latin-regular.woff2") format("woff2"), url("fonts/lexend-tera-v4-latin-regular.woff") format("woff"), url("fonts/lexend-tera-v4-latin-regular.ttf") format("truetype"), url("fonts/lexend-tera-v4-latin-regular.svg#LexendTera") format("svg")
}

html,
body {
	height: 100%
}

body {
	color: #000;
	font-size: 14px;
	font-family: sans-serif;
	line-height: 1
}

@media screen and (min-width: 981px) {
	body {
		min-width: 980px
	}
}

em,
strong {
	font-weight: bold
}

a {
	color: #65397c
}

img {
	vertical-align: top
}

@media screen and (min-width: 481px) {
	.for-mobile {
		display: none
	}
}

@media screen and (max-width: 979px) {
	.not-for-tablet {
		display: none
	}
}

@media screen and (max-width: 480px) {
	.not-for-mobile {
		display: none
	}
}

.em,
.required {
	color: #C00
}

.theme {
	color: #8b468f
}

input[type="text"],
input[type="password"],
input[type="email"],
input[type="tel"] {
	border: 1px solid #DDD;
	-webkit-border-radius: 3px;
	-moz-border-radius: 3px;
	-ms-border-radius: 3px;
	-o-border-radius: 3px;
	border-radius: 3px;
	height: 32px;
	width: 100%;
	text-indent: 8px
}

textarea {
	border: 1px solid #DDD;
	-webkit-border-radius: 3px;
	-moz-border-radius: 3px;
	-ms-border-radius: 3px;
	-o-border-radius: 3px;
	border-radius: 3px;
	box-sizing: border-box;
	width: 100%;
	height: 240px;
	padding: 8px;
	font-size: 14px;
	line-height: 1.5
}

select {
	height: 32px;
	line-height: 32px;
	border: 1px solid #DDD
}

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

	input[type="text"],
	input[type="password"],
	input[type="email"],
	input[type="tel"],
	textarea,
	select {
		font-size: 16px
	}
}

.header {
	text-align: center
}

.header .copy {
	display: none
}

body.home .header {
	background: #65397c url(images/top.jpg.webp) center no-repeat;
	-webkit-background-size: cover;
	-moz-background-size: cover;
	-o-background-size: cover;
	background-size: cover;
	padding: 80px 0;
	color: #FFF;
	font-weight: bold
}

@media screen and (max-width: 480px) {
	body.home .header {
		background: #65397c url(images/top-sp.jpg.webp) center no-repeat;
		-webkit-background-size: cover;
		-moz-background-size: cover;
		-o-background-size: cover;
		background-size: cover
	}

	.no-webp body.home .header {
		background-image: url(images/top-sp.jpg);
		-webkit-background-size: cover;
		-moz-background-size: cover;
		-o-background-size: cover;
		background-size: cover
	}
}

.no-webp body.home .header {
	background-image: url(images/top.jpg)
}

body.home .header .copy {
	display: block;
	font-size: 14px;
	margin-bottom: 20px
}

@media screen and (max-width: 480px) {
	body.home .header .copy {
		font-size: 12px
	}
}

body.home .header h1 {
	margin-bottom: 44px
}

@media screen and (max-width: 480px) {
	body.home .header h1 img {
		width: 80%;
		height: auto
	}
}

body:not(.home) .header h1 {
	/*
	padding: 13px 20px 13px 10px;
	*/
	padding: 5px 20px 10px 10px;
	float: left
}

body:not(.home) .header h1 img {
	filter: invert(100%);
	/*
	height: 24px;
	*/
	height: 32px;
	width: auto
}

.header .global-menu {
	font-family: "Oswald", sans-serif;
	font-weight: 400;
	letter-spacing: 3px;
	font-size: 0
}

body:not(.home) .header .global-menu {
	float: left;
	height: 50px;
	line-height: 50px
}

@media screen and (max-width: 767px) {
	.header .global-menu {
		display: none
	}
}

.header .global-menu li {
	display: inline-block;
	padding: 0 15px;
	font-size: 16px
}

.header .global-menu li a {
	text-decoration: none;
	color: #000
}

body.home .header .global-menu {
	margin-bottom: 360px
}

body.home .header .global-menu a {
	color: #FFF
}

.header .description {
	font-size: 12px;
	line-height: 1.8
}

@media screen and (max-width: 1365px) {
	.header .description {
		padding: 0 10px
	}
}

@media screen and (max-width: 979px) {
	.header .description {
		text-align: left
	}
}

@media screen and (max-width: 767px) {
	.header .description {
		margin: 200px 0 -50px
	}
}

@media screen and (max-width: 480px) {
	.header .description {
		margin: 180px 0 -68px;
		font-size: 10px
	}
}

.header-inner {
	*zoom: 1
}

.header-inner:after {
	content: "";
	display: table;
	clear: both
}

.mobile-menu {
	position: fixed;
	right: -240px;
	top: 0;
	z-index: 400;
	width: 240px;
	height: 100%;
	background: #65397c;
	-webkit-transition: .5s;
	-moz-transition: .5s;
	-o-transition: .5s;
	transition: .5s
}

.mobile-menu.active {
	right: 0
}

.mobile-menu ul {
	padding-top: 15px
}

.mobile-menu li a {
	display: block;
	padding: 15px 0 15px 24px;
	color: #FFF;
	font-family: "Oswald", sans-serif;
	font-weight: 400;
	letter-spacing: 3px;
	font-size: 14px;
	text-decoration: none
}

.main > section {
	padding-top: 100px;
	text-align: center
}

.main > section h2 {
	color: #65397c;
	font-family: "Lexend Tera", sans-serif;
	font-size: 24px
}

.main > section h2 + p {
	margin-top: 30px;
	font-weight: bold;
	line-height: 1.5
}

@media screen and (max-width: 480px) {
	.main > section {
		padding-top: 50px
	}

	.main > section h2 {
		font-size: 20px
	}

	.main > section + p {
		margin-top: 24px
	}
}

.section-body .section-child {
	padding-top: 80px
}

.section-body .section-child h3 {
	font-size: 18px;
	font-weight: bold;
	color: #65397c;
	letter-spacing: 2px
}

@media screen and (max-width: 480px) {
	.section-body .section-child {
		padding-top: 44px
	}

	.section-body .section-child h3 {
		font-size: 16px
	}
}

#company {
	padding-left: 10px;
	padding-right: 10px
}

#company .services dl {
	margin-top: 50px
}

#company .services dt {
	margin-top: 44px;
	font-size: 16px;
	font-weight: bold;
	color: #8b468f
}

#company .services dd {
	margin-top: 15px;
	font-size: 12px;
	line-height: 1.5
}

#company .services dd.fx {
	max-width: 708px;
	margin-left: auto;
	margin-right: auto;
	padding: 20px;
	background-color: rgba(139,70,143,0.1);
}
#company .services dd.fx p {
	box-sizing: border-box;
	text-align: left;
	line-height: 1.5;
	padding-top: 15px;
	font-size: 0.75rem;
	padding-right: 10px;
}
#company .services dd.fx p a {
	display: table;
	margin-top: 15px;
	border: 1px solid #8b468f;
	border-radius: 3px;
	padding: 15px 20px;
	font-size: 1rem;
	text-decoration: none;
}
#company .services dd.fx figure img {
	width: 100%;
	height: auto;
}

@media screen and (min-width: 768px) {
	#company .services dd.fx {
		font-size: 0;
	}
	#company .services dd.fx p,
	#company .services dd.fx figure {
		display: inline-block;
		width: 50%;
		vertical-align: middle;
	}
}

@media screen and (max-width: 767px) {
	#company .services dd {
		text-align: left
	}
	#company .services dd.fx p a {
		margin: 15px auto;
	}
}

#company .overview {
	padding-top: 100px
}

@media screen and (max-width: 767px) {
	#company .overview {
		padding-top: 80px;
		display: table;
		margin: 0 auto
	}
}

#company .overview dl {
	display: table;
	margin: 50px auto 0;
	color: #8b468f;
	text-align: left
}

@media screen and (max-width: 480px) {
	#company .overview dl {
		display: block
	}
}

#company .overview dt {
	font-size: 9px
}

#company .overview dd {
	margin-top: 3px;
	font-size: 20px
}

#company .overview .other {
	display: inline-block;
	margin-top: 30px;
	padding: 0 15px;
	border-left: 1px solid #999;
	color: #000
}

#company .overview .other dt {
	color: #999
}

#company .overview .other dd {
	font-size: 14px
}

@media screen and (max-width: 767px) {
	#company .overview .other:nth-child(3) {
		display: table;
		margin: 30px auto 0
	}

	#company .overview .other:nth-child(3) + .other {
		border-left: none
	}
}

@media screen and (max-width: 480px) {
	#company .overview .other {
		display: block !important;
		margin-top: 15px;
		padding: 0;
		border: none
	}
}

#company .overview .name + .other {
	border-left: none
}

#recruit {
	margin-top: 80px;
	padding: 80px 10px;
	background: #8b468f;
	color: #FFF
}

#recruit h2,
#recruit h3 {
	color: #FFF
}

#recruit table {
	margin: 30px auto 0
}

#recruit th,
#recruit td {
	padding: 5px 0;
	font-weight: bold;
	text-align: left;
	line-height: 1.5
}

#recruit th {
	padding-right: 30px
}

@media screen and (min-width: 768px) {
	#recruit th {
		padding-right: 80px
	}
}

@media screen and (max-width: 480px) {

	#recruit tr,
	#recruit th,
	#recruit td {
		display: block
	}

	#recruit tr:not(:first-child) {
		margin-top: 15px
	}

	#recruit th {
		font-weight: normal
	}
}

.button {
	margin-top: 30px
}

.button a,
.button button,
.button input[type="submit"] {
	display: inline-block;
	-webkit-border-radius: 5px;
	-moz-border-radius: 5px;
	-ms-border-radius: 5px;
	-o-border-radius: 5px;
	border-radius: 5px;
	border: none;
	background: #8b468f;
	text-decoration: none;
	color: #FFF;
	font-size: 16px;
	font-weight: bold
}

.button .cancel {
	background-color: #999 !important;
}

.button a:not(:first-child),
.button button:not(:first-child),
.button input[type="submit"] {
	margin-left: 10px
}

.button a:hover,
.button button:hover {
	opacity: 0.7
}

.button a {
	padding: 20px 30px
}

.button button,
.button input[type="submit"] {
	height: 50px;
	padding: 0 30px;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	border: none
}

#recruit .button a {
	border: 1px solid #FFF;
	background: transparent
}

#contact .section-body,
body.page-contact .section-body {
	max-width: 480px;
	padding: 0 10px;
	margin: 30px auto 0
}

#contact .section-body input,
#contact .section-body textarea,
body.page-contact .section-body input,
body.page-contact .section-body textarea {
	margin-top: 15px
}

#contact .section-body .error,
body.page-contact .section-body .error {
	display: block;
	margin-top: 8px;
	text-align: left;
	font-weight: bold
}

#contact .section-body form > p:first-child,
body.page-contact .section-body form > p:first-child {
	margin: 30px 0 50px;
	font-weight: bold;
	line-height: 1.5
}

body.page-contact .complete .introduction {
	margin: 30px 0 50px;
	line-height: 1.5
}

#contact .section-body .message,
body.page-contact .section-body .message {
	margin-top: 30px;
	border: 1px solid #8b468f;
	background: rgba(24, 88, 179, 0.2);
	color: #8b468f;
	font-weight: bold;
	padding: 50px 0
}

.confirmation > p {
	display: table;
	min-width: 300px;
	margin: 20px auto 0 !important;
	text-align: left;
}

.confirmation > p b {
	display: block;
	margin: 24px 0 8px;
	color: #8b468f;
}

.confirmation > p span {
	display: inline-block;
	box-sizing: border-box;
	min-width: 300px;
	padding: 15px;
	background-color: #EEE;
}

.page-privacy .section-body {
	max-width: 960px;
	margin: 50px auto;
	padding: 0 10px;
	text-align: left;
}

.page-privacy .section-body h3,
.page-privacy .section-body p,
.page-privacy .section-body li {
	margin-top: 15px;
	line-height: 1.5;
}

.page-privacy .section-body h3 {
	font-weight: bold;
}

.page-privacy .section-body ol {
	list-style: decimal outside;
	padding-left: 1.5em;
}

.menu-switch {
	position: fixed;
	right: 10px;
	top: 10px;
	z-index: 500;
	width: 32px;
	height: 28px
}

body.home .menu-switch {
	mix-blend-mode: hard-light
}

.menu-switch:before,
.menu-switch:after {
	content: " "
}

.menu-switch:before,
.menu-switch:after,
.menu-switch span {
	display: block;
	width: 32px;
	height: 2px;
	background: #000;
	position: absolute;
	left: 0;
	-webkit-transition: .5s;
	-moz-transition: .5s;
	-o-transition: .5s;
	transition: .5s
}

body.home .menu-switch:before,
body.home .menu-switch:after,
body.home .menu-switch span {
	background: #65397c
}

.menu-switch:before {
	top: 0
}

.menu-switch:after {
	bottom: 0
}

.menu-switch span {
	top: 50%;
	margin-top: -1px
}

.menu-switch.active:before {
	-webkit-transform: rotate(45deg);
	-moz-transform: rotate(45deg);
	-ms-transform: rotate(45deg);
	-o-transform: rotate(45deg);
	transform: rotate(45deg);
	margin-top: 13px
}

.menu-switch.active:after {
	-webkit-transform: rotate(-45deg);
	-moz-transform: rotate(-45deg);
	-ms-transform: rotate(-45deg);
	-o-transform: rotate(-45deg);
	transform: rotate(-45deg);
	margin-bottom: 13px
}

.menu-switch.active span {
	left: 300px
}

body:not(.home) .menu-switch.active:before,
body:not(.home) .menu-switch.active:after,
body:not(.home) .menu-switch.active span {
	background: #FFF
}

.overlay {
	display: none;
	position: fixed;
	left: 0;
	top: 0;
	z-index: 300;
	width: 100%;
	height: 100%;
	background: rgba(0, 0, 0, 0.7)
}

.footer {
	text-align: center
}

.home .footer {
	padding-top: 100px
}

.page .footer {
	padding-top: 0
}

.footer .copyright {
	display: block;
	padding: 50px 0;
	font-size: 12px
}

.page-header {
	padding-top: 80px;
	text-align: center
}

.page-head {
	font-size: 30px;
	font-weight: bold;
	letter-spacing: 3px
}

.page-body {
	margin-top: 80px
}

body:not(.home) .page-body {
	max-width: 960px;
	margin-right: auto;
	margin-left: auto;
	padding-left: 10px;
	padding-right: 10px
}

.page-body h2,
.page-body h3 {
	font-weight: bold;
	line-height: 1.5
}

.page-body h2 {
	font-size: 16px
}

.page-body h2:not(:first-child) {
	margin-top: 2em
}

.page-body h3:not(:first-child) {
	margin-top: 1.5em
}

.page-body p {
	line-height: 1.5
}

.page-body p:not(:first-child) {
	margin-top: 1em
}

#booking-package-locale-ja {
	max-width: 748px;
	margin: 0 auto
}

@media screen and (max-width: 768px) {
	#booking-package-locale-ja {
		margin-left: 10px;
		margin-right: 10px
	}
}

#bottomPanel,
.bottomBarPanel,
#paymentPanel {
	text-align: center
}

#bottomPanel button,
.bottomBarPanel button,
#paymentPanel button {
	width: auto !important;
	height: 50px;
	min-width: 200px;
	padding: 0 20px;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	border: none;
	-webkit-border-radius: 5px;
	-moz-border-radius: 5px;
	-ms-border-radius: 5px;
	-o-border-radius: 5px;
	border-radius: 5px;
	background: #8b468f;
	color: #FFF;
	font-weight: bold
}

#bottomPanel button[id^="return"],
.bottomBarPanel button[id^="return"],
#paymentPanel button[id^="return"] {
	background: #999
}

button[class$="DayButton"],
button[class$="DayButtton"] {
	display: none
}