@charset "utf-8";
/*----------------------------------------------------------------------------------------

	index.css

----------------------------------------------------------------------------------------*/

/* トップページのタイトル //
---------------------------------------------- */
.toptitle .txt {
	padding-left: 2px;
	font-size: 1.6rem;
	letter-spacing: -0.02em;
}
.toptitle .hd {
	color: var(--bgc1);
}
.toptitle .hd a {
	font-size: 4rem;
	letter-spacing: 0.04em;
}
.toptitle .hd a::after {
	margin-left: 10px;
	width: 37px;
	height: 37px;
	background: url(../images/common/arrow-circle-b.png) no-repeat center / contain;
	display: inline-block;
	position: relative;
	top: 5px;
	content: "";
}

/* 買いたい・売りたい部分 //
---------------------------------------------- */
.top-estate {
	margin-top: 85px;
	padding-top: 12px;
	position: relative;
	overflow: hidden;
	z-index: 1;
}
.top-estate .toptitle .hd {
	margin-bottom: 15px;
}
.top-estate .toptitle .hd i {
	margin: auto;
	width: 1478px;
	position: absolute;
	top: -36px;
	right: -100%;
	left: -100%;
	z-index: -1;
	color: #f1f5f8;
	font-size: 230px;
	font-weight: 800;
	line-height: 1;
	white-space: nowrap;
	font-family: "Outfit", serif;
}
.top-estate .toptitle .txt .kensu {
	margin-left: 1.6rem;
}
.top-estate .toptitle .txt .kensu span {
	color: var(--acc2);
	font-size: 2.6rem;
	font-weight: 600;
	font-family: "Outfit", serif;
}

/* メインビジュアル //
////////////////////////////////////////////////////////////////////*/

#mv {
	height: 628px;
	background: linear-gradient(to right, #eeeded 50%, #1e3760 50%);
	overflow: hidden;
	position: relative;
	z-index: 1;
}

#mv .hd {
	margin: auto;
	padding-top: 178px;
	width: 1250px;
	position: relative;
	z-index: 2;
	font-size: 3.8rem;
	line-height: 1;
	text-align: right;
}
#mv .hd .catch {
	margin-bottom: 33px;
	display: block;
	color: #01a0c9;
	font-size: 5rem;
	font-weight: 600;
	line-height: 1.2;
	font-family: "Outfit", serif;
}
#mv .hd .catch span {
	display: block;
	opacity: 0.7;
}
#mv .hd .catch span:first-child {
	letter-spacing: 0.065em;
}
#mv .hd .catch span:last-child {
	letter-spacing: 0.05em;
}
#mv .hd .mess {
	margin-right: -2.8rem;
	display: block;
	color: #fff;
	letter-spacing: 0.2em;
}
#mv .hd .mess em {
	color: #121212;
}
#mv .bg {
	box-sizing: border-box;
	padding-right: calc(((100% - 1200px) / 2) + 180px);
	width: 100%;
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	overflow: hidden;
}
#mv .bg:not(.swiper-initialized) .swiper-slide:not(:first-child) {
	display: none;
}
#mv .bg .mv-top {
	background-color: #eeeded;
}
#mv .bg .mv-trophy {
	background-color: #920506;
}
#mv .bg img {
	margin-left: auto;
	max-width: 1380px;
	width: 100%;
	height: 100%;
	background-color: #d9d7d0;
	object-fit: cover;
	object-position: right;
}
#mv .bg .arrows .btn-arrow {
	box-sizing: border-box;
	width: 120px;
	display: flex;
	opacity: 0;
	position: absolute;
	top: 0;
	bottom: 0;
	z-index: 2;
	cursor: pointer;
	align-items: center;
	transition: opacity 0.2s;
}
#mv .bg .arrows .btn-arrow:hover {
	opacity: 1;
}
#mv .bg .arrows .btn-arrow i {
	color: #fff;
	font-size: 3rem;
}
#mv .bg .arrows .btn-arrow.next {
	padding-right: 40px;
	right: 0;
}
#mv .bg .arrows .btn-arrow.prev {
	padding-left: 40px;
	left: 0;
}
#mv .bg .dots {
	position: absolute;
	top: initial;
	bottom: 120px;
	z-index: 2;
	line-height: 1;
	text-align: center;
}
#mv .bg .dots .swiper-pagination-bullet {
	margin: 0 5px;
	width: 10px;
	height: 10px;
	background: #ccc;
	box-shadow: 0 0 8px 2px #fff;
	opacity: 1;
}
#mv .bg .dots .swiper-pagination-bullet-active {
	background: var(--bgc1);
}
.brn-space {
	margin-top: 55px;
}
.brn-space p {
	text-align: center;
}
.brn-space p + p {
	margin-top: 40px;
}
.brn-space a {
	display: inline-block;
	vertical-align: bottom;
}
.brn-space .campaignbnr {
	margin: 40px auto 0;
	width: 1080px;
}

/* 買いたい 売りたい 速報 //
////////////////////////////////////////////////////////////////////*/

#sokuhou > div {
	margin-top: -109px;
	padding-bottom: 32px;
	position: relative;
	z-index: 2;
}

/* 買いたい //
////////////////////////////////////////////////////////////////////*/

#buy .toptitle {
	margin-bottom: 40px;
}
#buy .search {
	margin-bottom: 43px;
	display: grid;
	grid-template-columns: 1fr 1fr 1fr 1fr;
	gap: 20px;
}
#buy .search > li {
	background-color: #fff;
	border-radius: 15px;
	overflow: hidden;
}
#buy .search > li > a {
	padding: 0 20px 20px;
	display: block;
	position: relative;
}
#buy .search > li .img-fit {
	margin: 0 -20px 22px;
	height: 250px;
	background-color: #efefef;
}
#buy .search > li .shd {
	font-size: 1.6rem;
	font-weight: 500;
	line-height: 1;
	letter-spacing: -0.02em;
}
#buy .search > li .kensu {
	margin-top: 15px;
	display: block;
}
#buy .search > li .kensu em {
	color: var(--acc2);
	font-size: 2.6rem;
	font-weight: 600;
	font-family: "Outfit", serif;
}
#buy .search > li .more {
	position: absolute;
	right: 19px;
	bottom: 22px;
}

#buy .ranking {
	position: relative;
}
#buy .ranking .tksn-ranking {
	position: initial;
}
#buy .ranking .hd {
	margin-bottom: 35px;
	padding-left: 40px;
	font-size: 2.2rem;
	font-weight: 400;
	letter-spacing: 0.1em;
}
#buy .ranking .tksn-ranking .deco {
	padding-top: 7px;
}

/* 売りたい //
////////////////////////////////////////////////////////////////////*/

#sell {
	margin-bottom: 80px;
}
#sell .toptitle {
	margin-bottom: 56px;
}

/* コラム //
---------------------------------------------- */
#sell > .sellcolums {
	box-sizing: border-box;
	margin: 0 calc((100% - 1200px) / 2) 40px 0;
	padding: 0 40px 23px calc((100% - 1200px) / 2);
	position: relative;
}
#sell > .sellcolums::after {
	width: 100%;
	background-color: var(--acc1);
	position: absolute;
	top: 125px;
	bottom: 0;
	left: 0;
	z-index: -1;
	content: "";
}
#sell > .sellcolums .arrows {
	position: relative;
}
#sell > .sellcolums .btn-arrow {
	width: 41px;
	height: 40px;
	background-color: rgba(0, 0, 0, 0);
	position: absolute;
	top: -48px;
	cursor: pointer;
	transition: opacity 0.2s;
}
#sell > .sellcolums .btn-arrow:disabled {
	opacity: 0;
}
#sell > .sellcolums .btn-arrow.next {
	right: -41px;
}
#sell > .sellcolums .btn-arrow.prev {
	left: -41px;
	transform: scale(-1, 1);
}
#sell > .sellcolums .card {
	width: 480px;
	height: auto;
	counter-increment: columcount;
}
#sell > .sellcolums .card a {
	display: block;
}
#sell > .sellcolums .card .img-fit {
	margin-bottom: 17px;
	height: 280px;
	background-color: #efefef;
}
#sell > .sellcolums .card .shd {
	margin-bottom: 9px;
	color: var(--bgc1);
	font-size: 2.8rem;
	line-height: 1.2;
	letter-spacing: 0.1em;
}
#sell > .sellcolums .card .txt {
	font-size: 1.6rem;
	line-height: 1.625;
	letter-spacing: 0.1em;
}
#sell > .sellcolums .card .more {
	margin-top: 10px;
}
#sell > .sellcolums .card .shd::before {
	margin-bottom: 10px;
	display: block;
	color: var(--bgc1);
	font-size: 1.2rem;
	font-weight: 400;
	line-height: 1;
	letter-spacing: -0.03em;
	font-family: "Outfit", serif;
	content: "Column #"counter(columcount, decimal-leading-zero);
}
#sell > .sellcolums .card:hover :is(.pic img, .shd, .txt, .more) {
	transition: opacity 0.2s;
}
#sell > .sellcolums .card:hover :is(.pic img, .shd, .txt, .more) {
	opacity: 0.8;
}

/* 売りたい コンテンツ //
---------------------------------------------- */
#sell > .contents {
	display: flex;
	flex-wrap: wrap;
}
#sell > .contents .list {
	width: 560px;
	display: flex;
	flex-direction: column;
}
#sell > .contents .list > .title {
	margin-bottom: 24px;
}
#sell > .contents .list > .title .hd {
	margin-bottom: 30px;
	color: var(--bgc1);
	font-size: 3rem;
	line-height: 1;
}
#sell > .contents .list > .title .txt {
	font-size: 1.6rem;
	line-height: 1.6;
	letter-spacing: 0.04em;
}
#sell > .contents .list > .ichiran {
	margin-top: auto;
	padding-top: 20px;
	text-align: right;
}
#sell > .contents .oazukari {
	margin-left: auto;
}
#sell > .contents .oazukari .tksn-cover {
	display: flex;
}
#sell > .contents .section-sateiform.wide {
	margin-bottom: 80px;
}
#sell > .contents .oazukari form[name^="get_checked_bukken_"],
#sell > .contents .oazukari div[id^="des255-contents-wrapper-"] {
	height: 100%;
}

/* 会社案内 //
////////////////////////////////////////////////////////////////////*/

#company .toptitle {
	margin-bottom: 95px;
}
#company .message {
	min-height: 500px;
	background: url(../images/index/company-bg.jpg) no-repeat top / auto 100%, #bed3f1;
}
#company .message > div {
	display: grid;
	grid-template-columns: 698px 1fr;
}
#company .photos {
	margin-top: -65px;
	padding: 275px 0 0 40px;
	position: relative;
	z-index: 1;
}
#company .photos .photo:nth-child(1){
	width: 650px;
	height: 400px;
	position: absolute;
	top: 0;
	left: 0;
	z-index: -1;
}
#company .photos .photo:nth-child(2) {
	width: 300px;
	height: 200px;
}
#company .text {
	padding: 44px 20px 50px 0;
	font-size:1.6rem;
	font-weight: 500;
	line-height: 1.75;
}
#company .menu {
	margin-top: -16px;
	position: relative;
	z-index: 1;
	display: flex;
	justify-content: space-between;
}
#company .menu > li {
	width: 384px;
	height: 140px;
	background-color: #fff;
	position: relative;
}
#company .menu > li > a {
	box-sizing: border-box;
	padding: 39px 20px 0;
	height: 100%;
	background-repeat: no-repeat;
	background-size: cover;
	position: relative;
	z-index: 1;
	display: block;
	color: #fff;
}
#company .menu > li.profile > a {
	background-image: url(../images/index/link-profile.jpg);
}
#company .menu > li.staff > a {
	background-image: url(../images/index/link-staff.jpg);
}
#company .menu > li.access > a {
	background-image: url(../images/index/link-access.jpg);
}
#company .menu > li > a > i {
	margin-bottom: 14px;
	display: flex;
	font-size: 1.2rem;
	font-weight: 600;
	line-height: 1;
	letter-spacing: 0.04em;
	font-family: "Outfit", serif;
	white-space: nowrap;
	align-items: center;
}
#company .menu > li > a > i::after {
	margin-left: 12px;
	width: 100%;
	height: 1px;
	background-color: #fff;
	display: block;
	content: "";
}
#company .menu > li > a > em {
	font-size: 2rem;
	font-weight: 700;
	letter-spacing: -0.02em;
}
#company .menu > li > a > img {
	position: absolute;
	top: 0;
	left: 0;
	z-index: -1;
}




