html {
	font-size: 2.66vw;
}

body {
	-webkit-font-smoothing: antialiased;
	background: #fff;
	color: #09253d;
	font-family: "Noto Sans JP", sans-serif;
}

a {
	display: block;
	transition: 0.2s;
}

a:hover {
	opacity: 0.6;
	transition: 0.2s;
}

dt {
	font-weight: normal;
}

img {
	display: block;
	max-width: 100%;
	width: 100%;
}

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

/* Remove default padding */

ul,
ol {
	padding: 0;
}

/* Remove default margin */

body,
h1,
h2,
h3,
h4,
p,
ul,
ol,
figure,
blockquote,
dl,
dd {
	margin: 0;
}

th,
td {
	padding: 0;
}

/* Set core root defaults */

/* Set core body defaults */

body {
	text-rendering: optimizeSpeed;
}

/* Remove list styles on ul, ol elements with a class attribute */

ul,
ol {
	list-style: none;
}

/* A elements that don't have a class get default styles */

a:not([class]) {
	-webkit-text-decoration-skip: ink;
	text-decoration-skip-ink: auto;
}

/* Make images easier to work with */

img {
	display: block;
	max-width: 100%;
	width: 100%;
}

/* Inherit fonts for inputs and buttons */

input,
button,
textarea,
select {
	font: inherit;
}

/* フォームリセット */

input,
button,
select,
textarea {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	background: transparent;
	border: none;
	border-radius: 0;
	font: inherit;
	outline: none;
}

textarea {
	resize: vertical;
}

input[type=checkbox],
input[type=radio] {
	display: none;
}

input[type=submit],
input[type=button],
label,
button,
select {
	cursor: pointer;
}

select::-ms-expand {
	display: none;
}

/*
 * footer
 * -------------------------------------------------------------
 */

.footer {
	background: #09253d;
	margin-left: auto;
	margin-right: auto;
	max-width: 430px;
	padding: 1.8rem 0 1.5rem;
}

.footer.--confirm {
	position: sticky;
	top: 100%;
}

.footer__logo {
	margin: 0 auto;
	max-width: 3.2rem;
}

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

.footer__copyright {
	color: #fff;
	font-size: 0.9rem;
	font-weight: 400;
	margin-top: 1.4rem;
	text-align: center;
}

/*
 * header
 * -------------------------------------------------------------
 */

.header {
	margin-left: auto;
	margin-right: auto;
	max-width: 430px;
}

.header__inner {
	align-items: center;
	background: #09253d;
	display: grid;
	height: 2.4rem;
	justify-items: center;
	place-items: center;
	position: 0 3rem;
}

.header__text {
	color: #fff;
	font-size: 1.2rem;
	font-weight: 400;
}

.header__text span {
	background: url(./../images/h_emoji.webp) no-repeat center/100%;
	display: inline-block;
	height: 0.9rem;
	width: 0.9rem;
}

/*
 * l-inner
 * -------------------------------------------------------------
 */

.l-inner {
	margin-left: auto;
	margin-right: auto;
	padding: 0 2rem;
}

/*
 * l-main
 * -------------------------------------------------------------
 */

.l-main {
	margin-left: auto;
	margin-right: auto;
	max-width: 430px;
	overflow: hidden;
}

/*
 * l-section
 * -------------------------------------------------------------
 */

.l-section {
	padding: 3rem 0 5rem;
}

/*
 * l-wrap
 * -------------------------------------------------------------
 */

.l-wrap {
	background: #E5F7F8;
	box-shadow: 0 0 5px rgba(0, 0, 0, 0.3);
	margin-left: auto;
	margin-right: auto;
	max-width: 430px;
	min-height: 100dvh;
	position: relative;
	z-index: 10;
}

/*
 * pc-wrap
 * -------------------------------------------------------------
 */

.pc-wrap {
	background: linear-gradient(to bottom, #002f4f 0%, #003050 45%, #004c68 75%, #007b79 100%);
	bottom: 0;
	display: flex;
	display: none;
	height: 100%;
	justify-content: space-between;
	left: 0;
	overflow-y: scroll;
	position: fixed;
	right: 0;
	top: 0;
	width: 100%;
}

.pc-wrap__left {
	align-items: center;
	display: flex;
	display: none;
	flex-direction: column;
	padding-top: 13rem;
	padding-top: 9vh;
	width: calc(50% - 18.75rem);
}

.pc-wrap__right {
	align-items: center;
	display: flex;
	display: none;
	flex-direction: column;
	padding-top: 21.5rem;
	padding-top: 15vh;
	width: calc(50% - 18.75rem);
}

.pcNav {
	align-items: center;
	display: flex;
	flex-direction: column;
	justify-content: center;
	width: 100%;
}

.pcNav__list {
	align-items: center;
	display: flex;
	flex-direction: column;
	max-width: 25.4rem;
	width: 100%;
}

.pcNav__list::before {
	background: url(./../images/nav_obj.webp) no-repeat center/100%;
	content: "";
	display: block;
	height: 3.1rem;
	margin-bottom: 2rem;
	width: 4.5rem;
}

.pcNav__item {
	width: 100%;
}

.pcNav__item:not(:last-child) {
	border-bottom: 2px dotted #335972;
}

.pcNav__link {
	align-items: center;
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
	padding: 2.6rem 0;
}

.pcNav__linkEng {
	color: #8097a7;
	display: block;
	font-family: "Klee One", serif, cursive;
	font-size: 1.4rem;
	font-weight: 400;
	text-align: center;
}

.pcNav__linkJa {
	display: block;
	max-width: 19.3rem;
}

.pcInfo {
	align-items: center;
	display: flex;
	flex-direction: column;
	gap: 6.5rem;
	justify-content: center;
}

.pcInfo__logo {
	max-width: 10.7rem;
}

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

.pcInfo__copyright {
	color: #e5eaed;
	font-size: max(1.3rem, min(1.5vw, 1.8rem));
	font-weight: 300;
}

.pcInfo__links {
	display: flex;
	gap: 2.7rem;
	justify-content: center;
}

.pcInfo__links a {
	max-width: 3.3rem;
}

.pcInfo__links a img {
	-o-object-fit: cover;
	height: 100%;
	object-fit: cover;
}

/*
 * burger
 * -------------------------------------------------------------
 */

.burger {
	align-items: center;
	background: #00b2b7;
	border: 3px solid #09253d;
	border-radius: 0.5rem;
	cursor: pointer;
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
	height: 4.4rem;
	justify-content: center;
	position: relative;
	position: fixed;
	right: 1rem;
	right: calc((100% - 37.5rem) / 2 + 1rem);
	top: 3.3rem;
	transition: background 0.2s transform 0.1s;
	width: 4.4rem;
	z-index: 2000;
}

.burger.is-active {
	background: transparent;
	border-color: #fff;
	border-width: 2px;
	height: 3.7rem;
	width: 3.7rem;
}

.burger span {
	background: #fff;
	display: block;
	height: 3px;
	transition: all 0.2s;
	width: 2.3rem;
}

.burger span.is-active {
	border-radius: 2rem;
	height: 2px;
	position: absolute;
	width: 3.1rem;
}

.burger span.is-active:nth-child(1) {
	top: 50%;
	transform: translateY(-50%) rotate(-45deg);
}

.burger span.is-active:nth-child(2) {
	opacity: 0;
}

.burger span.is-active:nth-child(3) {
	top: 50%;
	transform: translateY(-50%) rotate(45deg);
}

/*
 * c-linkText
 * -------------------------------------------------------------
 */

.c-linkText {
	-webkit-text-decoration: underline;
	color: #00b2b7;
	display: inline-block;
	text-decoration: underline;
	text-decoration-thickness: 1px;
	text-underline-offset: 2px;
}

/*
 * c-secHead
 * -------------------------------------------------------------
 */

.c-secHead {
	align-items: center;
	display: flex;
	flex-direction: column;
	gap: 1.6rem;
}

.c-secHead__eng {
	align-items: center;
	display: flex;
	font-family: "Klee One", serif, cursive;
	font-size: 1.1rem;
	font-weight: 400;
	gap: 0.8rem;
	justify-content: center;
}

.c-secHead__eng::before {
	background: url(./../images/ttl_obj.webp) no-repeat center/100%;
	content: "";
	display: block;
	height: 2.2rem;
	margin-top: 0.2rem;
	width: 3.2rem;
}

.c-secHead__ja img {
	-o-object-fit: cover;
	height: 100%;
	object-fit: cover;
}

/*
 * cta
 * -------------------------------------------------------------
 */

.cta {
	align-items: center;
	background: #09253d;
	bottom: 0;
	display: flex;
	gap: 0.4rem;
	left: 50%;
	max-width: 430px;
	padding: 0.4rem;
	position: fixed;
	transform: translateX(-50%);
	transition: opacity 0.3s ease, transform 0.3s ease;
	width: 100.2%;
	z-index: 100;
}

.cta__btn {
	height: 6.5rem;
	padding: 1.2rem 0.7rem;
	width: 50%;
}

.cta__btn:hover {
	opacity: 1;
}

.cta__btn.--price {
	background: #00b2b7;
}

.cta__btn.--contact {
	background: #ff931e;
}

.cta__text {
	display: block;
}

.cta__btn.--price .cta__text {
	max-width: 16.2rem;
}

.cta__btn.--contact .cta__text {
	max-width: 14.4rem;
}

.cta.is-hidden {
	opacity: 0;
	pointer-events: none;
}

/*
 * nav
 * -------------------------------------------------------------
 */

.nav {
	-webkit-overflow-scrolling: touch;
	background: linear-gradient(to bottom, #002f4f 0%, #003050 45%, #004c68 75%, #007b79 100%);
	bottom: 0;
	height: auto;
	left: 0;
	margin-left: auto;
	margin-right: auto;
	max-width: 430px;
	opacity: 0;
	overflow-y: auto;
	padding: 3.3rem 2rem 0;
	position: fixed;
	right: 0;
	top: 0;
	transition: all 0.6s;
	visibility: hidden;
	width: 100%;
	z-index: 1000;
}

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

.nav__sns {
	display: flex;
	gap: 1.8rem;
}

.nav__sns a {
	width: 3.3rem;
}

.nav__list {
	align-items: center;
	display: flex;
	flex-direction: column;
	padding-top: 2.7rem;
}

.nav__list::before {
	background: url(./../images/nav_obj.webp) no-repeat center/100%;
	content: "";
	display: block;
	height: 2.2rem;
	margin-bottom: 2.1rem;
	width: 3.2rem;
}

.nav__item {
	max-width: 18rem;
	width: 100%;
}

.nav__item:not(:last-child) {
	border-bottom: 2px dotted #335972;
}

.nav__link {
	align-items: center;
	display: flex;
	flex-direction: column;
	padding: 1.8rem 0 1.5rem;
}

.nav__item:nth-child(1) .nav__link {
	padding-top: 0;
}

.nav__linkJa {
	display: block;
	margin-top: 0.8rem;
	max-width: 13.2rem;
}

.nav__linkEng {
	color: #8097a7;
	font-family: "Klee One", serif, cursive;
	font-size: 1rem;
	font-weight: 400;
}

.nav__footer {
	align-items: center;
	display: flex;
	flex-direction: column;
	gap: 2.2rem;
	margin-top: 4rem;
}

.nav__logo {
	max-width: 5.2rem;
}

.nav__copyright {
	color: #fff;
	font-size: 0.8rem;
	font-weight: 300;
}

/*
 * acd
 * -------------------------------------------------------------
 */

.acd {
	border: 2px solid #09253d;
}

.acd__ttlWrap {
	background: #fff;
	cursor: pointer;
	display: flex;
	justify-content: space-between;
}

.acd__ttl {
	flex: 1;
	font-size: 1.4rem;
	font-weight: 700;
	padding: 1.2rem 1rem 1rem;
}

.acd__btn {
	background: #09253d;
	display: inline-block;
	height: 4rem;
	position: relative;
	width: 4rem;
}

.acd__btn::before,
.acd__btn::after {
	background: #fff;
	content: "";
	display: block;
	left: 50%;
	position: absolute;
	top: 50%;
	transform: translate(-50%, -50%);
	transition: transform 0.2s;
}

.acd__btn::before {
	height: 1.5rem;
	width: 3px;
}

.acd__btn::after {
	height: 3px;
	width: 1.5rem;
}

.acd__cont {
	background: #fff;
	display: none;
	padding: 1rem;
}

.acd__text {
	font-size: 1.4rem;
	font-weight: 700;
	line-height: 1.4;
}

.acd.is-open .acd__btn::before {
	transform: translate(-50%, -50%) rotate(90deg);
}

/*
 * confirm
 * -------------------------------------------------------------
 */

.confirm {
	padding: 2rem 0;
}

.confirm__inner {
	padding: 0 3.3rem;
}

.confirm__head {
	font-size: 1.4rem;
	font-weight: 800;
	text-align: center;
}

.confirm__table {
	border: 2px solid #09253d;
	margin-top: 1.6rem;
	width: 100%;
}

.confirm__table th,
.confirm__table td {
	font-size: 1rem;
	height: 2.8rem;
	vertical-align: middle;
}

.confirm__table th {
	background: #abe6e7;
	font-weight: 400;
	padding: 0.5rem 1.1rem;
	width: 9.6rem;
}

.confirm__table td {
	font-weight: 600;
	padding: 0.5rem 1rem;
}

.confirm__table tr:not(:last-child) {
	border-bottom: 1px solid #09253d;
}

.confirm__table tr.textarea {
	border-bottom: none;
}

.confirm__table .textarea td {
	padding: 1.3rem 1.5rem;
}

.confirm__actions {
	display: flex;
	gap: 2rem;
	justify-content: space-between;
	margin-top: 2.5rem;
}

.confirm__btn {
	max-width: 13.5rem;
	transition: all 0.2s;
}

.confirm__btn:hover {
	filter: brightness(110%);
}

/*
 * contact
 * -------------------------------------------------------------
 */

.contact {
	padding: 3rem 0;
}

.contact__secHeadJa {
	max-width: 27.2rem;
}

.contact__body {
	margin: 1.5rem auto 0;
	max-width: 30rem;
}

.contact__lead {
	color: #00b2b7;
	font-size: 1.2rem;
	font-weight: 400;
	text-align: center;
}

.privacy {
	margin-top: 1.6rem;
}

.privacy dl,
.privacy ul {
	margin-top: 1em;
}

.privacy__cont {
	font-size: 1.4rem;
	font-weight: 400;
	line-height: 1.4;
}

.privacy__end {
	margin-top: 2em;
}

/*
 * faq
 * -------------------------------------------------------------
 */

.faq__secHeadJa {
	max-width: 23.3rem;
}

.faq__list {
	display: flex;
	flex-direction: column;
	gap: 1rem;
	margin-top: 2rem;
}

.faq__notes {
	margin-top: 1.3rem;
}

.faq__note {
	font-size: 0.9rem;
	font-weight: 400;
	line-height: 1.5555555556;
	text-align: justify;
}

/*
 * form
 * -------------------------------------------------------------
 */

.form {
	margin-top: 2rem;
}

.form__item:not(:nth-child(1)) {
	margin-top: 1.6rem;
}

.form__label {
	align-items: center;
	display: block;
	display: flex;
	font-size: 1.4rem;
	font-weight: 700;
}

.form__req {
	color: #ff1100;
	font-size: 1rem;
	font-weight: 900;
	margin-left: 2px;
}

.form__reqText {
	font-size: 1rem;
	font-weight: 500;
}

.form__input {
	margin-top: 0.5rem;
}

.form__input,
.form__select,
.form__textarea {
	background: #fff;
	border: 2px solid #09253d;
	font-size: 1.5rem;
	font-weight: 400;
	padding: 0.6rem 1.1rem;
	width: 100%;
}

.form__input::-moz-placeholder,
.form__textarea::-moz-placeholder {
	color: #9da8b1;
}

.form__input::placeholder,
.form__textarea::placeholder {
	color: #9da8b1;
}

.form__textarea {
	margin-top: 0.5rem;
	min-height: 13rem;
	resize: vertical;
}

/* 利用日
------------------------------ */

.form__dateFields {
	display: flex;
	gap: 0.6rem;
	margin-top: 0.5rem;
}

.form__dateSelect {
	align-items: center;
	display: flex;
	flex: 1;
	gap: 0.4rem;
}

.form__selectWrap {
	flex: 1;
	position: relative;
}

.form__selectWrap::before {
	background: #09253d;
	content: "";
	display: block;
	height: 3.3rem;
	pointer-events: none;
	position: absolute;
	right: 0;
	top: 0;
	width: 3.3rem;
}

.form__selectWrap::after {
	-webkit-clip-path: polygon(100% 0, 0 0, 50% 100%);
	background: #09253d;
	background: #fff;
	clip-path: polygon(100% 0, 0 0, 50% 100%);
	content: "";
	height: 1rem;
	pointer-events: none;
	position: absolute;
	right: 0.9rem;
	top: 50%;
	transform: translateY(-50%);
	width: 1.5rem;
	z-index: 2;
}

.form__dateSelect:nth-child(1) .form__selectWrap {
	width: 9.5rem;
}

.form__dateLabel {
	display: block;
	font-size: 1.4rem;
	font-weight: 600;
}

/* 人数
------------------------------ */

.form__item--inline .form__inline {
	align-items: center;
	display: flex;
	gap: 0.8rem;
}

.form__input--short {
	align-items: center;
	display: grid;
	justify-items: center;
	padding: 0.8rem 0.5rem;
	place-items: center;
	width: 3.6rem;
}

.form__unit {
	font-size: 1.4rem;
	font-weight: 600;
}

/* Check
------------------------------ */

.form__check {
	margin-top: 1.6rem;
}

.form__check .form__req {
	position: relative;
	top: -0.1rem;
}

.form__label--check {
	align-items: center;
	cursor: pointer;
	display: flex;
	justify-content: center;
	margin-left: auto;
	margin-right: auto;
	position: relative;
	width: -moz-fit-content;
	width: fit-content;
}

.form__label--check::before {
	background: #fff;
	border: 2px solid #09253d;
	border-radius: 1px;
	content: "";
	height: 1.3rem;
	margin: 0.3rem 0.8rem 0 0;
	width: 1.3rem;
}

.form__label--check:has(:checked)::after {
	border: solid #09253d;
	border-width: 0 2px 2px 0;
	content: "";
	height: 1rem;
	left: 0.4rem;
	position: absolute;
	top: 0.3rem;
	transform: rotate(40deg);
	width: 0.5rem;
}

.form__label--check input {
	opacity: 0;
	pointer-events: none;
	position: absolute;
}

input[type=checkbox],
input[type=radio] {
	display: block;
}

.form__submit {
	margin-top: 3rem;
	text-align: center;
}

/* Submit
------------------------------ */

.form__btn {
	cursor: pointer;
	display: inline-block;
	max-width: 25.5rem;
	transition: all 0.2s;
	width: 100%;
}

.form__btn:hover {
	filter: brightness(110%);
	opacity: 1;
}

/*
 * fv
 * -------------------------------------------------------------
 */

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

/*
 * point
 * -------------------------------------------------------------
 */

.point__secHeadJa {
	max-width: 23.5rem;
}

.point__list {
	grid-gap: 1.2rem;
	display: grid;
	gap: 1.2rem;
	grid-template-columns: repeat(3, 1fr);
	margin-top: 2.6rem;
}

.point__item {
	display: flex;
	flex-direction: column;
	gap: 1.7rem;
}

.point__img {
	border: 2px solid #09253d;
	border-radius: 0.8rem;
	overflow: hidden;
}

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

.point__desc {
	align-items: center;
	background: #fff;
	border-radius: 0.8rem;
	display: flex;
	flex-direction: column;
	gap: 2.6rem;
	padding: 3.3rem 1.1rem 3.9rem;
	position: relative;
}

.point__desc::before {
	-webkit-clip-path: polygon(50% 0%, 0% 100%, 100% 100%);
	background: #fff;
	clip-path: polygon(50% 0%, 0% 100%, 100% 100%);
	content: "";
	display: block;
	height: 0.9rem;
	left: 50%;
	position: absolute;
	top: -0.8rem;
	transform: translateX(-50%);
	width: 1.4rem;
}

.point__icon.--icon1 {
	max-width: 4rem;
}

.point__icon.--icon2 {
	max-width: 6.2rem;
}

.point__icon.--icon3 {
	max-width: 6.6rem;
}

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

.point__ttl {
	align-items: center;
	display: flex;
	flex-direction: column;
	font-size: 1.3rem;
	font-weight: 800;
	gap: 0.6rem;
	line-height: 1.3846153846;
	text-align: center;
}

.point__ttl::before {
	background: url(./../images/check.webp) no-repeat center/100%;
	content: "";
	display: block;
	height: 1.4rem;
	width: 1.8rem;
}

.point__text {
	font-size: 1.4rem;
	font-weight: 800;
	margin-top: 2.6rem;
	text-align: center;
}

/*
 * price
 * -------------------------------------------------------------
 */

.price__secHeadJa {
	max-width: 24rem;
}

.price__notes {
	margin-top: 1rem;
	text-align: center;
}

.price__note {
	font-size: 1rem;
	font-weight: 300;
	line-height: 1.9;
}

.price__text {
	font-size: 1.4rem;
	font-weight: 800;
	text-align: center;
}

/*
 * priceSim
 * -------------------------------------------------------------
 */

.priceSim {
	display: flex;
	flex-direction: column;
	gap: 1rem;
	margin-top: 1.8rem;
}

.priceSim__field {
	align-items: center;
	display: flex;
	flex-direction: column;
	gap: 0.3rem;
}

.priceSim__label {
	align-items: center;
	color: #00b2b7;
	display: flex;
	font-size: 1.4rem;
	font-weight: 700;
	gap: 0.4rem;
	justify-content: center;
}

.priceSim__label::before {
	background: url(./../images/price_icon.webp) no-repeat center/100%;
	content: "";
	display: block;
	height: 2.4rem;
	width: 1.7rem;
}

.priceSim__selectWrap {
	display: inline-block;
	position: relative;
}

.priceSim__selectWrap::before {
	background: #00b2b7;
	border-left: 4px solid #061737;
	content: "";
	display: block;
	height: 4.3rem;
	pointer-events: none;
	position: absolute;
	right: 0.4rem;
	top: 0.4rem;
	width: 4.6rem;
}

.priceSim__selectWrap::after {
	-webkit-clip-path: polygon(100% 0, 0 0, 50% 100%);
	background: #09253d;
	background: #061737;
	clip-path: polygon(100% 0, 0 0, 50% 100%);
	content: "";
	height: 1.1rem;
	pointer-events: none;
	position: absolute;
	right: 1.7rem;
	top: 50%;
	transform: translateY(-50%);
	width: 1.6rem;
	z-index: 2;
}

.priceSim__select {
	-webkit-appearance: none;
	-moz-appearance: none;
	-moz-text-align-last: center;
	appearance: none;
	background: #fff;
	border: 4px solid #061737;
	border-radius: 0;
	box-sizing: border-box;
	color: #061737;
	cursor: pointer; /* 右は矢印エリア分広めに */
	font-size: 1.8rem;
	font-weight: 700;
	height: 5rem;
	padding: 0 6rem 0 1.5rem;
	text-align: center;
	text-align-last: center;
	width: 19.4rem;
}

.priceSim__cardTtl {
	align-items: center;
	display: flex;
	font-size: 1.4rem;
	font-weight: 700;
}

.priceSim__cardTtl span {
	color: #00b2b7;
}

.priceSim__cardTtl small {
	display: inline-block;
	font-size: 1rem;
	font-weight: 400;
	letter-spacing: -0.05em;
	margin-top: 0.4rem;
}

.priceSim__card.--card1 .priceSim__cardTtl::before {
	background: url(./../images/price_img1.webp) no-repeat center/100%;
	content: "";
	display: block;
	height: 4.5rem;
	margin-top: 1.3rem;
	width: 6.5rem;
}

.priceSim__card.--card2 .priceSim__cardTtl::before {
	background: url(./../images/price_img2.webp) no-repeat center/100%;
	content: "";
	display: block;
	height: 3.8rem;
	margin-top: 0.5rem;
	width: 5.6rem;
}

.priceSim__table {
	border: 2px solid #09253d;
	border-collapse: collapse;
	width: 100%;
}

.priceSim__card.--card1 .priceSim__table {
	margin-top: -1rem;
}

.priceSim__table tbody tr:not(:last-child) {
	border-bottom: 2px solid #09253d;
}

.priceSim__table th,
.priceSim__table td {
	text-align: center;
	vertical-align: middle;
}

.priceSim__table th {
	background: #09253d;
	color: #fff;
	font-size: 1.2rem;
	font-weight: 400;
	padding: 0.6rem 1rem 0.9rem;
}

.priceSim__table th:not(:last-child) {
	border-right: 1px dashed #fff;
}

.priceSim__table th:last-child {
	color: #00b2b7;
	font-weight: 800;
}

.priceSim__table td {
	background: #fff;
	font-size: 1.45rem;
	font-weight: 700;
	padding: 1.2rem;
}

.priceSim__table td:not(:last-child) {
	border-right: 1px dashed #09253d;
}

.priceHighlightCell {
	text-align: center;
}

.priceHighlight {
	color: #00b2b7;
	display: inline-block;
	font-size: 1.9rem;
	font-weight: 900;
	position: relative;
	z-index: 1;
}

.priceHighlight::before { /* 帯の太さ */
	background: rgba(255, 255, 0, 0.8);
	bottom: 0;
	content: ""; /* テキストとの隙間 */
	height: 0.6em;
	left: 0;
	position: absolute;
	right: 0;
	z-index: -1;
}

/*
 * thanks
 * -------------------------------------------------------------
 */

.thanks {
	padding: 4.5rem 0 10.5rem;
}

.thanks__head {
	margin-left: auto;
	margin-right: auto;
	max-width: 16rem;
}

.thanks__body {
	margin: 2.8rem auto 0;
	max-width: 28rem;
}

.thanks__text {
	border-bottom: 1px solid #09253d;
	border-top: 1px solid #09253d;
	font-size: 1.2rem;
	font-weight: 600;
	line-height: 2;
	padding: 1.2rem 0;
	text-align: center;
}

.thanks__btn {
	margin: 4rem auto 0;
	max-width: 16rem;
}

.thanks__btn:hover {
	filter: brightness(110%);
	opacity: 1;
}

/*
 * u-pc
 * -------------------------------------------------------------
 */

.u-pc {
	display: block;
}

/*
 * u-sp
 * -------------------------------------------------------------
 */

.u-sp {
	display: none;
}

/*
 * u-visually-hidden
 * -------------------------------------------------------------
 */

.u-visually-hidden {
	clip: rect(0 0 0 0) !important;
	border: 0 !important;
	height: 1px !important;
	margin: -1px !important;
	overflow: hidden !important;
	padding: 0 !important;
	position: absolute !important;
	white-space: nowrap !important;
	width: 1px !important;
}

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

html {
	font-size: 10px;
}

.pc-wrap {
	display: flex;
}

.u-pc {
	display: none;
}

.u-sp {
	display: block;
}

}

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

.header {
	max-width: 37.5rem;
}

.l-main {
	max-width: 37.5rem;
}

.l-wrap {
	max-width: 37.5rem;
}

.pc-wrap__left {
	display: flex;
}

.pc-wrap__right {
	display: flex;
}

.burger {
	display: none;
}

.cta {
	max-width: 37.5rem;
}

.nav {
	max-width: 37.5rem;
}

}

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

a[href^="tel:"] {
	pointer-events: none;
}

}


/*# sourceMappingURL=style.css.map */
