﻿/* Move down content because we have a fixed navbar that is 50px tall */
html {
    height: 100%;
}

body {
    padding-top: 50px;
    padding-bottom: 20px;
    font-family: 'Noto Sans JP', 'Hiragino Sans', 'Yu Gothic', 'Meiryo', sans-serif;
    text-align: center;
    height: 100%;
}

.btn:hover{

}

/* テキストボックスのスピンボタンを非表示にする */
input[type="number"]::-webkit-inner-spin-button,
input[type="number"]::-webkit-outer-spin-button {
    -webkit-appearance: none;
    appearance: none;
    margin: 0;
}

.hide-contlole {
    display: none;
}

body .frame {
    padding-top: 0px;
    padding-bottom: 0px;
    font-family: "Noto Sans JP","メイリオ", "Meiryo", verdana, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "ＭＳ Ｐゴシック", "MS PGothic", Sans-Serif;
    text-align: center;
    height: 100%;
}

body h1 {
    margin: 0 auto;
}

body h2 {
    margin: 0 auto;
    padding-left: 10px;
    font-size: 18px;
}

/* Wrapping element */
/* Set some basic padding to keep content from hitting the edges */
.body-content {
    padding-left: 15px;
    padding-right: 15px;
}

/* Override the default bootstrap behavior where horizontal description lists 
   will truncate terms that are too long to fit in the left column 
*/
.dl-horizontal dt {
    white-space: normal;
}

/* Set widths on the form inputs since otherwise they're 100% wide */
input[type="text"],
input[type="password"],
input[type="email"],
input[type="tel"],
input[type="select"] {
    max-width: 100%;
}


.overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(255, 255, 255, 0.8);
    z-index: 1000;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.5em;
    color: #333;
}

.overlay-content {
    background-color: #fff;
    padding: 20px 40px;
    border: 1px solid #ccc;
    border-radius: 10px;
}

.custom-upload-button {
    display: inline-block;
    margin-left:10px;
    padding: 8px 16px;
    background-color: #007bff;
    color: white;
    cursor: pointer;
    border-radius: 4px;
    margin-top: 8px;
    margin-bottom: 8px;
}

    .custom-upload-button:hover {
        background-color: #0056b3;
    }

/*.custom-delete-button {
    display: inline-block;
    padding: 8px 16px;
    background-color: #dc3545;
    color: white;
    border: none;
    border-radius: 4px;
    cursor: pointer;
    margin-top: 8px;
    margin-bottom: 8px;
}

    .custom-delete-button:hover {
        background-color: #c82333;
    }*/

.delete-button {
    background: none;
    border: none;
    color: dodgerblue; /* デフォルトをグレー */
    cursor: pointer;
    padding: 0;
    font-size: 1.2rem;
    line-height: 1;
}

    .delete-button:hover {
        color: #0056b3; /* ホバーで黒にしてもOK、または赤など任意 */
    }

.file-display-box {
    background-color: #f8f9fa; /* オプション: 背景色 */
    padding: 4px 8px;
    border-radius: 6px;
}


.file-display-box {
    background-color: #f8f9fa; /* 背景グレー（任意） */
    padding: 4px 8px;
    border-radius: 6px;
}

.file-link {
    color: #007bff;
    text-decoration: underline;
}

.file-link-button {
    font-weight:bold;
    color: #007bff;
    text-decoration: underline;
    border:none;
    background-color:Background;
}


/* Responsive: Portrait tablets and up */
@media screen and (min-width: 768px) {
    .jumbotron {
        margin-top: 20px;
    }

    .body-content {
        padding: 0;
    }
}

.loading {
    position: fixed;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    background-color: #fff;
    opacity: 0;
    cursor: wait;
    z-index: 100000;
}

.link-contents-title {
    display: inline-block;
    text-overflow: ellipsis;
    white-space: nowrap;
    overflow: hidden;
    margin: 0 auto;
    width: 50%;
    border-radius: 3px;
    border: 1px solid dodgerblue;
    color: darkblue;
    background-color: white;
    font-size: 18px;
    padding: 10px;
    text-align: left;
    font-size: 18px;
    margin: 5px;
    display: inline-block;
    text-decoration: underline;
}

.link-contents-title2 {
    text-overflow: ellipsis;
    white-space: nowrap;
    overflow: hidden;
    margin: 0 auto;
    width: 80%;
    border-radius: 3px;
    border: 1px solid darkgray;
    color: black;
    font-size: 18px;
    font-weight: bold;
    padding: 10px;
    text-align: left;
    font-size: 18px;
    margin: 5px;
    display: inline-block;
}

.link-contents-title3 {
    text-overflow: ellipsis;
    white-space: nowrap;
    overflow: hidden;
    margin: 0 auto;
    width: 70%;
    border-radius: 3px;
    border: 1px solid darkgray;
    color: black;
    font-size: 18px;
    font-weight: bold;
    padding: 10px;
    text-align: left;
    font-size: 18px;
    margin: 5px;
    display: inline-block;
}


.block-div {
    margin-top: 40px;
}

.block-div-short {
    margin-top: 20px;
}

.block-div-top-short {
    margin-top: 10px;
}

.block-div-top-veryshort {
    margin-top: 5px;
}

.block-div-top-bottom-short {
    margin-top: 10px;
    margin-bottom: 10px;
}

.block-div-short3 {
    margin-top: 20px;
    display: inline-block;
}

.alert-block-div {
    margin-top: 5px;
    margin-bottom: 20px;
    line-height: 2.3em;
}

.alert-block-div2 {
    margin-top: 5px;
    line-height: 2.3em;
}

.block-div-short2 {
    margin-left: 0.5em;
    margin-top: 10px;
}

.block-div-short4 {
    margin-top: 10px;
    display: flex;
    align-items: center;
}

.block-div-short5 {
    margin-top: 5px;
    display: flex;
    align-items: center;
}

.kakomi-box-info {
    margin: 0 auto;
    padding: 1em;
    width: 100%;
    font-size: 18px;
    border: 1px solid; /* 枠線 */
    border-color: darkorange;
    background-color: ivory;
    text-align: left;
}

.kakomi-box-info-bold {
    margin: 0 auto;
    padding: 1em;
    width: 100%;
    font-size: 18px;
    border: 1px solid; /* 枠線 */
    border-color: darkorange;
    background-color: ivory;
    text-align: left;
    font-weight: 700;
    color: red;
}

.kakomi-box-fileattach {
    margin: 0 auto;
    margin-top: 10px;
    padding: 10px;
    width: 100%;
    border: 1px solid; /* 枠線 */
    border-color: dodgerblue;
    text-align: left;
}


.kakomi-box-errorinfo {
    margin: 0 auto;
    margin-bottom: 1em;
    padding: 0.5em;
    width: 90%;
    color: maroon;
    font-size: 18px;
    border: 1px solid; /* 枠線 */
    border-color: maroon;
    background-color: lightyellow;
    text-align: left;
}

.kakomi-box-errorinfo-max {
    margin: 0 auto;
    margin-bottom: 1em;
    padding: 0.5em;
    width: 100%;
    color: maroon;
    font-size: 18px;
    border: 1px solid; /* 枠線 */
    border-color: maroon;
    background-color: lightyellow;
    text-align: left;
}


.basetable .details-errorinfo {
    color: maroon;
    text-align: left;
    background-color: lightyellow;
    padding-left: 0.5em;
}

.navi-a-fixed-bottom {
    background-color: dodgerblue;
    border-color: #080808;
    right: 0;
    left: 0;
    margin-top: 20px;
    padding-top: 10px;
    padding-bottom: 10px;
    margin-bottom: 0;
}

.agree-box {
    font-size: 20px;
    font-weight: 700;
}

.left-side {
    float: left;
}

.left-side2 {
    clear: both;
    text-align: left;
    margin: 0 auto;
    width: 900px;
}

.right-side {
    clear: both;
    text-align: right;
    margin: 0 auto;
    width: 900px;
}

.right-side2 {
    float: right;
    display: inline;
    margin: 0 auto;
}


.navi-a-bottom-left-1 {
    padding-left: 20px;
    font-size: 18px;
    line-height: 20px;
    color: white;
}

.navi-a-bottom-left-2 {
    padding-left: 40px;
    font-size: 18px;
    line-height: 20px;
    color: white;
}

    .navi-a-bottom-left-2 a {
        color: white;
    }

.right-side p {
    text-align: right;
    display: inline;
    padding-bottom: 50px;
}

.navi-a-bottom-right {
    padding-right: 10px;
    padding-left: 5px;
    color: white;
    font-size: 14px;
}

.body2 {
    padding-top: 10px;
}

.cl-heaer-title {
    padding-top: 10px;
}

.cl-cell-hd-w {
    font-size: 16px;
    font-weight: bold;
    height: 30px;
    border: solid;
    border-color: silver;
    border-width: thin;
    padding: 5px;
    margin: 0px;
    text-align: center;
    background-color: whitesmoke;
    width: 60px;
    color: black;
}

.cl-cell-hd-sat {
    font-size: 16px;
    font-weight: bold;
    height: 30px;
    border: solid;
    border-color: silver;
    border-width: thin;
    padding: 5px;
    margin: 0px;
    text-align: center;
    background-color: dodgerblue;
    color: white;
    width: 60px;
}

.cl-cell-hd-sun {
    font-size: 16px;
    font-weight: bold;
    height: 30px;
    border: solid;
    border-color: silver;
    border-width: thin;
    padding: 5px;
    margin: 0px;
    text-align: center;
    background-color: lightpink;
    color: white;
    width: 60px;
}

.cl-cell {
    font-size: 16px;
    height: 30px;
    border: solid;
    border-color: silver;
    border-width: thin;
    padding: 0px;
    margin: 0px;
    text-align: center;
    background-color: white;
}

.cl-selected-cell {
    font-size: 16px;
    height: 30px;
    border: solid;
    border-color: silver;
    border-width: thin;
    padding: 0px;
    margin: 0px;
    text-align: center;
    background-color: orange;
}

.date-lnk {
    background-color: white;
    font-size: 22px;
    font-weight: bold;
    font-family: Verdana, Geneva, Tahoma, sans-serif;
    color: darkblue;
    height: 30px;
    border: solid;
    border-color: silver;
    border-width: thin;
    padding: 0px;
    margin: 0px;
    text-align: center;
    background-color: white;
}

.date-selected-lnk {
    font-size: 22px;
    font-weight: bold;
    font-family: Verdana, Geneva, Tahoma, sans-serif;
    color: darkblue;
    height: 30px;
    border: solid;
    border-color: silver;
    border-width: thin;
    padding: 0px;
    margin: 0px;
    text-align: center;
}


.basetable {
    padding: 0;
    margin: 0px;
    border: solid;
    border-color: black;
    border-width: thin;
    text-align: left;
    vertical-align: middle;
    background-color: white;
    width: 100%;
}


    .basetable th {
        height: 40px;
        border: solid;
        border-color: black;
        border-width: thin;
        text-align: center;
        background-color: azure;
    }

    .basetable td {
        height: 40px;
        border: solid;
        border-color: black;
        border-width: thin;
        text-align: center;
    }

    .basetable .unregistered {
        background-color: mistyrose;
    }

    .basetable .inprogress {
        background-color: lightyellow;
    }

    .basetable .comp {
        background-color: #e8ffd1;
    }


    .basetable .longcontents {
        max-width: 200px;
        overflow: hidden;
        text-overflow: ellipsis;
        /*        white-space: nowrap;*/
        text-align: left;
        padding-left: 0.5em;
    }

    .basetable .w10 {
        width: 10%;
    }

    .basetable .w20 {
        width: 20%;
    }

    .basetable .w30 {
        width: 30%;
    }

    .basetable .w40 {
        width: 40%;
    }

    .basetable .w50 {
        width: 50%;
    }

    .basetable .w60 {
        width: 60%;
    }

    .basetable .w70 {
        width: 70%;
    }

    .basetable .w80 {
        width: 80%;
    }

    .basetable .w90 {
        width: 90%;
    }

.frametable {
    padding: 0;
    margin: 0px;
    border: none;
    text-align: left;
    vertical-align: middle;
    width: 80%;
}


    .frametable th {
        height: 40px;
        border: solid;
        border: none;
        text-align: center;
    }

    .frametable td {
        height: 40px;
        border: none;
        text-align: center;
    }

    .frametable .longcontents {
        text-align: left;
        padding-left: 0.5em;
    }

    .frametable .w10 {
        width: 10%;
    }

    .frametable .w20 {
        width: 20%;
    }

    .frametable .w30 {
        width: 30%;
    }

    .frametable .w40 {
        width: 40%;
    }

    .frametable .w50 {
        width: 50%;
    }

    .frametable .w60 {
        width: 60%;
    }

    .frametable .w70 {
        width: 70%;
    }

    .frametable .w80 {
        width: 80%;
    }

    .frametable .w90 {
        width: 90%;
    }


.timeTableHeader {
    column-span: all;
    border: solid;
    border-color: silver;
    border-width: thin;
    margin: 0px;
    text-align: center;
    vertical-align: middle;
    height: 30px;
}

.timeTable {
    padding: 0;
    margin: 0px;
    border: solid;
    border-color: silver;
    border-width: thin;
    text-align: center;
    vertical-align: middle;
}

.timeshift_list {
    display: inline;
    font-size: 13px;
    vertical-align: middle;
}

.reservedCell {
    background-color: lightgray;
    width: 21px;
    height: 21px;
    padding-left: 0px;
    padding-right: 0px;
    border: solid;
    border-color: silver;
    border-width: thin;
    margin: 0px;
    text-align: center;
    vertical-align: middle;
}

.timeTableBtn {
    -webkit-appearance: none;
    border-radius: 0;
    display: block;
    background-color: white;
    margin: 0px;
    border: none;
    width: 20px;
    padding: 0px;
    height: 20px;
}

.timeTableBtn_t {
    -webkit-appearance: none;
    border-radius: 0;
    display: block;
    background-color: white;
    margin: 0px;
    border: none;
    width: 20px;
    padding: 0px;
    height: 20px;
}

.timeTableBtn_on {
    -webkit-appearance: none;
    border-radius: 0;
    display: block;
    margin: 0 auto;
    padding: 0;
    background-color: darkorange;
    border: none;
    width: 20px;
}

.timeTableBtn_t_on {
    -webkit-appearance: none;
    border-radius: 0;
    display: block;
    margin: 0 auto;
    padding: 0;
    background-color: darkorange;
    border: none;
    width: 20px;
}


.go-next {
    background-color: #FFFFFF;
    border: 1px solid;
    border-color: dodgerblue;
    border-radius: 3px;
    height: 40px;
    color: #333333;
    font-size: 18px;
    text-align: center;
    margin-top: 10px;
    margin-left: 5px;
    margin-right: 5px;
}


.timeTableBtn:hover {
    background-color: darkorange;
}

#Room01targetDate {
    padding-top: 10px;
}

.button_login {
    margin: 0 auto;
    margin-bottom: 10px;
    padding: 0px;
    width: 100px;
    height: 40px;
    background-color: #f08080;
    border: 2px solid;
    border-color: #f08080;
    border-radius: 3px;
    font-size: 18px;
    font-weight: bold;
    text-align: center;
    color: white;
}

.button_clear {
    margin: 0 auto;
    padding: 0px;
    width: 60px;
    background-color: #FFFFFF;
    border: 1px solid;
    border-color: dodgerblue;
    border-radius: 3px;
    height: 25px;
    color: #333333;
    font-size: 18px;
    text-align: center;
}

.status_right {
    display: inline;
    margin-top: 5px;
    margin-bottom: 10px;
}

.room_remarks {
    font-size: 18px;
    margin-right: 1em;
}

.room_targetdate_info {
    clear: left;
    font-size: 18px;
    height: 30px;
    vertical-align: middle;
}

.room_targettime_info {
    display: inline;
    clear: left;
    font-size: 18px;
    margin-left: 1em;
    margin-bottom: 5px;
}

.room_targettime_info_t {
    display: inline;
    clear: left;
    font-size: 18px;
    margin-left: 0px;
    margin-bottom: 5px;
}

.room_name {
    font-size: 18px;
    font-weight: bold;
    margin-right: 1em;
}

.month-title {
    font-size: 30px;
    font-weight: bold;
    padding-left: 15px;
    padding-right: 15px;
    color: steelblue;
    font-family: Verdana, Geneva, Tahoma, sans-serif;
}

.month-move {
    padding-left: 10px;
    padding-right: 10px;
    font-weight: bold;
    color: darkblue;
    font-size: 30px;
    padding-left: 15px;
    padding-right: 15px;
    color: steelblue;
    font-family: Verdana, Geneva, Tahoma, sans-serif;
}

.month-move-btn-left {
    width: 0;
    height: 0;
    border-top: 12px solid transparent;
    border-right: 12px solid darkblue;
    border-bottom: 12px solid transparent;
}

.month-move-btn-right {
    width: 0;
    height: 0;
    border-top: 12px solid transparent;
    border-left: 12px solid darkblue;
    border-bottom: 12px solid transparent;
}

.targetDate {
    font-size: 18px;
    padding-left: 0.25em;
    padding-right: 0.25em;
}

.holidaymark {
    padding: 1px;
    font-size: 18px;
    border: solid;
    border-width: 1px;
    margin-left: 10px;
    border-color: blue;
    color: blue;
}

.holidaymark2 {
    padding: 2px;
    font-size: 18px;
    border: solid;
    border-width: 1px;
    margin-left: 10px;
    margin-bottom: 5px;
    border-color: red;
    color: red;
}

.kakomi-box {
    font-size: 20px;
    margin: 0 auto;
    margin-bottom: 10px;
    padding-right: 30px;
    padding: 1em;
    width: 880px;
    background-color: #f7f7f7; /* 背景色 */
    border: 1px solid; /* 枠線 */
    border-color: dodgerblue;
    text-align: left;
}

.kakomi-box-calendar {
    margin: 0 auto;
    padding: 1em;
    margin-bottom: 10px;
    width: 500px;
    background-color: none; /* 背景色 */
    border: none; /* 枠線 */
    font-family: Arial, Helvetica, sans-serif;
}

.waiting_area {
    margin: 0 auto;
    width: 500px;
    position: fixed;
    height: 0px;
}

.waiting_area2 {
    margin: 0 auto;
    width: 100%;
    height: 0px;
    position: absolute;
    z-index: 1;
    top: 664px;
    left: 1123px;
}

.kakomi-box-room {
    margin: 0 auto;
    margin-top: 10px;
    margin-bottom: 10px;
    padding-right: 10px;
    padding: 1em;
    width: 810px;
    font-size: 18px;
    background-color: #f7f7f7; /* 背景色 */
    border: 1px solid; /* 枠線 */
    border-color: darkgray;
    text-align: left;
}

.kakomi-box-room2 {
    margin: 0 auto;
    margin-top: 30px;
    margin-bottom: 10px;
    padding: 30px;
    width: 400px;
    font-size: 18px;
    background-color: #f7f7f7; /* 背景色 */
    border: 1px solid; /* 枠線 */
    border-color: darkgray;
    text-align: center;
}

.wide150{
    width:60%;
}
.kakomi-box-inside {
    margin: 0 auto;
    margin-top: 0px;
    margin-bottom: 0px;
    padding-right: 10px;
    width: 100%;
    font-size: 18px;
    background-color: #f7f7f7; /* 背景色 */
    border: 1px solid; /* 枠線 */
    border-color: darkgray;
    text-align: left;
}


.guidance {
    margin: 0 auto;
    margin-top: 10px;
    margin-bottom: 10px;
    padding: 10px;
    width: 300px;
    font-size: 18px;
    background-color: ivory; /* 背景色 */
    border: 1px solid; /* 枠線 */
    border-color: dodgerblue;
    text-align: center;
}


.room_img {
    float: left;
    margin-right: 10px;
    margin-bottom: 5px;
    width: 150px;
    height: 100px;
}

.ResTbl {
    display: block;
    clear: left;
}

.for_pc {
    display: block;
    clear: left;
}

.for_mobile {
    display: none;
}

/*---------------login---------------*/

.kakomi-box-login {
    border-radius: 3px;
    font-size: 18px;
    padding: 1em;
    margin: 0 auto;
    margin-top: 15px;
    max-width: 400px;
    color: #666; /* 文字色 */
    background-color: azure; /* 背景色 */
    border: 1px solid; /* 枠線 */
    border-color: dodgerblue;
    border-radius: 2px;
    text-align: center;
}

.text_00 {
    margin: 0 auto;
    width: 80%;
    border-radius: 3px;
    border: 1px solid dodgerblue;
    color: #333;
    font-size: 18px;
    padding: 10px;
}
.text_100p {
    margin: 0 auto;
    width: 100%;
    border-radius: 3px;
    border: 1px solid dodgerblue;
    color: #333;
    font-size: 18px;
    padding: 10px;
}

.text_10 {
    margin: 0 auto;
    width: 60%;
    border-radius: 3px;
    border: 1px solid dodgerblue;
    color: #333;
    font-size: 18px;
    padding: 10px;
}

.text_string {
    margin: 0 auto;
    width: 150px;
    border-radius: 3px;
    border: 1px solid #1B73BA;
    border-color: dodgerblue;
    color: #333;
    font-size: 18px;
    padding: 10px;
    text-align: left;
}

.text_margin_05 {
    margin-left: 0.5em;
    margin-right: 0.5em;
}

.text_string_300 {
    margin: 0 auto;
    width: 300px;
    border-radius: 3px;
    border: 1px solid #1B73BA;
    border-color: dodgerblue;
    color: #333;
    font-size: 18px;
    padding: 10px;
    text-align: left;
}

.text_string_170 {
    margin: 0 auto;
    width: 170px;
    border-radius: 3px;
    border: 1px solid #1B73BA;
    border-color: dodgerblue;
    color: #333;
    font-size: 18px;
    padding: 10px;
    text-align: left;
}

.text_price {
    margin: 0 auto;
    margin-right: 0.5em;
    width: 150px;
    border-radius: 3px;
    border: 1px solid #1B73BA;
    border-color: dodgerblue;
    color: #333;
    font-size: 18px;
    padding: 10px;
    text-align: right;
}

.text_price_100 {
    margin: 0 auto;
    margin-right: 0.2em;
    width: 100px;
    border-radius: 3px;
    border: 1px solid #1B73BA;
    border-color: dodgerblue;
    color: #333;
    font-size: 18px;
    padding: 10px;
    text-align: right;
}

.text_price_80 {
    margin: 0 auto;
    margin-right: 0.5em;
    width: 80px;
    border-radius: 3px;
    border: 1px solid #1B73BA;
    border-color: dodgerblue;
    color: #333;
    font-size: 18px;
    padding: 10px;
    text-align: right;
}

.text_zip1 {
    margin: 0 auto;
    width: 100px;
    border-radius: 3px;
    border: 1px solid #1B73BA;
    border-color: dodgerblue;
    color: #333;
    font-size: 18px;
    padding: 10px;
}

.text_zip2 {
    margin: 0 auto;
    width: 120px;
    border-radius: 3px;
    border: 1px solid #1B73BA;
    border-color: dodgerblue;
    color: #333;
    font-size: 18px;
    padding: 10px;
}

.list_pref {
    margin: 0 auto;
    width: 120px;
    border-radius: 3px;
    border: 1px solid #1B73BA;
    border-color: dodgerblue;
    color: #333;
    font-size: 18px;
    padding: 10px;
}

.list_inds {
    margin: 0 auto;
    width: 350px;
    border-radius: 3px;
    border: 1px solid #1B73BA;
    border-color: dodgerblue;
    color: #333;
    font-size: 18px;
    padding: 10px;
}

.list_bank {
    margin: 0 auto;
    width: 300px;
    border-radius: 3px;
    border: 1px solid #1B73BA;
    border-color: dodgerblue;
    color: #333;
    font-size: 18px;
    padding: 10px;
}
.list_month {
    margin: 0 auto;
    width: 200px;
    border-radius: 3px;
    border: 1px solid #1B73BA;
    border-color: dodgerblue;
    color: #333;
    font-size: 18px;
    padding: 10px;
}

.list_year_c {
    margin: 0 auto;
    width: 100px;
    border-radius: 3px;
    border: 1px solid #1B73BA;
    border-color: dodgerblue;
    color: #333;
    font-size: 18px;
    padding: 5px;
    background-color: white;
    height: 50px;
}

.list_month_day {
    margin: 0 auto;
    width: 84px;
    border-radius: 3px;
    border: 1px solid #1B73BA;
    border-color: dodgerblue;
    color: #333;
    font-size: 18px;
    padding:0px;
    padding-top: 10px;
    padding-bottom: 10px;
    text-align:center;
}


.list_single_num {
    margin: 0 auto;
    width: 70px;
    border-radius: 3px;
    border: 1px solid #1B73BA;
    border-color: dodgerblue;
    color: #333;
    font-size: 18px;
    padding: 10px;
}


.login-header-a {
    border-left: 5px solid #4169e1;
    margin: 0 auto;
    margin-top: 15px;
    max-width: 810px;
    text-align: left;
    font-size: 18px;
    padding-bottom: 5px;
    border-bottom: 1px solid #4169e1;
}

    .login-header-a span {
        color: black;
        padding-left: 10px;
    }

.login-header-b {
    font-size: 18px;
    text-align: center;
}

.btn_style_help {
    padding-left: 8px;
    padding-right: 8px;
    padding-top: 1px;
    padding-bottom: 1px;
    background-color: dodgerblue;
    border: 1px solid;
    color: white;
    text-align: center;
    cursor: pointer;
    border-radius: 5px;
    border-color: dodgerblue;
    margin-left: 0.5em;
    margin-bottom: 2px;
}

.btn_style_ex {
    padding: 0;
    background-color: #FFFFFF;
    border: none;
    color: #428bca;
    font-size: 18px;
    text-align: center;
    cursor: pointer;
    margin-top: 5px;
}

.btn_style_ex2 {
    border: 1px solid;
    border-color: darkgray;
    border-radius: 3px;
    padding: 0;
    padding-left: 10px;
    padding-right: 10px;
    background-color: lightgray;
    color: black;
    font-size: 18px;
    text-align: center;
    cursor: pointer;
}

.btn_style_01 {
    margin: 0 auto;
    width: 180px;
    background-color: #FFFFFF;
    border: 1px solid;
    border-color: darkgray;
    border-radius: 3px;
    height: 50px;
    color: #333333;
    font-size: 18px;
    text-align: center;
    text-decoration: none;
    cursor: pointer;
    margin-top: 5px;
}

.searchbtn_style {
    margin: 0 auto;
    width: 280px;
    background-color: #FFFFFF;
    border: 1px solid;
    border-color: dodgerblue;
    border-radius: 3px;
    height: 50px;
    color: #333333;
    font-size: 18px;
    text-align: center;
    text-decoration: none;
    cursor: pointer;
    margin-top: 5px;
    margin-left: 5px;
}

.btn_style_zip {
    margin-left:10px;
    width: 150px;
    background-color: #FFFFFF;
    border: 1px solid;
    border-color: dodgerblue;
    border-radius: 3px;
    height: 50px;
    color: #333333;
    font-size: 18px;
    text-align: center;
    text-decoration: none;
    cursor: pointer;
}


.btn_style_04 {
    margin: 0 auto;
    width: 100%;
    background-color: #FFFFFF;
    border: 1px solid;
    border-color: dodgerblue;
    border-radius: 3px;
    min-height:50px;
    color: dodgerblue;
    font-size: 18px;
    text-align: center;
    text-decoration: none;
    cursor: pointer;
    margin-top: 5px;
}
.btn_style_05 {
    margin: 0 auto;
    width: 60px;
    background-color: #FFFFFF;
    border: 1px solid;
    border-color: dodgerblue;
    border-radius: 3px;
    height: 50px;
    color: dodgerblue;
    font-size: 18px;
    text-align: center;
    text-decoration: none;
    cursor: pointer;
    margin-top: 5px;
}
.btn_style_06 {
    margin: 0 auto;
    width: 100px;
    background-color: #FFFFFF;
    border: 1px solid;
    border-color: dodgerblue;
    border-radius: 3px;
    height: 50px;
    color: dodgerblue;
    font-size: 18px;
    text-align: center;
    text-decoration: none;
    cursor: pointer;
    margin-top: 5px;
}

.btn_style_07 {
    margin: 0 auto;
    width: 120px;
    background-color: #FFFFFF;
    border: 1px solid;
    border-color: orangered;
    border-radius: 3px;
    height: 40px;
    color: orangered;
    font-size: 18px;
    text-align: center;
    text-decoration: none;
    cursor: pointer;
}


.btn_style_incomplete {
    margin: 0 auto;
    width: 100%;
    background-color: #FFFFFF;
    border: 1px solid;
    border-color: red;
    border-radius: 3px;
    height: 50px;
    color: red;
    font-size: 18px;
    text-align: center;
    text-decoration: none;
    cursor: pointer;
    margin-top: 5px;
}


    .btn_style_04:hover {
        background-color: rgba(30, 144, 255, 0.1); /* dodgerblue の透明色 */
        color: dodgerblue;
        border-color: dodgerblue;
    }

    .label_btn_style_01 {
        height: 50px;
        display: inline-block;
        padding: 10px 15px;
        background-color: #fff;
        cursor: pointer;
        border-radius: 3px;
        border: 1px solid;
        border-color: darkgray;
        color: #333333;
        font-weight: 400;
        transition: 0.3s;
    }

    .label_btn_style_01::after {
        content: 'ファイル選択';
    }

.label_btn_style_02 {
    height: 50px;
    display: inline-block;
    padding: 10px 15px;
    background-color: #fff;
    cursor: pointer;
    border-radius: 3px;
    border: 1px solid;
    border-color: darkgray;
    color: #333333;
    font-weight: 400;
    transition: 0.3s;
    margin-left: 2em;
}

    .label_btn_style_02::after {
        content: 'ファイル選択';
    }

.btn_style_02 {
    margin: 10px;
    width: 280px;
    background-color: #FFFFFF;
    border: 1px solid;
    border-color: dodgerblue;
    border-radius: 3px;
    height: 40px;
    color: #333333;
    font-size: 18px;
    text-align: center;
    text-decoration: none;
    cursor: pointer;
    display: inline
}

.btn_style_03 {
    width: 180px;
    background-color: gold;
    border: 1px solid;
    border-color: darkorange;
    border-radius: 3px;
    height: 50px;
    color: #333333;
    font-size: 18px;
    font-weight: 700;
    text-align: center;
    text-decoration: none;
    cursor: pointer;
    margin-top: 5px;
}

.btn_style_preview {
    width: 100px;
    background-color: #FFFFFF;
    border: 1px solid;
    border-color: darkgray;
    border-radius: 3px;
    height: 50px;
    color: #333333;
    font-size: 18px;
    text-align: center;
    text-decoration: none;
    cursor: pointer;
    margin-top: 5px;
}

.details-line {
    margin-left: 0.5em;
    margin-right: 0.5em;
}

.error-alert {
    margin: 0 auto;
    padding: 4px;
    color: #990000;
    background: #FFEBE8;
    border: 1px solid #990000;
    border-radius: 2px;
}

.info-disp {
    margin: 0 auto;
    padding: 4px;
    padding-left: 7px;
    color: blue;
    background-color: azure;
    border: 1px solid blue;
    border-radius: 2px;
}


.info-area {
    margin: 0 auto;
    padding: 10px;
    color: dodgerblue;
    font-weight: bold;
}

.error-alert-panel {
    margin: 0 auto;
    padding-bottom: 10px;
    padding-top: 10px;
}


.contents-title {
    text-align: left;
    font-size: 18px;
    margin-top: 5px;
    margin-bottom: 5px;
}

.contents-title2 {
    text-align: left;
    font-size: 18px;
    margin-top: 5px;
    margin-bottom: 5px;
    display: inline-block;
}


.contents-title-bold {
    padding-top:1.5em;
    text-align: left;
    font-size: 18px;
    font-weight: 700;
}
.contents-title-bold2 {
    text-align: left;
    font-size: 18px;
    font-weight: 700;
}

.help-title-bold {
    font-size: 18px;
    font-weight: 700;
}

.contents-coments {
    text-align: left;
    font-size: 18px;
    margin-left: 2em;
}

.contents-title-center {
    padding-top: 20px;
    margin: 0 auto;
    width: 80%;
    font-size: 18px;
}

.label-comp {
    margin-left: 5px;
    border-color: dodgerblue;
    border-radius: 5px;
    color: white;
    padding-left: 10px;
    padding-right: 10px;
    padding-bottom: 3px;
    background-color: dodgerblue;
    text-align: center;
}
.label-incomp {
    margin-left:5px;
    border-color: red;
    border-radius: 5px;
    color: white;
    padding-left: 10px;
    padding-right: 10px;
    padding-bottom: 3px;
    background-color: red;
    text-align: center;
}
/*---------------webEntry---------------*/
.kakomi-box-entry {
    border-radius: 3px;
    font-size: 18px;
    padding: 1em;
    margin: 0 auto;
    max-width: 810px;
    border: 2px solid #ccc; /* 枠線 */
    border-color: dodgerblue;
    text-align: left;
    font-weight: bold;
    display: block;
    position: relative;
}

.kakomi-box-error {
    color: #990000;
    background: #FFEBE8;
    border-radius: 3px;
    font-size: 18px;
    padding: 1em;
    margin: 0 auto;
    max-width: 810px;
    border: 2px solid #ccc; /* 枠線 */
    border-color: #990000;
    text-align: left;
    font-weight: bold;
    display: block;
}

.reservation_info {
    display: block;
}


.kakomi-box-entry2 {
    font-size: 18px;
    padding: 1em;
    margin: 0 auto;
    max-width: 450px;
    text-align: center;
}

.kakomi-box-check {
    margin: 0 auto;
    margin-top: 10px;
    border: 2px solid dodgerblue; /* 枠線 */
    border-radius: 3px;
    font-size: 18px;
    padding: 1em;
    max-width: 810px;
    text-align: center;
    position: relative;
}

.entry-header {
    margin: 0 auto;
    padding: 10px;
    max-width: 810px;
    font-size: 18px;
    text-align: right;
}

.msr_text_02 {
    padding-bottom: 20px;
    border-radius: 3px;
    width: 100%;
    border: 1px solid #1B73BA;
    box-sizing: border-box;
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    color: #333;
    font-size: 18px;
    padding: 10px;
    height: 30px;
}

.input_table {
    box-sizing: border-box;
    border-collapse: collapse;
    margin: 0 auto;
    width: 810px;
}

    .input_table th {
        border: 1px solid dodgerblue;
        padding: .5em 1em;
        width: 30%;
    }

    .input_table td {
        border: 1px solid dodgerblue;
        padding: .5em 1em;
        text-align: left;
    }

.input_table2 {
    border: none;
}

    .input_table2 td {
        border: none;
        padding: 0px;
        width: 70px;
    }

.input_table th {
    text-align: left;
    background: azure;
    font-size: 18px;
    font-weight: 400;
}

.input_table span {
    padding-right: 20px
}

    .input_table span#ChargeTotal, #TaxLabel1, #TaxLabel2, #TaxLabel3, #Tax, #TaxRate {
        padding-right: 5px
    }

.input_table .error-alert {
    display: block;
    margin-top: 5px;
}


.cancel_table {
    box-sizing: border-box;
    border-collapse: collapse;
    margin: 10px auto;
    width: 810px;
}

    .cancel_table th {
        border: 1px solid #ff5e00;
        padding: .5em 1em;
        width: 30%;
    }

    .cancel_table td {
        border: 1px solid #ff5e00;
        padding: .5em 1em;
        text-align: left;
    }


    .cancel_table th {
        text-align: left;
        background: #ffab74;
        font-size: 18px;
        font-weight: 400;
    }

    .cancel_table span {
        padding-right: 20px
    }

        .cancel_table span#cancelcharge {
            padding-right: 5px
        }

    .cancel_table .error-alert {
        display: block;
        margin-top: 5px;
    }

#RentalToolsList tbody tr td {
    border: none;
    text-align: left;
    padding-top: 0px;
    padding-bottom: 2px;
}

#RentalToolsList label {
    font-weight: normal;
}

#RentalToolsList2 li {
    list-style: none;
}

.input_table ul {
    padding: 0px;
}


#UserDivision tbody tr td {
    border: none;
    text-align: left;
    padding-top: 0px;
    padding-bottom: 2px;
}

#UserDivision tbody td {
    width: 50px;
    padding: 0px;
    margin: 0px;
}


#UserDivision label {
    font-weight: normal;
}


.input_cell_contents {
    border: none;
}

.remarks-text {
    height: 80px;
    border-radius: 3px;
    width: 100%;
    border: 1px solid #1B73BA;
    box-sizing: border-box;
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    color: #333;
    font-size: 18px;
    padding: 10px;
}

.must {
    background: red;
    color: #FFF;
    border-radius: 3px;
    font-size: 18px;
    margin-right: 10px;
    padding: 5px 10px;
    letter-spacing: 0.2em;
}

span.must {
    padding-left: 5px;
    padding-right: 5px;
}

.oparation-flow {
    text-align: center;
    padding-top: 10px;
    margin-top: 10px;
    margin-bottom: 10px;
}

.oparation-flow-block1 {
    background-color: darkorange;
    color: white;
    padding: 10px;
    display: inline;
    margin-right: 10px;
    position: relative;
    display: inline-block;
    width: 120px;
}

    .oparation-flow-block1:after {
        border-left: 20px solid darkorange; /* 右向きの三角形を作るため左のボーダーに色を付ける */
        border-top: 20px solid transparent; /* 上のボーダーを透過に指定 */
        border-bottom: 20px solid transparent; /* 下のボーダーを透過に指定 */
        content: "";
        position: absolute;
        left: 50%; /* 一旦中央へ寄せる */
        top: 0;
        margin-left: 50px; /* 四角形の幅の半分右へ移動する */
    }

.oparation-flow-block2 {
    background-color: lightgray;
    padding: 10px;
    display: inline;
    margin-right: 10px;
    margin-bottom: 10px;
    position: relative;
    display: inline-block;
    width: 120px;
}

    .oparation-flow-block2:after {
        border-left: 20px solid lightgray; /* 右向きの三角形を作るため左のボーダーに色を付ける */
        border-top: 20px solid transparent; /* 上のボーダーを透過に指定 */
        border-bottom: 20px solid transparent; /* 下のボーダーを透過に指定 */
        content: "";
        position: absolute;
        left: 50%; /* 一旦中央へ寄せる */
        top: 0;
        margin-left: 50px; /* 四角形の幅の半分右へ移動する */
    }

.oparation-flow-block3-1 {
    background-color: lightgray;
    padding: 10px;
    display: inline;
    margin-right: 10px;
    position: relative;
    display: inline-block;
    width: 120px;
}

.oparation-flow-block3-2 {
    background-color: darkorange;
    color: white;
    padding: 10px;
    display: inline;
    margin-right: 10px;
    position: relative;
    display: inline-block;
    width: 120px;
}

summary {
    display: list-item;
    font-weight: 700;
    cursor: pointer;
}

.link-style-btn {
    cursor: pointer;
    border: none;
    background: none;
    color: #0033cc;
    text-align: left;
    text-decoration: underline;
}

button.link-style-btn {
    cursor: pointer;
    border: none;
    background: none;
    color: #0033cc;
    text-align: left;
    text-decoration: underline;
}

.bank-area{
    text-align:center;
}

.navbar-inverse {
    background-color: dodgerblue;
}
    .navbar-inverse .navbar-brand {
        color: white;
    }

@media (max-width: 600px) {
    .btn_style_zip {
        margin-left: 0px;
        margin-top: 5px;
    }

    .wide150 {
        width: 110px;
    }


    .list_inds {
        width: 270px;
        background-color:white;
        height:55px;
    }

    .label_btn_style_01::after {
        content: '選択';
    }

    .label_btn_style_02::after {
        content: '選択';
    }

    .link-contents-title2 {
        width: 70%;
    }

    .link-contents-title3 {
        width: 55%;
    }

    .navbar-brand {
        font-size: 20px;
    }

    .text_00 {
        width: 100%;
    }

    .text_10 {
        width: 100%;
    }

    .text_string_300 {
        width: 100%;
    }

    .basetable {
        width: 100%;
    }

    .frametable {
        width: 100%;
    }

    .left-side2 {
        width: 100%;
    }

    .left-side {
        clear: both;
        text-align: left
    }

    .right-side {
        width: 100%;
    }

    .navi-a-bottom-left-1 {
        padding-left: 16px;
        font-size: 18px;
    }

    .navi-a-bottom-left-2 {
        padding-left: 16px;
        font-size: 18px;
    }

    .navi-a-bottom-right {
        font-size: 12px;
        padding: 0px;
        padding-right: 10px;
    }

    .waiting_area {
        position: fixed;
        margin: 0 auto;
        width: 70%;
        text-align: center;
        height: 0px;
        top: 103px;
    }

    .date-lnk {
        font-size: 18px;
    }

    .date-selected-lnk {
        font-size: 18px;
    }

    .month-title {
        font-size: 20px;
        font-weight: bold;
        padding-left: 5px;
        padding-right: 5px;
    }

    .month-move-btn-left {
        border-top: 8px solid transparent;
        border-right: 8px solid darkblue;
        border-bottom: 8px solid transparent;
    }

    .month-move-btn-right {
        border-top: 8px solid transparent;
        border-left: 8px solid darkblue;
        border-bottom: 8px solid transparent;
    }

    .kakomi-box-room {
        width: 90%;
    }

    .kakomi-box-room2 {
        width: 90%;
    }

    .kakomi-box-login {
        width: 90%;
    }

    .kakomi-box-calendar {
        width: 90%;
    }

    .kakomi-box-check {
        width: 90%;
    }

    .room_targetdate_info {
        height: 50px;
    }

    .room_targettime_info {
        margin-left: 0;
    }

    .button_clear {
        width: 40px;
        font-size: 11px;
    }

    .for_pc {
        display: none;
    }

    .for_mobile {
        display: block;
        clear: left;
    }

    .ResTbl {
        display: none;
    }

    .room_img {
        clear: left;
    }

    .login-header-a {
        margin-top: 40px;
        width: 90%;
    }

    .input_table {
        box-sizing: border-box;
        border-collapse: collapse;
        margin: 0 auto;
        width: 90%;
    }

        .input_table th,
        .input_table td {
            display: block;
            border: 1px solid dodgerblue;
            padding: .5em 1em;
        }

        .input_table th,
        .input_table td {
            border-top: none;
        }

        .input_table th {
            text-align: left;
            background: azure;
            font-size: 14px;
            font-weight: 400;
            width: 100%;
        }

    .cancel_table {
        box-sizing: border-box;
        border-collapse: collapse;
        margin: 10px auto;
        width: 90%;
    }

        .cancel_table th,
        .cancel_table td {
            display: block;
            border: 1px solid #ff5e00;
            padding: .5em 1em;
        }

        .cancel_table th,
        .cancel_table td {
            border-top: none;
        }

        .cancel_table th {
            text-align: left;
            background: #ffab74;
            font-size: 14px;
            font-weight: 400;
            width: 100%;
        }

    .input_table2 {
        border: none;
    }

        .input_table2 td {
            border: none;
            padding: 0px;
            width: 70px;
        }



    table tr:first-child th {
        border-top: 1px solid dodgerblue;
    }

    .oparation-flow-block1 {
        padding: 12px;
        padding-left: 7px;
        padding-right: 7px;
        font-size: 12px;
        width: 90px;
    }

        .oparation-flow-block1:after {
            margin-left: 35px; /* 四角形の幅の半分右へ移動する */
        }

    .oparation-flow-block2 {
        padding: 12px;
        padding-left: 7px;
        padding-right: 7px;
        font-size: 12px;
        width: 90px;
    }

        .oparation-flow-block2:after {
            margin-left: 35px; /* 四角形の幅の半分右へ移動する */
        }

    .oparation-flow-block3-1 {
        padding: 12px;
        padding-left: 7px;
        padding-right: 7px;
        font-size: 12px;
        width: 90px;
    }

    .oparation-flow-block3-2 {
        padding: 12px;
        padding-left: 7px;
        padding-right: 7px;
        font-size: 12px;
        width: 90px;
    }

    .kakomi-box-entry {
        width: 90%;
    }

    .btn_style_01 {
        width: 80%;
    }

    .searchbtn_style {
        margin: 0;
        margin-top: 5px;
    }


    .btn_style_02 {
        width: 230px;
    }

    .list_bank {
        width: 270px;
    }
}



.modal-mask {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,.45);
    z-index: 1000;
}

.modal-panel {
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%,-50%);
    background: #fff;
    border-radius: 8px;
    padding: 16px;
    z-index: 1001;
}

@media (max-width: 800px) {
    .navbar-brand {
        font-size: 14px;
        padding-left:5px
    }
    .kakomi-box-room {
        width: 95%;
    }

    .kakomi-box-room2 {
        width: 95%;
    }

    .login-header-a {
        width: 95%;
    }

    .label_btn_style_01 {
        padding: 10px 10px;
    }
}

@media (max-width: 600px) {
    /* ファイル名（a / button）があるときだけ発火 */
    .kakomi-box-inside:has(a.file-link, button.file-link-button) {
        display: grid;
        grid-template-columns: auto 1fr auto; /* 🗑 | 金額 | 添付 */
        grid-template-rows: auto auto; /* 1行目 / 2行目 */
        column-gap: 8px;
        row-gap: 8px;
        align-items: center;
    }

        /* 中間の箱を透過して子を親グリッドに直接配置 */
        .kakomi-box-inside:has(a.file-link, button.file-link-button) .file-display-box {
            display: contents !important;
            width: 100% !important;
        }

        /* 1行目：🗑＋金額＋円 */
        .kakomi-box-inside:has(a.file-link, button.file-link-button) .delete-button {
            grid-column: 1;
            grid-row: 1;
            margin: 0;
        }

        .kakomi-box-inside:has(a.file-link, button.file-link-button) .file-display-box > div:first-child {
            grid-column: 2;
            grid-row: 1;
            display: flex;
            align-items: center;
            gap: 6px;
        }

        .kakomi-box-inside:has(a.file-link, button.file-link-button) .text_price_100 {
            width: 8em !important; /* 入力幅を小さめに */
            max-width: none;
        }

        /* 2行目：ファイル名（左）＋ 添付（右） */
        .kakomi-box-inside:has(a.file-link, button.file-link-button) a.file-link,
        .kakomi-box-inside:has(a.file-link, button.file-link-button) button.file-link-button {
            grid-column: 1 / 3;
            grid-row: 2; /* 左側（🗑～金額の領域）に収める */
            min-width: 0;
            white-space: nowrap;
            overflow: hidden;
            text-overflow: ellipsis;
        }
        /* 添付ボタンの“親”を右端セルへ */
        .kakomi-box-inside:has(a.file-link, button.file-link-button) .file-display-box > .ms-2.d-inline-flex.align-items-center {
            grid-column: 3;
            grid-row: 2;
            justify-self: end;
            margin-left: 0 !important;
        }
}


.p_str_bold{
    margin:0;
    font-weight:bold;
}
.p_str {
    margin: 0;
}
mark {
    background-color: orange;
}
/* ---- スマホ時：ファイル名がある時だけ3行化 ---- */
/*@media (max-width: 600px) {*/

    /* 3行化のトリガー：.file-link / .file-link-button を含む場合のみ */
    /*.kakomi-box-inside:has(.file-link, .file-link-button) {
        display: flex;
        flex-direction: column;
        gap: 8px;
    }

        .kakomi-box-inside:has(.file-link, .file-link-button) .delete-button {
            display: block;
            align-self: flex-start;
            margin: 0;
        }

        .kakomi-box-inside:has(.file-link, .file-link-button) .file-display-box {
            display: flex;
            flex-wrap: wrap;
            gap: 8px;
            width: 100%;
        }

            .kakomi-box-inside:has(.file-link, .file-link-button) .file-display-box > div:first-child {
                flex: 0 0 100%;
                display: flex;
                align-items: center;
                gap: 6px;
            }

        .kakomi-box-inside:has(.file-link, .file-link-button) .text_price_100 {
            width: 100% !important;
            max-width: none;
        }

        .kakomi-box-inside:has(.file-link, .file-link-button) .file-link,
        .kakomi-box-inside:has(.file-link, .file-link-button) .file-link-button {
            flex: 1 1 auto;
            min-width: 0;
            white-space: nowrap;
            overflow: hidden;
            text-overflow: ellipsis;
        }

        .kakomi-box-inside:has(.file-link, .file-link-button) .custom-upload-button {
            margin-left: auto;
        }
}*/

