/*====================
共通：お問い合わせコンテンツ
ブレイクポイント: variables.css 参照
====================*/
.c-contents-contact {
	position: relative;
	overflow-x: clip;
	background: #fff;
}

.c-contents-contact__inner {
	box-sizing: border-box;
	width: 1520px;
	max-width: 1520px;
	margin-inline: auto;
	padding: 80px 0;
}

@media screen and (max-width: 1919px) {
	.c-contents-contact__inner {
		width: min(calc(100% - clamp(48px, 6vw, 80px)), 1520px);
		padding: 72px clamp(32px, 4vw, 40px);
	}
}

@media screen and (max-width: 1365px) {
	.c-contents-contact__inner {
		width: calc(100% - 48px);
		padding: 64px 24px;
	}
}

@media screen and (max-width: 1279px) {
	.c-contents-contact__inner {
		width: 100%;
		max-width: 100%;
		padding: 64px clamp(24px, 4vw, 40px);
	}
}

.c-contents-contact__main {
	display: flex;
	flex-direction: row;
	align-items: stretch;
	justify-content: center;
	gap: 24px;
}

@media screen and (max-width: 1365px) {
	.c-contents-contact__main {
		gap: 20px;
	}
}

@media screen and (max-width: 1279px) {
	.c-contents-contact__main {
		flex-direction: column;
		gap: 36px;
	}
}

.c-contents-contact__content {
	display: flex;
	flex-direction: column;
	flex: 0 0 600px;
	width: 600px;
	max-width: 600px;
	min-width: 0;
	overflow: visible;
}

@media screen and (max-width: 1279px) {
	.c-contents-contact__content {
		display: block;
		flex: none;
		width: 100%;
		max-width: 560px;
		margin-inline: auto;
	}
}

.c-contents-contact__head {
	position: relative;
	z-index: 1;
	margin-bottom: 32px;
	padding-top: 0;
}

@media screen and (max-width: 1279px) {
	.c-contents-contact__head {
		margin-bottom: 28px;
		padding-top: 56px;
	}
}

.c-contents-contact__visual-head {
	position: relative;
	z-index: 0;
	min-height: 186px;
	margin-bottom: 20px;
	overflow: visible;
}

@media screen and (max-width: 1279px) {
	.c-contents-contact__visual-head {
		position: absolute;
		top: 64px;
		right: clamp(16px, 4vw, 40px);
		left: clamp(16px, 4vw, 40px);
		min-height: 72px;
		margin-bottom: 0;
		pointer-events: none;
	}
}

.c-contents-contact__yuragi-slot {
	display: block;
	position: absolute;
	right: 0;
	bottom: 0;
	z-index: 1;
	width: 348px;
	height: 186px;
	pointer-events: none;
}

@media screen and (max-width: 1279px) {
	.c-contents-contact__yuragi-slot {
		display: none;
	}
}

.c-contents-contact__yuragi {
	position: relative;
}

.c-contents-contact__yuragi--head {
	width: 348px;
	height: 186px;
}

.c-contents-contact__yuragi--btn {
	width: 91px;
	height: 94px;
}

.c-contents-contact__yuragi-shape {
	position: absolute;
	display: block;
	transform-origin: 50% 50%;
}

/* 348×186 — 左下 0,0 → top = 186 - y - height */
.c-contents-contact__yuragi-shape--1 {
	left: 0;
	top: 177px;
	width: 8px;
	height: 9px;
	background: #35566b;
	opacity: 1;
	clip-path: polygon(50% 0, 100% 100%, 0 100%);
}

.c-contents-contact__yuragi-shape--2 {
	left: 54px;
	top: 138px;
	width: 21px;
	height: 24px;
	background: #9ad7ff;
	opacity: 0.8;
	clip-path: polygon(40% 0, 100% 100%, 0 75%);
}

.c-contents-contact__yuragi-shape--3 {
	left: 86px;
	top: 50px;
	width: 8px;
	height: 18px;
	background: #b7d7eb;
	opacity: 0.5;
	clip-path: polygon(50% 0, 100% 100%, 0 100%);
}

.c-contents-contact__yuragi-shape--4 {
	left: 136px;
	top: -5px;
	width: 88px;
	height: 91px;
	background: #d1edff;
	opacity: 0.7;
	clip-path: polygon(16% 0, 100% 100%, 0 82%);
}

.c-contents-contact__yuragi-shape--5 {
	left: 166px;
	top: 2px;
	width: 23px;
	height: 42px;
	background: #16346d;
	opacity: 0.5;
	clip-path: polygon(50% 0, 100% 100%, 0 100%);
}

.c-contents-contact__yuragi-shape--6 {
	left: 278px;
	top: 83px;
	width: 41px;
	height: 24px;
	background: #92c8ea;
	opacity: 0.5;
	clip-path: polygon(0 0, 100% 38%, 22% 100%);
}

.c-contents-contact__yuragi-shape--7 {
	left: 324px;
	top: 24px;
	width: 18px;
	height: 20px;
	background: #35566b;
	opacity: 0.5;
	clip-path: polygon(50% 0, 100% 100%, 0 100%);
}

/* btn 91×94 — 左下 0,0 */
.c-contents-contact__yuragi-shape--btn-1 {
	left: 1px;
	top: 2px;
	width: 88px;
	height: 91px;
	background: #d1edff;
	opacity: 0.5;
	clip-path: polygon(16% 0, 100% 100%, 0 82%);
}

.c-contents-contact__yuragi-shape--btn-2 {
	left: 17px;
	top: 6px;
	width: 23px;
	height: 42px;
	background: #16346d;
	opacity: 0.5;
	clip-path: polygon(50% 0, 100% 100%, 0 100%);
}

.c-contents-contact__bg-text {
	position: absolute;
	top: 0;
	right: 0;
	left: auto;
	z-index: 0;
	width: 100%;
	margin: 0;
	color: rgba(26, 45, 90, 0.08);
	font-family: var(--font-en);
	font-size: clamp(114px, 10.8vw, 222px);
	font-style: italic;
	font-weight: 500;
	line-height: 1.2;
	letter-spacing: -0.02em;
	text-align: right;
	white-space: nowrap;
	pointer-events: none;
}

.c-contents-contact__deco {
	display: block;
	line-height: 0;
	pointer-events: none;
}

.c-contents-contact__deco img {
	display: block;
	width: 100%;
	height: auto;
	max-width: none;
}

.c-contents-contact__deco--head {
	display: none;
}

@media screen and (max-width: 1279px) {
	.c-contents-contact__deco--head {
		display: block;
		position: absolute;
		top: 0;
		right: 0;
		z-index: 1;
		width: clamp(90px, 16vw, 160px);
	}
}

.c-contents-contact__deco--btn-pc {
	display: block;
	position: absolute;
	bottom: 0;
	left: 0;
	z-index: 0;
	width: 91px;
	height: 94px;
	transform: translate(-38%, 42%);
}

@media screen and (max-width: 1279px) {
	.c-contents-contact__deco--btn-pc {
		display: none;
	}
}

.c-contents-contact__deco--bottom-sp {
	position: absolute;
	bottom: 0;
	left: 0;
	z-index: 1;
	width: clamp(80px, 24vw, 140px);
}

.c-contents-contact__title {
	position: relative;
	z-index: 2;
	margin: 0 0 24px;
	color: var(--color-c-color);
	font-size: 60px;
	font-weight: 700;
	line-height: 1.3;
	letter-spacing: 0.07em;
}

@media screen and (max-width: 1919px) {
	.c-contents-contact__title {
		font-size: clamp(52px, 4.2vw, 60px);
	}
}

@media screen and (max-width: 1535px) {
	.c-contents-contact__title {
		font-size: clamp(48px, 4vw, 56px);
	}
}

@media screen and (max-width: 1365px) {
	.c-contents-contact__title {
		font-size: 48px;
	}
}

.c-contents-contact__title.js-anim-sweep {
	display: block;
	width: 100%;
}

.c-contents-contact__build {
	display: flex;
	flex-direction: column;
}

.c-contents-contact__lead {
	position: relative;
	z-index: 2;
	margin: 0;
	color: var(--color-c-color);
	font-size: 20px;
	font-weight: 500;
	line-height: 1.5;
	letter-spacing: 0.12em;
}

@media screen and (max-width: 1535px) {
	.c-contents-contact__lead {
		font-size: clamp(18px, 1.5vw, 20px);
	}
}

@media screen and (max-width: 1365px) {
	.c-contents-contact__lead {
		font-size: 18px;
	}
}

.c-contents-contact__br-sp {
	display: none;
}

@media screen and (max-width: 1279px) {
	.c-contents-contact__br-sp {
		display: inline;
	}
}

.c-contents-contact__line {
	position: relative;
	z-index: 2;
	display: block;
	width: 100%;
	height: 1px;
	margin: 24px 0 0;
	padding: 0;
	border: 0;
	background: rgba(26, 45, 90, 0.25);
}

.c-contents-contact__list {
	display: flex;
	flex-direction: column;
	gap: 6px;
	margin: 0 0 32px;
	padding: 0;
	list-style: none;
}

.c-contents-contact__item {
	position: relative;
	padding-left: 1.1em;
	color: #333333;
	font-size: 16px;
	font-weight: 500;
	line-height: 1.7;
	letter-spacing: 0.16em;
}

.c-contents-contact__item::before {
	content: "・";
	position: absolute;
	left: 0;
}

.c-contents-contact__actions {
	position: relative;
	display: flex;
	flex-direction: column;
	align-items: stretch;
	gap: 24px;
	max-width: 406px;
	margin-top: auto;
	overflow: visible;
}

@media screen and (max-width: 1279px) {
	.c-contents-contact__actions {
		gap: 16px;
		max-width: 100%;
		margin-top: 0;
	}
}

.c-contents-contact__tel {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 4px;
	width: 100%;
	padding: 20px 24px;
	border-radius: 8px;
	background: var(--color-c-color);
	box-shadow: 0 0 0 rgba(26, 45, 90, 0);
	color: #fff;
	text-decoration: none;
	transition:
		background-color 0.25s ease,
		box-shadow 0.25s ease,
		transform 0.25s ease;
}

.c-contents-contact__tel:hover {
	background: #152447;
	box-shadow: 0 8px 24px rgba(26, 45, 90, 0.22);
	transform: translateY(-2px);
}

.c-contents-contact__tel:active {
	box-shadow: 0 4px 14px rgba(26, 45, 90, 0.16);
	transform: translateY(0);
}

.c-contents-contact__tel:focus-visible {
	outline: 2px solid var(--color-c-color);
	outline-offset: 3px;
}

.c-contents-contact__tel-row {
	display: flex;
	align-items: center;
	gap: 12px;
}

.c-contents-contact__tel-icon {
	display: flex;
	flex-shrink: 0;
	align-items: center;
	justify-content: center;
	width: 26px;
	height: 26px;
	border-radius: 50%;
	background: #fff;
	transition: transform 0.25s ease;
}

.c-contents-contact__tel:hover .c-contents-contact__tel-icon {
	transform: scale(1.08);
}

.c-contents-contact__tel-icon img {
	display: block;
	width: 15px;
	height: 17px;
	max-width: none;
}

.c-contents-contact__tel-num {
	font-size: 32px;
	font-weight: 700;
	line-height: 1.2;
	letter-spacing: 0.07em;
}

.c-contents-contact__tel-hours {
	font-size: 14px;
	font-weight: 500;
	line-height: 1.5;
	text-align: center;
}

.c-contents-contact__btn-wrap {
	position: relative;
}

.c-contents-contact__btn {
	position: relative;
	z-index: 1;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	min-height: 50px;
	padding: 12px 24px;
	border-radius: 8px;
	background: var(--color-c-color);
	box-shadow: 0 0 0 rgba(26, 45, 90, 0);
	color: #fff;
	font-size: 16px;
	font-weight: 700;
	line-height: 1.5;
	text-decoration: none;
	transition:
		background-color 0.25s ease,
		box-shadow 0.25s ease,
		transform 0.25s ease;
}

.c-contents-contact__btn:hover {
	background: #152447;
	box-shadow: 0 8px 24px rgba(26, 45, 90, 0.22);
	transform: translateY(-2px);
}

.c-contents-contact__btn:active {
	box-shadow: 0 4px 14px rgba(26, 45, 90, 0.16);
	transform: translateY(0);
}

.c-contents-contact__btn:focus-visible {
	outline: 2px solid var(--color-c-color);
	outline-offset: 3px;
}

.c-contents-contact__visual {
	position: relative;
	display: flex;
	flex-direction: column;
	flex: 1 1 auto;
	width: auto;
	max-width: none;
	min-width: 0;
}

@media screen and (max-width: 1279px) {
	.c-contents-contact__visual {
		display: block;
		position: static;
		flex: none;
		width: 100%;
		max-width: 560px;
		margin-inline: auto;
		padding-bottom: 24px;
	}
}

.c-contents-contact__collage {
	display: block;
	position: relative;
	z-index: 1;
	margin-top: auto;
	line-height: 0;
}

@media screen and (max-width: 1279px) {
	.c-contents-contact__collage {
		margin-top: 0;
	}
}

.c-contents-contact__collage img {
	display: block;
	width: 100%;
	height: auto;
	border-radius: 8px;
}

.c-contents-contact__deco--btn-pc {
	transition:
		opacity 0.6s ease,
		transform 0.6s cubic-bezier(0.22, 1, 0.36, 1);
}

.js-anim-scroll-in:not(.is-scroll-inview) .c-contents-contact__deco--btn-pc {
	opacity: 0;
	transform: translate(-38%, 42%) translate3d(-8px, 10px, 0) rotate(-6deg);
}

.js-anim-scroll-in.is-scroll-inview .c-contents-contact__deco--btn-pc {
	opacity: 1;
	transform: translate(-38%, 42%);
	transition-delay: 1.05s;
}

@media (prefers-reduced-motion: reduce) {
	.js-anim-scroll-in:not(.is-scroll-inview) .c-contents-contact__deco--btn-pc {
		opacity: 1;
		transform: translate(-38%, 42%);
	}

	.c-contents-contact__tel,
	.c-contents-contact__btn {
		transition: background-color 0.25s ease;
	}

	.c-contents-contact__tel:hover,
	.c-contents-contact__btn:hover {
		box-shadow: none;
		transform: none;
	}

	.c-contents-contact__tel:hover .c-contents-contact__tel-icon {
		transform: none;
	}
}

/* max-1279（タブレット・1カラム） */
@media screen and (max-width: 1279px) {
	.c-contents-contact__inner {
		max-width: 100%;
		padding: 64px clamp(24px, 4vw, 40px);
	}

	.c-contents-contact__main {
		gap: 36px;
	}

	.c-contents-contact__content {
		display: block;
		width: 100%;
		max-width: 560px;
		margin-inline: auto;
	}

	.c-contents-contact__visual {
		display: block;
		position: static;
		width: 100%;
		max-width: 560px;
		margin-inline: auto;
		padding-bottom: 24px;
	}

	.c-contents-contact__collage {
		margin-top: 0;
	}

	.c-contents-contact__actions {
		margin-top: 0;
		max-width: 100%;
	}

	.c-contents-contact__visual-head {
		position: absolute;
		top: 64px;
		right: clamp(16px, 4vw, 40px);
		left: clamp(16px, 4vw, 40px);
		margin-bottom: 0;
		min-height: 72px;
		pointer-events: none;
	}

	.c-contents-contact__bg-text {
		font-size: clamp(72px, 14vw, 120px);
	}

	.c-contents-contact__deco--head {
		width: clamp(90px, 16vw, 160px);
	}

	.c-contents-contact__head {
		padding-top: 56px;
	}

	.c-contents-contact__title {
		font-size: clamp(28px, 4.5vw, 36px);
	}

	.c-contents-contact__lead {
		font-size: clamp(17px, 2.2vw, 18px);
	}

	.c-contents-contact__tel,
	.c-contents-contact__btn-wrap,
	.c-contents-contact__btn {
		max-width: 100%;
	}

	.c-contents-contact__deco--btn-pc {
		display: none;
	}
}

/* max-1079（820px帯・iPad Air） */
@media screen and (max-width: 1079px) {
	.c-contents-contact__inner {
		padding: 56px 24px;
	}

	.c-contents-contact__visual-head {
		top: 56px;
	}

	.c-contents-contact__head {
		padding-top: 48px;
	}

	.c-contents-contact__bg-text {
		font-size: clamp(64px, 15vw, 104px);
	}

	.c-contents-contact__title {
		font-size: clamp(26px, 5vw, 32px);
	}

	.c-contents-contact__content,
	.c-contents-contact__visual {
		max-width: 480px;
	}
}

/* max-819（768px帯・iPad mini） */
@media screen and (max-width: 819px) {
	.c-contents-contact__inner {
		padding: 48px 20px;
	}

	.c-contents-contact__main {
		gap: 32px;
	}

	.c-contents-contact__visual-head {
		top: 48px;
		right: 20px;
		left: 20px;
	}

	.c-contents-contact__head {
		padding-top: 44px;
	}

	.c-contents-contact__bg-text {
		font-size: clamp(60px, 17vw, 96px);
	}

	.c-contents-contact__title {
		font-size: 26px;
	}

	.c-contents-contact__content,
	.c-contents-contact__visual {
		max-width: 100%;
	}
}

/* max-600（スマホ） */
@media screen and (max-width: 600px) {
	.c-contents-contact__inner {
		padding: 40px 16px;
	}

	.c-contents-contact__visual-head {
		top: 40px;
		right: 16px;
		left: 16px;
		min-height: 64px;
	}

	.c-contents-contact__head {
		padding-top: 40px;
		margin-bottom: 24px;
	}

	.c-contents-contact__bg-text {
		font-size: clamp(56px, 18vw, 80px);
	}

	.c-contents-contact__deco--head {
		width: clamp(72px, 20vw, 110px);
	}

	.c-contents-contact__title {
		font-size: 24px;
	}

	.c-contents-contact__lead {
		font-size: 18px;
	}

	.c-contents-contact__list {
		gap: 12px;
	}

	.c-contents-contact__tel {
		padding: 16px 20px;
	}

	.c-contents-contact__btn {
		padding: 12px 20px;
	}
}

/* max-467 */
@media screen and (max-width: 467px) {
	.c-contents-contact__inner {
		padding: 36px 16px;
	}

	.c-contents-contact__bg-text {
		font-size: clamp(52px, 19vw, 72px);
	}

	.c-contents-contact__title {
		font-size: 28px;
	}

	.c-contents-contact__lead {
		font-size: 17px;
	}

	.c-contents-contact__tel-num {
		font-size: 28px;
	}
}

/* max-374 */
@media screen and (max-width: 374px) {
	.c-contents-contact__bg-text {
		font-size: 50px;
	}

	.c-contents-contact__title {
		font-size: 28px;
	}
}

/* max-360 */
@media screen and (max-width: 360px) {
	.c-contents-contact__inner {
		padding: 32px 12px;
	}

	.c-contents-contact__visual-head {
		right: 12px;
		left: 12px;
	}

	.c-contents-contact__bg-text {
		font-size: 48px;
	}

	.c-contents-contact__deco--head {
		width: 68px;
	}

	.c-contents-contact__tel,
	.c-contents-contact__btn {
		padding-inline: 16px;
	}
}
