html {
    overflow-y: scroll;
}

body.login {
    height: 100vh;
    background-color: #DED6E0;
}
body.login.front {
    background: linear-gradient(to top, rgba(201, 230, 253, 0.7) 0%, rgba(151, 217, 225, 0.1) 100%), url('../img/bg_front.jpg'); 
    background-size: cover;
}
body.login.admin {
    background: linear-gradient(to top, rgba(201, 230, 253, 0.7) 0%, rgba(151, 217, 225, 0.1) 100%), url('../img/bg_admin.jpg'); 
    background-size: cover;
}
body.login.family {
    background: linear-gradient(to top, rgba(201, 230, 253, 0.2) 0%, rgba(151, 217, 225, 0.1) 100%), url('../img/bg_family.jpg'); 
    background-size: cover;
}
.bg-white {
    background-color: #fff !important;
}

.mt10 { margin-top: 10px; }
.mt15 { margin-top: 15px; }
.mt30 { margin-top: 30px; }
.mt50 { margin-top: 50px; }
.mt100 { margin-top: 100px; }
.mt120 { margin-top: 120px; }
.mt150 { margin-top: 150px; }

.no-gutter > [class*='col-'] {
    padding-right:0;
    padding-left:0;
}

#fullOverlay {
    position: fixed;
    left: 0; 
    top: 0;
    width: 100%; 
    height: 100%;
    background: rgba(100, 100, 100, .6);
    z-index: 2147483647;
    opacity: 0;
    visibility: hidden;
    transition: .3s linear;
}
#fullOverlay.is-open {
    opacity: 1;
    visibility: visible;
}

#content {
    margin-bottom: 100px;
}

body {
    font-family: "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro", "Meiryo", "メイリオ", sans-serif !important;
    /*background-color: #f5f5f5 !important;*/
    position: relative;
    background-color: #FEFEFE !important;
}

#header {
    border-top:5px solid #337ab7;
}

#header-container {
    width:100%;;
    padding-right: 0px;
    padding-left: 0px;
}

#header_line {
    width: 100%;
    background-color: #f1f1f1;
    margin:0;
    padding:0px;
}

.header-title {
    display:block;
    padding-right: 0px;
    padding-left: 0px;
    margin-left: 10px;
}
.header-title a {
    color:#333 !important;
}
.header-title a:hover,
.header-title a:visited,
.header-title a:active,
.header-title a:link{
    color:#333 !important;
    text-decoration: none;
}

.header-help-box {
    float: right;
    height: 39px;
}

.header-help-box a {
    /*padding: 5px 13px 5px 13px;*/
    padding-top: 3px;
    margin-top: 2px;
    color:#FFF !important;
    display: block;
    width: 35px;
    font-size: 20px;
    height: 35px;
    text-align: center;
    background-color: transparent;
    border: 2px solid #FFF;
    border-radius: 50%;
    transition: .5s;
}
.header-help-box a:hover {
    color: #999 !important;
    background-color: #CCC !important;
}

.header-info-box {
    float: right;
    height: 39px;
    border-left: 1px solid #666;
}
.header-info-box i {
    margin-right: 3px;
}
.header-info-box-link {
    padding-top: 3px;
    margin-top: 2px;
    color:#FFF !important;
    display: block;
    width: 35px;
    font-size: 20px;
    height: 35px;
    text-align: center;
    background-color: #f8b735;
    border: 2px solid #f8b735;
    border-radius: 50%;
    transition: .5s;
}
.header-info-box-link:hover,
.header-info-box-link:visited,
.header-info-box-link:active,
.header-info-box-link:link{
    text-decoration: none;
}

.header-info-box-link:hover{
    color: #FFF !important;
    background-color: #f38218 !important;
    border-color: 2px solid #f38218  !important;
}

.header-img {
    display:block;
    width:100%;
}

.navi {
    margin:0px;
    background-color: #14497c;
    padding-top:0px;
    padding-bottom:0px;
    border: none;
}

.nav-container {
    display: flex !important;
    flex-flow: row;
    justify-content: center;
    margin: 0;
    list-style-type: none;
}

.navbar-schedule > li {
    text-align: center;
    float: left;
    border-right: 1px solid #ffffff;

}
.navbar-schedule > li:first-child {
    border-left: 1px solid #ffffff;
}

.navbar-schedule > li > a {
    position: relative;
    color:white;
    margin:0px;
    padding-top:0px;
    padding-bottom:0px;
    padding-left:15px !important;
    padding-right:15px !important;
    border-bottom: 3px solid #14497c;
    transition: .5s;
    background-color:#14497c;
}
.navbar-schedule > li.active > a {
    background-color: #4E7CE8;
    border-bottom: 3px solid #4E7CE8;
}

.navbar-schedule > li > a:focus, 
.navbar-schedule > li > a:hover {
    color:#FFF !important;
    background-color: #4E7CE8 !important;
    border-bottom-color: #4E7CE8;
}
.navbar-schedule > li > a:hover,
.navbar-schedule > li > a:focus {
    color:#FFF !important;
    background-color: #4E7CE8 !important;
    border-bottom-color: #191970;
}

.navbar-schedule > li > a:hover::before {
    border-top: 0;
    border-bottom: solid 5px #191970;
    border-left: solid 5px transparent;
    border-right: solid 5px transparent;
    width: 0;
    height: 0;
    content: '';
    position: absolute;
    left: calc(50% - 5px);
    bottom: 0px;
}

.header-hamburger-nav {
    background-color:#14497c;
}
.header-hamburger-link {
    float: right;
    display: block;
    background-color: #9B9B9B;
    padding: 10px 15px;
    color: #FFF;
}
.header-hamburger-link:hover,
.header-hamburger-link:visited,
.header-hamburger-link:link,
.header-hamburger-link:active {
    color: #FFF;
    background-color: #9B9B9B;
}

.header-hamburger-list {
    margin: 0px;
    padding: 0px;
}
.header-hamburger-list > li {
    list-style-type: none;
    padding: 10px;
    background-color: #9B9B9B;
    border-bottom: 1px solid #FFF;
}
.header-hamburger-list > li > a {
    display: block;
    color: #EEE;
}

#main {
    padding-top:10px;
}

.button_list {
    width:100%;
    height:50px;
    padding:0px;

}
ul.button_list > li {
    padding:5px 2px 5px 2px;
    list-style-type: none;
    float: left;
}
.btn-gm {
    padding-top: 10px !important;
    padding-bottom: 10px !important;
}
/*
.btn-gm:nth-of-type(n+2) {
    margin-left: 15px;
}
*/
.btn-schedule {
    color: #ffffff;
    background-color: #14497c;
    border: 1px solid #14497c !important;
    transition: .3s;
}

.btn-schedule:hover,
.btn-schedule:visited,
.btn-schedule:link,
.btn-schedule:active {
    color: #ffffff;
}
.btn-schedule:hover {
    color: #ffffff;
    background-color: #7AA3DA;
}

.clear {
    clear: both;
}

.header-lv1 {
    background-color: #2A3F54;
    padding: 5px 15px;
    border-radius: 5px;
    margin-bottom: 20px;
}

.header-lv1-title {
    position: relative;
    color: #FFF;
    margin-top: 10px;
    margin-bottom: 10px;
    margin-left: 15px;
    font-size: 18px;
}
.header-lv1-title:has(.btn-guide) {
    margin-top: 5px;
    margin-bottom: 5px;
}

.header-lv1-title::before {
    position: absolute;
    content: ' ';
    left: -15px;
    width: 5px;
    height: 100%;
    background-color: #FFF;
}
.header-lv1-title:has(.btn-guide)::before {
    top: 5px;
    height: 20px;
}


.link-area {
    margin-top: 1px;
}
.link-area a {
    display: inline-block;
    color: #2A3F54;
    text-decoration: underline;
    padding: 8px 15px;
    background-color: #FEFEFE;
    border-radius: 5px;
    font-weight: 600;
    transition: .3s;
}
.link-area a:hover,
.link-area a:active,
.link-area a:link,
.link-area a:visited
 {
    color: #2A3F54;
    text-decoration: none;
}
.link-area a:hover {
    color: #FFF;
    background-color: #9B9B9B;
}

table > thead {
    color:#ffffff;
    background-color: #2A3F54
}

.required {
    color:red;
}

.login-box-wrap {
    min-height:500px;
     position: relative;
}

.login-box
{
    margin-top:10%;
}
.login-box2 {
    position: absolute;
    top: 50%;
    left: 50%;
    -ms-transform: translate(-50%,-50%);
    -webkit-transform : translate(-50%,-50%);
    transform : translate(-50%,-50%);
    margin: auto;
}

.login-panel-body {
    width:90%;
    margin:0 auto;
    padding-top: 30px;
}

.btn-login {
    width: 100%;
    padding: 15px;
}

.login-row {
    padding-top:10px;
}
.login-button-box {
    padding-top:20px;
}

.kidoku {
    float: right;
    font-size: 21px;
    font-weight: 700;
}


ul.schedule-list {
    width:98%;
    padding-left:0px;
}

ul.schedule-list > li {
    width:100%;
    margin:10px auto 10px 0px;;
    list-style-type: none;

}

span.title {
    font-size:x-large;
    font-weight: bold;
}

span.subtitle {
    font-weight: bold;
}

ul.schedule-list > li > ul {
    margin-top:5px;
    border-top: 1px solid gray;
    padding-left: 5px;
}

ul.schedule-list > li > ul > li {
    width:100%;
    margin:10px auto 10px 0px;;
    list-style-type: none;
}

ul.schedule-list > li > ul > li > ul {
    width:100%;
    padding-left: 10px;
}


ul.schedule-list > li > ul > li > ul > li {
    width:100%;
    margin:10px auto 10px 0px;
    list-style-type: none;
}

ul.schedule-list > li > ul > li > ul > li > ul {
    width:100%;
    margin-top:10px;
    padding-left: 10px;
}
ul.schedule-list > li > ul > li > ul > li > ul > li {
    width:100%;
    margin:10px auto 10px 0px;;
    list-style-type: none;
}
div.subtitle-area {
    margin-top:10px;

}
span.calendar-title {
    font-size: x-large;
    font-weight: bold;
}

#page-top {
    position: fixed;
    bottom: 50px;
    right: 20px;
    font-size: 100%;
    z-index: 999999;
}
#page-top a {
    font-size:48pt;
    background: transparent ;
    text-decoration: none;
    color: #337ab7;
    text-align: center;
}
#page-top a:hover {
    text-decoration: none;
}
/*
.sidebar {
  display: none;
}

@media screen and (min-width: 768px) {
  .sidebar {
    position: fixed;
    top: 0;
    bottom: 0;
    left: 0;
    display: block;
  }
}
*/
#fixed_navi.affix {
    top: 110px;
}
#fixed_navi.affix-bottom {
    position: absolute;
}

.subtitle {
    font-weight: bold;
}

.modal-header-conduct {
    border-radius: 5px 5px 0px 0px;
    background-color: #337ab7;
    color: #FFF;
}
.modal-header-schedule {
    border-radius: 5px 5px 0px 0px;
    background-color: #337ab7;
    color: #FFF;
}

.control-label {
    padding-top: 7px;
}

@media (min-width: 768px) {
  .form-horizontal .control-label {
    padding-top: 7px;
    margin-bottom: 0;
    text-align: left !important;
  }
}

.message {
    color:black;
}
.login-message {
    color:#333;
}
.logout ,.help {
    color:black;
}

@media only screen and (max-width:767px){
    table#deleted thead{
        display: none;
    }
    table#deleted tbody tr{
        display: block;
        margin-bottom: 1em;
    }
    table#deleted tbody th,
    table#deleted tbody td{
        display: list-item;
        list-style-type: none;
        border: none;
    }

    table#deleted tbody td:nth-of-type(1) {
        display: list-item !important;
        color:#ffffff;
        background-color: #79A1D4
    }

    table#deleted tbody td:nth-of-type(2):before { content: "[種別]"; }
    table#deleted tbody td:nth-of-type(3):before { content: "[予定リスト]"; }
    table#deleted tbody td:nth-of-type(4):before { content: "[実施リスト]"; }
    table#deleted tbody td:nth-of-type(5):before { content: "[予定日]"; }
}

.modal-open {
    padding-right: 0px !important;
}

.data-row-odd {
    background-color: #fff;
    padding-top:5px;
    padding-bottom:5px;
    border-bottom: 1px solid #ddd ;
}
.data-row-even {
    background-color: #f9f9f9 ;
    border-bottom: 1px solid #ddd ;
    padding-top:5px;
    padding-bottom:5px;
}

.sc-header {
    padding-top:5px;
    background-color: #4c6cb3;
    color:#FFF;
    border-radius: 5px 5px 5px 5px;
    margin-top: 5px;
    margin-bottom: 5px;
}

.sc-sub-header-start {
    padding-top:5px;
    color:#FAFAFA;
    background-color:  #79A1D4;
    border-radius: 5px 5px 0px 0px;
    margin-top: 5px;
}

.sc-sub-header-end {
    padding-top:5px;
    color:#FAFAFA;
    background-color:  #79A1D4;
    border-radius:0px 0px  5px 5px ;
}
.sc-sub-header-end a {
    color:white;
}

.conduct-title {
    margin-top:10px;
    padding-top:5px;
    padding-bottom:5px;
    border-radius: 5px;
    color:#000;
    background-color: #f5f5f5;
    border-top:1px solid #f5f5f5;
    border-bottom:1px solid #f5f5f5;
}
.schedule-title {
    color:white;
}
.schedule-title {
    color:white !important;
    text-decoration: underline;
}

#schedule_list {
    padding-top:30px;
}

.category-nav {
    margin-bottom:0px !important;
}
.category-note {
    margin-top:0px !important;
    border-top:0px !important;
}
.category-note-submit {
    padding-left:15px;
    padding-top:10px;
}

.note-area {
    padding-right:5px;
}

.toggle-btn {
    padding-top:10px !important;
    padding-bottom:10px !important;
    margin-right:5px !important;
}

.alert-label {
    vertical-align: middle;
    font-weight: normal;
}

 /* The switch - the box around the slider */
.switch {
  position: relative;
  display: inline-block;
  vertical-align: middle;
  width: 30px;
  height: 17px;
}

/* Hide default HTML checkbox */
.switch input {display:none;}

/* The slider */
.slider {
  position: absolute;
  cursor: pointer;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: #ccc;
  -webkit-transition: .4s;
  transition: .4s;
}

.slider:before {
  position: absolute;
  content: "";
  height: 13px;
  width: 13px;
  left: 2px;
  bottom: 2px;
  background-color: white;
  -webkit-transition: .4s;
  transition: .4s;
}

input:checked + .slider {
  background-color: #2196F3;
}

input:focus + .slider {
  box-shadow: 0 0 1px #2196F3;
}

input:checked + .slider:before {
  -webkit-transform: translateX(13px);
  -ms-transform: translateX(13px);
  transform: translateX(13px);
}

/* Rounded sliders */
.slider.round {
  border-radius: 17px;
}

.slider.round:before {
  border-radius: 50%;
}
/*
.toggle-group {
    width: 30px !important;
    height: 20px !important;
}

.toggle-group > label {
    width: 30px !important;
    height: 20px !important;
}
*/
.input-file {
    position: relative;
    padding: 50px 0 20px 0px;
    text-align: center;
    height: 130px;
}

.drop-area {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    padding: 20px 0 0;
    margin-bottom: 0px;
    border: 2px dashed #494949;
    background: rgba(22, 165, 191, 0);
    transition: all 0.25s cubic-bezier(0.21, 0.51, 0.51, 1);
}

.drop-area.dragover {
    border: 2px solid #16a5bf;
    background: rgba(22, 165, 191, 0.6);
}

.upload-file {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 10;
    display: block;
    width: 300px;
    height: 80px;
    opacity: 0;
}
.upload-file:hover {
    background-image: linear-gradient(
        -45deg,
        rgba(204, 204, 204, 0.36) 25%,
        #FFF 25%,
        #FFF 50%,
        rgba(204, 204, 204, 0.3) 50%,
        rgba(204, 204, 204, 0.3) 75%,
        #FFF 75%,
        #FFF
    );
    background-size: 40px 40px;
    background-attachment: fixed;
    background-position: 0 0;
    -webkit-animation: bgroop 20s linear infinite;
    animation: bgroop 20s linear infinite;
}

.input-file-wrap {
    position: relative;
    display: inline-block;
}

.btn-input-file {
    display: table;
    width: 300px;
    margin-top: 20px;
}

.btn-input-file span {
    position: relative;
    z-index: 2;
    display: table-cell;
    width: 300px;
    height: 30px;
    border: 1px solid #333;
    border-radius: 4px;
    background: #333;
    text-decoration: none;
    color: #fff;
    font-size: 14px;
    line-height: 1;
    font-weight: bold;
    vertical-align: middle;
}

#upload-file-wrap.selected .btn-input-file {
    display: none;
}

.upload-icon-image {
    display: block;
    width: 64px;
    margin-left: auto;
    margin-right: auto;
}

.preview-file-wrap {
    padding: 10px 30px 10px 30px;
    height: 130px;
    border: 2px dashed #494949;
}

.upload-file-title {
    font-size: 12px;
    text-align: center;
    margin-bottom: 0px;
}

.img-action-button-area {
    width: 100px;
    margin-right: auto;
    margin-left: auto;
    font-size: 12px;
    text-align: center;
}

.img-del {
    display: inline-block;
    color: #FFF;
    background-color: #B30B0b;
    padding: 5px 10px;
    border-radius: 6px;
}
.img-del:hover {
    color: #fff;
    text-decoration: none;
}

.img-display {
    display: inline-block;
    color: #FFF;
    background-color: #213435;
    padding: 5px 10px;
    border-radius: 6px;
}
.img-display:hover,
.img-display.focus {
    color: #fff;
    text-decoration: none;
}

.chk-company {
    padding-top: 5px;
    padding-bottom: 10px;
    border-bottom: 1px solid gray;
}
.chk-company-name {
    padding-bottom: 10px;
    border-bottom: 1px solid gray;
}
.auth-flow-delete {
    font-size: 24px;
}

.bg-white {
    background-color: #FFF !important;
}
.tab-file-warp {
    padding: 10px;
}
.preview-warp {
    padding: 10px;
}
.application-content {
    /*margin-bottom: 100px;*/
}

.application-footer {
    padding-top: 15px;
    padding-right: 20px;
    padding-bottom: 15px;
    background-color: #FFF;
    z-index: 100;
    margin-top: 20px;
    position: static;
    bottom: 0;
    left: 0;
    overflow: hidden;
    width: 100%;
    position: fixed;
    border-top: 3px solid #14497c;
    background-color: #f1f1f1;
}

.application-footer .container  {
    width: 100%;
}

.footer-button-area {
    text-align: right;
}
.accompanying-tab {
    position:relative;
}
.accompanying-tab-close {
    position:absolute;
    right: 5px;
    top: -55px;
}
.accompanying-tab-close > a {
    font-size: 24px;
}

.attachment-drop-area {
    position: relative;
    width: 100%;
    height: 200px;
    border: 1px solid #CCC;
    border-radius: 5px;
}

@-webkit-keyframes bgroop {
    from {
        background-position: 0  0;
    }
    to {
        background-position: 0 1956px;
    }
}
@keyframes bgroop {
    from {
        background-position: 0 0;
    }
    to {
        background-position: 0 1956px;
    }
}

.attachment-drop-area:hover {
    background-image: linear-gradient(
        -45deg,
        rgba(204, 204, 204, 0.36) 25%,
        #FFF 25%,
        #FFF 50%,
        rgba(204, 204, 204, 0.3) 50%,
        rgba(204, 204, 204, 0.3) 75%,
        #FFF 75%,
        #FFF
    );
    background-size: 40px 40px;
    background-attachment: fixed;
    background-position: 0 0;
    -webkit-animation: bgroop 20s linear infinite;
    animation: bgroop 20s linear infinite;
}

.attachment-drop-icon-area {
    text-align: center;
}
.attachment-drop-icon {
    width: 20%;
    margin-left: auto;
    margin-right: auto;
    margin-top: 0px;
    opacity: 0.6;
}
.attachment-drop-icon img {
    width: 50px;
    margin-bottom: 10px;
    margin-top: 70px;
}
.attachment-drop-icon span {
    margin-top: 10px;
    color: rgba(204, 204, 204, 0.2);
}
.attachment-drop-area input[type="file"] {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    height: 100%;
    width: 100%;
    opacity: 0;
    cursor: pointer;
    z-index: 5;
}
.attachment-preview-area {
    width: 100%;
    height: 150px;
    border: 1px solid rgba(204, 204, 204, 0.6);
    border-radius: 5px;
    margin-top: 10px;
    overflow-x: scroll;
}
.attachment-preview-scroll {
    height: 100%;

}

.attachment-preview-img {
    position: relative;
    width: 100px;
    padding-top: 25px;
    margin-left: 10px;
    margin-right: 10px;
    height: 100%;
    text-align: center;
    float: left;
}
.upload-file-icon {
    width: 50px;
}
.attachment-preview-title {
    margin-top: 5px;
    font-size: 12px;
    word-break: break-all;
    word-wrap: break-word;
}
.attachment-preview-close {
    position: absolute;
    top: 5px;
    right: 10px;
    font-size: 20px;
    color: #B30B00;
}
.attachment-preview-close:hover,
.attachment-preview-close:active,
.attachment-preview-close:focus,
.attachment-preview-close:link {
    color: #7c0808;
    text-decoration: none;
}
.file_download:hover,
.file_download:active,
.file_download:focus, 
.file_download:link {
    text-decoration: none;
}

#editor {
    min-height: 47em;
}

.step-list{
    list-style-type: none;
    display:table;
    width:100%;
    padding:0;
    margin:5px auto 20px auto;
    overflow:hidden;
    text-align: center;
    font-size: 16px;
    border-radius: 5px;
}

.step-list li{
    display:table-cell;
    position:relative;
    background: #504944;
    padding: 1em 0.5em 1em 2em;
    color: #fff;
}
.step-list li:last-child{
    padding-right: 1em;
}
.step-list li:last-child:before,
.step-list li:last-child:after{
    display:none;
}
.step-list li::before,
.step-list li:after{
    content: "";
    position: absolute;
    width: 0;
    height: 0;
    margin: auto;
}
.step-list li::before{
    top:-15px;
    right:-1em;
    border-style: solid;
    border-color: transparent transparent transparent #fff;
    border-width: 40px 0 40px 1em;
    z-index: 10;
}
.step-list li::after{
    top: -15px;
    right: -.8em;
    border-style: solid;
    border-color: transparent transparent transparent #504944;
    border-width: 40px 0 40px 1em;
    z-index: 10;
}
.step-list li.active{
    background: #9bbb30;
    font-weight: bold;
}
.step-list li.active::after{
    border-color: transparent transparent transparent #9bbb30;
}

.mail-body-preview {
    display: block;
    width: 100%;
    padding: 6px 12px;
    font-size: 14px;
    line-height: 1.42857143;
    color: #555;
    background-color: #fff;
    background-image: none;
    border: 1px solid #ccc;
    border-radius: 4px;
    -webkit-box-shadow: inset 0 1px 1px rgba(0,0,0,.075);
    box-shadow: inset 0 1px 1px rgba(0,0,0,.075);
    -webkit-transition: border-color ease-in-out .15s,-webkit-box-shadow ease-in-out .15s;
    -o-transition: border-color ease-in-out .15s,box-shadow ease-in-out .15s;
    transition: border-color ease-in-out .15s,box-shadow ease-in-out .15s;
}

.comapny_level {
    display:table;
    padding:0;
    margin:20px auto 20px 0px;
    overflow:hidden;
    text-align: center;
    font-size: 16px;
    border-radius: 5px;
}
.comapny_level > li {
    display:table-cell;
    list-style-type: none;
    position:relative;
    background: #E2E8ED;
    padding: .5em 2em .5em 2em;
    color: #fff;
}
.comapny_level > li > a {
    color: #5F848E;
}
.comapny_level > li > a:active,
.comapny_level > li > a:link,
.comapny_level > li > a:visited,
.comapny_level > li > a:hover {
    color: #5F848E;
    text-decoration: none;
}

.comapny_level > li:last-child:before,
.comapny_level > li:last-child:after{
    display:none;
}
.comapny_level > li::before,
.comapny_level > li:after{
    content: "";
    position: absolute;
    width: 0;
    height: 0;
    margin: auto;
}
.comapny_level > li::before{
    top:-15px;
    right:-1em;
    border-style: solid;
    border-color: transparent transparent transparent #fff;
    border-width: 40px 0 40px 1em;
    z-index: 10;
}
.comapny_level > li::after{
    top: -15px;
    right: -.8em;
    border-style: solid;
    border-color: transparent transparent transparent #E2E8ED;
    border-width: 40px 0 40px 1em;
    z-index: 10;
}
.comapny_level > li.active{
    background: #007AB0;
    font-weight: normal;
}
.comapny_level > li.active::after{
    border-color: transparent transparent transparent #007AB0;
}
.comapny_level > li.active > a {
    color: #B4D1E1;
}
.comapny_level > li.active > a:hover,
.comapny_level > li.active > a:link,
.comapny_level > li.active > a:visited,
.comapny_level > li.active > a:active {
    color: #B4D1E1;
    text-decoration: none;
}


.list-group > .list-group {
    display: block;
    margin-bottom: 0;
}
.list-group-item:focus-within + .list-group {
    display: block;
}

.list-group > .list-group-item {
    border-radius: 0;
    border-width: 1px 0 0 0;
}

.list-group > .list-group-item:first-child {
    border-top-width: 0;
}

.list-group  > .list-group > .list-group-item {
    padding-left: 2.5rem;
}

.item_name_value {
    display: block;
    width: 100%;
    height: 34px;
    padding: 6px 12px;
    font-size: 14px;
    line-height: 1.42857143;
    color: #555;
    background-color: #fff;
    background-image: none;
    border: 1px solid #ccc;
    border-radius: 4px;
    -webkit-box-shadow: inset 0 1px 1px rgb(0 0 0 / 8%);
    box-shadow: inset 0 1px 1px rgb(0 0 0 / 8%);
    -webkit-transition: border-color ease-in-out .15s,-webkit-box-shadow ease-in-out .15s;
    -o-transition: border-color ease-in-out .15s,box-shadow ease-in-out .15s;
    transition: border-color ease-in-out .15s,box-shadow ease-in-out .15s;
}

.delete-button-area {
    text-align: center;
    width: 100%;
    margin-top: 5px;
}
.valign-middle {
    vertical-align: middle !important;
}

.bg-transparent {
    background-color: transparent !important;
    border: none !important;
    box-shadow: none !important;
    padding-left: 0px !important;
}

.top-title {
    display: block;
    text-align: center;
    width: 100%;
    color: #2a2a2a;
    font-weight: 400;
    text-align: center;
    letter-spacing: .04em;
    font-size: 30px;
    margin-bottom: 0px;
    font-weight: 600;
}
.top-title:first-letter{
    color:#5bc0de;
    font-size:32px;
}

.top-subtitle {
    display: block;
    text-align: center;
    margin-top: 5px;
    margin-bottom: 10px;
    font-weight: 600;
}

.notice-area {
    max-width: 80%;
    margin-left: auto;
    margin-right: auto;
    margin-top: 20px;
    margin-bottom: 10px;
}

@media screen and (max-width: 769px) {
    .notice-area {
        min-width: 100%;
        width: 100%;
    }
}

.news {
    margin: 0;
    padding: 0;
}
.news-item:first-child {
    border-top: 1px solid #000;
}

.news-item {
    list-style-type: none;
    border-bottom: 1px solid #000;
    padding: 15px 10px;
}

.news-item-date,
.news-item-title,
.news-item-open {
    float: left;
}

.news-item-date {
    width: 20%;
}
.news-item-title {
    width: 70%;
}
.news-item-open {
    width: 10%;
    text-align: center;
}

.news-item-button {
    padding: 5px;
    color: #EEE;
    background-color: #666;
    border-radius: 5px;
    transition: .3s linear;
}
.news-item-button:hover,
.news-item-button:active,
.news-item-button:link,
.news-item-button:visited {
    color: #EEE;
    text-decoration: none;
}
.news-item-button:hover {
    background-color: #333;
}

.news-item-content {
    margin-left: 20%;
    margin-right: 10%;
    margin-top: 15px;
}
.notice-attachment-file {
    margin-top: 10px;
}

.notice-attachment-file > a {
    display: inline-block;
    width: 25px;
}
.notice-attachment-file > a > img {
    width: 100%;
}

.read-more-area {
    margin-top: 30px;
    margin-right: 0px;
    text-align: right;
}

.todolist-area {
    max-width: 100%;
    margin-left: auto;
    margin-right: auto;
    margin-top: 20px;
    margin-bottom: 10px;
}


@media screen and (max-width: 769px) {
    .news-item-date {
        width: 30%;
    }
    .news-item-title {
        width: 50%;
    }
    .news-item-open {
        width: 20%;
    }
    .news-item-content {
        margin-left: 0%;
        margin-right: 0%;
    }
}

.tab-list {
    padding: 0px;
    margin: 0px;
}

.tab-list > li {
    list-style-type: none;
    float: left;

    background-color: #999;
    transition: .3s;
    margin-left: 1px;
}
.tab-list > li:first-child {
    margin-left: 0px;
}
.tab-list > li.active {
    background-color: #CACACA;
}
.tab-list > li > a {
    display: block;
    padding: 15px;
    color: #000;
}
@media screen and (max-width: 769px) {
    .tab-list > li > a {
        padding: 15px 5px;
    }
}
.tab-list > li:hover {
    background-color: rgba(0, 0, 0, 0.15);
}
.tab-list > li > a:hover, 
.tab-list > li > a:active,
.tab-list > li > a:link,
.tab-list > li > a:visited {
    color: #000;
    text-decoration: none;
}
.tab-list::after {
    content: '';
    display: block;
    clear: both;
}
.tab-content > div#task-content,
.tab-content > div#application-content,
.tab-content > div#service-application,
.tab-content > div#service-content,
.tab-content > div#progress-management-alert-content,
.tab-content > div#progress-management-content {
    background-color: #F2F2F2;
    padding: 30px 30px 10px 30px;
}
@media screen and (max-width: 769px) {
    .tab-content > div#task-content,
    .tab-content > div#application-content,
    .tab-content > div#service-application,
    .tab-content > div#progress-management-alert-content,
    .tab-content > div#progress-management-content,
    .tab-content > div#service-content {
        padding: 15px 15px 10px 15px;
    }
}

.todolist-subtitle {
    font-size: 18px;
}

.todo-alert-hint-messages {
    font-size: 18px;
    color: #E50000;
    margin-bottom: 20px;
}
.canvas-chart {
    position: relative;
    margin-top: 20px;
}
.canvas-chart canvas {
    background-color: #FFF;
}
.canvas-chart a {
    position: absolute;
    top: 20px;
    left: 10px;
    font-weight: 600;
    font-size: 18px;
}
@media screen and (max-width: 769px) {
    .canvas-chart a {
        font-size: 12px;
    }
}

.document-progress-area {
    max-width: 100%;
    margin-left: auto;
    margin-right: auto;
    margin-top: 20px;
    margin-bottom: 10px;
}
.document-file-area {
    max-width: 100%;
    margin-left: auto;
    margin-right: auto;
    margin-top: 20px;
    margin-bottom: 10px;
}
.share-file-list {
    padding: 0px;
    margin: 0px;
    background-color: #e8e8e8;
}
.share-file-list > li:first-child {
    border-top: 1px solid #333;
}
.share-file-list > li {
    list-style-type: none;
    padding: 30px 10px;
    border-bottom: 1px solid #333;
}
.share-file-item-name {
    float: left;
    width: 60%;
}
.share-file-item-button-area {
    float: left;
    width: 40%;

}
.share-file-item-button {
    background-color: #cc0000;
    color: #FFF;
    padding: 5px 10px;
    border-radius: 5px;
    transition: .3s;
}
.share-file-item-button:hover,
.share-file-item-button:visited,
.share-file-item-button:link,
.share-file-item-button:active {
    text-decoration: none;
}
.share-file-item-button:hover {
    background-color: #c0392b;
    color: #FFF;

}
.admin-file-area {
    max-width: 100%;
    margin-left: auto;
    margin-right: auto;
    margin-top: 50px;
    margin-bottom: 10px;
}
.admin-file-list {
    padding: 0px;
    margin: 0px;
    background-color: #e8e8e8;
}
.admin-file-list > li:first-child {
    border-top: 1px solid #333;
}
.admin-file-list > li {
    list-style-type: none;
    padding: 30px 10px;
    border-bottom: 1px solid #333;
}
.admin-file-item-name {
    float: left;
    width: 60%;
}
.admin-file-item-button-area {
    float: left;
    width: 40%;

}
.admin-file-item-button {
    background-color: #cc0000;
    color: #FFF;
    padding: 5px 10px;
    border-radius: 5px;
    transition: .3s;
}
.admin-file-item-button:hover,
.admin-file-item-button:visited,
.admin-file-item-button:link,
.admin-file-item-button:active {
    text-decoration: none;
}
.admin-file-item-button:hover {
    background-color: #c0392b;
    color: #FFF;

}

.useful-link-area {
    max-width: 100%;
    margin-left: auto;
    margin-right: auto;
    margin-top: 50px;
    margin-bottom: 10px;
}

.useful-list {
    padding: 0px;
    margin: 0px;
    background-color: #e8e8e8;
}
.useful-list > li:first-child {
    border-top: 1px solid #333;
}
.useful-list > li {
    list-style-type: none;
    padding: 20px 10px;
    border-bottom: 1px solid #333;
}
.useful-category {
    float: left;
    width: 40%;
}
.useful-link {
    float: left;
    width: 60%;
}

.search-hide {
    display: block;
    color: #666;
    font-size: 14px;
    transition: .3s linear;
}
.search-hide:hover,
.search-hide:active,
.search-hide:link,
.search-hide:visited {
    color: #666;
    text-decoration: none;
}
.search-hide:hover {
    color: #999;
}
.search-hide-white {
    display: block;
    color: #EEE;
    font-size: 14px;
    transition: .3s linear;
}
.search-hide-white:hover,
.search-hide-white:active,
.search-hide-white:link,
.search-hide-white:visited {
    color: #EEE;
    text-decoration: none;
}
.search-hide-white:hover {
    color: #CCC;
}

.pagination {
    margin: 0px !important;
}

.flow-line1 {
    border-bottom: 1px dotted #666;
}
.flow-line2 {
    border-bottom: 1px solid #666;
}

.application-approval-area {
    width: 100%;
    margin-top: 50px;
}

.employee-info-area {
    margin-top: 20px;
    padding: 30px 30px 100px 30px;
    background-color: #e8e8e8;
}

.bg-comment {
    background-color: #6F8EBC !important;
}

.communication-comment {
    position: relative;
    width: 100%;
}

.communication-comment .icon {
    position: absolute;
    top: 5px;
}
.communication-comment .icon > a {
    display: block;
    border-radius: 50%;
    width:  35px;
    height: 35px;
    border:1px solid #333;
    text-align: center;
    padding: 7px;
    color: #333;
    background-color: #FFF;

}
.communication-comment-right .icon {
    right: 10px;

}
.communication-comment-left .icon {
    left: 10px;
}

.communication-comment .name-date {
    position: absolute;
    top: 10px;
    color:#000;
    font-size: 14px;
    font-weight: 400;
}
.communication-comment-right .name-date {
    right: 50px;
}
.communication-comment-left .name-date {
    left: 50px;
}

.communication-comment .comment-box {
    position: relative;
    display: flex;
    justify-content: flex-end;
    padding-top: 35px;
    margin-bottom: 10px;
    padding-bottom: 10px;
    font-size: 14px;
}
.communication-comment-left .comment-box {
    justify-content: flex-start;
    margin-left: 60px;
}
.communication-comment-right .comment-box {
    justify-content: flex-end;
    margin-right: 60px;
}

.communication-comment .comment-box .comment {
    padding: 15px 35px;
    max-width: 50%;
    word-break: break-all;
    word-wrap: break-word;
    position: relative;
    font-size: 16px;
}
.communication-comment-left .comment-box .comment {
    border-radius: 0px 10px 10px 10px;
    color: #000;
    border: 1px solid #CCC;
    background-color: #CCC;
}
.communication-comment-right .comment-box .comment {
    border-radius: 10px 0px 10px 10px;
    color: #000;
    border: 1px solid #00c300;
    background-color: #00c300;
}

.communication-comment-left .comment-box .comment:before {
    content: "";
    position: absolute;
    top: 11px;
    left: -24px;
    margin-top: -12px;
    border: 12px solid transparent;
    border-top: 0px solid #CCC;
    border-right: 12px solid #CCC;
    z-index: 0;
}

.communication-comment-right .comment-box .comment:before {
    content: "";
    position: absolute;
    top: 12px;
    right: -24px;
    margin-top: -12px;
    border: 12px solid transparent;
    border-top: 0px solid #00c300;
    border-left: 12px solid #00c300;
    z-index: 0;
}

.communication-comment .comment-box .image {
    padding: 10px 10px;
    border-radius: 10px;
    max-width: 40%;
    word-break: break-all;
    word-wrap: break-word;
}

@media screen and (max-width: 568px) {
    .communication-comment .comment-box .comment {
        max-width: 60%;
    }
    .communication-comment .comment-box .image {
        max-width: 60%;
    }
}

.communication-comment .comment-box .image img {
    display: block;
    width: 100%;
}

.communication-comment .comment-box .download {
    padding: 10px 10px;
    border-radius: 10px;
    max-width: 40%;
}
.communication-comment .comment-box .download > a {
    display: block;
    text-align: center;
    padding: 5px;
}

.communication-comment .comment-box .download > a > span {
    display: block;
    margin-top: 5px;
}

.communication-comment .comment-box .download > a {
    color: #000;
}
.communication-comment .comment-box .download > a :hover {
    color: #666;
    opacity: 0.6;
    text-decoration: none;
}

.dropdown-menu.right {
    right:0;
    left:auto;
}
.dropdown-menu.right::before {right:auto !important; left:9px;}
.dropdown-menu.right::after {right:auto !important; left:10px;}
.dropdown-menu.left {
    right:auto;
    left:0;
}
.dropdown-menu.left::before {right:auto !important; left:9px;}
.dropdown-menu.left::after {right:auto !important; left:10px;}

.dropdown-menu.red {
    color: #a94442;
    border-color: #ebccd1;
    background-color: #f2dede !important;
}
.dropdown-menu.red > li {
    color: #a94442;
    border-color: #ebccd1;
    background-color: #f2dede !important;
}
.dropdown-menu.red > li:hover {
    background-color: #f2dede !important;
}
.dropdown-menu.red > li > a {
    color: #a94442;
    border-color: #ebccd1;
    background-color: #f2dede !important;
    background-image: none;
}
.dropdown-menu.red > li > a:hover {
    color: #742f2e;
    background-color: #f2dede !important;
    background-image: none;
}
.dropdown-menu.info {
    color: #31708f;
    background-color: #d9edf7 !important;
    border-color: #bce8f1;
}
.dropdown-menu.info > li {
    color: #31708f;
    background-color: #d9edf7 !important;
    border-color: #bce8f1;
}
.dropdown-menu.info > li:hover {
    background-color: #2aabd2 !important;
}
.dropdown-menu.info > li > a {
    color: #31708f;
    background-color: #d9edf7 !important;
    border-color: #bce8f1;
    background-image: none;
}
.dropdown-menu.priminfoary > li > a:hover {
    color: #fff;
    background-color: #2aabd2 !important;
    background-image: none;
}


/* overlay at start */
.mfp-fade.mfp-bg {
    opacity: 0;
  
    -webkit-transition: all 0.15s ease-out;
    -moz-transition: all 0.15s ease-out;
    transition: all 0.15s ease-out;
  }
  /* overlay animate in */
  .mfp-fade.mfp-bg.mfp-ready {
    opacity: 0.8;
  }
  /* overlay animate out */
  .mfp-fade.mfp-bg.mfp-removing {
    opacity: 0;
  }
  
  /* content at start */
  .mfp-fade.mfp-wrap .mfp-content {
    opacity: 0;
  
    -webkit-transition: all 0.15s ease-out;
    -moz-transition: all 0.15s ease-out;
    transition: all 0.15s ease-out;
  }
  /* content animate it */
  .mfp-fade.mfp-wrap.mfp-ready .mfp-content {
    opacity: 1;
  }
  /* content animate out */
  .mfp-fade.mfp-wrap.mfp-removing .mfp-content {
    opacity: 0;
  }

  .panel-link-area > a {
      color: #000;
      text-decoration: underline;
  }

.download-area {
    padding: 10px 0;
    text-align: center;
}
.download-area > a {
    color: #ffffff;
    background-color: #14497c;
    border: 1px solid #14497c !important;
    display: inline-block;
    padding: 6px 12px;
    margin-bottom: 0;
    font-size: 14px;
    font-weight: 400;
    line-height: 1.42857143;
    text-align: center;
    white-space: nowrap;
    vertical-align: middle;
    -ms-touch-action: manipulation;
    touch-action: manipulation;
    cursor: pointer;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    background-image: none;
    border: 1px solid transparent;
    border-radius: 4px;
    transition: .3s;
}

.download-area > a:hover,
.download-area > a:visited,
.download-area > a:link,
.download-area > a:active {
    color: #ffffff;
    text-decoration: none;
}
.download-area > a:hover {
    color: #ffffff;
    background-color: #7AA3DA;
}

option:disabled {
    background-color: #ddd;
    opacity: 1;
}


.w100 { width: 100px !important; }
.w200 { width: 200px !important; }
.w250 { width: 250px !important; }
.w300 { width: 300px !important; }

.flex-container {
    display: flex;
    flex-wrap: wrap;
    width: 100%;
}

.service-company-select,
.category-select,
.service-select {
    width: 45%;
    display: block;
    padding: 10px;
    margin: 10px;
    border:1px solid gray;
    box-shadow: 5px 5px 5px #999;
}

.service-company-select:nth-child(even),
.category-select:nth-child(even),
.service-select:nth-child(even) {
    margin-left: 0px;
}
@media screen and (max-width: 568px) {

    .service-company-select,
    .category-select,
    .service-select {
        width: 100%;
        margin-left: 0px;
    }
}

.service-company-select.active,
.category-select.active,
.service-select.active {
    transition: .3s;
    background-color: #eee;
}
.service-company-select > .radio-box,
.category-select > .radio-box,
.service-select > .radio-box {
    float: left;
    width: 10%;
    padding: 5px 0 0 0;
}
.service-company-select > .radio-box > .service_category_id,
.category-select > .radio-box > .service_company_id,
.service-select > .radio-box > .service_form_id {
    position: static;
    margin: 5px 0 0 0;
}
.service-company-select > .service-company-title,
.category-select > .category-title,
.service-select > .service-title {
    float: left;
    width: 85%;
    margin-top: 6px;
    font-size: 16px;
    font-weight: 600;
}
.service-company-select > .explanation,
.category-select > .explanation,
.service-select > .explanation {
    width: 100%;
    margin-top: 10px;
}
.service-company-select > .explanation > p,
.category-select > .explanation > p,
.service-select > .explanation > p {
    margin: 0px;
    padding: 0px;
    font-weight: normal;
}

.template-files {
    display: inline-block;
    font-size: 14px;
}
.template-files > a {
    display: inline-block;
    width: 30px;
}
.template-files > a > img {
    width: 100%;
    image-rendering: -webkit-optimize-contrast;
}
.service-form-detail-icon {
    margin-top: 10px;
    text-align: right !important;
}

.explanation > p {
    margin: 0px;
    padding: 0px;
    font-weight: normal;
}

@media (max-width: 767px) {
    .nav-tabs.nav-tabs-dropdown,
    .nav-tabs-dropdown {
        width: 100%;
        border: 1px solid #dddddd;
        border-radius: 5px;
        overflow: hidden;
        position: relative;
    }
    .nav-tabs-dropdown > li {
        width: 100%;
    }
    .nav-tabs.nav-tabs-dropdown::after,
    .nav-tabs-dropdown::after {
        content: "☰";
        position: absolute;
        top: 8px;
        right: 15px;
        z-index: 2;
        pointer-events: none;
    }
    .nav-tabs.nav-tabs-dropdown.open a,
    .nav-tabs-dropdown.open a {
        position: relative;
        display: block;
    }
    .nav-tabs.nav-tabs-dropdown.open > li.active > a,
    .nav-tabs-dropdown.open > li.active > a {
        background-color: #eeeeee;
    }
    .nav-tabs.nav-tabs-dropdown li,
    .nav-tabs-dropdown li {
        display: block;
        padding: 0;
        vertical-align: bottom;
    }
    .nav-tabs.nav-tabs-dropdown > li > a,
    .nav-tabs-dropdown > li > a {
        position: absolute;
        top: 0;
        left: 0;
        margin: 0;
        width: 100%;
        height: 100%;
        display: inline-block;
        border-color: transparent;
    }
    .nav-tabs.nav-tabs-dropdown > li > a:focus,
    .nav-tabs.nav-tabs-dropdown > li > a:hover,
    .nav-tabs.nav-tabs-dropdown > li > a:active,
    .nav-tabs-dropdown > li > a:focus,
    .nav-tabs-dropdown > li > a:hover,
    .nav-tabs-dropdown > li > a:active {
        border-color: transparent;
    }
    .nav-tabs.nav-tabs-dropdown > li.active > a,
    .nav-tabs-dropdown > li.active > a {
        display: block;
        border-color: transparent;
        position: relative;
        z-index: 1;
        background: #fff;
    }
    .nav-tabs.nav-tabs-dropdown > li.active > a:focus,
    .nav-tabs.nav-tabs-dropdown > li.active > a:hover,
    .nav-tabs.nav-tabs-dropdown > li.active > a:active,
    .nav-tabs-dropdown > li.active > a:focus,
    .nav-tabs-dropdown > li.active > a:hover,
    .nav-tabs-dropdown > li.active > a:active {
        border-color: transparent;
    }
}

.mfs-auto {
    margin-left: auto !important;
  }

.content-margin {
    margin-left: 256px;
}

.wrapper {
    display: flex;
    flex-direction: column;
    min-height: calc(100vh - 50px);
}

.sidebar {
    display: flex;
    flex-direction: column;
    width: 256px;
    padding: 0px;
    color: #FFF;
    background: #4f5d73;
    position: fixed;
    top: 0;
    bottom: 0;
    z-index: 1030;
}

@media screen and (max-width: 767px) { 
    .sidebar {
        margin-left: -256px;
    }
    .content-margin {
        margin-left : 0px;
    }
}

.sidebar .sidebar-brand {
    display: flex;
    flex: 0 0 56px;
    align-items: center;
    justify-content: center;
    background: rgba(0, 0, 21, 0.2);
    
}
.sidebar .sidebar-brand > a {
    font-size: 10px;
    color: #FFFF;
    font-weight: 600;
    transition: .3s;
}
.sidebar .sidebar-brand > a:hover {
    text-decoration: none;
    color: #ccc;
}
.sidebar .sidebar-brand > a > img {
    display: block;
    width: 100%;
    image-rendering: -webkit-optimize-contrast;
}
.sidebar .sidebar-nav {
    position: relative;
    display: flex;
    flex: 1;
    flex-direction: column;
    padding: 0 0 40px 0;
    margin-bottom: 0;
    overflow-x: hidden;
    overflow-y: auto;
    list-style: none;
    scrollbar-width: thin;
    scrollbar-color: #999 transparent;
}
.sidebar-sub-nav {
    padding: 0px;
    margin-bottom: 0;
}
.sidebar .sidebar-nav .sidebar-nav-item {
    position: relative;
}
.sidebar .sidebar-nav .sidebar-nav-item .open-icon {
    position: absolute;
    right: 10px;
    top: 10px;
}

.sidebar .sidebar-nav .sidebar-nav-item .sidebar-nav {
    display: block;
}

.sidebar .sidebar-nav::-webkit-scrollbar {
    width: 6px;
}

.sidebar .sidebar-nav::-webkit-scrollbar-track {
    background: transparent;
}

.sidebar .sidebar-nav::-webkit-scrollbar-thumb {
    border-radius: 5px;
    background: #999;
}

.sidebar .sidebar-nav li {
    list-style: none;
}

.sidebar .sidebar-nav li .sidebar-nav-link {
    display: flex;
    flex: 1;
    align-items: center;
    padding: 0.8445rem 1rem;
    text-decoration: none;
    white-space: nowrap;
    transition: background 0.25s, color 0.25s;
    color: #fff;
    transition: .3s;
}

.sidebar-sub-nav li .sidebar-nav-link {
    padding: 0.8445rem 0px 0.8445rem 2rem !important;
    margin-bottom: 0;
}
.sidebar-sub-nav li ul li .sidebar-nav-link {
    padding: 0.8445rem 0px 0.8445rem 2.5rem !important;
    margin-bottom: 0;
}

.sidebar .sidebar-nav li .sidebar-nav-link:hover {
    color: #fff;
    background: rgba(255, 255, 255, 0.2);
}

.sidebar .sidebar-nav li .sidebar-nav-link .sidebar-nav-icon {
    margin-left: -1rem;
    flex: 0 0 56px;
    height: 1.09375rem;
    font-size: 1.09375rem;
    text-align: center;
    transition: 0.25s;
    fill: currentColor;
    color: #8a93a2;
}

.sidebar .sidebar-nav li.active .sidebar-nav-link {
    /*    background: #252c35;*/
    background: rgba(255, 255, 255, 0.2);
}

.sidebar .sidebar-nav .sidebar-nav-title {
    padding: 0.5rem 1rem;
    margin-top: 0.5rem;
    font-size: 80%;
    font-weight: 700;
    text-transform: uppercase;
    transition: 0.25s;
    color: rgba(255, 255, 255, 0.6);
}

.header {
    position: fixed;
    right: 0;
    left: 0;
    z-index: 1029;
    height: 104px;
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;

    border: 0;
    box-shadow: 0 2px 2px 0 rgba(60, 75, 100, 0.14), 0 3px 1px -2px rgba(60, 75, 100, 0.12), 0 1px 5px 0 rgba(60, 75, 100, 0.2);
    -webkit-clip-path: inset(0 0 -1000px 0);
    clip-path: inset(0 0 -1000px 0);
}
.header.front {
    background: #0f084b;
}
.header.admin {
    background: #42AAC3;
}
.header.traders {
    background: #009159;
}
.header.family {
    background: #F25F70;
}

.header .header-toggler {
    cursor: pointer;
    color: #FFF;
    border-color: rgba(0, 0, 21, 0.1);
    min-width: 50px;
    font-size: 1.09375rem;
    background-color: transparent;
    border: 0;
    border-color: currentcolor;
    border-radius: 0.25rem;
    padding: 0;
    margin-left: 0;
    border-style: none;
    outline: 0;
}

.header .header-toggler .icon-lg {
    width: 1.25rem;
    height: 1.25rem;
    font-size: 2rem;
    text-align: center;
}

.header .header-toggler .icon {
    display: inline-block;
    color: inherit;
    text-align: center;
    fill: currentColor;
}

.header .header-toggler:focus {
    outline: 0;
}

.header .header-toggler:hover {
    text-decoration: none;
}

.header-title {
    margin-left:20px;
    margin-top: 12px;
    font-size: 20px;
    color: #FFF; 
}

.header .header-nav {
    height: 56px;
    display: flex;
    flex-direction: row;
    align-items: center;
    padding: 0;
    margin-bottom: 0;
    list-style: none;
    padding-right: 1rem !important;
}

.header .header-nav .header-nav-item {
    position: relative;
}

.header .header-nav .header-nav-item .title {
    margin-top: 0.5rem;
    font-size: 16px;
    padding-left: 16px;
}

.header .header-nav .header-nav-item .header-nav-link {
    display: flex;
    align-items: center;
    padding-right: 0.5rem;
    padding-left: 0.5rem;
    color: rgba(0, 0, 21, 0.5);
}

.header .header-nav .header-nav-item .header-nav-link:hover,
.header .header-nav .header-nav-item .header-nav-link:active,
.header .header-nav .header-nav-item .header-nav-link:visited {
    text-decoration: none;
}

.header .header-nav .header-nav-item .header-nav-link .avatar {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 50em;
    width: 36px;
    height: 36px;
}

.header .header-nav .header-nav-item .header-nav-link .avatar .avatar-img {
    width: 100%;
    height: 100%;
    color: #FFF;
    text-align: center;
    font-size: 16px;
    line-height: 36px;
    border-radius: 50em;
}

.header .header-nav .header-nav-item .dropdown-menu .dropdown-item a {
    color: #4f5d73;
}

.header .header-nav .header-nav-item .dropdown-menu .dropdown-item .icon {
    margin-right: 1rem;
    width: 1rem;
    height: 1rem;
    font-size: 1rem;
}

.header .subheader {
    border-top: 1px solid #d8dbe0;
    padding-left: 1rem !important;
    padding-right: 1rem !important;
    justify-content: space-between !important;
    display: flex;
    flex-basis: 100%;
    flex-shrink: 0;
    flex-grow: 1;
    width: 100%;
    height: 48px;
    background-color: #FFF;
}

.header .subheader .breadcrumb {
    padding-left: 1rem !important;
    padding-right: 1rem !important;
    margin: 0 !important;
    border: 0 !important;
    display: flex;
    flex-wrap: wrap;
    padding: 0.75rem 1rem;
    padding-right: 1rem;
    padding-left: 1rem;
    margin-bottom: 1.5rem;
    list-style: none;
    border-radius: 0;
    border-bottom: 1px solid;
    background-color: transparent;
    border-color: #d8dbe0;
}
.header .subheader .breadcrumb li {
    margin-top: 7px;
}

.header .subheader .breadcrumb-item::before {
    padding-right: 0.5rem;
}

.header .subheader .breadcrumb-item + .breadcrumb2-item::before {
    display: inline-block;
    color: #8a93a2;
    content: "/";
}

.header .subheader .breadcrumb-item + .breadcrumb2-item {
    padding-left: 0.5rem;
}

.contents {
    display: flex;
    flex-direction: row;
    flex-grow: 1;
    padding-left: 10px;
    padding-right: 10px;
    padding-top: 104px;
}

.contents .main-content {
    flex: 1;
    min-width: 0;
    padding-top: 2rem;
    padding-bottom: 100px;
}

.footer {
    display: flex;
    flex: 0 0 50px;
    flex-wrap: wrap;
    align-items: center;
    height: 50px;
    padding: 0 1rem;
    color: #4f5d73;
    background: #ebedef;
    border-top: 1px solid #d8dbe0;
}


.payslip-header {
    width: calc(100% - 6px) !important;
    margin-bottom: 0px !important;
    border-bottom-width: 0px !important;
}
.payslip-detail-wrapper {
    margin-top: -1px;
    width: 100%;
    height: 228px;
    overflow-x: hidden;
    overflow-y: scroll;
    scrollbar-width: thin;
    scrollbar-color: #999 transparent;
}
.payslip-detail-wrapper::-webkit-scrollbar {
    width: 6px;
}
.payslip-detail-wrapper::-webkit-scrollbar-thumb {
    background: #999;
    border-radius: 3px;
} 
.payslip-detail-wrapper::-webkit-scrollbar-track {
  background: transparent;
}

.payslip-detail-wrapper table {
    border-top-width: 0px !important;
}

.header2 {

}
.header-area {
    padding-top: 10px;
    padding-bottom: 5px;
    background-color: #4f5d73;
}
.header2 .header-area .header-title {
    text-align: center;
}
.header2 .header-menu {
    display: flex;
    padding-top: 5px;
    padding-bottom: 5px;
    background-color: #4f5d73;
}
.header2 .header-menu .header-nav {
    list-style: none;
}

.header2 .header-toggler {
    cursor: pointer;
    color: #FFF;
    border-color: rgba(0, 0, 21, 0.1);
    min-width: 50px;
    font-size: 1.09375rem;
    background-color: transparent;
    border: 0;
    border-color: currentcolor;
    border-radius: 0.25rem;
    padding: 0;
    margin-left: 0;
    border-style: none;
    outline: 0;
}

.header2 .header-toggler .icon-lg {
    width: 1.25rem;
    height: 1.25rem;
    font-size: 2rem;
    text-align: center;
}

.header2 .header-toggler .icon {
    display: inline-block;
    color: inherit;
    text-align: center;
    fill: currentColor;
}

.header2 .header-toggler:focus {
    outline: 0;
}

.header2 .header-toggler:hover {
    text-decoration: none;
}
.header2  .header-nav-link {
    position: relative;
}

@media screen and (max-width: 767px) { 
    .contents {
        padding-top: 0px;
        padding-left: 0px;
        padding-right: 0px;
    }
    .application-footer {
        margin-left: 0px !important;
        padding-right: 0px;
    }
}

.min-size-control {
    min-width: 80px;
}
.application-hide {
    text-align: center;
    display: block;
    color: #666;
    transition: .3s linear;
}
.application-hide:hover,
.application-hide:active,
.application-hide:link,
.application-hide:visited {
    color: #666;
    text-decoration: none;
}
.application-hide:hover {
    color: #999;
}

.top-wrapper {
    padding-left: 30px;
    padding-right: 30px;
}
@media screen and (max-width: 767px) { 
    .top-wrapper {
        padding-left: 5px;
        padding-right: 5px;
    }
}

.calc {
    position: relative;
}
.calc .calc_loading {
    position: absolute;
    top: 13px;
    left: calc(50% - 16px);
}

.copy-arrow {
    width: 100%;
    margin-left: auto;
    margin-right: auto;
}

.application-submenu {
    padding: 12px 15px;
    margin-bottom: 1rem;
    list-style: none;
    background-color: #B00000;
    border-radius: 5px;
    width: fit-content;
}
.application-submenu > li {
    display: inline-block;
    font-size: 16px;
    font-weight: 600;
}
.application-submenu > li > a {
    color: #F1F1F1;
}
.application-submenu > li > a:hover,
.application-submenu > li > a:active,
.application-submenu > li > a:visited {
    color: #F1F1F1;
    text-decoration: none;
}
.application-submenu > li + li:before {
    padding: 0 5px;
    color: #F1F1F1;
    content: "/\00a0";
}

.position-relative {
    position: relative;
}

.item-tab-close,
.company-item-tab-close {
    position:absolute;
    right: 5px;
    top: -70px;
}
.item-tab-close > a,
.company-item-tab-close > a {
    font-size: 24px;
}

.row-eq-height {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    margin-bottom: 2rem;
}
.row-eq-height .panel {
    height: 100%;
}

.dropdown-menu.right {
    left: auto;
    right: 0;
}
.nav-scroll {
    width: 100%;
    overflow-x: auto;
    overflow-y: hidden;
    scrollbar-width: thin;
    scrollbar-color: #999 transparent;
}

.nav-scroll::-webkit-scrollbar {
  height: 6px;
}
.nav-scroll::-webkit-scrollbar-thumb {
  background: #999;
  border-radius: 3px;
}
.nav-scroll::-webkit-scrollbar-track {
  background: transparent;
}

.nav-scroll > .nav {
    display: flex;
    justify-content: flex-start;
}
.nav-scroll > .nav > li {
    position: relative;
    flex: 0 0 auto;
}

.bg-image-none {
    background-image: none !important;
}

.button-area {
    margin-top: 20px;
}

.input-group > .form-control + .input-group-addon {
    border-left: none;
}

.input-group > .form-control ~ .input-group-addon {
    border-right: none;
}

.table>tbody>tr.lock>td,
.table>tbody>tr.lock>th,
.table>tbody>tr>td.lock,
.table>tbody>tr>th.lock,
.table>tfoot>tr.lock>td,
.table>tfoot>tr.lock>th,
.table>tfoot>tr>td.lock,
.table>tfoot>tr>th.lock,
.table>thead>tr.lock>td,
.table>thead>tr.lock>th,
.table>thead>tr>td.lock,
.table>thead>tr>th.lock {
	background-color: #BBB;
}

.flow-line1.active,
.flow-line2.active {
    color: #31708f;
    background-color: #d9edf7;
}

.preview-upload-area {
    position: relative;
}

.lock_upload {
    position: absolute;
    display: none;
    top:0;
    left:0;
    width: 100%;
    height: 100%;
    z-index: 99;
    
    background-color: rgba(68, 68, 68, 0.8);
}
.lock_upload.active {
    display: table !important;
}

.lock_upload > figure {
    display: table-cell;
    vertical-align: middle;
    text-align: center;
}
.lock_upload > figure > img {
    width: 64px;
    height: 64px;
}
.border-bottom-none {
    border-bottom: 0px !important;
}
.preview-button-area {
    margin-top: .25rem;
    margin-bottom: .25rem;
}
.preview-download-area {
    display: inline-block;
}
.preview-delete-area {
    display: inline-block;
}

#pTable {
    table-layout: fixed;
}

.d-none {
    display: none;
}

.fixed01,
.fixed02,
.fixed03,
.fixed04,
.fixed05 {
    position: sticky;
    top:0;
}

th.fixed01,
th.fixed02,
th.fixed03,
th.fixed04,
th.fixed05 {
    background: #2A3F54;
}
tr.even > td {
    background: #FFF;
}
tr.odd > td  {
    background: #f9f9f9;
}

.fixed01::before,
.fixed02::before,
.fixed03::before,
.fixed04::before,
.fixed05::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0px;
    width: calc(100% + 1px);
    height: calc(100% + 1px);
    border-collapse: collapse !important;
    border: 1px solid #ddd !important;
    border-collapse: inherit;
}
.fixed01{
    left: 0;
    z-index: 996;
}
.fixed02{
    left: 115px;
    z-index: 997;
}
.fixed03 {
    left: 315px;
    z-index: 998;
}
.fixed04 {
    left: 465px;
    z-index: 999;
}
.fixed05 {
    left: 545px;
    z-index: 1000;
}

.bg-blue {
    background-color: rgba(102, 153, 255, 0.4) !important;
}

.sample {
    min-height: 500px;
}

#preview {
    min-height: 500px;
}

.talk-room_comment-row {
    display: flex;
    align-items: stretch;
}

.talk-room_comment-row-icons {
    margin-right: 10px;
    display: flex;
    align-items: center;
    flex-direction: column;
}

.talk-room_comment-file-select-button {
    display: block;
    color: #637189;
    width: 30px;
}

.talk-room_comment-file-select-button > i {
    font-size: 25px;
    color: #637189;
}

.talk-room_comment-row-comment {
    flex-grow: 1;
}

.talk-room_comment-row-buttons {
    margin-left: 10px;
    margin-right: 5px;
    display: flex;
    align-items: end;
}

.talk-room_comment-row-buttons-button {
    margin-top: auto;
    display: block;
    color: #637189;
    width: 30px;
}

.talk-room_comment-row-buttons-button > i {
    font-size: 25px;
    color: #637189;
}

.dl-line {
    width: 100%;
}

.dl-line > dt {
    margin-bottom: 5px;
    width: 40%;
    float: left;
}

.dl-line > dd {
    margin-bottom: 5px;
    margin-left: 40%;
}

.border-radius-30 {
    border-radius: 30px !important;
}


.communication-date {
    width: 100%;
    text-align: center;
}
.communication-date > .date {
    display: inline-block;
    background-color: rgba(95,124,164, .7);
    color: #FFF;
    padding: 5px 15px;
    border-radius: 15px;
}

.ms-choice {
    padding: 6px 12px;
    height: 34px;
    font-size: 14px;
    line-height: 1.42857143;
    border: 1px solid #ccc;
    border-radius: 4px;
}
.ms-drop ul > li {
    padding: 6px 12px;
    font-size: 14px;
    line-height: 1.42857143;
}
.ms-choice > span {
    top: 7px;
}

.list_width_type_00 { min-width: auto; }
.list_width_type_01 { min-width: 100px; }
.list_width_type_02 { min-width: 200px; }
.list_width_type_03 { min-width: 300px; }
.list_width_type_04 { min-width: 400px; }
.list_width_type_05 { min-width: 500px; }

.btn-guide {
    font-weight: 600;
    margin-left: 15px;
    padding-top: 2px;
    padding-bottom: 2px;
}
.btn-guide > span {
    margin-left: 5px;
    font-size: 14px;
}
.guide-icon {
    width: 25px;
    height: 25px;
}