/* リキッドレイアウト対応 */

body {
	font-family: "Noto Sans JP", sans-serif;
}

.u-desktop {
	display: none;
}

html {
	font-size: 16px;
}

*,
*::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;
}

/* Set core root defaults */

html {
	scroll-behavior: smooth;
}

/* Set core body defaults */

body {
	line-height: 1.5;
	min-height: 100vh;
	text-rendering: optimizeLegibility;
}

/* 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%;
}

/* Natural flow and rhythm in articles by default */

article > * + * {
	margin-top: 1em;
}

/* Inherit fonts for inputs and buttons */

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

/* Blur images when they have no alt attribute */

img:not([alt]) {
	filter: blur(10px);
}

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

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;
}

/* ホバー */

a {
	-webkit-text-decoration: none;
	color: inherit;
	text-decoration: none;
	transition: opacity 0.3s;
}

.layout-about {
	margin-top: 5.3125rem;
}

.layout-blog {
	padding-top: 5.3125rem;
	position: relative;
}

.layout-breadcrumb {
	margin-top: 0.5rem;
}

.breadcrumb--white.layout-breadcrumb {
	margin-top: 0rem;
	padding-top: 5.5rem;
}

.layout-campaign {
	margin-top: 2.8125rem;
	overflow-x: hidden;
}

.layout-contact {
	margin-top: 5rem;
}

.layout-contact.layout-contact--sub {
	margin-top: 6.625rem;
}

.layout-contact.layout-contact--margin {
	margin-top: 5.875rem;
}

.layout-footer {
	margin-top: 6.25rem;
	padding-bottom: 3.5rem;
	padding-top: 3rem;
}

.layout-footer.layout-footer--sub {
	margin-top: 9.25rem;
}

.layout-footer.layout-footer--margin {
	margin: 0;
}

.layout-header {
	left: 0;
	position: fixed;
	right: 0;
	top: 0;
	z-index: 900;
}

.layout-information {
	background: #ddf0f1;
	margin-top: 4.625rem;
	padding-bottom: 5.25rem;
	padding-top: 5.25rem;
}

.layout-price {
	margin-top: 5.3125rem;
	padding-bottom: 5.25rem;
	padding-top: 5.25rem;
}

.layout-privacy-policy {
	margin-top: 3.25rem;
}

.layout-sitemap {
	margin-top: 1.4375rem;
}

.layout-sub-about {
	margin-top: 3.25rem;
}

.layout-sub-blog {
	margin-top: 3.25rem;
}

.layout-sub-campaign {
	margin-top: 3.25rem;
}

.layout-sub-contact-thanks {
	margin-top: 3.25rem;
}

.layout-sub-contact {
	margin-top: 3.1875rem;
}

.layout-sub-faq {
	margin-top: 3.25rem;
}

.layout-sub-gallery {
	margin-top: 2.5rem;
}

.layout-sub-information {
	margin-top: 7.625rem;
}

.layout-sub-price {
	margin-top: 3.25rem;
}

.layout-sub-voice {
	margin-top: 3.25rem;
}

.layout-tab {
	margin-top: 3.25rem;
}

.layout-terms {
	margin-top: 3.25rem;
}

.layout-voice-card {
	margin-top: 5.5625rem;
}

.about {
	position: relative;
}

.about__inner {
	max-width: 39.375rem;
}

.about__content {
	margin-top: 3.4375rem;
	position: relative;
}

.about__content.about__content--sub {
	margin: 0;
}

.about__shisa-img {
	left: 0;
	position: absolute;
	top: -1.625rem;
	width: 37.1014492754%;
}

.about__shisa-img img {
	-o-object-fit: cover;
	aspect-ratio: 128/194;
	height: auto;
	object-fit: cover;
	width: 100%;
}

.about__fish-img {
	margin-left: auto;
	width: 81.4492753623%;
}

.about__fish-img.about__fish-img--sub {
	width: auto;
}

.about__fish-img img {
	-o-object-fit: cover;
	aspect-ratio: 281/186;
	height: auto;
	object-fit: cover;
	width: 100%;
}

.about__fish-img.about__fish-img--sub img {
	aspect-ratio: 345/228;
}

.about__text {
	color: #408f95;
	font-family: "Gotu", sans-serif;
	font-size: 2.5rem;
	font-weight: 400;
	line-height: 1;
	margin-top: 2.5rem;
}

.about__text.about__text--sub {
	color: #fff;
	left: calc(50% - min(50vw, 9.25rem));
	margin-top: 0;
	position: absolute;
	top: 1.5rem;
}

.about__description {
	color: #0d2936;
	font-weight: 400;
	line-height: 1.5;
	margin-top: 1rem;
}

.about__description.about__description--sub {
	margin-top: 2.5rem;
}

.about__btn {
	margin-top: 3.125rem;
	text-align: center;
}

.animation {
	overflow: hidden;
	position: relative;
	width: 100%;
}

.animation .is-open {
	background-color: #408f95;
	height: 100%;
	position: absolute;
	right: 0;
	top: 0;
	transition: width 0.7s ease-in-out;
	width: 0%;
	z-index: 2;
}

.animation img {
	opacity: 0;
	transition: opacity 0.7s ease-in-out;
	width: 100%;
}

.blog-card-list {
	background-color: #fff;
	box-shadow: 2px 2px 10px rgba(0, 0, 0, 0.25);
	display: flex;
	flex-direction: column;
	height: 100%;
	padding: 1rem 1rem 1.5rem;
}

.blog-card-list:hover {
	opacity: 1;
}

.blog-card-list__item-img {
	overflow: hidden;
	width: 100%;
}

.blog-card-list__item-img img {
	-o-object-fit: cover;
	aspect-ratio: 301/201;
	object-fit: cover;
	transition: 0.6s;
	width: 100%;
}

.blog-card-list__title-wrap {
	border-bottom: 1px solid #408f95;
	margin-top: 0.9375rem;
}

.blog-card-list__item-category {
	color: #0d2936;
	font-family: "Gotu", sans-serif;
	font-size: 0.75rem;
	font-weight: 400;
	line-height: 1.5;
}

.blog-card-list__item-title {
	color: #0d2936;
	font-weight: 500;
	line-height: 1.5;
	padding-bottom: 0.25rem;
}

.blog-card-list__item-text {
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 5;
	color: #0d2936;
	display: -webkit-box;
	font-weight: 400;
	line-height: 1.5;
	margin-top: 1rem;
	overflow: hidden;
	text-overflow: ellipsis;
}

.blog-card-lists {
	grid-gap: 2.4375rem;
	display: grid;
	gap: 2.4375rem;
	grid-template-columns: repeat(1, 1fr);
	position: relative;
}

.blog-detail {
	height: 100%;
}

.blog-detail__title-wrap {
	border-bottom: 1px solid #408f95;
}

.blog-detail__item-category {
	color: #0d2936;
	font-family: "Gotu", sans-serif;
	font-size: 0.75rem;
	font-weight: 400;
	line-height: 1.5;
}

.blog-detail__item-title {
	color: #0d2936;
	font-size: 1.5rem;
	font-weight: 500;
	line-height: 1.2083333333;
	margin-top: 0.5rem;
	padding-bottom: 0.25rem;
}

.blog-detail__item-img {
	margin-top: 2.5rem;
	width: 100%;
}

.blog-detail__container {
	margin-top: 1.5rem;
}

.blog-detail__container p {
	color: #0d2936;
	font-weight: 400;
	line-height: 1.5;
}

.blog-detail__container p:not(:first-of-type) {
	margin-top: 1.5rem;
}

.blog-detail__container img {
	-o-object-fit: cover;
	aspect-ratio: 345/231;
	margin-top: 2.5rem;
	object-fit: cover;
	width: 100%;
}

.blog-detail__container ul {
	grid-gap: 0.25rem;
	display: grid;
	gap: 0.25rem;
	margin-top: 1.5rem;
}

.blog-detail__container li {
	color: #0d2936;
	line-height: 1.5;
	padding-left: 1.6875rem;
	position: relative;
}

.blog-detail__container li::before {
	background: url("../images/common/sub-blog-icon-img.svg");
	background-position: center center;
	background-repeat: no-repeat;
	background-size: contain;
	content: "";
	height: 1.125rem;
	left: 0;
	position: absolute;
	top: 0.75rem;
	transform: translateY(-50%);
	width: 1.125rem;
}

.blog-detail__pagination {
	margin-top: 2.5rem;
}

.blog-detail__pagination-wrap {
	align-items: center;
	display: flex;
	gap: 5.125rem;
	justify-content: center;
}

.blog-detail__pagination-link {
	border: 1px solid #408f95;
	height: 2.375rem;
	position: relative;
	transition: background 0.3s;
	width: 2.375rem;
}

.blog-detail__pagination-link::before {
	content: "";
	display: block;
	height: 0.625rem;
	position: absolute;
	top: 50%;
	transform: translateY(-50%) rotate(45deg);
	transition: border 0.3s;
	width: 0.625rem;
}

.blog-detail__pagination-link--prev::before {
	border-bottom: 1px solid #408f95;
	border-left: 1px solid #408f95;
	left: 40%;
}

.blog-detail__pagination-link--next::before {
	border-right: 1px solid #408f95;
	border-top: 1px solid #408f95;
	right: 40%;
}

.blog-detail__pagination-link:hover {
	background-color: #408f95;
	opacity: 1;
}

.blog-detail__pagination a:hover::before {
	border-color: #fff;
}

.blog__inner {
	max-width: 39.375rem;
}

.blog__lists {
	margin-top: 1.8125rem;
}

.blog__btn {
	margin-top: 2.625rem;
	text-align: center;
}

.breadcrumb.breadcrumb--white span {
	color: #fff;
}

.breadcrumb__inner {
	align-items: center;
	display: flex;
	gap: 1.25rem;
	max-width: 37.5rem;
}

.breadcrumb span {
	color: #0d2936;
	font-size: 0.875rem;
	font-weight: 400;
	text-transform: uppercase;
}

.breadcrumb span a {
	position: relative;
}

.breadcrumb span a::before,
.breadcrumb span a::after {
	background-color: #0d2936;
	border-radius: 100vh;
	content: "";
	height: 0.0625rem;
	position: absolute;
	right: -0.8125rem;
	top: 50%;
	transform-origin: calc(100% - 0.5px) 50%;
	width: 0.35rem;
}

.breadcrumb.breadcrumb--white span a::before,
.breadcrumb.breadcrumb--white span a::after {
	background-color: #fff;
}

.breadcrumb span a::before {
	transform: rotate(49.4deg);
}

.breadcrumb span a::after {
	transform: rotate(-49.4deg);
}

.btn {
	background-color: #408f95;
	border: 1px solid #408f95;
	display: inline-block;
	padding: 0.8125rem 4.875rem 0.8125rem 2.375rem;
	position: relative;
	transition: 0.3s;
	z-index: 1;
}

.btn.btn--white {
	background-color: #fff;
	border: none;
	padding: 0.8125rem 5.1875rem 0.8125rem 2.3125rem;
}

.btn::before {
	background: #fff;
	content: "";
	display: block;
	height: 100%;
	left: 0;
	position: absolute;
	top: 0;
	transform: scaleX(0);
	transform-origin: left top;
	transition: 0.3s;
	transition-property: transform;
	width: 100%;
}

.btn.btn--white::before {
	transform: scaleX(1);
}

.btn::after {
	border: 1px solid #408f95;
	bottom: -0.25rem;
	content: "";
	left: 0.25rem;
	position: absolute;
	right: -0.25rem;
	top: 0.25rem;
	transition: 0.3s;
	z-index: -1;
}

.btn.btn--white::after {
	border: 1px solid #fff;
}

.btn__arrow {
	margin-left: 0.5rem;
}

.btn__arrow.btn__arrow--submit {
	margin-left: 1rem;
}

.btn__arrow.btn__arrow--white {
	margin-left: 1rem;
}

.btn__arrow::before {
	background-color: #fff;
	border-radius: 100vh;
	content: "";
	height: 0.0625rem;
	left: 0;
	position: absolute;
	top: 50%;
	width: 2.5rem;
}

.btn__arrow::after {
	background-color: #fff;
	border-radius: 100vh;
	content: "";
	height: 0.0625rem;
	left: calc(50% + 1.875rem);
	position: absolute;
	top: 50%;
	transform: rotate(45deg);
	transform-origin: 100% 50%;
	width: 0.625rem;
}

.btn.btn--white .btn__arrow::before,
.btn.btn--white .btn__arrow::after {
	background-color: #408f95;
}

.btn span {
	color: #fff;
	font-family: "Gotu", sans-serif;
	font-size: 0.875rem;
	font-weight: 400;
	line-height: 1.5714285714;
	position: relative;
	transition: 0.3s;
	z-index: 2;
}

.btn.btn--white span {
	color: #408f95;
}

.btn.btn--submit {
	padding: 0.8125rem 6.25rem 0.8125rem 3.125rem;
}

.campaign-card {
	background-color: #fff;
	box-shadow: 2px 2px 10px rgba(0, 0, 0, 0.25);
	display: flex;
	flex-direction: column;
	height: 100%;
}

.campaign-card__item {
	display: flex;
	flex-direction: column;
	height: 100%;
}

.campaign-card__img {
	overflow: hidden;
	width: 100%;
}

.campaign-card__img img {
	-o-object-fit: cover;
	aspect-ratio: 280/188;
	height: auto;
	object-fit: cover;
	transition: 0.6s;
	width: 100%;
}

.campaign-card__img.campaign-card__img--side img {
	aspect-ratio: 294/188;
}

.campaign-card__title-wrap {
	margin-top: 1rem;
	padding-left: 1rem;
	padding-right: 1rem;
}

.campaign-card__title-wrap.campaign-card__title-wrap--side {
	margin-top: 1rem;
	padding-left: 1.4375rem;
	padding-right: 1.4375rem;
	text-align: center;
}

.campaign-card__category {
	border: 1px solid #408f95;
	color: #408f95;
	display: inline-block;
	font-size: 0.75rem;
	font-weight: 400;
	line-height: 1.8333333333;
	padding: 0.1875rem 0.6875rem;
}

.campaign-card__title {
	border-bottom: 1px solid #408f95;
	color: #0d2936;
	font-size: 1rem;
	font-weight: 500;
	line-height: 1.5;
	margin-top: 0.25rem;
	padding-bottom: 0.5rem;
}

.campaign-card__title.campaign-card__title--side {
	margin-top: 0rem;
}

.campaign-card__price-wrapper {
	margin-top: auto;
	padding: 0.5rem 2.125rem 1.5rem 2.1875rem;
}

.campaign-card__price-wrapper.campaign-card__price-wrapper--side {
	padding: 0.5625rem 2.5625rem 1.5rem 2.625rem;
}

.campaign-card__text {
	color: #0d2936;
	font-size: 0.875rem;
	font-weight: 400;
	line-height: 1.7142857143;
	text-align: center;
}

.campaign-card__text.campaign-card__text--side {
	font-size: 0.875rem;
}

.campaign-card__price-wrap {
	align-items: center;
	display: flex;
	gap: 1.1875rem;
	justify-content: center;
	margin-top: 0.5rem;
}

.campaign-card__price-wrap.campaign-card__price-wrap--side {
	gap: 1rem;
	margin-top: 0.8125rem;
}

.campaign-card__price-original {
	color: #0d2936;
	font-family: "Lato", sans-serif;
	font-size: 1.25rem;
	font-weight: 700;
	line-height: 1;
	margin-top: 0.625rem;
	position: relative;
}

.campaign-card__price-original.campaign-card__price-original--side {
	font-size: 1.25rem;
	margin-top: 0.375rem;
}

.campaign-card__price-original::before {
	border: 2px solid #c94800;
	content: "";
	height: 0.0625rem;
	left: -0.125rem;
	line-height: 1;
	position: absolute;
	top: 0.5rem;
	width: 5rem;
}

.campaign-card__price-original.campaign-card__price-original--side::before {
	width: 4.75rem;
}

.campaign-card__price-discount {
	color: #408f95;
	font-family: "Lato", sans-serif;
	font-size: 2rem;
	font-weight: 700;
	line-height: 1;
	margin-top: -0.1875rem;
}

.campaign-card__price-discount.campaign-card__price-discount--side {
	font-size: 2rem;
}

.campaign-card__text {
	color: #0d2936;
	font-size: 0.875rem;
	font-weight: 400;
	line-height: 1.7142857143;
	text-align: center;
}

.campaign-card__text.campaign-card__text--left {
	margin-top: 1.5rem;
	text-align: left;
}

.campaign-card__meta-date {
	font-family: "Lato", sans-serif;
}

.campaign-card__meta-text {
	color: #408f95;
	font-size: 0.875rem;
	line-height: 1.2857142857;
	margin-top: 0.4375rem;
}

.campaign-card__btn {
	margin-top: 0.875rem;
	text-align: center;
}

.campaign {
	position: relative;
}

.campaign__swiper-button-wrap {
	display: flex;
	gap: 5rem;
	justify-content: right;
	position: absolute;
	right: calc(50% - 33.75rem);
	top: 0;
}

.campaign__swiper-button-wrap .swiper-button-prev {
	transform: scale(-1, 1);
}

.campaign__swiper-button-wrap .swiper-button-prev,
.campaign__swiper-button-wrap .swiper-button-next {
	border: 1px solid #408f95;
	border-radius: 50vh;
	height: 5rem;
	position: relative;
	transition: opacity 0.3s;
	width: 5rem;
}

.campaign__swiper-button-wrap .swiper-button-prev:hover,
.campaign__swiper-button-wrap .swiper-button-next:hover {
	opacity: 0.7;
}

.campaign__swiper-button-wrap .swiper-button-prev::before,
.campaign__swiper-button-wrap .swiper-button-next::before {
	background-color: #408f95;
	border-radius: 100vh;
	content: "";
	height: 0.0625rem;
	left: 50%;
	position: absolute;
	top: 51%;
	transform: translate(-50%, -50%);
	width: 2.5rem;
}

.campaign__swiper-button-wrap .swiper-button-prev::after,
.campaign__swiper-button-wrap .swiper-button-next::after {
	background-color: #408f95;
	border-radius: 100vh;
	content: "";
	height: 0.0625rem;
	left: calc(50% + 0.5625rem);
	position: absolute;
	top: 50%;
	transform: translate(-50%, -50%);
	transform: rotate(45deg);
	transform-origin: 100% 50%;
	width: 0.625rem;
}

.swiper-button-prev,
.swiper-button-next,
.swiper-pagination-bullets.swiper-pagination-horizontal {
	bottom: auto;
	bottom: initial;
	left: auto;
	left: initial;
	margin: 0;
	padding: 0;
	right: auto;
	right: initial;
	top: auto;
	top: initial;
}

.swiper-button-prev::after,
.swiper-button-next::after {
	content: "";
}

.campaign__swiper {
	margin-right: calc(50% - 50vw);
	margin-top: 1.875rem;
}

.campaign__swiper .swiper-slide {
	height: auto;
	padding-bottom: 0.8125rem;
}

.campaign__btn {
	margin-top: 1.6875rem;
	padding-bottom: 0.25rem;
	text-align: center;
}

.contact {
	position: relative;
}

.contact::before {
	background: url("../images/common/contact-fish-img.webp");
	background-repeat: no-repeat;
	background-size: cover;
	content: "";
	height: 3.125rem;
	left: calc(50% + 3.96875rem);
	position: absolute;
	top: -1.625rem;
	width: 6.8125rem;
}

.contact__item:nth-child(1) {
	padding-left: 1.5625rem;
	padding-right: 1.5625rem;
}

.contact__item:nth-child(2) {
	filter: drop-shadow(0px 4px 4px rgba(0, 0, 0, 0.25));
	margin-top: 2.5rem;
}

.contact__item-logo {
	filter: drop-shadow(0px 4px 4px rgba(0, 0, 0, 0.25));
	margin-left: auto;
	margin-right: auto;
	max-width: 10.875rem;
	padding-bottom: 0.3125rem;
	width: 100%;
}

.contact__item-logo img {
	-o-object-fit: contain;
	height: 100%;
	object-fit: contain;
	width: 100%;
}

.contact__wrap {
	border-top: 1px solid #408f95;
	filter: drop-shadow(0px 4px 4px rgba(0, 0, 0, 0.25));
	margin-left: auto;
	margin-right: auto;
	max-width: 37.5rem;
	padding-top: 1rem;
}

.contact__item-text + .contact__item-text {
	margin-top: 0.25rem;
}

.contact__item-text {
	color: #0d2936;
	font-size: 1rem;
	line-height: 1.5;
	text-align: center;
}

.contact__item-text.contact__item-text--small {
	color: #408f95;
	font-size: 0.875rem;
	line-height: 1.2857142857;
	margin-top: 0.5rem;
	text-align: center;
}

.contact__btn {
	margin-top: 2.375rem;
	padding-bottom: 0.25rem;
	text-align: center;
}

.drawer {
	background-color: #408f95;
	bottom: 0;
	display: none;
	height: calc(100vh - 5rem);
	left: 0;
	position: absolute;
	right: 0;
	top: 5rem;
	width: 100%;
	z-index: 900;
}

.drawer__inner {
	height: inherit;
	margin-left: auto;
	margin-right: auto;
	max-width: 33.125rem;
	padding-left: 0.9375rem;
	padding-right: 0.9375rem;
}

.drawer__wrap {
	height: inherit;
	overflow-y: scroll;
	scrollbar-width: none;
}

.drawer__wrap::-webkit-scrollbar {
	display: none;
}

.error-page {
	background: #408f95;
	padding-bottom: 2.5rem;
	position: relative;
}

.error-page::before {
	background: url("../images/common/error-img.webp");
	background-position: center center;
	background-repeat: no-repeat;
	background-size: contain;
	content: "";
	height: 21.5625rem;
	left: 50%;
	position: absolute;
	top: 5rem;
	transform: translateX(-50%);
	width: 21.5625rem;
	z-index: 1;
}

.error-page__inner {
	max-width: 39.375rem;
}

.error-page__number {
	color: #fff;
	font-family: "Lato", sans-serif;
	font-size: 5rem;
	letter-spacing: 0.5em;
	line-height: 1.2;
	padding-top: 3.25rem;
	position: relative;
	text-align: center;
	text-indent: 0.5em;
	z-index: 2;
}

.error-page__message {
	color: #fff;
	font-family: "Lato", sans-serif;
	line-height: 1.5;
	text-align: center;
}

.error-page__btn {
	margin-top: 2.5rem;
	text-align: center;
}

.footer {
	background: #408f95;
}

.footer__inner {
	max-width: 39.375rem;
}

.footer__logo {
	max-width: 7.5rem;
}

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

.footer__sns-icons {
	display: flex;
	gap: 1rem;
	margin-top: 1rem;
}

.footer__sns-icon {
	width: 1.5rem;
}

.footer__copyright {
	color: #fff;
	font-family: "Gotu", sans-serif;
	font-size: 0.75rem;
	font-weight: 400;
	line-height: 1.5;
	margin-top: 1.75rem;
	text-align: center;
}

.form__wrap:nth-of-type(1) {
	border-bottom: 1px dashed #408f95;
	padding-bottom: 1.5rem;
}

.form__wrap + .form__wrap {
	border-bottom: 1px dashed #408f95;
	margin-top: 1.5rem;
	padding-bottom: 1.5rem;
}

.form__label {
	color: #0d2936;
	font-weight: 700;
	line-height: 1.4375;
}

.form__label span {
	background-color: #c94800;
	color: #fff;
	display: inline-block;
	font-size: 0.75rem;
	letter-spacing: 0.4em;
	margin-left: 0.5rem;
	padding: 0.125rem 0.875rem;
}

.form__input,
.form__select,
.form__radio,
.form__checkbox,
.form__textarea {
	margin-top: 1rem;
}

.form__input,
.form__textarea {
	flex-grow: 1;
}

.form-input input {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	background-color: transparent;
	background-image: none;
	border: 1px solid #408f95;
	border-radius: 0;
	line-height: 1.4375;
	padding: 0.4375rem 0.9375rem;
	width: 100%;
}

.form-input input:focus {
	border: 1px solid #408f95;
	box-shadow: none;
	outline: none;
}

.form-input input::-moz-placeholder {
	color: #ddf0f1;
}

.form-input input::placeholder {
	color: #ddf0f1;
}

.form-select {
	flex-grow: 1;
}

.form-select select {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	background-image: url("../images/common/arrow-icon.svg");
	background-position: right 0.5rem top 0.875rem;
	background-repeat: no-repeat;
	background-size: 0.75rem;
	border: 1px solid #408f95;
	border-radius: 0;
	cursor: pointer;
	font-size: 0.75rem;
	line-height: 1.4166666667;
	padding: 0.625rem 0.4375rem 0.6875rem 0.4375rem;
	width: 100%;
}

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

.form-select select:focus {
	border: 1px solid #408f95;
	box-shadow: none;
	outline: none;
}

.wpcf7-list-item {
	display: block;
	margin-left: 0;
}

.form__checkbox .wpcf7-list-item:not(:first-child) {
	margin-top: 0.25rem;
}

.form-checkbox label {
	display: block;
}

.form-checkbox label:not(:first-of-type) {
	margin-top: 0.1875rem;
}

.form-checkbox input {
	display: none;
}

.form-checkbox input + span {
	cursor: pointer;
	display: inline-block;
	line-height: 1.1875;
	padding: 0 0 0 1.4375rem;
	position: relative;
}

.form-checkbox input + span::before {
	background: #fff;
	border: 1px solid #408f95;
	content: "";
	display: block;
	height: 0.875rem;
	left: 0;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	width: 0.875rem;
}

.form-checkbox input + span::after {
	border-bottom: 0.125rem solid #c94800;
	border-left: 0.125rem solid #c94800;
	content: "";
	display: block;
	height: 0.3125rem;
	left: 0;
	margin-left: 0.125rem;
	margin-top: -0.0625rem;
	opacity: 0;
	position: absolute;
	top: 50%;
	transform: translateY(-50%) rotate(-35deg);
	transition: 0.3s;
	width: 0.5625rem;
}

.form-checkbox input:checked + span::after {
	opacity: 1;
}

.form__textarea {
	height: 12.5rem;
}

.form-textarea textarea {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	background-color: transparent;
	background-image: none;
	border: 1px solid #408f95;
	border-radius: 0;
	font-size: 0.9375rem;
	height: 12.5rem;
	padding: 0.4375rem 0.875rem;
	resize: none;
	width: 100%;
}

.form-textarea textarea:focus {
	border: 1px solid #408f95;
	box-shadow: none;
	outline: none;
}

.contact__form-privacy {
	margin-top: 2.25rem;
	text-align: center;
}

.contact__form-privacy input {
	display: none;
}

.contact__form-privacy input + span {
	cursor: pointer;
	display: inline-block;
	font-size: 0.875rem;
	line-height: 1.5714285714;
	padding: 0 0 0 1.9375rem;
	position: relative;
	text-align: left;
}

.contact__form-privacy input + span::before {
	background: #fff;
	border: 1px solid #408f95;
	content: "";
	display: block;
	height: 1.375rem;
	left: 0;
	position: absolute;
	top: 0;
	width: 1.375rem;
}

.contact__form-privacy input + span::after {
	border-bottom: 0.125rem solid #c94800;
	border-left: 0.125rem solid #c94800;
	content: "";
	display: block;
	height: 0.5rem;
	left: 0;
	margin-left: 0.1875rem;
	margin-top: 0.3125rem;
	opacity: 0;
	position: absolute;
	top: 0;
	transform: rotate(-35deg);
	transition: 0.3s;
	width: 0.9375rem;
}

.contact__form-privacy input:checked + span::after {
	opacity: 1;
}

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

/* 入力フィールド全体に対する共通設定 */

.form-input input.wpcf7-not-valid,
.form-textarea textarea.wpcf7-not-valid {
	background-color: rgba(201, 72, 0, 0.2);
	border: 1px solid #c94800;
	color: #0d2936;
}

.form-input input.wpcf7-not-valid::-moz-placeholder,
.form-textarea textarea.wpcf7-not-valid::-moz-placeholder {
	color: #fff;
}

.form-input input.wpcf7-not-valid::placeholder,
.form-textarea textarea.wpcf7-not-valid::placeholder {
	color: #fff;
}

.wpcf7-checkbox.wpcf7-not-valid input + span::before {
	background-color: rgba(201, 72, 0, 0.2);
	border: 1px solid #c94800;
}

.g-map {
	-o-object-fit: cover;
	aspect-ratio: 295/160;
	height: auto;
	margin-left: auto;
	margin-right: auto;
	margin-top: 1rem;
	object-fit: cover;
	overflow: hidden;
}

.g-map iframe {
	height: 100%;
	width: 100%;
}

.header {
	background-color: rgba(13, 41, 54, 0.68);
	height: 5rem;
	transition: background-color 0.3s ease;
}

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

.header.is-scrolled {
	background-color: #9a9a9a;
}

.header.is-open {
	background-color: #408f95;
	transition: 0.3s;
}

.header__inner {
	display: flex;
	height: inherit;
	justify-content: space-between;
	padding-left: 0.9375rem;
}

.header__logo {
	height: inherit;
	max-width: 6.375rem;
	width: 100%;
	z-index: 999;
}

.header__logo a {
	align-items: center;
	display: flex;
	height: inherit;
}

.header__logo img {
	-o-object-fit: contain;
	height: 100%;
	object-fit: contain;
	width: 100%;
}

.header__nav {
	display: none;
	height: inherit;
}

.header__nav-items {
	display: flex;
	gap: 2.5rem;
	height: inherit;
}

.header__nav-item {
	height: inherit;
}

.header__nav-item a {
	align-items: center;
	color: #fff;
	display: flex;
	flex-direction: column;
	font-family: "Gotu", sans-serif;
	font-size: 1.125rem;
	height: inherit;
	justify-content: center;
	line-height: 1;
}

.header__nav-item a:hover {
	opacity: 1;
}

.header__nav-item span {
	display: block;
	font-family: "Noto Sans JP", sans-serif;
	font-size: 0.625rem;
	line-height: 1.5;
	margin-top: 0.25rem;
}

.header__hamburger {
	border: none;
	cursor: pointer;
	height: inherit;
	margin: 0;
	outline: none;
	padding: 0;
	position: relative;
	transition: 0.3s;
	width: 3.875rem;
	z-index: 999;
}

.header__hamburger span {
	background-color: #fff;
	display: block;
	height: 0.0625rem;
	left: 50%;
	position: relative;
	transform: translateX(-50%);
	transition: 0.3s;
	width: 2rem;
}

.header__hamburger span:nth-of-type(1) {
	top: -0.6875rem;
}

.header__hamburger span:nth-of-type(2) {
	top: 0;
}

.header__hamburger span:nth-of-type(3) {
	top: 0.6875rem;
}

.header__hamburger.is-open span:nth-of-type(1) {
	top: 0;
	transform: translateX(-50%) rotate(37deg);
	width: 2.5rem;
}

.header__hamburger.is-open span:nth-of-type(2) {
	opacity: 0;
}

.header__hamburger.is-open span:nth-of-type(3) {
	top: -0.125rem;
	transform: translateX(-50%) rotate(-37deg);
	width: 2.5rem;
}

.hover-underline {
	display: inline-block;
	position: relative;
}

.hover-underline::after {
	background: #fff;
	bottom: 1.375rem;
	content: "";
	height: 1px;
	left: 0;
	position: absolute;
	transform: scaleX(0);
	transform-origin: center;
	transition: transform 0.5s ease;
	width: 100%;
}

.hover-underline:hover::after {
	transform: scaleX(1);
}

.hover-underline:focus::after {
	transform: scaleX(1);
}

.information-list__item.information-list__item--sub {
	border: 2px solid #408f95;
	display: none;
	padding: calc(1.5rem - 2px);
}

.information-list__item.information-list__item--sub.is-active {
	display: block;
}

.information-list__item-img {
	width: 100%;
}

.information-list__item-img.information-list__item-img--sub {
	margin-top: 0.5rem;
}

.information-list__item-img img {
	-o-object-fit: cover;
	aspect-ratio: 345/227;
	height: auto;
	object-fit: cover;
	width: 100%;
}

.information-list__item-img.information-list__item-img--sub img {
	aspect-ratio: 297/189;
}

.information-list__item-text {
	color: #0d2936;
	font-size: 1.25rem;
	font-weight: 700;
	line-height: 1.2;
	margin-top: 1.5rem;
	padding-bottom: 0.25rem;
}

.information-list__item-text.information-list__item-text--sub {
	font-size: 1.5rem;
	margin-top: 0rem;
}

.information-list__description {
	border-top: 1px solid #408f95;
	color: #0d2936;
	font-weight: 400;
	line-height: 1.5;
	padding-top: 0.5rem;
}

.information__inner {
	max-width: 39.375rem;
}

.information__list {
	margin-top: 1.875rem;
}

.information__list.information__list--sub {
	margin-top: 0rem;
}

.information__btn {
	margin-top: 2.4375rem;
	text-align: center;
}

.inner {
	margin-left: auto;
	margin-right: auto;
	padding-left: 15px;
	padding-right: 15px;
	width: 100%;
}

/* 初期設定 */

button {
	background: none;
	height: 100%;
	padding: 0;
}

:where(dialog) {
	background-color: transparent;
	background-color: initial;
	border: medium none currentColor;
	border: initial;
	color: inherit;
	max-width: none;
	max-width: initial;
	overflow: visible;
	overflow: initial;
	padding: 0;
	padding: initial;
	width: auto;
	width: initial;
}

body:has(dialog[open]) {
	overflow: hidden;
}

/* モーダルのスタイル ============ */

/* ダイアログの初期状態（非表示時） */

dialog::backdrop {
	opacity: 0;
	transition: background 0.5s ease-in-out;
}

/* ダイアログ表示時のスタイル */

dialog.is-open {
	opacity: 1;
}

dialog.is-open::backdrop {
	background: rgba(32, 32, 32, 0.8);
	opacity: 1;
}

.modal__inner {
	display: inline-block;
	height: auto;
	max-width: 100%;
	position: relative;
}

.modal__img img {
	-o-object-fit: contain;
	height: 100%;
	max-height: 90vh;
	max-width: 100%; /* 親より大きくならないようにする */
	object-fit: contain;
	width: 100%;
}

.mv {
	height: 100vh;
	min-height: 25rem;
	position: relative;
	z-index: 1;
}

.mv__inner {
	height: inherit;
	min-height: inherit;
}

.mv__title-wrap {
	color: #fff;
	left: 50%;
	opacity: 0;
	position: absolute;
	text-align: center;
	top: 50%;
	transform: translate(-50%, -50%);
	transition: opacity 1s ease;
	z-index: 2;
}

/* 緑色のローディング中タイトル */

.mv__title-wrap.is-loading {
	color: #408f95;
	opacity: 1;
}

/* 白色のメインタイトル */

.mv__title-wrap.is-main {
	color: #fff;
	opacity: 1;
}

/* ローディング中はフェードアウト用 */

.mv__title-wrap.is-hidden {
	opacity: 0;
}

.mv__loading-title {
	color: #408f95;
}

.mv__main-title {
	font-family: "Lato", sans-serif;
	font-size: 2.5rem;
	font-weight: 400;
	letter-spacing: 0.54em;
	line-height: 1.2;
	text-indent: 0.54em;
}

.mv__sub-title {
	font-family: "Gotu", sans-serif;
	font-size: 1.25rem;
	font-weight: 400;
	line-height: 1.65;
}

/* ローディングアニメーション全体 */

.fv-loading {
	animation: out 3s forwards;
	bottom: 0;
	height: 100vh;
	left: 0;
	overflow: hidden;
	position: fixed;
	right: 0;
	top: 0;
	width: 100%;
	z-index: 9999;
}

/* ローディング内のコンテナ */

.fv-loading__container {
	display: flex;
	flex-direction: column;
	height: 100%;
	position: relative;
	width: 100%;
}

/* 左右のスプリット画像 */

.fv-loading__split-left,
.fv-loading__split-right {
	height: 100vh;
	overflow: hidden;
	position: relative;
	width: 100vw;
}

/* 左右画像共通の初期設定 */

.fv-loading__split-left img,
.fv-loading__split-right img {
	-o-object-fit: cover;
	animation: fadeSlideUp 1s ease-in-out forwards;
	height: 100%;
	object-fit: cover;
	position: absolute;
	transform: translateY(100%);
	width: 100%;
}

/* 左側画像のスライドイン */

.fv-loading__split-left img {
	-o-object-position: center bottom;
	animation: slideInTop 2.5s cubic-bezier(0.7, 0, 0.8, 1) forwards;
	object-position: center bottom;
}

/* 右側画像のアニメーション */

.fv-loading__split-right img {
	-o-object-position: center top;
	animation: slideInRightFastShrink 2.5s cubic-bezier(0.7, 0, 0.8, 1) forwards;
	animation-delay: 0.2s;
	object-position: center top;
}

.mv__swiper,
.mv__swiper .mv__swiper-img,
.mv__swiper .mv__swiper-img picture,
.mv__swiper .mv__swiper-img img {
	height: inherit;
	min-height: inherit;
}

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

/* Swiperの初期状態（非表示） */

.js-mv-swiper {
	opacity: 0;
	transition: opacity 0.6s ease, visibility 0s linear 0.6s;
	visibility: hidden;
}

/* 表示状態（ローディング後にJSで付与するクラス） */

.js-mv-swiper.is-visible {
	opacity: 1;
	transition-delay: 0s;
	visibility: visible;
}

.nav {
	grid-column-gap: 2.4375rem;
	-moz-column-gap: 2.4375rem;
	column-gap: 2.4375rem;
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	margin-top: 0.75rem;
	padding-left: 1.4375rem;
}

.nav.nav--margin {
	-moz-column-gap: 1.4375rem;
	column-gap: 1.4375rem;
	margin-top: 0rem;
}

.nav__items:nth-child(1) {
	order: 1;
}

.nav__items:nth-child(2) {
	order: 3;
}

.nav__items:nth-child(3) {
	order: 2;
}

.nav__items:nth-child(4) {
	order: 4;
}

.nav__item.nav__item--title {
	margin-top: 1rem;
	position: relative;
}

.nav__item.nav__item--title a {
	color: #fff;
	display: inline-block;
	font-size: 1rem;
	font-weight: 700;
	line-height: 1.125;
	padding: 0.75rem 0;
}

.nav__item.nav__item--title::before {
	background: url("../images/common/footer-icon.webp");
	background-position: center center;
	background-repeat: no-repeat;
	background-size: contain;
	content: "";
	height: 1.125rem;
	left: -1.375rem;
	position: absolute;
	top: 0.75rem;
	width: 1.125rem;
}

.nav__item.nav__item--sitemap {
	margin-top: 1rem;
	position: relative;
}

.nav__item.nav__item--sitemap a {
	color: #0d2936;
	display: inline-block;
	font-size: 1rem;
	font-weight: 700;
	line-height: 1.125;
	padding: 0.75rem 0;
}

.nav__item.nav__item--sitemap::before {
	background: url("../images/common/sitemap-icon.webp");
	background-position: center center;
	background-repeat: no-repeat;
	background-size: contain;
	content: "";
	height: 1.125rem;
	left: -1.375rem;
	position: absolute;
	top: 0.75rem;
	width: 1.125rem;
}

.nav__item a {
	color: #fff;
	display: inline-block;
	font-size: 1rem;
	font-weight: 400;
	line-height: 1.125;
	padding: 0.75rem 0;
	white-space: nowrap;
}

.nav__item.nav__item--color a {
	color: #0d2936;
}

.pagenavi .wp-pagenavi {
	clear: both;
	display: flex;
	gap: 0.75rem;
	justify-content: center;
}

.pagenavi .wp-pagenavi a,
.pagenavi .wp-pagenavi span {
	align-content: center;
	background-color: #fff;
	border: 1px solid #408f95;
	color: #408f95;
	font-family: "Lato", sans-serif;
	font-weight: 700;
	height: 2.375rem;
	justify-content: center;
	line-height: 1;
	min-width: 2.375rem;
	padding-left: 0.3125rem;
	padding-right: 0.3125rem;
	place-content: center;
	text-align: center;
	transition: 0.3s;
	white-space: nowrap;
}

.pagenavi .wp-pagenavi .current {
	background-color: #408f95;
	border-color: #408f95;
	color: #fff;
}

.wp-pagenavi .previouspostslink {
	margin-right: 1.75rem;
	position: relative;
}

.wp-pagenavi .previouspostslink::before {
	border-left: 1px solid #408f95;
	border-top: 1px solid #408f95;
	content: "";
	display: block;
	height: 0.625rem;
	left: 0.9375rem;
	position: absolute;
	top: 50%;
	transform: translateY(-50%) rotate(-45deg);
	width: 0.625rem;
}

.wp-pagenavi .nextpostslink {
	margin-left: 1.75rem;
	position: relative;
}

.wp-pagenavi .nextpostslink::before {
	border-right: 1px solid #408f95;
	border-top: 1px solid #408f95;
	content: "";
	display: block;
	height: 0.625rem;
	position: absolute;
	right: 0.9375rem;
	top: 50%;
	transform: translateY(-50%) rotate(45deg);
	transition: border 0.3s;
	width: 0.625rem;
}

.pagetop {
	bottom: 1rem;
	filter: drop-shadow(0px 4px 4px rgba(0, 0, 0, 0.25));
	opacity: 0;
	position: fixed;
	right: 0.9375rem;
	transition: opacity 0.3s, visibility 0.3s;
	visibility: hidden;
	z-index: 999;
}

.pagetop.is-open {
	opacity: 1;
	visibility: visible;
}

.pagetop.is-hidden {
	opacity: 0;
	pointer-events: none;
	transition: opacity 0.3s, visibility 0.3s;
	visibility: hidden;
}

.pagetop img {
	border-radius: 100vh;
	width: 3rem;
}

.price-category__title {
	border-bottom: 1px solid #408f95;
	color: #0d2936;
	font-weight: 700;
	line-height: 1.5;
	padding-bottom: 0.25rem;
}

.price-category__item {
	display: flex;
	justify-content: space-between;
	margin-top: 0.5rem;
}

.price-category__item-name {
	color: #0d2936;
	font-size: 0.875rem;
	font-weight: 400;
	line-height: 1.7142857143;
}

.price-category__item-price {
	color: #0d2936;
	font-size: 0.875rem;
	font-weight: 400;
	line-height: 1.7142857143;
	padding-left: 0.9375rem;
}

.price-lists__category {
	margin-top: 2.4375rem;
}

.price {
	background: #ddf0f1;
	position: relative;
}

.price__inner {
	max-width: 39.375rem;
}

.price__content {
	margin-top: 1.8125rem;
}

.price__img {
	width: 100%;
}

.price__img img {
	-o-object-fit: cover;
	aspect-ratio: 345/227;
	object-fit: cover;
	width: 100%;
}

.price__btn {
	margin-top: 2.5rem;
	text-align: center;
}

.privacy-policy {
	position: relative;
}

.privacy-policy::after {
	background: url("../images/common/voice-fish-img.webp");
	background-repeat: no-repeat;
	background-size: cover;
	content: "";
	height: 3.4375rem;
	left: max(0px, 50% - min(48vw, 10.75rem));
	position: absolute;
	top: -1.5625rem;
	width: 7.5rem;
	z-index: -1;
}

.privacy-policy__inner {
	max-width: 39.375rem;
}

.privacy-policy__title {
	color: #0d2936;
	font-size: 1.5rem;
	font-weight: 500;
	line-height: 1.4583333333;
}

.privacy-policy__introduction {
	color: #0d2936;
	line-height: 2;
	margin-top: 2.5rem;
}

.privacy-policy__items ol {
	counter-reset: number;
	line-height: 2;
	margin-top: 1.9375rem;
}

.privacy-policy__items ol:nth-of-type(2),
.privacy-policy__items ol:nth-of-type(3),
.privacy-policy__items ol:nth-of-type(4) {
	margin-top: 0;
}

.privacy-policy__items li {
	padding-left: 1.5rem;
	text-indent: -1.1875rem;
}

.privacy-policy__items li::before {
	content: counter(number) ". ";
	counter-increment: number;
}

.privacy-policy__items p {
	color: #0d2936;
	line-height: 2;
	margin-top: 1.9375rem;
}

.section-title {
	text-align: center;
}

.section-title__main {
	color: #0d2936;
	font-family: "Gotu", sans-serif;
	font-size: 2rem;
	font-weight: 400;
	line-height: 1;
}

.section-title__main.section-title__main--big {
	font-size: 5rem;
}

.section-title__main::first-letter {
	color: #408f95;
}

.section-title__sub {
	color: #408f95;
	font-size: 0.75rem;
	font-weight: 400;
	line-height: 1.5;
	margin-top: 0.375rem;
}

.section-title__sub.section-title__sub--contact {
	margin-top: -0.3125rem;
}

.sitemap {
	position: relative;
}

.sitemap::after {
	background: url("../images/common/voice-fish-img.webp");
	background-repeat: no-repeat;
	background-size: cover;
	content: "";
	height: 3.4375rem;
	left: max(0px, 50% - min(48vw, 10.75rem));
	position: absolute;
	top: 0.3125rem;
	width: 7.5rem;
	z-index: -1;
}

.sitemap__inner {
	max-width: 39.375rem;
}

.sitemap__nav {
	grid-column-gap: 3.125rem;
	-moz-column-gap: 3.125rem;
	column-gap: 3.125rem;
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	margin-top: 0.75rem;
	padding-left: 1.4375rem;
}

.sub-about {
	position: relative;
}

.about.sub-about::before {
	background: url("../images/common/voice-fish-img.webp");
	background-repeat: no-repeat;
	background-size: cover;
	content: "";
	height: 3.4375rem;
	left: max(0px, 50% - min(46vw, 25rem));
	position: absolute;
	top: -1.5625rem;
	width: 7.5rem;
	z-index: -1;
}

.sub-blog-archive__link {
	color: #408f95;
	cursor: pointer;
	font-size: 1.5rem;
	line-height: 1.2083333333;
	padding-left: 2.0625rem;
	position: relative;
}

.sub-blog-archive__link::before {
	border-color: transparent transparent transparent #408f95;
	border-style: solid;
	border-width: 0.6875rem 0 0.6875rem 1rem;
	content: "";
	display: inline-block;
	height: 0;
	left: 0.25rem;
	position: absolute;
	top: 0.4375rem;
	transition: 0.3s;
	width: 0;
}

.sub-blog-archive__item:nth-of-type(2) .sub-blog-archive__link::before {
	top: 0.25rem;
}

.sub-blog-archive__link.is-open::before {
	transform: rotate(90deg);
}

.sub-blog-archive__month {
	grid-gap: 0.625rem;
	display: grid;
	gap: 0.625rem;
	margin-top: 0.625rem;
}

.sub-blog-archive__month-item {
	color: #408f95;
	display: block;
	font-size: 1.5rem;
	line-height: 1.2083333333;
	padding-left: 3.4375rem;
	position: relative;
}

.sub-blog-archive__month-item::before {
	border-color: transparent transparent transparent #408f95;
	border-style: solid;
	border-width: 0.625rem 0 0.625rem 0.9375rem;
	content: "";
	display: inline-block;
	height: 0;
	left: 1.9375rem;
	position: absolute;
	top: 0.3125rem;
	width: 0;
}

.sub-blog-cards {
	grid-gap: 2.5rem;
	display: grid;
	gap: 2.5rem;
}

.sub-blog-lists {
	grid-gap: 1.5rem;
	display: grid;
	gap: 1.5rem;
}

.sub-blog-popularity {
	background-color: #fff;
	box-shadow: 2px 2px 10px rgba(0, 0, 0, 0.25);
	display: flex;
	gap: 1rem;
	height: 100%;
	padding: 1rem;
}

.sub-blog-popularity__item-img {
	overflow: hidden;
	width: 46.2%;
}

.sub-blog-popularity__item-img img {
	-o-object-fit: cover;
	aspect-ratio: 121/90;
	object-fit: cover;
	transition: 0.6s;
	width: 100%;
}

.sub-blog-popularity__title-wrap {
	width: 47.7%;
}

.sub-blog-popularity__item-category {
	color: #0d2936;
	font-family: "Gotu", sans-serif;
	font-size: 0.75rem;
	font-weight: 400;
	line-height: 1.5;
}

.sub-blog-popularity__item-title {
	color: #0d2936;
	font-weight: 500;
	line-height: 1.5;
	margin-top: 0.25rem;
}

.sub-blog-popularity__item-text {
	color: #0d2936;
	font-weight: 400;
	line-height: 1.5;
	margin-top: 1rem;
}

.sub-blog-review__item-img {
	margin-top: 1.875rem;
}

.sub-blog-review__item-img img {
	-o-object-fit: cover;
	aspect-ratio: 294/218;
	height: auto;
	object-fit: cover;
}

.sub-blog-review__title-wrap {
	margin-top: 1rem;
}

.sub-blog-review__item-age {
	color: #0d2936;
	font-size: 0.75rem;
	line-height: 1.5;
}

.sub-blog-review__item-title {
	color: #0d2936;
	font-size: 1.5rem;
	font-weight: 500;
	line-height: 1.4583333333;
	margin-top: 0.5rem;
}

.sub-blog-sidebar {
	grid-gap: 5.625rem;
	display: grid;
	gap: 5.625rem;
}

.sub-blog-sidebar__item:first-child {
	padding-top: 0.5rem;
}

.sub-blog-sidebar__title {
	color: #0d2936;
	font-size: 1.5rem;
	font-weight: 400;
	line-height: 1.4583333333;
	padding-left: 5.125rem;
	position: relative;
}

.sub-blog-sidebar__title::before {
	background: #408f95;
	content: "";
	height: 3.125rem;
	left: 0;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	width: 0.5rem;
}

.sub-blog-sidebar__title::after {
	background: url(../images/common/sub-blog-icon.webp);
	background-position: center center;
	background-repeat: no-repeat;
	background-size: contain;
	content: "";
	height: 3.125rem;
	left: 1.5rem;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	width: 3.125rem;
	z-index: 1;
}

.sub-blog-sidebar__list {
	margin-top: 1.875rem;
}

.sub-blog-sidebar__cards {
	margin-top: 1.875rem;
}

.sub-blog-sidebar__archive-list {
	grid-gap: 0.625rem;
	display: grid;
	gap: 0.625rem;
	margin-top: 2.125rem;
}

.sub-blog {
	position: relative;
}

.sub-blog::before {
	background: url("../images/common/voice-fish-img.webp");
	background-repeat: no-repeat;
	background-size: cover;
	content: "";
	height: 3.4375rem;
	left: max(0px, 50% - min(46vw, 25rem));
	position: absolute;
	top: -1.5rem;
	width: 7.5rem;
	z-index: -1;
}

.sub-blog__inner {
	display: flex;
	flex-direction: column;
	max-width: 39.375rem;
}

.sub-blog__pagenavi {
	margin-top: 5.3125rem;
}

.sub-blog__sidebar {
	margin-top: 5.0625rem;
	padding-left: 1.5625rem;
	padding-right: 1.625rem;
}

.sub-blog__category-link {
	border-bottom: 1px solid #f0ecf4;
	display: block;
	font-size: 1.125rem;
	line-height: 1.3;
	padding: 1.5rem 1.875rem 1.5rem 0;
	position: relative;
}

.sub-blog__category-link::before {
	border-right: 0.125rem solid #333;
	border-top: 0.125rem solid #333;
	content: "";
	height: 0.5rem;
	position: absolute;
	right: 1.25rem;
	top: 50%;
	transform: translateY(-50%) rotate(45deg);
	transition: 0.3s;
	width: 0.5rem;
}

.sub-blog__btn {
	margin-top: 2.6875rem;
	text-align: center;
}

.sub-campaign-cards {
	grid-gap: 2.4375rem;
	display: grid;
	gap: 2.4375rem;
	grid-template-columns: repeat(1, 1fr);
}

.sub-campaign__cards {
	margin-left: auto;
	margin-right: auto;
	margin-top: 2.5rem;
	width: 81.159%;
}

.sub-campaign {
	position: relative;
}

.sub-campaign::before {
	background: url("../images/common/voice-fish-img.webp");
	background-repeat: no-repeat;
	background-size: cover;
	content: "";
	height: 3.4375rem;
	left: max(0px, 50% - min(46vw, 25rem));
	position: absolute;
	top: -1.5625rem;
	width: 7.5rem;
	z-index: -1;
}

.sub-campaign__inner {
	max-width: 43.375rem;
}

.sub-campaign__pagenavi {
	margin-top: 5.3125rem;
}

.sub-contact-thanks {
	position: relative;
	text-align: center;
}

.sub-contact-thanks::before {
	background: url("../images/common/voice-fish-img.webp");
	background-repeat: no-repeat;
	background-size: cover;
	content: "";
	height: 3.4375rem;
	left: max(0px, 50% - min(48vw, 10.6875rem));
	position: absolute;
	top: -1.5625rem;
	width: 7.5rem;
	z-index: -1;
}

.sub-contact-thanks__title {
	color: #0d2936;
	line-height: 1.125;
}

.sub-contact-thanks__message {
	color: #0d2936;
	line-height: 1.4375;
	margin-top: 2.5rem;
}

.sub-contact {
	position: relative;
}

.sub-contact::before {
	background: url("../images/common/voice-fish-img.webp");
	background-repeat: no-repeat;
	background-size: cover;
	content: "";
	height: 3.4375rem;
	left: max(0px, 50% - min(46vw, 25rem));
	position: absolute;
	top: -1.5rem;
	width: 7.5rem;
	z-index: -1;
}

.sub-contact__inner {
	max-width: 39.375rem;
}

.sub-faq-lists {
	grid-gap: 2.5rem;
	display: grid;
	gap: 2.5rem;
}

.sub-faq-list__item-question {
	background-color: #408f95;
	color: #fff;
	cursor: pointer;
	line-height: 1.4375;
	padding: 1rem;
	position: relative;
}

.sub-faq-list__item-question::before,
.sub-faq-list__item-question::after {
	background: #fff;
	content: "";
	height: 0.0625rem;
	position: absolute;
	right: 1rem;
	top: 50%;
	transition: 0.3s;
	width: 1.75rem;
}

.sub-faq-list__item-question::after {
	transform: rotate(0deg);
}

.sub-faq-list__item-question.is-open::after {
	transform: rotate(90deg);
}

.sub-faq-list__item-answer {
	border: 1px solid #408f95;
	color: #0d2936;
	line-height: 1.4375;
	padding: 1.4375rem 0.9375rem;
}

.sub-faq {
	position: relative;
}

.sub-faq__inner {
	max-width: 39.375rem;
}

.sub-faq::after {
	background: url("../images/common/voice-fish-img.webp");
	background-repeat: no-repeat;
	background-size: cover;
	content: "";
	height: 3.4375rem;
	left: max(0px, 50% - min(46vw, 25rem));
	position: absolute;
	top: -1.5625rem;
	width: 7.5rem;
	z-index: -1;
}

.sub-gallery-list {
	grid-gap: 0.5rem;
	display: grid;
	gap: 0.5rem;
}

.sub-gallery-list__item img {
	-o-object-fit: cover;
	aspect-ratio: 345/219;
	height: 100%;
	object-fit: cover;
	width: 100%;
}

.sub-gallery-list__item:nth-of-type(6n + 1) img,
.sub-gallery-list__item:nth-of-type(6n + 6) img {
	aspect-ratio: 345/523;
}

.sub-gallery {
	position: relative;
}

.sub-gallery__inner {
	max-width: 39.375rem;
}

.sub-gallery__list {
	margin-top: 2.5rem;
}

.sub-gallery__modal {
	align-items: center;
	display: none;
	justify-content: center;
	max-width: 43.75rem;
	opacity: 0;
	transition: opacity 0.3s ease-in-out, transform 0.3s ease-in-out; /* モーダル枠組みのスタイル */
	width: 95%;
}

.sub-gallery__modal[open] {
	display: flex;
	opacity: 1;
}

.sub-gallery__modal .modal__img {
	opacity: 0;
	transition: opacity 0.5s ease-in-out, transform 0.5s ease-in-out;
}

.sub-gallery__modal.is-open .modal__img {
	opacity: 1;
}

.sub-gallery__modal.is-closing {
	opacity: 0;
}

.sub-gallery__modal.is-closing .modal__img {
	opacity: 0;
}

.sub-gallery__modal.is-closing::backdrop {
	opacity: 0;
	transition: opacity 0.5s ease-in-out, transform 0.5s ease-in-out;
}

.sub-information {
	position: relative;
}

.sub-information::before {
	background: url("../images/common/voice-fish-img.webp");
	background-repeat: no-repeat;
	background-size: cover;
	content: "";
	height: 3.4375rem;
	left: max(0px, 50% - min(46vw, 25rem));
	position: absolute;
	top: -5.9375rem;
	width: 7.5rem;
	z-index: -1;
}

.sub-information__inner {
	max-width: 39.375rem;
}

.sub-information__list {
	margin-top: calc(1rem - 2px);
}

.sub-mv {
	min-height: 25rem;
	position: relative;
	z-index: 1;
}

.sub-mv__inner {
	min-height: inherit;
}

.sub-mv__title {
	color: #fff;
	font-family: "Lato", sans-serif;
	font-size: 2.5rem;
	font-weight: 400;
	left: 50%;
	line-height: 1;
	position: absolute;
	text-align: center;
	top: 50%;
	transform: translate(-50%, -50%);
	z-index: 2;
}

.sub-mv__img {
	background-color: #408f95;
}

.sub-mv__img img {
	-o-object-fit: cover;
	aspect-ratio: 375/460;
	height: 28.75rem;
	object-fit: cover;
	opacity: 0.7;
	width: 100%;
}

.sub-price-list {
	border-collapse: collapse;
	line-height: 1;
	text-align: center;
	width: 100%;
}

.sub-price-lists {
	grid-gap: 2.3125rem;
	display: grid;
	gap: 2.3125rem;
}

.sub-price-list__head {
	background-color: #408f95;
	border: 1px solid #408f95;
	color: #fff;
	font-weight: 700;
	line-height: 1.5;
	padding-bottom: 0.4375rem;
	padding-left: 2rem;
	padding-top: 0.4375rem;
	position: relative;
}

.sub-price-list__head::before {
	background: url("../images/common/sub-information-icon1-1.webp");
	background-position: center center;
	background-repeat: no-repeat;
	background-size: contain;
	content: "";
	height: 1.5rem;
	margin-left: -2rem;
	position: absolute;
	width: 1.5rem;
	z-index: 1;
}

.sub-price-list__data {
	border: 1px solid #408f95;
	color: #0d2936;
	line-height: 1.5;
	padding-bottom: 0.375rem;
	padding-left: 0.9375rem;
	padding-right: 0.9375rem;
	padding-top: 0.375rem;
	width: 70%;
}

.sub-price-list__value {
	border: 1px solid #408f95;
	color: #0d2936;
	line-height: 1.5;
	padding: 1.0625rem 1rem;
	text-align: right;
	width: 70%;
}

.sub-price {
	position: relative;
}

.sub-price__inner.inner {
	max-width: 39.375rem;
}

.sub-price__inner::after {
	background: url("../images/common/voice-fish-img.webp");
	background-repeat: no-repeat;
	background-size: cover;
	content: "";
	height: 3.4375rem;
	left: max(0px, 50% - min(46vw, 25rem));
	position: absolute;
	top: -1.5rem;
	width: 7.5rem;
	z-index: -1;
}

.sub-tab {
	grid-gap: 1.25rem;
	grid-row-gap: 0.875rem;
	align-content: center;
	display: grid;
	gap: 1.25rem;
	grid-template-columns: repeat(2, auto);
	justify-content: center;
	place-content: center;
	row-gap: 0.875rem;
}

.sub-tab__menu-item a {
	background-color: #fff;
	border: 1px solid #408f95;
	color: #408f95;
	display: inline-block;
	font-size: 0.875rem;
	line-height: 1.5714285714;
	min-width: 10.125rem;
	padding: 0.3125rem;
	text-align: center;
	transition: 0.3s;
}

.sub-tab__menu-item.is-active a {
	background-color: #408f95;
	color: #fff;
}

.sub-voice {
	position: relative;
}

.sub-voice::before {
	background: url("../images/common/voice-fish-img.webp");
	background-repeat: no-repeat;
	background-size: cover;
	content: "";
	height: 3.4375rem;
	left: max(0px, 50% - min(46vw, 25rem));
	position: absolute;
	top: -1.5625rem;
	width: 7.5rem;
	z-index: -1;
}

.sub-voice__inner {
	max-width: 39.375rem;
}

.sub-voice__lists {
	margin-top: 2.5rem;
}

.sub-voice__pagenavi {
	margin-top: 5.0625rem;
}

.swiper-slide {
	flex-shrink: 0;
	width: 17.5rem;
}

.tab {
	grid-column-gap: 1.25rem;
	-moz-column-gap: 1.25rem;
	grid-row-gap: 1.25rem;
	align-content: center;
	column-gap: 1.25rem;
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	justify-content: center;
	place-content: center;
	row-gap: 1.25rem;
}

.tab__menu-item {
	background-color: #ddf0f1;
	color: #408f95;
	cursor: pointer;
	font-size: 0.875rem;
	line-height: 1.4285714286;
	min-width: 6.375rem;
	padding: 0.625rem 1rem;
	text-align: center;
	transition: 0.3s;
}

.tab__menu-item.is-active {
	background-color: #408f95;
	box-shadow: 2px 2px 4px rgba(0, 0, 0, 0.25);
	color: #fff;
}

.terms {
	position: relative;
}

.terms::after {
	background: url("../images/common/voice-fish-img.webp");
	background-repeat: no-repeat;
	background-size: cover;
	content: "";
	height: 3.4375rem;
	left: max(0px, 50% - min(48vw, 10.75rem));
	position: absolute;
	top: -1.5625rem;
	width: 7.5rem;
	z-index: -1;
}

.terms__inner {
	max-width: 39.375rem;
}

.terms__title {
	color: #0d2936;
	font-size: 1.5rem;
	font-weight: 500;
	line-height: 1.4583333333;
}

.terms__introduction {
	color: #0d2936;
	line-height: 2;
	margin-top: 2.5rem;
}

.terms__items ol {
	counter-reset: number;
	line-height: 2;
	margin-top: 1.9375rem;
}

.terms__items li {
	padding-left: 1.5rem;
	text-indent: -1.1875rem;
}

.terms__items li::before {
	content: counter(number) ". ";
	counter-increment: number;
}

.terms__items p:first-of-type {
	margin-top: 0;
}

.terms__items p {
	color: #0d2936;
	line-height: 2;
	margin-top: 1.9375rem;
}

.voice-card-list {
	background-color: #fff;
	box-shadow: 2px 2px 10px rgba(0, 0, 0, 0.25);
	display: flex;
	flex-direction: column;
	height: 100%;
	padding: 0.9375rem 1rem 1.5rem;
}

.voice-card-list__item-content {
	display: flex;
}

.voice-card-list__item-info {
	border-bottom: 1px solid #408f95;
	width: 47.6038338658%;
}

.voice-card-list__item-age {
	color: #0d2936;
	font-size: 0.75rem;
	font-weight: 400;
	line-height: 1.5;
}

.voice-card-list__item-category {
	border: 1px solid #408f95;
	color: #408f95;
	display: inline-block;
	font-size: 0.75rem;
	font-weight: 400;
	line-height: 1.8333333333;
	padding: 0.1875rem 0.6875rem;
}

.voice-card-list__item-title {
	color: #0d2936;
	font-weight: 500;
	line-height: 1.4375;
	margin-top: 0.25rem;
	padding-bottom: 0.25rem;
}

.voice-card-list__item-img {
	margin-left: 0.8125rem;
	margin-top: 0.5625rem;
	width: 48.2428115016%;
}

.voice-card-list__item-img img {
	-o-object-fit: cover;
	aspect-ratio: 151/117;
	object-fit: cover;
	width: 100%;
}

.voice-card-list__item-text {
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 7;
	color: #0d2936;
	display: -webkit-box;
	font-weight: 400;
	line-height: 1.5;
	margin-top: 1rem;
	overflow: hidden;
	text-overflow: ellipsis;
}

.voice-card-lists {
	grid-gap: 2.4375rem;
	grid-row-gap: 2.4375rem;
	display: grid;
	gap: 2.4375rem;
	grid-template-columns: repeat(1, 1fr);
	row-gap: 2.4375rem;
}

.voice {
	position: relative;
}

.voice__inner {
	max-width: 39.375rem;
}

.voice__lists {
	margin-top: 2.8125rem;
}

.voice__btn {
	margin-top: 2.4375rem;
	text-align: center;
}

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

.u-desktop {
	display: block;
}

.u-mobile {
	display: none;
}

a:hover {
	opacity: 0.8;
}

html {
	font-size: 1.4814814815vw;
}

.layout-about {
	margin-top: 8.75rem;
}

.layout-blog {
	padding-top: 6.25rem;
}

.breadcrumb--white.layout-breadcrumb {
	padding-top: 6.125rem;
}

.layout-campaign {
	margin-top: 7.5rem;
}

.layout-contact {
	margin-top: 8.75rem;
}

.layout-contact.layout-contact--sub {
	margin-top: 8.75rem;
}

.layout-contact.layout-contact--margin {
	margin-top: 7.875rem;
}

.layout-footer {
	margin-top: 10rem;
	padding-bottom: 5rem;
	padding-top: 5rem;
}

.layout-footer.layout-footer--sub {
	margin-top: 10.25rem;
}

.layout-information {
	margin-top: 10.25rem;
	padding-bottom: 4.75rem;
	padding-top: 6.3125rem;
}

.layout-price {
	margin-top: 9rem;
	padding-bottom: 6.4375rem;
	padding-top: 6.25rem;
}

.layout-privacy-policy {
	margin-top: 9.375rem;
}

.layout-sitemap {
	margin-top: 8.625rem;
}

.layout-sub-about {
	margin-top: 14.375rem;
}

.layout-sub-blog {
	margin-top: 9.3125rem;
}

.layout-sub-campaign {
	margin-top: 9.375rem;
}

.layout-sub-contact-thanks {
	margin-top: 9.375rem;
}

.layout-sub-contact {
	margin-top: 9.375rem;
}

.layout-sub-faq {
	margin-top: 9.375rem;
}

.layout-sub-gallery {
	margin-top: 7.5rem;
}

.layout-sub-information {
	margin-top: 9.5rem;
}

.layout-sub-price {
	margin-top: 9.375rem;
}

.layout-sub-voice {
	margin-top: 9.375rem;
}

.layout-tab {
	margin-top: 9.25rem;
}

.layout-terms {
	margin-top: 9.375rem;
}

.layout-voice-card {
	margin-top: 9.0625rem;
}

.about::before {
	background: url("../images/common/about-bg-img.webp");
	background-position: center center;
	background-repeat: no-repeat;
	background-size: contain;
	bottom: -5.625rem;
	content: "";
	height: 11.3125rem;
	position: absolute;
	right: max(0px, 50% - min(48vw, 39.8125rem));
	width: 12.125rem;
	z-index: 1;
}

.about__content {
	margin-top: 7.5rem;
}

.about__shisa-img {
	max-width: 25rem;
	top: -4.9375rem;
}

.about__shisa-img img {
	aspect-ratio: 400/605;
}

.about__fish-img {
	max-width: 55rem;
}

.about__fish-img img {
	aspect-ratio: 880/581;
}

.about__text-wrapper {
	display: flex;
	gap: 2.5rem;
	max-width: 52.5rem;
	position: absolute;
	right: 2.5625rem;
	top: 7.625rem;
}

.about__text-wrapper.about__text-wrapper--sub {
	align-items: center;
}

.about__text {
	color: #fff;
	font-size: 5rem;
	line-height: 1.25;
	margin-top: 0rem;
}

.about__text.about__text--sub {
	left: 0;
	position: static;
	top: 0;
}

.about__description {
	color: #fff;
	margin-top: 0rem;
}

.about__description.about__description--sub {
	margin-top: 0rem;
}

.about__btn {
	margin-top: 2.375rem;
}

.blog-card-list:hover .blog-card-list__item-img img {
	transform: scale(1.2);
}

.blog-card-list__title-wrap {
	margin-top: 1.5rem;
}

.blog-card-lists {
	gap: 2.5rem;
	grid-template-columns: repeat(3, 1fr);
}

.blog-card-lists.blog-card-lists--2col {
	grid-template-columns: repeat(2, 1fr);
	row-gap: 5rem;
}

.blog-detail__item-category {
	font-size: 0.875rem;
	line-height: 1.2857142857;
}

.blog-detail__item-title {
	font-size: 2rem;
	line-height: 1.1875;
	padding-bottom: 0.5rem;
}

.blog-detail__container {
	margin-top: 2.5rem;
}

.blog-detail__container p:not(:first-of-type) {
	margin-top: 2.5rem;
}

.blog-detail__container img {
	aspect-ratio: 700/468;
}

.blog-detail__container ul {
	margin-top: 2.5rem;
}

.blog-detail__pagination {
	margin-top: 5rem;
}

.blog__inner::before {
	background: url("../images/common/blog-bg-img.webp");
	background-position: center center;
	background-repeat: no-repeat;
	background-size: cover;
	content: "";
	height: 60.6060606061%;
	left: 0;
	position: absolute;
	top: 0;
	width: 100%;
	z-index: -1;
}

.blog__inner::after {
	background: url("../images/common/blog-fish-img.webp");
	background-position: center center;
	background-repeat: no-repeat;
	background-size: contain;
	content: "";
	height: 12.5625rem;
	left: max(0px, 50% - min(48vw, 38.75rem));
	position: absolute;
	top: 1.5rem;
	width: 27.3125rem;
	z-index: 1;
}

.blog__lists {
	margin-top: 5rem;
}

.blog__btn {
	margin-top: 4.9375rem;
}

.btn:hover {
	opacity: 1;
}

.btn:hover::before {
	transform: scaleX(1);
	transform-origin: left top;
}

.btn:hover .btn__arrow::before,
.btn:hover .btn__arrow::after {
	background-color: #408f95;
}

.btn:hover span {
	color: #408f95;
}

.campaign-card__img img {
	aspect-ratio: 333/223;
}

.campaign-card__img.campaign-card__img--sub img {
	aspect-ratio: 520/347;
}

.campaign-card__title-wrap {
	margin-top: 1.5rem;
}

.campaign-card__title-wrap.campaign-card__title-wrap--sub {
	padding-left: 1.4375rem;
	padding-right: 1.4375rem;
}

.campaign-card__category {
	padding: 0.3125rem 0.9375rem 0.3125rem 1rem;
}

.campaign-card__title.campaign-card__title--sub {
	font-size: 1.5rem;
	line-height: 1.2083333333;
	margin-top: 0.4375rem;
}

.campaign-card__price-wrapper {
	padding: 0.875rem 2.125rem 2.5625rem 2.1875rem;
}

.campaign-card__price-wrapper.campaign-card__price-wrapper--sub {
	padding: 1.5625rem 1.5rem 2.75rem 1.5rem;
}

.campaign-card__text {
	font-size: 1rem;
}

.campaign-card__price-wrap {
	gap: 1.625rem;
}

.campaign-card__price-wrap.campaign-card__price-wrap--sub {
	gap: 2.5rem;
	margin-top: 0.5625rem;
}

.campaign-card__price-original {
	font-size: 1.5rem;
}

.campaign-card__price-original::before {
	left: 0;
	top: 0.625rem;
	width: 5.6875rem;
}

.campaign-card__price-discount {
	font-size: 2.5rem;
}

.campaign-card__text {
	font-size: 1rem;
	line-height: 1.5;
}

.campaign-card__meta {
	color: #408f95;
	margin-top: 1.75rem;
	text-align: center;
}

.campaign-card__meta-date {
	font-size: 1rem;
	font-weight: 700;
	line-height: 1.125;
}

.campaign__swiper {
	margin-top: 2.5rem;
}

.campaign__btn {
	margin-top: 4.125rem;
}

.contact::before {
	height: 8.625rem;
	left: auto;
	right: max(0px, 50% - min(48vw, 41.875rem));
	top: -2.3125rem;
	width: 18.8125rem;
}

.contact__list {
	align-items: center;
	background-color: #fff;
	box-shadow: 4px 4px 10px rgba(0, 0, 0, 0.25);
	display: flex;
	padding: 5rem 3.125rem;
	width: 100%;
}

.contact__item:nth-child(1) {
	padding-left: 0rem;
	padding-right: 0rem;
}

.contact__item:nth-child(2) {
	filter: none;
	margin-left: auto;
	margin-right: auto;
	margin-top: 0rem;
	padding-left: 1.25rem;
	z-index: 1;
}

.contact__item-content {
	border-right: 1px solid #408f95;
	padding-right: 5.0625rem;
}

.contact__item-logo {
	filter: none;
	max-width: 12.5rem;
	padding-bottom: 0.5rem;
}

.contact__wrap {
	display: flex;
	filter: none;
	max-width: 27.5rem;
	padding-top: 1.5rem;
}

.contact__wrap-text {
	padding-top: 0rem;
	width: 33.1818181818%;
}

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

.error-page {
	padding-bottom: 9.8125rem;
}

.error-page::before {
	height: 43.625rem;
	left: max(0px, 50% - min(48vw, 11.875rem));
	top: 5.625rem;
	width: 43.625rem;
}

.error-page__number {
	font-size: 10rem;
	line-height: 1.2;
	padding-top: 7.4375rem;
}

.error-page__message {
	margin-top: 1.5rem;
}

.error-page__btn {
	margin-top: 5rem;
}

.footer__logo-wrap {
	display: flex;
	gap: 2.5rem;
}

.footer__logo {
	max-width: 12.5rem;
}

.footer__sns-icons {
	margin-top: 0rem;
	padding-top: 2.3125rem;
}

.footer__sns-icon {
	width: 2rem;
}

.footer__copyright {
	font-size: 0.875rem;
	line-height: 1.2857142857;
	margin-top: 4.25rem;
}

.form__wrap {
	display: flex;
}

.form__wrap:nth-of-type(1) {
	padding-bottom: 2.5rem;
}

.form__wrap + .form__wrap {
	margin-top: 2.5rem;
	padding-bottom: 2.5rem;
}

.form__wrap.form__wrap--margin {
	margin-top: 2.125rem;
}

.form__label {
	max-width: 13.75rem;
	width: 100%;
}

.form__input,
.form__select,
.form__radio,
.form__checkbox,
.form__textarea {
	margin-top: 0;
}

.form-select select {
	background-position: right 0.5rem top 0.625rem;
	padding: 0.375rem 0.4375rem 0.3125rem 0.4375rem;
}

.form-checkbox label:not(:first-of-type) {
	margin-top: 0.25rem;
}

.contact__form-privacy {
	margin-top: 4.75rem;
}

.contact__form-privacy input + span {
	padding: 0 0 0 2.375rem;
}

.form__submit {
	margin-top: 2.5rem;
}

.g-map {
	aspect-ratio: 273/148;
	margin-left: 1.3125rem;
	margin-top: 0rem;
	width: 62.0454545455%;
}

.header {
	height: 5.625rem;
}

.header__inner {
	padding-left: 2.5rem;
	padding-right: 2.5rem;
}

.header__logo {
	filter: drop-shadow(0px 4px 4px rgba(0, 0, 0, 0.25));
	max-width: 8.3125rem;
}

.header__nav {
	display: block;
}

.header__hamburger {
	display: none;
}

.information-list__item {
	align-items: center;
	display: flex;
	gap: 3rem;
	justify-content: center;
}

.information-list__item.information-list__item--sub {
	padding-left: 0;
	padding-right: 0;
}

.information-list__item.information-list__item--sub.is-active {
	align-items: center;
	animation: fade 0.3s;
	display: flex;
	justify-content: center;
}

.information-list__item-img {
	width: 50%;
}

.information-list__item-img.information-list__item-img--sub {
	margin-top: 0;
	width: calc(45.5555555556% + 2px);
}

.information-list__item-img img {
	aspect-ratio: 540/356;
}

.information-list__item-img.information-list__item-img--sub img {
	aspect-ratio: 492/313;
}

.information-list__item-wrap {
	width: 45.5555555556%;
}

.information-list__item-wrap.information-list__item-wrap--sub {
	margin-left: 0;
	width: calc(45.5555555556% + 2px);
}

.information-list__item-text {
	font-size: 1.5rem;
	line-height: 1;
	margin-top: 0;
	padding-bottom: 0.5rem;
}

.information__list {
	margin-top: 2.5rem;
}

.inner {
	max-width: 1130px;
	padding-left: 25px;
	padding-right: 25px;
}

.mv__main-title {
	font-size: 5rem;
	line-height: 1.25;
}

.fv-loading__container {
	flex-direction: row;
}

.fv-loading__split-left,
.fv-loading__split-right {
	width: 50vw;
}

.fv-loading__split-left img {
	-o-object-position: right center;
	animation: slideInLeftFast 2.5s cubic-bezier(0.7, 0, 0.8, 1) forwards;
	object-position: right center;
}

.fv-loading__split-right img {
	-o-object-position: left center;
	animation: slideInRightFastShrink 2.5s cubic-bezier(0.7, 0, 0.8, 1) forwards;
	animation-delay: 0.2s;
	object-position: left center;
}

.nav {
	grid-column-gap: 0rem;
	-moz-column-gap: 0rem;
	column-gap: 0rem;
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	margin-top: 0.6875rem;
	padding-left: 0rem;
}

.nav__items {
	padding-left: 1.375rem;
}

.nav__items:not(:first-child) {
	padding-left: 2.375rem;
}

.nav__items:nth-child(2) {
	order: 2;
}

.nav__items:nth-child(3) {
	order: 3;
}

.nav__item.nav__item--title {
	margin-top: 0;
}

.nav__item.nav__item--title:not(:first-child) {
	margin-top: 1rem;
}

.nav__item.nav__item--sitemap {
	margin-top: 0;
}

.nav__item.nav__item--sitemap:not(:first-child) {
	margin-top: 1rem;
}

.pagenavi .wp-pagenavi a:hover {
	background-color: #408f95;
	border-color: #408f95;
	color: #fff;
	opacity: 1;
}

.wp-pagenavi .previouspostslink:hover::before {
	border-color: #fff;
	opacity: 1;
}

.wp-pagenavi .nextpostslink:hover::before {
	border-color: #fff;
	opacity: 1;
}

.pagetop {
	bottom: 1.25rem;
	right: 1.25rem;
}

.pagetop img {
	width: 5rem;
}

.price-category__item-name {
	font-size: 1rem;
	line-height: 1.5;
}

.price-category__item-price {
	font-size: 1rem;
	line-height: 1.5;
}

.price-lists__category:first-child {
	margin-top: 0rem;
}

.price__inner::after {
	background: url("../images/common/price-fish-img.webp");
	background-repeat: no-repeat;
	background-size: cover;
	bottom: 3.625rem;
	content: "";
	height: 12.5625rem;
	left: max(0px, 50% - min(48vw, 38.75rem));
	position: absolute;
	width: 27.3125rem;
	z-index: 1;
}

.price__content {
	display: flex;
	flex: 1;
	flex-wrap: wrap;
	gap: 5.9375rem;
	margin-top: 2.5rem;
	order: 2;
}

.price__img {
	flex: 1;
	order: 1;
	width: 45.5555555556%;
}

.price__img img {
	aspect-ratio: 492/745;
}

.price__lists {
	width: 45.5555555556%;
}

.price__btn {
	margin-top: 5rem;
}

.privacy-policy::after {
	height: 8.625rem;
	left: max(0px, 50% - min(48vw, 38.75rem));
	top: -4.375rem;
	width: 18.8125rem;
}

.privacy-policy__inner {
	max-width: 53.125rem;
}

.privacy-policy__title {
	font-size: 2rem;
	line-height: 1.4375;
}

.privacy-policy__items li {
	padding-left: 1.5625rem;
}

.section-title__main {
	font-size: 2.5rem;
}

.section-title__main.section-title__main--white {
	color: #fff;
}

.section-title__main.section-title__main--white::first-letter {
	color: #ddf0f1;
}

.section-title__sub {
	margin-top: 0.5rem;
}

.section-title__sub.section-title__sub--white {
	color: #fff;
}

.sitemap::after {
	background: none;
}

.sitemap__nav {
	grid-column-gap: 5.9375rem;
	-moz-column-gap: 5.9375rem;
	column-gap: 5.9375rem;
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	margin-top: 0rem;
	padding-left: 0rem;
}

.about.sub-about::before {
	height: 8.625rem;
	left: max(0px, 50% - min(48vw, 38.75rem));
	top: -9.3125rem;
	width: 18.8125rem;
}

.sub-blog::before {
	height: 8.625rem;
	left: max(0px, 50% - min(48vw, 38.75rem));
	top: -4.375rem;
	width: 18.8125rem;
}

.sub-blog__inner {
	flex-direction: row;
	gap: 5.375rem;
}

.sub-blog__pagenavi {
	margin-top: 5rem;
}

.sub-blog__sidebar {
	margin-top: 0;
	padding-left: 0;
	padding-right: 0;
	width: 27.22%;
}

.sub-campaign-cards {
	gap: 2.5rem;
	grid-template-columns: repeat(2, 1fr);
	row-gap: 5rem;
}

.sub-campaign__cards {
	width: 100%;
}

.sub-campaign::before {
	height: 8.625rem;
	left: max(0px, 50% - min(48vw, 38.75rem));
	top: -4.375rem;
	width: 18.8125rem;
}

.sub-campaign__pagenavi {
	margin-top: 5rem;
}

.sub-contact-thanks::before {
	height: 8.625rem;
	left: max(0px, 50% - min(48vw, 38.75rem));
	top: -4.375rem;
	width: 18.8125rem;
}

.sub-contact::before {
	height: 8.625rem;
	left: max(0px, 50% - min(48vw, 38.75rem));
	top: -4.375rem;
	width: 18.8125rem;
}

.sub-contact__inner {
	max-width: 46.875rem;
}

.sub-faq-list__item-question {
	font-size: 1.25rem;
	line-height: 1.45;
	padding: 1.625rem 7rem 1.5625rem 2.5rem;
}

.sub-faq-list__item-question::before,
.sub-faq-list__item-question::after {
	right: 2.5rem;
	width: 2rem;
}

.sub-faq-list__item-answer {
	margin-top: 1rem;
	padding: 2.4375rem;
}

.sub-faq__inner {
	max-width: 46.875rem;
}

.sub-faq::after {
	height: 8.625rem;
	left: max(0px, 50% - min(48vw, 38.75rem));
	top: -4.375rem;
	width: 18.8125rem;
}

.sub-gallery-list {
	grid-auto-flow: dense;
	grid-template-columns: repeat(13, 1fr);
}

.sub-gallery-list__item {
	grid-column: span 7;
	grid-row: span 1;
}

.sub-gallery-list__item:nth-of-type(6n + 1),
.sub-gallery-list__item:nth-of-type(6n + 6) {
	grid-column: span 6;
	grid-row: span 2;
}

.sub-gallery-list__item img {
	aspect-ratio: 580/369;
}

.sub-gallery-list__item:nth-of-type(6n + 1) img,
.sub-gallery-list__item:nth-of-type(6n + 6) img {
	aspect-ratio: 492/746;
}

.sub-gallery::after {
	background: url("../images/common/contact-fish-img.webp");
	background-position: center center;
	background-repeat: no-repeat;
	background-size: contain;
	content: "";
	height: 8.625rem;
	position: absolute;
	right: max(0px, 50% - min(48vw, 39.8125rem));
	top: -5rem;
	width: 18.8125rem;
	z-index: 1;
}

.sub-gallery__list {
	margin-top: 5rem;
}

.sub-gallery__modal {
	max-width: 57.5rem;
}

.sub-gallery__modal:nth-of-type(6n + 1),
.sub-gallery__modal:nth-of-type(6n + 6) {
	max-width: 37.5rem;
}

.sub-information::before {
	height: 8.625rem;
	left: max(0px, 50% - min(48vw, 38.75rem));
	top: -4.5rem;
	width: 18.8125rem;
}

.sub-information__list {
	margin-top: calc(1.5rem - 2px);
}

.sub-mv__title {
	font-size: 5rem;
	line-height: 1.25;
	top: 59%;
}

.sub-mv__img img {
	aspect-ratio: 1440/548;
	height: 34.25rem;
}

.sub-price-lists {
	gap: 5rem;
}

.sub-price-list__head {
	padding-bottom: 6.9375rem;
	padding-left: 0;
	padding-top: 2.5625rem;
	width: 28.57%;
}

.sub-price-list__head::before {
	height: 4rem;
	left: 50%;
	top: 43%;
	width: 4rem;
}

.sub-price-list__data {
	padding: 1.0625rem 0.9375rem;
	text-align: left;
	width: 48.57%;
}

.sub-price-list__value {
	padding: 1.0625rem 1rem;
	width: 48.57%;
}

.sub-price__inner.inner {
	max-width: 46.875rem;
}

.sub-price__inner::after {
	height: 8.625rem;
	left: max(0px, 50% - min(48vw, 38.75rem));
	top: -4.375rem;
	width: 18.8125rem;
}

.sub-tab {
	align-content: initial;
	gap: 1rem 2rem;
	grid-template-columns: repeat(auto-fit, minmax(auto, 10.125rem));
	justify-content: initial;
	place-content: initial;
}

.sub-tab__menu-item a:hover {
	background-color: #408f95;
	border-color: #408f95;
	color: #fff;
	opacity: 1;
}

.sub-voice::before {
	height: 8.625rem;
	left: max(0px, 50% - min(48vw, 38.75rem));
	top: -4.375rem;
	width: 18.8125rem;
}

.sub-voice__pagenavi {
	margin-top: 4.5rem;
}

.swiper-slide {
	width: 20.8125rem;
}

.tab {
	-moz-column-gap: 5.625rem;
	column-gap: 5.625rem;
}

.tab__menu-item {
	font-size: max(1rem, min(1.91vw, 1.5rem));
	line-height: 1.4583333333;
	padding: 1.8125rem 1.875rem 1.625rem 6.375rem;
	position: relative;
}

.tab__menu-item::before {
	-webkit-mask-image: url("../images/common/sub-information-icon.svg");
	-webkit-mask-size: cover;
	-webkit-mask-repeat: no-repeat;
	-webkit-mask-position: center center;
	background-color: currentColor;
	content: "";
	display: inline-block;
	height: 4rem;
	left: 1.875rem;
	mask-image: url("../images/common/sub-information-icon.svg");
	mask-position: center center;
	mask-repeat: no-repeat;
	mask-size: cover;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	width: 4rem;
}

.tab__menu-item.tab__menu-item--tab2 {
	padding: 1.8125rem 1.125rem 1.625rem 5.625rem;
}

.tab__menu-item.tab__menu-item--tab2::before {
	-webkit-mask-image: url("../images/common/sub-information-icon2.svg");
	left: 1.125rem;
	mask-image: url("../images/common/sub-information-icon2.svg");
}

.tab__menu-item.tab__menu-item--tab3::before {
	-webkit-mask-image: url("../images/common/sub-information-icon3.svg");
	mask-image: url("../images/common/sub-information-icon3.svg");
}

.tab__menu-item:hover {
	background-color: #408f95;
	border-color: #408f95;
	color: #fff;
	opacity: 1;
}

.tab__menu-item.is-active {
	box-shadow: 4px 4px 8px rgba(0, 0, 0, 0.25);
}

.terms::after {
	height: 8.625rem;
	left: max(0px, 50% - min(48vw, 38.75rem));
	top: -4.375rem;
	width: 18.8125rem;
}

.terms__inner {
	max-width: 53.125rem;
}

.terms__title {
	font-size: 2rem;
	line-height: 1.4375;
}

.terms__items li {
	padding-left: 1.5625rem;
}

.voice-card-list {
	padding: 1.5rem;
}

.voice-card-list__item-info {
	margin-top: 1.4375rem;
	width: 58.4745762712%;
}

.voice-card-list__item-wrap {
	align-items: flex-end;
	display: flex;
	justify-content: space-between;
}

.voice-card-list__item-category {
	padding: 0.3125rem 0.9375rem;
}

.voice-card-list__item-title {
	font-size: 1.5rem;
	line-height: 1.4583333333;
	margin-top: 0.5rem;
}

.voice-card-list__item-img {
	margin-left: 1rem;
	margin-top: 0rem;
	width: 38.1355932203%;
}

.voice-card-list__item-img img {
	aspect-ratio: 180/140;
}

.voice-card-list__item-text {
	margin-top: 2.4375rem;
}

.voice-card-lists {
	grid-template-columns: repeat(2, 1fr);
	row-gap: 5.0625rem;
}

.voice__inner::before {
	background: url("../images/common/voice-fish-img.webp");
	background-repeat: no-repeat;
	background-size: cover;
	content: "";
	height: 8.625rem;
	left: max(0px, 50% - min(48vw, 38.75rem));
	position: absolute;
	top: -7.5rem;
	width: 18.8125rem;
	z-index: 1;
}

.voice__inner::after {
	background: url("../images/common/voice-fish-img2.webp");
	background-repeat: no-repeat;
	background-size: cover;
	bottom: -4.5rem;
	content: "";
	height: 10.125rem;
	position: absolute;
	right: max(0px, 50% - min(48vw, 33.75rem));
	width: 4.4375rem;
	z-index: 1;
}

.voice__lists {
	margin-top: 1.875rem;
}

.voice__btn {
	margin-top: 5rem;
}

}

@media (min-width: 1080px) {

html {
	font-size: 16px;
}

}

@media (max-width: 375px) {

html {
	font-size: 4.2666666667vw;
}

}

@keyframes slideInLeftFast {

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

100% {
	transform: translateY(0);
}

}

@keyframes slideInRightFastShrink {

0% {
	transform: translateY(100%) scale(0.8);
}

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

}

@keyframes slideInTop {

0% {
	transform: translateY(-100%);
}

100% {
	transform: translateY(0);
}

}

@keyframes slideInBottom {

0% {
	transform: translateY(100%) scale(0.8);
}

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

}


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