/* Section-specific visual styles. */
@charset "UTF-8";

@media (max-width: 1280px) and (min-width: 481px) {
	html,
	body {
		font-size: calc(100vw * var(--default-font-size) / 1280);
	}
}

@media (max-width: 480px) {
	html {
		font-size: calc(100vw * var(--default-font-size) / 480);
	}
}

select {
	color: #999 !important; /* 初期はグレー */
}
select.has-value {
	color: #317295 !important; /* 選択後はテーマカラー */
}

input::placeholder {
	color: #999;
}

textarea::placeholder {
	color: #999;
}

input[type="date"] {
	appearance: none; /* ブラウザのデフォルトスタイルを無効化 */
	-webkit-appearance: none;
	-moz-appearance: none;
	color: #999 !important;
}

input[type="date"],
input[type="time"],
input[type="datetime-local"] {
	-webkit-appearance: none;
	appearance: none;
}

input[type="date"]::-webkit-date-and-time-value,
input[type="time"]::-webkit-date-and-time-value {
	text-align: left;
}

input[type="date"].has-value {
	color: #317295 !important; /* 入力後はテーマカラー */
}

.grecaptcha-badge {
	visibility: hidden;
}

.sp-only {
	display: none;
}
@media (max-width: 480px) {
	.sp-only {
		display: block;
	}
}

.top {
	display: none;
	background-color: #bf380c;
	padding: 6.25rem;
	height: 300vh;
}

.top__title {
	font-size: 1.875rem;
}

.contactForm__input {
	width: 100%;
	padding: 8px;
	border: 1px solid #ccc;
}

.controls {
	text-align: center;
	margin-top: 10px;
}

.controls button {
	margin: 0 5px;
	padding: 6px 12px;
	font-size: 16px;
}

.slide-button,
.top__scroll-button {
	background-color: #bf380c;
	color: #000;
	border: none;
}
.slide-button.active,
.top__scroll-button.active {
	border: 1px solid #000;
}

.top-slide {
	padding: 1.25rem;
}

.simulator__wrapper {
	background-color: #f7f4e9;
}

.simulator {
	max-width: 1280px;
	margin: 0 auto;
	background-color: #f7f4e9;
	padding: 6.25rem 8.125rem;
}
@media (max-width: 480px) {
	.simulator {
		padding: 2.5rem 0.625rem;
	}
}

.simulator__inner {
	background-color: #bf380c;
	border-radius: 1.875rem;
}
@media (max-width: 480px) {
	.simulator__inner {
		border-radius: 0.3125rem;
	}
}

.simulator__title-wrapper {
	position: relative;
	text-align: center;
	padding: 0.875rem 0 1.25rem;
}

.simulator__title {
	color: #fff;
	margin-left: -2.5rem;
}

.simulator__title-small {
	font-size: 1.75rem;
	font-weight: 700;
	margin-right: 0.125rem;
}
@media (max-width: 480px) {
	.simulator__title-small {
		font-size: 1.125rem;
	}
}

.simulator__title-small-text {
	position: relative;
	display: inline-block;
}
.simulator__title-small-text::before {
	content: "";
	width: 6px;
	height: 6px;
	background-color: #fff;
	border-radius: 50%;
	position: absolute;
	top: -6px;
	left: 50%;
	transform: translateX(-50%);
}
@media (max-width: 480px) {
	.simulator__title-small-text::before {
		width: 3px;
		height: 3px;
		top: -3px;
	}
}

.simulator__title-minutes {
	font-size: 2.25rem;
	font-weight: 700;
	margin-right: 0.625rem;
}
@media (max-width: 480px) {
	.simulator__title-minutes {
		font-size: 1.5rem;
	}
}

.simulator__title-text {
	font-size: 2.5rem;
	font-weight: 700;
}
@media (max-width: 480px) {
	.simulator__title-text {
		font-size: 1.5rem;
	}
}

.simulator__title-image-wrapper {
	width: 9.125rem;
	position: absolute;
	top: calc(50% + 1.875rem);
	right: 0;
	transform: translateY(-50%);
	z-index: 0;
}
@media (max-width: 480px) {
	.simulator__title-image-wrapper {
		width: 5.3125rem;
	}
}

.simulator__content-wrapper {
	overflow: hidden;
	opacity: 0;
	height: 0;
}
.simulator__content-wrapper.init {
	opacity: 1;
	height: auto;
}

.simulator__content-inner {
	background-color: #fff;
	/* border-radius: 1.25rem; */
	border-radius: 0 0 1.25rem 1.25rem;
}
@media (max-width: 480px) {
	.simulator__content-inner {
		border-radius: 0 0 0.3125rem 0.3125rem;
	}
}

.simulator__content {
	padding: 0 0.625rem 0.625rem;
	z-index: 1;
}

.simulator__content-title-wrapper {
	width: 100%;
	box-shadow: 0px 4px 14px rgba(0, 0, 0, 0.25);
}

.simulator__content-title {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 1.25rem;
	padding: 0.875rem 0;
}
@media (max-width: 480px) {
	.simulator__content-title {
		gap: 0.625rem;
	}
}

.simulator__content-title-image-wrapper {
	width: 5.5rem;
}
@media (max-width: 480px) {
	.simulator__content-title-image-wrapper {
		width: 2.25rem;
	}
}

.simulator__content-title-text {
	font-size: 2.375rem;
	color: #317295;
	font-weight: 700;
}
@media (max-width: 480px) {
	.simulator__content-title-text {
		font-size: 0.875rem;
	}
}

.simulator__content-title-text-small {
	font-size: 0.875rem;
	color: #317295;
	margin-top: 0.5rem;
}
@media (max-width: 480px) {
	.simulator__content-title-text-small {
		font-size: 0.625rem;
		margin-top: 0.25rem;
	}
}

.simulator__content-buttons {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 1.25rem;
	padding: 1.375rem 0.625rem;
}
@media (max-width: 480px) {
	.simulator__content-buttons {
		gap: 0.5rem;
		padding: 0.625rem 0.5rem;
	}
}

.simulator__content-button {
	width: calc(33.3333333333% - 0.875rem);
	box-shadow: 0px 4px 16px rgba(0, 0, 0, 0.3);
	display: flex;
	align-items: center;
	/* justify-content: space-between; */
	border-radius: 4px;
	padding: 1.375rem 1.25rem;
	border: 3px solid #fff;
	/* transform:skew(-4deg,0deg); */
	gap: 8px;
	position: relative;
}
.simulator__content-button.active {
	border: 3px solid #bf380c;
	background-image: linear-gradient(
		0deg,
		rgba(255, 135, 0, 0.3),
		rgba(255, 135, 0, 0.3)
	);
}

.simulator__content-button:before {
	position: absolute;
	content: "";
	border: 2px solid #bf380c;
	height: 2.3rem;
	aspect-ratio: 1 / 1;
	border-radius: 50%;
	background-color: white;
	/* transform: translateY(-1px); */
}

.simulator__content-button.active .simulator__content-button-arrow {
	opacity: 1;
	z-index: 1;
}
@media (max-width: 480px) {
	.simulator__content-button.active {
		border: 2px solid #bf380c;
	}
}
@media (max-width: 480px) {
	.simulator__content-button {
		width: calc(50% - 0.25rem);
		padding: 1rem 0.5rem;
		/* border-radius: 0.3125rem; */
		/* border: 2px solid #fff; */
		box-shadow: 0px 2px 8px rgba(0, 0, 0, 0.3);
	}
	.simulator__content-button:before {
		border: 1px solid #bf380c;
		height: 1.2rem;
		transform: translateX(-1px);
	}
}

.simulator__content-button-text {
	font-size: 1.625rem;
	color: #317295;
	font-weight: 700;
}
@media (max-width: 480px) {
	.simulator__content-button-text {
		font-size: 1rem;
	}
}

.simulator__content-button-text--small {
	font-size: 1.625rem;
}
@media (max-width: 480px) {
	.simulator__content-button-text--small {
		font-size: 1rem;
	}
}

.simulator__content-button-arrow {
	width: 2.4375rem;
	opacity: 0;
}
@media (max-width: 480px) {
	.simulator__content-button-arrow {
		width: 1rem;
	}
}

.simulator__content-controls {
	display: flex;
	align-items: center;
	justify-content: space-between;
	position: relative;
}

.simulator__content-controls--last {
	display: block;
	padding: 0.625rem 0 1.25rem;
}

.simulator__content-back-button {
	display: inline-flex;
	align-items: center;
	gap: 0.25rem;
	padding: 0 0.625rem 1.25rem;
}
@media (max-width: 480px) {
	.simulator__content-back-button {
		padding: 0 0.3125rem 0.625rem;
	}
}

.simulator__content-back-button--last {
	position: absolute;
	left: 0;
	top: calc(50% - 0.3125rem);
	transform: translateY(-50%);
	padding: 0;
}

.simulator__content-back-button-image-wrapper {
	width: 2.875rem;
}
@media (max-width: 480px) {
	.simulator__content-back-button-image-wrapper {
		width: 1.25rem;
	}
}

.simulator__content-back-button-text {
	font-size: 1.5rem;
	color: #bf380c;
	font-weight: 700;
	padding-bottom: 0.125rem;
	border-bottom: 2px solid #bf380c;
}
@media (max-width: 480px) {
	.simulator__content-back-button-text {
		font-size: 0.75rem;
	}
}

.simulator__content-next-button {
	padding: 0 0.875rem 1.25rem;
}
@media (max-width: 480px) {
	.simulator__content-next-button {
		padding: 0 0.3125rem 0.625rem;
	}
}

.simulator__content-next-button-text {
	font-size: 1.5rem;
	color: #bf380c;
	font-weight: 700;
	padding-bottom: 0.125rem;
	border-bottom: 2px solid #bf380c;
}
@media (max-width: 480px) {
	.simulator__content-next-button-text {
		font-size: 0.75rem;
	}
}

.simulator__form {
	padding: 3.75rem 4.375rem 0;
}
@media (max-width: 480px) {
	.simulator__form {
		padding: 1.25rem 0.625rem 0;
	}
}

.simulator__form-item {
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 3.125rem;
}
.simulator__form-item:last-child {
	margin-bottom: 0;
}
@media (max-width: 480px) {
	.simulator__form-item {
		display: block;
		margin-bottom: 0.875rem;
	}
}

.simulator__form-label-wrapper {
	width: 16.8125rem;
	margin-right: 1.25rem;
	display: flex;
	align-items: center;
	justify-content: space-between;
}
@media (max-width: 480px) {
	.simulator__form-label-wrapper {
		width: auto;
		margin-right: 0;
		margin-bottom: 0.25rem;
		justify-content: flex-start;
	}
}

.simulator__form-label-text {
	font-size: 1.5rem;
	color: #317295;
	font-weight: 700;
}
@media (max-width: 480px) {
	.simulator__form-label-text {
		font-size: 0.75rem;
		margin-right: 0.75rem;
	}
}

.simulator__form-label-required {
	font-size: 1.25rem;
	color: #317295;
	padding: 0.125rem 0.5rem;
	border-radius: 0.3125rem;
	border: 1px solid #bf380c;
	color: #bf380c;
}
@media (max-width: 480px) {
	.simulator__form-label-required {
		font-size: 0.75rem;
	}
}

.simulator__form-input {
	flex: 1;
	border: 2px solid #bf380c;
	border-radius: 0.3125rem;
	padding: 0.625rem 0.875rem;
	font-size: 1.5rem;
	color: #317295;
}
@media (max-width: 480px) {
	.simulator__form-input {
		width: 100%;
		border: 1px solid #bf380c;
		font-size: 0.75rem;
		padding: 0.5rem;
	}
}

.simulator__form-button-wrapper {
	width: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
}

.simulator__form-button {
	padding: 1.25rem 3.75rem;
	background-image: linear-gradient(94.07deg, #f35c0b 0%, #bf380c 100%);
	color: #fff;
	font-size: 2rem;
	font-weight: 700;
	border-radius: 1.25rem;
	opacity: 0.5;
	transition: opacity 0.2s ease-in-out;
	pointer-events: none;
}
.simulator__form-button.active {
	opacity: 1;
	pointer-events: auto;
}
@media (max-width: 480px) {
	.simulator__form-button {
		width: 70%;
		border-radius: 0.3125rem;
		text-align: center;
		padding: 0.625rem 1.25rem;
		font-size: 1rem;
		margin: 0 auto;
	}
}

.simulator__result-button-wrapper {
	padding: 3.75rem 0;
	display: flex;
	align-items: center;
	justify-content: center;
}
@media (max-width: 480px) {
	.simulator__result-button-wrapper {
		padding: 1.25rem 0;
	}
}

.simulator__result-button {
	padding: 1.25rem 2.5rem;
	background-image: linear-gradient(94.07deg, #f35c0b 0%, #bf380c 100%);
	color: #fff;
	border-radius: 1.25rem;
	font-size: 1.5rem;
	font-weight: 700;
	display: flex;
	align-items: center;
	gap: 0.625rem;
}
@media (max-width: 480px) {
	.simulator__result-button {
		border-radius: 0.3125rem;
		font-size: 1rem;
		padding: 0.625rem 1.25rem;
	}
}

.simulator__result-button-image-wrapper {
	width: 2.5rem;
}
@media (max-width: 480px) {
	.simulator__result-button-image-wrapper {
		width: 1.25rem;
	}
}

.simulator__result-content {
	padding: 6.875rem 4.375rem 0;
}
@media (max-width: 480px) {
	.simulator__result-content {
		padding: 3.75rem 0.625rem 2.5rem;
	}
}

.simulator__result-title-wrapper {
	width: 100%;
	position: relative;
}

.simulator__result-title-image-wrapper {
	width: 18.75rem;
	position: absolute;
	top: 0;
	left: 50%;
	transform: translate(-50%, -100%);
	z-index: 1;
}
@media (max-width: 480px) {
	.simulator__result-title-image-wrapper {
		width: 9.375rem;
	}
}

.simulator__result-title-text-wrapper {
	margin-bottom: 6.25rem;
	display: flex;
	align-items: center;
	justify-content: center;
}
@media (max-width: 480px) {
	.simulator__result-title-text-wrapper {
		margin-bottom: 2.5rem;
	}
}

.simulator__result-title-text-inner {
	position: relative;
	margin: 0 0.625rem;
}
@media (max-width: 480px) {
	.simulator__result-title-text-inner {
		margin: 0 0.3125rem;
	}
}

.simulator__result-title-bar {
	display: block;
	height: 0.9375rem;
	background-color: #f35c0b;
	border-radius: 0.625rem;
}
@media (max-width: 480px) {
	.simulator__result-title-bar {
		height: 0.5rem;
		border-radius: 0.3125rem;
	}
}

.simulator__result-title-text {
	font-size: 2.25rem;
	color: #f35c0b;
	font-weight: 700;
}
@media (max-width: 480px) {
	.simulator__result-title-text {
		font-size: 1.125rem;
	}
}

.simulator__result-title-text--large {
	font-size: 5rem;
}
@media (max-width: 480px) {
	.simulator__result-title-text--large {
		font-size: 1.5rem;
	}
}

.simulator__result-title-decoration-wrapper {
	width: 2.25rem;
}
@media (max-width: 480px) {
	.simulator__result-title-decoration-wrapper {
		width: 0.875rem;
	}
}

.simulator__result-description {
	font-size: 1.5rem;
	color: #317295;
	font-weight: 700;
	line-height: 1.5;
	text-align: center;
}
@media (max-width: 480px) {
	.simulator__result-description {
		font-size: 0.75rem;
	}
}

.simulator__result-description--force {
	color: #bf380c;
}

.simulator__result-form {
	width: 34.375rem;
	margin: 0 auto 2.5rem;
	position: relative;
}
.simulator__result-form::before {
	content: "";
	width: 105%;
	height: 100%;
	background-color: #bf380c;
	position: absolute;
	bottom: -1.125rem;
	left: 50%;
	transform: translateX(-50%);
	z-index: 0;
	border-radius: 1.25rem;
}
@media (max-width: 480px) {
	.simulator__result-form {
		width: 80%;
	}
}

.simulator__result-form-inner {
	position: relative;
	z-index: 1;
	background-color: #fff;
	padding: 2.75rem 0 1.625rem;
	border: 5px solid #bf380c;
	border-radius: 1.25rem;
}
@media (max-width: 480px) {
	.simulator__result-form-inner {
		padding: 1.25rem 0 0.625rem;
	}
}

.simulator__result-form-sub-title {
	font-size: 1rem;
	color: #fff;
	font-weight: 700;
	position: absolute;
	top: 0;
	left: 50%;
	transform: translate(-50%, -50%);
	background-color: #bf380c;
	padding: 0.5rem 1.5625rem;
	white-space: nowrap;
	border-radius: 0.625rem;
}
@media (max-width: 480px) {
	.simulator__result-form-sub-title {
		font-size: 0.75rem;
		padding: 0.25rem 0.9375rem;
	}
}

.simulator__result-form-title {
	font-size: 1.75rem;
	color: #317295;
	font-weight: 700;
	margin-bottom: 1.25rem;
	text-align: center;
}
@media (max-width: 480px) {
	.simulator__result-form-title {
		font-size: 1rem;
		margin-bottom: 0.625rem;
	}
}

.simulator__result-form-button-wrapper {
	font-size: 1.75rem;
	display: flex;
	align-items: center;
	justify-content: center;
	color: #fff;
	font-weight: 700;
}
@media (max-width: 480px) {
	.simulator__result-form-button-wrapper {
		font-size: 0.875rem;
	}
}

.simulator__result-form-button {
	width: 21.25rem;
	text-align: center;
	background-color: #bf380c;
	padding: 1.25rem 1.25rem;
	border-radius: 1.875rem;
	line-height: 1;
}
@media (max-width: 480px) {
	.simulator__result-form-button {
		width: 10rem;
		border-radius: 0.625rem;
		padding: 0.625rem 0.625rem;
	}
}

.simulator__result-form-description {
	font-size: 1.125rem;
	color: #317295;
}
@media (max-width: 480px) {
	.simulator__result-form-description {
		font-size: 0.75rem;
	}
}

.voice__inner {
	max-width: 1280px;
	margin: 0 auto;
	padding: 5rem 1.25rem 4.5rem;
}
@media (max-width: 480px) {
	.voice__inner {
		padding: 3rem 1rem 2.5rem;
	}
}

.voice__content {
	max-width: 1080px;
	margin: 0 auto;
}

.voice__title-wrapper {
	text-align: center;
	margin-bottom: 2.75rem;
}
@media (max-width: 480px) {
	.voice__title-wrapper {
		margin-bottom: 1.5rem;
	}
}

.voice__title-label {
	display: inline-block;
	margin-bottom: 0.875rem;
	font-size: 1rem;
	letter-spacing: 0.08em;
	font-weight: 700;
	color: #f35c0b;
	padding: 0.4rem 0.95rem;
}
@media (max-width: 480px) {
	.voice__title-label {
		font-size: 0.75rem;
		padding: 0.3rem 0.7rem;
		margin-bottom: 0.5rem;
	}
}

.voice__title-text {
	display: block;
	font-size: 2.8rem;
	line-height: 1.25;
	font-weight: 700;
	color: #317295;
	text-shadow: 0 1px 0 rgba(255, 255, 255, 0.35);
}
@media (max-width: 480px) {
	.voice__title-text {
		font-size: 1.5rem;
	}
}

.voice__list-wrapper {
	width: 100%;
	max-width: 1000px;
	margin: 0 auto;
}

.voice__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.25rem;
}
@media (min-width: 768px) {
	.voice__grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
	.voice__grid .voice__card:last-child {
		grid-column: 1 / -1;
		max-width: 30rem;
		justify-self: center;
	}
}

.voice__card {
	position: relative;
	display: flex;
	flex-direction: column;
	background-color: #fff;
	border: 1px solid #f7f4e9;
	border-radius: 1rem;
	overflow: hidden;
	box-shadow: 0 8px 18px rgba(40, 33, 25, 0.07);
}
@media (max-width: 480px) {
	.voice__card {
		border-radius: 0.75rem;
	}
}

.voice__card-badge {
	position: absolute;
	top: 0.875rem;
	left: 0.875rem;
	z-index: 2;
	background-color: #5b7c20;
	color: #fff;
	font-size: 0.875rem;
	font-weight: 700;
	line-height: 1;
	padding: 0.5rem 0.7rem;
	border-radius: 9999px;
	box-shadow: 0 4px 10px rgba(0, 0, 0, 0.2);
}
@media (max-width: 480px) {
	.voice__card-badge {
		font-size: 0.75rem;
		padding: 0.4rem 0.62rem;
		top: 0.75rem;
		left: 0.75rem;
	}
}

.voice__card-image {
	height: 230px;
	background-repeat: no-repeat;
	background-position: 60% 40%;
	background-size: auto 500px;
}

.voice__card-image--v1 {
	background-image: url("../images/external/www.omatomekun.com/wp-content/themes/omatomekun/images/voice/v1.jpg");
}

.voice__card-image--v2 {
	background-image: url("../images/external/www.omatomekun.com/wp-content/themes/omatomekun/images/voice/v2.jpg");
	background-position: 60% 18%;
	background-size: auto 420px;
}

.voice__card-image--v3 {
	background-image: url("../images/external/www.omatomekun.com/wp-content/themes/omatomekun/images/voice/v3.jpg");
	background-position: 60% 30%;
}

.voice__card-title {
	background-color: #bf380c;
	color: #fff;
	text-align: center;
	font-weight: 700;
	font-size: 1.125rem;
	padding: 0.9rem 0.75rem;
	line-height: 1.4;
}

.voice__card-body {
	padding: 1rem 1rem 0;
	flex: 1;
}

.voice__card-text {
	text-align: justify;
	font-size: 1rem;
	line-height: 1.75;
	font-weight: 600;
	color: #3d3024;
}

.voice__card-meta {
	padding: 0.875rem 1rem 1rem;
	text-align: right;
	font-size: 0.95rem;
	line-height: 1.6;
	color: #5e4a36;
}

@media (max-width: 480px) {
	.voice__card-image {
		height: 205px;
		background-size: auto 430px;
	}
	.voice__card-image--v2 {
		background-size: auto 390px;
	}
	.voice__card-title {
		font-size: 1rem;
		padding: 0.75rem 0.6rem;
	}
	.voice__card-body {
		padding: 0.75rem 0.75rem 0;
	}
	.voice__card-text {
		font-size: 0.875rem;
		line-height: 1.7;
	}
	.voice__card-meta {
		padding: 0.75rem;
		font-size: 0.8125rem;
	}
}

.property-count {
	position: relative;
	overflow: hidden;
}

.property-count__bg-main {
	position: absolute;
	top: 0;
	left: 50%;
	transform: translateX(-50%);
	z-index: 1;
	width: 150%;
	border-left: 0.625rem solid transparent;
	border-right: 0.625rem solid transparent;
	border-bottom: 0.625rem solid #bf380c; /* ← 上向き三角の色と大きさ */
}
@media (max-width: 480px) {
	.property-count__bg-main {
		width: 180%;
	}
}

.property-count__bg-main-inner {
	display: block;
	position: relative;
	width: 100%;
	height: 100%;
}

.property-count__bg-main-image {
	display: block;
	position: relative;
	z-index: 1;
}

.property-count__bg-sub {
	position: absolute;
	display: block;
	top: 0;
	right: 0;
	width: 50%;
	height: 100%;
	z-index: 0;
	background-color: #f2c81c;
}

.property-count__inner {
	position: relative;
	z-index: 2;
}

.property-count__title-label {
	display: block;
	width: 15rem;
	margin: 0 auto 1.25rem;
}
@media (max-width: 480px) {
	.property-count__title-label {
		width: 7.5rem;
		margin: 0 auto 0.625rem;
	}
}

.property-count__title {
	text-align: center;
	padding: 11.25rem 0 5.625rem;
}
@media (max-width: 480px) {
	.property-count__title {
		padding: 6.25rem 0 0.3125rem 5rem;
		margin-bottom: 1.25rem;
	}
}

.property-count__title-text {
	display: inline-block;
	font-size: 4rem;
	color: #fff;
	font-weight: 700;
	position: relative;
}
@media (max-width: 480px) {
	.property-count__title-text {
		font-size: 1.5rem;
	}
}

.property-count__title-text-image-wrapper {
	display: block;
	width: 13.25rem;
	position: absolute;
	bottom: 0;
	left: -0.625rem;
	transform: translateX(-100%);
}
@media (max-width: 480px) {
	.property-count__title-text-image-wrapper {
		width: 5rem;
	}
}

.property-count__contents {
	background-color: #bf380c;
	border-radius: 0 0 0.625rem 0.625rem;
	padding-bottom: 2.5rem;
}
@media (max-width: 480px) {
	.property-count__contents {
		padding-bottom: 1.25rem;
	}
}

.property-count__list {
	max-width: 1280px;
	margin: 0 auto;
	display: flex;
	flex-wrap: wrap;
	gap: 0.25rem;
	padding: 0 4.375rem 3.75rem;
}
@media (max-width: 480px) {
	.property-count__list {
		padding: 0 1.25rem 6.25rem;
	}
}

.property-count__item {
	width: calc(20% - 0.25rem);
	background-color: #fff;
	border-radius: 0.3125rem;
	padding: 1.125rem 0;
	text-align: center;
	font-size: 1.5rem;
	color: #bf380c;
	cursor: pointer;
}
.property-count__item--other {
	width: calc(40% - 0.25rem);
}
@media (max-width: 480px) {
	.property-count__item--other {
		width: calc(33.33333% - 0.25rem);
	}
}
.property-count__item.active {
	background-color: #f35c0b;
	color: #fff;
}
@media (max-width: 480px) {
	.property-count__item {
		font-size: 0.75rem;
		width: calc(33.33333% - 0.25rem);
	}
}

.property-count__content-wrapper {
	position: relative;
	z-index: 1;
	background-color: #fff;
	display: none;
}
.property-count__content-wrapper.active {
	display: block;
}

.property-count__content {
	max-width: 1280px;
	margin: 0 auto;
	position: relative;
	overflow: hidden;
	padding: 4.375rem 0 3.75rem;
}

.property-count__content-title {
	font-size: 2.5rem;
	color: #bf380c;
	position: absolute;
	top: 0;
	left: 50%;
	transform: translate(-50%, -50%);
	background-color: #fff;
	padding: 0.625rem 3.75rem;
	border-radius: 3.75rem;
}
@media (max-width: 480px) {
	.property-count__content-title {
		width: 80%;
		text-align: center;
		font-weight: 700;
		font-size: 1.5rem;
		padding: 1.25rem 0;
	}
}

.property-count__swiper {
	padding: 0 6.875rem;
	opacity: 0;
	height: 0;
}
.property-count__swiper.init {
	opacity: 1;
	height: auto;
}
@media (max-width: 480px) {
	.property-count__swiper {
		width: 90%;
		padding: 0 1.25rem;
		margin: 0 auto;
	}
}

.property-count__swiper-slide {
	box-shadow: 0px 8px 24px rgba(0, 0, 0, 0.25);
	border-radius: 0.625rem;
	height: auto;
	overflow: hidden;
}

.property-count__swiper-slide-image-wrapper {
	width: 100%;
	position: relative;
	padding-top: 103.0042918455%;
	overflow: hidden;
}

.property-count__swiper-slide-image {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.property-count__swiper-slide-text-wrapper {
	padding: 1.25rem;
}

.property-count__swiper-slide-text-item {
	margin-bottom: 0.625rem;
	display: flex;
	justify-content: space-between;
	position: relative;
	color: #317295;
	font-size: 1.125rem;
	font-weight: 700;
}
.property-count__swiper-slide-text-item:last-child {
	margin-bottom: 0;
}

.property-count__swiper-slide-text-item-text {
	display: inline-block;
	text-align: left;
	width: calc(50% + 0.9375rem);
}
@media (max-width: 480px) {
	.property-count__swiper-slide-text-item-text {
		width: calc(50% + 0.625rem);
	}
}

.property-count__swiper-slide-text-item-separator {
	position: absolute;
	top: 0.5625rem;
	left: calc(50% - 1.875rem);
	transform: translate(-50%, -50%);
	color: #317295;
}
@media (max-width: 480px) {
	.property-count__swiper-slide-text-item-separator {
		left: calc(50% - 1.25rem);
	}
}

.swiper-pagination-bullet {
	border: 2px solid #bf380c !important;
	background-color: #fff !important;
}

.swiper-pagination-bullet-active {
	background-color: #bf380c !important;
	border: 2px solid #bf380c !important;
}

.property-count__swiper-button-prev,
.property-count__swiper-button-next {
	width: 3.125rem;
	height: 3.125rem;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	cursor: pointer;
	z-index: 10;
}
.property-count__swiper-button-prev.swiper-button-disabled,
.property-count__swiper-button-next.swiper-button-disabled {
	opacity: 0;
	pointer-events: none;
}

.property-count__swiper-button-prev {
	left: 0.625rem;
}

.property-count__swiper-button-next {
	right: 0.625rem;
}

.faq__inner {
	padding: 5rem 4rem;
	max-width: 1180px;
	margin: 0 auto;
}
@media (max-width: 480px) {
	.faq__inner {
		padding: 3.25rem 1rem;
	}
}

.faq__title {
	text-align: center;
	margin-bottom: 2.5rem;
}
@media (max-width: 480px) {
	.faq__title {
		margin-bottom: 1.5rem;
	}
}

.faq__title-label {
	display: inline-block;
	font-size: 1rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	color: #f35c0b;
	border-radius: 9999px;
	padding: 0.4rem 0.95rem;
	margin-bottom: 0.875rem;
}
@media (max-width: 480px) {
	.faq__title-label {
		margin-bottom: 0.5rem;
		font-size: 0.75rem;
		padding: 0.3rem 0.7rem;
	}
}

.faq__title-text {
	display: block;
	font-size: 2.8rem;
	font-weight: 700;
	line-height: 1.25;
	color: #317295;
}
@media (max-width: 480px) {
	.faq__title-text {
		font-size: 1.5rem;
	}
}

.faq__content {
	max-width: 980px;
	margin: 0 auto;
}

.faq__content-inner {
	display: flex;
	flex-direction: column;
	gap: 1rem;
}
@media (max-width: 480px) {
	.faq__content-inner {
		gap: 0.75rem;
	}
}

.faq__content-item {
	background: #fff;
	border: 1px solid #f7f4e9;
	border-radius: 1rem;
	box-shadow: 0 8px 18px rgba(40, 33, 25, 0.07);
	overflow: hidden;
}
@media (max-width: 480px) {
	.faq__content-item {
		border-radius: 0.75rem;
	}
}

.faq__content-item-title {
	display: grid;
	grid-template-columns: 2.625rem minmax(0, 1fr) 2.25rem;
	align-items: center;
	column-gap: 0.875rem;
	padding: 1rem 1.125rem;
	border: 1px solid #f7f4e9;
	cursor: pointer;
	transition: background-color 0.2s ease;
}
.faq__content-item-title.open {
	background: #f7f4e9;
}
@media (max-width: 480px) {
	.faq__content-item-title {
		grid-template-columns: 1.875rem minmax(0, 1fr) 1.625rem;
		column-gap: 0.625rem;
		padding: 0.875rem 0.75rem;
	}
}

.faq__content-item-title-arrow {
	display: flex;
	width: 2.25rem;
	height: 2.25rem;
	align-items: center;
	justify-content: center;
	border-radius: 9999px;
	border: 1px solid #f7f4e9;
	background: #f7f4e9;
	margin-left: auto;
}
.faq__content-item-title-arrow.open .faq__content-item-title-arrow-image--plus {
	display: none;
}
.faq__content-item-title-arrow.open
	.faq__content-item-title-arrow-image--minus {
	display: block;
}
@media (max-width: 480px) {
	.faq__content-item-title-arrow {
		width: 1.625rem;
		height: 1.625rem;
	}
}

.faq__content-item-title-arrow-image {
	width: 62%;
	height: auto;
}

.faq__content-item-title-arrow-image--minus {
	display: none;
}

.faq__content-item-question {
	display: inline-flex;
	width: 2.625rem;
	min-width: 2.625rem;
	height: 2.625rem;
	align-items: center;
	justify-content: center;
	border-radius: 9999px;
	background: #bf380c;
	font-size: 1.25rem;
	font-weight: 700;
	line-height: 1;
	color: #ffffff;
}
@media (max-width: 480px) {
	.faq__content-item-question {
		width: 1.875rem;
		min-width: 1.875rem;
		height: 1.875rem;
		font-size: 1rem;
		font-weight: 700;
	}
}

.faq__content-item-title-text {
	display: block;
	font-size: 1.1875rem;
	font-weight: 700;
	line-height: 1.55;
	color: #000000;
}
@media (max-width: 480px) {
	.faq__content-item-title-text {
		font-size: 1rem;
		line-height: 1.45;
	}
}

.faq__content-item-content-wrapper {
	height: 0;
	overflow: hidden;
}
.faq__content-item-content-wrapper.open {
	height: auto;
}

.faq__content-item-content {
	padding: 0 1.125rem 1rem;
}
@media (max-width: 480px) {
	.faq__content-item-content {
		padding: 0 0.75rem 0.875rem;
	}
}

.faq__content-item-content-inner {
	padding: 1rem;
	display: grid;
	grid-template-columns: 2.625rem minmax(0, 1fr);
	align-items: flex-start;
	column-gap: 0.875rem;
	border-radius: 0.875rem;
	background: transparent;
}
@media (max-width: 480px) {
	.faq__content-item-content-inner {
		padding: 0.875rem 0.75rem;
		grid-template-columns: 1.875rem minmax(0, 1fr);
		column-gap: 0.625rem;
		border-radius: 0.625rem;
	}
}

.faq__content-item-answer {
	display: block;
	width: auto;
	min-width: auto;
	height: auto;
	font-size: 1.4rem;
	font-weight: 700;
	line-height: 1.2;
	color: #f35c0b;
}
@media (max-width: 480px) {
	.faq__content-item-answer {
		font-size: 1.15rem;
	}
}

.faq__content-item-content-text {
	display: block;
	font-size: 1rem;
	color: #000000;
	line-height: 1.7;
}
@media (max-width: 480px) {
	.faq__content-item-content-text {
		font-size: 0.9375rem;
		line-height: 1.6;
	}
}

.contact {
	max-width: 1280px;
	margin: 0 auto;
	padding-bottom: 5rem;
	background: #ffffff;
}

.contact__inner {
	width: 100%;
	max-width: 1100px;
	margin: 0 auto;
}

.contact__notice-wrap {
	margin: 0 auto;
	padding: 0 1rem;
}

.contact__notice {
	padding: 1.25rem 1.5rem;
	border: 1px solid #f2c81c;
	border-left: 6px solid #bf380c;
	box-shadow: 0 10px 28px rgba(122, 53, 0, 0.08);
}

.contact__notice-title {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	line-height: 1.5;
}

.contact__notice-items {
	gap: 0.35rem;
	line-height: 1.5;
}

.contact__notice-note {
	color: #317295;
	line-height: 1.6;
}

.contact__form-wrap {
	padding: 1.25rem 1rem 0;
}

.contact__form-card {
	max-width: 1000px;
	margin: 0 auto;
	background: #ffffff;
	border: 1px solid #f7f4e9;
	border-radius: 1.5rem;
	box-shadow: 0 14px 36px rgba(40, 33, 25, 0.1);
	overflow: hidden;
}

.contact__form {
	padding: 1.25rem 1.5rem 1.75rem;
}

.contact__form-feedback {
	margin-bottom: 1rem;
	padding: 0.75rem 0.875rem;
	border-radius: 0.75rem;
	font-size: 0.95rem;
	line-height: 1.5;
}

.contact__form-feedback--success {
	border: 1px solid #7ab55c;
	background: #edf8e5;
	color: #245a0d;
}

.contact__form-feedback--error {
	border: 1px solid #f0b2b2;
	background: #fff1f1;
	color: #8d2121;
}

.contact__form-feedback-list {
	margin: 0;
	padding-left: 1.2rem;
}

.contact__form-grid {
	gap: 0;
}

.contact__form-row {
	padding: 1rem 0;
}

.contact__form-row + .contact__form-row {
	border-top: 1px solid #f7f4e9;
}

.contact__form-label-area {
	align-items: center;
}

.contact__form-label {
	color: #317295;
	letter-spacing: 0.02em;
}

.contact__form-badge {
	min-width: 3.4em;
	text-align: center;
	font-weight: 700;
	line-height: 1.2;
}

.contact__form-badge--required {
	color: #bf380c;
	border-color: #bf380c;
	background: #f7f4e9;
}

.contact__form-badge--optional {
	color: #317295;
	border-color: #f7f4e9;
	background: #f7f4e9;
}

.contact__form-control-area {
	min-width: 0;
}

.contact__form-input-image-wrapper {
	width: 30px;
	display: block;
	position: absolute;
	top: 12px;
	right: 10px;
}
@media (max-width: 480px) {
	.contact__form-input-image-wrapper {
		width: 20px;
		top: 9px;
	}
}

.contact__form-option-input-wrapper {
	flex: 1;
	min-width: 0;
	position: relative;
}

.contact__form-checkbox {
	font-size: 1rem;
	line-height: 1.4;
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 0.5rem 0.75rem;
}
@media (max-width: 480px) {
	.contact__form-checkbox {
		font-size: 1rem;
		grid-template-columns: minmax(0, 1fr);
	}
}

.contact__form-checkbox .wpcf7-list-item {
	margin: 0;
}

.contact__form-checkbox .wpcf7-list-item label {
	display: flex;
	gap: 0.5rem;
	align-items: flex-start;
	padding: 0.5rem 0.625rem;
	border: 1px solid #f7f4e9;
	border-radius: 0.625rem;
	background: #f7f4e9;
	color: #000000;
}

.contact__form-checkbox .wpcf7-list-item input {
	margin-top: 0.28rem;
	accent-color: #bf380c;
}

.contact__form-checkbox .wpcf7-list-item-label {
	font-size: 0.95rem;
	line-height: 1.45;
	color: #000000;
}

.contact__form-input,
.contact__form-textarea,
.contact__form-select {
	flex: 1;
	border: 1px solid #f7f4e9;
	border-radius: 0.75rem;
	padding: 0.75rem 0.875rem;
	font-size: 1.0625rem;
	line-height: 1.45;
	color: #000000;
	width: 100%;
	background: #f7f4e9;
	transition:
		border-color 0.2s ease,
		box-shadow 0.2s ease,
		background-color 0.2s ease;
}
@media (max-width: 480px) {
	.contact__form-input,
	.contact__form-textarea,
	.contact__form-select {
		font-size: 1rem;
		padding: 0.6875rem 0.75rem;
	}
}

.contact__form-select {
	padding-right: 2.25rem;
	appearance: none;
	background-image:
		linear-gradient(45deg, transparent 50%, #bf380c 50%),
		linear-gradient(135deg, #bf380c 50%, transparent 50%);
	background-position:
		calc(100% - 18px) calc(50% - 2px),
		calc(100% - 12px) calc(50% - 2px);
	background-size: 6px 6px;
	background-repeat: no-repeat;
}
@media (max-width: 480px) {
	.contact__form-select {
		background-position:
			calc(100% - 14px) calc(50% - 1px),
			calc(100% - 9px) calc(50% - 1px);
	}
}

.contact .wpcf7-form-control-wrap {
	flex: 1;
}
.contact .wpcf7-form-control-wrap select,
.contact .wpcf7-form-control-wrap textarea {
	width: 100%;
}

.contact__form-input::placeholder,
.contact__form-textarea::placeholder {
	color: #999999;
}

/* Contact form values should be readable in black even after has-value state toggles. */
.contact .contact__form select {
	color: #000000 !important;
}

.contact .contact__form input[type="date"] {
	color: #000000 !important;
}

.contact .contact__form select.has-value {
	color: #000000 !important;
}

.contact .contact__form input[type="date"].has-value {
	color: #000000 !important;
}

.contact__form-input:focus,
.contact__form-textarea:focus,
.contact__form-select:focus {
	outline: none;
	border-color: #f35c0b;
	background: #ffffff;
	box-shadow: 0 0 0 3px rgba(184, 119, 63, 0.15);
}

.contact__form-textarea {
	min-height: 7.5rem;
	resize: vertical;
}

.contact__field-note {
	display: block;
	margin-top: 0.5rem;
	color: #317295;
	line-height: 1.5;
}

.contact__datetime-row {
	margin-bottom: 0.625rem;
	align-items: stretch;
}

.contact__datetime-row:last-child {
	margin-bottom: 0;
}

.contact__submit-wrap {
	position: relative;
	margin-top: 1.5rem;
	width: 100%;
	max-width: 24rem;
	border-radius: 0.875rem;
	background: #bf380c;
	border: 1px solid #bf380c;
	box-shadow: none;
	transition: background-color 0.2s ease;
}

.contact__submit-wrap:hover {
	background: #bf380c;
}

.contact__form-button {
	width: 100%;
	padding: 0.95rem 0.75rem;
	font-size: 1.2rem;
	font-weight: 700;
	letter-spacing: 0.03em;
	color: #fff;
	background: transparent;
	border: none;
	cursor: pointer;
}
@media (max-width: 480px) {
	.contact__form-button {
		font-size: 1rem;
		padding: 0.85rem 0.75rem;
	}
}

input[type="date"]::-webkit-calendar-picker-indicator {
	cursor: pointer;
	background: transparent;
}

.contact .wpcf7-spinner {
	position: absolute;
	top: 50%;
	right: 0.625rem;
	transform: translateY(-50%);
}

@media (min-width: 481px) {
	.contact__form-row {
		display: grid;
		grid-template-columns: minmax(0, 18rem) minmax(0, 1fr);
		column-gap: 1.5rem;
		align-items: flex-start;
	}

	.contact__form-label-area {
		display: grid;
		grid-template-columns: minmax(0, 1fr) auto;
		column-gap: 0.75rem;
		align-items: center;
		justify-content: initial;
		width: 100%;
		min-width: 0;
		padding-top: 0.45rem;
	}

	.contact__form-label {
		margin-right: 0;
		min-width: 0;
	}

	.contact__form-badge {
		flex-shrink: 0;
	}
}

@media (max-width: 480px) {
	.contact {
		padding-bottom: 3.5rem;
	}

	.contact__notice-wrap {
		padding: 0 0.5rem;
	}

	.contact__notice {
		padding: 1rem 0.875rem;
	}

	.contact__form-wrap {
		padding: 1rem 0.5rem 0;
	}

	.contact__form {
		padding: 0.875rem 0.875rem 1.25rem;
	}

	.contact__form-row {
		padding: 0.75rem 0;
	}

	.contact__datetime-row {
		flex-direction: column;
		gap: 0.5rem;
	}

	.contact__submit-wrap {
		margin-top: 1.25rem;
	}
}

.consult {
	width: 100%;
	padding: 6.25rem 0 9.375rem;
	background-color: #fff;
}
@media (max-width: 480px) {
	.consult {
		padding: 3.125rem 0 6.25rem;
	}
}

.consult__inner {
	width: 100%;
	max-width: 1280px;
	margin: 0 auto;
	padding: 0 6.25rem;
}
@media (max-width: 480px) {
	.consult__inner {
		padding: 0 1.25rem;
	}
}

.consult__frame-wrap {
	width: 100%;
	display: flex;
	gap: 2.5rem;
	justify-content: center;
}
@media (max-width: 480px) {
	.consult__frame-wrap {
		gap: 1.25rem;
	}
}

.consult__frame-inner {
	position: relative;
	z-index: 0;
}

.consult__frame-image-wrap {
	width: 21.25rem;
}
@media (max-width: 480px) {
	.consult__frame-image-wrap {
		width: 9.375rem;
	}
}

.consult__frame {
	width: 100%;
	display: block;
}

.consult__frame-left-text {
	position: absolute;
	z-index: 1;
	top: 50%;
	left: 50%;
	transform: translate(-50%, calc(-50% - 0.625rem));
	font-size: 1.5rem;
	color: #317295;
	white-space: nowrap;
}
@media (max-width: 480px) {
	.consult__frame-left-text {
		font-size: 0.75rem;
		top: 65%;
	}
}

.consult__frame-text-fix {
	font-weight: 700;
	color: #bf380c;
	white-space: nowrap;
}

.consult__frame-right-text {
	position: absolute;
	z-index: 1;
	top: 50%;
	left: 50%;
	transform: translate(-50%, calc(-50% - 0.625rem));
	font-size: 1.5rem;
	color: #317295;
	white-space: nowrap;
}
@media (max-width: 480px) {
	.consult__frame-right-text {
		font-size: 0.75rem;
		top: 65%;
	}
}

.consult__title {
	font-size: 2.375rem;
	font-weight: 700;
	color: #317295;
	margin-top: 0.625rem;
	text-align: center;
}
@media (max-width: 480px) {
	.consult__title {
		font-size: 1.25rem;
		margin-top: 0rem;
	}
}

.consult__content {
	width: 100%;
	display: flex;
	gap: 2.5rem;
	justify-content: center;
	margin-top: 2.5rem;
}
@media (max-width: 480px) {
	.consult__content {
		flex-direction: column;
		margin: 2.1875rem auto 0;
		gap: 3.125rem;
	}
}

.consult__content-inner {
	width: 26.25rem;
	position: relative;
	z-index: 0;
}
@media (max-width: 480px) {
	.consult__content-inner {
		width: 100%;
	}
}

.consult__form-phrase-wrap {
	width: 16.5625rem;
	background-color: #bf380c;
	border-radius: 0.625rem;
	position: absolute;
	top: -0.9375rem;
	left: 0;
	box-shadow: 0rem 0.3125rem 0.3125rem rgba(0, 0, 0, 0.25);
}
@media (max-width: 480px) {
	.consult__form-phrase-wrap {
		width: 12.5rem;
		border-radius: 0.3125rem;
	}
}

.consult__content-phrase {
	padding: 0.625rem 0;
	color: #fff;
	text-align: center;
}
@media (max-width: 480px) {
	.consult__content-phrase {
		font-size: 0.75rem;
	}
}

.consult__form-frame {
	background-color: #fff;
	border: solid 2px #bf380c;
	border-radius: 1.25rem;
	padding: 2.8125rem 0 1.25rem;
}
@media (max-width: 480px) {
	.consult__form-frame {
		border: solid 3px #bf380c;
		padding: 1.875rem 0 0.9375rem;
	}
}

.consult__content-text {
	font-size: 1.75rem;
	font-weight: 700;
	color: #317295;
	text-align: center;
}
@media (max-width: 480px) {
	.consult__content-text {
		font-size: 1.375rem;
	}
}

.consult__button-wrap {
	display: block;
	width: 21.25rem;
	margin: 1.25rem auto 0;
	cursor: pointer;
}
@media (max-width: 480px) {
	.consult__button-wrap {
		width: 17.5rem;
	}
}

.consult__button {
	width: 100%;
	display: block;
}

.consult__form-bg {
	width: 26.25rem;
	height: 12.25rem;
	background-color: #bf380c;
	border-radius: 1.25rem;
	position: absolute;
	top: 1.5625rem;
	left: 0.9375rem;
	z-index: -1;
}
@media (max-width: 480px) {
	.consult__form-bg {
		width: 100%;
		height: 9.375rem;
		top: 1.25rem;
		left: 0.625rem;
	}
}

.consult__line-phrase-wrap {
	width: 16.5625rem;
	background-color: #06c755;
	border-radius: 0.625rem;
	position: absolute;
	top: -0.9375rem;
	left: 0;
	box-shadow: 0rem 0.3125rem 0.3125rem rgba(0, 0, 0, 0.25);
}
@media (max-width: 480px) {
	.consult__line-phrase-wrap {
		width: 12.5rem;
		border-radius: 0.3125rem;
	}
}

.consult__line-frame {
	background-color: #fff;
	border: solid 2px #06c755;
	border-radius: 1.25rem;
	padding: 2.8125rem 0 1.25rem;
}
@media (max-width: 480px) {
	.consult__line-frame {
		border: solid 3px #06c755;
		padding: 1.875rem 0 0.9375rem;
	}
}

.consult__line-bg {
	width: 26.25rem;
	height: 12.25rem;
	background-color: #06c755;
	border-radius: 1.25rem;
	position: absolute;
	top: 1.5625rem;
	left: 0.9375rem;
	z-index: -1;
}
@media (max-width: 480px) {
	.consult__line-bg {
		width: 100%;
		height: 9.375rem;
		top: 1.25rem;
		left: 0.625rem;
	}
}

.consult__pc {
	display: block;
}
@media (max-width: 480px) {
	.consult__pc {
		display: none;
	}
}

.consult__sp {
	display: none;
}
@media (max-width: 480px) {
	.consult__sp {
		display: block;
	}
}

.trouble__title {
	font-size: 3.125rem;
	color: #fff;
	margin-top: 1.25rem;
}
@media (max-width: 480px) {
	.trouble__title {
		font-size: 1.25rem;
		margin-top: 0.625rem;
	}
}

.trouble__title-fix {
	font-size: 3.875rem;
	font-weight: 700;
}
@media (max-width: 480px) {
	.trouble__title-fix {
		font-size: 1.5rem;
	}
}

.trouble__content-wrap {
	width: 71.25rem;
	height: 26.125rem;
	background-color: #fff;
	padding: 2.5rem 3rem;
	position: relative;
	border-radius: 2.5rem;
	margin: 0 auto;
	box-shadow: 0rem 0.625rem 0.625rem rgba(0, 0, 0, 0.25);
}
@media (max-width: 480px) {
	.trouble__content-wrap {
		width: 80%;
		padding: 1.25rem;
		border-radius: 0.625rem;
	}
}

li.trouble__list {
	display: flex;
	align-items: center;
}
@media (max-width: 480px) {
	.trouble__list {
		align-items: flex-start;
	}
}

.trouble__list-icon-wrap {
	width: 2.1875rem;
	margin-right: 0.625rem;
}
@media (max-width: 480px) {
	.trouble__list-icon-wrap {
		max-width: 1.4375rem;
		min-width: 1.4375rem;
		margin: 0.3125rem 0.625rem 0 0;
	}
}

.trouble__list-description {
	font-size: 1.25rem;
	color: #317295;
}
@media (max-width: 480px) {
	.trouble__list-description {
		font-size: 1rem;
	}
}

.trouble__list-description-fix {
	font-size: 1.375rem;
	font-weight: 700;
	color: #bf380c;
	/* text-decoration: underline wavy; 同時適用だと iPhone へ反映されないため個別に記載。TailwindCSS で追記*/
}
@media (max-width: 480px) {
	.trouble__list-description-fix {
		font-size: 1rem;
		line-height: 1.5625rem;
	}
}

.trouble__text-image-wrap {
	width: 29.3125rem;
	position: absolute;
	top: 0;
	right: 0;
}
@media (max-width: 480px) {
	.trouble__text-image-wrap {
		width: 100%;
		position: absolute;
		top: -45%;
		left: 0;
	}
}

.trouble__text-image {
	width: 100%;
	display: block;
}

.trouble__description-wrap {
	display: flex;
	justify-content: center;
	margin-top: 2.8125rem;
	align-items: center;
}
@media (max-width: 480px) {
	.trouble__description-wrap {
		flex-direction: column;
		padding: 0 4rem;
		text-align: center;
	}
}

.trouble__description-icon-wrap {
	width: 4.6875rem;
	margin-right: 0.625rem;
}
@media (max-width: 480px) {
	.trouble__description-icon-wrap {
		width: 2.5rem;
		margin-right: 0rem;
	}
}

.trouble__description-icon {
	width: 100%;
	display: block;
}

.trouble__description {
	font-size: 2.8125rem;
	font-weight: 700;
	color: #317295;
	text-shadow:
		1px 1px 0 #fff,
		-1px 1px 0 #fff,
		1px -1px 0 #fff,
		-1px -1px 0 #fff;
}
@media (max-width: 480px) {
	.trouble__description {
		font-size: 1.375rem;
		line-height: 2.125rem;
	}
}

.trouble__description-fix {
	font-size: 1.75rem;
	margin: 0 0.3125rem;
}
@media (max-width: 480px) {
	.trouble__description-fix {
		font-size: 1.125rem;
		margin: 0;
	}
}

.trouble__description-circle {
	background-image: radial-gradient(
		circle at center,
		#f35c0b 20%,
		transparent 20%
	);
	background-position: top right;
	background-repeat: repeat-x;
	background-size: 1em 0.3em;
	padding-top: 0.625rem;
}
@media (max-width: 480px) {
	.trouble__description-circle {
		padding-top: 0;
	}
}

.trouble__description-border {
	background: linear-gradient(transparent 60%, rgba(255, 135, 0, 0.5) 30%);
	border-radius: 0.625rem;
}
@media (max-width: 480px) {
	.trouble__description-border {
		background: linear-gradient(transparent 60%, rgba(255, 135, 0, 0.5) 10%);
	}
}

.trouble__bottom-line {
	position: absolute;
	bottom: 0;
	left: 50%;
	background-color: #bf380c;
	width: 0.1875rem;
	height: 5.4375rem;
}
@media (max-width: 480px) {
	.trouble__bottom-line {
		height: 2.375rem;
	}
}

.trouble__pc {
	display: block;
}
@media (max-width: 480px) {
	.trouble__pc {
		display: none;
	}
}

.trouble__sp {
	display: none;
}
@media (max-width: 480px) {
	.trouble__sp {
		display: block;
	}
}

.service {
	width: 100%;
	position: relative;
	z-index: 0;
	background-color: #f7f4e9;
}

.service__bg {
	width: 66.25rem;
	height: 93.75rem;
	border-radius: 1.875rem;
	background-color: #bf380c;
	position: absolute;
	top: 0;
	left: 50%;
	transform: translate(-50%);
	z-index: -1;
}
@media (max-width: 480px) {
	.service__bg {
		width: 90%;
		border-radius: 0.625rem;
	}
}

.service__inner {
	max-width: 1280px;
	margin: 0 auto;
	padding: 5rem 4.375rem 10.9375rem;
	text-align: center;
}
@media (max-width: 480px) {
	.service__inner {
		padding: 1.875rem 0.625rem 3.125rem;
	}
}

.service__line {
	position: absolute;
	top: 0;
	left: 50%;
	background-color: #fff;
	width: 0.1875rem;
	height: 1.875rem;
}
@media (max-width: 480px) {
	.service__line {
		height: 1.125rem;
	}
}

.service__title-read {
	font-size: 1.5rem;
	color: #fff;
	font-weight: 700;
}
@media (max-width: 480px) {
	.service__title-read {
		font-size: 0.75rem;
	}
}

.service__title {
	font-size: 3.125rem;
	color: #fff;
	margin-top: 1.25rem;
	font-weight: 700;
}
@media (max-width: 480px) {
	.service__title {
		font-size: 2rem;
	}
}

.service__description {
	font-size: 1rem;
	color: #fff;
	margin-top: 1.25rem;
	line-height: 1.875rem;
}
@media (max-width: 480px) {
	.service__description {
		width: 20rem;
		font-size: 0.75rem;
		text-align: start;
		margin: 1.25rem auto 0;
	}
}

.service__description-fix {
	color: #f35c0b;
	font-weight: 700;
}

.service__image-wrap-top {
	margin-top: 2.5rem;
}
@media (max-width: 480px) {
	.service__image-wrap-top {
		margin-top: 1.25rem;
	}
}

.service__image {
	width: 100%;
	display: block;
}

.service__description-center {
	font-size: 3.375rem;
	color: #fff;
	margin-top: 2.5rem;
}
@media (max-width: 480px) {
	.service__description-center {
		font-size: 1.125rem;
		margin-top: 1.25rem;
	}
}

.service__description-small {
	font-size: 2.8125rem;
}
@media (max-width: 480px) {
	.service__description-small {
		font-size: 1rem;
	}
}

.service__description-circle {
	background-image: radial-gradient(
		circle at center,
		#f35c0b 10%,
		transparent 20%
	);
	background-position: top right;
	background-repeat: repeat-x;
	background-size: 1em 0.3em;
	padding-top: 1.25rem;
}
@media (max-width: 480px) {
	.service__description-circle {
		padding-top: 0.625rem;
	}
}

.service__image-wrap-bottom {
	margin-top: 1.875rem;
}
@media (max-width: 480px) {
	.service__image-wrap-bottom {
		margin-top: 0.625rem;
	}
}

.case {
	width: 100%;
	position: relative;
	z-index: 1;
	background-color: #f7f4e9;
	/* border-radius: 1.875rem; */
	box-shadow: 0rem 0rem 1.875rem rgba(0, 0, 0, 0.3);
}
@media (max-width: 480px) {
	.case {
		border-radius: 0.625rem;
	}
}

.case__inner {
	max-width: 1500px;
	margin: 0 auto;
}

.case__title-read {
	font-size: 1.5rem;
	color: #f35c0b;
	font-weight: 700;
}
@media (max-width: 480px) {
	.case__title-read {
		font-size: 0.75rem;
	}
}

.case__title {
	font-size: 3.875rem;
	color: #317295;
	margin: 1.25rem 0 3.125rem;
	font-weight: 700;
}
@media (max-width: 480px) {
	.case__title {
		font-size: 1.4375rem;
		margin: 0.625rem 0 1.25rem;
	}
}

.case__title-fix {
	font-size: 3.125rem;
}
@media (max-width: 480px) {
	.case__title-fix {
		font-size: 1.125rem;
	}
}

.case__image-wrap {
	display: flex;
	flex-flow: column;
	gap: 0.75rem;
}
@media (max-width: 480px) {
	.case__image-wrap {
		gap: 0rem;
	}
}

.case__image {
	width: 100%;
	display: block;
}

.case__pc {
	display: block;
}
@media (max-width: 480px) {
	.case__pc {
		display: none;
	}
}

.case__sp {
	display: none;
}
@media (max-width: 480px) {
	.case__sp {
		display: block;
	}
}

.company {
	width: 100%;
	background-color: #f7f4e9;
}

.company__inner {
	width: 100%;
	max-width: 1280px;
	padding: 6.25rem 5rem;
	display: flex;
	justify-content: space-between;
	margin: 0 auto;
}
@media (max-width: 480px) {
	.company__inner {
		display: block;
		padding: 3.125rem 1.25rem;
	}
}

.company__title-read {
	font-size: 1.5rem;
	color: #f35c0b;
	font-weight: 700;
}
@media (max-width: 480px) {
	.company__title-read {
		font-size: 0.75rem;
		text-align: center;
	}
}

.company__title {
	font-size: 3.125rem;
	color: #317295;
	margin-top: 1.25rem;
	font-weight: 700;
}
@media (max-width: 480px) {
	.company__title {
		font-size: 1.4375rem;
		text-align: center;
	}
}

.company__list-wrap {
	width: 43.75rem;
}
@media (max-width: 480px) {
	.company__list-wrap {
		width: 100%;
		margin-top: 1.25rem;
	}
}

.company__list {
	display: flex;
	padding: 1.5625rem 0;
	align-items: center;
	border-bottom: 1px solid #f2c81c;
	position: relative;
}
@media (max-width: 480px) {
	.company__list {
		padding: 0.9375rem 0;
	}
}

.company__list::before {
	content: "";
	width: 11.25rem;
	height: 0.0625rem;
	display: inline-block;
	background-color: #bf380c;
	position: absolute;
	top: -0.0625rem;
	left: 0;
}
@media (max-width: 480px) {
	.company__list::before {
		width: 5rem;
	}
}

.company__list:last-child::after {
	content: "";
	width: 11.25rem;
	height: 0.0625rem;
	display: inline-block;
	background-color: #bf380c;
	position: absolute;
	bottom: -0.0625rem;
	left: 0;
}
@media (max-width: 480px) {
	.company__list:last-child::after {
		width: 5rem;
	}
}

.company__list:first-child {
	border-top: 1px solid #f2c81c;
}

.company__list-title {
	width: 11.25rem;
	font-size: 1.375rem;
	color: #bf380c;
	font-weight: 700;
}
@media (max-width: 480px) {
	.company__list-title {
		width: 5rem;
		font-size: 0.75rem;
	}
}

.company__list-description {
	font-size: 1.375rem;
	color: #317295;
}
@media (max-width: 480px) {
	.company__list-description {
		font-size: 0.75rem;
		margin-left: 1.25rem;
	}
}

.point {
	width: 100%;
	position: relative;
}

.point__inner {
	width: 100%;
	max-width: 1280px;
	margin: 0 auto;
	padding: 5rem 4.375rem 9.375rem;
}
@media (max-width: 480px) {
	.point__inner {
		padding: 3.125rem 1.25rem;
	}
}

.point__title-read {
	font-size: 1.5rem;
	color: #f35c0b;
	font-weight: 700;
	text-align: center;
}
@media (max-width: 480px) {
	.point__title-read {
		font-size: 0.75rem;
	}
}

.point__title {
	font-size: 3.875rem;
	color: #317295;
	margin-top: 1.25rem;
	font-weight: 700;
	text-align: center;
	line-height: 5rem;
}
@media (max-width: 480px) {
	.point__title {
		font-size: 1.4375rem;
		line-height: 1.875rem;
	}
}

.point__title-fix {
	font-size: 3.125rem;
}
@media (max-width: 480px) {
	.point__title-fix {
		font-size: 1.25rem;
	}
}

.point__contents-wrap {
	display: flex;
	flex-flow: column;
	gap: 4.375rem;
	margin-top: 2.5rem;
}
@media (max-width: 480px) {
	.point__contents-wrap {
		margin-top: 1.25rem;
		gap: 3.125rem;
	}
}

.point__contents {
	display: flex;
	justify-content: space-between;
	align-items: center;
}
@media (max-width: 480px) {
	.point__contents {
		flex-flow: column-reverse;
	}
}

.point__contents:last-child {
	flex-direction: row-reverse;
}
@media (max-width: 480px) {
	.point__contents:last-child {
		flex-flow: column-reverse;
	}
}

.point__contents-text {
	width: 31.25rem;
}
@media (max-width: 480px) {
	.point__contents-text {
		width: 100%;
		margin-top: 1.25rem;
	}
}

.point__contents-title {
	font-size: 2.1875rem;
	color: #bf380c;
	line-height: 3.125rem;
}
@media (max-width: 480px) {
	.point__contents-title {
		font-size: 1.25rem;
		text-align: center;
		line-height: 1.25rem;
	}
}

.point__contents-description {
	font-size: 1.125rem;
	color: #317295;
	line-height: 1.5625rem;
	margin-top: 1.875rem;
}
@media (max-width: 480px) {
	.point__contents-description {
		font-size: 0.875rem;
		margin-top: 1.25rem;
		line-height: 1.5625rem;
	}
}

.point__contents-image-wrap {
	width: 32.625rem;
}
@media (max-width: 480px) {
	.point__contents-image-wrap {
		width: 100%;
	}
}

.point__image {
	width: 100%;
	display: block;
}

.point__pc {
	display: block;
}
@media (max-width: 480px) {
	.point__pc {
		display: none;
	}
}

.point__sp {
	display: none;
}
@media (max-width: 480px) {
	.point__sp {
		display: block;
	}
}

.reason {
	width: 100%;
	padding: 2.5rem 0 2.5rem;
	background: #ffffff;
}
@media (max-width: 480px) {
	.reason {
		padding: 1.75rem 0 0.75rem;
	}
}

.reason__hero-wrap {
	max-width: 1180px;
	margin: 0 auto;
	padding: 0 1rem;
}
@media (max-width: 480px) {
	.reason__hero-wrap {
		padding: 0 0.5rem;
	}
}

.reason__hero-cover {
	position: relative;
	overflow: hidden;
	border-radius: 1.5rem;
	box-shadow: 0 14px 30px rgba(40, 33, 25, 0.14);
}
.reason__hero-cover::before {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(
		180deg,
		rgba(255, 255, 255, 0.08),
		transparent 55%
	);
}
@media (max-width: 480px) {
	.reason__hero-cover {
		border-radius: 1rem;
	}
}

.reason__hero-title-image {
	position: relative;
	z-index: 1;
}

.reason__inner {
	max-width: 1180px;
	margin: 0 auto;
	padding: 2rem 1rem 0;
}
@media (max-width: 480px) {
	.reason__inner {
		padding: 1.25rem 0.5rem 0;
	}
}

.reason__list {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 1rem;
}
@media (max-width: 480px) {
	.reason__list {
		grid-template-columns: 1fr;
		gap: 0.75rem;
	}
}

.reason__item {
	position: relative;
	background: #fff;
	border-radius: 1rem;
	box-shadow: 0 8px 20px rgba(40, 33, 25, 0.08);
	padding: 2.6rem 1.1rem 1.2rem;
}
@media (max-width: 480px) {
	.reason__item {
		border-radius: 0.75rem;
		padding: 2.25rem 0.9rem 1rem;
	}
}

.reason__item-icon-wrap {
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 0.875rem;
	background: #f7f4e9;
	min-height: 7.5rem;
}
@media (max-width: 480px) {
	.reason__item-icon-wrap {
		min-height: 6.25rem;
	}
}

.reason__item-icon {
	width: 100%;
	max-width: 8.75rem;
	padding: 1rem 0;
	margin: 0 auto;
}
@media (max-width: 480px) {
	.reason__item-icon {
		max-width: 6rem;
		padding: 0.75rem 0;
	}
}

.reason__accent {
	color: #bf380c;
	background: none;
	text-decoration: underline;
	text-underline-offset: 0.2em;
	text-decoration-thickness: 0.09em;
	text-decoration-color: rgba(122, 53, 0, 0.3);
}

.reason__item .reason__item-title {
	font-size: 1.28rem;
	font-weight: 700;
	text-align: center;
	color: #317295;
	white-space: normal;
	line-height: 1.45;
	margin: 0.95rem 0 0.75rem;
	text-shadow: none;
}
@media (max-width: 480px) {
	.reason__item .reason__item-title {
		font-size: 1.06rem;
		margin: 0.75rem 0 0.55rem;
	}
}

.reason__item .reason__item-description {
	font-size: 0.96rem;
	color: #317295;
	line-height: 1.72;
	margin: 0;
}
@media (max-width: 480px) {
	.reason__item .reason__item-description {
		font-size: 0.9rem;
		line-height: 1.64;
	}
}

.reason__item-num {
	width: 3.8rem;
	aspect-ratio: 1;
	background: #f35c0b;
	font-weight: 700;
	user-select: none;
	position: absolute;
	top: 0.7rem;
	left: 0.8rem;
	border-radius: 0.8rem;
	border: none;
	box-shadow: none;
}
@media (max-width: 480px) {
	.reason__item-num {
		width: 3.25rem;
		top: 0.6rem;
		left: 0.68rem;
		border-radius: 0.65rem;
	}
}

.reason__item-num::before {
	content: "REASON";
	position: absolute;
	top: 0.45rem;
	left: 0;
	right: 0;
	font-size: 0.5rem;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-align: center;
	line-height: 1;
	color: rgba(255, 255, 255, 0.9);
}
.reason__item-num::after {
	content: attr(num-data);
	position: absolute;
	top: 1.1rem;
	left: 0;
	right: 0;
	font-size: 1.45rem;
	font-weight: 800;
	text-align: center;
	line-height: 1;
	color: #ffffff;
}
@media (max-width: 480px) {
	.reason__item-num::before {
		top: 0.36rem;
		font-size: 0.44rem;
	}

	.reason__item-num::after {
		top: 0.96rem;
		font-size: 1.2rem;
	}
}

.step {
	width: 100%;
	max-width: 1180px;
	margin: 0 auto;
	padding: 4.75rem 3.5rem 0;
}
@media (max-width: 480px) {
	.step {
		padding: 2.5rem 1rem 0;
	}
}

.step__title-read {
	display: block;
	width: fit-content;
	margin: 0 auto;
	padding: 0.3rem 0.8rem;
	border-radius: 9999px;
	font-size: 1rem;
	letter-spacing: 0.08em;
	color: #f35c0b;
	font-weight: 700;
	text-align: center;
}
@media (max-width: 480px) {
	.step__title-read {
		font-size: 0.75rem;
		padding: 0.25rem 0.6rem;
	}
}

.step__title-wrap {
	display: block;
	margin-top: 1rem;
	text-align: center;
	color: #317295;
}
@media (max-width: 480px) {
	.step__title-wrap {
		margin-top: 0.625rem;
	}
}

.step__title-sub {
	width: auto;
	display: block;
	text-align: center;
	font-size: 1.25rem;
	font-weight: 700;
	color: #bf380c;
}
@media (max-width: 480px) {
	.step__title-sub {
		font-size: 1rem;
	}
}

.step__title {
	font-size: 2.8rem;
	line-height: 1.25;
	font-weight: 700;
	margin-top: 0.35rem;
}
@media (max-width: 480px) {
	.step__title {
		font-size: 1.5rem;
		margin-top: 0.25rem;
	}
}

.step__title-fix {
	font-size: inherit;
}
@media (max-width: 480px) {
	.step__title-fix {
		font-size: inherit;
	}
}

.step__contents-list-wrap {
	max-width: 980px;
	margin: 2.5rem auto 0;
}
@media (max-width: 480px) {
	.step__contents-list-wrap {
		margin-top: 1.25rem;
	}
}

.step__contents-list {
	border: 1px solid #f7f4e9;
	border-radius: 1rem;
	background: #fff;
	box-shadow: 0 8px 20px rgba(40, 33, 25, 0.08);
	position: relative;
	z-index: 1;
	margin-bottom: 2.75rem;
}
.step__contents-list:last-child {
	margin-bottom: 0;
}

.step__contents-list-inner {
	padding: 1.5rem 1.5rem 1.35rem;
	border: 1px solid #f7f4e9;
}
@media (max-width: 480px) {
	.step__contents-list-inner {
		padding: 1rem 0.875rem 0.9rem;
	}
}

.step__contents {
	display: grid;
	grid-template-columns: 4.25rem minmax(0, 1fr);
	column-gap: 1rem;
	align-items: flex-start;
}
@media (max-width: 480px) {
	.step__contents {
		grid-template-columns: 3rem minmax(0, 1fr);
		column-gap: 0.75rem;
	}
}

.step__contents-num-wrap {
	width: 4.25rem;
	min-width: 4.25rem;
}
@media (max-width: 480px) {
	.step__contents-num-wrap {
		min-width: 3rem;
		width: 3rem;
	}
}

.step__contents-image {
	width: 100%;
	display: block;
}

.step__contents-text {
	margin-left: 0;
}
@media (max-width: 480px) {
	.step__contents-text {
		width: 100%;
	}
}

.step__contents-title {
	font-size: 1.4rem;
	line-height: 1.45;
	color: #bf380c;
	font-weight: 700;
}
@media (max-width: 480px) {
	.step__contents-title {
		display: block;
		height: auto;
		font-size: 1.1rem;
		margin-left: 0;
	}
}

.step__contents-description {
	font-size: 1rem;
	color: #000000;
	line-height: 1.7;
	margin-top: 0.75rem;
}
@media (max-width: 480px) {
	.step__contents-description {
		font-size: 0.9375rem;
		margin-top: 0.55rem;
		line-height: 1.65;
	}
}

.step__contents-image-wrap {
	width: 21.875rem;
}
@media (max-width: 480px) {
	.step__contents-image-wrap {
		width: 100%;
	}
}

.step__arrow-wrap {
	width: 3.125rem;
	position: absolute;
	bottom: -1.5625rem;
	left: 50%;
	transform: translateX(-50%);
	z-index: 2;
	pointer-events: none;
	filter: drop-shadow(0 5px 8px rgba(40, 33, 25, 0.16));
}
@media (max-width: 480px) {
	.step__arrow-wrap {
		width: 2.5rem;
		bottom: -1.25rem;
		left: 50%;
	}
}

.step__pc {
	display: block;
}
@media (max-width: 480px) {
	.step__pc {
		display: none;
	}
}

.step__sp {
	display: none;
}
@media (max-width: 480px) {
	.step__sp {
		display: block;
	}
}

/* Shared CTA button behavior for .child-cover wrappers */
.child-cover-group .child-cover {
	position: relative;
	display: flex;
	width: 100%;
	align-items: center;
	justify-content: center;
	justify-items: center;
	border: 2px solid;
	border-radius: 0.5rem;
	box-shadow: 0 0 6px rgba(0, 0, 0, 0.6);
	transition: all 150ms ease;
}

@media (hover: hover) {
	.child-cover-group .child-cover:hover {
		transform: scale(1.02);
		box-shadow: 4px 4px 14px rgba(0, 0, 0, 0.8);
	}
}

.child-cover-group .child-cover:active {
	box-shadow: none;
}

.child-cover-group--header .child-cover {
	padding: 0.5rem;
	text-wrap: nowrap;
}

@media (min-width: 769px) and (max-width: 1049px) {
	.child-cover-group--header .child-cover {
		min-width: 8.6em;
		height: 44px;
	}
}

@media (min-width: 1050px) {
	.child-cover-group--header .child-cover {
		min-width: 170px;
		height: 60px;
	}
}

.child-cover-group--banner .child-cover {
	max-width: 300px;
	height: 60px;
	padding-block: 0.5rem;
}

.thanks {
	min-height: 100vh;
	background:
		linear-gradient(
			180deg,
			rgba(247, 244, 233, 0.92) 0%,
			rgba(247, 244, 233, 0.98) 100%
		),
		url("../images/external/www.omatomekun.com/wp-content/themes/omatomekun/images/common/bg-wood.jpg")
			center/cover no-repeat;
	padding: 2.5rem 1rem 3.5rem;
}

.thanks__inner {
	max-width: 960px;
	margin: 0 auto;
}

.thanks__hero {
	position: relative;
	border-radius: 1.5rem;
	overflow: hidden;
	margin-bottom: 1.25rem;
	box-shadow: 0 12px 26px rgba(40, 33, 25, 0.16);
}

.thanks__hero-bg {
	background: linear-gradient(135deg, #bf380c 0%, #f35c0b 100%);
	height: 12.5rem;
}

.thanks__hero-content {
	position: absolute;
	inset: 0;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	text-align: center;
	padding: 1rem;
}

.thanks__hero-logo {
	width: 13.75rem;
	display: block;
	margin: 0 auto 0.6rem;
}

.thanks__hero-lead {
	font-size: 1rem;
	font-weight: 700;
	color: #f7f4e9;
	letter-spacing: 0.08em;
	margin-bottom: 0.45rem;
}

.thanks__hero-title {
	font-size: 2rem;
	font-weight: 700;
	line-height: 1.28;
	color: #fff;
}

.thanks__card {
	background: #fff;
	border: 1px solid #f7f4e9;
	border-radius: 1.5rem;
	box-shadow: 0 14px 36px rgba(40, 33, 25, 0.1);
	padding: 2.2rem 2rem 2rem;
	text-align: center;
}

.thanks__title-label {
	display: inline-block;
	font-size: 1rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	color: #f35c0b;
	border-radius: 9999px;
	padding: 0.4rem 0.95rem;
	border: 1px solid rgba(243, 92, 11, 0.25);
	margin-bottom: 0.8rem;
}

.thanks__title-text {
	font-size: 2.2rem;
	font-weight: 700;
	line-height: 1.25;
	color: #317295;
}

.thanks__description {
	margin-top: 1rem;
	font-size: 1.0625rem;
	line-height: 1.8;
	color: #3d3024;
}

.thanks__points {
	max-width: 680px;
	margin: 1.5rem auto 0;
	display: flex;
	flex-direction: column;
	gap: 0.625rem;
}

.thanks__point-item {
	display: flex;
	align-items: flex-start;
	gap: 0.5rem;
	padding: 0.7rem 0.9rem;
	border: 1px solid #f7f4e9;
	border-radius: 0.75rem;
	background: #fdfaf4;
	text-align: left;
	font-size: 1rem;
	line-height: 1.5;
	color: #3d3024;
}

.thanks__point-icon {
	width: 1rem;
	margin-top: 0.2rem;
	flex-shrink: 0;
}

.thanks__actions {
	margin-top: 1.6rem;
	display: flex;
	justify-content: center;
	gap: 0.75rem;
}

.thanks__button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 15rem;
	padding: 0.9rem 1.1rem;
	border-radius: 0.625rem;
	font-size: 1.0625rem;
	font-weight: 700;
	color: #fff;
	border: 2px solid transparent;
	transition: transform 0.15s ease;
}

.thanks__button:hover {
	transform: translateY(-1px);
}

.thanks__button--primary {
	background-color: #bf380c;
	border-color: #bf380c;
}

.thanks__button--line {
	background-color: #06c755;
	border-color: #06c755;
}

@media (max-width: 480px) {
	.thanks {
		padding: 1.25rem 0.75rem 2rem;
	}

	.thanks__hero {
		border-radius: 1rem;
		margin-bottom: 0.9rem;
	}

	.thanks__hero-bg {
		height: 10rem;
	}

	.thanks__hero-logo {
		width: 10rem;
		margin-bottom: 0.45rem;
	}

	.thanks__hero-lead {
		font-size: 0.75rem;
		margin-bottom: 0.35rem;
	}

	.thanks__hero-title {
		font-size: 1.25rem;
	}

	.thanks__card {
		border-radius: 1rem;
		padding: 1.3rem 1rem 1.2rem;
	}

	.thanks__title-label {
		font-size: 0.75rem;
		padding: 0.3rem 0.7rem;
		margin-bottom: 0.5rem;
	}

	.thanks__title-text {
		font-size: 1.5rem;
	}

	.thanks__description {
		margin-top: 0.75rem;
		font-size: 0.9rem;
		line-height: 1.65;
	}

	.thanks__points {
		margin-top: 1rem;
		gap: 0.5rem;
	}

	.thanks__point-item {
		padding: 0.55rem 0.62rem;
		font-size: 0.85rem;
	}

	.thanks__actions {
		margin-top: 1rem;
		flex-direction: column;
		gap: 0.55rem;
	}

	.thanks__button {
		width: 100%;
		min-width: 0;
		font-size: 0.95rem;
		padding: 0.8rem 0.9rem;
	}
}
