@charset "utf-8";
/* CSS Document */

body {
	color: #3C3C3C;
	font-family: "Hannari Mincho", 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;
}

.aside {
	background-color: #FFFEEF;
	cursor: pointer;
	max-width: 18.75rem;
	overflow: hidden;
	width: 100%;
}

.aside__img {
	overflow: hidden;
}

.aside__img img {
	-o-object-fit: cover;
	aspect-ratio: 300/300;
	height: auto;
	object-fit: cover;
	transition: transform 0.4s ease, opacity 0.4s ease;
	width: 100%;
}

.aside__img:hover img {
	opacity: 0.85;
	transform: scale(1.05);
}

.aside__logo {
	height: auto;
	width: 100%;
}

.button__text {
	align-items: center;
	background: linear-gradient(to bottom, #FF8A8A 0%, #B93C3C 100%);
	border-radius: 5.90625rem;
	box-shadow: 0 0.235625rem 0.235625rem rgba(0, 0, 0, 0.25);
	color: #fff;
	display: inline-flex;
	font-size: 1rem;
	font-weight: 300;
	justify-content: center;
	letter-spacing: 0.09em;
	line-height: 1.25;
	padding: 1rem 0rem;
	position: relative;
	transition: box-shadow 0.4s, transform 0.4s;
	width: 20.125rem;
	will-change: transform;
}

.button__text--black {
	background: linear-gradient(to bottom, #808080 0%, #212121 100%);
}

.button__text:hover {
	box-shadow: 0 0.25rem 0.4375rem rgba(0, 0, 0, 0.5);
	cursor: pointer;
	transform: translateY(-5px);
}

.disclaimer {
	margin-top: 1.5rem;
	padding-bottom: 0.625rem;
	text-align: center;
}

.disclaimer__text {
	font-size: 0.625rem;
	font-weight: 300;
	letter-spacing: 0.02em;
	line-height: 1.5;
}

.fv {
	background-image: url("/wp-content/themes/swell_child/asset/img/fv-bg-sp.webp");
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
	color: #fff;
	padding: 10.9375rem 0 1.875rem;
	text-align: center;
}

.fv__inner {
	margin-left: auto;
	margin-right: auto;
	max-width: 500px;
	padding: 0 0.625rem;
}

.fv__logo {
	height: 6.3125rem;
	margin-left: auto;
	margin-right: auto;
	width: 18.4375rem;
}

.fv__title {
	font-size: 1.8125rem;
	font-weight: 300;
	letter-spacing: 0.1em;
	line-height: 1.2068965517;
	margin-top: 1.25rem;
}

.fv__sentence {
	background-color: rgba(255, 255, 255, 0.6);
	border-radius: 0.125rem;
	color: #000;
	margin: 1.875rem auto 0;
	max-width: 48.3125rem;
	padding: 1.25rem 1rem 1.5625rem;
}

.fv__text {
	color: #000;
	font-size: 1rem;
	font-weight: 300;
	line-height: 1.5625;
}

.fv__buttons {
	margin-top: 1.25rem;
	text-align: center;
}

.fv__button-text {
	align-items: center;
	background: linear-gradient(to bottom, #6B6B6B 0%, #101010 100%);
	box-shadow: 0 0.235625rem 0.235625rem rgba(0, 0, 0, 0.25);
	color: #fff;
	display: inline-flex;
	font-size: 1.125rem;
	font-weight: 300;
	justify-content: center;
	letter-spacing: 0.03em;
	line-height: 1.3888888889;
	overflow: hidden;
	padding: 1rem 0rem 1.125rem;
	position: relative;
	transition: box-shadow 0.4s, transform 0.4s;
	width: 95%;
	z-index: 1;
}

.fv__button-text:hover {
	box-shadow: 0 0.375rem 0.75rem rgba(0, 0, 0, 0.35);
	transform: translateY(-0.1875rem);
}

.fv__button-text::before {
	background: linear-gradient(120deg, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0.6) 50%, rgba(255, 255, 255, 0) 100%);
	content: "";
	height: 100%;
	left: -75%;
	position: absolute;
	top: 0;
	transform: skewX(-20deg);
	width: 50%;
	z-index: 2;
}

.fv__button-text:hover::before {
	animation: shine 1s ease-in-out;
}

.header__hamburger {
	background-color: #B29382;
	border-radius: 0.125rem;
	display: inline-block;
	padding: 1.15625rem 0.75rem;
	text-align: right;
	transition: background-color 0.3s ease;
	z-index: 9999;
}

.header__hamburger span {
	background-color: #fff;
	display: block;
	height: 0.125rem;
	position: relative;
	text-align: right;
	transition: background-color 0.3s ease, transform 0.3s ease;
}

.header__hamburger.is-open {
	background: none;
	background-color: #B29382;
	box-shadow: 0 0.25rem 0.25rem rgba(0, 0, 0, 0.25);
	height: 3.1875rem;
	margin: 0;
	padding-left: 0.625rem;
	position: fixed;
	right: 1.0625rem;
	top: 3.125rem;
	width: 3.1875rem;
	z-index: 9999;
}

.header__hamburger.is-open span {
	background-color: #fff;
	height: 0.125rem;
}

.header__hamburger span:nth-child(1) {
	top: 0;
	width: 1.9375rem;
}

.header__hamburger span:nth-child(2) {
	margin: 0.375rem 0;
	width: 1.9375rem;
}

.header__hamburger span:nth-child(3) {
	top: 0;
	width: 1.9375rem;
}

.header__hamburger.is-open span:nth-child(1) {
	left: 0.3125rem;
	top: 0.375rem;
	transform: rotate(42deg);
	width: 1.375rem;
}

.header__hamburger.is-open span:nth-child(2) {
	opacity: 0;
	transform: translateY(-50%);
	width: 1.375rem;
}

.header__hamburger.is-open span:nth-child(3) {
	left: 0.3125rem;
	top: -0.575rem;
	transform: rotate(-42deg);
	width: 1.375rem;
}

.header {
	left: 0;
	overflow: hidden;
	position: fixed;
	right: 0;
	top: 0;
	transition: top 0.1s ease;
	z-index: 9999;
}

.header.is-fixed-shadow {
	background-color: #fff;
	box-shadow: 0 0.25rem 0.625rem rgba(0, 0, 0, 0.1);
}

.header__container {
	align-items: center;
	display: flex;
	height: inherit;
	height: 5.875rem;
	justify-content: space-between;
	padding-right: 1rem;
	position: relative;
	transition: background-color 0.3s ease;
}

.header__logo {
	height: 3.375rem;
	position: relative;
	width: 11rem;
	z-index: 8000;
}

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

.introduction-card--margin {
	margin-top: 1.75rem;
}

.introduction-card__content {
	background-color: #FAF6F3;
	box-shadow: 0 0.25rem 0rem rgba(0, 0, 0, 0.25);
	padding: 0rem 1.46875rem 2.5rem;
	text-align: center;
}

.introduction-pc__name {
	background-color: #B29382;
	color: #fff;
	font-size: 1.41875rem;
	font-weight: 300;
	letter-spacing: 0.09em;
	line-height: 1.2511013216;
	margin-top: 1.125rem;
	padding: 1.1875rem 0 1.14375rem;
}

.introduction__img {
	overflow: hidden;
}

.introduction__img img {
	-o-object-fit: cover;
	aspect-ratio: 302/149;
	height: auto;
	object-fit: cover;
	transition: transform 0.4s ease;
	width: 100%;
}

.introduction__img a:hover img {
	transform: scale(1.05);
}

.introduction-card__source {
	align-items: flex-end;
	display: flex;
	font-size: 0.59375rem;
	font-weight: 300;
	justify-content: center;
	letter-spacing: 0.09em;
	line-height: 2.9894736842;
}

.introduction-card__source-text {
	-webkit-text-decoration: underline;
	text-decoration: underline;
}

.introduction-card__feature {
	align-items: center;
	display: flex;
	gap: 2.375rem;
	justify-content: center;
	margin-top: 0.4375rem;
}

.introduction-card__feature-line {
	background-color: #B29382;
	flex: 1;
	height: 0.0625rem;
	max-width: 5.625rem;
}

.introduction-card__feature-text {
	font-size: 1.25rem;
	font-weight: 300;
	letter-spacing: 0.09em;
	line-height: 1.42;
}

.introduction-card__table {
	margin-top: 0.71875rem;
}

.introduction-card__table img {
	-o-object-fit: cover;
	aspect-ratio: 302/268;
	height: auto;
	object-fit: cover;
	width: 100%;
}

.introduction-card__buttons {
	margin-top: 1.875rem;
}

.introduction-card__button + .introduction-card__button {
	margin-top: 0.59375rem;
}

.introduction-card__button-text {
	align-items: center;
	background: linear-gradient(to bottom, #FF8A8A 0%, #B93C3C 100%);
	border-radius: 5.90625rem;
	box-shadow: 0 0.235625rem 0.235625rem rgba(0, 0, 0, 0.25);
	color: #fff;
	display: inline-flex;
	font-size: 0.9375rem;
	font-weight: 300;
	justify-content: center;
	letter-spacing: 0.09em;
	line-height: 1.26;
	padding: 1rem 0rem;
	position: relative;
	transition: box-shadow 0.4s, transform 0.4s;
	width: 100%;
	will-change: transform;
}

.introduction-card__button-text--black {
	background: linear-gradient(to bottom, #808080 0%, #212121 100%);
}

.introduction-card__button-text:hover {
	box-shadow: 0 0.25rem 0.4375rem rgba(0, 0, 0, 0.5);
	cursor: pointer;
	transform: translateY(-5px);
}

.introduction-pc__list {
	align-items: flex-end;
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
	gap: 2.5rem;
}

.introduction-pc__item {
	margin: 0;
	max-width: calc(33.3333% - 1.6666666667rem);
	width: 100%;
}

.introduction-pc__head {
	align-items: flex-end;
	display: flex;
	gap: 1.5rem;
	justify-content: center;
}

.introduction-pc__slash {
	height: 3.125rem;
	width: 1.25rem;
}

.introduction-pc__comment {
	font-size: 1.1875rem;
	font-weight: 300;
	letter-spacing: 0.09em;
	line-height: 1.4947368421;
}

.introduction-pc__comment span {
	color: #7C6152;
}

.recommend-swiper__inner {
	padding-right: 0;
	position: relative;
	transition: padding 0.3s ease;
}

.recommend-swiper__button-prev,
.recommend-swiper__button-next {
	border-radius: 50%;
	bottom: 43%;
	cursor: pointer;
	height: 2.75rem;
	position: absolute;
	transform: translateY(-50%);
	width: 2.75rem;
	z-index: 10;
}

.recommend-swiper__button-prev {
	left: -1.25rem;
}

.recommend-swiper__button-next {
	right: -1.25rem;
}

.recommend-swiper__button-prev::after,
.recommend-swiper__button-next::after {
	background-position: center;
	background-repeat: no-repeat;
	background-size: contain;
	content: "";
	display: block;
	height: 100%;
	width: 100%;
}

.recommend-swiper__button-prev::after {
	background-image: url("/wp-content/themes/swell_child/asset/img/arrow-left.svg");
}

.recommend-swiper__button-next::after {
	background-image: url("/wp-content/themes/swell_child/asset/img/arrow-right.svg");
}

.recommend-swiper__pagination {
	display: none;
}

.introduction {
	padding: 3.75rem 0;
	text-align: center;
}

.introduction__inner {
	margin-left: auto;
	margin-right: auto;
	max-width: 500px;
	padding: 0 1.25rem;
}

.introduction__container {
	margin-top: 1.875rem;
}

.link-pc {
	background-color: #f8f8f8;
	padding: 1.875rem 0;
	text-align: center;
}

.link-pc__inner {
	margin: 0 auto;
	max-width: 71.625rem;
	padding: 0 1.25rem;
}

.link-pc__list {
	align-items: center;
	display: flex;
	justify-content: center;
}

.link-pc__item--second {
	display: inline-block;
	padding: 0 0.625rem;
	width: 25.375rem;
}

.link-pc__item {
	-webkit-text-decoration: none;
	display: inline-block;
	position: relative;
	text-align: center;
	text-decoration: none;
	transition: color 0.3s ease;
}

.link-pc__item::after {
	background-color: #B29382;
	bottom: 0;
	content: "";
	height: 0.0625rem;
	left: 50%;
	position: absolute;
	transform: translateX(-50%) scaleX(0);
	transform-origin: center;
	transition: transform 0.4s ease;
	width: 100%;
}

.link-pc__item:hover::after {
	transform: translateX(-50%) scaleX(1);
}

.link-pc__item:hover .link-pc__text {
	color: #B29382;
}

.link-pc__item:hover .link-pc__label {
	color: #B29382;
}

.link-pc__label {
	color: #B29382;
	font-family: "Wolpe Pegasus", serif;
	font-size: 1rem;
	font-weight: 300;
	letter-spacing: 0.09em;
	line-height: 1.875;
}

.link-pc__text {
	color: #343434;
	font-size: 1.25rem;
	font-weight: 300;
	letter-spacing: 0.09em;
	line-height: 1.3;
}

.link-pc__divider {
	background-color: transparent;
	border-left: 1px solid #B29382;
	height: 5.625rem;
	margin-left: 3.125rem;
	padding-right: 3.125rem;
	transform: skewX(-16deg);
	width: 0.0625rem;
}

.link-sp {
	text-align: center;
}

.link-sp__inner {
	margin-left: auto;
	margin-right: auto;
	max-width: 500px;
	padding: 0 0.625rem;
}

.link-sp__list {
	margin-top: 1.875rem;
}

.link-sp__item {
	-webkit-text-decoration: none;
	background-color: #F7F7F7;
	box-shadow: 0 0.125rem 0.125rem rgba(0, 0, 0, 0.25);
	color: inherit;
	display: block;
	padding: 0.625rem 0 1.25rem;
	text-decoration: none;
}

.link-sp__item + .link-sp__item {
	margin-top: 0.5625rem;
}

.link-sp__en {
	color: #B29382;
	font-family: "Wolpe Pegasus", serif;
	font-size: 1rem;
	font-weight: 300;
	letter-spacing: 0.09em;
	line-height: 1.875;
}

.link-sp__jp {
	font-size: 1.125rem;
	font-weight: 300;
	letter-spacing: 0.02em;
	line-height: 1.4444444444;
	margin-top: 0.3125rem;
}

.list {
	padding-top: 3.75rem;
}

.list__inner {
	margin-left: auto;
	margin-right: auto;
	max-width: 500px;
	padding: 0 2.15625rem;
}

.list__header {
	text-align: center;
}

.list__title {
	align-items: center;
	display: flex;
	flex-direction: column;
	text-align: center;
}

.list__title-en {
	color: #7C6152;
	font-family: "Wolpe Pegasus", serif;
	font-size: 1rem;
	font-weight: 300;
	letter-spacing: 0.09em;
	line-height: 1.875;
	text-transform: uppercase;
}

.list__title-jp {
	align-items: center;
	display: flex;
	justify-content: center;
	margin-top: 1.25rem;
	width: 100%;
}

.list__title-jp-text {
	display: flex;
	flex-direction: column;
	font-size: 1.5rem;
	font-weight: 300;
	letter-spacing: 0.02em;
	line-height: 1.3333333333;
}

.list__title-jp-main {
	color: #7C6152;
}

.list__list {
	display: flex;
	flex-direction: column;
	gap: 1.875rem;
	margin-top: 1.875rem;
}

.list__item {
	background-color: #fff;
	box-shadow: 0 0rem 0.25rem rgba(0, 0, 0, 0.25);
	width: 100%;
}

.list__head {
	-webkit-text-decoration: none;
	align-items: center;
	background-color: #B29382;
	color: #fff;
	display: flex;
	min-height: 4.5rem;
	padding: 0.6875rem 0rem 0.625rem 2rem;
	position: relative;
	text-align: left;
	text-decoration: none;
}

.list__arrow {
	height: 2.3125rem;
	position: absolute;
	right: 6%;
	top: 50%;
	transform: translate(0%, -50%);
	transition: transform 0.3s ease;
	width: 2.3125rem;
}

.list__head:hover .list__arrow {
	transform: translate(20%, -50%);
}

.list__name {
	font-size: 1.25rem;
	font-weight: 300;
	letter-spacing: 0.05em;
	line-height: 1.25;
}

.list__content {
	padding: 0.76875rem 0.96875rem 1.4375rem;
}

.list__wrapper {
	text-align: center;
}

.list__block {
	margin-top: 0.8125rem;
}

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

.list__block--margin {
	margin-top: 1.0625rem;
}

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

.list__block--margin-second {
	margin-top: 1.1875rem;
}

.list__block--margin-second:first-of-type {
	margin-top: 0;
}

.list__location {
	align-items: center;
	display: flex;
	font-size: 1.125rem;
	font-weight: 300;
	gap: 1.5625rem;
	justify-content: center;
	letter-spacing: 0;
	line-height: 1.27;
	position: relative;
}

.list__location--number {
	gap: 0.78125rem;
}

.list__location::before,
.list__location::after {
	background-color: #3C3C3C;
	content: "";
	flex-grow: 1;
	height: 0.0625rem;
	max-width: 100%;
}

.list__address,
.list__tel {
	font-size: 1rem;
	font-weight: 300;
	line-height: 1.27;
	margin-top: 0.5rem;
}

.list__address {
	align-items: center;
	display: flex;
	justify-content: center;
	min-height: 3.75rem;
	text-align: center;
}

.list__sentence {
	align-items: center;
	background-color: #F6F6F6;
	display: flex;
	margin-top: 0.54375rem;
	min-height: 8.875rem;
	padding: 0.7rem 1.4rem;
}

.list__text {
	font-size: 1rem;
	font-weight: 300;
	line-height: 1.27;
}

.list__map {
	aspect-ratio: 290/90;
	margin-top: 0.71875rem;
	overflow: hidden;
	position: relative;
	width: 100%;
}

.list__map iframe {
	border: 0;
	display: block;
	height: 100%;
	width: 100%;
}

.list__buttons {
	margin: 3.125rem auto 0;
	text-align: center;
	width: 87.436%;
}

.list__button-text {
	align-items: center;
	background: linear-gradient(to top, #7C6152 0%, #AC846E 100%);
	border-radius: 6.25rem;
	box-shadow: 0 0.235625rem 0.235625rem rgba(0, 0, 0, 0.25);
	color: #fff;
	display: inline-flex;
	font-size: 1rem;
	font-weight: 300;
	justify-content: center;
	letter-spacing: 0.02em;
	line-height: 1.375;
	padding: 1.03125rem 0rem;
	position: relative;
	transition: box-shadow 0.4s, transform 0.4s;
	width: 100%;
	will-change: transform;
}

.list__button-text:hover {
	box-shadow: 0 0.25rem 0.4375rem rgba(0, 0, 0, 0.5);
	cursor: pointer;
	transform: translateY(-5px);
}

.pagetop {
	align-items: flex-end; /* 子要素を右寄せに */
	bottom: -0.5rem;
	display: none; /* 初期状態で確実に非表示にする */
	flex-direction: column; /* 縦方向に要素を並べる */
	overflow: hidden;
	position: relative;
	position: fixed;
	right: 0;
	z-index: 1000;
}

.pagetop__inner {
	margin-left: auto;
	margin-right: auto;
	max-width: 500px;
}

.pagetop a {
	display: inline-block; /* リンク領域を画像サイズに限定 */
	transition: 0.5s;
	width: auto; /* 画像のサイズに応じてリンク領域を設定 */
}

.pagetop a:hover {
	opacity: 0.8;
}

.pagetop__img-top {
	height: 100%;
	width: 100%;
}

.pagetop__img-top img {
	border: solid 6px #fff;
	width: 26.5625rem;
}

.pagetop__close {
	background: none;
	border: none;
	color: #fff;
	cursor: pointer;
	font-size: 1.5rem;
	line-height: 1;
	position: absolute;
	right: 0.25rem;
	top: 0.25rem;
	z-index: 1100;
}

/* 光のスタイル */

.pagetop {
	overflow: hidden;
}

.pagetop a::before {
	background-image: linear-gradient(130deg, rgba(255, 255, 255, 0) 20%, rgba(255, 255, 255, 0.5) 50%, rgba(255, 255, 255, 0) 80%);
	content: "";
	height: 100%;
	left: -100%;
	position: absolute;
	top: 0;
	transition: 0.5s;
	width: 100%;
}

/* ホバー時のスタイル */

.pagetop a:hover::before {
	left: 100%;
	top: 0;
}

.pc-nav__content {
	align-items: center;
	display: flex;
	gap: 1.0625rem;
	position: relative;
	z-index: 1000;
}

.pc-nav__list {
	display: flex;
}

.pc-nav__item {
	align-items: center;
	display: flex;
	gap: 2.3125rem;
	justify-content: center;
	padding: 0 min(2.45vw, 1.25rem);
}

.pc-nav__ja {
	-webkit-text-decoration: none;
	color: #fff;
	display: inline-block;
	font-size: 1rem;
	font-weight: 300;
	letter-spacing: 0;
	line-height: 1.375;
	position: relative;
	text-decoration: none;
	transition: color 0.3s ease, transform 0.3s ease;
}

.pc-nav__ja::after {
	background-color: #fff;
	bottom: -0.125rem;
	content: "";
	height: 0.125rem;
	left: 0;
	opacity: 0;
	position: absolute;
	transform: scaleX(0.5);
	transform-origin: center;
	transition: opacity 0.3s ease, transform 0.3s ease;
	width: 100%;
}

.pc-nav__ja:hover {
	transform: translateY(-0.125rem);
}

.pc-nav__ja:hover::after {
	opacity: 1;
	transform: scaleX(1);
}

.pc-nav__ja.is-scrolled {
	color: #3C3C3C;
}

.pc-nav__ja.is-scrolled::after {
	background-color: #3C3C3C;
}

.pc-nav__banner {
	background-color: #343434;
	height: 4.3125rem;
	transition: 0.5s;
}

.pc-nav__banner:hover {
	opacity: 0.7;
}

.pc-nav__banner-box {
	align-items: center;
	display: flex;
	justify-content: center;
	padding: 0.625rem 1.5625rem;
	text-align: center;
}

.pc-nav__banner-text {
	color: #fff;
	font-size: 1rem;
	font-weight: 300;
	line-height: 1.5625;
	text-align: center;
}

.point {
	background-image: url("/wp-content/themes/swell_child/asset/img/point-bg.webp");
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
	padding: 3.75rem 0 4.5625rem;
	text-align: center;
}

.point__inner {
	margin-left: auto;
	margin-right: auto;
	max-width: 500px;
	padding: 0 1.25rem;
}

.point__en {
	color: #B29382;
	font-family: "Wolpe Pegasus", serif;
	font-size: 1rem;
	font-weight: 300;
	letter-spacing: 0.09em;
	line-height: 1.875;
}

.point__title {
	font-size: 1.5rem;
	font-weight: 300;
	letter-spacing: 0.02em;
	line-height: 1.2916666667;
	margin-top: 0.625rem;
}

.point__title span {
	color: #7C6152;
	font-size: 1.5rem;
}

.point__list {
	margin-top: 1.875rem;
}

.point__item + .point__item {
	margin-top: 1.875rem;
}

.point__img {
	width: 100%;
}

.point__img img {
	-o-object-fit: cover;
	aspect-ratio: 350/196;
	height: auto;
	object-fit: cover;
	width: 100%;
}

.point__sentence {
	background-color: #fff;
	box-shadow: 0 0rem 0.25rem rgba(0, 0, 0, 0.25);
	padding: 1.875rem 1.14375rem;
	text-align: left;
	width: 100%;
}

.point__head {
	border-left: solid 2px #B29382;
	font-size: 1.125rem;
	font-weight: 300;
	letter-spacing: 0.02em;
	line-height: 1.3055555556;
	padding-left: 0.875rem;
}

.point__head--font {
	font-size: 1rem;
}

.point__head span {
	color: #7C6152;
}

.point__text {
	font-size: 0.875rem;
	font-weight: 300;
	letter-spacing: 0.03em;
	line-height: 1.7142857143;
	margin-top: 1.25rem;
}

.point__text span {
	color: #7C6152;
}

.recommend-case {
	background-color: #FAF6F3;
	padding: 2.5rem 0;
}

.recommend-case__inner {
	margin-left: auto;
	margin-right: auto;
	max-width: 500px;
	padding: 0 1.25rem;
	position: relative;
}

.recommend-case__source {
	align-items: flex-end;
	bottom: 16.5%;
	display: flex;
	font-size: 0.625rem;
	font-weight: 300;
	justify-content: center;
	left: 50%;
	letter-spacing: 0.09em;
	line-height: 2;
	margin-top: 0.29375rem;
	position: absolute;
	transform: translate(-50%, 0%);
	z-index: 100;
}

.recommend-case__source-text {
	-webkit-text-decoration: underline;
	text-decoration: underline;
}

.recommend-case__subtitle {
	font-size: 0.9625rem;
	font-weight: 300;
	letter-spacing: 0.02em;
	line-height: 1.25;
	margin-top: 1.25rem;
	text-align: center;
}

.recommend-case__subtitle span {
	color: #8F512F;
}

.recommend-case__main {
	margin-top: 1.25rem;
}

.recommend-case__main img {
	-o-object-fit: cover;
	aspect-ratio: 350/231;
	height: auto;
	object-fit: cover;
	width: 100%;
}

.recommend-case__wrapper {
	margin-bottom: 0.25rem;
	margin-top: 0.625rem;
}

.recommend-case__images {
	align-items: center;
	display: flex;
	gap: 0.625rem;
}

.recommend-case__img-left img,
.recommend-case__img-right img {
	-o-object-fit: cover;
	aspect-ratio: 170/104;
	height: auto;
	object-fit: cover;
	width: 100%;
}

.recommend-case__buttons {
	margin: 5.1875rem auto 0.375rem;
	text-align: center;
	width: 92%;
}

.recommend-case__button-text {
	align-items: center;
	background: linear-gradient(to bottom, #FF8A8A 0%, #B93C3C 100%);
	border-radius: 6.25rem;
	box-shadow: 0 0.235625rem 0.235625rem rgba(0, 0, 0, 0.25);
	color: #fff;
	display: inline-flex;
	font-size: 1rem;
	font-weight: 300;
	justify-content: center;
	letter-spacing: 0.09em;
	line-height: 1.25;
	margin-left: auto;
	margin-right: auto;
	padding: 1.0625rem 0rem;
	position: relative;
	transition: box-shadow 0.4s, transform 0.4s;
	width: 100%;
	will-change: transform;
}

.recommend-case__button-text:hover {
	box-shadow: 0 0.25rem 0.4375rem rgba(0, 0, 0, 0.5);
	cursor: pointer;
	transform: translateY(-5px);
}

.recommend-company {
	margin-top: 5.125rem;
}

.recommend-company__inner {
	margin-left: auto;
	margin-right: auto;
	max-width: 500px;
}

.recommend-company__name {
	background-color: #B29382;
	color: #fff;
	font-size: 1.75rem;
	font-weight: 300;
	left: 0%;
	line-height: 1.7857142857;
	padding: 0.625rem 1.6875rem 0.8125rem;
	position: absolute;
	text-align: center;
	top: -7.5%;
	width: 86%;
}

.recommend-company__text {
	font-size: 1.25rem;
	font-weight: 300;
	letter-spacing: 0.02em;
	line-height: 1.4;
	padding-left: 1.6875rem;
	text-align: left;
}

.recommend-company__text span {
	color: #8F512F;
}

.recommend-company__bg {
	display: none;
}

.recommend-company__flex {
	background-color: #FAF6F3;
	padding: 3.5625rem 0 1.875rem;
	position: relative;
	z-index: 1;
}

.recommend-company__images {
	margin: 1.25rem auto 0;
	width: 89.745%;
}

.recommend-company__img img {
	-o-object-fit: cover;
	aspect-ratio: 350/233;
	height: auto;
	object-fit: cover;
	width: 100%;
}

.recommend-company__photo img {
	-o-object-fit: cover;
	aspect-ratio: 463/221;
	height: 13.8125rem;
	object-fit: cover;
	width: 100%;
}

.recommend-company__source {
	align-items: flex-end;
	display: flex;
	font-size: 0.625rem;
	font-weight: 300;
	justify-content: center;
	letter-spacing: 0.09em;
	line-height: 3;
	margin-top: 0.625rem;
}

.recommend-company__source-text {
	-webkit-text-decoration: underline;
	text-decoration: underline;
}

.recommend-info-pc__flex {
	align-items: center;
	display: flex;
	gap: 1.1875rem;
	justify-content: center;
}

.recommend-info-pc__flex--one {
	gap: 2.25rem;
}

.recommend-info__content {
	width: 47.78%;
}

.recommend-info__content--one {
	width: 42.9%;
}

.recommend-info__map {
	aspect-ratio: 452/186;
	overflow: hidden;
	position: relative;
	width: 100%;
}

.recommend-info__map--one {
	aspect-ratio: 384/384;
	overflow: hidden;
	position: relative;
	width: 100%;
}

.recommend-info__map + .recommend-info__map {
	margin-top: 1rem;
}

.recommend-info__map iframe {
	border: 0;
	display: block;
	height: 100%;
	width: 100%;
}

.recommend-info__wrapper {
	background-color: #fff;
	padding: 1.9375rem 2.875rem 2.5rem 2rem;
	width: 50.21%;
}

.recommend-info__wrapper--one {
	width: 53.07%;
}

.recommend-info__name {
	border-bottom: solid 1px #957461;
	font-size: 1.5rem;
	font-weight: 300;
	line-height: 1.2083333333;
	padding-bottom: 0.625rem;
}

.recommend-info__box {
	margin-top: 0.9375rem;
}

.recommend-info__box--one {
	margin-top: 1.875rem;
}

.recommend-info__studio {
	font-size: 1.25rem;
	font-weight: 300;
	line-height: 1.2;
}

.recommend-info__address {
	display: flex;
	font-size: 1rem;
	font-weight: 300;
	line-height: 1.75;
	margin: 0rem -1.875rem auto auto;
	margin-top: 1.3125rem;
	width: calc(100% + 1.875rem);
}

.recommend-info__address-span {
	width: 4.125rem;
}

.recommend-info__tel {
	font-size: 1rem;
	font-weight: 300;
	line-height: 1.1875;
	margin-top: 0.625rem;
}

.recommend-info__box + .recommend-info__box {
	margin-top: 1.25rem;
}

.recommend-info__link {
	align-items: center;
	border-top: solid 1px #957461;
	display: flex;
	font-size: 1.25rem;
	font-weight: 300;
	gap: 1.25rem;
	line-height: 1.2;
	margin-top: 1.125rem;
	padding-top: 0.75rem;
}

.recommend-info__link--one {
	margin-top: 4.9375rem;
}

.recommend-info__link-link:hover {
	-webkit-text-decoration: underline;
	text-decoration: underline;
}

.recommend-info-sp__content {
	background-color: #fff;
	padding: 1.25rem 1rem;
}

.recommend-info-sp__name {
	border-bottom: solid 1px #957461;
	font-size: 1.25rem;
	font-weight: 300;
	line-height: 1.2;
	padding-bottom: 1.25rem;
}

.recommend-info-sp__wrapper {
	margin-top: 1.25rem;
}

.recommend-info-sp__wrapper + .recommend-info-sp__wrapper {
	margin-top: 1.25rem;
}

.recommend-info-sp__studio {
	font-size: 1.125rem;
	font-weight: 300;
	line-height: 1.2222222222;
}

.recommend-info-sp__address {
	display: flex;
	font-size: 0.875rem;
	font-weight: 300;
	line-height: 1.2142857143;
	margin-top: 0.625rem;
}

.recommend-info-sp__address-span {
	width: 3.5rem;
}

.recommend-info-sp__tel {
	font-size: 0.875rem;
	font-weight: 300;
	line-height: 1.2142857143;
	margin-top: 0.625rem;
}

.recommend-info-sp__map {
	aspect-ratio: 314/151;
	margin-top: 0.625rem;
	overflow: hidden;
	position: relative;
	width: 100%;
}

.recommend-info-sp__map iframe {
	border: 0;
	display: block;
	height: 100%;
	width: 100%;
}

.recommend-info-sp__link {
	border-top: 1px solid #957461;
	margin-top: 1.25rem;
	padding-top: 1.25rem;
}

.recommend-info-sp__link-text {
	font-size: 1.125rem;
	font-weight: 300;
	line-height: 1.2222222222;
}

.recommend-info-sp__link-link {
	font-size: 0.875rem;
	font-weight: 300;
	line-height: 1.2142857143;
	margin-top: 0.625rem;
}

.recommend-info {
	background-color: #FAF6F3;
	padding: 1.875rem 0;
}

.recommend-info__inner {
	margin-left: auto;
	margin-right: auto;
	max-width: 500px;
	padding: 0 1.25rem;
}

.recommend-info__inner--one {
	margin-left: auto;
	margin-right: auto;
	max-width: 500px;
	padding: 0 1.25rem;
}

.recommend-point {
	padding: 3.75rem 0;
}

.recommend-point__inner {
	margin-left: auto;
	margin-right: auto;
	max-width: 500px;
	padding: 0 1.25rem;
}

.recommend-point__list {
	display: flex;
	flex-direction: column;
	gap: 1.875rem;
	margin-top: 1.875rem;
	padding: 0 1.0625rem;
}

.recommend-point__item {
	background-color: #FAF6F3;
	padding: 2.5rem 1.125rem;
	position: relative;
	width: 100%;
}

.recommend-point__item span {
	color: #8F512F;
}

.recommend-point__icon {
	height: 5.125rem;
	left: 0;
	position: absolute;
	top: 0;
	width: 4.875rem;
}

.recommend-point__head {
	border-bottom: solid 1px #B29382;
	font-size: 1.25rem;
	font-weight: 300;
	letter-spacing: 0.02em;
	line-height: 1.4;
	padding-bottom: 1.25rem;
	text-align: center;
}

.recommend-point__text {
	font-size: 1rem;
	font-weight: 300;
	letter-spacing: 0.02em;
	line-height: 1.625;
	margin-top: 1.25rem;
	padding: 0 0.1875rem;
}

.recommend-point__buttons {
	margin-top: 1.875rem;
	text-align: center;
}

.recommend-point__button + .recommend-point__button {
	margin-top: 0.625rem;
}

.recommend-section-title {
	position: relative;
	text-align: center;
}

.recommend-section-title__text {
	font-size: 1.5rem;
	font-weight: 300;
	letter-spacing: 0.02em;
	line-height: 1.3333333333;
	position: relative;
}

.recommend-section-title__text::after {
	background-color: #a28f7a;
	content: "";
	display: block;
	height: 0.0625rem;
	margin: 1.875rem auto 0;
	width: 100%;
}

.recommend-section-title__line {
	background-color: #a28f7a;
	flex: 1;
	height: 0.0625rem;
}

.recommend-voice {
	padding: 3.75rem 0;
}

.recommend-voice__inner {
	margin-left: auto;
	margin-right: auto;
	max-width: 500px;
	padding: 0 1.25rem;
}

.recommend-voice__list {
	display: flex;
	flex-direction: column;
	gap: 1.875rem;
	margin-top: 1.875rem;
}

.recommend-voice__item {
	display: flex;
	flex-direction: column;
	height: auto;
}

.recommend-voice__head {
	align-items: center;
	display: flex;
	gap: 0.6875rem;
	justify-content: center;
}

.recommend-voice__head img {
	height: 1.875rem;
	width: 1rem;
}

.recommend-voice__comment {
	color: #7C6152;
	font-size: 0.99rem;
	font-weight: 300;
	letter-spacing: 0.04em;
	line-height: 1.6666666667;
}

.recommend-voice__content {
	background-color: #FAF6F3;
	display: flex;
	flex-direction: column;
	height: 100%;
	margin-left: 1.5625rem;
	margin-right: 1.5625rem;
	margin-top: 0.8125rem;
	padding: 1.875rem 1.25rem 2.25rem;
}

.recommend-voice__icon {
	border-radius: 50%;
	box-shadow: 0 0 0.25rem rgba(0, 0, 0, 0.25);
	height: auto;
	margin-left: auto;
	margin-right: auto;
	width: 57.695%;
}

.recommend-voice__text {
	font-size: 1rem;
	font-weight: 300;
	letter-spacing: 0.04em;
	line-height: 1.75;
	margin-top: 1.25rem;
	padding-bottom: 1.25rem;
}

.recommend-voice__text--font {
	font-size: 0.9375rem;
	line-height: 2;
}

.recommend-voice__source {
	align-items: flex-end;
	display: flex;
	font-size: 0.6875rem;
	font-weight: 300;
	justify-content: center;
	letter-spacing: 0.04em;
	line-height: 2.7272727273;
	margin-top: auto;
}

.recommend-voice__source-text {
	-webkit-text-decoration: underline;
	text-decoration: underline;
}

.recommend-voice__buttons {
	margin-top: 1.875rem;
	text-align: center;
}

.recommend-voice__button + .recommend-voice__button {
	margin-top: 0.625rem;
}

.recommend {
	display: flex;
	justify-content: center;
	margin-left: auto;
	margin-right: auto;
}

.recommend__container {
	padding-top: 3.75rem;
	width: 100%;
}

.recommend__header {
	text-align: center;
}

.scroll-hint-icon {
	background: rgba(0, 0, 0, 0.7);
	border-radius: 5px;
	box-sizing: border-box;
	height: auto;
	left: calc(50% - 70px);
	opacity: 0;
	padding: 20px 10px 10px 10px;
	position: absolute;
	text-align: center;
	top: calc(50% - 25px);
	transition: opacity 0.3s;
	width: 140px;
}

.scroll-top {
	border-radius: 50%;
	bottom: 3.125rem;
	box-shadow: 0 0.25rem 0.25rem rgba(0, 0, 0, 0.25);
	height: 2.5rem;
	position: fixed;
	right: 0.5rem;
	width: 2.5rem;
	z-index: 9999;
}

.scroll-top img {
	display: block;
	height: 2.5rem;
	width: 2.5rem;
}

.section-header__en {
	color: #B29382;
	font-family: "Wolpe Pegasus", serif;
	font-size: 1rem;
	font-weight: 300;
	letter-spacing: 0.09em;
	line-height: 1.25;
	text-transform: uppercase;
}

.section-header__tabs {
	align-items: center;
	display: flex;
	flex-wrap: wrap;
	gap: 0.625rem;
	justify-content: center;
	margin-top: 1.25rem;
}

.section-header__tab {
	background-color: #B29382;
	color: #fff;
	display: inline-block;
	font-size: 1.25rem;
	font-weight: 300;
	letter-spacing: 0.09em;
	line-height: 1.5;
	padding: 0.3125rem 1.25rem;
}

.section-header__title {
	display: flex;
	flex-direction: column;
	margin-top: 1.25rem;
}

.section-header__title--recommend {
	margin-top: 1.875rem;
}

.section-header__title-top {
	font-size: 1.375rem;
	font-weight: 300;
	letter-spacing: 0.09em;
	line-height: 1.1818181818;
}

.section-header__title-bottom {
	font-size: 1.375rem;
	font-weight: 300;
	letter-spacing: 0.09em;
	line-height: 2.2727272727;
}

.section-header__title-bottom--recommend {
	line-height: 1.2727272727;
}

.section-header__title-bottom span {
	color: #7C6152;
	font-size: 1.875rem;
}

.header__sp-nav {
	padding-top: 6.25rem;
}

.header__sp-nav.is-scrolled {
	padding-top: 5rem;
}

.overlay {
	background-color: rgba(229, 209, 199, 0.6);
	height: 100%;
	left: 0;
	opacity: 0;
	position: fixed;
	top: 1.6875rem;
	transition: opacity 0.3s ease, visibility 0.3s ease;
	visibility: hidden;
	width: 100%;
	z-index: 8887;
}

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

.sp-nav {
	background-color: #F7F7F7;
	height: 100vh;
	overflow-y: auto;
	position: fixed;
	right: 0;
	top: 1.8125rem;
	transform: translateX(100%);
	transition: ease 0.3s;
	width: 68.1%;
	z-index: 8888;
}

.sp-nav.is-open {
	transform: translateX(0);
}

.sp-nav__list {
	height: 100%;
	overflow-y: auto;
	padding: 0rem 0.8125rem 2.5rem 1.375rem;
	width: 100%;
}

.sp-nav__list {
	box-sizing: border-box;
}

.sp-nav__item {
	border-bottom: solid 1px #E7E7E7;
	padding-bottom: 1.25rem;
}

.sp-nav__item + .sp-nav__item {
	margin-top: 1.25rem;
}

.sp-nav__link {
	align-items: center;
	display: flex;
}

.sp-nav__dot {
	color: #fff;
	font-size: 1.75rem;
}

.sp-nav__ja {
	color: #343434;
	font-size: 1rem;
	font-weight: 300;
	line-height: 1.375;
}

.top {
	background-color: #343434;
	color: #fff;
	height: 1.875rem;
	position: relative;
	z-index: 9999;
}

.top-text {
	align-items: center;
	display: flex;
	font-size: 0.8125rem;
	font-weight: 300;
	height: inherit;
	line-height: 1.2307692308;
	padding-bottom: 0.5rem;
	padding-top: 0.375rem;
	text-align: center;
}

.top {
	transition: opacity 0.3s ease, visibility 0.3s ease;
}

.top.is-hidden {
	opacity: 0;
	visibility: hidden;
}

.works-swiper {
	position: relative;
}

.works-swiper__button-prev,
.works-swiper__button-next {
	border-radius: 50%;
	bottom: 14.5%;
	box-shadow: 0 0.25rem 0.25rem rgba(0, 0, 0, 0.25);
	cursor: pointer;
	height: 2.6875rem;
	position: absolute;
	transform: translateY(-50%);
	width: 2.6875rem;
	z-index: 10;
}

.works-swiper__button-prev {
	left: 1.5625rem;
}

.works-swiper__button-next {
	right: 1.5625rem;
}

.works-swiper__button-prev::after,
.works-swiper__button-next::after {
	background-position: center;
	background-repeat: no-repeat;
	background-size: contain;
	content: "";
	display: block;
	height: 100%;
	width: 100%;
}

.works-swiper__button-prev::after {
	background-image: url("/wp-content/themes/swell_child/asset/img/slider-prev.svg");
}

.works-swiper__button-next::after {
	background-image: url("/wp-content/themes/swell_child/asset/img/slider-next.svg");
}

.works-swiper__pagination {
	display: none;
}

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

.u-desktop {
	display: block;
}

.u-mobile {
	display: none;
}

html {
	font-size: 1.2903225806vw;
}

.button__text {
	border-radius: 6.25rem;
	padding: 1.0625rem 0;
}

.disclaimer {
	margin-top: 2rem;
	padding-bottom: 1.25rem;
}

.disclaimer__text {
	font-size: 0.75rem;
	letter-spacing: 0.09em;
	line-height: 4;
}

.fv {
	background-image: url("/wp-content/themes/swell_child/asset/img/fv-bg.webp");
	padding: 11.3125rem 0 4.5625rem;
}

.fv__inner {
	max-width: 100%;
	padding: 0;
}

.fv__title {
	font-size: 4rem;
	line-height: 1.203125;
	margin-top: 1.3125rem;
}

.fv__sentence {
	margin: 3.75rem auto 0;
	padding: 1.875rem 0 2.25rem;
}

.fv__text {
	font-size: 1.125rem;
	letter-spacing: 0.09em;
	line-height: 1.6666666667;
}

.fv__buttons {
	margin-top: 1.875rem;
}

.fv__button-text {
	font-size: 1.25rem;
	line-height: 1.25;
	padding: 0.9375rem 0rem 1.3125rem;
	width: 23.5625rem;
}

.header__hamburger {
	display: none;
}

.header__container {
	height: 6.25rem;
	padding-right: 0rem;
}

.header__logo {
	height: 6.375rem;
	width: 20.6875rem;
}

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

.introduction-card--margin {
	margin-top: 0rem;
}

.introduction-card__content {
	padding: 0rem 1.5625rem 2.6875rem;
}

.introduction-pc__name {
	font-size: 1.5rem;
	line-height: 1.25;
	padding: 1.25rem 0;
}

.introduction__img img {
	aspect-ratio: 320/158;
}

.introduction-card__source {
	font-size: 0.625rem;
	line-height: 3;
}

.introduction-card__source-text a:hover {
	opacity: 0.5;
	transition: 0.3s;
}

.introduction-card__feature {
	gap: 2.5rem;
	margin-top: 0.5rem;
}

.introduction-card__feature-line {
	max-width: 6rem;
}

.introduction-card__feature-text {
	font-size: 1.375rem;
	line-height: 1.3636363636;
}

.introduction-card__table {
	margin-top: 0.8125rem;
}

.introduction-card__table img {
	aspect-ratio: 320/284;
}

.introduction-card__buttons {
	margin-top: 2.0625rem;
}

.introduction-card__button + .introduction-card__button {
	margin-top: 0.625rem;
}

.introduction-card__button-text {
	border-radius: 6.25rem;
	font-size: 1rem;
	line-height: 1.25;
	padding: 1.0625rem 0;
}

.introduction-pc__head {
	gap: 0.89375rem;
}

.introduction-pc__slash {
	height: 3.3125rem;
}

.introduction-pc__comment {
	font-size: 1.25rem;
	line-height: 1.5;
}

.introduction {
	padding: 3.875rem 0 6.125rem;
}

.introduction__inner {
	max-width: 77.5rem;
	padding: 0 1.5625rem;
}

.introduction__container {
	margin-top: 3.75rem;
}

.list {
	padding-top: 5.1875rem;
}

.list__inner {
	max-width: 65.875rem;
	padding: 0 1.5625rem;
}

.list__title-jp {
	gap: 3.125rem;
	margin-top: 0.75rem;
}

.list__title-jp-line {
	background-color: #333;
	flex: 1;
	height: 0.0625rem;
	margin-top: 0.625rem;
	max-width: 11.8125rem;
}

.list__title-jp-text {
	font-size: 2.25rem;
	letter-spacing: 0.09em;
	line-height: 1.3333333333;
}

.list__list {
	flex-direction: row;
	flex-wrap: wrap;
	gap: 1.25rem;
	margin-top: 2.5rem;
}

.list__item {
	margin: 0;
	max-width: calc(33.3333% - 0.8333333333rem);
}

.list__buttons {
	margin: 3.125rem auto 0;
	width: 100%;
}

.list__button-text {
	font-size: 1.5rem;
	letter-spacing: 0.09em;
	line-height: 1;
	padding: 1.8125rem 0rem 1.9375rem;
	width: 56.4375rem;
}

.pagetop {
	bottom: 0;
}

.pagetop__inner {
	max-width: 100%;
}

.pagetop__img-top {
	display: flex;
	justify-content: flex-end; /* 右寄せ */
}

.pagetop__img-top img {
	height: 12.5rem;
	width: 40.625rem;
}

.pagetop__close {
	right: 0.5rem;
	top: 0.5rem;
}

.point {
	padding: 5rem 0 6.25rem;
}

.point__inner {
	max-width: 83.125rem;
	padding: 0 1.5625rem;
}

.point__title {
	font-size: 2.25rem;
	letter-spacing: 0.09em;
	line-height: 1.3888888889;
	margin-top: 0rem;
}

.point__title span {
	font-size: 2.875rem;
	line-height: 1.0869565217;
}

.point__list {
	margin-top: 3.75rem;
}

.point__item {
	align-items: flex-end;
	display: flex;
}

.point__item--reverse {
	flex-direction: row-reverse;
}

.point__item + .point__item {
	margin-top: 3.75rem;
}

.point__img {
	width: 44.92%;
}

.point__img img {
	aspect-ratio: 575/323;
}

.point__sentence {
	display: flex;
	flex-direction: column;
	height: 17.4375rem;
	justify-content: center;
	padding: 2.125rem 5.6875rem 1.75rem 2.375rem;
	width: 55.07%;
}

.point__head {
	border-left: solid 3px #B29382;
	font-size: 1.5rem;
	letter-spacing: 0.02em;
	line-height: 1.3125;
	padding-left: 1.125rem;
}

.point__head--font {
	font-size: 1.5rem;
}

.point__text {
	font-size: 1rem;
	letter-spacing: 0.09em;
	line-height: 1.75;
	margin-top: 0.875rem;
}

.recommend-case {
	padding: 2.75rem 0 1.25rem;
}

.recommend-case__inner {
	max-width: 60.4375rem;
}

.recommend-case__source {
	bottom: 0;
	left: 0;
	margin-top: 1rem;
	position: static;
	text-align: center;
	transform: translate(0%, 0%);
}

.recommend-case__source-text a:hover {
	opacity: 0.5;
	transition: 0.3s;
}

.recommend-case__subtitle {
	font-size: 1rem;
	letter-spacing: 0.09em;
	margin-top: 0.75rem;
	text-align: left;
}

.recommend-case__main {
	margin-top: 1.9375rem;
}

.recommend-case__main img {
	aspect-ratio: 927/399;
}

.recommend-case__wrapper {
	align-items: center;
	display: flex;
	gap: 2.0625rem;
	margin-bottom: 0.25rem;
	margin-top: 0.4375rem;
}

.recommend-case__images {
	gap: 0.3125rem;
	width: 62.245%;
}

.recommend-case__img-left img,
.recommend-case__img-right img {
	aspect-ratio: 286/133;
}

.recommend-case__buttons {
	margin: 0rem auto 0;
	width: 31.932%;
}

.recommend-case__button-text {
	font-size: 0.9375rem;
	line-height: 1.2666666667;
	padding: 1.125rem 0;
}

.recommend-company {
	margin-top: 3.75rem;
	padding-bottom: 1.75rem;
	position: relative;
}

.recommend-company__inner {
	max-width: 100%;
	padding-right: 2.5rem;
}

.recommend-company__name {
	font-size: 2rem;
	line-height: 1.5625;
	padding: 1.0625rem 0 1.125rem;
	position: static;
	top: 0;
	width: 100%;
}

.recommend-company__text {
	letter-spacing: 0.09em;
	min-height: 7.375rem;
	padding-top: 1rem;
	text-align: center;
}

.recommend-company__text--padding {
	padding-top: 1.625rem;
}

.recommend-company__bg {
	background-color: #FAF6F3;
	display: block;
	height: calc(100% - 5rem);
	left: 0;
	position: absolute;
	top: 5rem;
	width: 100%;
	z-index: 0;
}

.recommend-company__flex {
	background-color: transparent;
	display: flex;
	padding: 0;
}

.recommend-company__content {
	width: 47.82%;
}

.recommend-company__images {
	margin: 0rem auto 0;
	width: 52.17%;
}

.recommend-company__img img {
	aspect-ratio: 575/424;
	height: 26.5rem;
}

.recommend-company__photo {
	margin-left: auto;
	width: 88.023%;
}

.recommend-company__source {
	margin-top: 0.5625rem;
}

.recommend-company__source-text a:hover {
	opacity: 0.5;
	transition: 0.3s;
}

.recommend-info {
	padding: 3.3125rem 0 6.25rem;
}

.recommend-info__inner {
	max-width: 61.625rem;
}

.recommend-info__inner--one {
	max-width: 58.4375rem;
}

.recommend-point__inner {
	max-width: 64.25rem;
}

.recommend-point__list {
	flex-direction: row;
	flex-wrap: wrap;
	gap: 1.25rem;
	margin-top: 3.125rem;
	padding: 0;
}

.recommend-point__item {
	margin: 0;
	max-width: calc(33.3333% - 0.8333333333rem);
	padding: 2.625rem 1.125rem 2.5625rem;
}

.recommend-point__head {
	letter-spacing: 0.09em;
	min-height: 6.5625rem;
}

.recommend-point__head--font {
	font-size: 1.1875rem;
}

.recommend-point__head--padding {
	padding-top: 1rem;
}

.recommend-point__head--padding-second {
	padding-top: 1.875rem;
}

.recommend-point__text {
	letter-spacing: 0.09em;
	margin-top: 1.125rem;
	padding: 0 0.125rem;
}

.recommend-point__buttons {
	align-items: center;
	display: flex;
	gap: 1.25rem;
	justify-content: center;
	margin-top: 3.125rem;
}

.recommend-point__button + .recommend-point__button {
	margin-top: 0rem;
}

.recommend-section-title {
	align-items: center;
	display: flex;
	gap: 1.25rem;
	justify-content: center;
}

.recommend-section-title__text::after {
	display: none;
}

.recommend-voice__inner {
	max-width: 61.3125rem;
}

.recommend-voice__list {
	flex-direction: row;
	flex-wrap: wrap;
	gap: 1.25rem;
	margin-top: 3.1875rem;
}

.recommend-voice__item {
	margin: 0;
	max-width: calc(33.3333% - 0.8333333333rem);
}

.recommend-voice__content {
	margin-left: 0rem;
	margin-right: 0rem;
}

.recommend-voice__icon {
	height: 9.4375rem;
	width: 9.4375rem;
}

.recommend-voice__source-text a:hover {
	opacity: 0.5;
	transition: 0.3s;
}

.recommend-voice__buttons {
	align-items: center;
	display: flex;
	gap: 1.25rem;
	justify-content: center;
	margin-top: 3.125rem;
}

.recommend-voice__button + .recommend-voice__button {
	margin-top: 0rem;
}

.recommend {
	max-width: 90rem;
}

.recommend__container {
	padding-top: 4.25rem;
	width: 93.097%;
}

.scroll-top {
	bottom: 3.125rem;
	height: 3.75rem;
	right: 1.125rem;
	width: 3.75rem;
}

.scroll-top img {
	height: 3.75rem;
	width: 3.75rem;
}

.section-header__tabs {
	margin-top: 1.5rem;
}

.section-header__title {
	margin-top: 1rem;
}

.section-header__title--recommend {
	margin-top: 1rem;
}

.section-header__title-top {
	font-size: 2.25rem;
	line-height: 1.2;
}

.section-header__title-bottom {
	font-size: 2.25rem;
	line-height: 1.2;
}

.section-header__title-bottom--recommend {
	line-height: 1.2;
}

.section-header__title-bottom span {
	font-size: 2.875rem;
}

.overlay {
	display: none;
}

.sp-nav {
	display: none;
}

.top-text {
	font-size: 1rem;
	line-height: 1.1875;
	padding-bottom: 0.375rem;
	padding-left: 1.5625rem;
	padding-top: 0.3125rem;
	text-align: left;
}

.works-swiper__button-prev,
.works-swiper__button-next {
	bottom: auto;
	bottom: initial;
	height: 3.125rem;
	top: 55%;
	width: 3.125rem;
}

.works-swiper__button-prev {
	left: -1.5%;
}

.works-swiper__button-next {
	right: -1.5%;
}

}

@media (min-width: 1240px) {

html {
	font-size: 16px;
}

}

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

.works-swiper__button-prev {
	left: -8.5%;
}

.works-swiper__button-next {
	right: -8.5%;
}

}

@media (max-width: 390px) {

html {
	font-size: 4.1025641026vw;
}

}

@keyframes shine {

0% {
	left: -75%;
}

100% {
	left: 125%;
}

}

/* Swiper 矢印を最前面に出す */
.works-swiper__button-prev,
.works-swiper__button-next {
  z-index: 200;
  pointer-events: auto;
}
/* ===== Swiper 表示不具合の最終修正 ===== */
.works-swiper__slider.swiper {
	overflow: hidden;
  }

  /* Follower Banner CSS */
#follower-banner {
	position: fixed;
	bottom: 10px;
	right: 0px;
	background: #fff;
	box-shadow: 0 2px 5px rgba(0,0,0,0.1);
	display: flex;
	justify-content: center;
	align-items: center;
	z-index: 10050; /* overlayより前に */
	padding: 3px;
	border-radius: 5px;
	max-width: 30%;
	opacity: 0;               /* 初期は非表示 */
	transform: translateY(10px);
	pointer-events: none;
	transition: opacity 0.3s ease, transform 0.3s ease;
  }
  
  #follower-banner.is-visible {
	opacity: 1;
	transform: translateY(0);
	pointer-events: auto;
  }
  
  #follower-banner a { display: block; }
  #follower-banner img { max-width: 100%; height: auto; }
  
  #close-banner {
	position: absolute;
	top: 5px;
	right: 5px;
	font-size: 20px;
	cursor: pointer;
  }
  
  @media (max-width: 768px) {
	#follower-banner { max-width: 100%; }
  }
  
  #internal-link{
	padding: 3rem 0;
	background: rgba(29, 42, 80, 0.10);
  }
  
  .internal-link__main-title{
	font-size: 1.3rem;
	text-align: center;
	margin-bottom: 2rem;
	font-weight: bold;
  }
  
  .internal-link__area-items{
	justify-content: space-between;
	display: flex;
	-webkit-flex-wrap: wrap;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	/* justify-content: center; */
	overflow: hidden;
	margin: 2rem 0;
  }
  
  .internal-link__area-item-child-title{
	font-size: 1.5rem;
	border-bottom: 1px solid #000;
	margin-bottom: 1rem;
  }
  
  .internal-link__area-item-child-inners{
	margin-left: 1rem;
  }
  
  .internal-link__area-item-child-inner{
	width: 30%;
	margin: 0.5rem;
	box-sizing: border-box;
  }
  
  .internal-link__area-item-child-inner a{
	font-size: 1rem;
	position: relative;
	padding-left: 2.5rem;
	font-weight: 500;
  }
  
  .internal-link__area-item-child-inner a::before{
	content: "";
	margin: auto;
	position: absolute;
	top: 0;
	bottom: 0;
	left: 2px;
	width: 9px;
	height: 9px;
	border-top: 1px solid #000;
	border-right: 1px solid #000;
	transform: rotate(45deg);
  }
  
  @media screen and (max-width: 768px) {
	.internal-link__area-item-child-inner{
	  width: 100%;
	}
	.internal-link__area-item-child-title{
	  margin-bottom: 2rem;
	}
	.internal-link__area-items {
	  display: block;
	}
  }

  #media_image-2 {
	display: none;
  }

  /* scroll top 共通 */
.scroll-top {
	position: fixed;
	right: 1.125rem;
	width: 3.75rem;
	height: 3.75rem;
	border-radius: 50%;
	box-shadow: 0 0.25rem 0.25rem rgba(0, 0, 0, 0.25);
	z-index: 9999;
}

.scroll-top img {
	width: 3.75rem;
	height: 3.75rem;
	display: block;
}

@media (max-width: 767px) {
	.scroll-top {
		bottom: 150px; /* バナーの上にスペースを確保 */
	}
}

@media (min-width: 768px) {
	.scroll-top {
		bottom: 160px; /* PCではもっと余裕を持たせる */
	}
}

/* 1500px〜2199px */
@media (min-width: 1500px) and (max-width: 2199px) {
	.scroll-top {
		bottom: 240px;
	}
}

/* 2200px〜 */
@media (min-width: 2200px) {
	.scroll-top {
		bottom: 310px;
	}
}
/*# sourceMappingURL=style.css.map */



