@charset "utf-8";

/* =====================================================
--------------------------------------------------------
オンラインお部屋探し
--------------------------------------------------------
===================================================== */

/* メインビジュアル */
.mainvisual {
	position: relative;
	display: flex;
	flex-direction: column;
	align-items: center;
	margin-bottom: 24px;
	padding-top: 32px;
	width: 100%;
	height: 300px;
	background: var(--color-grey-dark) url(/img/support/online/mainvisual-sp.png) no-repeat center bottom / cover;
	color: #fff;
	font-weight: bold;
	text-shadow: 2px 2px 2px rgba(34, 34, 34, 0.6);
}

.mainvisual h1 {
	font-size: 16px;
}

.mainvisual_catch {
	display: flex;
	justify-content: center;
	align-items: center;
	font-size: 16px;
}

.mainvisual_catch span {
	position: relative;
	margin: 0 24px;
}

.mainvisual_catch span::before,
.mainvisual_catch span:after {
	position: absolute;
	top: 50%;
	translate: 0 -50%;
	color: #fff;
	font-family: 'icomoon';
	font-size: 16px;
	font-weight: normal;
	content: "\e92d";
}

.mainvisual_catch span::before {
	left: -18px;
}

.mainvisual_catch span:after {
	right: -18px;
}

.mainvisual_lead {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	gap: 4px;
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	font-size: 24px;
}

@media screen and (min-width:1024px) {
	.mainvisual {
		margin: 64px 0 48px;
		padding-top: 80px;
		height: 540px;
		background-image: url(/img/support/online/mainvisual-pc.png);
		background-size: auto;
	}
	.mainvisual h1 {
		font-size: 24px;
	}
	.mainvisual_catch {
		font-size: 32px;
	}
	.mainvisual_lead {
		font-size: 36px;
	}
}

p:has(+ iframe) {
	margin: 0 auto 24px;
	text-align: center;
	line-height: 2;
}

iframe {
	display: block;
	margin: auto;
	aspect-ratio: 16 / 9;
}

@media screen and (min-width:1024px) {
	p:has(+ iframe) {
		margin: 0 auto 80px;
		width: 680px;
		line-height: 1.4;
	}
}




/* step共通 */
.step {
	padding-top: 32px;
	padding-bottom: 48px;
	font-size: 16px;
}

.step h2 {
	display: flex;
	align-items: center;
	margin-bottom: 20px;
	font-size: 24px;
	font-weight: bold;
}

.step h2::before {
	width: 16px;
	height: 40px;
	border-top: 2px solid var(--color-black);
	border-left: 2px solid var(--color-black);
	content: "";
}

.step h2::after {
	width: 16px;
	height: 40px;
	border-bottom: 2px solid var(--color-black);
	border-right: 2px solid var(--color-black);
	content: "";
}

@media screen and (min-width:1024px) {
	.step {
		padding-top: 48px;
		padding-bottom: 80px;
	}
	.step h2 {
		margin-bottom: 40px;
		font-size: 40px;
	}
	.step h2::after {
		width: 20px;
		height: 54px;
	}
	.c--flex-1-2 > div:has(img) {
		width: calc((100% - 24px) / 2 + 36px);
	}

	.c--flex-1-2 > div:not(:has(img)) {
		display: flex;
		flex-direction: column;
		justify-content: center;
		width: calc((100% - 24px) / 2 - 36px);
	}
}



/* オンライン接客 */
.call p + p {
	padding-left: 1em;
	font-size: 14px;
	text-indent: -1em;
}



/* オンライン内見 */
div:has(> .preview) {
	background: var(--color-black);
}

div:has(> .preview) h2,
div:has(> .preview) h2 + p {
	color: #fff;
}

div:has(> .preview) h2::before,
div:has(> .preview) h2::after {
	border-color: #fff;
}

.preview .c--flex-1-2 {
	margin-bottom: 32px;
}

.preview h3 {
	margin-bottom: 8px;
	color: #fff;
	font-size: 20px;
}

.preview li {
	padding: 16px;
	background: #fff;
}

.preview li span {
	font-weight: bold;
}

@media screen and (min-width:1024px) {
	.preview .c--flex-1-2 {
		flex-direction: row-reverse;
	}
	.preview h3 {
		margin-bottom: 20px;
		font-size: 28px;
	}
}


/* IT重説 */
.statement {
	padding-bottom: 0;
}

@media screen and (min-width:1024px) {
	.statement {
		padding-bottom: 80px;
	}
}




/* 書類や鍵の郵送 */
.send .c--flex-1-2 {
	flex-direction: row-reverse;
}
@media screen and (min-width:1024px) {
	.send .c--flex-1-2 {
		flex-direction: row-reverse;
	}
}



/* 物件検索 */
.lp--search .c--flex-1-3 a {
	padding: 60px 8px 16px 8px;
}

.lp--search .c--flex-1-3 a::before,
.lp--search .c--flex-1-3 a::after {
	top: 12px;
	left: 50%;
	translate: -50% 0;
	font-size: 32px;
	pointer-events: none;
}