/*
#calendar table.fc-scrollgrid {
    writing-mode: vertical-lr;
}

#calendar table.fc-scrollgrid th,
#calendar table.fc-scrollgrid td {
    writing-mode: horizontal-tb;
    min-height:25px;
}
*/



/* ユーザー画面 エラーメッセージ */
.user-error {
    margin: 0 auto 10px;
    padding: 0 40px;
    text-align: center;
}
.user-error .negative {
    margin-top: -55px;
}
body.home .user-error .negative {
    margin-top: 80px;
}
body.mypage .user-error .negative {
    margin: -30px 0 30px;
}
body.mypage.calendar .user-error .negative {
    margin: 0 0 30px;
}
.session-message {
    display: inline-block;
    font-size: 20px;
    font-weight: bold;
    color: #ff8d40;
    border: solid 3px #ff8d40;
    padding: 0.7em 1.5em;
    margin-bottom: 10px;
}
.session-message .sub {
    display: block;
    font-size: 1.5rem;
    margin-top: 6px;
}
@media screen and (max-width: 480px) {
    .user-error {
        padding: 0 20px;
    }
    .user-error .negative {
        margin-top: -20px;
    }
    body.mypage .user-error .negative {
        margin: -15px 0 0;
    }
    .session-message {
        font-size: 13px;
        padding: 0.4em 0.6em;
        line-height: 1.4;
        border-width: 2px;
        margin-bottom: 5px;
    }
    .session-message .sub {
        font-size: 1.1rem;
        margin-top: 2px;
    }
}

.profile-info {
    text-align: center;;
}
.input-error {
    margin-top: 6px;
    font-size: 13px;
    color: #cc0000;
}


.mt5 { margin-top: 5px; }
.mt10 { margin-top: 10px; }
.mt15 { margin-top: 15px; }
.mt20 { margin-top: 20px; }
.mt25 { margin-top: 25px; }
.mt30 { margin-top: 30px; }
.mt40 { margin-top: 40px; }
.mt40 { margin-top: 50px; }
.mt60 { margin-top: 60px; }
.mb10 { margin-bottom: 10px; }
.mb15 { margin-bottom: 15px; }
.mb20 { margin-bottom: 20px; }
.mb25 { margin-bottom: 25px; }
.mb30 { margin-bottom: 30px; }

.fs12 { font-size: 12px; }
.fs13 { font-size: 13px; }
.fs14 { font-size: 14px; }
.fs15 { font-size: 15px; }
.fs16 { font-size: 16px; }

.ta-left { text-align: left !important; }
.ta-right { text-align: right !important; }
.ta-center { text-align: center !important; }

button,
select,
#submitAddRoom {
    cursor: pointer;
}

.bg-table__row .table__cell,
.bg-session .table__cell.date,
.table__cell.unclickable {
    position: relative;
    cursor: default;
}
.bg-table__row  .table__cell::before,
.bg-session .table__cell.date:not(.on_session)::before,
.table__cell.unclickable::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    display: block;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.4);
    z-index: 4;
}
.table__cell.unclickable span.status.status-ng {
    position: relative;
    z-index: 3;
}
.bg-table__row .table__cell.unclickable span.status.status-ng {
    z-index: 1;
}


/* スペック調整 */
span.spec {
    width: 130px!important;
    border: 1px solid #bbb;
}


/* モーダル「別の場所も予約する」ボタン */
.nav-btn-box a.nav-btn {
    cursor: pointer;
}


/* aタグのスタイルをbuttonに移植 */
.reservation button:hover {
  transition: opacity 0.3s ease;
  opacity: 0.7;
}
.reservation .nav-btn-box button.nav-btn_black,
.reservation.reminder .nav-btn.nav-btn_black {
    width: 306px;
    padding: 18px 0;
    border: solid 1px #000;
    border-radius: 50px;
    background-color: #000;
    font-size: 1.8rem;
    font-weight: bold;
    text-align: center;
    color: #fff;
}
.reservation .nav-btn-box button.nav-btn {
    position: relative;
    display: block;
}
.reservation .nav-btn-box button.nav-btn_black::after,
.reservation.reminder .nav-btn.nav-btn_black::after {
  position: absolute;
  top: 0;
  right: 20px;
  bottom: 0;
  display: inline-block;
  width: 18.17px;
  height: 13.08px;
  margin: auto;
  background-image: url(../img/arrow_03.png);
  background-repeat: no-repeat;
  background-size: contain;
  vertical-align: middle;
  content: "";
}
@media screen and (max-width: 480px) {
  .reservation button.login-btn {
    font-size: 1.6rem;
  }
    .reservation .nav-btn-box button.nav-btn_black,
    .reservation.reminder .nav-btn.nav-btn_black {
        width: 280px;
        font-size: 1.5rem;
    }
}


/* ログインボタン */
.reservation button.login-btn {
    display: inline-block!important;
    border: none;
    border-radius: 0;
}
.reservation button.login-btn::after {
    display: none;
}
@media screen and (max-width: 480px) {
    .reservation button.login-btn {
        width: 100%!important;
    }
}


/* パスワードリセット完了 */
.reservation.reminder .inner.center {
    text-align: center;
}
.reservation.reminder .nav-btn.nav-btn_black {
    position: relative;
    display: inline-block;
}
.password-changed-note {
    margin-top: 20px;
    text-align: center;
    color: #cc0000;
}


/* カレンダー：予約セッションあり */
.explanation-area.calendar-added .intro-box {
    margin-bottom: 10px;
}
.explanation-area.calendar-added .explanation-box .time-box {
    align-items: flex-start;
    margin-bottom: 0px;
}
.explanation-area.calendar-added .explanation-box .time-box p {
    padding-top: 0px;
    font-size: 2.4rem!important;
}
.explanation-area.calendar-added .explanation-box p {
    padding-top: 24px;
}

/* カレンダー：モーダルのステータス画像 */
#reservationModal .table-container img.ok {
    width: 15px;
    height: 15px;
}
#reservationModal .table-container img.ng {
    width: 11px;
    height: 11px;
}

/* カレンダー：予約中 */
table .rsvd {
    font-weight: bold;
    color: #ff8d40;
}

/* 確認画面：削除ボタン */
button[type="submit"].confirm-delete {
    display: block;
    position: relative;
    text-decoration: none;
    color: #000000;
    font-size: 1.5rem;
    line-height: 1.6;
    text-align: left;
    letter-spacing: 0.03em;
    -webkit-text-size-adjust: 100%;
    width: 100%;
    padding: 0;
    border: none;
    border-radius: 0;
    background-color: transparent;
    font-weight: normal;
}
button[type="submit"].confirm-delete::after {
    display: none;
}
button[type="submit"].confirm-delete::before {
    display: inline-block;
    width: 10px;
    height: 10px;
    margin-right: 5px;
    background: url(/img/ico_status-ng.png) no-repeat;
    background-size: contain;
    content: "";
}
@media screen and (max-width: 480px) {
    button[type="submit"].confirm-delete {
        text-align:right;
    }
}

/* 前のページに戻るボタン */
button[type="submit"].nav-link.nav-link_back {
    display: flex;
    align-items: center;
    font-size: 1.5rem;
    text-align: left;
    color: #000;
    width: 100%;
    padding: 0;
    border: none;
    border-radius: 0;
    background-color: transparent;
    font-weight: normal;
}
button[type="submit"].nav-link.nav-link_back:before {
    display: inline-block;
    width: 12px;
    height: 12px;
    margin-right: 6px;
    background-image: url(/img/arrow_01.png);
    background-repeat: no-repeat;
    background-size: contain;
    vertical-align: middle;
    content: "";
}

/* 白いナビボタン */
button.nav-btn.nav-btn_white {
    width: 306px;
    padding: 18px 0;
    border: solid 1px #707070;
    border-radius: 50px;
    background-color: #fff;
    font-size: 1.8rem;
    font-weight: bold;
    text-align: center;
    color: #000;
}
@media screen and (max-width: 480px) {
    button.nav-btn.nav-btn_white {
        width: 280px!important;
        font-size: 1.5rem!important;
    }
}




/* 変更するボタン */
button.edit-btn {
    display: block;
    width: 106px;
    padding: 10px 0;
    border: 1px solid #707070;
    background-color: #fff;
    color: #000;
    border-radius: 33px;
    text-align: center;
    font-size: 1.5rem;
    line-height: 1;
}

/* 変更するボタン */
button[type="submit"].nav-btn_white-l {
    position: relative;
    display: inline-block;
    width: 306px;
    padding: 17px 0;
    border: solid 1px #707070;
    border-radius: 50px;
    background-color: #fff;
    font-size: 1.5rem;
    line-height: 1.2;
    text-align: center;
    color: #000;
    font-weight: normal;
}
button[type="submit"].nav-btn_white-l::after {
    position: absolute;
    top: 0;
    right: 25px;
    bottom: 0;
    display: inline-block;
    width: 10.17px;
    height: 10.17px;
    margin: auto;
    background-image: url(/img/arrow_02.png);
    background-repeat: no-repeat;
    background-size: contain;
    vertical-align: middle;
}
button[type="submit"].nav-btn_white-l span {
    display: block;
    padding-top: 8px;
    font-size: 1.8rem!important;
    font-weight: bold;
    color: #000;
}


/* マイページ　PDFボタン */
button[type="submit"].mypage-pdf {
    position: static;
    width: auto;
    background-color: transparent;
    font-size: 1.5rem;
    font-weight: normal;
    text-align: center;

    display: inline-block;
    padding: 5px 30px;
    border: 1px solid #707070;
    border-radius: 33px;
    text-decoration: none;    
    color: #000;
}
body.mypage-detail .navigation-area form.first {
    margin-right: 30px;
}
button[type="submit"].mypage-pdf::after {
    display: none;
}
@media screen and (max-width: 480px) {
    button[type="submit"].mypage-pdf {
        width: 49%;
        padding: 8px 0;
        font-size: 1.2rem;
    }
    body.mypage-detail .navigation-area form.first {
        margin-right: 2%;
    }
}


/* モーダル　変更するボタン */
.modal button.nav-btn.nav-btn_white {
    display: block;
    width: 202px;
    margin: 0 auto;
    padding: 20px 0;
    line-height: 1;
    border: solid 1px #707070;
    border-radius: 50px;
    background-color: #fff;
    font-size: 1.8rem;
    font-weight: bold;
    text-align: center;
    color: #000;
}
.modal button.nav-btn.nav-btn_white::after {
    position: absolute;
    top: 0;
    right: 20px;
    bottom: 0;
    display: inline-block;
    width: 18.17px;
    height: 13.08px;
    margin: auto;
    background-image: url(/img/arrow_02.png);
    background-repeat: no-repeat;
    background-size: contain;
    vertical-align: middle;
    content: "";
}


/* マイページ 編集 付帯品の変更ボタン */
.reservation .confirm03 .table-box .table-row .right.full {
    width: calc(100% - 20px);
}

/* マイページ 編集 モーダル変更するボタン */
button[type="submit"].av-btn.nav-btn_white {
    position: relative;
    display: block;
    width: 202px;
    margin: 0 auto;
    padding: 20px 0;
    line-height: 1;
    border: solid 1px #707070;
    border-radius: 50px;
    background-color: #fff;
    font-size: 1.8rem;
    font-weight: bold;
    text-align: center;
    color: #000;
}
button[type="submit"].av-btn.nav-btn_white::after {
    position: absolute;
    top: 0;
    right: 20px;
    bottom: 0;
    display: inline-block;
    width: 18.17px;
    height: 13.08px;
    margin: auto;
    background-image: url(/img/arrow_02.png);
    background-repeat: no-repeat;
    background-size: contain;
    vertical-align: middle;
    content: "";
}


/* マイページ一覧 */
@media screen and (max-width: 480px) {
    .reservation.mypage.mypage-list .table_area.list_item {
        margin-bottom: 20px;
    }
    .reservation.mypage.mypage-list .table_area td {
        height: 34px!important;
    }
    .reservation.mypage-list .table_area .list_item td:nth-child(5) {
        margin: 0 auto!important;
        height: 54px!important;
    }
    .reservation.mypage-list .table_area .list_item td:nth-child(5) .btn_box {
        /* justify-content: flex-end!important; */
        justify-content: center!important;
    }
    .reservation.mypage.mypage-list button[type="submit"].mypage-pdf {
        width: auto;
        padding: 5px 30px;
    }
}


/* マイページ 予約変更・キャンセルの注意事項 */
.reservation.mypage.mypage-detail .read_text,
.reservation.mypage.cancel .read_text {
    text-align: center;
    font-size: 15px;
    margin-bottom: 40px;
}
.reservation.mypage.mypage-detail .read_text.edit-caution,
.reservation.mypage.cancel .read_text.edit-caution {
    color: #cc0000;
    margin-bottom: 16px;
}
.reservation.mypage.mypage-detail .read_text.edit-caution {
    margin-bottom: 40px;
}
.reservation.mypage.mypage-detail .read_text p,
.reservation.mypage.cancel .read_text p {
    display: inline-block;
    text-align: left;
}
.reservation.mypage.cancel .nav-btn-box  {
    margin-bottom: 60px;
}
.reservation.mypage.cancel .nav-btn-box a,
.reservation.mypage.cancel .nav-btn-box button {
    margin: 0 20px;
}
@media screen and (max-width: 480px) {
    .reservation.mypage.cancel .nav-btn-box a,
    .reservation.mypage.cancel .nav-btn-box button {
        margin: 0;
    }
}
.reservation.mypage.mypage-detail .limit-over {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.4s ease, opacity 0.4s ease;
    opacity: 0;
  }
.reservation.mypage.mypage-detail .limit-over.show {
    max-height: 200px;
    opacity: 1;
  }
@media screen and (max-width: 480px) {
    .reservation.mypage .navigation-area .nav-btn-box form {
        width: 49%;
    }
    .reservation.mypage .navigation-area .nav-btn-box form .nav-btn.nav-btn_white-l {
        width: 100%;
        padding: 8px 0;
        font-size: 1.2rem;
    }
    .reservation.mypage .navigation-area .nav-btn-box form .nav-btn.nav-btn_white-l span {
        font-size: 1.4rem!important;
        padding-top: 3px;
    }
    button[type="submit"].nav-btn_white-l::after {
        right: 5px;
    }


    /* マイページ ヘッダーナビのSPサイズ */    
    .reservation.mypage .mypage-nav-area .nav-btn-box {
        display: flex!important;
    }
    .reservation.mypage .mypage-nav-area .nav-btn-box .nav-btn_01,
    .reservation.mypage .mypage-nav-area .nav-btn-box form {
        width: 49%;
    }
    .reservation.mypage .mypage-nav-area .nav-btn-box .nav-btn_01.admin {
        padding: 17px 7% 8px 0;
    }
    .reservation.mypage .mypage-nav-area .nav-btn-box form .nav-btn {
        width: 100%;
    }
    .reservation.mypage .mypage-nav-area .nav-btn-box form .nav-btn.nav-btn_02 {
        padding: 17px 15% 17px 0;
    }
}


/* マイページ 会員情報の確認・変更 タイトルエリア */    
.reservation .navigation-area.nav-only.wide {
    margin-bottom: 120px;
}
.reservation.mypage .ttl-area.min {
    margin-bottom: 40px;
}
.reservation.mypage .ttl-area.min h2 {
    font-size: 2.4rem;
}
.reservation .navigation-area.nav-only.min {
    margin-bottom: 40px;
}
@media screen and (max-width: 480px) {
    .reservation .navigation-area.nav-only.wide {
        margin-bottom: 50px;
    }
    .reservation.mypage .ttl-area.min {
        margin-bottom: 30px;
    }
    .reservation.mypage .ttl-area.min h2 {
        font-size: 2rem;
    }
    .reservation .navigation-area.nav-only.min {
        margin-bottom: 30px;
    }
}


/* マイページ 確認ボタン */
@media screen and (max-width: 480px) {
    .reservation.mypage.cancel .nav-btn-box.flex {
        justify-content: space-between;
    }
    .reservation.mypage.cancel .nav-btn-box.flex form,
    .reservation.mypage.cancel .nav-btn-box.flex a {
        width: 47%;
        margin: 0;
    }
    .reservation.mypage.cancel .nav-btn-box.flex form button {
        width: 100%;
        margin: 0;
    }
}


/* terns */
#terms-scroll-frame {
    border: none;
    /* height: 300px;
    padding: 45px 50px;
    background-color: #f7f7f7;
    overflow-y: auto; */
    overflow-y: scroll;
    height: 400px;
    background-color: rgb(247, 247, 247);
    padding: 45px 50px;
}
#terms-scroll-frame::-webkit-scrollbar {
  width: 6px;
}
#terms-scroll-frame::-webkit-scrollbar-track {
  background-color: #fff;
}
#terms-scroll-frame::-webkit-scrollbar-thumb {
  min-height: 100px;
  border-radius: 3px;
  background-color: #cac8c8;
}
.reservation.lastconfirm .submit-area .submit-terms-box .terms-list {
    overflow-y: visible!important;
    height: auto!important;
    background-color: transparent!important;
    padding: 0!important;
}
@media screen and (max-width: 480px) {
  #terms-scroll-frame {
    padding: 25px 20px;
  }
}


#agreement {
  pointer-events: none;
  opacity: 0.6;
}


/* ファイル添付 */
input[type="file"] {
    width: auto;
}


/* メールアドレス認証の確認リンク */
.verify-text {
    font-size: 15px;
}
.verify-button {
    margin-top: 40px;
}
@media screen and (min-width: 481px) {
    .verify-button button[type="submit"] {
        width: 396px;
    }
}
@media screen and (max-width: 480px) {
    .verify-text {
        font-size: 14px;
    }
}



/* エラー画面 */
body.index.reservation.error .max-inner {
    padding-top: 80px;
    text-align: center;
}
body.index.reservation.error .main .error-title {
    display: block;
    font-family: "游明朝", "YuMincho", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
    font-size: 2.2rem;
}
body.index.reservation.error .main p {
    font-size: 15px;
}



/* .flex.noSp */
@media screen and (max-width: 480px) {
  .reservation .navigation-area .flex.noSp {
    align-items: center!important;
    flex-direction: column-reverse!important;
  }
}



/* 確認画面の日付から選択し直すボタン増設分のアイコン */
.reservation.confirm .navigation-area .nav-btn-box a.nav-btn_refresh::after {
    position: absolute;
    top: -2px;
    right: 30px;
    bottom: 0;
    left: auto;
    display: inline-block;
    width: 23px;
    height: 20px;
    margin: auto;
    background-image: url(/img/arrow_06.png);
    background-repeat: no-repeat;
    background-size: contain;
    vertical-align: middle;
    content: "";
}
@media screen and (max-width: 480px) {
    .reservation.confirm .navigation-area .nav-btn-box a.nav-btn_refresh::after {
        width: 20px;
        height: 17px;
    }
}



/* SP時、利用内容編集モーダルのファイル選択突き抜け防止 */
.input-box .input-list .input-item.input-files .answer-box input[type="file"] {
    width: -webkit-fill-available!important;
    background: transparent;
}
@media screen and (max-width: 480px) {
    .modal .input-box .input-list .input-item.input-files .answer-box {
        padding: 10px 8px!important;
    }
    .modal .input-box .input-list .input-item.input-files .answer-box a {
        width: -webkit-fill-available!important;
        display: inline!important;
    }
}


