.yoyaku_btn {
    display: block;
    background-image: url(../img/yoyaku_char.png), url(../img/yoyaku_bg.png);
    background-repeat: no-repeat, repeat;
    background-position: right 1% center, center;
    background-size: contain, auto;
    padding: 1%;
    margin-top: 1%;
    border: solid 3px #405524;
    border-radius: 5px;
}

.yoyaku_btn img {
    margin: auto;
    width: 22%;
}

.yoyaku_btn:hover {
    opacity: 0.8;
}

.time_info {
    float: left;
    width: 49%;
    margin: 1%;
}

.time_info_box {
    width: 33%;
    float: left;
    display: flex;
}

.time_info_txt {
    vertical-align: bottom;
}

.time_info_box img {
    height: 1.2em;
    display: inline;
    margin: 0 5px;
}

table {
    border-collapse: collapse;
}

.date_box {
    display: flex;
    flex-direction: row;
    justify-content: space-between;
}

.date_box img {
    display: block;
    width: 100%;
}

.cal_date {
    margin-top: -0.2%;
}

.cal_next {}

.cal_prev {
    transform: rotate(180deg);
}

.cal_info {
    text-align: right;
    margin: 0.5% 1%;
    font-weight: bold;
}

.cal_info_l {
    float: left;
    width: 50%;
    text-align: left;
}

.date_select {}

.now_page {
    margin-bottom: 1%;
}

.now_page a {
    color: #fff;
    background: #ff6a6a;
    padding: 0.5% 3%;
    border-radius: 3px;
    font-weight: normal;
    display: block;
    width: fit-content;
}

.now_page a:hover {
    opacity: 0.8;
}

.date_select input[type="submit"] {
    padding: 0.7% 5%;
}

.cal_info_r {
    float: left;
    width: 50%;
}

.last_update {
    margin-top: 0.5%;
}

.room_detail a {
    color: #f00;
    text-decoration: underline;
}

.icons {
    font-weight: bold;
    text-align: right;
    margin: 1% 1% 1% 0%;
    float: right;
    width: 48%;
}

.cal_info img {
    display: inline;
    width: 1.5em;
    vertical-align: bottom;
}

.calendar_tbl {
    width: 100%;
    margin: auto;
}

.calendar_tbl th,
.calendar_tbl td {
    vertical-align: middle;
    text-align: left;
    border: solid 1px #ddd;
    width: 141px;
}

.calendar_tbl td.separate1 {
    border-left: solid 3px #13dcff;
}

.calendar_tbl td.separate3 {
    border-right: solid 3px #13dcff;
}

.calendar_tbl td.separate-1box {
    border-left: solid 3px #13dcff;
    border-right: solid 3px #13dcff;
}

.calendar_tbl th {
    padding: 5px;
    padding-left: 10px;
    background: #c9dfff;
    font-weight: bold;
}

th.room_th {
    width: 13%;
}

.time_icon_box {
    padding: 0 1%;
}

.time_icon {
    width: 29%;
    float: left;
    margin: 0 2.1%;
    margin-bottom: 3%;
}

.icon_space {
    margin-right: 0.5%;
    margin-left: 2%;
}

.icon_red {
    color: #f00;
}

.icon_blue_d {
    color: #000306;
    text-shadow: 0 0 #000306;
}

.icon_blue {
    color: #007eff;
}

.yoyaku_link {
    color: #007eff;
}

.yoyaku_link:hover {
    text-decoration: underline;
}

.cal_box {
    min-height: 30px;
    padding: 5%;
}

.calendar_tbl td:nth-last-child(1) .cal_day,
.calendar_tbl th:nth-last-child(1) {
    color: blue;
}

.calendar_tbl td:nth-last-child(7) .cal_day,
.calendar_tbl th:nth-last-child(7) {
    color: red;
}

.today {
    background: #d6ffd3;
}

.date_box {
    font-size: 2em;
    font-weight: bold;
    margin-bottom: 0.5%;
    text-align: center;
    background: #e6ecda;
    padding: 0.5%;
    border-radius: 100px;
}

.calendar_tbl {
    font-size: 1.1em;
    border: solid 2px #dddddd;
    border-bottom: solid 3px #13dcff;
}

.first_line {
    border-top: solid 3px #13dcff;
    font-size: 1.2em;
    font-weight: bold;
}

.room_name {
    vertical-align: middle;
    padding: 0.5%;
    background: #e5f5ff;
    font-weight: bold;
    color: #135568;
    border-color: #ccc !important;
    border-left: solid 3px #13dcff !important;
}

.select_box {
    font-size: 0.8em;
    padding: 2%;
    text-align: center;
}

.select_box_a {
    font-size: 0.8em;
    padding: 2%;
    text-align: center;
    background: #ff701d;
}

.submit {
    margin: 2% auto;
    display: block;
    font-size: 1.3em;
    padding: 0.2% 15%;
}

.time {
    font-size: 0.9em;
    text-align: center;
    font-weight: bold;
}

.time img {
    width: 33%;
    float: left;
}

tr:not(.first_line):hover,
tr:not(.first_line):hover .today {
    background: #ffe5ab;
}

tr:not(.first_line):hover .room_name {
    text-decoration: underline;
    background: #ffe5ab;
}

.js-scrollable {
    overflow: hidden;
    clear: both;
}

span.scroll-hint-icon {
    top: calc(10% - 25px);
}

.only_sp_t {
    display: none;
}

#monthpicker {
    font-size: 1.4em;
}

@media screen and (max-width:1200px) {
    .time_info_box {
        width: 33%;
    }

    .time_info {
        float: none;
        width: 65%;
    }

    .time_info_box {
        width: fit-content;
        padding-right: 1em;
    }

    .icons {
        text-align: center;
        width: 100%;
        float: none;
    }
}

@media screen and (max-width:1024px) {
    .calendar_tbl {
        min-width: 1000px;
    }

    .fixed {
        position: sticky;
        left: -1px;
        filter: drop-shadow(2px 1px 1px #999);
    }

    .only_sp_t {
        display: inline;
    }
}

@media screen and (max-width:960px) {
    .cal_next {
        flex-basis: 8%;
        padding: 1.2%;
    }

    .cal_prev {
        flex-basis: 8%;
        padding: 1.2%;
    }

    .cal_date {
        margin-top: 7px;
    }

    .room_name {
        font-size: 0.8em;
    }

    .cal_info_l {
        float: none;
        width: 100%;
        text-align: left;
    }

    .cal_info_r {
        float: none;
        width: 100%;
    }

    .time_info {
        width: 100%;
    }

    .yoyaku_btn img {
        width: 46%;
    }

}

@media screen and (max-width:650px) {

    .cal_prev,
    .cal_next {
        flex-basis: 50px;
        padding: 0;
    }

    .date_box {
        padding: 5px;
    }

    .cal_info_r {
        font-size: 0.9em;
    }

    .icons_bottom {
        font-size: 0.8em;
    }

    .now_page a {
        padding: 1%;
        width: 100%;
        display: block;
        text-align: center;
        margin: 2% 0;
    }

    .icons {
        font-size: 0.95em;
    }

    .yoyaku_btn img {
        width: 60%;
        margin: 0;
        margin-left: 2%;
    }
}

@media screen and (max-width:550px) {
    .time_info_box {
        float: none;
        margin-bottom: 2%;
    }
}

@media screen and (max-width:425px) {

    .cal_info {
        font-size: 1.2em;
    }

    .time_info {
        font-size: 1.2em;
    }

    .icons {
        margin-bottom: 5%;
    }

    .icon_box {
        display: block;
        text-align: left;
        font-size: 1.2em;
        margin-bottom: 2%;
    }

    #datepicker {
        width: 100%;
    }

    .date_select input[type="submit"] {
        margin: 1% 0;
    }

    .date_select {
        text-align: right;
    }

    th.room_th {
        width: 10%;
    }

    .yoyaku_btn img {
        width: 70%;
    }

    .time_info {
        margin: 6% 0;
    }
}