@charset "UTF-8";

@import url('https://use.fontawesome.com/releases/v5.15.4/css/all.css');
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&family=Noto+Serif+JP:wght@200..900&family=Manrope:wght@200..800&display=swap');

:root {
	--color-purple: #ac58ac;
	--color-lightpurple: #f7eef3;
	--color-black: #1A1A1A;
}

html {
	font-size: 62.5%;
	-webkit-text-size-adjust: 100%;
}

* {
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: 400;
	font-style: normal;
	font-size: 1.6rem;
	letter-spacing: 0.05em;
	margin: 0;
	padding: 0;
}

.indent {
	text-indent: -1em;
	padding-left: 1em;
}

.mincho {
	font-family: "Noto Serif JP", serif;
}

.strong {
	color: #EA5532;
}

.bold {
	font-weight: bold;
}

.cl_purple {
	color: var(--color-purple);
}

.cl_lightpurple {
	color: var(--color-lightpurple);
}

.cl_black {
	color: var(--color-black);
}

.txt-start {
	text-align: left;
}
.txt-center {
	text-align: center;
}
.txt-end {
	text-align: right;
}

.mt25 {
	margin-top: 25px;
}

.mb1em {
	margin-bottom: 1em;
}

.fs17 {
	font-size: 1.7rem !important;
}
.fs18 {
	font-size: 1.8rem !important;
}
.d-inline-block {
	display: inline-block !important;
}

div.box_purple {
	background-color: #f9eef7;
	margin: 2em 0;
	padding: 1.5em 1em;
	border-radius: 1em;
	text-align: center;
}

div.box_purple div {
	font-weight: bold;
	margin-bottom: 1em;
}

div.box_purple a {
	font-weight: bold;
	font-size: 1.4rem;
	color: var(--color-purple);
	background: #fff;
	padding: 0.75em 1em;
	border: solid 1px #fff;
	border-radius: 2em;
}

div.box_purple a:hover {
	border: solid 1px var(--color-purple);
	color: var(--color-black);
	opacity: 1;
}

body {
	margin: 0;
}

h1 {
	font-size: 2em;
	margin: 0.67em 0;
}

hr {
	-webkit-box-sizing: content-box;
	box-sizing: content-box;
	height: 0;
	overflow: visible;
}

a {
	background-color: transparent;
}

b,
strong {
	font-weight: bolder;
}

small {
	font-size: 80%;
}

img {
	border-style: none;
}

ol,
ul {
	list-style: none;
}

caption,
th {
	text-align: left;
}

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

img,
a {
	text-decoration: none;
	vertical-align: top;
}

a:link,
a:visited {
	color: #333;
}

strong {
	font-weight: bold;
}

hr {
	margin: 10px 0;
	padding: 0;
	border-top: 1px solid #cccccc;
}

.clear {
	clear: both;
}

.left {
	float: left;
}

.right {
	float: right;
}

.clearfix:after {
	content: " ";
	display: block;
	clear: both;
	height: 0;
	visibility: hidden;
	font-size: 0.1em;
	line-height: 0;
}

.clearfix {
	min-height: 0.1px;
}

* html .clearfix {
	height: 0.1px;
}

.clearfix:after {
	content: "";
	display: block;
	clear: both;
}

a,
a:visited {
	color: black;
	text-decoration: none;
	-webkit-transition: all .3s ease;
	transition: all .3s ease;
}

a img,
a:visited img {
	backface-visibility: hidden;
	-webkit-backface-visibility: hidden;
	-webkit-text-decoration-skip: none;
}

a:hover,
a:visited:hover {
	text-decoration: none;
}

img {
	width: 100%;
	max-width: 100%;
	height: auto;
}

.l-h-title,
.l-h-title__border {
	color: var(--color-black);
	position: relative;
	z-index: 3;
}

/* flow */
.flow {
	background: #f9eef7;
	max-width: 1440px;
	width: 100%;
	margin: auto;
	position: relative;
	text-align: center;
}

.flow .l-h-title {
	margin: 0 auto;
	padding: 4em 0 3em 0;
}

.flow .grid {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	max-width: 1050px;
	margin: 0 auto;
	padding-bottom: 4em;
	gap: 40px;
}

.flow .flow-box {
	flex-basis: calc((100% - 80px) / 3);
	box-sizing: border-box;
}

.flow-box:nth-child(1) .content,
.flow-box:nth-child(2) .content,
.flow-box:nth-child(3) .content {
	height: 370px;
}

.flow-box:nth-child(4) .content,
.flow-box:nth-child(5) .content {
	height: 190px;
}

.flow .flow-box .no {
	font-family: "Manrope", sans-serif;
	font-size: 3.9rem;
	font-weight: 600;
	color: var(--color-purple);
	text-align: left;
	margin-bottom: 10px;
}

.flow .flow-box .content {
	background-color: #fff;
	padding: 0 1.5em 1.5em;
	border-radius: 10px;
}

.flow .flow-box .content span {
	display: inline-block;
	font-size: 1.8rem;
}

.flow .flow-box .content img {
	width: auto;
	max-height: 85px;
	margin-top: -15%;
}

.flow .flow-box .content div {
	color: var(--color-purple);
	font-size: 1.9rem;
	margin: 1em 0;
}

.flow .flow-box .content p {
	text-align: left;
	font-size: 1.4rem;
}
/* price */
.price {
	max-width: 1440px;
	width: 100%;
	margin: auto;
	position: relative;
	text-align: center;
}

.price .l-h-title {
	margin: 0 auto;
	padding: 4em 0 3em 0;
}

.price .grid {
	max-width: 1050px;
	display: grid;
	grid-template-columns: 1fr 1fr;
	margin: 0 auto;
	padding-bottom: 8em;
	gap: 30px;
}

.price .price-box {
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	box-sizing: border-box;
	height: 100%;
}

.price .price-box p {
	margin-top: auto;
	margin-bottom: 0;
	padding-top: 0.5em;
	font-size: 2.5rem;
	font-weight: bold;
}
.price .price-box p span {
	display: inline-block;
}

.price .price-box .content {
	flex-grow: 1;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	padding: 0.25em 0;
	background: var(--color-purple);
}

.price .price-box .content div {
	flex-grow: 1;
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	color: #fff;
	margin: 0;
	padding: 0.25em 0.5em;
	background: var(--color-purple);
}

.price .grid .price-box:nth-child(2),
.price .grid .price-box:nth-child(4),
.price .grid .price-box:nth-child(6) {
	padding: 0 0 0 30px;
	border-left: 1px dashed #4D4D4D;
}

/* access */
#access {
	max-width: 1440px;
	width: 100%;
	margin: auto;
	position: relative;
	text-align: center;
}

#access .l-h-title {
	margin: 0 auto;
	padding: 4em 0 3em 0;
}

#access .grid {
	max-width: 1050px;
	display: grid;
	grid-template-columns: 1fr 1fr;
	margin: 0 auto;
	padding-bottom: 8em;
}

#access .access-box {
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	box-sizing: border-box;
	height: 100%;
	background: #FAFAFA;
}

#access .access-box div {
	justify-content: center;
}

#access .access-box.info div {
	padding: 7em 5em;
}

#access .access-box img {
	max-width: 110px;
}

#access .access-box p.name {
	font-size: 1.9rem;
	font-weight: bold;
	padding: 1em 0;
}

#access .access-box p.bumon {
	font-size: 1.4rem;
	padding-bottom: 2em;
	border-bottom: 1px dashed #4D4D4D;
}

#access .access-box p.info {
	font-size: 1.4rem;
	padding: 2em 0 0.5em;
}
#access .access-box p.info span {
	display: block;
	font-size: 1.4rem;
}

#access .access-box p.info span:nth-child(2) {
	padding: 1em 0 0.5em;
	font-weight: bold;
}


#map {
	height: 100%;
	width: 100%;
}


/* contact */
.contact {
	max-width: 1440px;
	width: 100%;
	margin: auto;
	position: relative;
	text-align: center;
}

.contact > p {
	padding: 0 1em;
}

.contact .l-h-title {
	margin: 0 auto;
	padding: 4em 0 3em 0;
}

.contact .grid {
	max-width: 1050px;
	display: grid;
	grid-template-columns: 1fr 1fr 1fr;
	margin: 3em auto 0;
	padding-bottom: 8em;
}

.contact .contact-box {
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	box-sizing: border-box;
	height: 100%;
	background: #FAFAFA;
}

.contact > .grid > div:nth-child(2) {
	background: var(--color-lightpurple);
}

.contact .contact-box:last-child {
	background: #F5D6EB;
}


.contact .contact-box div {
	justify-content: center;
	padding: 3em 1em;
}

.contact .contact-box img {
	max-width: 68px;
}

.contact .contact-box a span {
	display: block;
	font-size: 2.4rem;
	color: var(--color-purple);
}


.l-h-title__jp {
	font-size: 1.6rem;
	letter-spacing: 0.1em;
}

.l-h-title__en {
	font-size: 3.4rem;
	letter-spacing: 0.32em;
	font-weight: 400;
}

.l-sideber-nav {
	color: #fff;
	position: fixed;
	top: 0;
	left: 0;
	z-index: 100;
	background: rgba(0, 0, 0, 0);
	-webkit-transition: ease-in-out 0.3s;
	transition: ease-in-out 0.3s;
}

.l-sideber-nav .l-sideber-nav__headerlogo a {
	-webkit-transform: translateX(-20%);
	transform: translateX(-20%);
	opacity: 0;
	display: block;
	width: 120px;
	margin: 0 0 0 -13px;
}

.l-sideber-nav__wrap {
	visibility: hidden;
	opacity: 0;
	-webkit-transition: ease-in-out .2s;
	transition: ease-in-out .2s;
	max-width: 100%;
	width: 45%;
	max-width: 720px;
	background: var(--color-purple);
	position: fixed;
	top: 0;
	bottom: 0;
	right: 0;
	padding: 0 5%;
}

.l-sideber-nav__logo {
	max-width: 250px;
}

.l-sideber-nav__logo a {
	display: block;
}

.l-sideber-nav #gnavi {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-flow: wrap;
	flex-flow: wrap;
	padding: 40px 0 30px 0;
}

.l-sideber-nav #gnavi li {
	width: 100%;
	-webkit-transform: translateX(-20%);
	transform: translateX(-20%);
	opacity: 0;
	position: relative;
	font-size: 1.6rem;
	height: 20%;
}

.l-sideber-nav #gnavi a {
	width: 100%;
	height: 100%;
	display: block;
/*	text-align: left;*/
	text-align: center;
	padding: 20px 0;
	color: inherit;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-direction: column;
	flex-direction: column;
}

.l-sideber-nav #gnavi a .en {
	display: block;
	font-size: 2rem;
	line-height: 1;
	font-weight: 400;
}

.l-sideber-nav #gnavi a .jp {
	font-size: 1.4rem;
	line-height: 1;
}

.l-sideber-nav .l-sideber__info {
	-webkit-transform: translateX(-20%);
	transform: translateX(-20%);
	opacity: 0;
	width: 100%;
	font-size: 1.4rem;
	line-height: 2.1;
	text-align: center;
}

.l-sideber-nav .l-sideber__info .wrap {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-direction: column;
	flex-direction: column;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
}

.l-sideber-nav .l-sideber__info a {
	font-weight: 400;
	color: inherit;
	border: 1px solid;
	height: 50px;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-direction: column;
	flex-direction: column;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
}

.l-sideber-nav .l-sideber__info a+a {
	margin-top: 10px;
}

.l-sideber-nav .l-sideber__info .caution {
	font-size: 1.2rem;
	line-height: 1.6;
	padding-top: 20px;
}

.l-sideber__switch {
	display: block;
	position: fixed;
	z-index: 99;
	top: 19px;
	right: 20px;
	text-align: center;
}

.l-sideber__switch a {
	display: block;
	font-weight: bold;
}

.l-sideber__switch__icon {
	position: relative;
	width: 24px;
	height: 21px;
	margin: auto;
}

.l-sideber__switch__icon span {
	display: block;
	background: var(--color-purple);
	width: 100%;
	height: 2px;
	position: absolute;
	-webkit-transition: top .5s ease, -webkit-transform .2s ease-in-out;
	transition: top .5s ease, -webkit-transform .2s ease-in-out;
	transition: transform .2s ease-in-out, top .5s ease;
	transition: transform .2s ease-in-out, top .5s ease, -webkit-transform .2s ease-in-out;
}

.l-sideber__switch__icon span:nth-child(1) {
	top: 0;
}

.l-sideber__switch__icon span:nth-child(2) {
	top: 7px;
}

.l-sideber__switch__icon span:nth-child(3) {
	top: 14px;
}

.l-sideber__switch__txt {
	color: var(--color-purple);
	font-weight: 600;
	line-height: 1;
	font-size: 1rem;
}

.open {
	overflow: hidden;
}

.open .l-sideber-nav {
	display: block;
	width: 100%;
	height: 100%;
	background: rgba(0, 0, 0, 0.4);
}

.open .l-sideber-nav__wrap {
	display: block;
	visibility: visible;
	opacity: 1;
	overflow-y: scroll;
	padding-top: 60px;
	padding-bottom: 60px;
	width: 400px;
}

.open .l-sideber-nav .l-sideber-nav__headerlogo a {
	-webkit-animation: o-p-k_slideIn 1.2s ease 0.1s 1 forwards;
	animation: o-p-k_slideIn 1.2s ease 0.1s 1 forwards;
}

.open .l-sideber-nav #gnavi li:nth-child(1) {
	-webkit-animation: o-p-k_slideIn 1.2s ease 0.2s 1 forwards;
	animation: o-p-k_slideIn 1.2s ease 0.2s 1 forwards;
}

.open .l-sideber-nav #gnavi li:nth-child(2) {
	-webkit-animation: o-p-k_slideIn 1.2s ease 0.3s 1 forwards;
	animation: o-p-k_slideIn 1.2s ease 0.3s 1 forwards;
}

.open .l-sideber-nav #gnavi li:nth-child(3) {
	-webkit-animation: o-p-k_slideIn 1.2s ease 0.4s 1 forwards;
	animation: o-p-k_slideIn 1.2s ease 0.4s 1 forwards;
}

.open .l-sideber-nav #gnavi li:nth-child(4) {
	-webkit-animation: o-p-k_slideIn 1.2s ease 0.5s 1 forwards;
	animation: o-p-k_slideIn 1.2s ease 0.5s 1 forwards;
}

.open .l-sideber-nav .l-sideber__info {
	-webkit-animation: o-p-k_slideIn 1.2s ease 0.6s 1 forwards;
	animation: o-p-k_slideIn 1.2s ease 0.6s 1 forwards;
}

.open #nav-toggle span:nth-child(1) {
	top: 7px;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
}

.open #nav-toggle span:nth-child(2) {
	top: 7px;
	-webkit-transform: rotate(-45deg);
	transform: rotate(-45deg);
}

.open #nav-toggle span:nth-child(3) {
	top: 7px;
	width: 0;
	left: 50%;
}

.open .l-sideber__switch {
	margin-right: 20px;
}

.open .l-sideber__switch__icon span {
	background: #fff;
}

.open .l-sideber__switch__txt {
	color: #fff;
}

.scroll-prevent {
	height: 100%;
	overflow: hidden;
}

.l-footer {
	background: var(--color-purple);
	margin: auto;
}

.l-footer .l-footer__nav {
	max-width: 1100px;
	width: 80%;
	height: 150px;
	margin: auto;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
}

.l-footer .l-footer__logo {
	display: block;
	cursor: pointer;
	width: 211px;
	margin: 5px 0 0 0;
}

.l-footer .l-footer__list {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	width: 360px;
	height: 36px;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	color: #008475;
	font-size: 1.1rem;
	line-height: 1;
}

.l-footer .l-footer__list li {
	width: calc(100% / 3);
	margin-bottom: 18px;
}

.l-footer .l-footer__list li a {
	color: inherit;
	letter-spacing: 0.1em;
	font-weight: 400;
}

.l-footer__copy {
	background: var(--color-purple);
	vertical-align: middle;
	color: #fff;
	font-size: 1.2rem;
	padding: 25px 0;
	font-weight: 400;
}

main {
	display: block;
	overflow: hidden;
}

.o-c-btn__blank a,
.o-c-btn__menuBack a {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	text-align: center;
	color: #008475;
	font-size: 1.6rem;
	line-height: 1;
	border: 1px solid #008475;
	-webkit-transition: ease-in-out .2s;
	transition: ease-in-out .2s;
	font-weight: 400;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-ms-flex-direction: row;
	flex-direction: row;
	justify-content: center;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	height: 46px;
}

.o-c-btn__blank a:after,
.o-c-btn__menuBack a:after {
	content: "";
	display: block;
	margin-left: 8px;
	width: 12px;
	height: 12px;
	background: url(../img/icon_window.png) no-repeat center/cover;
}

.o-c-btn a {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	text-align: center;
	color: #008475;
	font-size: 1.6rem;
	line-height: 1;
	border: 1px solid #008475;
	-webkit-transition: ease-in-out .2s;
	transition: ease-in-out .2s;
	font-weight: 400;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-ms-flex-direction: row;
	flex-direction: row;
	justify-content: center;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	height: 46px;
}

.o-c-btn__menuBack {
	display: none;
}

.o-c-btn__menuBack a {
	font-size: 1.2rem;
	line-height: 1;
	height: 46px;
}

.o-c-btn__menuBack a:after {
	display: none;
}

.fadein_v1 {
	-webkit-transition: ease-in-out .5s;
	transition: ease-in-out .5s;
	opacity: 0;
	-webkit-transform: translateY(20px);
	transform: translateY(20px);
}

.fadein_v1.scrollWatch {
	opacity: 1;
	-webkit-transform: translateY(0px);
	transform: translateY(0px);
}

.fadein {
	opacity: 0;
}

.fadeinup {
	opacity: 0;
}

.fadeinright {
	opacity: 0;
}

.fadeinleft {
	opacity: 0;
}

.fadein_v2 {
	-webkit-transition: ease-in-out .9s;
	transition: ease-in-out .9s;
	opacity: 0;
	-webkit-transform: translateY(30px);
	transform: translateY(30px);
}

.fadein_v2.scrollWatch {
	opacity: 1;
	-webkit-transform: translateY(0px);
	transform: translateY(0px);
}

.o-c-a-colorWrap {
	position: relative;
}

.o-c-a-colorWrap:after {
	content: "";
	display: block;
	position: absolute;
	top: 0;
	right: 0;
	height: 100%;
	width: 100%;
	background: var(--color-purple);
	-webkit-transition: 0.8s cubic-bezier(0.57, 0.15, 0.13, 0.97);
	transition: 0.8s cubic-bezier(0.57, 0.15, 0.13, 0.97);
}

.o-c-a-colorWrap.show:after {
	width: 0;
}

.o-c-a-fadein {
	-webkit-transition: ease-in-out .5s;
	transition: ease-in-out .5s;
	opacity: 0;
	-webkit-transform: translateY(20px);
	transform: translateY(20px);
}

.o-c-a-fadein.show {
	opacity: 1;
	-webkit-transform: translateY(0px);
	transform: translateY(0px);
}

section.o-c-s-wave_bottom:after {
	content: "";
	display: block;
	width: 100%;
	height: 120px;
	background: url(../img/item_wave-bottom.png) no-repeat top center/100%;
	background-color: #fff;
}

section.o-c-s-wave_top:before {
	content: "";
	display: block;
	width: 100%;
	height: 120px;
	background: url(../img/item_wave-top.png) no-repeat bottom center/100%;
	background-color: #fff;
}

#loading,
.o-p-l-loading {
	position: absolute;
	top: 50%;
	left: 50%;
	-webkit-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
	width: 186px;
}

#loader-bg,
.o-p-l-loader-bg {
	position: fixed;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	background: #fff;
	z-index: 1001;
}

#o-p-pagetop {
	cursor: pointer !important;
	position: fixed;
	right: 20px;
	bottom: 60px;
	font-size: 1.4rem;
}

#o-p-pagetop .arrow {
	position: absolute;
	display: block;
	width: 1px;
	background: #000;
	-webkit-animation: heightTrans 2s ease-in-out 1s infinite;
	animation: heightTrans 2s ease-in-out 1s infinite;
	top: -85px;
	right: 51%;
}

@-webkit-keyframes heightTrans {
	0% {
		height: 45px;
	}

	80% {
		height: 0;
	}

	100% {
		height: 0;
	}
}

@keyframes heightTrans {
	0% {
		height: 45px;
	}

	80% {
		height: 0;
	}

	100% {
		height: 0;
	}
}

#o-p-pagetop .en {
	transform: rotate(90deg);
	-webkit-transform: rotate(90deg);
}

#o-p-pagetop.o-p-position {
	position: absolute;
	bottom: 90px;
}

.o-p-s-slide_arrow {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-direction: column;
	flex-direction: column;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	width: 34px;
	height: 34px;
	z-index: 1;
	cursor: pointer;
	-webkit-transition: ease-in-out .2s;
	transition: ease-in-out .2s;
}

.o-p-s-slide_arrow:hover,
.o-p-s-slide_arrow:active {
	opacity: .2;
}

.o-p-s-slide_arrow img {
	-webkit-transition: ease-in-out .2s;
	transition: ease-in-out .2s;
}

.o-p-s-slide_arrow.prev-arrow:hover img {
	-webkit-transform: translateX(-10px) rotate(-180deg);
	transform: translateX(-10px) rotate(-180deg);
}

.o-p-s-slide_arrow.prev-arrow img {
	-webkit-transform: rotate(-180deg);
	transform: rotate(-180deg);
}

.o-p-s-slide_arrow.next-arrow:hover img {
	-webkit-transform: translateX(10px);
	transform: translateX(10px);
}

@-webkit-keyframes o-p-k_dots_change {
	0% {
		width: 0;
	}

	100% {
		width: 100%;
	}
}

@keyframes o-p-k_dots_change {
	0% {
		width: 0;
	}

	100% {
		width: 100%;
	}
}

@-webkit-keyframes spin {
	0% {
		-webkit-transform: rotate(0deg);
		transform: rotate(0deg);
	}

	100% {
		-webkit-transform: rotate(360deg);
		transform: rotate(360deg);
	}
}

@keyframes spin {
	0% {
		-webkit-transform: rotate(0deg);
		transform: rotate(0deg);
	}

	100% {
		-webkit-transform: rotate(360deg);
		transform: rotate(360deg);
	}
}

@-webkit-keyframes o-p-k_slideIn {
	100% {
		opacity: 1;
		-webkit-transform: translateX(0%);
		transform: translateX(0%);
	}

	@media screen and (max-width: 480px) {
		80% {
			opacity: 1;
			-webkit-transform: translateX(0%);
			transform: translateX(0%);
		}
	}
}

@keyframes o-p-k_slideIn {
	100% {
		opacity: 1;
		-webkit-transform: translateX(0%);
		transform: translateX(0%);
	}

	@media screen and (max-width: 480px) {
		80% {
			opacity: 1;
			-webkit-transform: translateX(0%);
			transform: translateX(0%);
		}
	}
}

@-webkit-keyframes o-p-k_fadeIn {
	100% {
		opacity: 1;
		-webkit-transform: translateY(0%);
		transform: translateY(0%);
	}

	@media screen and (max-width: 480px) {
		80% {
			opacity: 1;
			-webkit-transform: translateX(0%);
			transform: translateX(0%);
		}
	}
}

@keyframes o-p-k_fadeIn {
	100% {
		opacity: 1;
		-webkit-transform: translateY(0%);
		transform: translateY(0%);
	}

	@media screen and (max-width: 480px) {
		80% {
			opacity: 1;
			-webkit-transform: translateX(0%);
			transform: translateX(0%);
		}
	}
}

.u-f20 {
	font-size: 2rem;
	line-height: 2;
}

.u-f18 {
	font-size: 1.8rem;
	line-height: 2;
}

.u-f16 {
	font-size: 1.6rem;
	line-height: 2;
}

.u-f14 {
	font-size: 1.4rem;
	line-height: 2;
}

.u-f12 {
	font-size: 1.2rem;
	line-height: 2;
}

.u-f10 {
	font-size: 1rem;
	line-height: 2;
}

.u-text-align--center {
	text-align: center;
}

.u-text-align--left {
	text-align: left;
}

.u-text-align--right {
	text-align: right;
}

.u-vertical-align--top {
	vertical-align: top;
}

.u-vertical-align--middle {
	vertical-align: middle;
}

.u-vertical-align--bottom {
	vertical-align: bottom;
}

.u-mb0 {
	margin-bottom: 0px;
}

.u-mb5 {
	margin-bottom: 5px;
}

.u-mb10 {
	margin-bottom: 10px;
}

.u-mb15 {
	margin-bottom: 15px;
}

.u-mb20 {
	margin-bottom: 20px;
}

.u-mb25 {
	margin-bottom: 25px;
}

.u-mb30 {
	margin-bottom: 30px;
}

.u-mb35 {
	margin-bottom: 35px;
}

.u-mb40 {
	margin-bottom: 40px;
}

.u-mb45 {
	margin-bottom: 45px;
}

.u-mb50 {
	margin-bottom: 50px;
}

.u-mb55 {
	margin-bottom: 55px;
}

.u-mb60 {
	margin-bottom: 60px;
}

.u-mb65 {
	margin-bottom: 65px;
}

.u-mb70 {
	margin-bottom: 70px;
}

.u-mb75 {
	margin-bottom: 75px;
}

.u-mb80 {
	margin-bottom: 80px;
}

.u-mt0 {
	margin-top: 0px;
}

.u-mt5 {
	margin-top: 5px;
}

.u-mt10 {
	margin-top: 10px;
}

.u-mt15 {
	margin-top: 15px;
}

.u-mt20 {
	margin-top: 20px;
}

.u-mt25 {
	margin-top: 25px;
}

.u-mt30 {
	margin-top: 30px;
}

.u-mt35 {
	margin-top: 35px;
}

.u-mt40 {
	margin-top: 40px;
}

.u-mt45 {
	margin-top: 45px;
}

.u-mt50 {
	margin-top: 50px;
}

.u-mt55 {
	margin-top: 55px;
}

.u-mt60 {
	margin-top: 60px;
}

.u-mt65 {
	margin-top: 65px;
}

.u-mt70 {
	margin-top: 70px;
}

.u-mt75 {
	margin-top: 75px;
}

.u-mt80 {
	margin-top: 80px;
}

.u-mr0 {
	margin-right: 0px;
}

.u-mr5 {
	margin-right: 5px;
}

.u-mr10 {
	margin-right: 10px;
}

.u-mr15 {
	margin-right: 15px;
}

.u-mr20 {
	margin-right: 20px;
}

.u-mr25 {
	margin-right: 25px;
}

.u-mr30 {
	margin-right: 30px;
}

.u-mr35 {
	margin-right: 35px;
}

.u-mr40 {
	margin-right: 40px;
}

.u-mr45 {
	margin-right: 45px;
}

.u-mr50 {
	margin-right: 50px;
}

.u-mr55 {
	margin-right: 55px;
}

.u-mr60 {
	margin-right: 60px;
}

.u-mr65 {
	margin-right: 65px;
}

.u-mr70 {
	margin-right: 70px;
}

.u-mr75 {
	margin-right: 75px;
}

.u-mr80 {
	margin-right: 80px;
}

.u-ml0 {
	margin-left: 0px;
}

.u-ml5 {
	margin-left: 5px;
}

.u-ml10 {
	margin-left: 10px;
}

.u-ml15 {
	margin-left: 15px;
}

.u-ml20 {
	margin-left: 20px;
}

.u-ml25 {
	margin-left: 25px;
}

.u-ml30 {
	margin-left: 30px;
}

.u-ml35 {
	margin-left: 35px;
}

.u-ml40 {
	margin-left: 40px;
}

.u-ml45 {
	margin-left: 45px;
}

.u-ml50 {
	margin-left: 50px;
}

.u-ml55 {
	margin-left: 55px;
}

.u-ml60 {
	margin-left: 60px;
}

.u-ml65 {
	margin-left: 65px;
}

.u-ml70 {
	margin-left: 70px;
}

.u-ml75 {
	margin-left: 75px;
}

.u-ml80 {
	margin-left: 80px;
}

.u-pb0 {
	padding-bottom: 0px;
}

.u-pb5 {
	padding-bottom: 5px;
}

.u-pb10 {
	padding-bottom: 10px;
}

.u-pb15 {
	padding-bottom: 15px;
}

.u-pb20 {
	padding-bottom: 20px;
}

.u-pb25 {
	padding-bottom: 25px;
}

.u-pb30 {
	padding-bottom: 30px;
}

.u-pb35 {
	padding-bottom: 35px;
}

.u-pb40 {
	padding-bottom: 40px;
}

.u-pb45 {
	padding-bottom: 45px;
}

.u-pb50 {
	padding-bottom: 50px;
}

.u-pb55 {
	padding-bottom: 55px;
}

.u-pb60 {
	padding-bottom: 60px;
}

.u-pb65 {
	padding-bottom: 65px;
}

.u-pb70 {
	padding-bottom: 70px;
}

.u-pb75 {
	padding-bottom: 75px;
}

.u-pb80 {
	padding-bottom: 80px;
}

.u-pt0 {
	padding-top: 0px;
}

.u-pt5 {
	padding-top: 5px;
}

.u-pt10 {
	padding-top: 10px;
}

.u-pt15 {
	padding-top: 15px;
}

.u-pt20 {
	padding-top: 20px;
}

.u-pt25 {
	padding-top: 25px;
}

.u-pt30 {
	padding-top: 30px;
}

.u-pt35 {
	padding-top: 35px;
}

.u-pt40 {
	padding-top: 40px;
}

.u-pt45 {
	padding-top: 45px;
}

.u-pt50 {
	padding-top: 50px;
}

.u-pt55 {
	padding-top: 55px;
}

.u-pt60 {
	padding-top: 60px;
}

.u-pt65 {
	padding-top: 65px;
}

.u-pt70 {
	padding-top: 70px;
}

.u-pt75 {
	padding-top: 75px;
}

.u-pt80 {
	padding-top: 80px;
}

.u-pr0 {
	padding-right: 0px;
}

.u-pr5 {
	padding-right: 5px;
}

.u-pr10 {
	padding-right: 10px;
}

.u-pr15 {
	padding-right: 15px;
}

.u-pr20 {
	padding-right: 20px;
}

.u-pr25 {
	padding-right: 25px;
}

.u-pr30 {
	padding-right: 30px;
}

.u-pr35 {
	padding-right: 35px;
}

.u-pr40 {
	padding-right: 40px;
}

.u-pr45 {
	padding-right: 45px;
}

.u-pr50 {
	padding-right: 50px;
}

.u-pr55 {
	padding-right: 55px;
}

.u-pr60 {
	padding-right: 60px;
}

.u-pr65 {
	padding-right: 65px;
}

.u-pr70 {
	padding-right: 70px;
}

.u-pr75 {
	padding-right: 75px;
}

.u-pr80 {
	padding-right: 80px;
}

.u-pl0 {
	padding-left: 0px;
}

.u-pl5 {
	padding-left: 5px;
}

.u-pl10 {
	padding-left: 10px;
}

.u-pl15 {
	padding-left: 15px;
}

.u-pl20 {
	padding-left: 20px;
}

.u-pl25 {
	padding-left: 25px;
}

.u-pl30 {
	padding-left: 30px;
}

.u-pl35 {
	padding-left: 35px;
}

.u-pl40 {
	padding-left: 40px;
}

.u-pl45 {
	padding-left: 45px;
}

.u-pl50 {
	padding-left: 50px;
}

.u-pl55 {
	padding-left: 55px;
}

.u-pl60 {
	padding-left: 60px;
}

.u-pl65 {
	padding-left: 65px;
}

.u-pl70 {
	padding-left: 70px;
}

.u-pl75 {
	padding-left: 75px;
}

.u-pl80 {
	padding-left: 80px;
}

.u-float__clear {
	clear: both;
}

.u-float__left {
	float: left;
}

.u-float__right {
	float: right;
}

.sp,
.tab {
	display: none;
}

.pc {
	display: block;
}

.news__title.tab {
	display: none;
}

br.pc {
	display: block;
}

br.lg {
	display: none;
}

br.md {
	display: none;
}

br.sm {
	display: none;
}

.scroll_parts {
	width: 7px;
	margin: auto;
}

a {
	-webkit-transition: ease-in-out .2s;
	transition: ease-in-out .2s;
}

a:hover {
	opacity: .6;
}

img {
	-ms-flex-negative: 0;
	flex-shrink: 0;
}

.frame__scroll {
	position: fixed;
	z-index: 3;
	bottom: 180px;
	right: 5px;
	font-size: 1.2rem;
	font-weight: 400;
	-webkit-transform: rotate(90deg);
	transform: rotate(90deg);
	color: var(--color-purple);
}

.frame__scroll div:first-child {
	font-size: 1.2rem;
	font-weight: 400;
}

.frame__scroll .scroll_parts {
	-webkit-transform: rotate(-90deg);
	transform: rotate(-90deg);
	position: absolute;
	left: 94px;
	top: -28px;
}

.frame__social {
	position: fixed;
	z-index: 6;
	top: 0;
	bottom: 0;
	right: 14px;
	margin: auto;
	height: 76px;
}

.frame__social .social__icon {
	display: block;
	width: 160px;
	position: relative;
	-webkit-transform: translateX(60px);
	transform: translateX(60px);
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	right: -68px;
}

.frame__social .social__icon::after {
	display: block;
	-webkit-transition: ease-in-out .1s;
	transition: ease-in-out .1s;
	font-size: 1.2rem;
	opacity: 0;
	font-weight: bold;
	white-space: nowrap;
	color: #fff;
	background: var(--color-purple);
	margin: 0 0 0 -16px;
	padding: 6px 0 9px 22px;
	width: 100%;
}

.frame__social .social__icon:nth-child(1)::after {
	content: "お電話でのご連絡";
}

.frame__social .social__icon:nth-child(2)::after {
	content: "メールでのご連絡";
}

.frame__social .social__icon:nth-child(3)::after {
	content: "ネット予約";
}
.frame__social .social__icon:nth-child(4)::after {
	content: "ご来院アクセス";
}

.frame__social .social__icon:hover {
	-webkit-transform: translateX(0);
	transform: translateX(0);
	opacity: 1;
	right: -15px;
}

.frame__social .social__icon:hover::after {
	opacity: 1;
}

.frame__social .social__icon::before {
	display: none;
}

.frame__social .social__icon:nth-child(1)::before {
	content: "お電話でのご連絡";
}

.frame__social .social__icon:nth-child(2)::before {
	content: "メールでのご連絡";
}

.frame__social .social__icon:nth-child(3)::before {
	content: "ネット予約";
}

.frame__social .social__icon:nth-child(4)::before {
	content: "ご来院アクセス";
}

.frame__social .social__icon:hover::before {
	opacity: 1;
	-webkit-transform: translateX(0);
	transform: translateX(0);
}

.frame__social .social__icon+.social__icon {
	margin-top: 12px;
}

.frame__social .social__icon img {
	width: 32px;
	height: 32px;
	position: relative;
	z-index: 4;
}

.frame__info {
	display: block;
	position: fixed;
	z-index: 10;
	top: 50%;
	left: -76px;
	font-size: 1.2rem;
	font-weight: 400;
	-webkit-transform: rotate(-270deg);
	transform: rotate(-270deg);
	color: var(--color-purple);
}

.frame__page_top {
	opacity: 0;
	pointer-events: none;
	display: block;
	position: fixed;
	z-index: 3;
	bottom: 125px;
	right: 0;
	font-size: 1.2rem;
	font-weight: 400;
	-webkit-transition: ease-in-out .2s;
	transition: ease-in-out .2s;
}

.frame__page_top a {
	display: block;
	color: var(--color-purple);
}

.frame__page_top .scroll_parts {
	-webkit-transform: rotate(180deg);
	transform: rotate(180deg);
}

.frame__page_top span {
	display: block;
	font-size: 1.2rem;
	font-weight: 400;
	-webkit-transform: rotate(90deg);
	transform: rotate(90deg);
	margin-top: 40px;
}

.frame__page_top.show {
	opacity: 1;
	pointer-events: auto;
}

.frame__page_top.show a:hover {
	opacity: .3;
}

.frame__booking {
	color: var(--color-purple);
	position: absolute;
	right: 120px;
	z-index: 5;
	font-weight: 400;
}

.frame__booking a {
	display: -webkit-inline-box;
	display: -ms-inline-flexbox;
	display: inline-flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	color: inherit;
	height: 65px;
	-webkit-font-smoothing: initial;
}

.frame__booking .telBox {
	font-size: 1.9rem;
	line-height: 1;
	letter-spacing: 0.12em;
	margin-left: 49px;
}

.frame__booking .telBox .icon {
	width: 17px;
	margin: 0px 9px 2px 0px;
}

.frame__booking .webBox {
	font-size: 1.4rem;
	line-height: 1;
	font-weight: 500;
	letter-spacing: 0.13em;
}

.frame__booking .webBox::after {
	content: '／';
	padding: 0 2em;
}

.frame__booking .webBox:last-child::after {
	content: '';
	padding: 0;
}

.frame__booking .webBox .icon {
	width: 20px;
	margin: 0 12px 4px 0;
}

#hero {
	position: relative;
}

#hero:before {
	content: "";
	width: 50%;
	height: calc(100% + 27px);
	background: var(--color-lightpurple);
	position: absolute;
	top: 0;
	right: 0;
}

#hero .hari_01 {
	position: absolute;
	left: 27%;
	top: -70px;
	z-index: 3;
	width: 290px;
	-webkit-animation: spin 20s linear infinite;
	animation: spin 20s linear infinite;
}

#hero .hari_02 {
	position: absolute;
	left: -28px;
	bottom: -107px;
	z-index: 3;
	width: 297px;
	-webkit-animation: spin 40s linear infinite;
	animation: spin 40s linear infinite;
}

#hero .hero__inner {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	width: calc(100% - 120px);
	height: calc(100% - 120px);
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	margin: auto;
}

#hero .hero__info {
	position: relative;
	z-index: 6;
	color: var(--color-purple);
	width: 77%;
}

#hero .hero__info .logo {
	max-width: 190px;
	margin: 0 auto 50px 0;
}

#hero .hero__info .catch {
	font-size: 4.1rem;
	line-height: 1;
	letter-spacing: 0.235em;
	margin-bottom: 30px;
	-webkit-font-smoothing: initial;
}

#hero .hero__info .txt {
	font-size: 1.58rem;
	line-height: 2.3;
	letter-spacing: 0.2em;
}

#hero .hero__info__open {
	line-height: 1;
	font-weight: 600;
	letter-spacing: 0.15em;
	font-size: 1.9rem;
}

#hero .hero__bg__slider {
	height: 100%;
	position: absolute;
	right: 0;
	top: 0;
	width: calc(100% - 520px);
	min-width: 540px;
}

#hero .hero__bg__slider .slick-list,
#hero .hero__bg__slider .slick-track {
	height: 100%;
}

#hero .hero__bg__slider:before {
	content: "";
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	right: 0;
	opacity: .3;
	z-index: 5;
	background: -webkit-linear-gradient(304deg, #fae4d9, #ffffff, #f9f8de);
	background: linear-gradient(146deg, #fae4d9, #ffffff, #f9f8de);
	background-size: 600% 600%;
	-webkit-animation: AnimationName 4s ease infinite;
	animation: AnimationName 4s ease infinite;
}

@-webkit-keyframes AnimationName {
	0% {
		background-position: 2% 0%;
	}

	50% {
		background-position: 99% 100%;
	}

	100% {
		background-position: 2% 0%;
	}
}

@keyframes AnimationName {
	0% {
		background-position: 2% 0%;
	}

	50% {
		background-position: 99% 100%;
	}

	100% {
		background-position: 2% 0%;
	}
}

#hero .hero__bg__slider__img {
	height: 100%;
}

#hero .hero__bg__slider__img img {
	-o-object-fit: cover;
	object-fit: cover;
	font-family: 'object-fit: cover;';
	width: 100%;
	height: 100%;
	-webkit-transform-origin: center top;
	transform-origin: center top;
	-webkit-transform: scale(1.1);
	transform: scale(1.1);
	-webkit-transition: 5s ease-out;
	transition: 5s ease-out;
}

#hero .hero__bg__slider__img.slick-active img {
	-webkit-transform: scale(1);
	transform: scale(1);
}

.sp_hero {
	display: none;
}

.sp_hero .inner {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	position: absolute;
	background: #f6f6f6;
	width: calc(100% - 60px);
	margin: auto;
	height: calc(100% - 60px);
	right: 0;
	left: 0;
	top: 0;
	bottom: 0;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-direction: column;
	flex-direction: column;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
}

.sp_hero .logo {
	max-width: 170px;
	margin: auto;
}

.sp_hero .catch {
	color: var(--color-purple);
	font-size: 2rem;
	line-height: 1.5;
	letter-spacing: 0.18em;
	margin-top: 18px;
	-webkit-font-smoothing: initial;
}

.sp_hero-cont {
	display: none;
}

.sp_hero-cont .txt p {
	opacity: 0;
}

.sp_hero-cont.show .txt p:nth-child(1) {
	-webkit-animation: o-p-k_fadeIn 2s ease 0.2s 1 forwards;
	animation: o-p-k_fadeIn 2s ease 0.2s 1 forwards;
}

.sp_hero-cont.show .txt p:nth-child(2) {
	-webkit-animation: o-p-k_fadeIn 2s ease 0.5s 1 forwards;
	animation: o-p-k_fadeIn 2s ease 0.5s 1 forwards;
}

.sp_hero-cont.show .txt p:nth-child(3) {
	-webkit-animation: o-p-k_fadeIn 2s ease 0.8s 1 forwards;
	animation: o-p-k_fadeIn 2s ease 0.8s 1 forwards;
}

.sp_hero-cont.show .txt p:nth-child(4) {
	-webkit-animation: o-p-k_fadeIn 2s ease 1.1s 1 forwards;
	animation: o-p-k_fadeIn 2s ease 1.1s 1 forwards;
}

.sp_hero-cont.show .txt p:nth-child(5) {
	-webkit-animation: o-p-k_fadeIn 2s ease 1.4s 1 forwards;
	animation: o-p-k_fadeIn 2s ease 1.1s 1 forwards;
}

.sp_hero-cont.show .txt p:nth-child(6) {
	-webkit-animation: o-p-k_fadeIn 2s ease 1.7s 1 forwards;
	animation: o-p-k_fadeIn 2s ease 1.1s 1 forwards;
}

.sp_hero-cont.show .txt p:nth-child(7) {
	-webkit-animation: o-p-k_fadeIn 2s ease 2s 1 forwards;
	animation: o-p-k_fadeIn 2s ease 1.1s 1 forwards;
}

.pc_hero {
	width: 100%;
	height: 100%;
	min-height: 600px;
}

#page_top {
	position: absolute;
	bottom: 0;
	color: var(--color-purple);
	font-style: 1.2rem;
}

.covid19 {
	margin: 187px auto 0;
	max-width: 750px;
	width: 80%;
	color: #008475;
	font-size: 1.4rem;
}

.covid19 dl {
	padding: 66px 80px 50px;
	text-align: center;
	border: 1px solid;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
}

.covid19 dt {
	font-size: 2.3rem;
	line-height: 1.6;
	padding-bottom: 20px;
}

.covid19 dd {
	text-align: left;
	line-height: 1.5;
	padding: 14px 10px 14px 28px;
	position: relative;
}

.covid19 dd::before {
	content: "」";
	position: absolute;
	display: block;
	left: 8px;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
	top: 8px;
	margin: auto;
	font-size: 2rem;
}

.covid19 dd::after {
	content: "";
	display: block;
	border: 1px solid;
	width: 20px;
	height: 20px;
	position: absolute;
	left: 0;
	top: 15px;
}

.news {
	max-width: 1096px;
	width: 80%;
	margin: 187px auto 207px;
	padding: 27px 70px;
}

.news .l-h-title__en {
	font-size: 3rem;
	letter-spacing: 0.25em;
}

.news .inner {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
}

.news__title {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-direction: column;
	flex-direction: column;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	width: 200px;
}

.news__box {
	color: #008475;
	font-size: 1.4rem;
	line-height: 1;
	width: calc(100% - 200px);
}

a.btn-more {
	display: inline-block;
	font-size: 1.4rem;
	margin-top: 2em;
	padding: 0.5em 1.5em;
	border: solid 1px var(--color-black);
	border-radius: 2em;
}

.news__box a {
	display: block;
}

.news__box a:hover {
	opacity: .7;
	-webkit-transform: translateX(10px);
	transform: translateX(10px);
}

.news__box__inner {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-ms-flex-direction: row;
	flex-direction: row;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	line-height: 1.6;
	padding: 25px 0px 25px 10px;
	color: var(--color-black);
}

.news__box__inner time {
	margin-right: 16px;
	color: var(--color-purple);
}

.news__box li+li {
	border-top: 1px solid var(--color-black);
}

.newsReview_wrap {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	margin: 130px auto 100px;
	max-width: 1096px;
	width: 80%;
}

.newsReview_wrap .news {
	width: 80%;
	margin: 0;
	max-width: 100%;
}

.newsReview_wrap .news .news__title {
	width: 170px;
}

.newsReview_wrap .news .news__box {
	width: calc(100% - 170px);
}

.newsReview_wrap .shinqcompass_review_widget {
	width: calc(40% - 20px);
}

.newsReview_wrap .shinqcompass_review_widget .shinqcompass_review_widget__arrow {
	width: 15px;
}

.concept {
	position: relative;
	margin-top: 0px;
}

.concept .hari_03 {
	position: absolute;
	right: 26%;
	bottom: -80px;
	z-index: 0;
	width: 270px;
	-webkit-animation: spin 40s linear infinite;
	animation: spin 40s linear infinite;
}

.concept .concept__inner {
	max-width: 1440px;
	width: 100%;
	margin: auto;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	position: relative;
}

.concept .concept__txt {
	display: block;
	max-width: 500px;
	/*  width: 50%; */
	position: absolute;
	top: 180px;
	left: -170px;
	z-index: 6;
}

.concept .concept__imgBox {
	width: 68%;
	z-index: 5;
	margin: 0 0 0 -15%;
	height: 100%;
}

.box2,
.box3 {
	padding-bottom: 150px;
}

.box2 .concept__imgBox {
	width: 60%;
}

.box2 .concept__txtBox {
	width: 46% !important;
}

.box2 .concept__txtBox__wrap {
	max-width: 670px !important;
}

.box3 .concept__imgBox {
	width: 46%;
}

.box3 .concept__txtBox {
	width: 60% !important;
}

.box3 .concept__txtBox__wrap {
	max-width: 670px !important;
	padding-left: 3em;
}

.box3 .concept__imgBox .row:nth-child(2) {
	justify-content: flex-start !important;
}

.concept .concept__imgBox .row:nth-child(2) {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	justify-content: flex-end;
	width: 100%;
	margin: 47px 0 0 auto;
}

.concept .concept__imgBox .row__item:nth-of-type(2) {
	margin: 0 0 0 45px;
}

.concept .concept__txtBox {
	width: 39%;
}

.concept .concept__txtBox__wrap {
	max-width: 460px;
}

.concept .concept__txtBox .en {
	display: inline-block;
	color: #F58C87;
	font-size: 2rem;
	margin: 87px 0 50px;
	letter-spacing: 0.25em;
}

.concept .concept__txtBox .jp {
	display: inline-block;
	color: var(--color-purple);
	font-size: 3.3rem;
	-webkit-font-smoothing: subpixel-antialiased;
	line-height: 1.9;
	letter-spacing: -0.01em;
	margin-bottom: 35px;
}

.concept .concept__txtBox .txt {
	font-size: 1.5rem;
	line-height: 2.1;
	letter-spacing: 0.03em;
	word-break: break-all;
	padding: 0 5% 0 0;
}

.concept .concept__txtBox .txt p+p {
	padding-top: 30px;
}

.greeting {
	padding: 0;
}

.greeting__inner {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	position: relative;
	/*  max-width: 1098px;*/
	max-width: 1230px;
	width: 93%;
	margin: 200px auto;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: reverse;
	-ms-flex-flow: row-reverse;
	flex-flow: row-reverse;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
}

.greeting__imgBox {
	max-width: 460px;
	/*
  max-width: 380px;
  width: 36%;
  height: 566px;
*/
}
.greeting__imgBox .sm, .concept__imgBox.sm {
	display: none;
}

.greeting__imgBox img {
	object-fit: contain;
	width: 100%;
}

.greeting__imgBox:before {
	content: "";
	display: none;
	height: inherit;
	background: #f6f6f6;
	margin: 40px 0 0 auto;
	width: 40%;
	position: absolute;
	right: 0;
}

.greeting__txtBox {
	max-width: 720px;
	width: 100%;
	padding-left: calc(100% * 0.07);
	padding-top: 0;
	padding-right: 60px;
}

.greeting__txtBox .en {
	display: inline-block;
	color: var(--color-purple);
	font-size: 2rem;
	margin: 0 0 50px;
	letter-spacing: 0.25em;
}

.greeting__txtBox .jp {
	display: inline-block;
	color: var(--color-purple);
	font-size: 3.3rem;
	-webkit-font-smoothing: subpixel-antialiased;
	line-height: 1.9;
	margin-bottom: 35px;
}

.greeting__txtBox .txt {
	font-size: 1.4rem;
	line-height: 2.25;
	letter-spacing: 0.03em;
	word-break: break-all;
	text-align: justify;
}

.greeting__director {
	position: relative;
	color: var(--color-purple);
	text-align: right;
	font-size: 2rem;
	font-weight: bold;
	padding-top: 66px;
	padding-right: 1.5em;
}

.greeting__director .name {
	padding: 0 0 0 17px;
}

.greeting__director .degree {
	display: block;
	font-weight: normal;
	font-size: 1.3rem;
	line-height: 1.7;
}

.menu .l-h-title,
.menu .l-h-title__border {
	max-width: 960px;
	width: 80%;
	margin: auto;
}

.menu__title__images {
	position: relative;
}

.menu__title__images_img:nth-child(1) {
	position: absolute;
	left: 0;
	bottom: 66px;
	width: calc(100% - 290px);
	height: 550px;
}

.menu__title__images_img:nth-child(1) img {
	-o-object-fit: cover;
	object-fit: cover;
	font-family: 'object-fit: cover;';
	width: 100%;
	height: 100%;
}

.menu__title__images_img:nth-child(2) {
	background: #f6f6f6;
	height: 560px;
	width: 670px;
	margin: 66px 0 0 auto;
}

.menu__inner {
	position: relative;
	padding: 96px 0 0 0;
}

.menu .hari_05 {
	position: absolute;
	right: 10%;
	top: 132px;
	z-index: 0;
	width: 280px;
	-webkit-animation: spin 45s linear infinite;
	animation: spin 45s linear infinite;
}

.menu__slider {
	max-width: 960px;
	width: 80%;
	margin: 75px auto 0;
}

.menu__slider .menu__slider__box {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	outline: none;
}

.menu__slider .slider__box__image {
	width: 40%;
	height: 520px;
}

.menu__slider .slider__box__image img {
	-o-object-fit: cover;
	object-fit: cover;
	font-family: 'object-fit: cover;';
	width: 100%;
	height: 100%;
}

.menu__slider .slider__box__cont {
	width: calc(60% - 70px);
	max-width: 510px;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-direction: column;
	flex-direction: column;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	padding-right: 15px;
}

.menu__slider .pickup {
	margin-bottom: 20px;
}

.menu__slider .pickup span {
	display: inline-block;
	color: var(--color-purple);
	border: 1px solid;
	font-size: 1.1rem;
	line-height: 1;
	padding: 2px;
}

.menu__slider .catch {
	color: #008475;
	font-size: 1.4rem;
	line-height: 1.6;
}

.menu__slider .title {
	color: #008475;
	font-size: 3.1rem;
	line-height: 1.3;
	margin: 7px 0 16px 0;
}

.menu__slider .txt {
	font-size: 1.5rem;
	line-height: 2.1;
}

.menu__slider .reason {
	display: inline-block;
	width: 100%;
	background: #ece5d1;
	color: #ad9a67;
	font-size: 1.1rem;
	font-weight: bold;
	padding: 10px 13px;
	margin: 10px 0 15px;
}

.menu__slider .reason span {
	display: inline-block;
	text-align: center;
	letter-spacing: 0.01em;
}

.menu__slider .reason span+span:before {
	display: inline-block;
	content: "／";
}

.menu__slider .menu_effect {
	margin: 42px 0 24px 0;
}

.menu__slider .effect_title {
	color: #008475;
	font-size: 1.6rem;
	line-height: 1;
	margin: 0 0 7px 0;
}

.menu__slider .effect_txt {
	font-size: 1.5rem;
	line-height: 1.8;
}

.menu__slider .o-c-btn__blank a,
.menu__slider .o-c-btn__menuBack a {
	width: 212px;
	font-size: 1.3rem;
}

.menu__slider .o-p-s-slide_arrow {
	position: absolute;
	top: 0;
	bottom: 0;
	margin: auto;
}

.menu__slider .o-p-s-slide_arrow.prev-arrow {
	left: -75px;
}

.menu__slider .o-p-s-slide_arrow.next-arrow {
	right: -75px;
}

.menu__slider .o-p-s-slide_dots li {
	display: inline-block;
	cursor: pointer;
	height: 1px;
	width: 26px;
	background: #b6d7d2;
	position: relative;
}

.menu__slider .o-p-s-slide_dots li+li {
	margin-left: 2px;
}

.menu__slider .o-p-s-slide_dots li button {
	display: none;
}

.menu__slider .o-p-s-slide_dots li.slick-active:after {
	content: "";
	position: absolute;
	height: inherit;
	width: 0%;
	display: block;
	top: 0;
	background: #008475;
	-webkit-animation-name: o-p-k_dots_change;
	animation-name: o-p-k_dots_change;
	-webkit-animation-duration: 4s;
	animation-duration: 4s;
	-webkit-animation-timing-function: linear;
	animation-timing-function: linear;
	-webkit-animation-iteration-count: 1;
	animation-iteration-count: 1;
	-webkit-animation-fill-mode: forwards;
	animation-fill-mode: forwards;
}

section.facility {
	position: relative;
}

section.facility .hari_06 {
	position: absolute;
	bottom: 110px;
	left: -190px;
	z-index: 3;
	width: 434px;
	-webkit-animation: spin 40s linear infinite;
	animation: spin 40s linear infinite;
}

section.facility .l-h-title__border {
	max-width: 960px;
	width: 80%;
	margin: auto;
	padding: 330px 0 290px 0;
}

section.facility .l-h-title__border:after {
	display: none;
}

section.facility .facility__slider__wrap {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: reverse;
	-ms-flex-flow: row-reverse;
	flex-flow: row-reverse;
	position: relative;
}

section.facility .inner:nth-child(1) {
	position: absolute;
	right: 0;
	top: -184px;
	width: 57%;
	z-index: 3;
}

section.facility .slider__images {
	top: 0;
	z-index: 1;
}

section.facility .slider__images:hover .o-p-s-slide_dots .slick-active:after {
	-webkit-animation-play-state: paused;
	animation-play-state: paused;
}

section.facility .slider__images .o-p-s-slide_dots {
	position: absolute;
	bottom: -22px;
}

section.facility .slider__images .image_box {
	margin: 0 0 0 5px;
	outline: none;
	max-width: 590px;
	width: 100%;
}

section.facility .slider__images .image_box img {
	-o-object-fit: cover;
	object-fit: cover;
	font-family: 'object-fit: cover;';
	width: 100%;
	height: 100%;
}

section.facility .o-p-s-slide_arrow {
	position: absolute;
	bottom: -74px;
}

section.facility .o-p-s-slide_arrow.prev-arrow {
	right: 119px;
}

section.facility .o-p-s-slide_arrow.next-arrow {
	right: 40px;
}

section.facility .inner:nth-child(2) {
	max-width: 960px;
	width: 80%;
	margin: auto;
	position: relative;
	z-index: 1;
}

section.facility .slider__cont {
	width: 777px;
}

section.facility .slider__cont .box {
	outline: none;
	color: #fff;
	font-size: 1.4rem;
	line-height: 2;
	padding: 92px 0 0 0;
}

section.facility .slider__cont .box>div {
	width: 320px;
}

section.facility .slider__cont .box .title {
	font-size: 2.4rem;
	line-height: 1;
	padding: 0 0 34px 0;
}

section.facility .o-p-s-slide_dots {
	position: absolute;
	bottom: 30px;
	left: 11px;
}

section.facility .o-p-s-slide_dots li {
	display: inline-block;
	cursor: pointer;
	height: 1px;
	width: 26px;
	background: #58aba1;
	position: relative;
}

section.facility .o-p-s-slide_dots li+li {
	margin-left: 2px;
}

section.facility .o-p-s-slide_dots li:last-child {
	display: none;
}

section.facility .o-p-s-slide_dots li button {
	display: none;
}

section.facility .o-p-s-slide_dots li.slick-active:after {
	content: "";
	position: absolute;
	height: inherit;
	width: 0%;
	display: block;
	top: 0;
	background: #004f46;
	-webkit-animation-name: o-p-k_dots_change;
	animation-name: o-p-k_dots_change;
	-webkit-animation-duration: 4s;
	animation-duration: 4s;
	-webkit-animation-timing-function: linear;
	animation-timing-function: linear;
	-webkit-animation-iteration-count: 1;
	animation-iteration-count: 1;
	-webkit-animation-fill-mode: forwards;
	animation-fill-mode: forwards;
}

section.facility .beta_wrap {
	position: absolute;
	width: 60%;
	left: 5%;
}

section.facility .beta_wrap .beta_item {
	background: #006f62;
	width: 88%;
	height: 350px;
}

.information {
	margin-top: 88px;
	padding-top: 288px;
}

.information .l-h-title__border {
	max-width: 960px;
	width: 80%;
	margin: auto;
}

.information .l-h-title__border:after {
	display: none;
}

.information .hari_04 {
	position: absolute;
	right: 25%;
	top: -196px;
	z-index: 0;
	width: 434px;
	-webkit-animation: spin 45s linear infinite;
	animation: spin 45s linear infinite;
}

.information__inner {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	position: relative;
	max-width: 1100px;
	width: 90%;
	margin: 120px auto 65px;
}

.information .txtBox {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	max-width: 550px;
	width: 50%;
	min-height: 535px;
	font-size: 1.4rem;
	line-height: 1.8;
	background: #f6f6f6;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-direction: column;
	flex-direction: column;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
}

.information .txtBox .wrap {
	padding: 0 0 0 13%;
	position: relative;
	z-index: 2;
}

.information .txtBox .logo {
	display: inline-block;
	max-width: 250px;
	padding: 0 0 30px 0;
}

.information .txtBox address span+span {
	margin-left: 20px;
}

.information .txtBox strong {
	font-weight: bold;
	display: block;
}

.information .txtBox p+p {
	padding-top: 10px;
}

.information .o-c-btn__blank a,
.information .o-c-btn__menuBack a {
	width: 212px;
	padding: 14px 0px;
	margin-top: 27px;
}

.information .mapBox {
	position: absolute;
	top: 65px;
	right: 0;
	z-index: 2;
	height: 100%;
	width: 50%;
}

.information .mapBox iframe {
	width: 100%;
	height: 100%;
}

.mapBox img {
	width: 90px;
	height: auto;
}

.booking {
	padding-top: 220px;
	padding-bottom: 120px;
}

.booking .booking__inner {
	padding: 40px 0 0 0;
}

.booking__about {
	letter-spacing: 0.1em;
}

.booking__about,
.booking__houes {
	text-align: center;
	font-size: 1.5rem;
	line-height: 2.3;
	color: #008475;
	margin: auto;
	width: 80%;
}

.booking__wrap {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	max-width: 960px;
	width: 80%;
	margin: auto;
	padding: 70px 0 50px;
}

.booking__wrap .telBox,
.booking__wrap .webBox {
	width: 50%;
	text-align: center;
	color: #008475;
}

.booking__wrap .telBox a,
.booking__wrap .webBox a {
	width: 100%;
	color: inherit;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-direction: column;
	flex-direction: column;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	height: 205px;
	font-weight: 400;
}

.booking__wrap .telBox .en,
.booking__wrap .webBox .en {
	letter-spacing: 0.1em;
}

.booking__wrap .telBox .icon,
.booking__wrap .webBox .icon {
	display: inline-block;
	padding-bottom: 20px;
}

.booking__wrap .telBox {
	background: #f3f3f3;
	font-size: 3.4rem;
}

.booking__wrap .telBox .icon {
	width: 40px;
}

.booking__wrap .webBox {
	font-weight: 400;
	background: #e6edeb;
	font-size: 2.1rem;
}

.booking__wrap .webBox .icon {
	width: 42px;
}

.booking__wrap .webBox .blank {
	display: inline-block;
	width: 17px;
	vertical-align: middle;
	margin: 1px 0px 0 7px;
}

.under-head {
	position: relative;
}

.under-head:before {
	content: "";
	display: block;
	height: 315px;
	width: 100%;
	background: var(--color-lightpurple);
	position: absolute;
	z-index: -1;
}

.under-head__img {
	width: calc(100% - 120px);
	height: 400px;
	margin: auto;
	padding-top: 60px;
}

.under-head__img img {
	-o-object-fit: cover;
	object-fit: cover;
	font-family: 'object-fit: cover;';
	width: 100%;
	height: 100%;
}

.under-head .l-h-title,
.under-head .l-h-title__border {
	max-width: 1100px;
	width: calc(100% - 120px);
	margin: 0 auto 90px;
	padding: 110px 0 0 0;
}

.under-head .hari_01 {
	position: absolute;
	right: 40px;
	bottom: 130px;
	z-index: 0;
	width: 270px;
	-webkit-animation: spin 70s linear infinite;
	animation: spin 70s linear infinite;
}

.under-head .hari_02.pll {
	position: absolute;
	left: -60px;
	top: -70px;
	z-index: 3;
	width: 297px;
	-webkit-animation: spin 200s linear infinite;
	animation: spin 200s linear infinite;
}

.news-index {
	margin: auto;
	max-width: 1100px;
	width: calc(100% - 120px);
}

.news-wrap {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	margin: auto;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
}

.news-wrap__contents {
	width: calc(100% - 335px - 93px);
	margin: 0 0 150px 0;
}

.news-wrap__contents li {
	margin: 0 0 100px 0;
}

.news-wrap__contents li .title {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	color: #008475;
	font-size: 2.8rem;
	-webkit-box-align: baseline;
	-ms-flex-align: baseline;
	align-items: baseline;
	border-bottom: 2px solid;
	margin: 0 0 30px 0;
	padding: 0 0 10px 0;
	-webkit-box-align: end;
	-ms-flex-align: end;
	align-items: flex-end;
}

.news-wrap__contents li .title h1 {
	width: calc(100% - 100px);
	line-height: 1.5;
}

.news-wrap__contents li .title h2 {
	line-height: 1.6;
	letter-spacing: 0.06em;
	-webkit-font-smoothing: subpixel-antialiased;
	width: calc(100% - 100px);
}

.news-wrap__contents li .title .day-cat {
	font-size: 1.4rem;
	line-height: 1;
	font-weight: bold;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
}

.news-wrap__contents li .title .day-cat:before {
	content: "";
	display: inline-block;
	width: 14px;
	height: 14px;
	vertical-align: middle;
	margin: 0 9px 1px 0;
	background: url(../../common/img/news/icon-news_date.png) no-repeat center/cover;
}

.news-wrap__contents li .text-area {
	font-size: 1.4rem;
	line-height: 2.4;
}

.news-wrap__contents li p+p {
	padding-top: 20px;
}

.news-wrap__sidebar {
	width: 335px;
	color: #008475;
}

.news-wrap__sidebar a {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	color: inherit;
}

.news-wrap__sidebar .thumb {
	width: 80px;
	height: 80px;
	margin: 0 20px 0 0;
}

.news-wrap__sidebar .thumb img {
	-o-object-fit: cover;
	object-fit: cover;
	font-family: 'object-fit: cover;';
	width: 100%;
	height: 100%;
}

.news-wrap__sidebar .title {
	width: calc(100% - 100px);
	font-size: 1.2rem;
	line-height: 1.6;
}

.news-wrap__sidebar time {
	display: block;
	color: #9a9a9a;
	font-size: 1rem;
}

.news-wrap__sidebar h3 {
	font-size: 1.7rem;
	line-height: 1;
	font-weight: 600;
	letter-spacing: 0.2em;
	padding: 0 0 25px 0;
}

.news-wrap__sidebar .inner {
	background: #f6f6f6;
	color: #008475;
	padding: 57px 42px;
	margin-bottom: 80px;
}

.news-wrap .latest_topics li+li {
	padding-top: 20px;
}

.news-wrap .archives {
	padding-top: 50px;
}

.news-wrap .archives li+li {
	padding-top: 15px;
}

.news-wrap .archives a {
	font-size: 1.3rem;
}

.news-wrap .archives a:before {
	content: "-";
	display: inline-block;
}

.p-n-post_style a {
	color: #008475;
	text-decoration: underline;
}

.navigation-index {
	width: 100%;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	color: #008475;
	position: relative;
}

.navigation-index .wp-pagenavi {
	width: 100%;
	text-align: center;
}

.navigation-index .wp-pagenavi *:not(.nextpostslink):not(.previouspostslink) {
	margin-right: 15px;
}

.navigation-index a,
.navigation-index span {
	display: inline-block;
	border: 1px solid;
	font-size: 1.4rem;
	line-height: 1;
	font-weight: 400;
	color: inherit;
	padding: 9px 10px;
}

.navigation-index .current {
	color: #fff;
	background: #008475;
	border-color: #008475;
}

.navigation-index .nextpostslink {
	position: absolute;
	right: 0;
}

.navigation-index .previouspostslink {
	position: absolute;
	left: 0;
}

.navigation-index .toppostslink {
	margin: auto;
}

.p-notFound {
	font-size: 1.4rem;
	line-height: 2.4;
}

.p-notFound .wrap {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	width: 100%;
	-webkit-box-pack: left;
	-ms-flex-pack: left;
	justify-content: left;
	margin-top: 20px;
}

.p-notFound .o-c-btn {
	width: 40%;
}

.p-notFound .o-c-btn+.o-c-btn {
	margin-left: 20px;
}