html,
body {
    height: 100%;
}
/*
th, td {
    white-space: nowrap;
}
*/
#app {
    min-height: 100vh;
    position: relative;
    padding-bottom: 30px;
    box-sizing: border-box;
}

#footer {
    height: 30px;
    width: 100%;
    background-color: whitesmoke;
    position: absolute;
    bottom: 0;
}

.num_val {
    text-align:right;
}

.dtlRow > div {
    border: 1px solid gray;
}
.dtlValueCol {
    /*    font: medium "IPAゴシック";*/
    font-size: medium;
    background-color: #eff4ff;
    color: #4c4c4c;
    border: 1px solid #c0c0c0;
    height: 40px;
    vertical-align: middle;
    padding-top: 9px;
}

.dtlValueCol6 {
    /*    font: medium "IPAゴシック";*/
    font-size: medium;
    background-color: #d7efff;
    color: #4c4c4c;
    border: 1px solid #c0c0c0;
    height: 220px;
    vertical-align: text-top;
    padding-top: 9px;
}

.dtlTitleCol {
    /*    font: bold medium "IPAゴシック";*/
    font-size: medium;
    /*
    background-color: #ccd6ff;
    color: #8491c3;
*/

    background-color: #7a5eff;
    color: #ffffff;
    border: 1px solid #c0c0c0;
    height: 40px;
    vertical-align: middle;
    text-align: center;
    padding-top: 9px;
}

.dtlBlankCol {
    height: 40px;
}

.center{
    text-align: center;
}

.right{
    text-align: right;
}


/* 入力用 */
.dtlInputCol {
    font-size: medium;
    background-color: lightyellow;
    color: #4c4c4c;
    height: 40px;
    vertical-align: middle;
    padding-left: 5px;
    padding-right: 5px;
}
.dtlInputNumCol {
    font-size: medium;
    background-color: lightyellow;
    color: #4c4c4c;
    height: 40px;
    vertical-align: middle;
    text-align: right;
    padding-left: 5px;
    padding-right: 5px;
}

.dtlRyokincol {
    margin-bottom : 20px;
}
@media (min-width: 768px) {
    .dtlRyokincol {
        margin-bottom : 20px;
    }
}
@media (min-width: 992px) {
    .dtlRyokincol {
        margin-bottom : 0px;
    }
}
@media (min-width: 1200px) {
    .dtlRyokincol {
        margin-bottom : 0px;
    }
}

.entryLabel {
    padding: 7px;
    background: #ccd6ff;
    border-radius: 3px;
    box-shadow: 1px 1px 1px;
    font-size: 10pt;
    font-weight: bold;
    /*		color: #8491c3; */
    color: #4a488e;
    text-align: center;
    padding-right: 10px;
    text-shadow: 1px 1px 3px #fff;

}

.entryLabelMust {
    padding: 7px;
    background: #eebbcb;
    border-radius: 3px;
    box-shadow: 1px 1px 1px;
    font-size: 10pt;
    font-weight: bold;
    color: #d9333f;
    text-align: center;
    padding-right: 10px;
    text-shadow: 1px 1px 3px #fff;

}

.formTitle {
    /*
        margin-left: -15px;
    */
    border-left: 12px solid #ccd6ff;
    color: #4c4c4c;


    font-size: middle;
    padding: 15px;
    box-shadow: 0 5px 2px -2px #ccd6ff;
}

.block {
    padding: 5px;
    background: #eddbff;
    border: 1px #eddbff solid;
    box-shadow: 0 2px 3px 0 #ddd;
    -moz-box-shadow: 0 2px 3px 0 #ddd;
    -webkit-box-shadow: 0 2px 3px 0 #ddd;
    height: 35px;
    color: #bf7fff;
}

.customRequired {
    vertical-align: bottom;
    color: red;
}
