@charset "UTF-8";

/* common
----------------------------------------------------*/
.propertyLayout #common_bg .cassette > .inner {
    max-width: 1200px;
}
.propertyLayout .property_cat > div {
    position: relative;
    padding: 40px 20px;
    text-align: center;
    margin-top: 60px;
    z-index: 1;
}
.propertyLayout .property_cat > div::before, .propertyLayout .property_cat > div::after {
    position: absolute;
    content: "";
    width: 100%;
    left: 0;
}
.propertyLayout .property_cat > div::before {
    border-radius: 20px;
    height: 100%;
    top: 0;
    z-index: -1;
}
.propertyLayout .property_cat > div::after {
    border-radius: 0 0 20px 20px;
    height: 20%;
    z-index: -2;
    bottom: -10px;
}
.propertyLayout .property_cat > div:nth-child(1)::after {
    background-color: #FF5573;
}
.propertyLayout .property_cat > div:nth-child(2)::after {
    background-color: #649FFF;
}
.propertyLayout .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;
}
.propertyLayout .property_cat .ttl span {
    display: block;
    font-size: 0.9rem;
    opacity: 0.3;
}
.propertyLayout .property_cat > div:nth-child(1)::before, .propertyLayout .property_cat > div:nth-child(1) .ttl {
    background-color: #FF849A;
}
.propertyLayout .property_cat > div:nth-child(2)::before, .propertyLayout .property_cat > div:nth-child(2) .ttl {
    background-color: #9FB8E0;
}
.propertyLayout .property_cat .btn_li {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
}
.propertyLayout .property_cat .btn_li > li {
    width: calc(96% / 2 - 2px);
}
.propertyLayout .property_cat .btn_li > li a {
    display: block;
    padding: 20px;
    background-color: #fff;
    border-radius: 10px;
    font-weight: bold;
    font-size: 0.8rem;
    transition: all 0.3s;
}
.propertyLayout .property_cat .btn_li > li a:hover {
    background-color: #FFF186;
}
.propertyLayout .property_cat .btn_li {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 20px 4%;
}
.propertyLayout .property_cat .btn_li > li .img {
    display: flex;
    justify-content: center;
    align-items: center;
    height: 58px;
    flex-direction: column;
    margin-bottom: 5px;
    transition: all 0.3s;
}
.propertyLayout .cat_name {
    text-align: center;
    padding: 5px;
    border-radius: 15px;
    color: #fff;
    font-weight: bold;
    max-width: 150px;
    margin-bottom: 10px;
}
.propertyLayout .land_sale {
    background-color: #6EBE00;
}
.propertyLayout .houses {
    background-color: #EF9429;
}
.propertyLayout .apartments {
    background-color: #EAD907;
}
.propertyLayout .investment {
    background-color: #D8501E;
}
.propertyLayout .residential {
    background-color: #F55ED2;
}
.propertyLayout .commercial {
    background-color: #A950B1;
}
.propertyLayout .land_lease {
    background-color: #147DE2;
}
.propertyLayout .parking {
    background-color: #34C2E3;
}
.propertyLayout .property_bnr {
    max-width: 1000px;
    width: 96%;
    margin: 60px auto 0;
    gap: 20px 4%;
}
.propertyLayout .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;
}
.propertyLayout .property_bnr > .flex_box01:nth-child(1) a {
    border-bottom-color: #2F9A79;
    color: #2F9A79;
    background-color: #F4FCF9;
}
.propertyLayout .property_bnr > .flex_box01:nth-child(2) a {
    border-bottom-color: #FF93A7;
    color: #FF93A7;
    background-color: #FFF2F4;
}
.propertyLayout .property_bnr > .flex_box01:nth-child(1) a::before, .propertyLayout .property_bnr > .flex_box01:nth-child(1) .ico {
    background-color: #2F9A79;
}
.propertyLayout .property_bnr > .flex_box01:nth-child(2) a::before, .propertyLayout .property_bnr > .flex_box01:nth-child(2) .ico {
    background-color: #FF93A7;
}
.propertyLayout .property_bnr a::before {
    position: absolute;
    content: "";
    width: 80px;
    height: 30px;
    clip-path: polygon(50% 0%, 0 100%, 100% 100%);
    top: -30px;
    left: 0;
}
.propertyLayout .property_bnr .ico {
    width: 60px;
    padding: 7px 0;
}
.propertyLayout .property_bnr .link_name {
    font-size: 1.2rem;
    position: relative;
    width: calc(100% - 80px);
}
.propertyLayout .property_bnr .link_name::after {
    position: absolute;
    content: "＞";
    top: 50%;
    transform: translateY(-50%);
    right: 0;
    transition: all 0.3s;
}
.propertyLayout .property_bnr a:hover .link_name::after {
    right: -10px;
}
.commonLayout #common_bg::after {
    position: absolute;
    content: "";
    background: url("../img/property/property_common_img01.png")no-repeat center center/cover;
   width: 85px;
  height: 129px;
  left: 0px;
  top: -29px;
}


        /* 【タブレット用のスタイル記述】 */
        @media screen and (min-width: 760px) {
            .propertyLayout .property_cat > div {
                padding: 40px;
            }
        }

        /* 【PC用のスタイル記述】 */
        @media screen and (min-width: 960px) {
            .propertyLayout .property_cat .ttl {
                font-size: 1.6rem;
            }
            .propertyLayout .property_cat .ttl span {
                font-size: 1.1rem;
            }
            .propertyLayout .property_cat .btn_li > li a {
                font-size: 1.1rem;
            }
        }
        /* 【タブレット用のスタイル記述】 */
        @media screen and (min-width: 1500px) {
            .commonLayout #common_bg::after {
                width: 195px;
                height: 279px;
                left: -160px;
                top: auto;
                bottom: -30px;
            }
        }





/* propertyAllLayout
----------------------------------------------------*/
.propertyPostLayout .property_cat {
    margin-bottom: 60px;
}
.propertyTaxLayout .property_cat, .propertySingleLayout .property_cat {
    margin-top: 60px;
}
.propertyAllLayout .property_li .img_wrap {
    position: relative;
    overflow: hidden;
}
.propertyAllLayout .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;
}
.propertyAllLayout .property_li a:hover .img {
    transform:scale(1.2,1.2);
}
.propertyAllLayout .property_li .img_wrap .status_icon, .propertySingleLayout .g_bg .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;
}
.propertyAllLayout .property_li .img_wrap .available, .propertySingleLayout .g_bg .available {
    display: none;
}
.propertyAllLayout .property_li .img_wrap .sold, .propertySingleLayout .g_bg .sold {
    color: #F12323;
    border-color: #F12323;
}
.propertyAllLayout .property_li .img_wrap .negotiations, .propertySingleLayout .g_bg .negotiations {
    color: #3C3C3C;
    border-color: #3C3C3C;
}
.propertyAllLayout .property_li .img_wrap .filled, .propertySingleLayout .g_bg .filled {
    color: #004c98;
    border-color: #004c98;
}

.propertyAllLayout .property_li li {
    border: 1px solid #D9D9D9;
    border-radius: 10px;
    overflow: clip;
}
.propertyAllLayout .property_li li a > div:last-child {
    padding: 15px 20px;
}
.propertyAllLayout .property_li li .ttl, .propertySingleLayout .g_bg .ttl {
    font-weight: bold;
    font-size: 1.1rem;
}
.propertyAllLayout .property_li li .price, .propertySingleLayout .g_bg .price {
    font-weight: bold;
    font-size: 0.9rem;
}
.propertyAllLayout .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) {
            .propertyAllLayout .property_li {
                gap: 60px 4%;
            }
            .propertyAllLayout .property_li .img_wrap .status_icon, .propertySingleLayout .g_bg .status_icon {
                width: 65px;
                height: 65px;
                font-size: 1.1rem;
            }
            .propertyAllLayout .property_li li {
                width: calc(92% / 3 - 2px);
            }
        }

        /* 【PC用のスタイル記述】 */
        @media screen and (min-width: 960px) {
        }



/* propertySingleLayout
----------------------------------------------------*/
.propertySingleLayout .g_bg {
    background-color: #F5F5F5;
    padding: 40px 20px;
    border-radius: 20px;
}
.propertySingleLayout .g_bg .flex_box01 {
    position: relative;
}
.propertySingleLayout .g_bg .ttl {
    font-size: 1.6rem;
    border-bottom: 1px solid #707070;
    color: #1C1C1C;
    margin-bottom: 20px;
}
.propertySingleLayout .g_bg .add {
    margin-top: 20px;
    margin-bottom: 10px;
}
.propertySingleLayout .ex_link {
    display: block;
    padding: 20px 0;
    text-align: center;
    border-radius: 10px;
    background-color: #FF506F;
    color: #fff;
    border: 2px solid #FF506F;
    font-weight: bold;
    font-size: 1.1rem;
    margin-top: 40px;
}
.propertySingleLayout .ex_link:hover {
    color: #FF506F;
    background-color: #fff;
}
.propertySingleLayout .ex_link span {
    display: inline-block;
    padding-right: 30px;
    position: relative;
}
.propertySingleLayout .ex_link span::after {
    position: absolute;
    content: "";
    background: url("../common/img/ex_icon.png")no-repeat center center/cover;
    width: 20px;
    height: 20px;
    top: 50%;
    transform: translateY(-50%);
    right: 0;
}


        /* 【タブレット用のスタイル記述】 */
        @media screen and (min-width: 760px) {
            .propertySingleLayout .g_bg {
                padding: 60px 40px;
                border-radius: 30px;
            }
            .propertySingleLayout .g_bg .flex {
                align-items: center;
            }
            .propertySingleLayout .g_bg .ttl {
                font-size: 1.6rem;
            }
            .propertySingleLayout .ex_link {
                font-size: 1.4rem;
            }
        }

        /* 【PC用のスタイル記述】 */
        @media screen and (min-width: 960px) {
        }
