.u-font__noto {
	font-family: "Zen Old Mincho", serif !important;
}

.u-font__rbt {
	font-family: "Cormorant Garamond", serif !important;
}

html {
	scroll-behavior: smooth;
}

/* スクロールバーを非表示にする */
/* 
::-webkit-scrollbar {
	display: none;
} */

/* Firefox用 */

/* スクロールバーを非表示にする */

/* html {
	scrollbar-width: none;
} */

.image_wrap{
    display: flex; /* Flexbox を使用して要素を並べる */
    flex-direction: column; /* 縦方向に並べる */
    align-items: flex-end; /* 右揃えにする */
}

.p-message__img {
    margin-bottom: 8px; /* 上に8pxの余白を追加 */
    margin-left: auto; /* 右揃えにするために追加 */
}

.name_text{
	font-size: 15px;
}

@media (max-width: 768px) {
	.name_text {
	  display: none;
	}
  }

body {
	background: #ffffff;
	scroll-behavior: smooth;
	scroll-padding-top: calc(90px + 0.625rem);
	scrollbar-width: none;
	color: #171717;
	font-weight: 400;
	font-size: 16px;
	font-family: "Zen Old Mincho", serif;
}

body.is-active {
	overflow: hidden;
}

body::-webkit-scrollbar {
	display: none;
}

a {
	transition: 0.3s;
	color: #171717;
	text-decoration: none;
}

picture,
img {
	display: inline-block;
}

img {
	width: 100%;
	height: 100%;
	-o-object-fit: cover;
	object-fit: cover;
}

.loaded {
	visibility: hidden;
	opacity: 0;
}

.body-hidden-initially {
	visibility: hidden;
}

*,
*::before,
*::after {
	box-sizing: border-box;
}

html,
body,
h1,
h2,
h3,
h4,
h5,
h6,
ul,
ol,
dl,
li,
dt,
dd,
p,
div,
span,
img,
a,
table,
tr,
th,
td,
small,
button,
time,
figure {
	vertical-align: baseline;
	margin: 0;
	margin: 0;
	border: 0;
	padding: 0;
	font-weight: inherit;
}

html {
	line-height: 1;
}

ol,
ul {
	list-style: none;
}

li,
dd {
	list-style-type: none;
}

header,
footer,
nav,
section,
article,
main,
aside,
figure,
figcaption {
	display: block;
}

img {
	vertical-align: bottom;
	border: none;
}

.l-drawer__icon {
	position: fixed;
	top: 38.5px;
	right: 62.4px;
	z-index: 90;
	transition: all 0.5s ease 0s;
	cursor: pointer;
	background: transparent;
	width: 44px;
	height: 24px;
}

.l-drawer__icon.is-active .bar1 {
	top: 5px;
	transform: rotate(-30deg);
}

.l-drawer__icon.is-active .bar2 {
	display: none;
}

.l-drawer__icon.is-active .bar3 {
	top: 5px;
	transform: rotate(30deg);
}

.l-drawer__icon__bars {
	display: block;
	position: relative;
	width: 40px;
	height: 20px;
}

.bar {
	position: absolute;
	top: 0;
	left: 0;
	transition: all 0.5s ease;
	background: #B2B2B2;
	width: 44px;
	height: 1px;
}

.bar1 {
	top: 0;
}

.bar2 {
	top: 11px;
}

.bar3 {
	top: 22px;
}

.l-drawer__title {
	font-weight: initial;
	font-size: 40px;
	font-family: "Cormorant Garamond", serif;
}

.l-drawer__title::before {
	left: -30%;
	width: 70px;
	height: 70px;
}

.l-drawer__content {
	position: fixed;
	top: 0;
	right: 0;
	transform: translateY(-105%);
	z-index: 89;
	transition: transform 0.5s ease 0s;
	background: #fff;
	padding-top: 10.25rem;
	width: 100%;
	height: 100%;
	overflow-y: scroll;
	color: #9F9F9F;
	text-align: center;
}

.l-drawer__content.is-active {
	transform: translateY(0);
}

.l-drawer__content__items {
	margin: 48px auto 0;
	margin-top: 5.625rem;
	max-width: 800px;
}

.l-drawer__content__item {
	position: relative;
	padding: 15px 0;
}

.l-drawer__content__item::before {
	position: absolute;
	top: 0;
	left: 50%;
	transform: translateX(-50%);
	background: url(../img/menu_line.png) no-repeat center center/cover;
	width: 100%;
	height: 1px;
	content: "";
}

.l-drawer__content__item a {
	display: inline-block;
	position: relative;
	transition: all 0.3s ease;
	padding: 0.9375rem 0;
	width: -moz-fit-content;
	width: fit-content;
	color: #9F9F9F;
	font-size: 16px;
	line-height: 0.8;
	font-family: "Cormorant Garamond", serif;
}

.l-drawer__content__item a span {
	font-size: 1.03125rem;
	font-family: "Zen Old Mincho", serif;
}

.l-drawer__content__item.--en {
	font-weight: 700;
	font-size: 21px;
	font-family: "Cormorant Garamond", serif;
}

.l-drawer__links {
	display: flex;
	flex-direction: column;
	margin: auto;
	width: -moz-fit-content;
	width: fit-content;
}

.l-drawer__links .l-drawer__btn {
	position: relative;
	padding-left: 2.1875rem;
}

.l-drawer__links .l-drawer__btn::before {
	position: absolute;
	top: 50%;
	left: 0;
	transform: translateY(-50%);
	background: url(../img/pdf_icon.svg) no-repeat center center/cover;
	width: 15px;
	height: 15px;
	content: "";
}

.l-main {
	min-height: calc(100vh - 240px);
	font-family: "Zen Old Mincho", serif;
}

.l-main.l-thanks {
	position: relative;
}

.l-main.l-thanks::before {
	position: absolute;
	bottom: 0;
	left: 0;
	background: url(../img/sky_bg.jpg) no-repeat top center/cover;
	width: 100%;
	height: 100%;
	content: "";
}

.l-inner {
	position: relative;
	margin: 0 auto;
	padding: 0 2.5rem;
	width: 100%;
	max-width: 1120px;
	height: inherit;
}

.copyright {
	padding-bottom: 40px;
	color: #171717;
	font-weight: bold;
	font-size: 16px;
	text-align: center;
}

.l-section--bg {
	background: url(../img/message_bg.jpg) no-repeat bottom center/cover;
}

.l-section--bg.--message_bg {
	background: url(../img/message_bg.jpg) no-repeat top center/cover;
}

.--overflow {
	overflow-x: hidden;
}

.fixed-background {
	position: fixed;
	top: 0;
	left: 0;
	background-position: center;
	background-size: cover;
	width: 100%;
	height: 100%;
}

.section {
	height: 100vh;
}

.l-nav {
	position: fixed;
	top: 9.5625rem;
	right: 16.3%;
	opacity: 1;
	z-index: 50;
	transition: all 0.3s ease;
	padding-left: 1.5625rem;
}

.l-nav::before {
	position: absolute;
	top: 50%;
	left: 0;
	transform: translateY(-50%);
	background: rgba(51, 51, 51, 0.8);
	width: 0.5px;
	height: 92%;
	content: "";
}

.l-nav.is-hidden {
	opacity: 0;
	transition: all 0.3s ease;
}

.l-nav__item {
	position: relative;
}

.l-nav__item:hover a {
	color: #E44175;
}

.l-nav__item::before {
	position: absolute;
	top: 50%;
	left: -1.625rem;
	transform: translateY(-50%);
	border-radius: 50%;
	background: #333;
	width: 3px;
	height: 3px;
	content: "";
}

.l-nav__item::after {
	position: absolute;
	top: 64%;
	left: -45%;
	transform: translateY(-50%);
	opacity: 0;
	transition: all 0.6s ease;
	background: url(../img/menu_circle.svg) no-repeat center center/cover;
	width: 34px;
	height: 36px;
	content: "";
}

.l-nav__item.is-active::after {
	opacity: 1;
}

.l-nav__item a {
	display: inline-block;
	transition: all 0.3s ease;
	font-style: italic;
	font-size: 16px;
	font-family: "Cormorant Garamond", serif;
}

.l-nav__item + .l-nav__item {
	margin-top: 20px;
}

.js-slideIn {
	overflow: hidden;
}

.js-slideIn .js-slideIn-element {
	display: inline-block;
	transform: translateY(120%);
}

.js-fadeIn-element2 {
	visibility: hidden;
	opacity: 0;
}

.last_slide {
	position: fixed;
	top: 0;
	left: 0;
}

.bg-fix-section {
	height: 100dvh;
	height: 100vh;
}

.bg-fix-section.--vh50 {
	height: 50vh;
}

.bg-fix-section.--vh80 {
	height: 80vh;
}

.bg-fix-section.--vh30 {
	height: 30vh;
}

.fixed-background {
	position: fixed;
	top: 0;
	left: 0;
	z-index: -1;
	transition: all 0.6s ease;
	background: url(../img/bg_sky_color.jpg) no-repeat center center/cover;
	height: 100vh;
}

.fixed-background.--bg_white {
	transition: all 0.6s ease;
	background-color: rgba(255, 255, 255, 0.8);
	background-blend-mode: overlay;
}

.fixed-background.--bg_white2 {
	transition: all 0.6s ease;
	background-color: rgba(255, 255, 255, 0.6);
	background-blend-mode: overlay;
}

.fixed-background.--bg_none {
	transition: all 0.6s ease;
	background-color: rgba(255, 255, 255, 0);
	background-blend-mode: overlay;
}

.color-section-none {
	transition: all 0.3s ease;
}

.gap {
	height: 100vh;
}

.gap-img {
	background: url(../img/gap_img.png) no-repeat bottom -1px center/cover;
	height: 100vh;
}

.gap-white {
	background: url(../img/gap_white.png) no-repeat bottom -1px center/cover;
	height: 100vh;
}

.fixed {
	position: sticky; /* Safariの対応 */
	top: 0; /* ビューポートの上端からの距離 */
	z-index: 1000; /* 必要に応じて他のコンテンツより前に表示 */
}

.no-scroll {
	height: 100%;
	overflow: hidden !important;
}

.c-title {
	position: relative;
	border-radius: 50%;
	width: 279px;
	height: 279px;
}

.c-title.--line_pink {
	border: 2px solid #FDD2D3;
}

.c-title.--line_white {
	border: 2px solid #fff;
}

.c-title.--line_blue {
	border: 2px solid #A1B0D8;
}

.c-title.--line_yellow {
	border: 2px solid #FDE5A6;
}

.c-title.--color_black {
	color: #171717;
}

.c-title.--color_white {
	color: #fff;
}

.c-title__text--jp {
	position: absolute;
	top: 117px;
	left: 46%;
	font-weight: 700;
	font-size: 16px;
	font-family: "Zen Old Mincho", serif;
	letter-spacing: 0.3em;
	writing-mode: vertical-lr;
}

.c-title__text {
	display: inline-block;
	position: absolute;
	top: 54px;
	left: 46%;
	font-style: italic;
	font-size: 52px;
	font-family: "Cormorant Garamond", serif;
}

.c-title__padding {
	padding-left: 39px;
}

.c-title__information {
	position: relative;
}

.c-title__information.change-color .c-title__circle.--line_pink {
	border: 2px solid #FFF;
}

.c-title__information.change-color .c-title__textWrap {
	color: #fff;
}

.transition-class {
	opacity: 0; /* 透明度を下げるなど、消える際のエフェクトを指定 */
	transition: opacity 0.5s ease-out;
}

.c-title__circle {
	display: inline-block;
	position: absolute;
	top: 0;
	right: 0;
	border-radius: 50%;
	width: 279px;
	height: 279px;
}

.c-title__circle.--line_pink {
	transition: all 0.3s ease;
	border: 2px solid #FDD2D3;
}

.c-title__textWrap {
	position: relative;
	top: 4px;
	right: 143px;
	transition: all 0.3s ease;
}

.c-title__textWrap .c-title__text {
	left: -0.3125rem;
}

.c-title__textWrap .c-title__text--jp {
	left: -0.4375rem;
	font-size: 16px;
	line-height: 1.3;
	writing-mode: initial;
}

.c-title.--message {
	top: 0;
	left: 0.625rem;
}

.p-topFv_bg {
	background: url(../img/bg_black.jpg) no-repeat center center/cover;
}

.p-topFv {
	position: relative;
}

.p-topFv.--loading {
	position: fixed;
	top: 0;
	z-index: 100;
	z-index: 100;
	animation-duration: 1.5s; /* アニメーションの持続時間 */
	animation-delay: 5s;
	animation-fill-mode: forwards; /* アニメーション終了時に最終状態を保持 */
	animation-name: opacity_animation2; /* 定義したアニメーション名を指定 */
	width: 100%;
	height: 100vh;
}

.fv__textBlock {
	position: absolute;
	top: 43.7%;
	font-weight: 400;
}

.fv__text span {
	display: block;
	font-size: 20px;
}

.fv__text span + span {
	margin-top: 4.875rem;
}

.fV__buttonWrap {
	position: absolute;
	bottom: 34px;
	left: 50%;
	transform: translateX(-50%);
	opacity: 0;
	animation-duration: 1.5s; /* アニメーションの持続時間 */
	animation-delay: 3s;
	animation-fill-mode: forwards; /* アニメーション終了時に最終状態を保持 */
	animation-name: opacity_animation; /* 定義したアニメーション名を指定 */
}

.fv__button {
	position: relative;
	border: 1px solid #9F9F9F;
	border-radius: 50%;
	width: 231px;
	height: 231px;
}

.fv__button p {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	color: #9F9F9F;
	font-style: italic;
	font-size: 40px;
	font-family: "Cormorant Garamond", serif;
}

.p-tovFv2 {
	position: fixed;
	top: 0;
	z-index: 99;
	animation-duration: 1.5s; /* アニメーションの持続時間 */
	animation-delay: 8s;
	animation-fill-mode: forwards; /* アニメーション終了時に最終状態を保持 */
	animation-name: opacity_animation3; /* 定義したアニメーション名を指定 */
	background: #fff;
	width: 100%;
	height: 100vh;
}

.p-title__title.--position {
	position: fixed;
	bottom: 10.5%;
	width: 80.625rem;
}

.opacity_animation {
	opacity: 0;
	animation-duration: 1.5s; /* アニメーションの持続時間 */
	animation-fill-mode: forwards; /* アニメーション終了時に最終状態を保持 */
	animation-name: opacity_animation; /* 定義したアニメーション名を指定 */
}

.opacity_animation2 {
	opacity: 0;
	animation-duration: 1.5s; /* アニメーションの持続時間 */
	animation-delay: 1.5s;
	animation-fill-mode: forwards; /* アニメーション終了時に最終状態を保持 */
	animation-name: opacity_animation; /* 定義したアニメーション名を指定 */
}

.p-tovFv2--white {
	position: fixed;
	top: 0;
	left: 0;
	z-index: 99;
	transition: opacity 0.5s ease, visibility 0.5s;
	background: #fff;
	width: 100%;
	height: 100vh;
}

.p-tovFv2--color {
	transition: opacity 0.5s ease, visibility 0.5s;
	width: 100%;
	height: 100vh;
}

.p-title {
	height: 100vh;
}

.p-title__inner {
	margin: auto;
	width: 100%;
	max-width: 1300px;
}

.p-title__title {
	position: absolute;
	bottom: 10.5%;
	width: 80.625rem;
}

.p-title__title--fixed {
	position: fixed;
	bottom: 10.5%;
	left: 50%;
	transform: translateX(-50%);
	width: 80.625rem;
}

.p-information {
	padding-top: 8.875rem;
}

.p-information .l-inner {
	display: flex;
}

.p-information__title {
	position: absolute;
	right: 5%;
}

.p-information__title.fixed {
	position: fixed;
	top: 10%;
	right: 5%;
}

.p-information__content {
	margin-top: 14.6875rem;
}

.p-information__content.--first .p-information__text {
	font-size: 18px;
}

.p-information__text {
	font-weight: bold;
	font-size: 16px;
	line-height: 1.4444444444;
}

.p-information__text:nth-child(2) {
	margin-top: 49px;
}

.p-information__text:nth-child(3) {
	margin-top: 71px;
}

.p-information__text:nth-child(4) {
	margin-top: 71px;
}

.p-information__text:nth-child(5) {
	margin-top: 30px;
}

.p-information__textWrap {
	padding-left: 11.25rem;
}

.p-information__textWrap .p-information__text:nth-child(1) {
	margin-top: 74px;
}

.p-information__textWrap .p-information__text:nth-child(2) {
	margin-top: 20px;
}

.p-information__textWrap .p-information__text:nth-child(3) {
	margin-top: 20px;
}

.p-information__textWrap .p-information__text:nth-child(4) {
	margin-top: 60px;
}

.p-information__textWrap .p-information__text:nth-child(5) {
	margin-top: 30px;
}

.p-information__contentTitle {
	display: inline-block;
	position: relative;
	font-weight: bold;
	font-size: 18px;
}

.p-information__contentTitle::before {
	position: absolute;
	bottom: -7px;
	left: 0;
	background: url(../img/text_line.svg) no-repeat center center/contain;
	width: 100%;
	height: 1px;
	content: "";
}

.p-information__text.--mt60 {
	margin-top: 60px;
}

.bg_white {
	background: #fff;
}

.p-message {
	padding-top: 31vh;
}

.p-message__title_text {
	top: 79px;
	left: 43%;
	width: calc(100% + 100px);
}

.p-message__title_text .c-title__padding {
	padding-left: 60px;
	line-height: 1.6;
}

.p-message__title_text--jp {
	top: 1.875rem;
	left: 44%;
}

.p-message__firstContent {
	display: flex;
}

.p-message__textWrap {
	flex: 1;
	margin-top: 63px;
	font-weight: bold;
	line-height: 1.8125;
}

.p-message__text {
	text-align: left;
}

.p-message__links {
	margin-top: 25px;
	padding-left: 1.25rem;
}

.p-message__btn {
	display: inline-block;
	position: relative;
	padding: 0 30px 1px 11px;
}

.p-message__btn::before,
.p-message__btn::after {
	position: absolute;
	bottom: -1px;
	left: 0;
	transition: all 0.3s ease-in-out;
	width: 100%;
	height: 1px;
	content: "";
}

.p-message__btn::before {
	background: #707070;
}

.p-message__btn::after {
	background: #A1B0D8;
	width: 0;
}

.p-message__btn:hover .link_arrow::before {
	right: -1.5625rem;
}

.p-message__btn:hover::after {
	width: 100%;
}

.link_arrow {
	position: relative;
}

.link_arrow::before {
	position: absolute;
	top: 54%;
	right: -1.25rem;
	transform: translateY(-50%);
	transition: all 0.3s ease;
	background: url(../img/arrow.svg) no-repeat center center/cover;
	width: 6px;
	height: 10px;
	content: "";
}

.p-message__img {
	width: 21.6875rem;
}

.p-message__subTitle {
	font-weight: bold;
	font-size: 18px;
	line-height: 1.4444444444;
}

.p-message__messageTexts {
	position: relative;
	margin-top: 3.40625rem;
	padding-top: 10px;
	padding-left: 5.125rem;
	line-height: 1.8125;
}

.p-message__messageTexts::before {
	position: absolute;
	top: 0;
	left: 2.34375rem;
	background-color: #171717;
	width: 1px;
	height: 100%;
	content: "";
}

.p-message__content.--mt {
	margin-top: -7.0625rem;
}

.p-message__content + .p-message__content {
	margin-top: 8.03125rem;
}

.p-message__messageText + .p-message__messageText {
	margin-top: 2.1875rem;
}

.p-message__profile {
	margin-top: 23.4375rem;
	color: #fff;
	text-shadow: 0 3px 6px rgba(0, 0, 0, 0.2);
}

.p-message__profileTitle {
	position: relative;
	font-style: italic;
	font-size: 33px;
	font-family: "Cormorant Garamond", serif;
}

.p-message__profileTitle span {
	margin-left: 13px;
	font-size: 16px;
	font-family: "Zen Old Mincho", serif;
}

.p-message__profileTitle::before {
	position: absolute;
	bottom: -21.2px;
	left: -14.3125rem;
	background: url(../img/profile_line.svg) no-repeat center center/contain;
	width: 91%;
	height: 2.5px;
	content: "";
}

.p-message__profileTexts {
	margin-top: 3.25rem;
	width: 396px;
	font-weight: 300;
	line-height: 1.8125;
	font-family: "Zen Kaku Gothic New", sans-serif;
}

.p-message__profileText + .p-message__profileText {
	margin-top: 2.1875rem;
}

.p-message__profileDl {
	margin-top: 2.5625rem;
	font-style: italic;
	font-weight: 300;
	font-family: "Cormorant Garamond", serif;
}

.p-message__profileDl + .p-message__profileDl {
	margin-top: 0;
}

.p-message__profileDl {
	display: flex;
	align-items: baseline;
}

.p-message__profileDt {
	font-size: 33px;
}

.p-message__profileDd {
	margin-left: 25px;
	font-style: normal;
	font-family: "Zen Old Mincho", serif;
	font-family: "Zen Kaku Gothic New", sans-serif;
}

.p-company {
	position: relative;
	padding: 136px 0;
}

.p-company__title {
	font-weight: initial;
	font-size: 20.5px;
	line-height: 1.9512195122;
}

.p-company__content {
	background: #FBF9FA;
}

.p-company__inner {
	margin: auto;
	margin-top: 120px;
	padding: 104px 0 122px;
	max-width: 730px;
}

.p-company__info {
	margin-top: 89px;
	font-size: 16.5px;
	line-height: 2.4242424242;
}

.p-company__dl {
	display: flex;
	border-bottom: 1px solid #333;
	border-bottom: 1px solid rgba(51, 51, 51, 0.5);
	padding: 6px 0 8px;
}

.p-company__dt {
	width: 29.8%;
}

.p-company__dd {
	flex: 1;
}

.p-company__dd.line-height--small {
	padding: 6px 0;
	line-height: 1.5151515152;
}

.p-contact {
	position: relative;
	margin-top: 22.5rem;
	padding-bottom: 14.5rem;
}

.p-contact .c-title {
	position: absolute;
	top: 62px;
	right: -6%;
	z-index: 10;
	width: 265px;
	height: 265px;
}

.p-contact .c-title .c-title__text--jp {
	top: 143px;
	left: 19px;
	writing-mode: lr;
}

.p-contact .c-title .c-title__text {
	top: 93px;
	left: -46px;
}

.p-contact .l-inner {
	padding: 0 1.1875rem 0 0.75rem;
}

.l-thanks .p-contact {
	height: 80vh;
}

.l-thanks .p-contact::before {
	display: none;
}

.p-contact__title {
	margin: auto;
	padding: 0 23px;
}

.p-contact__title--thanks {
	margin: auto;
	padding: 0 23px;
}

.p-contact___text {
	font-size: 16.5px;
	line-height: 2.4242424242;
	text-align: center;
}

.p-contact__bg {
	position: relative;
	margin: auto;
	border-radius: 5px 5px 10px 10px;
	background: rgba(255, 255, 255, 0.9);
	padding: 16rem 0 11.875rem;
	max-width: 1020px;
}

.p-contact__bg::before {
	position: absolute;
	top: -98px;
	left: 0;
	background: url(../img/contact_text.png) no-repeat bottom center/contain;
	width: 100%;
	height: 101px;
	content: "";
}

.p-contact__formWrapper {
	margin: 0 auto 0;
	max-width: 628px;
}

.p-contact__text {
	line-height: 1.875;
}

.p-contact__text.--thanks {
	text-align: center;
}

.p-contact__form {
	margin-top: 46px;
}

.p-contact__row + .p-contact__row {
	margin-top: 36px;
}

.p-contact__name {
	font-size: 16.5px;
	line-height: 1.8181818182;
}

.is-requird {
	margin-left: 7px;
	color: #7185CC;
	font-weight: bold;
	font-size: 14.5px;
}

.p-contact__data {
	margin-top: 9px;
}

input[type=text],
input[type=email],
input[type=tel],
textarea {
	outline: none;
	border: 1px solid #707070;
	border-radius: 5px;
	background: #FCFCFC;
	padding: 8px 20px;
	width: 100%;
	height: auto;
	line-height: 1.5;
	font-family: "Zen Old Mincho", serif;
}

input[type=text]:focus,
input[type=email]:focus,
input[type=tel]:focus,
textarea:focus {
	outline: 1px solid #171717;
}

input[type=text]::-moz-placeholder,
input[type=email]::-moz-placeholder,
input[type=tel]::-moz-placeholder,
textarea::-moz-placeholder {
	color: #9f9f9f;
}

input[type=text]::placeholder,
input[type=email]::placeholder,
input[type=tel]::placeholder,
textarea::placeholder {
	color: #9f9f9f;
}

textarea {
	height: 382px;
}

.p-contact__row--privacy {
	margin-top: 36px;
}

.p-contact__privacy {
	font-size: 16.5px;
	line-height: 1.8181818182;
}

.p-contact__privacy a {
	display: inline-block;
	position: relative;
	transition: all 0.3s ease;
}

.p-contact__privacy a:hover {
	color: #A1B0D8;
}

.p-contact__privacy a:hover::before {
	background: #A1B0D8;
}

.p-contact__privacy a::before {
	position: absolute;
	bottom: 3px;
	left: 0;
	background: #171717;
	width: 100%;
	height: 1px;
	content: "";
}

.p-contact__button {
	display: flex;
	margin: 40px auto 0;
}

.p-contact__button .button_text {
	padding-left: 0;
	width: 100%;
	height: 66px;
}

.p-contact__button input[type=submit] {
	transition: all 0.3s ease;
	cursor: pointer;
	border: none;
	border-radius: 5px;
	background: #333;
	width: inherit;
	height: inherit;
	color: #ffffff;
	font-size: 20.5px;
	font-family: "Zen Old Mincho", serif;
}

.p-contact__button input[type=submit]:hover {
	background: #7185CC;
}

.page-top {
	position: absolute;
	right: 6.5%;
	bottom: -3.8%;
	visibility: hidden;
	opacity: 0;
	z-index: 10;
	transition: all 0.3s ease;
	background: url(../img/page_top.svg) no-repeat center center/cover;
	width: 3.25rem;
	height: 3.25rem;
}

.page-top img {
	-o-object-fit: contain;
	object-fit: contain;
}

.page-top.is-active {
	visibility: visible;
	opacity: 1;
}

.confirmation__form {
	padding: 12.5rem 0;
}

.reserve-confirmation-ttl {
	margin-bottom: 1.875rem;
	font-size: 1.5rem;
	text-align: center;
}

.confirm-btn__wrapper {
	display: flex;
	justify-content: space-evenly;
	margin-top: 3.75rem;
}

.reserve__button {
	transition: all 0.3s ease;
	border: 1px solid #171717;
	background: #171717;
	padding: 1.25rem;
	width: 12.5rem;
	height: auto;
	color: #ffffff;
	font-size: 1.25rem;
}

.reserve__button.prev {
	border: 1px solid #878787;
	background: #878787;
}

.error {
	display: inline-block;
	box-sizing: border-box;
	padding: 0;
	width: 100%;
	color: red;
	font-size: 90%;
}

.error::before {
	display: none;
}

.p-privacy {
	position: relative;
	background: url(../img/sky_bg.jpg) no-repeat bottom center/cover;
	padding: 0 2.8125rem;
}

.privacy__inner {
	background: rgba(255, 255, 255, 0.9);
	padding-top: 28.625rem;
}

.p-privacy__formWrapper {
	margin: auto;
	width: 100%;
	max-width: 56.25rem;
}

.privacy__copyright {
	margin-top: 14.5rem;
}

.l-thanks .p-privacy::before {
	display: none;
}

.p-privacy__title {
	position: absolute;
	top: 124px;
	right: -4.125rem;
}

.p-privacy__title .c-title__text {
	top: 50%;
	left: -54%;
	transform: translateY(-50%);
}

.p-privacy__title .c-title__text--jp {
	top: 67%;
	left: -23%;
	transform: translateY(-50%);
	font-size: 16px;
	writing-mode: initial;
}

.privacy-policy__item__title {
	font-weight: 600;
}

.privacy-policy__item {
	margin-top: 1.875rem;
	font-size: 16px;
}

.privacy-policy__item + .privacy-policy__item {
	margin-top: 1.875rem;
}

.privacy-policy__item__desc {
	margin-top: 0.625rem;
	font-size: 16px;
	line-height: 1.8181818182;
}

.p-privacy__button {
	display: flex;
	position: relative;
	justify-content: center;
	align-items: center;
	cursor: pointer;
	margin: 3.75rem auto 0;
	background: transparent;
	padding-bottom: 7px;
	padding-left: 1.5rem;
	color: #171717;
	font-size: 19px;
	font-family: "Zen Old Mincho", serif;
}

.p-privacy__button::before {
	position: absolute;
	top: 45%;
	left: 0;
	transform: translateY(-50%);
	background: url(../img/close_btn.png) no-repeat center center/contain;
	width: 1.275rem;
	height: 0.90625rem;
	content: "";
}

.p-privacy__button::after {
	position: absolute;
	bottom: 0;
	left: 50%;
	transform: translateX(-50%);
	background: url(../img/close_line.png) no-repeat center center/cover;
	width: 160%;
	height: 1px;
	content: "";
}

.p-thanks {
	position: relative;
	padding: 0 2.8125rem;
}

.p-thanks .c-title {
	position: absolute;
	top: 62px;
	right: -6%;
	z-index: 10;
	width: 265px;
	height: 265px;
}

.p-thanks .c-title .c-title__text--jp {
	top: 143px;
	left: 19px;
	writing-mode: lr;
}

.p-thanks .c-title .c-title__text {
	top: 93px;
	left: -46px;
}

.thanks__inner {
	display: flex;
	flex-direction: column;
	justify-content: space-around;
	background: rgba(255, 255, 255, 0.9);
	padding-top: 28.625rem;
	height: 100vh;
}

.p-thanks__formWrapper {
	margin: 0 auto;
	width: 100%;
	max-width: 56.25rem;
}

.thanks__copyright {
	margin-top: 14.5rem;
}

.l-thanks .p-thanks::before {
	display: none;
}

.p-thanks__title {
	position: absolute;
	top: 124px;
	right: -4.125rem;
}

.p-thanks__title .c-title__text {
	top: 50%;
	left: -31%;
	transform: translateY(-50%);
}

.p-thanks__title .c-title__text--jp {
	top: 61%;
	left: 4%;
	transform: translateY(-50%);
	font-size: 16px;
	letter-spacing: 0;
	writing-mode: initial;
}

.thanks-policy__item__title {
	font-weight: 600;
}

.thanks-policy__item {
	margin-top: 1.875rem;
	font-size: 16px;
}

.thanks-policy__item + .thanks-policy__item {
	margin-top: 1.875rem;
}

.thanks-policy__item__desc {
	margin-top: 0.625rem;
	font-size: 16px;
	line-height: 1.8181818182;
}

.p-thanks__totop {
	margin-inline: auto;
	width: -moz-fit-content;
	width: fit-content;
}

.p-thanks__link.p-privacy__button {
	padding-left: 0;
}

.p-thanks__link.p-privacy__button::before {
	display: none;
}

.u-animation__fadeInUp,
.u-animation__fadeInLeft,
.u-animation__fadeInRight,
.u-animation__fadeInLeftBig,
.u-animation__fadeInRightBig {
	opacity: 0;
}

/* フェードイン時に入るクラス */

.js-fadeInUp {
	animation-duration: 1s;
	animation-fill-mode: forwards;
	animation-name: fadeInUpContents;
}

.js-fadeInUp__delay--1s {
	animation-duration: 1s;
	animation-fill-mode: forwards;
	animation-name: fadeInUpContents;
}

.js-fadeInUp__delay--2s {
	animation-duration: 1s;
	animation-fill-mode: forwards;
	animation-name: fadeInUpContents;
}

.js-fadeInLeft {
	animation-duration: 1s;
	animation-fill-mode: forwards;
	animation-name: fadeInLeftContents;
}

.js-fadeInLeft__delay--1s {
	animation-duration: 1s;
	animation-fill-mode: forwards;
	animation-name: fadeInLeftContents;
}

.js-fadeInLeft__delay--2s {
	animation-duration: 1s;
	animation-fill-mode: forwards;
	animation-name: fadeInLeftContents;
}

.js-fadeInLeftBig {
	animation-duration: 1s;
	animation-fill-mode: forwards;
	animation-name: fadeInLeftBigContents;
}

.js-fadeInLeftBig__delay--1s {
	animation-duration: 1s;
	animation-fill-mode: forwards;
	animation-name: fadeInLeftBigContents;
}

.js-fadeInLeftBig__delay--2s {
	animation-duration: 1s;
	animation-fill-mode: forwards;
	animation-name: fadeInLeftBigContents;
}

.js-fadeInRight {
	animation-duration: 1s;
	animation-fill-mode: forwards;
	animation-name: fadeInRightContents;
}

.js-fadeInRight__delay--1s {
	animation-duration: 1s;
	animation-fill-mode: forwards;
	animation-name: fadeInRightContents;
}

.js-fadeInRight__delay--2s {
	animation-duration: 1s;
	animation-fill-mode: forwards;
	animation-name: fadeInRightContents;
}

.js-fadeInRightBig {
	animation-duration: 1s;
	animation-fill-mode: forwards;
	animation-name: fadeInRightBigContents;
}

.js-fadeInRightBig__delay--1s {
	animation-duration: 1s;
	animation-fill-mode: forwards;
	animation-name: fadeInRightBigContents;
}

.js-fadeInRightBig__delay--2s {
	animation-duration: 1s;
	animation-fill-mode: forwards;
	animation-name: fadeInRightBigContents;
}

.u-sp {
	display: none;
}

.u-pc {
	display: none !important;
}

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

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

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

.u-pointer__none {
	pointer-events: none !important;
}

.u-nowrap {
	white-space: nowrap;
}

@media (hover: hover) {

a:hover {
	cursor: pointer;
}

}

@media screen and (max-width: 649px) and (min-width: 500px) {

.p-message__firstContent {
	margin: auto;
	width: 80%;
}

}

@media screen and (max-width: 767px) and (min-width: 580px) {

body {
	font-size: 18px;
}

}

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

.p-message__firstContent {
	margin: auto;
	width: 65%;
}

}

@media (min-width: 769px) {

.l-drawer__icon:hover .bar {
	opacity: 0.6;
}

.l-drawer__content__item a:hover {
	color: #A1B0D8;
}

.p-title__title.--position {
	left: 50%;
	transform: translateX(-50%);
}

.p-title__title {
	left: 50%;
	transform: translateX(-50%);
}

.p-message__title_text--jp {
	top: 90px;
	left: 28%;
}

.p-message__links {
	display: flex;
	flex-wrap: wrap;
	gap: 0.625rem 2.1875rem;
	padding-left: 1.25rem;
	width: 70%;
}

.p-message__links.--sp {
	display: none;
}

.p-message__img {
	margin-top: 63px;
}

.p-message__profile {
	padding-left: 6.4375rem;
}

.p-company .c-title__text::before {
	left: -26%;
}

.p-contact__title {
	width: 77.8%;
}

.page-top:hover {
	background: url(../img/page_top_black.svg) no-repeat center center/cover;
}

.reserve__button:hover {
	border: 1px solid #E44175;
	background: #E44175;
}

.reserve__button.prev:hover {
	opacity: 0.7;
}

.p-privacy__button:hover {
	opacity: 0.7;
}

.js-fadeInUp__delay--1s {
	animation-delay: 1s;
}

.js-fadeInUp__delay--2s {
	animation-delay: 2s;
}

.js-fadeInLeft__delay--1s {
	animation-delay: 1s;
}

.js-fadeInLeft__delay--2s {
	animation-delay: 2s;
}

.js-fadeInLeftBig__delay--1s {
	animation-delay: 1s;
}

.js-fadeInLeftBig__delay--2s {
	animation-delay: 2s;
}

.js-fadeInRight__delay--1s {
	animation-delay: 1s;
}

.js-fadeInRight__delay--2s {
	animation-delay: 2s;
}

.js-fadeInRightBig__delay--1s {
	animation-delay: 1s;
}

.js-fadeInRightBig__delay--2s {
	animation-delay: 2s;
}

.u-pc {
	display: block !important;
}

.u-center--pc {
	text-align: center !important;
}

.u-left--pc {
	text-align: left !important;
}

.u-right--pc {
	text-align: right !important;
}

.u-pointer__none--pc {
	pointer-events: none !important;
}

.u-nowrap--pc {
	white-space: nowrap;
}

}

@media screen and (max-width: 905px) and (min-width: 769px) {

.display-none-tab {
	display: none;
}

}

@media screen and (max-width: 979px) and (min-width: 769px) {

.p-information__title {
	right: 20%;
}

.p-message__content.--mt {
	margin-top: 0;
}

}

@media screen and (max-width: 980px) and (min-width: 769px) {

.p-contact .c-title .c-title__text--jp {
	top: 117px;
}

.p-contact .c-title .c-title__text {
	top: 72px;
}

.p-thanks .c-title .c-title__text--jp {
	top: 117px;
}

.p-thanks .c-title .c-title__text {
	top: 72px;
}

}

@media screen and (max-width: 1119px) and (min-width: 769px) {

html {
	font-size: calc(1600 / 1120 * 1vw);
}

}

@media screen and (max-width: 1129px) and (min-width: 769px) {

.p-contact .c-title {
	right: 0.3125rem;
	width: 16.25rem;
	height: 16.25rem;
}

.p-thanks .c-title {
	right: 0.3125rem;
	width: 16.25rem;
	height: 16.25rem;
}

}

@media screen and (max-width: 1280px) and (min-width: 769px) {

.c-title {
	right: 20%;
	width: 17.4375rem;
	height: 17.4375rem;
}

.c-title__circle {
	width: 17.4375rem;
	height: 17.4375rem;
}

.c-title.--message {
	right: 0;
}

.p-title__title.--position {
	left: 50%;
	transform: translateX(-50%);
	width: 80%;
}

.p-title__title {
	left: 50%;
	transform: translateX(-50%);
	width: 80%;
}

.p-title__title--fixed {
	left: 50%;
	transform: translateX(-50%);
	width: 80%;
}

.p-information {
	padding-top: 2.5rem;
}

.p-message__firstContent {
	gap: 1.25rem;
}

.p-message__textWrap {
	flex: auto;
	width: 60%;
}

.p-message__profileTitle::before {
	left: -6.5625rem;
	width: 84%;
	height: 3px;
}

.p-contact__bg {
	width: 90%;
}

.p-privacy__title {
	right: -1.25rem;
}

.p-thanks__title {
	right: -1.25rem;
}

}

@media screen and (max-width: 1280px) and (min-width: 980px) {

.p-information__title {
	right: 15%;
}

.p-message__content.--mt {
	margin-top: -3.125rem;
	margin-top: 0;
}

}

@media screen and (max-width: 1280px) and (min-width: 1130px) {

.p-contact .c-title {
	right: 0;
	width: 16.5625rem;
	height: 16.5625rem;
}

.p-thanks .c-title {
	right: 0;
	width: 16.5625rem;
	height: 16.5625rem;
}

}

@media (max-width: 1700px) {

.l-nav {
	right: 5%;
}

}

@media (max-width: 1500px) {

.l-drawer__content__item a {
	padding: 0.625rem 0.625rem;
}

}

@media (max-width: 1380px) {

.l-nav {
	right: 3%;
}

}

@media (max-width: 1200px) {

.l-nav__item::after {
	left: -43%;
}

}

@media (max-width: 980px) {

.l-nav {
	right: 2%;
}

}

@media (max-width: 900px) {

.l-nav__item::after {
	left: -34%;
	width: 30px;
	height: 32px;
}

}

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

html {
	font-size: calc(1600 / 390 * 1vw);
}

body {
	scroll-padding-top: calc(90px + 0.625rem);
	font-size: 14px;
}

.l-drawer__icon {
	top: 1.21875rem;
	right: 0.9625rem;
	width: 1.444375rem;
	height: 0.914375rem;
}

.l-drawer__icon__bars {
	width: 23px;
}

.bar {
	width: 1.4375rem;
}

.bar2 {
	top: 0.45625rem;
}

.bar3 {
	top: 0.9125rem;
}

.l-drawer__title {
	padding-left: 0.625rem;
	font-size: 1.375rem;
}

.l-drawer__title::before {
	left: -23%;
	width: 2.5rem;
	height: 2.5rem;
}

.l-drawer__content {
	transform: translate(0, -105%);
	background: #fff;
	width: 100%;
}

.l-drawer__content__items {
	margin: 58px auto 0;
	margin-top: 1.875rem;
	max-width: 311px;
}

.l-drawer__content__item a {
	padding: 0.625rem 0;
	font-size: 0.875rem;
}

.l-drawer__content__item a span {
	font-size: 0.6875rem;
}

.l-drawer__content__item.--en {
	font-size: 0.875rem;
}

.l-main {
	min-height: calc(100vh - 240px);
}

.l-inner {
	padding: 0 2.8125rem;
	width: 100%;
	max-width: 100%;
}

.copyright {
	padding-bottom: 20px;
	font-size: 8px;
}

.l-section--bg {
	background: white url(../img/message_bg_sp_top.jpg) no-repeat top center/contain;
}

.l-section--bg {
	position: relative;
	z-index: 1;
}

.l-section--bg::after {
	position: absolute;
	bottom: 0;
	left: 0;
	z-index: -2;
	background: url(../img/message_bg_sp_bottom.jpg) no-repeat top center/cover;
	width: 100%;
	height: 60%;
	content: "";
}

.l-section--bg.--message_bg {
	background: url(../img/message_bg_sp_top.jpg) no-repeat top center/contain;
}

.l-section--bg.--message_bg {
	position: relative;
	z-index: 1;
}

.l-section--bg.--message_bg::after {
	position: absolute;
	bottom: 0;
	left: 0;
	z-index: -2;
	background: url(../img/message_bg_sp_bottom.jpg) no-repeat bottom 20% center/cover;
	width: 100%;
	height: 80%;
	content: "";
}

.l-nav {
	display: none;
}

.bg-fix-section.--vh50.--SPvh100 {
	height: 100vh;
}

.fixed-background {
	background: url(../img/bg_sky_color_sp.png) no-repeat center center/cover;
}

.gap-img {
	background: url(../img/gap_img_sp.png) no-repeat bottom -1px center/contain;
}

.c-title.--line_pink {
	border: 1.5px solid #FDD2D3;
}

.c-title.--line_white {
	border: 1.5px solid #fff;
}

.c-title.--line_blue {
	border: 1.5px solid #A1B0D8;
}

.c-title.--line_yellow {
	border: 1.5px solid #FDE5A6;
}

.c-title {
	top: 80px;
	width: 117px;
	height: 117px;
}

.c-title__text--jp {
	top: 0.875rem;
	left: 45%;
	font-size: 14px;
}

.c-title__text {
	top: 0.875rem;
	left: 62%;
	font-size: 21px;
}

.c-title__padding {
	padding-left: 0.8125rem;
}

.c-title__information.change-color .c-title__circle.--line_pink {
	border: 1.5px solid #FFF;
}

.c-title__circle.--line_pink {
	border: 1.5px solid #FDD2D3;
}

.c-title__circle {
	top: 80px;
	right: initial;
	left: 50%;
	transform: translateX(-50%);
	width: 117px;
	height: 117px;
}

.c-title__textWrap .c-title__text {
	left: 0.875rem;
}

.c-title__textWrap .c-title__text--jp {
	left: -5px;
	font-size: 14px;
	line-height: 1.3;
}

.c-title__textWrap {
	top: 80px;
	right: 50%;
}

.p-topFv.--pc {
	display: none;
}

.fv__textBlock {
	top: 36.8%;
	left: 50%;
	transform: translateX(-50%);
	width: 100%;
	line-height: 2.0714285714;
	text-align: center;
}

.fv__text span {
	font-size: 14px;
	text-align: center;
}

.fv__text span + span {
	margin-top: 2.8125rem;
}

.fV__buttonWrap {
	bottom: 13%;
}

.fv__button {
	width: 133px;
	height: 133px;
}

.fv__button p {
	font-size: 24px;
}

.p-tovFv2 .p-title__title {
	top: 50%;
}

.p-title__title.--position {
	top: 50%;
	bottom: initial;
	width: 12.40625rem;
	height: 5.350625rem;
}

.p-title__inner {
	padding: 0 2.8125rem;
}

.p-title__title {
	top: 50%;
	bottom: initial;
	width: 12.40625rem;
	height: 5.350625rem;
}

.p-title__title--fixed {
	top: 50%;
	bottom: initial;
	width: 12.40625rem;
	height: 5.350625rem;
}

.p-information {
	padding-top: 0rem;
}

.p-information__title {
	right: initial;
	left: 50%;
	transform: translateX(-50%);
}

.p-information__content {
	top: 39.5%;
	top: 28%;
}

.p-information__content.--first {
	top: 33%;
}

.p-information__content.--first .p-information__text {
	font-size: 14px;
}

.p-information__content.--second {
	top: 28%;
}

.p-information__text:nth-child(2) {
	margin-top: 0.8125rem;
}

.p-information__text:nth-child(3) {
	margin-top: 2.8125rem;
}

.p-information__text:nth-child(4) {
	margin-top: 3.0625rem;
}

.p-information__text:nth-child(5) {
	margin-top: 3.0625rem;
}

.p-information__text {
	font-size: 14px;
	line-height: 1.6;
}

.p-information__textWrap .p-information__text:nth-child(1) {
	margin-top: 3.9375rem;
}

.p-information__textWrap .p-information__text:nth-child(2) {
	margin-top: 0.75rem;
}

.p-information__textWrap .p-information__text:nth-child(3) {
	margin-top: 2.5rem;
}

.p-information__textWrap .p-information__text:nth-child(4) {
	margin-top: 2.5rem;
}

.p-information__textWrap {
	padding-left: 0;
}

.p-information__contentTitle {
	bottom: -0.375rem;
	font-size: 14px;
}

.p-message {
	padding-top: 300px;
}

.p-message__title_text .c-title__padding {
	padding-left: 1.5625rem;
}

.p-message__title_text {
	top: 0.875rem;
	left: 62%;
}

.p-message__firstContent {
	position: relative;
	align-items: end;
	margin-top: 1.25rem;
	text-align: left;
}

.p-message__firstContent .p-message__text {
	width: 60%;
	font-size: 13px;
	line-height: 1.5384615385;
}

.p-message__textWrap {
	margin-top: 135px;
}

.p-message__text.--sp {
	margin-top: 3.0625rem;
	font-size: 13.5px;
	line-height: 1.6;
	line-height: 2.1481481481;
	text-align: center;
}

.p-message__links.--sp {
	display: flex;
	flex-direction: column;
	align-items: center;
	margin-top: 2.125rem;
	padding-left: 0;
	font-size: 13.5px;
	line-height: 2.1481481481;
	text-align: center;
}

.p-message__btn {
	padding: 0 0 1px 0;
	width: 160px;
}

.p-message__btn::after {
	width: 100%;
}

.p-message__btn {
	border-bottom: 1px solid #A1B0D8;
}

.link_arrow {
	position: initial;
}

.link_arrow::before {
	top: 50%;
	right: 0.375rem;
	transform: translateY(-50%);
	background: url(../img/arrow_sp.svg) no-repeat center center/cover;
}

.p-message__btn + .p-message__btn {
	margin-top: 0.8125rem;
}

.p-message__img {
	position: absolute;
	top: -0.0625rem;
	right: 0;
	width: 145px;
	height: 182px;
}

.p-message__subTitle {
	font-size: 13.5px;
}

.p-message__messageTexts::before {
	left: 0;
	background-color: #707070;
}

.p-message__messageTexts {
	margin-top: 1.5rem;
	padding-top: 0;
	padding-left: 10px;
	font-size: 13.5px;
}

.p-message__content + .p-message__content {
	margin-top: 3.625rem;
}

.p-message__content.--sp {
	margin-top: 89.7px;
	font-size: 13.5px;
}

.p-message__messageText + .p-message__messageText {
	margin-top: 1.4375rem;
}

.p-message__profile {
	margin-top: 11.25rem;
}

.p-message__profileTitle::before {
	right: 0;
	left: -60%;
	background: url(../img/text_line_sp.png) no-repeat center center/contain;
	width: 30.6875rem;
}

.p-message__profileTexts {
	margin-top: 2.125rem;
	width: 100%;
}

.p-message__profileText {
	font-size: 13.5px;
}

.p-message__profileText + .p-message__profileText {
	margin-top: 1.875rem;
}

.p-message__profileDl {
	margin-top: 2.1875rem;
}

.p-message__profileDl + .p-message__profileDl {
	margin-top: 0.3125rem;
}

.p-message__profileDt {
	font-size: 25px;
}

.p-message__profileDd {
	margin-left: 1.125rem;
	font-size: 13px;
	line-height: 1.5384615385;
}

.p-company {
	padding: 5.8125rem 0;
}

.p-company .c-title__text.--center::before {
	left: -24%;
}

.p-company__title {
	font-size: 1.1875rem;
}

.p-company__inner {
	margin-top: 2.375rem;
	padding: 3.3125rem 0 122px;
	width: 80%;
	max-width: initial;
}

.p-company__info {
	margin-top: 1.625rem;
	font-size: 0.90625rem;
}

.p-company__dl {
	padding: 0.625rem 0;
}

.p-company__dt {
	width: 32.8%;
}

.p-company__dd.line-height--small {
	padding: 0.4375rem 0;
}

.p-contact {
	margin-top: 10.75rem;
	padding-top: 0;
	padding-bottom: 5.1875rem;
}

.p-contact .c-title .c-title__text--jp {
	top: 61px;
	left: -28px;
	letter-spacing: 0;
}

.p-contact .c-title .c-title__text {
	top: 38px;
	left: -34px;
}

.p-contact .c-title {
	top: 21px;
	right: 6px;
	width: 117px;
	height: 117px;
}

.p-contact___text {
	font-size: 14.5px;
	line-height: 1.8620689655;
	text-align: center;
}

.p-contact__bg::before {
	top: -2.0625rem;
	background-size: contain;
	height: 2.1875rem;
}

.p-contact__bg {
	padding: 133px 1.6875rem 50px;
}

.p-contact__formWrapper {
	position: relative;
	z-index: 10;
	width: 96%;
	max-width: initial;
}

.p-contact__text {
	font-size: 0.90625rem;
	font-size: 14.5px;
	line-height: 1.8620689655;
	text-align: center;
}

.p-contact__row + .p-contact__row {
	margin-top: 1.25rem;
}

.p-contact__name {
	font-size: 14.5px;
	line-height: 1;
}

.is-requird {
	padding: 0 0.3125rem;
	font-size: 0.625rem;
}

.p-contact__data {
	margin-top: 0.25rem;
}

textarea {
	height: 17.125rem;
}

.p-contact__row--privacy {
	margin-top: 1.125rem;
	text-align: center;
}

.p-contact__privacy a span {
	display: none;
}

.p-contact__privacy {
	font-size: 13px;
	line-height: 1.7037037037;
}

.p-contact__button {
	margin-top: 0.9375rem;
}

.p-contact__button .button_text {
	height: 3.625rem;
}

.p-contact__button input[type=submit] {
	font-size: 0.8125rem;
}

.page-top {
	right: 2.9%;
	bottom: -8.9%;
}

.confirm-btn__wrapper {
	flex-direction: column;
	align-items: center;
	gap: 1.875rem;
}

.reserve__button.--confirm {
	height: 3.75rem;
}

.p-privacy {
	padding: 0 1.5rem;
}

.privacy__inner {
	padding: 0 1.3125rem;
	padding-top: 210px;
}

.p-privacy__title {
	right: -0.75rem;
}

.p-privacy__title .c-title__text {
	top: 44%;
	left: -37%;
}

.p-privacy__title .c-title__text--jp {
	left: -84%;
	font-size: 14px;
}

.privacy-policy__item {
	font-size: 14px;
}

.privacy-policy__item__desc {
	font-size: 14px;
	line-height: 1.7142857143;
	text-align: left;
}

.p-privacy__button {
	padding-bottom: 5px;
	padding-left: 1.375rem;
	font-size: 12px;
}

.p-privacy__button::before {
	width: 0.78125rem;
	height: 0.554375rem;
}

.p-privacy__button::after {
	background: url(../img/close_line_sp.svg) no-repeat center center/contain;
	width: 70px;
}

.p-thanks {
	padding: 0 1.5rem;
}

.p-thanks .c-title .c-title__text--jp {
	top: 61px;
	left: -28px;
	letter-spacing: 0;
}

.p-thanks .c-title .c-title__text {
	top: 38px;
	left: -34px;
}

.p-thanks .c-title {
	top: 21px;
	right: 6px;
	width: 117px;
	height: 117px;
}

.thanks__inner {
	padding: 0 1.3125rem;
	padding-top: 210px;
}

.p-thanks__title {
	right: -0.75rem;
}

.p-thanks__title .c-title__text {
	top: 44%;
	left: -37%;
}

.p-thanks__title .c-title__text--jp {
	left: -84%;
	font-size: 14px;
}

.thanks-policy__item {
	font-size: 14px;
}

.thanks-policy__item__desc {
	font-size: 14px;
	line-height: 1.7142857143;
	text-align: left;
}

.js-fadeInLeft {
	animation-name: fadeInUpContents;
}

.js-fadeInLeft__delay--1s {
	animation-name: fadeInUpContents;
}

.js-fadeInLeft__delay--2s {
	animation-name: fadeInUpContents;
}

.js-fadeInLeftBig {
	animation-name: fadeInUpContents;
}

.js-fadeInLeftBig__delay--1s {
	animation-name: fadeInUpContents;
}

.js-fadeInLeftBig__delay--2s {
	animation-name: fadeInUpContents;
}

.js-fadeInRight {
	animation-name: fadeInUpContents;
}

.js-fadeInRight__delay--1s {
	animation-name: fadeInUpContents;
}

.js-fadeInRight__delay--2s {
	animation-name: fadeInUpContents;
}

.js-fadeInRightBig {
	animation-name: fadeInUpContents;
}

.js-fadeInRightBig__delay--1s {
	animation-name: fadeInUpContents;
}

.js-fadeInRightBig__delay--2s {
	animation-name: fadeInUpContents;
}

.u-sp {
	display: block !important;
}

.u-center--sp {
	text-align: center !important;
}

.u-left--sp {
	text-align: left !important;
}

.u-right--sp {
	text-align: right !important;
}

.u-pointer__none--sp {
	pointer-events: none !important;
}

.u-nowrap--sp {
	white-space: nowrap;
}

}

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

.l-section--bg:after {
	height: 53%;
}

}

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

.l-section--bg:after {
	height: 50%;
}

}

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

.l-section--bg.--message_bg:after {
	height: 60%;
}

}

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

.p-message__firstContent .p-message__text {
	width: 54%;
}

.p-message__img {
	right: -0.9375rem;
}

}

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

.c-title__text--jp {
	top: 1.625rem;
	left: 43%;
}

.c-title__text {
	top: 1.4375rem;
}

.p-message__title_text {
	top: 1.5625rem;
}

}

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

.p-message__inner {
	padding: 0 1.875rem;
}

}

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

.p-message__inner {
	padding: 0 0.625rem;
}

.p-message__img {
	right: -0.1875rem;
}

}

@keyframes opacity_animation {

0% {
	opacity: 0;
}

100% {
	opacity: 1;
}

}

@keyframes opacity_animation2 {

0% {
	opacity: 1;
}

100% {
	display: none;
	visibility: hidden;
	opacity: 0;
	pointer-events: none;
}

}

@keyframes opacity_animation3 {

0% {
	opacity: 0;
}

1% {
	opacity: 1;
}

100% {
	display: none;
	opacity: 0;
}

}

@keyframes fadeInUpContents {

0% {
	transform: translateY(1.25rem);
	opacity: 0;
}

100% {
	transform: translateY(0);
	opacity: 1;
}

}

@keyframes fadeInLeftContents {

0% {
	transform: translateX(-1.25rem);
	opacity: 0;
}

100% {
	transform: translateX(0);
	opacity: 1;
}

}

@keyframes fadeInRightContents {

0% {
	transform: translateX(1.25rem);
	opacity: 0;
}

100% {
	transform: translateX(0);
	opacity: 1;
}

}

@keyframes fadeInLeftBigContents {

0% {
	transform: translateX(-62.5rem);
	opacity: 0;
}

100% {
	transform: translateX(0);
	opacity: 1;
}

}

@keyframes fadeInRightBigContents {

0% {
	transform: translateX(62.5rem);
	opacity: 0;
}

100% {
	transform: translateX(0);
	opacity: 1;
}

}

