@charset "UTF-8";

h2 span {
    color: #fff;
    text-align: center;
}


.rest_wrapper {
    padding: 3% 0%;
    background-color: rgba(255, 255, 255, 0.6);
    max-width: 1200px;
    margin: auto;
}

.cd-fixed-bg.cd-bg-2 {
    background-image: url(../img/rest/rest_top.jpg);
    height: 400px;
}

.cd-fixed-bg.cd-bg-2::before {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    background: black;
    opacity: 0.4;
}

.opentime {
    padding: 3%;
    background-color: #fcf5ef;
    box-shadow: 1.5px 1.5px 4px rgba(0, 0, 0, 0.2);
}


.tableopen {
    margin: 30px auto 0;
    background: rgba(255, 255, 255, 0.8);
    backdrop-filter: blur(10px);
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1);
    border-radius: 3px;
}

.tableopen td,
.tableopen th {
    padding: 20px;
    border: none;
}

.tableopen tr {
    border: 1px solid#ccc;
}

.flex_box {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}

.flex50 {
    width: 48%;
    padding: 2rem 1rem;
    background: #f5f9fa;
    border-radius: 3px;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
    margin-bottom: 20px;
}

.flex30 {
    width: 32%;
    padding: 1rem 1rem;
    background: #f5f9fa;
    border-radius: 3px;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
    margin: 0 5px 20px;
}

.flex_box::after {
    content: "";
    display: block;
    width: 32%;
}

.bcf {
    box-shadow: none;
    background: #ffffff;
}

.comperoom {
    display: flex;
    height: 66px;
    border-radius: 3px;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
    background-color: #fdeafb;
    color: #eb0570;
    transition: 0.5s;
    justify-content: center;
    align-items: center;
    max-width: 466px;
}

.comperoom:hover {
    background-color: #8b3082;
    color: #ffffff;
    transition: 0.5s;
}

h4 {
    padding-left: 0.5em;
}

.name {
    font-weight: bolder;
}

.textr {
    text-align: right;
}

.other {
    font-size: 20px;
    margin-top: 20px;
}

.other2 {
    font-size: 18px;
    margin: 20px 0;
}

.strong {
    font-size: 27px;
}

/* スマホ */

@media screen and (max-width:808px) {

    .flex50,
    .flex30 {
        width: 100%;
    }

    .rest_wrapper {
        padding: 3% 20px;

    }

    .other {
        font-size: 18px;
    }

    .other2 {
        font-size: 16px;
    }
}

@media screen and (max-width:430px) {
    .strong {
        font-size: 21px;
    }
}