/* サイド固定 */
.lpo_side {
	display: flex;
	align-items: flex-end;
	justify-content: center;
	width: 100px;
	height: 100vh;
	box-sizing: border-box;
	padding: 20px 0 20px 0;
	background: #eefdea;
	position: fixed;
	top: 0;
	right: 0;
	z-index: 100;
	>ul {
		display: flex;
		flex-direction: column;
		gap: 10px 0;
		margin: 0;
		padding: 0;
		list-style: none;
		>li {
			>a {
				display: flex;
				gap: 0 5px;
				padding: 15px;
				border-radius: 10px;
				font-size: 16px;
				line-height: 20px;
				color: #FFF;
				letter-spacing: 0.1em;
				text-decoration: none;
				-ms-writing-mode: tb-rl;
				writing-mode: vertical-rl;
				&:before {
					content: "";
					display: block;
					width: 22px;
					height: 22px;
					background-repeat: no-repeat;
					background-size: cover;
				}
			}
			&:not(:last-child) a {
				background: #cc5151;
				&:before {
					background-image: url(/img/top/t_side_icon01.webp);
				}
			}
			&:last-child a {
				background: #4cca2a;
				&:before {
					background-image: url(/img/top/t_side_icon02.webp);
				}
			}
		}
	}
}
/*メイン*/
.lpo_main {
	width: 100%;
	height: calc(100vh - 100px);
	max-height: 650px;
	background-image: url(/img/lpo/b_main_bg.webp);
	background-size: cover;
	margin-bottom: clamp(65px, 7.5vh, 80px);
	position: relative;
	>div.lpo_main_catch {
		max-width: 50vw;
		position: absolute;
		bottom: clamp(60px, 8.5vh, 85px);
		left: clamp(35px, 2.7vw, 50px);
		>p {
			margin: 0 0 30px 0;
		}
		>h2 {
			margin: 0;
		}
	}
	& img {
		display: block;
		max-width: 100%;
	}
}
.lpo_all {
	width: calc(100vw - 135px);
	& a {
		color: #000000;
		text-decoration: none;
	}
	& ul, & p, & h2, & h3 {
		padding: 0;
		margin: 0;
		list-style: none;
	}
	& img {
		display: block;
		max-width: 100%;
	}
	.lpo_tl {
		margin-bottom: clamp(30px, 3.8vh, 40px);
		>p {
			margin-bottom: clamp(24px, 2.8vh, 30px);
			font-size: clamp(40px, 2.7vw, 50px);
			line-height: 1;
			font-weight: 300;
		}
		>h2 {
			font-size: clamp(12px, 0.95vw, 18px);
			line-height: 1;
			font-weight: 500;
		}
	}
	.lpo_catch_txt {
		margin-bottom: clamp(35px, 4.2vh, 45px);
		font-size: clamp(22px, 1.6vw, 30px);
		line-height: 1.65;
		font-weight: 500;
	}
	.lpo_txt {
		font-size: clamp(12px, 0.88vw, 16px);
		line-height: 1.875;
	}
	.lpo_btn {
		display: flex;
		align-items: center;
		justify-content: space-between;
		width: clamp(300px, 20vw, 360px);
		padding: clamp(8px, 1vh, 11px) clamp(10px, 0.75vw, 12px) clamp(8px, 1vh, 11px) clamp(20px, 1.5vw, 25px);
		box-sizing: border-box;
		background: #FFF;
		border-radius: 20px;
		transition: all 0.2s;
		position: relative;
		>span {
			font-size: clamp(10px, 0.75vw, 14px);
			line-height: 1;
			text-decoration: underline;
			text-decoration-thickness: 1px;
			text-underline-offset: 8px;
			transition: all 0.2s;
		}
		>div {
			display: flex;
			align-items: center;
			justify-content: center;
			width: clamp(42px, 3vw, 56px);
			height: auto;
			aspect-ratio: 1 / 1;
			border-radius: 50%;
			transition: all 0.2s;
			>img {
				display: block;
				width: 30%;
				max-width: 16px;
				height: auto;
				aspect-ratio: 4 / 3;
			}
		}
		&:hover {
			border: 1px solid #333;
			>span {
				text-decoration-color: #333;
			}
			>div {
				background: #333;
			}
		}
	}
	.lpo_btn_gr {
		border: 1px solid #4cca2a;
		>span {
			text-decoration-color: #4cca2a;
		}
		>div {
			background: #4cca2a;
		}
	}
	.lpo_btn_beige {
		border: 1px solid #c9b879;
		>span {
			text-decoration-color: #c9b879;
		}
		>div {
			background: #c9b879;
		}
	}
	/*検索*/
	.lpo_sr_warp {
		width: clamp(900px, 67vw, 1240px);
		margin-right: auto;
		margin-left: auto;
		margin-bottom: clamp(90px, 11.5vh, 120px);
		.lpo_sr_box {
			display: flex;
			gap: 0 40px;
			.lpo_sr_map {
				width: calc(50% - 40px);
			}
			.lpo_sr_search {
				display: flex;
				flex-direction: column;
				justify-content: space-between;
				width: 50%;
				.lpo_sr_tit {
					font-size: clamp(12px, 0.95vw, 18px);
					margin-bottom: clamp(13px, 2vh, 20px);
					>span {
						padding-right: 2px;
						font-size: clamp(16px, 1.2vw, 22px);
					}
				}
				.lpo_sr_btn {
					>ul {
						display: flex;
						gap: 0 clamp(10px, 0.84vw, 15px);
						>li {
							>a {
								display: flex;
								flex-direction: column;
								align-items: center;
								justify-content: space-between;
								width: 100%;
								height: auto;
								text-align: center;
								box-sizing: border-box;
								padding: clamp(12px, 0.95vw, 18px) 0;
								border-radius: 10px;
								box-shadow: 0px 0px 10px 0px #d7ffcd;
								position: relative;
								transition: all 0.2s;
								>p {
									font-size: clamp(12px, 0.95vw, 18px);
									line-height: 1;
									letter-spacing: 0.05em;
								}
								&:hover {
									box-shadow: 0px 0px 3px 0px #d7ffcd;
									transform: translateY(3px);
								}
							}
						}
					}
				}
				.lpo_sr_btn_wide {
					>ul {
						>li {
							width: calc((100% - calc(clamp(10px, 0.84vw, 15px))*2)/ 3);
							>a {
								>img {
									width: 40%;
									margin: 0 auto clamp(5px, 0.55vw, 10px) auto;
								}
							}
						}
					}
				}
				.lpo_sr_btn_thin {
					>ul {
						>li {
							width: calc((100% - calc(clamp(10px, 0.84vw, 15px))*3)/ 4);
							>a {
								aspect-ratio: 1 / 1;
								>img {
									width: 55%;
									margin: 0 auto;
								}
							}
						}
					}
				}
				& form {
					width: 100%;
					display: flex;
					justify-content: space-between;
					>input {
						width: calc(100% - clamp(44px, 3.2vw, 60px) - clamp(30px, 2vw, 37px) - 10px);
						border-radius: 5px;
						border: 1px solid #ccc;
						box-sizing: border-box;
						padding: 7px 15px;
						font-size: clamp(12px, 0.95vw, 18px);
						font-weight: bold;
						letter-spacing: 0.1em;
						line-height: 3;
						&::placeholder {
							color: #9bdf89;
							font-weight: 300;
						}
					}
					.quick_keyword {
						.free_btn {
							padding: clamp(15px, 1.05vw, 20px) clamp(22px, 1.6vw, 30px);
							width: clamp(30px, 2vw, 37px);
							background-color: #4cca2a;
							text-align: center;
							border-radius: 5px;
							transition: all 0.2s;
							display: flex;
							align-content: center;
							justify-content: center;
							flex-wrap: wrap;
							&:hover {
								background-color: #000000;
							}
						}
					}
				}
			}
		}
	}
	/*物件*/
	.lpo_pro_warp {
		width: clamp(900px, 67vw, 1240px);
		margin-right: auto;
		margin-left: auto;
		margin-bottom: clamp(35px, 4.8vh, 50px);
	}
	& ul.lpo_pro_ul {
		display: flex;
		gap: 0 20px;
		>li {
			width: calc((100% - 60px)/4);
			>a {
				display: block;
				box-sizing: border-box;
				padding: 14px;
				border-radius: 10px;
				.lpo_house_img {
					width: 100%;
					aspect-ratio: 53 / 30;
					margin: 0 0 8px 0;
					border-radius: 8px;
					overflow: hidden;
					position: relative;
					>img {
						width: 100%;
						height: 100%;
						object-fit: cover;
						transition: all 0.2s;
					}
					>p {
						font-size: clamp(13px, 0.82vw, 15px);
						position: absolute;
						bottom: 0;
						right: 0;
						padding: 0 8px 0 12px;
						border-radius: 8px 0 0 0;
						background: #FFF;
						font-size: clamp(13px, 0.82vw, 15px);
						line-height: 2;
					}
				}
				>p {
					margin: 0 0 8px 0;
					font-size: clamp(15px, 1vw, 18px);
					line-height: 1.2;
				}
				.lpo_house_box {
					padding: 10px;
					border-radius: 8px;
					>div {
						display: flex;
						align-items: flex-end;
						gap: 0 10px;
						margin: 0 0 2px 0;
						>p {
							line-height: 1.2;
							letter-spacing: 0.05em;
						}
						.lpo_house_price {
							font-size: clamp(18px, 1.2vw, 22px);
						}
						.lpo_house_price_s {
							display: flex;
							align-items: center;
							gap: 0 10px;
							font-size: clamp(11px, 0.85vw, 16px);
							&:before {
								content: "";
								display: block;
								width: 1px;
								height: clamp(11px, 0.85vw, 16px);
								background: #000000;
								transform: rotate(25deg);
							}
						}
					}
					>p {
						>span {
							font-size: clamp(10px, 0.75vw, 14px);
							line-height: 1.5;
							overflow: hidden;
							display: -webkit-box;
							-webkit-box-orient: vertical;
							-webkit-line-clamp: 1;
						}
					}
				}
				&:hover {
					.lpo_house_img {
						>img {
							filter: grayscale(100%);
							transform: scale(1.2);
						}
					}
				}
			}
		}
	}
	.lpo_btn_warp {
		display: flex;
		justify-content: center;
		gap: 0 20px;
		margin: clamp(22px, 2.8vh, 30px) 0 0 0;
	}
	.lpo_pro_beige {
		& ul.lpo_pro_ul {
			>li {
				>a {
					border: 1px solid #c9b879;
					.lpo_house_box {
						background: #faf8f0;
					}
				}
			}
		}
	}
	.lpo_pro_green {
		& ul.lpo_pro_ul {
			>li {
				>a {
					border: 1px solid #4cca2a;
					background: #fff;
					.lpo_house_box {
						background: #eefdea;
					}
				}
			}
		}
	}
	.lpo_new_warp {
		position: relative;
		margin-bottom: clamp(90px, 11.5vh, 120px);
		&:before {
			content: "";
			display: block;
			width: 96%;
			height: calc(100% - 50px);
			margin: auto;
			background-image: url(/img/top/noise.png);
			background-repeat: repeat;
			background-size: 100px;
			mix-blend-mode: overlay;
			opacity: 0.7;
			position: absolute;
			right: 0;
			top: 0;
			bottom: 0;
			z-index: -1;
		}
		&:after {
			content: "";
			display: block;
			width: 96%;
			height: calc(100% - 50px);
			margin: auto;
			background: linear-gradient(180deg, rgba(242, 255, 239, 1) 0%, rgba(255, 255, 255, 1) 100%);
			position: absolute;
			right: 0;
			top: 0;
			bottom: 0;
			z-index: -2;
		}
		>div {
			width: clamp(900px, 67vw, 1240px);
			margin-right: auto;
			margin-left: auto;
		}
	}
	.lpo_house_pd {
		margin-bottom: clamp(90px, 11.5vh, 120px);
	}
	/*会員*/
	#lpo_mem {
		width: clamp(900px, 67vw, 1240px);
		margin: 0 auto clamp(90px, 11.5vh, 120px) auto;
		>a {
			display: flex;
			align-items: center;
			padding: 30px;
			border-radius: 20px;
			background: #faf8f0;
			transition: all 0.2s;
			&:hover {
				transform: translateY(-10px);
			}
			.lpo_mem_box {
				width: clamp(225px, 17.2vw, 320px);
				.lpo_mem_en {
					margin-bottom: clamp(15px, 1.9vh, 20px);
					font-size: clamp(15px, 1.05vw, 20px);
					line-height: 1.2;
					font-weight: 400;
				}
				.lpo_mem_name {
					display: inline-block;
					margin-bottom: clamp(15px, 1.9vh, 20px);
					padding-bottom: 8px;
					border-bottom: 1px solid #c9b879;
					font-size: clamp(20px, 1.55vw, 28px);
					line-height: 1.2;
					font-weight: 500;
				}
				>h2 {
					margin-bottom: clamp(15px, 1.9vh, 20px);
					font-size: clamp(32px, 2.3vw, 42px);
					line-height: 1.3;
					font-weight: 500;
					letter-spacing: 0.05em;
					.color_red {
						color: #cc5151;
					}
					.lpo_mem_tl_s {
						font-size: clamp(27px, 2vw, 36px);
					}
				}
				.lpo_btn {
					width: clamp(200px, 16vw, 300px);
				}
			}
			>ul {
				width: calc(100% - clamp(200px, 16vw, 300px));
				display: flex;
				gap: 10px;
				>li {
					width: calc((100% - 20px)/3);
					box-sizing: border-box;
					padding: 5px 1.3% 0 1.3%;
					position: relative;
					z-index: 1;
					&:before {
						content: "";
						display: block;
						width: 100%;
						height: auto;
						aspect-ratio: 1 / 1;
						background: #FFF;
						border-radius: 50%;
						position: absolute;
						top: 0;
						left: 0;
						z-index: -1;
					}
					.lpo_mem_num {
						font-size: clamp(20px, 1.5vw, 27px);
						font-weight: 300;
						line-height: 1.5;
					}
					>h3 {
						margin: 0 0 10px 0;
						font-size: clamp(19px, 1.45vw, 26px);
						font-weight: 500;
						line-height: 1.2;
						letter-spacing: 0.05em;
						>span {
							font-size: clamp(18px, 1.2vw, 22px);
						}
					}
					.lpo_mem_txt {
						margin: 0 0 8px 0;
						font-size: clamp(8px, 0.63vw, 12px);
						line-height: 1.33;
					}
					>img {
						width: 50%;
						margin: 0 auto;
					}
				}
			}
		}
	}
	/*物件購入が初めての方へ*/
	#lpo_message {
		margin-bottom: clamp(100px, 12.5vh, 130px);
		padding: clamp(80px, 9vh, 100px) 0 0 0;
		position: relative;
		&:before {
			content: "";
			width: 96%;
			display: block;
			height: 100%;
			background-image: url(/img/top/noise.png);
			background-repeat: repeat;
			background-size: 100px;
			mix-blend-mode: overlay;
			opacity: 0.7;
			position: absolute;
			bottom: 0;
			left: 0;
			z-index: -1;
		}
		&:after {
			content: "";
			display: block;
			width: 96%;
			height: 100%;
			background: linear-gradient(0deg, rgba(242, 255, 239, 1) 0%, rgba(255, 255, 255, 1) 100%);
			position: absolute;
			bottom: 0;
			left: 0;
			z-index: -2;
		}
		>div {
			display: flex;
			align-items: flex-end;
			justify-content: space-between;
			width: clamp(1000px, 75vw, 1400px);
			box-sizing: border-box;
			margin-right: auto;
			margin-left: auto;
			padding-bottom: clamp(60px, 7.5vh, 80px);
			position: relative;
			>div {
				width: clamp(560px, 44vw, 800px);
				margin: 0 auto;
				padding: 0 calc(clamp(1030px, 80vw, 1500px)/2) 0 0;
			}
			.lpo_txt {
				margin: 0 0 60px 0;
			}
			& ul {
				display: flex;
				gap: 0 10px;
				width: clamp(750px, 65vw, 1100px);
				>li {
					width: calc((100% - 20px) / 3);
					>h3 {
						height: clamp(64px, 9vh, 86px);
						position: relative;
						z-index: 1;
						>img {
							max-height: 100%;
						}
					}
					>img {
						width: clamp(160px, 12.5vw, 230px);
						margin: -20px auto 0 auto;
					}
					.lpo_mes_txt {
						margin-top: -15px;
						font-size: clamp(10px, 0.75vw, 14px);
						text-align: left;
						padding: 0 0 0 clamp(15px, 1.05vw, 20px);
						>p {
							padding: 0 0 0 clamp(20px, 1.5vw, 25px);
							border-left: 2px solid #4cca2a;
						}
					}
				}
			}
			.lpo_mes_btn {
				margin: clamp(50px, 6.3vh, 65px) 0 0 0;
				>a {
					width: clamp(260px, 22vw, 400px);
				}
			}
		}
		>img {
			width: clamp(410px, 34vw, 650px);
			height: clamp(450px, 55vh, 570px);
			border-radius: 40px 0 0 40px;
			object-fit: cover;
			position: absolute;
			right: 0;
			top: 0;
		}
	}
	/*売却*/
	#lpo_sale {
		margin-bottom: clamp(100px, 12.5vh, 130px);
		padding: clamp(80px, 9vh, 100px) 0 0 0;
		position: relative;
		>div {
			width: clamp(1030px, 80vw, 1500px);
			box-sizing: border-box;
			margin: 0 auto;
			padding: 0 0 0 calc(clamp(1030px, 80vw, 1500px)/2);
			position: relative;
			&:before {
				content: "";
				width: 100%;
				height: calc(100% - 50px);
				margin: auto;
				background-image: url(/img/top/noise.png);
				background-repeat: repeat;
				background-size: 100px;
				mix-blend-mode: overlay;
				opacity: 0.7;
				position: absolute;
				top: 0;
				bottom: 0;
				left: 0;
				z-index: -1;
			}
			&:after {
				content: "";
				width: 100%;
				height: calc(100% - 50px);
				margin: auto;
				background: #faf8f0;
				position: absolute;
				top: 0;
				bottom: 0;
				left: 0;
				z-index: -2;
			}
			.lpo_txt {
				margin: 0 0 60px 0;
			}
			.lpo_sale_btn {
				display: flex;
				gap: 0 10px;
			}
		}
		>img {
			width: clamp(500px, 42vw, 800px);
			height: auto;
			aspect-ratio: 80 / 57;
			border-radius: 0 40px 40px 0;
			position: absolute;
			top: 0;
			left: 0;
		}
	}
	/*当社について*/
	#lpo_about {
		width: clamp(1030px, 80vw, 1500px);
		margin: 0 auto 0 auto;
		position: relative;
		>div {
			width: clamp(1000px, 75vw, 1400px);
			margin: 0 auto 70px auto;
			.lpo_txt {
				margin: 0 0 60px 0;
			}
			.lpo_ab_btn {
				display: flex;
				gap: 0 10px;
			}
		}
		>ul {
			display: flex;
			gap: 0 10px;
			padding: 25px;
			background: #eefdea;
			border-radius: 20px;
			width: clamp(1000px, 75vw, 1400px);
			margin: 0 auto;
			>li {
				width: calc((100% - 30px)/4);
				>a {
					display: block;
					width: 100%;
					height: auto;
					aspect-ratio: 3 / 2;
					box-sizing: border-box;
					padding: 25px;
					background: #FFF;
					border-radius: 16px;
					position: relative;
					transition: all 0.2s;
					>img {
						width: 50%;
						margin: auto;
						position: absolute;
						right: 10px;
						bottom: 0;
						top: 0;
					}
					.lpo_ab_btn_en {
						margin: 0 0 5px 0;
						font-size: clamp(12px, 0.95vw, 18px);
						line-height: 1.2;
						font-weight: 300;
					}
					.lpo_ab_btn_name {
						font-size: clamp(18px, 1.3vw, 24px);
						line-height: 1.2;
						transition: all 0.2s;
					}
					.lpo_ab_btn_more {
						display: inline-block;
						padding: 0 20px 0 15px;
						clip-path: polygon(0 0, 90% 0, 100% 100%, 0% 100%);
						background: #4cca2a;
						font-size: clamp(9px, 0.7vw, 13px);
						font-weight: 300;
						line-height: 1.5;
						color: #FFF;
						position: absolute;
						bottom: 15px;
						right: 15px;
						transition: all 0.2s;
					}
					&:hover {
						.lpo_ab_btn_more {
							background: #000000;
						}
						.lpo_ab_btn_name {
							color: #4cca2a;
						}
					}
				}
			}
		}
		.lpo_ab_img01, .lpo_ab_img02 {
			width: clamp(400px, 28.5vw, 520px);
			height: auto;
			aspect-ratio: 3 / 2;
			position: absolute;
		}
		.lpo_ab_img01 {
			top: 0;
			right: 0;
		}
		.lpo_ab_img02 {
			top: calc(clamp(400px, 28.5vw, 520px)*0.7);
			right: 0;
		}
	}
}