.header--teacher_2 {
 height: 5.0vh;
 text-align: center;
 color: #515d62;
 display: -webkit-box;
 display: -webkit-flex;
 display: -ms-flexbox;
 display: flex;
 -webkit-box-pack: center;
 -webkit-justify-content: center;
 -ms-flex-pack: center;
 justify-content: center;
 -webkit-box-align: center;
 -webkit-align-items: center;
 -ms-flex-align: center;
 align-items: center;
 position: relative;
 background-color: #4c556e;
}
.header--teacher_2 .btn_back {
 position: absolute;
 top: 0;
 left: 0;
 width: 5.0vh;
 height: 5.0vh;
 padding: 0.5em;
}
.header--teacher_2 .btn_back img {
 width: 100%;
 height: 100%;
}
.page_controller_2 .btn_gray {
 background-color: #686f82;
 color: #fff;
 font-size: 16px;
 padding: 0.2em 1.0em;
 border-radius: 20px;
 position: absolute;
 top: 50%;
 transform: translate(0, -50%);
}
.page_controller_2 .btn_revice {
 right: 5px;
}
.page_controller_2 {
 height: 5vh;
 display: flex;
 justify-content: center;
 align-items: center;
 padding: 0.5em 1em;
 position: absolute;
 width: 100%;
}
.page_controller_2 .from_school_schedule_date {
 display: flex;
 align-items: center;
 color: #ffffff;
}

.page_controller_2 .from_school_schedule_date .calender {
  width: 3vw;
  position: relative;
}

@media screen and (max-width: 1024px) {
  .page_controller_2 .from_school_schedule_date .calender {
    width: 4.5vw;
    position: relative;
  }
}

.page_controller_2 .from_school_schedule_date .day_prev {
  margin-right: 1em;
}

.page_controller_2 .from_school_schedule_date .day_prev img, .from_school_schedule_date .day_next img {
 max-width: 36px;
	width: 4vh;
}

.page_controller_2 .from_school_schedule_date .day_next {
  margin-left: 1em;
}

.page_controller_2 .from_school_schedule_date .day_of_the_week {
  font-size: 0.8em;
  margin-left: 0.7em;
}

.page_controller_2 .shift_btn_area {
  position: absolute;
  right: 0;
}

.page_controller_2 .shift_btn_area .btn_henkou {
  line-height: 1.2em;
  background-color: #686f82;
  color: #fff;
  font-size: 1.1vw;
  padding: 0.3em;
  border-radius: 6px;
  float: left;
  margin-right: 3px;
}

@media screen and (max-width: 1024px) {
  .page_controller_2 .shift_btn_area .btn_henkou {
    padding: 0.5em;
  }
}

.page_controller_2 .shift_btn_area .btn_henkou img {
  display: block;
  height: 1.2em;
}

/*.page_controller_2 .from_school_schedule_date .calender label{*/
	/*position: inherit;
	line-height: inherit;
	font-size: initial;*/
/*}*/

.page_controller_2 .from_school_schedule_date .calender label::before {
    position: absolute;
    bottom: 0%;
    top: 0%;
    right: 0;
	  margin: auto;
    content: "";
    display: block;
    width: 4vh;
    height: 4vh;
    box-sizing: border-box;
    transform: translate(0, 0)!important;
    background-color: #ffffff;
    background-repeat: no-repeat;
    border-radius: 5px;
    border: solid 1px #394055;
}

.header--teacher_2 .from_school_schedule_date .calender label::after {
    position: absolute;
    top: 0%;
    bottom: 0%;
    right: 0.5vh;
    margin: auto;
    content: "";
    display: block;
    width: 3vh;
    height: 3vh;
    transform: translate(0, 0)!important;
    background-image: url(../img/ic/calender.svg);
    background-repeat: no-repeat;
}

.grid_sidenav_2 {
 z-index: 999;
}
.work_name_list li.select_all {
  width: 260px!important;
  height: 70px!important;
  padding: 10px 0.3em 10px 2.0vh;
  /*background-color: #0fc458;*/
  border-bottom: 1px solid #a2a8b9;
}
.work_name_list li.select_all p {
  line-height: 51px;
  font-size: 2.0vh;
  /*color: #ffffff;*/
  padding: 0!important;
}
.work_name_list .category_select {
  background-color: #ddf2d8;
}
.work_name_list#table_side {
 overflow-y: auto;
}
.from_school_schedule_side_wrap > .work_name_list {
 width: 100%;
 height: 100%;
}
.from_school_schedule_side_wrap > .work_name_list li.side_schedule_row {
 height: 5.1vw;
 border-bottom: 1px solid #a2a8b9;
}
.work_name_list {
 width: 80%;
 background-color: #fff;
 -webkit-overflow-scrolling: touch;
 overflow-scrolling: touch;
}
.work_name_list li {
 width: 100%;
 height: 6.8vh;
 font-size: 2vh;
 color: #5d686c;
}
.work_name_list li:not(.side_nap_check_row) p {
 width: 100%;
 height: 100%;
 display: -webkit-box;
 display: -webkit-flex;
 display: -ms-flexbox;
 display: flex;
 -webkit-box-align: center;
 -webkit-align-items: center;
 -ms-flex-align: center;
 align-items: center;
 padding: 0 0.3em 0 1.0em;
}
/*@media screen and (min-width: 1360px) {
 .work_name_list li p {
  width: 80%;
  padding-left: 1.0em;
  font-size: 2vh;
  word-break: break-word;
 }
}*/
#grid_container_workschedule {
 position: relative;
 overflow-y: scroll;
}

/* sticky table */
.sticky_table_wrapper {
 /*overflow: scroll;*/
 width: 100%;
 z-index: 1;
 /*height: 75vh;*/
}
.sticky_table thead .name_line th {
 height: 50px;
 width: 12vw;
 /* 縦スクロール時に固定する */
 position: -webkit-sticky;
 position: sticky;
 /* 高さが変わらないよう改行させない */
 /*white-space: nowrap;*/
	padding: 0.2em;
	box-sizing: border-box;
  word-wrap: break-word;
  overflow-wrap: break-word;
  text-align: center!important;
  background: #e6e7ed;
  color: #5d686c;
  font-size: inherit;
  line-height: 1.4em;
  z-index: 997;
  /*padding-bottom: 1.6em;*/
}
/*@media screen and (min-width: 1500px) {*/
/*  .sticky_table thead th {*/
/*    font-size: 16px;*/
/*  }*/
/*}*/
.sticky_table thead .s-n-p_line th {
  height: 20px;
  width: 6vw;
  /* 縦スクロール時に固定する */
  position: -webkit-sticky;
  position: sticky;
  /* 高さが変わらないよう改行させない */
  box-sizing: border-box;
  word-wrap: break-word;
  overflow-wrap: break-word;
  text-align: center !important;
  background: #e6e7ed;
  color: #5d686c;
  font-size: 0.8vw;
  line-height: 20px;
  z-index: 980;
}
.sticky_table thead .s-n-p_line th:nth-child(odd) {
  border-right: none;
}
.sticky_table thead .s-n-p_line th:nth-child(even) {
  border-leftt: none;
}
.sticky_table thead .name_line th:after {
  content: "/";
  position: absolute;
  width: 12vw;
  height: 20px;
  bottom: -20px;
  left: 8%;
  line-height: 20px;
  right: 0%;
  z-index: 999;
  font-size: 0.8vw;
}
.sticky_table thead .name_line th:first-child::after {
  content: none;
}

.sticky_table thead tr:nth-child(1) th {
 top: 0;
}
.sticky_table thead tr:nth-child(2) th {
 top: 5rem; /* 2行目は1行目の高さの位置に固定する */
}
.sticky_table thead tr:nth-child(3) th {
 top: 3rem; /* 3行目は1〜2行目の高さの位置に固定する */
}
.sticky_table th:first-child {
 /* 横スクロール時に固定する */
 position: -webkit-sticky;
 position: sticky;
 left: 0;
 background: #ffffff;
	z-index: 990;
}
.sticky_table thead th:first-child {
 /* ヘッダー行内の他のセルより手前に表示する */
 /*z-index: 2;*/
}
.sticky_table {
 border-collapse: separate;
	border-spacing: 0;
  table-layout: fixed;
  /*width: 100%;*/
}
.sticky_table th, .sticky_table td {
 text-align: center;
 font-weight: normal;
 height: 5.1vw;
 border-bottom: 1px solid #a2a8b9;
 border-right: 1px solid #a2a8b9;
}
/*.sticky_table thead th {*/
/* background: #e6e7ed;*/
/* color: #5d686c;*/
/* font-size: 1vw;*/
/* line-height: 1.4em;*/
/*	z-index: 999;*/
/*  !*word-wrap: break-all;*!*/
/*  overflow-wrap: break-word;*/
/*  text-align: center;*/
/*}*/
#work_type th p {
 font-size: 1vw;
 font-weight: 100;
 color: #5d686c;
 height: 100%;
 text-align: center;
 position: relative;
}
.sticky_table thead .name_line th:first-child {
 height: 70px;
 background: #e6e7ed !important;
 line-height: 25px;
 padding: 0.4em;
	z-index: 998;
  width: 8vw!important;
  max-width: 8vw!important;
  min-width: 262px;
}
.sticky_table thead tr th:first-child p {
  background: #ffcccc;
  position: relative;
  top: 0%;
  bottom: 0%;
  margin: auto;
  display: contents;
}
.sticky_table tbody td {
  width: 6vw;
  max-width: 6vw;
  /*min-width: 80px;*/
  min-width: 7.1vw;
}
.work_time {
 display: block;
 position: absolute;
 top: 0;
 width: 100%;
 background: #a2a8b9;
 border-right: 1px solid #a2a8b9;
	border-collapse: separate;
	border-spacing: 0;
 color: #ffffff;
 padding: 0.4em 0;
}
.work_num {
 padding-top: 2.4em;
 width: 100%;
 display: block;
 font-size: 1.2vw;
 font-weight: bold;
 letter-spacing: 0.2em;
}
span.gray_txt {
 color: #98a0a3;
 display: contents;
}

.start_work_plan{
	position: relative;
}

/*.start_work_plan::after{*/
/*content: "";*/
/*	width: 3vw;*/
/*	height: calc( 5.07vw * 14 );!*マスの数*!*/
/*	background: #cacdd8;*/
/*	position: absolute;*/
/*	top: 0;*/
/*	left: 0%;*/
/*	right: 0%;*/
/*	margin: auto;*/
/*	border-radius: 2vw;*/
/*	z-index: -100;*/
/*}*/

.start_work_result{
	position: relative;
}

/*.start_work_result::after{*/
/*content: "";*/
/*	width: 3vw;*/
/*	height: calc( 5.07vw * 16 );!*マスの数*!*/
/*	background: #4c556e;*/
/*	position: absolute;*/
/*	top: 0;*/
/*	left: 0%;*/
/*	right: 0%;*/
/*	margin: auto;*/
/*	border-radius: 2vw;*/
/*	z-index: -100;*/
/*}*/

/*@media screen and (min-width: 1350px) {*/
/*.start_work_plan::after{*/
/*content: "";*/
/*	width: 3vw;*/
/*	height: calc( 5.1vw * 14 );!*マスの数*!*/
/*	background: #cacdd8;*/
/*	position: absolute;*/
/*	top: 0;*/
/*	left: 0%;*/
/*	right: 0%;*/
/*	margin: auto;*/
/*	border-radius: 2vw;*/
/*	z-index: -100;*/
/*}*/

/*.start_work_result::after{*/
/*content: "";*/
/*	width: 3vw;*/
/*	height: calc( 5.1vw * 16 );!*マスの数*!*/
/*	background: #4c556e;*/
/*	position: absolute;*/
/*	top: 0;*/
/*	left: 0%;*/
/*	right: 0%;*/
/*	margin: auto;*/
/*	border-radius: 2vw;*/
/*	z-index: -100;*/
/*}*/
/*}*/

.sticky_table thead th span {
  width: auto;
  display: inline-block;
  margin: 0 auto;
  padding-left: 3.8vh;
  position: relative;
}
.sticky_table thead th:first-child span {
  padding: 0;
}
.sticky_table thead th .s-n-p {
  padding: 0;
  font-size: 1vw;
  position: absolute;
  bottom: 0.2em;
  left: 0%;
  right: 0%;
  margin: auto;
}
.sticky_table thead th span img {
  width: 3.2vh;
  position: absolute;
  left: 0;
  top: 0%;
  bottom: 0%;
  margin: auto;
}
.work_name_list .side_schedule_row p span {
  width: 3vh;
  height: 1em;
  margin-right: 0.5em;
}
