@charset "UTF-8";

/* common
----------------------------------------------------*/
.indexLayout .cat_name {
    text-align: center;
    padding: 5px;
    border-radius: 15px;
    color: #fff;
    font-weight: bold;
    max-width: 150px;
    margin-bottom: 10px;
}
.indexLayout .cat_name.land_sale {
    background-color: #6EBE00;
}
.indexLayout .cat_name.houses {
    background-color: #EF9429;
}
.indexLayout .cat_name.apartments {
    background-color: #EAD907;
}
.indexLayout .cat_name.investment {
    background-color: #D8501E;
}
.indexLayout .cat_name.residential {
    background-color: #F55ED2;
}
.indexLayout .cat_name.commercial {
    background-color: #A950B1;
}
.indexLayout .cat_name.land_lease {
    background-color: #147DE2;
}
.indexLayout .cat_name.parking {
    background-color: #34C2E3;
}
.indexLayout .property_cat > div {
    position: relative;
    padding: 40px 20px;
    text-align: center;
    margin-top: 60px;
    z-index: 1;
}
.indexLayout .property_cat > div::before, .indexLayout .property_cat > div::after {
    position: absolute;
    content: "";
    width: 100%;
    left: 0;
}
.indexLayout .property_cat > div::before {
    border-radius: 20px;
    height: 100%;
    top: 0;
    z-index: -1;
}
.indexLayout .property_cat > div::after {
    border-radius: 0 0 20px 20px;
    height: 20%;
    z-index: -2;
    bottom: -10px;
}
.indexLayout .property_cat > div:nth-child(1)::after {
    background-color: #FF5573;
}
.indexLayout .property_cat > div:nth-child(2)::after {
    background-color: #649FFF;
}
.indexLayout .property_cat .ttl {
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    top: -60px;
    border-radius: 50% / 100% 100% 0 0;
    padding: 20px 0 0;
    width: 160px;
    color: #fff;
    font-size: 1.3rem;
}
.indexLayout .property_cat .ttl span {
    display: block;
    font-size: 0.9rem;
    opacity: 0.3;
}
.indexLayout .property_cat > div:nth-child(1)::before, .indexLayout .property_cat > div:nth-child(1) .ttl {
    background-color: #FF849A;
}
.indexLayout .property_cat > div:nth-child(2)::before, .indexLayout .property_cat > div:nth-child(2) .ttl {
    background-color: #9FB8E0;
}
.indexLayout .property_cat .btn_li {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
}
.indexLayout .property_cat .btn_li > li {
    width: calc(96% / 2 - 2px);
}
.indexLayout .property_cat .btn_li > li a {
    display: block;
    padding: 20px;
    background-color: #fff;
    border-radius: 10px;
    font-weight: bold;
    font-size: 1.0rem;
    transition: all 0.3s;
}
.indexLayout .property_cat .btn_li > li a:hover {
    background-color: #FFF186;
}
.indexLayout .property_cat .btn_li {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 20px 4%;
}
.indexLayout .property_cat .btn_li > li .img {
    display: flex;
    justify-content: center;
    align-items: center;
    height: 58px;
    flex-direction: column;
    margin-bottom: 5px;
}
.indexLayout .property_bnr {
    max-width: 1000px;
    width: 96%;
    margin: 60px auto 0;
    gap: 20px 4%;
}
.indexLayout .property_bnr a {
    display: flex;
    align-items: center;
    gap: 0 20px;
    border-bottom: solid 10px;
    position: relative;
    border-radius: 0 20px 0 0;
    margin-top: 30px;
    font-weight: bold;
    padding: 20px 10px;
}
.indexLayout .property_bnr > .flex_box01:nth-child(1) a {
    border-bottom-color: #2F9A79;
    color: #2F9A79;
    background-color: #F4FCF9;
}
.indexLayout .property_bnr > .flex_box01:nth-child(2) a {
    border-bottom-color: #FF93A7;
    color: #FF93A7;
    background-color: #FFF2F4;
}
.indexLayout .property_bnr > .flex_box01:nth-child(1) a::before, .indexLayout .property_bnr > .flex_box01:nth-child(1) .ico {
    background-color: #2F9A79;
}
.indexLayout .property_bnr > .flex_box01:nth-child(2) a::before, .indexLayout .property_bnr > .flex_box01:nth-child(2) .ico {
    background-color: #FF93A7;
}
.indexLayout .property_bnr a::before {
    position: absolute;
    content: "";
    width: 80px;
    height: 30px;
    clip-path: polygon(50% 0%, 0 100%, 100% 100%);
    top: -30px;
    left: 0;
}
.indexLayout .property_bnr .ico {
    width: 60px;
    padding: 7px 0;
}
.indexLayout .property_bnr .link_name {
    font-size: 1.2rem;
    position: relative;
    width: calc(100% - 80px);
}
.indexLayout .property_bnr .link_name::after {
    position: absolute;
    content: "＞";
    top: 50%;
    transform: translateY(-50%);
    right: 0;
    transition: all 0.3s;
}
.indexLayout .property_bnr a:hover .link_name::after {
    right: -10px;
}
.indexLayout .property_li .img_wrap {
    position: relative;
    overflow: hidden;
}
.indexLayout .property_li .img_wrap .img {
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center center;
    height: 170px;
    transition: all 0.3s;
    z-index: 0;
  position: relative;
}
.indexLayout .property_li a:hover .img {
    transform:scale(1.2,1.2);
}
.indexLayout .property_li .img_wrap .status_icon {
    position: absolute;
    bottom: 10px;
    right: 10px;
    display: flex;
    justify-content: center;
    align-items: center;
    font-weight: bold;
    width: 60px;
    height: 60px;
    border-radius: 50%;
    background-color: #fff;
    border: 8px solid;
    font-size: 1rem;
    z-index: 1;
}
.indexLayout .property_li .img_wrap .available {
    display: none;
}
.indexLayout .property_li .img_wrap .sold {
    color: #F12323;
    border-color: #F12323;
}
.indexLayout .property_li .img_wrap .negotiations {
    color: #3C3C3C;
    border-color: #3C3C3C;
}
.indexLayout .property_li .img_wrap .filled {
    color: #004c98;
    border-color: #004c98;
}
.indexLayout .property_li li {
    border: 1px solid #D9D9D9;
    border-radius: 10px;
    overflow: clip;
}
.indexLayout .property_li li a > div:last-child {
    padding: 15px 20px;
}
.indexLayout .property_li li .ttl, .propertySingleLayout .g_bg .ttl {
    font-weight: bold;
    font-size: 1.1rem;
}
.indexLayout .property_li li .price, .propertySingleLayout .g_bg .price {
    font-weight: bold;
    font-size: 0.9rem;
}
.indexLayout .property_li li .price span, .propertySingleLayout .g_bg .price span {
    color: #FF0000;
    font-size: 1.5rem;
    display: inline-block;
    margin-left: 5px;
}



        /* 【タブレット用のスタイル記述】 */
        @media screen and (min-width: 760px) {
            .indexLayout .property_li {
                gap: 60px 4%;
            }
            .propertyAllLayout .property_li .img_wrap .status_icon {
                width: 65px;
                height: 65px;
                font-size: 1.1rem;
            }
            .indexLayout .property_li li {
                width: calc(92% / 3 - 2px);
            }
        }

        /* 【PC用のスタイル記述】 */
        @media screen and (min-width: 960px) {
            .indexLayout .title01 {
                margin-bottom: 55px;
            }
        }



/* loading
----------------------------------------------------*/
#loading {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #FDF076;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 99999;
  transition: opacity 1s ease; /* フェードアウト用 */
}
#loading .load_img_wp {
    width: 80%;
    position: relative;
    max-width: 692px;
    margin: 0 auto;
}
#loading .load_img_wp .load_icon {
    animation: poyopoyo 1s ease-out infinite;
    opacity: 1;
    position: absolute;
    left: 0;
    top: 0;
    max-width: 35px;
}
@keyframes poyopoyo {
  0%, 40%, 60%, 80% {
    transform: scale(1.0);
  }
  50%, 70% {
    transform: scale(0.8);
  }
}



        /* 【タブレット用のスタイル記述】 */
        @media screen and (min-width: 760px) {
            #loading .load_img_wp {
                width: 60%;
            }
            #loading .load_img_wp .load_icon {
                max-width: 60px;
            }
        }

        /* 【PC用のスタイル記述】 */
        @media screen and (min-width: 960px) {
            #loading .load_img_wp .load_icon {
                max-width: none;
            }
        }



/* c01
----------------------------------------------------*/
.indexLayout .bg01 {
    background: url("../img/index/index_c01_bg02.png")no-repeat top center/contain;
    position: relative;
    overflow-x: clip;
}

.indexLayout #c01 {
    position: relative;
    padding-top: 100px;
}
.indexLayout #c01::before, .indexLayout #c01::after {
    position: absolute;
    content: "";
    width: 100%;
    height: 16px;
    background: url("../common/img/common_line01.png")repeat-x center center;
    left: 50%;
    transform: translateX(-50%);
    max-width: 1200px;
}
.indexLayout #c01::before {
    top: 50px;
}
.indexLayout #c01::after {
    bottom: 30px;
}
.indexLayout #c01 .btn01 {
    margin-left: 0;
}
.indexLayout #c01 .y_box {
    padding: 40px 0;
    position: relative;
    z-index: 1;
    max-width: 950px;
    margin: 0 auto;
}
.indexLayout #c01 .y_box::before {
    position: absolute;
    content: "";
    background-color: #FFF8E0;
    width: 100%;
    height: 100%;
    z-index: -1;
    top: 0;
    left: 0;
    border-radius: 20px;
}
.indexLayout #c01 .y_box::after {
    position: absolute;
    content: "";
    background-color: #FCC800;
    width: 100%;
    height: 10%;
    min-height: 100px;
    bottom: -10px;
    left: 0;
    border-radius: 20px;
    z-index: -2;
}
.indexLayout #c01 .y_box > div {
    width: calc(92% - 40px);
    margin: 0 auto;
    max-width: 860px;
    position: relative;
}
.indexLayout #c01 .y_box > div::before, .indexLayout #c01 .y_box > div::after {
    position: absolute;
    content: "";
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center center;
}
.indexLayout #c01 .y_box > div::after {
    background-image: url("../img/index/index_c01_img02.png");
    bottom: -60px;
  right: -40px;
  width: 61px;
  height: 71px;
}
.indexLayout #c01 .news_t {
    display: flex;
    align-items: center;
    margin-bottom: 5px;
    gap: 0 30px;
    font-size: 0.9rem;
}
.indexLayout #c01 .news_t time {
    color: #FF9567;
}
.indexLayout #c01 .news_t .cat_icon {
    padding: 2px 0;
    text-align: center;
    width: 80px;
    border-radius: 50px;
    border: 1px solid;
}
.indexLayout #c01 .news_t .cat_icon.news {
    color: #FF6468;
    border-color: #FF6468;
    background-color: #FFF6F6;
}
.indexLayout #c01 .news_t .cat_icon.closed {
    color: #45CB6E;
    border-color: #45CB6E;
    background-color: #F6FFF7;
}
.indexLayout #c01 .news_t .cat_icon.information {
    color: #60D5D9;
    border-color: #60D5D9;
    background-color: #F4F9FF;
}
.indexLayout #c01 .news_li a {
    display: block;
    padding: 20px 40px 15px 0;
    border-bottom: 1px solid #D9D9D9;
    position: relative;
}
.indexLayout #c01 .news_li a:hover {
    color: #D18989;
}
.indexLayout #c01 .news_li a::after {
    position: absolute;
    content: "→";
    top: 50%;
    transform: translateY(-50%);
    right: 20px;
    transition: all 0.3s;
}
.indexLayout #c01 .news_li a:hover::after {
    right: 0;
}
.indexLayout #c01 h2 {
    position: relative;
    color: #49B594;
}
.indexLayout #c01 h2 .title_img {
    position: absolute;
    left: -40px;
    top: -55px;
    max-width: 70px;
}


        /* 【タブレット用のスタイル記述】 */
        @media screen and (min-width: 760px) {
            .indexLayout #c01 .y_box {
                padding: 60px 0;
            }
            .indexLayout #c01 .y_box::before, .indexLayout #c01 .y_box::after {
                border-radius: 30px;
            }
            .indexLayout #c01 h2 .title_img {
                left: -60px;
               top: -65px;
                max-width: 90px;
            }
            .indexLayout #c01 h2 {
                font-size: 2rem;
            }
            .indexLayout #c01 .y_box > div::after {
                bottom: -90px;
              right: -60px;
                width: 118px;
                height: 141px;
            }
        }

        /* 【PC用のスタイル記述】 */
        @media screen and (min-width: 960px) {
            .indexLayout #c01 h2 .title_img {
                left: -120px;
                top: -40px;
                max-width: 110px;
            }
            .indexLayout .bg01::after {
                position: absolute;
                content: "";
                background: url("../img/index/index_c01_bg01.png")no-repeat center center/cover;
                width: 1613px;
              height: 464px;
              top: 20px;
                left: 50%;
                transform: translateX(-50%);
                z-index: -1;
            }
            .indexLayout #c01 .y_box > div::before {
                background-image: url("../img/index/index_c01_bg03.png");
                bottom: 30px;
                left: -190px;
                width: 150px;
                height: 150px;
            }
            .indexLayout #c01 .y_box > div::after {
              right: -130px;
            }
        }



/* c02
----------------------------------------------------*/
.indexLayout #c02 {
    padding-top: 30px;
    position: relative;
}
.indexLayout #c02 .pink_bg {
    position: relative;
    padding-top: 80px;
}
.indexLayout #c02 .pink_img {
    position: absolute;
    width: 45%;
    top: 0;
    right: 0;
    max-width: 165px;
}
.indexLayout #c02 .pink_txt h3 {
    color: #E57878;
    margin-bottom: 20px;
    font-size: 1.4rem;
}
.indexLayout #c02 .pink_txt {
    width: calc(100% - 40px);
  background: #fff1f5;
  border-radius: 27% 73% 50% 50% / 53% 56% 44% 47%;
  padding: 30px 20px 40px;
    position: relative;
}

.indexLayout #c02 .pink_txt::after {
    position: absolute;
    content: "";
    border-radius: 27% 73% 50% 50% / 53% 56% 44% 47%;
    width: 100%;
    height: 100%;
    bottom: -10px;
    left: 0;
    background-color: #FF9898;
    z-index: -1;
}
.indexLayout #c02 .pink_txt p {
    line-height: 1.8;
}


        /* 【タブレット用のスタイル記述】 */
        @media screen and (min-width: 760px) {
            .indexLayout #c02 {
                padding-top: 60px;
            }
            .indexLayout #c02 .pink_txt h3 {
                font-size: 2rem;
            }
            .indexLayout #c02 .pink_txt {
                width: calc(100% - 140px);
                padding: 100px 70px 70px;
            }
            .indexLayout #c02 .pink_img {
                width: 42%;
                max-width: none;
            }
            .indexLayout #c02 .pink_txt .btn01 {
                margin-left: 0;
            }
        }

        /* 【PC用のスタイル記述】 */
        @media screen and (min-width: 960px) {
            .indexLayout #c02 .pink_txt {
                width: calc(65% - 260px);
                padding: 70px 140px;
            }
            .indexLayout #c02 .pink_bg {
                padding-top: 0;
                padding-bottom: 60px;
            }
            .indexLayout #c02 .pink_img {
                width: 45%;
                top: auto;
                bottom: 0;
            }
            .indexLayout #c02 .pink_bg::before, .indexLayout #c02 .pink_txt h3::after {
                position: absolute;
                content: "";
                background-size: cover;
                background-repeat: no-repeat;
                background-position: center center;
            }
            .indexLayout #c02 .pink_bg::before {
                background-image: url("../img/index/index_c02_before02.png");
                width: 201px;
                height: 192px;
                left: -80px;
                bottom: 30%;
                z-index: 1;
            }
            .indexLayout #c02::after {
                position: absolute;
                content: "";
                background: url("../img/index/index_c02_before03.png")no-repeat center center/cover;
                width: 356px;
                height: 306px;
                top: 25%;
                right: 0;
            }
            .indexLayout #c02 .pink_txt h3 {
                position: relative;
            }
            .indexLayout #c02 .pink_txt h3::after {
                background-image: url("../img/index/index_c02_before01.png");
                width: 95px;
                height: 95px;
                left: calc(50% + 130px);
                transform: translateX(-50%);
                top: -40px;
            }
        }

        /* 【PC用のスタイル記述】 */
        @media screen and (min-width: 1400px) {
            .indexLayout #c02::after {
                top: 160px;
                width: 536px;
                height: 436px;
            }
            .indexLayout #c02 .pink_bg::before {
                width: 201px;
                height: 192px;
                left: -80px;
                bottom: 30%;
            }
        }



/* c03
----------------------------------------------------*/
.indexLayout #c03 {
    padding-top: 100px;
    background: url("../img/index/index_c03_bg01.png")no-repeat center center/cover;
    position: relative;
    overflow-x: clip;
}
.indexLayout #c03 .w_box, .indexLayout #c04 .w_box {
    position: relative;
    background-color: transparent;
    z-index: 1;
}
.indexLayout #c03 .w_box::before, .indexLayout #c04 .w_box::before,
.indexLayout #c03 .w_box::after, .indexLayout #c04 .w_box::after {
    position: absolute;
    content: "";
}
.indexLayout #c03 .w_box::before, .indexLayout #c04 .w_box::before {
    width: 100%;
    height: 100%;
    background-color: #fff;
    border-radius: 20px;
    z-index: -1;
    top: 0;
    left: 0;
}
.indexLayout #c03 .w_box::after, .indexLayout #c04 .w_box::after {
    width: 100%;
    border-radius: 20px;
    height: 10%;
    min-height: 100px;
    background-color: rgb(252, 200, 0);
    bottom: -10px;
    left: 0px;
    z-index: -2;
}
.indexLayout #c03 .w_box .inner::before, .indexLayout #c03 .w_box .inner::after {
    position: absolute;
    content: "";
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center center;
}
.indexLayout #c03 .w_box .inner {
    position: relative;
}
.indexLayout #c03 .w_box .inner::after {
    background-image: url("../img/index/index_c03_img01.png");
    width: 52px;
  height: 90px;
  top: -20px;
    right: 0;
}



        /* 【タブレット用のスタイル記述】 */
        @media screen and (min-width: 760px) {
            .indexLayout #c03 .w_box::before, .indexLayout #c04 .w_box::before,
            .indexLayout #c03 .w_box::after, .indexLayout #c04 .w_box::after {
                border-radius: 30px;
            }
            .indexLayout #c03 .flex {
                justify-content: center;
            }
            .indexLayout #c03 .w_box .inner::after {
                width: 72px;
                height: 127px;
            }
        }

        /* 【PC用のスタイル記述】 */
        @media screen and (min-width: 960px) {
            .indexLayout #c03 .w_box .inner::before {
                background-image: url("../img/index/index_c03_before01.png");
                width: 200px;
                height: 200px;
                top: -140px;
                right: -140px;
            }
            .indexLayout #c03 .w_box .inner::after {
                width: 106px;
                height: 187px;
                top: -30px;
            }
        }
        /* 【タブレット用のスタイル記述】 */
        @media screen and (min-width: 1500px) {
            .indexLayout #c03 .w_box .inner::after {
                width: 148px;
                height: 260px;
                top: auto;
                bottom: 0;
                right: -200px;
            }
        }



/* c04
----------------------------------------------------*/
.indexLayout #c04 {
    background: url("../common/img/common_bg01.png");
    padding-bottom: 0;
}
.indexLayout #c04 .property_cat {
    margin-bottom: 60px;
}
.indexLayout #c04 .w_box .inner {
    position: relative;
}
.indexLayout #c04 .w_box .inner::after {
    position: absolute;
    content: "";
    background: url("../img/property/property_common_img01.png")no-repeat center center/cover;
    width: 85px;
  height: 129px;
  left: 0;
  top: 0;
    z-index: 1;
}
.indexLayout #c04 #common_bg {
    position: relative;
    padding: 100px 0;
  z-index: 1;
}
.indexLayout #c04 #common_bg::before, .indexLayout #c04 #common_bg::after {
    position: absolute;
    content: "";
    background: url("../common/img/common_bgImg01.png")no-repeat center center/cover;
    width: 208px;
    height: 110px;
    z-index: -1;
}
.indexLayout #c04 #common_bg::before {
    top: 20px;
    left: 20px;
}
.indexLayout #c04 #common_bg::after {
    bottom: 20px;
    right: 20px;
    transform: scale(-1, -1);
}

        /* 【タブレット用のスタイル記述】 */
        @media screen and (min-width: 760px) {
            .indexLayout #c04 .w_box .inner::after {
                left: -90px;
                top: 40px;
            }
            .indexLayout #c04 #common_bg::before, .indexLayout #c04 #common_bg::after {
                width: 368px;
               height: 195px;
            }
        }

        /* 【PC用のスタイル記述】 */
        @media screen and (min-width: 960px) {
            .indexLayout #c04 .w_box .inner::after {
                width: 135px;
                height: 199px;
            }
            .indexLayout #c04 #common_bg::before, .indexLayout #c04 #common_bg::after {
                width: 458px;
                height: 243px;
            }
        }

        /* 【タブレット用のスタイル記述】 */
        @media screen and (min-width: 1500px) {
            .indexLayout #c04 .w_box .inner::after {
                width: 195px;
                height: 279px;
                left: -310px;
                top: auto;
                bottom: -30px;
            }
        }