:root {
	--cta-bg-beige: #f0ebe4;
	--cta-icon-color: #333333;
	--black: #1e1e1e;
}

.c-cta-fiace {
	width: 100%;
	margin: 20px 0 0;
	color: var(--black);
	line-height: 1.6;
}

.c-cta-fiace__inner {
	display: grid;
	grid-template-columns: 1fr;
	width: 100%;
	max-width: 1280px;
	height: auto;
	margin: 0 auto;
	padding: 0;
	gap: 40px;
	align-content: space-around;
	align-items: stretch;
	justify-content: space-between;
	justify-items: stretch;
}
.c-cta-fiace__main {
	width: 100%;
	height: auto;
	display: grid;
	align-content: space-evenly;
	align-items: center;
	border-top: #dadada;
	border-top-width: 1px;
	border-top-style: dotted;
	text-align: center;
}
.c-cta-fiace__tel-wrap {
	margin-bottom: 2rem;
}
.c-cta-fiace__tel-link {
	font-size: 32px;
	letter-spacing: 0.05rem;
}

/* メインエリア */
.c-cta-fiace__row {
	display: grid;
	grid-template-columns: 1fr; /* スマホは1列 */
	align-items: center;
	gap: 20px;
	padding: 30px 0;
}

.c-cta-fiace__divider {
	border: none;
	border-top: 1px solid #fff;
	margin: 0;
}

.c-cta-fiace__tel-link {
	display: flex;
	align-items: center;
	justify-content: center;
	font-weight: 500;
	text-decoration: none;
	color: inherit;
}
p.c-cta-fiace__caption {
	font-size: 16px;
	margin: 0 auto 0.5rem;
	text-align: center;
}

.c-cta-fiace__text {
	text-align: justify;
	line-height: 1.8;
	letter-spacing: 0.05rem;
	margin: 0 5%;
}

/* アイコン共通（擬似要素） */
.c-cta-fiace__tel-link::before,
.c-cta-fiace__btn::before,
.c-cta-fiace__reserve-title::before {
	content: "";
	display: inline-block;
	background-color: var(--cta-icon-color);
	background: no-repeat;
	vertical-align: middle;
	position: relative;
	z-index: 2;
}
.c-cta-fiace__tel-link::before {
	width: 36px;
	height: 36px;
	margin-right: 6px;
	margin-top: 3px;
	background: url("../images/ico/ico-tel.svg") center center no-repeat;
}

/* ボタン基本スタイル */
.c-cta-fiace__btn-area {
	width: 90%;
	margin: 0 auto;
}

.c-cta-fiace__btn {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 100px;
	transition: opacity 0.7s;
	transition: color 0.7s ease;
}
.c-cta-fiace__btn,
.c-cta-fiace__store-list a {
	position: relative;
	overflow: hidden;
	z-index: 1;
	color: var(--black);
	text-decoration: none;
	font-weight: 500;
	border: 1px solid #ddd8d2;
	background: var(--cta-bg-beige);
	font-size: 20px;
	text-align: center;
	line-height: 1;
}

.c-cta-fiace__store-list a {
	display: block;
	padding: 23px 0;
	letter-spacing: 0.05rem;
	transition:
		color 0.3s ease,
		padding-left 0.4s cubic-bezier(0.25, 1, 0.5, 1);
}
.c-cta-fiace__store-list li a.c-cta-fiace__store-list_realshop {
	padding: 35px 0 37px;
}
.c-cta-fiace__store-list_online_sub {
	display: block;
	margin-top: 10px;
	font-size: 17px;
}

.c-cta-fiace__btn:hover,
.c-cta-fiace__btn-area:hover,
.c-cta-fiace__store-list a:hover {
	color: #414141;
	/* box-shadow: 0 8px 24px rgb(142 109 84 / 7%);  */
}

.c-cta-fiace__btn::after {
	content: "";
	position: absolute;
	inset: 0;
	background-color: #fff; /* ホバー背景色 */
	z-index: -1; /* テキストの後ろに配置 */
	transform: scaleX(0);
	transform-origin: left center;
	transition: transform 0.7s cubic-bezier(0.25, 1, 0.5, 1);
}
.c-cta-fiace__btn:hover::after {
	transform: scaleX(1);
}
a.c-cta-fiace__btn.c-cta-fiace__btn--catalog {
	font-size: 20px;
	letter-spacing: 0.4rem;
	position: relative;
	z-index: 1;
}
.c-cta-fiace__btn::before {
	width: 36px;
	height: 36px;
	margin-right: 8px;
}
.c-cta-fiace__btn--mail::before {
	background: url("../images/ico/ico-mail-thin-line.svg") center center
		no-repeat;
}
.c-cta-fiace__btn--catalog::before {
	background: url("../images/ico/ico-brochure-thin-line-2.svg") center center
		no-repeat;
	width: 44px;
	height: 44px;
	margin-right: 15px;
}

/* 来店予約エリア */
.c-cta-fiace__reserve {
	margin: 0 5%;
	text-align: center;
}

.c-cta-fiace__reserve-title {
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 22px;
	letter-spacing: 0.1rem;
	margin-bottom: 30px;
}

.c-cta-fiace__reserve-title::before {
	width: 32px;
	height: 32px;
	margin-right: 10px;
	background: url("../images/ico/ico-calendar-2.svg") center center no-repeat;
}

.c-cta-fiace__store-list {
	list-style: none;
	padding: 0;
	margin: 0 auto;
	display: grid;
	gap: 40px;
}

.c-cta-fiace__store-list a:hover::after {
	transform: scaleX(1);
}

.c-cta-fiace__store-list a::after {
	content: "";
	position: absolute;
	inset: 0;
	background-color: #ffffff;
	z-index: -1;
	transform: scaleX(0);
	transform-origin: left center;
	transition: transform 0.7s cubic-bezier(0.25, 1, 0.5, 1);
}

/* 375px以上 */
@media screen and (min-width: 375px) {
	.c-cta-fiace__btn-area {
		width: 85%;
	}
	.c-cta-fiace__text,
	.c-cta-fiace__reserve {
		margin: 0 7.5%;
	}
}
/* 428px以上 */
@media screen and (min-width: 428px) {
	.c-cta-fiace__btn-area {
		width: 85%;
	}
	.c-cta-fiace__text,
	.c-cta-fiace__reserve {
		margin: 0 7.5%;
	}
	.c-cta-fiace__tel-link {
		font-size: 36px;
		letter-spacing: 0.075rem;
	}
	.c-cta-fiace__btn,
	.c-cta-fiace__store-list a {
		font-size: 21px;
		letter-spacing: 0.05rem;
	}
	a.c-cta-fiace__btn.c-cta-fiace__btn--catalog {
		font-size: 22px;
		letter-spacing: 0.4rem;
	}
	.c-cta-fiace__reserve-title {
		font-size: 24px;
		margin-bottom: 36px;
	}
}
/* 480px以上 */
@media screen and (min-width: 480px) {
	.c-cta-fiace__btn-area {
		width: 80%;
	}
	.c-cta-fiace__text,
	.c-cta-fiace__reserve {
		margin: 0 10%;
	}
}
/* 580px以上 */
@media screen and (min-width: 580px) {
	.c-cta-fiace {
		margin: 20px 0 20px;
	}
	.c-cta-fiace__inner {
		gap: 56px;
	}
	.c-cta-fiace__btn-area {
		width: 75%;
	}
	.c-cta-fiace__text,
	.c-cta-fiace__reserve {
		margin: 0 12.5%;
	}
	.c-cta-fiace__reserve-title {
		font-size: 26px;
		margin-bottom: 40px;
	}
}

/* デスクトップ版 (680px以上) */
@media screen and (min-width: 680px) {
	.c-cta-fiace__inner {
		grid-template-columns: 1fr 1fr;
		gap: 5%;
		padding: 0;
		border-top: #dadada;
		border-top-width: 1px;
		border-top-style: solid;
		border-bottom: #dadada;
		border-bottom-width: 1px;
		border-bottom-style: solid;
	}
	.c-cta-fiace__main {
		border-top: none;
		border-top-width: 0;
		border-top-style: none;
	}
	.c-cta-fiace__row {
		grid-template-columns: 1fr;
		gap: 28px;
		padding: 30px 0;
	}
	.c-cta-fiace__row.catalog-request {
		gap: 16px;
		padding-bottom: 40px;
	}
	.c-cta-fiace__tel-link {
		font-size: 30px;
		letter-spacing: 0.06rem;
	}
	.c-cta-fiace__tel-wrap {
		margin-bottom: 1rem;
	}
	.c-cta-fiace__tel-link::before {
		width: 31px;
		height: 31px;
	}
	.c-cta-fiace__btn-area {
		width: 100%;
	}
	.c-cta-fiace__btn,
	.c-cta-fiace__store-list a {
		font-size: 19px;
		letter-spacing: 0.03rem;
	}
	.c-cta-fiace__btn {
		height: 88px;
	}
	.c-cta-fiace__btn::before {
		width: 32px;
		height: 32px;
	}
	.c-cta-fiace__divider {
		border-top: 1px solid #dadada;
	}
	.c-cta-fiace__info p.c-cta-fiace__text {
		font-size: 16px;
		margin: 0;
		line-height: 1.5;
	}
	.c-cta-fiace__btn--catalog::before {
		width: 36px;
		height: 36px;
	}
	.c-cta-fiace__reserve {
		border-left: 1px solid #ddd;
		margin: 0;
		padding: 36px 0 36px 10%;
	}
	.c-cta-fiace__reserve-title {
		font-size: 24px;
		margin-bottom: 36px;
	}
	.c-cta-fiace__reserve-title::before {
		width: 40px;
		height: 40px;
	}
	.c-cta-fiace__store-list {
		gap: 42px;
	}
	.c-cta-fiace__store-list li a.c-cta-fiace__store-list_realshop {
		padding: 36px 0 38px;
	}
	.c-cta-fiace__store-list a {
		padding: 22px 0;
	}
}
/* デスクトップ版 (834px以上) */
@media screen and (min-width: 834px) {
	.c-cta-fiace__inner {
		gap: 7%;
	}
	.c-cta-fiace__row {
		gap: 16px;
	}

	.c-cta-fiace__btn--catalog::before {
		width: 40px;
		height: 40px;
	}
	.c-cta-fiace__reserve {
		padding: 36px 0 36px 16%;
	}
	.c-cta-fiace__reserve-title {
		letter-spacing: 0.15rem;
	}
	.c-cta-fiace__btn,
	.c-cta-fiace__store-list a {
		font-size: 18px;
	}
	a.c-cta-fiace__btn.c-cta-fiace__btn--catalog {
		font-size: 20px;
	}
	.c-cta-fiace__store-list_online_sub {
		font-size: 15px;
	}
	.c-cta-fiace__btn {
		height: 78px;
	}
	.c-cta-fiace__store-list li a.c-cta-fiace__store-list_realshop {
		padding: 28px 0 30px;
	}
	.c-cta-fiace__store-list a {
		padding: 16px 0;
	}
}

/* デスクトップ版 (912px以上) */
@media screen and (min-width: 912px) {
	.c-cta-fiace__inner {
		gap: 5%;
		border-top: none;
		border-top-width: 0;
		border-top-style: none;
		border-bottom: none;
		border-bottom-width: 0;
		border-bottom-style: none;
	}
	.c-cta-fiace__main {
		border-top: #dadada;
		border-top-width: 1px;
		border-top-style: solid;
		border-bottom: #dadada;
		border-bottom-width: 1px;
		border-bottom-style: solid;
	}
	.c-cta-fiace__btn-area {
		width: 80%;
	}
	.c-cta-fiace__info p.c-cta-fiace__text {
		margin: 0 auto;
		width: 80%;
	}
	.c-cta-fiace__reserve {
		border: 1px solid #ddd;
		padding: 40px 15%;
	}
	.c-cta-fiace__store-list_online_sub {
		font-size: 14px;
	}
}
/* デスクトップ版 (1112px以上) */
@media screen and (min-width: 1112px) {
	.c-cta-fiace {
		margin: 40px 0;
	}
	.c-cta-fiace__inner {
		grid-template-columns: 0.63fr 0.37fr;
		gap: 5%;
		padding: 0;
	}

	.c-cta-fiace__row {
		grid-template-columns: 0.52fr 0.48fr; /* テキスト | ボタン固定幅 */
		gap: 5%;
	}
	.c-cta-fiace__tel-wrap {
		margin-bottom: 0.5rem;
	}
	.c-cta-fiace__tel-link {
		font-size: 34px;
	}

	.c-cta-fiace__tel-link::before {
		width: 34px;
		height: 34px;
		margin-top: 4px;
	}
	.c-cta-fiace__btn-area {
		width: 100%;
		margin: 0 auto;
	}

	.c-cta-fiace__caption {
		font-size: 15px;
	}
	.c-cta-fiace__info p.c-cta-fiace__text {
		width: 95%;
	}

	.c-cta-fiace__btn {
		width: 100%;
		height: 96px;
		font-size: 17px;
	}
	.c-cta-fiace__reserve {
		padding: 32px 15% 48px;
	}
	.c-cta-fiace__reserve-title {
		font-size: 22px;
		margin-bottom: 24px;
	}

	.c-cta-fiace__store-list {
		gap: 32px;
	}
	.c-cta-fiace__store-list a {
		font-size: 17px;
	}
}
/* デスクトップ版 (1160px以上) */
@media screen and (min-width: 1160px) {
	.c-cta-fiace__tel-link {
		font-size: 35px;
	}
	.c-cta-fiace__tel-link::before {
		width: 36px;
		height: 36px;
	}
}

/* デスクトップ版 (1280px以上) */
@media screen and (min-width: 1280px) {
}
