/*---------------------------------------------------
 common
----------------------------------------------------*/
.main {
    height: 100%;
}

a[href^="tel:"] {
    text-decoration: none !important;
    color: #fff !important;
}

.object-fit-cover {
    object-fit: cover;
}

.object-fit-contain {
    object-fit: contain;
}

.overflow-hidden {
    overflow: hidden !important;
}

.overflow-x-hidden {
    overflow-x: hidden !important;
}

.vertical-rl {
    writing-mode: vertical-rl;
}

.text-overflow {
    text-overflow: ellipsis;
    overflow: hidden;
    white-space: nowrap;
}

.link-hover {
    position: relative;
    transition: 0.3s;
    z-index: 0;
}

.spread-width {
    max-width: 1366px;
    width: 100%;
}

.rounded-shape {
    border-radius: 50%;
    aspect-ratio: 100 / 100;
    max-width: 190px;
    width: 100%;
    max-height: 190px;
    height: 100%;
}

.rounded-text-center {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

.rounded-arrow-position {
    position: absolute;
    top: 65%;
    left: 50%;
    transform: translateX(-50%);
}

.square-shape {
    height: 120px;
}

@media screen and (min-width: 992px) {
    a[href^="tel:"] {
        pointer-events: none;
    }
}

@media (hover: hover) and (pointer: fine) {
    .link-hover:hover {
        opacity: 0.5;
    }

    .cursor-pointer:hover {
        cursor: pointer;
    }

    .link-hover-effect:hover::before {
        transform: translateX(100%);
    }

    .link-hover-effect:hover::after {
        transform: scale(0);
    }
}

/*---------------------------------------------------
 single-contractor-generic
----------------------------------------------------*/
.about-img-wrapper {
    aspect-ratio: 540 / 445;
}

.img-floor-width {
    max-width: 600px;
    width: 100%;
}

.floor-plan-img-wrapper {
    aspect-ratio: 616 / 559;
}

.reserve-button {
    background-color: #E38A3F;
    border-radius: 20px;
    max-width: 326px;
    width: 100%;
}

.map-container iframe {
    width: 100%;
    height: 350px;
}

.staff-img-radius {
    border-radius: 10px;
}

@media screen and (min-width: 992px) {
    .reserve-button {
        max-width: 615px;
    }
}

/*---------------------------------------------------
 land
----------------------------------------------------*/
.land-info-column {
    margin-bottom: 1rem !important;
}

.land-info-separate {
    margin: 0 0 2rem !important;
}

.land-map-container iframe {
    width: 100%;
    height: 400px;
}

@media screen and (max-width: 991px) {
    .land-info-column {
        gap: 0 !important;
    }
}

/*---------------------------------------------------
 form
----------------------------------------------------*/
.reservation-title-width {
    width: 67px;
}

.contact-title-width {
    width: 44px;
}

.bg-contact-form {
    background-color: #fff !important;
    border-radius: 10px;
}

.wpcf7-list-item.first {
    margin-left: 0 !important;
}

.wpcf7-list-item label {
    white-space: nowrap;
}

.check .wpcf7-list-item,
.check-style .wpcf7-list-item {
    margin-bottom: 24px !important;
    margin-left: 0 !important;
}

.check .wpcf7-list-item {
    margin-right: 20px;
    display: block;
}

.wpcf7-list-item-label {
    margin-left: 4px !important;
}

.input-height {
    height: 48px;
    font-size: 18px;
}

.input-small-width {
    width: 100% !important;
}

.any::after {
    content: "任意";
    position: absolute;
    background-color: #7B7B7B;
    top: -2px;
    align-self: center;
    letter-spacing: 0.1em;
    margin-left: 20px;
    padding: 2px 9px;
    font-weight: normal;
    color: #fff !important;
}

.select-wrapper::after {
    content: "";
    position: absolute;
    top: 50%;
    left: 90%;
    width: 9px;
    height: 9px;
    border-bottom: 1px solid #333;
    border-right: 1px solid #333;
    transform: rotate(45deg) translateY(-50%);
}

.textarea-height {
    resize: none;
    height: 160px;
    font-size: 18px;
}

.wpcf7-spinner {
    display: none !important;
}

.wpcf7-acceptance .wpcf7-list-item {
    margin-left: 0;
}

.check-style {
    display: grid;
    grid-template-columns: 1fr 1fr;
}

@media screen and (min-width: 992px) {
    input[type="checkbox"]:hover,
    .wpcf7-list-item-label:hover {
        cursor: pointer;
    }

    .select-wrapper::after {
        top: 50%;
        left: 45%;
        width: 9px;
        height: 9px;
    }

    .check-style {
        grid-template-columns: 1fr 1fr 1fr 1fr;
        gap: 0 20px;
    }

    .check {
        display: block;
        width: 100% !important;
    }

    .check .wpcf7-list-item {
        margin-right: 40px;
        display: inline-block;
    }

    .input-small-width {
        width: 50% !important;
    }
}

/*---------------------------------------------------
 thanks-page
----------------------------------------------------*/
.thanks-page-height {
    height: calc(100lvh - 250px);
}

@media screen and (min-width: 992px) {
    .thanks-page-height {
        height: calc(100svh - 310px);
    }
}