/** W3C **/
body {
    font-family: 'Lucida Grande', 'Hiragino Kaku Gothic ProN', Meiryo, 'ＭＳ Ｐゴシック', sans-serif;
    background-color: #fdfff6;
}
h2 {
    line-height: 1em;
    margin: 10px 0;
}
hr.blank {
    border: 0;
    overflow: hidden;
    margin: 40px 0 0;
}
form {
    margin-top: 40px;
}
form.noframe {
    margin-top: 0;
    margin-bottom: 2px;
}
table {
    font-size: 14px;
    background-color: #FFF;
}

/** Bootstrap **/
.btn:enabled:hover {
    cursor: pointer;
}
.navbar {
    border-radius: 0;
}
.navbar-header {
    float: left;
}
.navbar-nav {
    float: left;
    margin: 0;
}
.navbar-nav>li {
    float: left;
}
.navbar-nav>li>a {
    padding-top: 15px;
    padding-bottom: 15px;
}
.navbar-right {
    float: right !important;
    margin-right: -15px;
}
.flash {
    position: fixed;
    z-index: 1;
    width: 100%;
    margin: 8px auto;
}
.flash .alert {
    width: 100%;
    margin: 0px auto;
    opacity: 0.98;
    box-shadow: 2px 2px 8px #999;
}
.form-group h3 {
    border-bottom: 1px solid #eeeeee;
}
.form-control {
    border-color: #666;
}
.panel_noframe {
    overflow: hidden;
    box-shadow: none;
    margin: 0 0 4px 0;
    border: none;
    background-color: transparent;
}
.table-clickable tbody tr,
td.clickable {
    cursor: pointer;
}
.table-bordered th {
    background-color: #EEE;
}
.table-bordered th.bg-success {
    background-color: #dff0d8;
}
tr.text-center th,
tr.text-center td {
    text-align: center;
}
tr th.text-left,
tr td.text-left {
    text-align: left;
}
tr th.text-right,
tr td.text-right {
    text-align: right;
}
.table>thead>tr>th {
    vertical-align: middle;
}
.datepicker-dropdown {
    margin-top: 64px;
}
.pagination_frame .count {
    float: right;
    line-height: 40px;
}
.pagination {
    margin-top: 0;
    margin-bottom: 4px;
}
.container.full {
    width: 100%;
}
@media (min-width: 768px) {
.container.short {
    width: 768px;
}
}

/** Layout **/
#main {
    padding: 0 16px;
    margin-top: 60px;
}
.verticle_middle {
  display: flex;
  justify-content: center;
  align-items: center;
}
.box {
    border-radius: 4px;
    background-color: #FFF;
    border: 1px solid #CCC;
    padding: 24px;
    box-shadow: 0px 0px 8px #CCC;
}
.border_box {
    border-radius: 4px;
    background-color: #FFF;
    border: 1px solid #CCC;
    padding: 16px;
}
.slit {
    margin-right: 1rem;
}

/** Parts **/
#loading {
    display: none;
    position: fixed;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.2);
    top: 0;
}
#loading img {
    position: absolute;
    top: 50%;
    left: 50%;
    margin-left: -8px;
    margin-top: -8px;
}
