@charset "utf-8";
@import "anime.css";

/*
------------
property_index.css
------------
*/

/* title_area */
#title_area::before {
    background-image: url(../../images/content/property/titleBg.webp);
}
@media only screen and (max-width: 768px) {
    #title_area::before {
        background-image: url(../../images/content/property/titleBgSP.webp);
    }
}
/* filter_area */
#filter_area {
    margin: 85px 0 0 0;
}
#filter_area .inner {
    width: calc(100vw * 1100 / 1400);
    max-width: 1100px;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    align-items: center;
    gap: 20px 0;
}
#filter_area .inner .sort {
    display: flex;
    justify-content: flex-start;
    flex-wrap: wrap;
    align-items: center;
    gap: 10px 20px;
}
#filter_area .inner .sort label {
    font-size: 1.6rem;
    font-weight: 500;
    letter-spacing: 0.05em;
    color: var(--accent_color);
}
#filter_area .inner .sort select {
    font-size: 1.6rem;
    font-weight: 500;
    letter-spacing: 0.05em;
    appearance: none;
    cursor: pointer;
    border: none;
    color: var(--main_font_color);
    background-color: var(--main_bg_color);
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 8 8'%3E%3Cpath fill='none' stroke='currentColor' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round' d='M1 2l3 3 3-3'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 12px center;
    background-size: 10px 10px;
    border-radius: 6px;
    padding: 15px 40px 15px 20px;
    border: 1px solid var(--main_bg_color);
    transition: all .3s ease;
}
#filter_area .inner .sort select:focus {
    outline: none;
}
#filter_area .inner .sort select:hover {
    border: 1px solid var(--accent_color);
}
#filter_area .inner .element {
    display: flex;
    justify-content: flex-start;
    flex-wrap: wrap;
    gap: 10px;
}
#filter_area .inner .element button {
    appearance: none;
    cursor: pointer;
    outline: none;
    background-color: #fff;
    border: 1px solid var(--main_font_color);
    display: flex;
    align-items: center;
    gap: 0 10px;
    padding: 10px 10px 10px 20px;
    border-radius: 300px;
    transition: all .3s ease;
}
#filter_area .inner .element button svg {
    width: 20px;
    height: auto;
    aspect-ratio: 1 / 1;
}
#filter_area .inner .element button svg .bg {
    fill: var(--main_font_color);
    transition: all .3s ease;
}
#filter_area .inner .element button svg .arrow {
    fill: var(--main_bg_color);
    transition: all .3s ease;
}
#filter_area .inner .element button:hover {
    background-color: var(--main_font_color);
    color: var(--main_bg_color);
    gap: 0 20px;
}
#filter_area .inner .element button:hover svg .bg {
    fill: var(--main_bg_color);
}
#filter_area .inner .element button:hover svg .arrow {
    fill: var(--main_font_color);
}
#filter_area .panel_area {
    margin: 45px 0 0 0;
}
#filter_area .panel {
    overflow: hidden;
    height: 0;
    opacity: 0;
    background: var(--sub_bg_color);
    transition: all .3s ease;
    color: var(--main_bg_color);
}
#filter_area .panel.is-open {
    opacity: 1;
}
#filter_area .panel .element {
    padding: 75px 0;
    width: calc(100vw * 1100 / 1400);
    max-width: 1100px;
    margin: 0 auto;
}
#filter_area .panel .element form {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    align-items: flex-start;
}
#filter_area .panel .element form .form_item:not(:first-child) {
    margin: 30px 0 0 0;
}
#filter_area .panel .element form .form_item.submit_item {
    margin: 80px 0 0 0;
    display: flex;
    justify-content: center;
}
#filter_area .panel .element form .form_item {
    width: 100%;
}
#filter_area .panel .element form .form_item.w_half {
    width: calc(100% / 2 - 30px);
}
#filter_area .panel .element form .form_item label.form_label,
#filter_area .panel .element form .form_item legend {
    font-size: 1.6rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    color: var(--main_bg_color);
    display: block;
    margin: 0 0 15px 0;
}
#filter_area .panel .element form .form_item ul.list {
    display: flex;
    justify-content: flex-start;
    flex-wrap: wrap;
    align-items: flex-start;
    gap: 12px;
}
#filter_area .panel .element form .form_item ul.list li {
    width: calc(100% / 4 - 9px);
}
#filter_area .panel .element form .form_item .range {
    width: 100%;
    display: flex;
    justify-content: flex-start;
    flex-wrap: wrap;
    align-items: center;
    gap: 14px;
}
#filter_area .panel .element form .form_item .range .field {
    width: calc((100% - 42px) / 2);
}
#filter_area .panel .element form .form_item .range .field select {
    width: 100%;
    font-size: 1.6rem;
    font-weight: 500;
    letter-spacing: 0.05em;
    appearance: none;
    cursor: pointer;
    border: none;
    color: var(--main_font_color);
    background-color: var(--main_bg_color);
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 8 8'%3E%3Cpath fill='none' stroke='currentColor' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round' d='M1 2l3 3 3-3'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 12px center;
    background-size: 10px 10px;
    border-radius: 6px;
    padding: 15px 40px 15px 20px;
    border: 1px solid var(--main_bg_color);
    transition: all .3s ease;
}
#filter_area .panel .element form .form_item .range .field select:focus {
    outline: none;
}
#filter_area .panel .element form .form_item .range .field select:hover {
    border: 1px solid var(--accent_color);
}
#filter_area .panel .element form .form_item .range .tilde {
    position: relative;
    width: 14px;
    display: block;
}
#filter_area .panel .element form .form_item .range .tilde::before {
    content: "";
    width: 14px;
    height: 2px;
    background-color: var(--main_bg_color);
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
}
#filter_area .panel .element form .form_item .size100 {
    width: 100%;
}
#filter_area .panel .element form .form_item input[type="text"] {
    background-color: var(--main_bg_color);
    border: none;
    font-size: 1.6rem;
    letter-spacing: 0.05em;
    font-weight: 500;
    padding: 15px 20px;
    border-radius: 6px;
}
#filter_area .panel .element form .form_item input[type="text"]:focus {
    outline: none;
}
#filter_area .panel .element form .form_item input[type="checkbox"] {
    display: none;
}
#filter_area .panel .element form .form_item ul.list label {
    display: block;
    background-color: var(--main_bg_color);
    border: 1px solid var(--main_bg_color);
    font-size: 1.6rem;
    font-weight: 500;
    letter-spacing: 0.05em;
    color: var(--main_font_color);
    text-align: center;
    padding: 18px 0;
    border-radius: 6px;
    cursor: pointer;
    transition: all .3s ease;
}
#filter_area .panel .element form .form_item ul.list label:hover {
    background-color: transparent;
    color: var(--main_bg_color);
}
#filter_area .panel .element form .form_item ul.list input[type="checkbox"]:checked + label {
    background-color: var(--accent_color);
    color: var(--main_bg_color);
    border: 1px solid var(--accent_color);
}
#filter_area .panel .element button.sbm {
    appearance: none;
    cursor: pointer;
    outline: none;
    background-color: var(--accent_color);
    border: 1px solid var(--accent_color);
    color: var(--main_bg_color);
    display: flex;
    align-items: center;
    gap: 0 10px;
    padding: 10px 10px 10px 20px;
    border-radius: 300px;
    transition: all .3s ease;
}
#filter_area .panel .element button.sbm svg {
    width: 20px;
    height: auto;
    aspect-ratio: 1 / 1;
}
#filter_area .panel .element button.sbm .bg {
    fill: var(--main_bg_color);
    transition: all .3s ease;
}
#filter_area .panel .element button.sbm .arrow {
    fill: var(--accent_color);
    transition: all .3s ease;
}
#filter_area .panel .element button.sbm:hover {
    background-color: var(--main_bg_color);
    color: var(--main_font_color);
    gap: 0 20px;
}
#filter_area .panel .element button.sbm:hover svg .bg {
    fill: var(--accent_color);
}
#filter_area .panel .element button.sbm:hover svg .arrow {
    fill: var(--main_bg_color);
}
#filter_area .panel .element .close_item {
    margin: 60px 0 0 0;
    display: flex;
    justify-content: center;
}
#filter_area .panel .element .close_item button.panel_close {
    appearance: none;
    cursor: pointer;
    outline: none;
    display: flex;
    align-items: center;
    gap: 0 10px;
    border: none;
    background-color: transparent;
    color: var(--main_bg_color);
    font-size: 1.6rem;
    letter-spacing: 0.05em;
    font-weight: 500;
    transition: all .3s ease;
}
#filter_area .panel .element .close_item button.panel_close svg {
    width: 14px;
    height: auto;
    aspect-ratio: 1 / 1;
}
#filter_area .panel .element .close_item button.panel_close svg .bg {
    fill: var(--main_bg_color);
}
#filter_area .panel .element .close_item button.panel_close:hover {
    opacity: .6;
}
#filter_area .panel.theme .element ul.list {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    align-items: flex-start;
    gap: 12px;
}
#filter_area .panel.theme .element ul.list li {
    width: calc(100% / 4 - 9px);
}
#filter_area .panel.theme .element ul.list li a {
    display: block;
    background-color: var(--main_bg_color);
    border: 1px solid var(--main_bg_color);
    font-size: 1.6rem;
    font-weight: 500;
    letter-spacing: 0.05em;
    color: var(--main_font_color);
    text-align: center;
    padding: 18px 0;
    border-radius: 6px;
    transition: all .3s ease;
}
#filter_area .panel.theme .element ul.list li a:hover {
    background-color: transparent;
    color: var(--main_bg_color);
}
@media only screen and (max-width: 768px) {
    #filter_area {
        margin: 65px 0 0 0;
    }
    #filter_area .inner {
        width: 85vw;
        max-width: 85vw;
        display: block;
    }
    #filter_area .inner .sort {
        display: none;
    }
    #filter_area .inner .element {
        display: block;
    }
    #filter_area .inner .element button {
        background-color: var(--sub_bg_color);
        border: none;
        color: var(--main_bg_color);
    }
    #filter_area .inner .element button svg .bg {
        fill: var(--main_bg_color);
    }
    #filter_area .inner .element button svg .arrow {
        fill: var(--sub_bg_color);
    }
    #filter_area .inner .element button:hover {
        background-color: var(--sub_bg_color);
        color: var(--main_bg_color);
        gap: 0 10px;
    }
    #filter_area .inner .element button:hover svg .arrow {
        fill: var(--sub_bg_color);
    }
    #filter_area .inner .element button.btn-terms {
        display: none;
    }
    #filter_area .panel_area {
        margin: 30px 0 0 0;
    }
    #filter_area .panel .element {
        padding: 50px 0;
        width: 85vw;
        max-width: 85vw;
    }
    #filter_area .panel .element .close_item {
        margin: 45px 0 0 0;
    }
    #filter_area .panel.theme .element ul.list {
        display: block;
    }
    #filter_area .panel.theme .element ul.list li {
        width: 100%;
    }
    #filter_area .panel.theme .element ul.list li:not(:first-child) {
        margin: 10px 0 0 0;
    }
    #filter_area .panel.theme .element ul.list li a {
        display: block;
        border: none;
    }
    #filter_area .panel.theme .element ul.list li a:hover {
        background-color: var(--main_bg_color);
        color: var(--main_font_color);
    }
}
/* area_nav */
#area_nav {
    width: calc(100vw * 1100 / 1400);
    max-width: 1100px;
    margin: 60px auto 0 auto;
}
#area_nav ul {
    display: flex;
    justify-content: flex-start;
    flex-wrap: wrap;
    align-items: flex-start;
    gap: 20px;
}
#area_nav ul li {
    width: calc(100% / 4 - 15px);
    text-align: center;
}
#area_nav ul li a {
    display: block;
    background-color: var(--accent_color);
    color: var(--main_bg_color);
    font-size: 1.6rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    padding: 20px 0;
    border-radius: 6px;
    transition: all .3s ease;
}
#area_nav ul li a:hover {
    background-color: var(--main_bg_color);
    color: var(--accent_color);
}
@media only screen and (max-width: 768px) {
    #area_nav {
        width: 85vw;
        max-width: 85vw;
        margin: 40px auto 0 auto;
    }
    #area_nav ul {
        gap: 6px;
    }
    #area_nav ul li {
        width: calc(100% / 2 - 3px);
    }
    #area_nav ul li a {
        padding: 18px 0;
    }
    #area_nav ul li a:hover {
        background-color: var(--accent_color);
        color: var(--main_bg_color);
    }
}
/* property_list */
#property_list {
    margin: 100px 0 0 0;
}
#property_list .inner {
    width: calc(100vw * 1100 / 1400);
    max-width: 1100px;
    margin: 0 auto;
}
#property_list .inner p.empty_data {
    font-size: 1.6rem;
    font-weight: 500;
    letter-spacing: 0.125em;
    line-height: 1.6;
    text-align: center;
    padding: 0 0 100px 0;
}
#property_list .area_block {
    width: calc(100vw * 1100 / 1400);
    max-width: 1100px;
    margin: 0 auto;
}
#property_list .area_block:not(:first-child) {
    margin: 125px auto 0 auto;
}
#property_list .area_block:nth-child(even) {
    padding: 125px 0;
    position: relative;
    z-index: 1;
}
#property_list .area_block:nth-child(even)::before {
    content: "";
    width: 100vw;
    height: 100%;
    background-color: var(--main_bg_color);
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    z-index: -1;

}
#property_list .area_block h3 {
    display: flex;
    align-items: center;
    font-size: 2.8rem;
    font-weight: 600;
    letter-spacing: 0.15em;
    position: relative;
}
#property_list .area_block h3::after {
    content: "";
    flex: 1;
    height: 1px;
    background-color: var(--accent_color);
    margin-left: 1em;
}
#property_list .area_block .list {
    display: flex;
    justify-content: flex-start;
    flex-wrap: wrap;
    align-items: stretch;
    gap: 65px 39px;
    margin: 60px 0 0 0;
}
#property_list .area_block .list article {
    width: calc(100% / 3 - 26px);
    position: relative;
    padding: 0 0 65px 0;
}
#property_list .area_block .list article .img_area {
    width: 100%;
    height: auto;
    aspect-ratio: 340 / 255;
    overflow: hidden;
    border-radius: clamp(10px, calc(100vw * 14 / 1400), 14px);
    position: relative;
}
#property_list .area_block .list article .img_area ul {
    position: absolute;
    top: 10px;
    left: 10px;
    display: flex;
    justify-content: flex-start;
    flex-wrap: wrap;
    gap: 5px;
}
#property_list .area_block .list article .img_area ul li {
    display: inline-block;
    background-color: var(--accent_color);
    color: var(--main_bg_color);
    font-size: 1.3rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    padding: 5px 15px;
    border-radius: 4px;
}
#property_list .area_block .list article .img_area ul li.new {
    background-color: #ff3333;
}
#property_list .area_block .list article figure {
    width: 100%;
    height: 100%;
}
#property_list .area_block .list article figure img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
#property_list .area_block .list article h4 {
    font-size: 1.6rem;
    font-weight: 600;
    letter-spacing: 0.05em;
    line-height: 1.5;
    color: var(--accent_color);
    padding: 0 10px;
    margin: 15px 0 0 0;
}
#property_list .area_block .list article dl {
    padding: 0 10px;
    margin: 10px 0 0 0;
    font-size: 1.3rem;
    letter-spacing: 0.05em;
    line-height: 1.5;
    font-weight: 500;
    display: flex;
    flex-wrap: wrap;
    gap: 5px 0;
}
#property_list .area_block .list article dl dt {
    width: 6em;
    text-align: justify;
    text-align-last: justify;
}
#property_list .area_block .list article dl dd {
    width: calc(100% - 6em);
    padding: 0 0 0 15px;
}
#property_list .area_block .list article p.recommend {
    border-top: 1px solid #e8e8e8;
    padding: 20px 10px 0 10px;
    margin: 20px 0 0 0;
    font-size: 1.3rem;
    letter-spacing: 0.05em;
    line-height: 1.5;
    font-weight: 500;

}
#property_list .area_block .list article p.link_area {
    position: absolute;
    bottom: 0;
    left: 0;
}
@media only screen and (max-width: 768px) {
    #property_list {
        margin: 60px 0 0 0;
    }
    #property_list .inner {
        width: 85vw;
        max-width: 85vw;
    }
    #property_list .inner p.empty_data {
        text-align: left;
        padding: 0 0 65px 0;
    }
    #property_list .area_block {
        width: 85vw;
        max-width: 85vw;
    }
    #property_list .area_block:not(:first-child) {
        margin: 65px auto 0 auto;
    }
    #property_list .area_block:nth-child(even) {
        padding: 65px 0;
    }
    #property_list .area_block h3 {
        font-size: 2.2rem;
    }
    #property_list .area_block .list {
        display: block;
        margin: 40px 0 0 0;
    }
    #property_list .area_block .list article {
        width: 100%;
        padding: 0;
    }
    #property_list .area_block .list article:not(:first-child) {
        margin: 60px 0 0 0;
    }
    #property_list .area_block .list article .img_area {
        border-radius: clamp(10px, calc(100vw * 14 / 375), 14px);
    }
    #property_list .area_block .list article p.link_area {
        position: static;
        margin: 20px 0 0 0;
    }
    #property_list .area_block .list article p.link_area.element_btn.btn01 a {
        color: var(--sub_font_color);
        background-color: var(--accent_color);
        border: 1px solid var(--accent_color);
    }
    #property_list .area_block .list article p.link_area.element_btn.btn01 a:hover {
        background-color: var(--accent_color);
        color: var(--sub_font_color);
    }
    #property_list .area_block .list article p.link_area.element_btn.btn01 a svg .bg {
        fill: var(--main_bg_color);
    }
    #property_list .area_block .list article p.link_area.element_btn.btn01 a svg .arrow {
        fill: var(--accent_color);
        transition: all .3s ease;
    }
    #property_list .area_block .list article p.link_area.element_btn.btn01 a:hover svg .bg {
        fill: var(--main_bg_color);
    }
    #property_list .area_block .list article p.link_area.element_btn.btn01 a:hover svg .arrow {
        fill: var(--accent_color);
    }
    #property_list .area_block .view_more {
        margin: 60px 0 0 0;
    }
    #property_list .area_block .view_more button {
        appearance: none;
        cursor: pointer;
        outline: none;
        background-color: var(--sub_bg_color);
        border-radius: 300px;
        color: var(--main_bg_color);
        width: 100%;
        height: calc(1em + 30px);
        font-family: "Cinzel", serif;
        font-size: 1.6rem;
        font-weight: 600;
        letter-spacing: 0.05em;
        position: relative;
    }
    #property_list .area_block .view_more button span {
        display: inline-block;
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
    }
    #property_list .area_block .view_more button svg {
        position: absolute;
        top: 50%;
        right: 15px;
        transform: translateY(-50%);
        width: 20px;
        height: auto;
        aspect-ratio: 1 / 1;
    }
    #property_list .area_block .view_more button svg .bg {
        fill: var(--main_bg_color);
    }
    #property_list .area_block .view_more button svg .arrow {
        fill: var(--sub_bg_color);
    }
    .property-fadein {
        animation: propertyFadeIn 0.4s ease forwards;
    }
}
/* floating_search */
#floating_search {
    display: none;
}
@media only screen and (max-width: 768px) {
    #floating_search {
        display: block;
        position: relative;
        z-index: 10;
    }
    #floating_search .inner {
        width: 90vw;
        position: fixed;
        bottom: 20px;
        left: 50%;
        transform: translateX(-50%);
        display: flex;
        justify-content: flex-start;
        flex-wrap: wrap;
        gap: 0 5px;
    }
    #floating_search .inner button {
        width: calc(100% / 2 - 2.5px);
        appearance: none;
        cursor: pointer;
        outline: none;
        border: none;
        background-color: var(--sub_bg_color);
        color: var(--main_bg_color);
        padding: 18px 0;
        border-radius: 6px;
    }
}
/* filter_sort, filter_terms*/
.smp_filter {
    display: none;
}
@media only screen and (max-width: 768px) {
    body.no-scroll {
        overflow: hidden;
    }
    .smp_filter {
        display: flex;
        flex-direction: column;
        position: fixed;
        inset: 0;
        z-index: 100000;
        background-color: var(--sub_bg_color);
        width: 100vw;
        height: 100%;
        min-height: 100vh;
        transform: translateX(100%);
        transition: all .5s ease;
    }
    .smp_filter.show {
        transform: translateX(0);  
    }
    .smp_filter .inner {
        flex: 1;
        min-height: 0;
        overflow-y: auto;
        -webkit-overflow-scrolling: touch;
    }
    .smp_filter .inner .header {
        display: flex;
        justify-content: space-between;
        flex-wrap: wrap;
        padding: 30px 10vw;
    }
    .smp_filter .inner .header p {
        font-size: 2.2rem;
        font-weight: 600;
        letter-spacing: 0.1em;
        color: var(--main_bg_color);
    }
    .smp_filter .inner .header button.btn_close {
        appearance: none;
        cursor: pointer;
        outline: none;
        display: flex;
        align-items: center;
        gap: 0 10px;
        border: none;
        background-color: transparent;
        color: var(--main_bg_color);
        font-size: 1.6rem;
        letter-spacing: 0.05em;
        font-weight: 500;
    }
    .smp_filter .inner .header button.btn_close svg {
        width: 14px;
        height: auto;
        aspect-ratio: 1 / 1;
    }
    .smp_filter .inner .header button.btn_close svg .bg {
        fill: var(--main_bg_color);
    }
    #filter_sort .inner .element ul li {
        border-top: 1px solid var(--accent_color);
    }
    #filter_sort .inner .element ul li a {
        display: flex;
        justify-content: space-between;
        align-items: center;
        font-size: 1.6rem;
        letter-spacing: 0.05em;
        font-weight: 500;
        color: var(--main_bg_color);
        padding: 20px 10vw;
    }
    #filter_sort .inner .element ul li svg {
        width: 20px;
        height: auto;
        aspect-ratio: 1 /1;
    }
    #filter_sort .inner .element ul li svg .bg {
        fill: var(--main_bg_color);
    }
    #filter_sort .inner .element ul li svg .arrow {
        fill: var(--accent_color);
    }
    #filter_terms .inner .element ul.parent li {
        border-top: 1px solid var(--accent_color);
        font-size: 1.6rem;
        letter-spacing: 0.05em;
        font-weight: 500;
        line-height: 1.5;
        color: var(--main_bg_color);
        padding: 20px 10vw;
        display: flex;
        justify-content: flex-start;
        align-items: center;
    }
    #filter_terms .inner .element ul.parent li .form_label {
        width: 7em;
    }
    #filter_terms .inner .element ul.parent li input[type="text"] {
        outline: none;
    }
    #filter_terms .inner .element ul.parent li input[type="text"],
    #filter_terms .inner .element ul.parent li .toggle,
    #filter_terms .inner .element ul.parent li .range {
        width: calc(100% - 7em);
    }
    #filter_terms .inner .element ul.parent li .range {
        display: flex;
        justify-content: flex-start;
        flex-wrap: wrap;
        gap: 5px 0;
    }
    #filter_terms .inner .element ul.parent li .range .toggle {
        width: auto;
    }
    #filter_terms .inner .element ul.parent li .range .tilde {
        position: relative;
        width: 5px;
        display: block;
        padding: 0 10px;
    }
    #filter_terms .inner .element ul.parent li .range .tilde::before {
        content: "";
        width: 5px;
        height: 2px;
        background-color: var(--main_bg_color);
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
    }
    #filter_terms .inner .element ul.parent li .muted {
        color: #666;
    }
    #filter_terms .inner .element ul.parent li input[type="text"] {
        background-color: var(--main_bg_color);
        border: none;
        font-size: 1.6rem;
        letter-spacing: 0.05em;
        font-weight: 500;
        padding: 10px 10px;
        border-radius: 6px;
    }
    #filter_terms .inner .flter_submit_wrap {
        padding: 20px 0;
        width: 85vw;
        margin: 0 auto;
        display: flex;
        justify-content: flex-start;
        gap: 5px;
    }
    #filter_terms .inner .flter_submit_wrap input {
        font-size: 1.6rem;
        font-weight: 500;
        letter-spacing: 0.05em;
        text-align: center;
        width: calc(100% / 2 - 2.5px);
        background: transparent;
        border: none;
        padding: 12px 0;
        border-radius: 4px;
    }
    #filter_terms .inner .flter_submit_wrap input.btn_clear_parent {
        background-color: var(--main_bg_color);
        color: var(--main_font_color);
    }
    #filter_terms .inner .flter_submit_wrap input.btn_submit_parent {
        background-color: var(--accent_color);
        color: var(--main_bg_color);
    }
    .filter_panel.smp_filter {
        background-color: var(--main_bg_color);
    }
    .filter_panel.smp_filter .header {
        padding: 30px 10vw 30px 5vw;
    }
    .filter_panel.smp_filter .header p {
        color: var(--main_font_color);
    }
    .filter_panel.smp_filter .header button.btn_back {
        appearance: none;
        cursor: pointer;
        outline: none;
        display: flex;
        align-items: center;
        gap: 0 10px;
        border: none;
        background-color: transparent;
        color: var(--main_font_color);
        font-size: 1.6rem;
        letter-spacing: 0.05em;
        font-weight: 500;
    }
    .filter_panel.smp_filter .header button.btn_back svg {
        width: 20px;
        height: auto;
        aspect-ratio: 1 / 1;
    }
    .filter_panel.smp_filter .header button.btn_back svg .bg {
        stroke: var(--main_font_color);
    }
    .filter_panel.smp_filter .header button.btn_back svg .arrow {
        fill: var(--main_font_color);
    }
    .filter_panel.smp_filter .element ul.child li {
        display: block;
        border-top: 1px solid var(--main_font_color);
        font-size: 1.6rem;
        letter-spacing: 0.05em;
        font-weight: 500;
        color: var(--main_font_color);
        padding: 20px 10vw;
    }
    .filter_panel.smp_filter .element ul.child li input[type="checkbox"] {
        display: none;
    }
    .filter_panel.smp_filter .element ul.child li:has(input[type="checkbox"]:checked) {
        background-color: var(--accent_color);
        color: var(--main_bg_color);
    }
    .filter_panel.smp_filter .element ul.child li label {
        display: block;
    }
    .filter_panel.smp_filter .element .filter_btn {
        padding: 20px 0;
        width: 85vw;
        margin: 0 auto;
        display: flex;
        justify-content: flex-start;
        gap: 5px;
    }
    .filter_panel.smp_filter .element .filter_btn button {
        appearance: none;
        cursor: pointer;
        outline: none;
        font-size: 1.6rem;
        font-weight: 500;
        letter-spacing: 0.05em;
        text-align: center;
        width: calc(100% / 2 - 2.5px);
        background: transparent;
        border: none;
        padding: 12px 0;
        border-radius: 4px;
    }
    .filter_panel.smp_filter .element .filter_btn button.btn_clear {
        border: 1px solid var(--main_font_color);
        color: var(--main_font_color);
    }
    .filter_panel.smp_filter .element .filter_btn button.btn_decide {
        background-color: var(--accent_color);
        color: var(--main_bg_color);
    }
}
@media only screen and (max-width: 768px) {
    #page_top {
        bottom: 90px;
    }
    .scroll_show #page_top {
        bottom: 90px;
    }
}
/* common_inquiry */
#common_inquiry {
    margin: 0;
}