html {
    position: relative;
    min-height: 100%;
}
header {
}
main {
}
footer,
.footer-container {
    /*min-height: 50px;*/
}
.footer-container {
    padding: 0;
}
.back-to-top {
    position: fixed;
    right: 5px;
    z-index:999999;
    /*bottom: 5px;*/
    /*border: 1px solid;*/
}
.form-group:last-child {
    margin-bottom:0;
}
.navbar-dark .navbar-toggler {
    color: rgba(255, 255, 255, 0.5);
    border-color: rgba(255, 255, 255, 0.5);
}
.tm-navbar .tm-user .dropdown-menu {
    right:0;
    left:auto;
}
.tm-nav-button {
	padding-bottom: 0;
    padding-left: 0;
    padding-top: 0;
}
.tm-nav-links .tm-nav-links-all {
    display:none;
}
.fullscreen {
    display: block;
    z-index: 9999;
    position: fixed;
    width: 100%;
    height: 100%;
    top: 0;
    right: 0;
    left: 0;
    bottom: 0;
    overflow: auto;
}
.bootstrap-select>.dropdown-toggle.bs-placeholder,
.bootstrap-select>.dropdown-toggle.bs-placeholder:active,
.bootstrap-select>.dropdown-toggle.bs-placeholder:focus,
.bootstrap-select>.dropdown-toggle.bs-placeholder:hover {
    color: inherit;
    background-color: #fff;
    border-color: #ced4da;
}
.tm-user {
    margin: auto;
}
.tm-user-menu {
    position: relative;
}
.tm-user-menu:hover {
    border: none;
    outline: none;
    text-decoration: none;
}
.tm-user-avatar {
    margin-right:8px;
}
.tm-user-menu .tm_msg_count {
    position: absolute;
    top:-8px;
    left:22px;
    font-size:0.55rem;
}
.tm-user-menu .tm_mypage_msg_count {
    position: absolute;
    top:-6px;
    right:-8px;
}
.tm-page-title {
    border-bottom: 1px solid;
    padding-top: 0.5rem;
    padding-bottom: 0.5rem;
}
.tm-table {
    width:100%;
}
hr.solid {
    border-top-width: 1px;
    border-top-style: solid;
}
hr.double {
    border-top-width: 3px;
    border-top-style: double;
}
hr.dashed {
    border-top-width: 1px;
    border-top-style: dashed;
}
hr.dotted {
    border-top-width: 1px;
    border-top-style: dotted;
}
table.dataTable thead th {
    border:none;
}
table.dataTable .btn {
    /*font-size:0.8rem;*/
    padding-top:.4rem;
    padding-bottom:.4rem;
}
table.dataTable.dtr-inline.collapsed>tbody>tr>td.dtr-control,
table.dataTable.dtr-inline.collapsed>tbody>tr>th.dtr-control {
    padding-left: 40px;
}
table.dataTable.dtr-inline.collapsed.table-sm>tbody>tr>td:first-child:before,
table.dataTable.dtr-inline.collapsed.table-sm>tbody>tr>th:first-child:before {
    top:30%;
    padding:5px;
    left: 1px;
}
div.table-responsive>div.dataTables_wrapper>div.row>div[class^="col-"]:first-child {
    padding-right: 0;
}
div.dataTables_wrapper div.dataTables_info {
    text-align: left;
}
div.dataTables_wrapper div.dataTables_paginate {
    text-align: right;
}
div.dataTables_wrapper div.dataTables_filter label input {
    max-width:140px;
}
table.dataTable tbody td {
    vertical-align: middle;
}
div.dataTables_wrapper>div.row {
    margin: 0;
}
div.dataTables_wrapper>div.row>div[class^="col-"]:first-child {
    padding-right: 0;
}
div.dataTables_wrapper>div.row>div[class^="col-"]:first-child {
    padding-left: 0;
}
table.dataTable tbody tr.selected a,
table.dataTable tbody th.selected a,
table.dataTable tbody td.selected a {
    color: inherit;
}
.tags-input-group {
    position: relative;
    flex: 1 1 auto;
    width: 1%;
    min-width: 0;
    margin-bottom: 0;
}
.tagify {
    line-height: inherit !important;
}
.tagify .tagify__tag__removeBtn {
    color:#fff !important;
    font: 20px/1 Arial !important;
    margin-right: 6px !important;
    margin-left: -2px !important;
    width: 20px !important;
    height: 20px !important;
}
.tagify__input{
    display: none !important;
}
@media screen and (max-width: 1199px) {
    /*
    #store-select {
        max-width:200px;
    }
    */
}
@media screen and (max-width: 991px) {
    .modal {
        padding-left:0 !important;
        padding-right:0 !important;
    }
    .modal-fluid {
        max-width: inherit;
        width: 96%;
        /*margin-left: 15px;*/
    }
    /*
    #store-select {
        max-width:150px;
    }
    */
}
@media screen and (max-width: 767px) {
    .tm-nav-title {
        max-width: 100px;
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
    }
    /*
    #store-select {
        max-width:130px;
    }
    */
    div.dataTables_wrapper div.dataTables_length {
        text-align: left;
    }
    div.dataTables_wrapper div.dataTables_filter {
        text-align: right;
    }
    .tm-user-menu-name {
        display:none;
    }
}
@media screen and (max-width: 575px) {
    .tm-nav-title {
        display: none;
    }
    .tm-nav-links a {
        display: none;
    }
    .tm-nav-links .tm-nav-links-all {
        display: inline-block;
    }
    .tm-page-title {
        font-size:1.25rem;
    }
    div.dataTables_wrapper div.dataTables_info {
        text-align: center;
    }
    div.dataTables_wrapper div.dataTables_paginate {
        text-align: center;
    }
    .tm-page-mypage footer .btn-group .btn-format1 span {
        max-width:80px;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
    }
}
@media (min-width: 576px) {
    .modal-dialog {
        margin-top: 0.75rem;
    }
}
/* [Summarnote] Embed size of youtube video
.note-video-clip {
    width: 320px;
    height: 180px;
}
*/
.note-toolbar .dropdown-toggle::after {
    display:none;
}
.note-editor .note-toolbar .note-color-all .note-dropdown-menu,
.note-popover .popover-content .note-color-all .note-dropdown-menu {
    min-width: 350px;
}
.note-editor .note-toolbar .note-para .note-dropdown-menu,
.note-popover .popover-content .note-para .note-dropdown-menu {
    min-width: 260px;
}
/* WYSIWIGエディタ */
img, .note-video-clip {
    max-width:100%;
}
/* 時刻 */
.event-time {
    font-size: 28px;
    line-height: 1;
    font-weight: 400;
}
/* ID, 公開, 状態, 残り */
.event-id, .event-publish, .event-status, .event-remaining {
    font-size: 20px;
    line-height: 1;
    font-weight: 400;
}
/* 残りの測定時間 */
.event-remaining-time {
    font-size: 1rem;
    line-height: 0.8;
    font-weight: 400;
}
/* マイページボタン */
.tm-mypage-entry-buttons {
    font-size: 0.9rem;
    position: absolute;
    top: 5px;
    right: 5px;
}
#category-select {
    max-width: 160px;
}
/* タイムテーブル */
.timeline {
    border-left: 3px solid #007bff;
    border-bottom-right-radius: 4px;
    border-top-right-radius: 4px;
    background: rgba(0, 123, 255, 0.09);
    margin: 0 0 0 auto;
    position: relative;
    padding: 30px 30px 10px 50px;
    list-style: none;
    text-align: left;
    max-width: 75%;
}
@media (max-width: 767px) {
    .timeline {
        max-width: 98%;
        padding: 25px;
    }
}
.timeline .event-tt-event {
    border-bottom: 1px dashed #000;
    padding-bottom: 10px;
    margin-bottom: 25px;
    position: relative;
}
@media (max-width: 767px) {
    .timeline .event-tt-event {
        padding-top: 30px;
    }
}
.timeline .event-tt-event:last-of-type {
    padding-bottom: 0;
    margin-bottom: 0;
    border: none;
}
.timeline .event-tt-event:before,
.timeline .event-tt-event:after {
    position: absolute;
    display: block;
    top: 0;
}
.timeline .event-tt-event:before {
    top: -5px;
    left: -200px;
    content: attr(data-date);
    text-align: right;
    font-weight: 400;
    font-size: 1.25em;
    min-width: 120px;
}
@media (max-width: 767px) {
    .timeline .event-tt-event:before {
        left: 0px;
        text-align: left;
    }
}
.timeline .event-tt-event:after {
    -webkit-box-shadow: 0 0 0 3px #007bff;
    box-shadow: 0 0 0 3px #007bff;
    left: -55.8px;
    background: #fff;
    border-radius: 50%;
    height: 9px;
    width: 9px;
    content: "";
    top: 5px;
}
@media (max-width: 767px) {
    .timeline .event-tt-event:after {
        left: -31.8px;
    }
}
/* 日付 */
.event-date {
    width: 100%;
    padding: 8px 6px;
    background:#007bff;
    color: #fff;
    border-radius: 1px;
    border: 1px dashed #fff;
    box-shadow: 0 0 0 4px #007bff;
    text-align: center;
    line-height: 1;
}
.event-date-hyphen {
    display: none;
}
.event-date-year {
    display: block;
    font-size: 18px;
    border-bottom: 1px dashed;
    padding-bottom: 8px;
}
.event-date-month, .event-date-day {
    display: inline-block;
    font-size: 32px;
}
.event-date-month::after {
    content: "/";
}

.note-editor button:has(.note-icon-align-justify),
.note-editor .note-list {
    display:none;
}
.note-editor .note-toolbar .note-para .note-dropdown-menu {
    min-width: 130px;
}
.tm-icon-block {
    width:20px;
    vertical-align:top;
}
.card-title-icon {
    width:26px;
    vertical-align:top;
}
.tm-calendar-event-icon {
    width:20px;
    vertical-align:top;
}
.tm-recent-event-icon {
    width:22px;
    vertical-align:top;
}
.tm-event-icon {
    width:24px;
    vertical-align:top;
}