/*テンプレート変更*/
#change-template-modal .template_list{
  width:100%;
  height: 20vw;
  border: 1px solid #CCCCCC;
}

/*ラジオボタン*/
#change-template-modal input[type="radio"] {
  display: none;
}

#change-template-modal input[type="radio"]:checked + label {
  background: #30C40C;
  border: 1px solid #ccc;
  color: #fff;
  padding: 0.2em 1em;
  border-radius: 10px;
}
@media screen and (max-width: 1280px) and (min-width: 500px) {
  #change-template-modal input[type="radio"]:checked + label {
    padding: 0.4em 1em;
  }
}

#change-template-modal input[type="radio"] + label {
  background: #fff;
  border: 1px solid #ccc;
  padding: 0.2em 1em;
  border-radius: 10px;
}

@media screen and (max-width: 1280px) and (min-width: 500px) {
  #change-template-modal input[type="radio"] + label {
    padding: 0.4em 1em;
  }
}

#change-template-modal div.template_button {
  margin: 1vw 1vw 1.5vw 1vw;
  white-space: nowrap;
}

#change-template-modal .template_preview {
  width:100%;
  height: 20vw;
  border: 1px solid #CCCCCC;
}

#change-template-modal button.btn_color_green {
  margin: 0 0 25px 25px;
}

#change-template-modal button.btn_color_white {
  margin: 0 0 0 25px;
}

#change-template-modal{
  font-size:1.2vw;
}

#change-template-modal .modal_contents_form{
  color:#5d686c;
}

#change-template-modal div div.modalL{
  width:48%;
  padding:0.5vw 0 0 0;
  float:left;
  line-height:1.5em;
  margin-right: 0.75em;
}

#change-template-modal div.modalR{
  width:49%;
  padding:10px;
  float:right;
  line-height:1.5em;
  margin-left: 0.75em;
}

#change-template-modal .scroll {
  width: 100%;
  height: 100%;
  overflow-y: auto;
  word-break: break-all;
  word-wrap: normal;
  position: relative;/*追加*/
}

#modal_tyohyou_area {
  width: 1000px;
  transform: scale(0.3);
  transform-origin: 2% 0;
  position: absolute;
}

/*タグ変更*/
#hidetag-modal .modal_contents_form .tyusyaku {
  color: #FF0000;
  font-size: 16px;
  margin-bottom: 2vw;
}
#hidetag-modal .modal_contents_form .tag_table {
  max-height: 270px;
  overflow-y: scroll;
  padding-right: 10px;
}
#hidetag-modal .modal_contents_form table {
  width: 100%;
  border: 1px solid #C3C3C3;
  font-size: 15px;
  table-layout: fixed;
  color: #4C556E;
}
#hidetag-modal .modal_contents_form table th, #hidetag-modal .modal_contents_form table td {
  border: 1px solid #C3C3C3;
  font-weight: 400;
  box-sizing: border-box;
  vertical-align: top;
  padding: 10px;
  text-align: left;
  word-wrap: break-word;
  width: calc((100% - 60px) / 3);
}
#hidetag-modal .modal_contents_form table th, #hidetag-modal .modal_contents_form table td:last-of-type {
  width: 60px;
}
#hidetag-modal .modal_contents_form table thead th {
  font-weight: 600;
  text-align: center;
  letter-spacing: 0.14em;
}
#hidetag-modal .modal_contents_form table thead th:last-of-type {
  width: 1vw;
}
@media screen and (max-width: 1280px) and (min-width: 500px) {
  #hidetag-modal .modal_contents_form table thead th:last-of-type {
    width: 3vw;
  }
}
#hidetag-modal .modal_contents_form table tbody td.naiyou p {
  max-height: 100px;
  min-height: 38px;
  overflow-y: scroll;
  padding-right: 10px;
  line-height: 1.2em;
}
#hidetag-modal .modal_contents_form table tbody td select {
  width: 100%;
  height: 38px;
  padding: 10px 40px 10px 10px;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  border: 1px solid #DCDCDC;
  box-shadow: 0px 0px 5px 2px #dcdcdc inset;
  border-radius: 10px;
  background: url(../img/arrow02.jpg) right 50% no-repeat, #fff;
  background-size: 40px;
  line-height: 1.5em;
  cursor: pointer;
}
#hidetag-modal .modal_contents_form table tbody td:last-of-type button{
  display: block;
  margin: 0 auto;
}

/*登録ポップアップ　※個別計画*/
#teaching-modal .modal_contents_form .any_contents{
  height: 194px;
}

/*登録ポップアップ　※印鑑以外*/
#teaching-modal .modal_contents_form {
  display: flex;
  font-size: 15px;
  height: 215px;
}
#teaching-modal .textbox {
  width: 22vw;
  height: 280px;
  margin-right: 20px;
}
#teaching-modal .textbox textarea {
  border-radius: 6px;
  border: 1px solid #30C40C;
  height: 140px;
  margin-bottom: 10px;
  box-sizing: border-box;
  padding: 10px;
  width: 100%;
}
#teaching-modal .textbox button {
  background: #30C40C;
  width: 116px;
  height: 30px;
  border-radius: 6px;
  line-height: 30px;
  margin: 0 0 0 auto;
  display: block;
  color: #fff;
}
#teaching-modal .textlist {
  width: calc(100% - 22vw - 20px);
  height: 187px;
  border: 1px solid #C3C3C3;
  box-sizing: border-box;
  border-radius: 6px;
  padding: 10px;
}
#teaching-modal .textlist ul {
  overflow-y: scroll;
  height: 100%;
}
#teaching-modal .textlist li {
  display: flex;
  margin-bottom: 10px;
}
#teaching-modal .textlist li:last-of-type{
  margin-bottom: 0;
}
#teaching-modal .textlist li p {
  background: #535E64;
  border-radius: 6px;
  padding: 10px;
  width: calc(100% - 65px);
  margin-right: 20px;
  color: #fff;
  line-height: 1.4em;
  letter-spacing: 0.08em;
  cursor: pointer;
}
#teaching-modal .textlist li p span{
  /* 3点リーダー */
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  word-break: break-all;
}
#teaching-modal .textlist li > div {
  position: relative;
  width: 45px;
}
#teaching-modal .textlist li > div button {
  position: absolute;
  left: 0;
  top: 0%;
  bottom: 0%;
  margin: auto;
}
@media screen and (max-width: 1280px) {
  #teaching-modal .textlist li p {
    line-height: 1em;
  }
  #teaching-modal .textlist li p span{
    font-size: 1.2vw;
  }
  .textlist li > div button img{
    width: 85%;
    height: 85%;
    object-fit: contain;
  }
}

/*個別指導計画*/
#teaching-modal .change_display {
  appearance: none;
  width: 1.5vw;
  height: 1.5vw;
  border: 1px solid #DCDCDC;
  border-radius: 0;
  box-shadow: 0 0 5px 2px #DCDCDC inset;
  margin-right: 10px;
  font-size: 1.8vw;
  font-weight: bold;
}
#teaching-modal label{
  font-size: 18px !important;
  font-weight: bold;
  color: #4c556e;
  font-family: 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', Meiryo, メイリオ, Osaka, 'MS PGothic', arial, helvetica, sans-serif;
}
@media screen and (max-width: 1280px) {
  #teaching-modal label{
    font-size: 14px !important;
  }
}
#teaching-modal input.change_display[type="checkbox"]:checked {
  background: url(../img/check.png) 50% 50% no-repeat;
  opacity: 1;
}

/*印鑑登録ポップアップ*/
#teaching-stamp-modal .modal_contents_form {
  display: flex;
  font-size: 15px;
}
#teaching-stamp-modal .textbox {
  /*width: 260px;*/
  width: 22vw;
  height: 240px;
  margin-right: 20px;
}
#teaching-stamp-modal .textbox textarea {
  border-radius: 6px;
  border: 1px solid #30C40C;
  height: 240px;
  margin-bottom: 10px;
  box-sizing: border-box;
  padding: 10px;
  width: 100%;
}

#teaching-stamp-modal .textlist {
  width: calc(100% - 22vw - 20px);
  height: 240px;
  border: 1px solid #C3C3C3;
  box-sizing: border-box;
  border-radius: 6px;
  padding: 10px;
}
#teaching-stamp-modal .textlist ul {
  overflow-y: scroll;
  height: 100%;
}
#teaching-stamp-modal .textlist li {
  display: flex;
  margin-bottom: 10px;
}
#teaching-stamp-modal .textlist li:last-of-type{
  margin-bottom: 0;
}
#teaching-stamp-modal .textlist li p {
  background: #535E64;
  border-radius: 6px;
  padding: 10px;
  color: #fff;
  line-height: 1.4em;
  letter-spacing: 0.08em;
  cursor: pointer;
}
@media screen and (max-width: 1280px) {
  #teaching-stamp-modal .textbox textarea {
    font-size: 15px;
  }
  #teaching-stamp-modal .textlist li p {
    line-height: 1em;
  }
  #teaching-stamp-modal .textlist li p span{
    font-size: 1.2vw;
  }
}

/*園児名登録ポップアップ*/
#teaching-kid-modal .kid_list{
  width:100%;
  height: 20vw;
  border: 1px solid #CCCCCC;
  padding:10px;
  line-height:1.5em;
}

#teaching-kid-modal input[type="radio"]:checked + label {
  background: #30C40C;
  border: 1px solid #ccc;
  color: #fff;
}
#teaching-kid-modal input[type="radio"] + label {
  background: #fff;
  border: 1px solid #ccc;
  padding: 0.2em 1em;
  border-radius: 10px;
  display: inline-block;
  margin: 0 5px 5px 0;
  cursor: pointer;
}

#teaching-kid-modal div.kid_button_area {
  width: 100%;
  overflow-y: auto;
}

#teaching-kid-modal button.btn_color_green {
  margin: 0 0 25px 25px;
}

#teaching-kid-modal button.btn_color_white {
  margin: 0 0 0 25px;
}

#teaching-kid-modal{
  font-size:1.2vw;
}

#teaching-kid-modal .modal_contents_form{
  color:#5d686c;
}

#teaching-kid-modal .scroll{
  width:100%;
  height: 35vh;
  overflow-y:auto;
  word-break:break-all;
  word-wrap:normal;
  white-space:pre-wrap;
}
@media screen and (max-width: 1280px) and (min-width: 500px) {
  #teaching-kid-modal .scroll {
    height: 23vh;
  }
}

/* 基本案挿入ポップアップで使用 */
#insert-draft-modal{
  font-size:1.2vw;
}

#insert-draft-modal .modal_contents_inner {
  max-width: 80vw; /* 画面幅の80%までに制限 */
  max-height: 80vh; /* 画面高さの80%までに制限 */
  overflow: auto; /* 必要に応じてスクロールを表示 */
}

#insert-draft-modal .draft_button {
  display: flex;
  justify-content: space-between; /* ボタン間のスペースを均等に分配 */
  align-items: center;
}

#insert-draft-modal .btn_sounyu {
  margin: 1.0vw auto 0;
  left: 6.0vw;
  position: relative;
  list-style: none;
}

@media screen and (max-width: 1280px) {
  #insert-draft-modal .btn_sounyu {
    left: 8vw;
  }
}

#insert-draft-modal .btn_sounyu_under {
  position: static;
}

#insert-draft-modal .draft_footer {
  display: flex;
}

#insert-draft-modal .btn_sounyusettei {
  position: relative;
  list-style: none;
}

#insert-draft-modal .btn_sounyu button {
  width: 180px;
  height: 60px;
  border-radius: 100px;
  box-shadow: none;
  background: linear-gradient(to right, #2ED803, #07C184); /* グラデーション */
  line-height: 1em;
  color: #fff;
  font-size: 1.4vw;
  text-align: center;
}

@media screen and (max-width: 1280px) {
  #insert-draft-modal .btn_sounyu button {
    width: 150px;
    height: 50px;
    font-size: 1.8vw;
  }
}

#insert-draft-modal .btn_sounyusettei button {
  float: right;
  padding: 0.2em 1em 0.2em 1em;
  background-color: #30c40c;
  position: relative;
  border-radius: 20px;
  color: #fff;
  font-size: 1.2vw;
  margin: auto 1.5em;
}

@media screen and (max-width: 1280px) {
  #insert-draft-modal .btn_sounyusettei button {
    padding: 0.3em 2em 0.5em 2em;
    font-size: 1.4vw;
  }
}

#insert-draft-modal .button-html-spacing {
  margin: 1em 1.5em /* 上側のスペースを調整 */
}

#teaching-modal .comment_textbox {
  width: -webkit-fill-available;
  height: 200px;
}
#teaching-modal .comment_textbox textarea {
  border-radius: 6px;
  border: 1px solid #30C40C;
  height: 100%;
  margin-bottom: 10px;
  box-sizing: border-box;
  padding: 10px;
  width: 100%;
}

#teaching-calendar-modal .modal_contents_inner{
  overflow: hidden;
}

#teaching-calendar-modal .container {
  display: flex;
  flex-direction: column;
  align-items:flex-start;
  padding: 10px;
}

#teaching-calendar-modal .container-year {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items:center;
  height: 12.8vw
}

#teaching-calendar-modal .container-month {
  display: flex;
  flex-direction: column;
  align-items:left;
  padding-left: 2.2vw;
  padding-right: 2.2vw
}

#teaching-calendar-modal .dropdown-container {
  margin-bottom: 20px;
}

#teaching-calendar-modal .container div.category-year {
  padding-bottom: 3.2vw;
}

#teaching-calendar-modal label {
  font-weight: bold;
  margin-right: 10px;
}

#teaching-calendar-modal select {
  padding: 1vh;
  font-size: 1.3vw;
}

#teaching-calendar-modal div.modal_contents_form {
  justify-content: center;
  padding: 2vw;
}

#teaching-calendar-modal .months {
  display: flex;
  flex-direction: column;
  align-items:left;
  padding-top: 2vw;
}

#teaching-calendar-modal .years {
  display: flex;
  flex-direction: column;
}

#teaching-calendar-modal .row {
  display: flex;
  align-items: center;
  height: 7.3vw;
}

#teaching-calendar-modal .row-over {
  display: flex;
  height: 7.3vw;
}

#teaching-calendar-modal .row-under {
  display: flex;
  height: 7.3vw;
}

#original-calendar-modal .row-original {
  display: flex;
  align-items: center;
}

#teaching-calendar-modal .month {
  width: 7.3vw;
  height: 7.3vw;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  margin-right: -1px;
  cursor: pointer;
}

#teaching-calendar-modal .row-over .month-text {
  width: 7.3vw;
  height: 2.2vw;
  line-height: 2.2vw;
  font-size: 1.1vw;
  border: 1px solid #C3C3C3; /* 枠線のスタイル */
  border-bottom-width: 0; /* 下のボーダーを非表示にする */
  color: #4C556E; /* 背景色 */
  background-color: #ededed; /* 背景色 */
  text-align: center;
  align-items: center;
  justify-content: center;
  letter-spacing: 0.0825vw;
}

#teaching-calendar-modal .row-under .month-text {
  width: 7.3vw;
  height: 2.2vw;
  line-height: 2.2vw;
  font-size: 1.1vw;
  border: 1px solid #C3C3C3; /* 枠線のスタイル */
  border-top-width: 0; /* 上のボーダーを非表示にする */
  border-bottom-width: 0; /* 下のボーダーを非表示にする */
  color: #4C556E; /* 背景色 */
  background-color: #ededed; /* 背景色 */
  text-align: center;
  align-items: center;
  justify-content: center;
  letter-spacing: 0.0825vw;
}

#teaching-calendar-modal .month-image {
  border: 1px solid #C3C3C3; /* 枠線のスタイル */
  background-color: #fff; /* 白の背景色 */
  width: 7.3vw;
  height: 5.1vw;
  align-items: center;
  text-align: center;
  display: flex;
  justify-content: center;
  margin-bottom: -1px;
}

#teaching-calendar-modal .month-image img {
  width: 2.9vw;
  height: 2.9vw;
}

#teaching-calendar-modal .year {
  width: 8.78vw;
  height: 7.32vw;
  display: flex;

  flex-direction: column;
  align-items: center;
  justify-content: center;
  margin-right: -1px;
  cursor: pointer;
}

#teaching-calendar-modal .year-text {
  width: 8.78vw;
  height: 2.2vw;
  line-height: 2.2vw;
  font-size: 1.1vw;
  border: 1px solid #C3C3C3; /* 枠線のスタイル */
  color: #4C556E; /* 背景色 */
  background-color: #ededed; /* 背景色 */
  text-align: center;
  align-items: center;
  justify-content: center;
  letter-spacing: 0.0825vw;
}

#teaching-calendar-modal .year-image {
  border: 1px solid #C3C3C3;
  border-top-width: 0; /* 上のボーダーを非表示にする */
  background-color: #fff;
  width: 8.78vw;
  height: 5.12vw;
  text-align: center!important;
  display: flex;
  justify-content: center!important;
  align-items: center!important; /* 画像を垂直方向に中央揃えするために追加 */
}

#teaching-calendar-modal .year-image img {
  width: 2.93vw;
  height: 2.93vw;
}

#teaching-calendar-modal .year_prev img, .year_next img {
  width: 2.2vw;
  height: 2.2vw;
  margin-right: 1.46vw;
  margin-left: 1.46vw;
  margin-top: 2.56vw;
  margin-bottom: 2.56vw;
}

#teaching-calendar-modal .common-select {
  display: flex;
  justify-content: left;
  align-items: center;
  text-align:center;
}

#teaching-calendar-modal .common-select select {
  width: 8.8vw;
  height: 2.9vw;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  border: 1px solid #DCDCDC;
  box-shadow: 0px 0px 5px 2px #DCDCDC inset;
  border-radius: 10px;
  background: url(../img/arrow02.jpg) right 50% no-repeat, #fff;
  background-size: 3.3vw;
  font-size: 1.3vw;
  color:#4C556E;
  text-align: center;
  display: inline-block;
}

#teaching-calendar-modal div.common-select select {
  float: left;
  text-align: left;
}

#teaching-calendar-modal div.year-add {
  float: left;
  margin: 0 0 0 20px;
  cursor: pointer;
  padding-top: 5px; /*20210716*/
}

#teaching-calendar-modal p.year-add-txt {
  font-size: 15pt;
  color:#4C556E;
  float: left;
  margin: 0 0 0 15px;
  line-height: 2.93vw;
}

#teaching-calendar-modal p.week-add-txt {
  font-size: 1.3vw;
  color:#4C556E;
  float: left;
  margin: 2vw 0 0 3.2vw;
  line-height: 2.93vw;
}

#teaching-calendar-modal p.month-add-txt {
  font-size: 1.3vw;
  color:#4C556E;
  float: left;
  line-height: 2.93vw;
}

#teaching-calendar-modal .year_prev, .year_next {
  display: flex;
  align-items: center;
}

#teaching-calendar-modal .image-container .hidden-image {
  opacity: 0;
  transition: opacity 0.2s ease;
}

#teaching-calendar-modal .year.grayed{
  cursor: default;
}
#teaching-calendar-modal .year.grayed .year-image{
  background-color: #f2f2f2;
}
#original-calendar-modal .modal_contents_form {
  justify-content: center;
  padding: 1vw;
}
#original-calendar-modal .container-month {
  display: flex;
  flex-direction: column;
  align-items:left;
}
#original-calendar-modal .modal_contents_inner{
  overflow: hidden;
}
#original-calendar-modal .modal_contents_inner .modal_heading_title{
padding: 0;
}
#original-calendar-modal .modal_contents_inner .modal_heading{
border-bottom: 2px solid #515d62;
padding:10px;
}
#original-calendar-modal .modal_contents_inner .common-select{
display: flex;
  flex-wrap: wrap;
font-size:1.2vw ;
align-items: center;
margin-bottom:0.9vw;
color: #4c556e;
}
#original-calendar-modal .modal_contents_inner .common-select select{
width: 6.2vw;
height: 2vw;
padding: 1px 10px;
font-size:1.2vw;
border: 1px solid #dcdcdc;
box-shadow: 0px 0px 5px 2px #dcdcdc inset;
border-radius: 0.5vw;
background: url(../img/arrow02.jpg) right 50% no-repeat, #fff;
background-size: 2.1vw;
cursor: pointer;
-webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
color: #4c556e;
}
#original-calendar-modal .modal_contents_inner .common-select .original_year_text{
  padding: 0 1vw 0 0;
}
#original-calendar-modal .modal_contents_inner .common-select .childcare_year_text{
  padding: 0 1vw;
}
#original-calendar-modal .modal_contents_inner .modal_contents_form{
margin: 0 4.6vw;
}
#original-calendar-modal .modal_contents_inner .modal_contents_form .days{
font-size: 1.1vw;
}
#original-calendar-modal .modal_contents_inner .modal_contents_form .dayweek ul{
display: flex;
  flex-wrap: wrap;
border: 1px solid #b4b4b4;
}
#original-calendar-modal .modal_contents_inner .modal_contents_form .dayweek ul li{
width: calc(100% / 7);
line-height: 1.9em;
list-style: none;
text-align: center;
background-color: #686f80;
color:#fff;
border-right: 1px solid #b4b4b4;
font-weight: bold;
}
#original-calendar-modal .modal_contents_inner .modal_contents_form .dayweek ul li:last-child{
border-right: none;
}
#original-calendar-modal .modal_contents_inner .modal_contents_form .dayweek ul li.bg_red{
color:#e693b4;
}
#original-calendar-modal .modal_contents_inner .modal_contents_form .dayweek ul li.bg_blue{
color:#8aa7d3;
}
#original-calendar-modal .modal_contents_inner .modal_contents_form .row-original {
display: flex;
  flex-wrap: wrap;
}
#original-calendar-modal .modal_contents_inner .modal_contents_form .row-original .day{
width: calc((100% - 1px) / 7);
text-align: center;
border-bottom: 1px solid #b4b4b4;
border-left: 1px solid #b4b4b4;
}
#original-calendar-modal .modal_contents_inner .modal_contents_form .row-original .day:last-child{
border-right: 1px solid #b4b4b4;
}
#original-calendar-modal .modal_contents_inner .modal_contents_form .row-original .day .day-text{
line-height: 1.4em;
background-color: #eeeeee;
color: #4c556e;
height: 1.4em;
font-size: 15px;
}
#original-calendar-modal .modal_contents_inner .modal_contents_form .row-original .day-image{
  height: 4vw;
}
#original-calendar-modal .modal_contents_inner .modal_contents_form .row-original .day-image img{
height: 2.7vw;
margin: 0.6vw 0;
}

/* CSS Document */
/* @charset "UTF-8"; */

.teaching_calendar_pop {
  padding-top: 1vw!important;
  padding-bottom: 1vw!important;
  padding-left: 0!important;
  padding-right: 0!important;
}

.teaching_calendar_pop .day_select {
  display: flex;
}
.teaching_calendar_pop .calendar_select_area {
  display: flex;
  padding-top: 4%;
  justify-content: center;
}
.syuunichi_ca_table thead:first-child{
  height:10%;
}
.teaching_calendar_pop .day_select select:first-child{
  margin-left: 3.9vw;
}
.teaching_calendar_pop .day_select select {
  width: 120px;
  height: 40px;
  padding: 1vh;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  border: 1px solid #DCDCDC;
  box-shadow: 0px 0px 5px 2px #DCDCDC inset;
  border-radius: 10px;
  background: url(../img/arrow02.jpg) right 50% no-repeat, #fff;
  background-size: 40px;
  cursor: pointer;
  margin-top: 3.6%;
  font-size: 1.3vw;
  line-height: 1.3vw;
}
.teaching_calendar_pop .day_select p{
  font-size:1.3vw;
  line-height: 40px;
  padding:0 1vw 0 1vw;
  margin-top: 3.6%;
}

.teaching_calendar_pop table.syuunichi_ca_table{
  width:5.9vw;
  margin-right: 1.4vw;
}
.teaching_calendar_pop table.ca_table_area{
  width: 70.3%;
}
.teaching_calendar_pop table.ca_table_day thead tr th{
  writing-mode:inherit;
}
.teaching_calendar_pop table.syuunichi_ca_table tr:first-child{
  border: none;
}
.teaching_calendar_pop table.syuunichi_ca_table tr,.teaching_calendar_pop table.ca_table_area tr{
  border:1px solid #c3c3c3;
}
.teaching_calendar_pop table tr:nth-child(odd) td{
  background: #f7f7f7
}
.teaching_calendar_pop table.syuunichi_ca_table th.non-hyo{
  background: #fff;
  border: none;
}
.teaching_calendar_pop table tr.border-hyo{
  border-top: 1px solid #c3c3c3!important;
}
.teaching_calendar_pop table th{
  writing-mode:vertical-rl;
  text-orientation:upright;
  padding:5px;
  background:#686f80;
  color: #fff;
  text-align: center;
  font-weight: normal;
  border-right: 1px solid #c3c3c3;
  font-size: 1vw;
}
.teaching_calendar_pop table.ca_table_area th:first-child{
  color: #e693b4;
}
.teaching_calendar_pop table.ca_table_area th:last-child{
  color: #8aa7d3;
}
.teaching_calendar_pop table.syuunichi_ca_table th p{
  font-size: 0.8vw;
}
.teaching_calendar_pop table.syuunichi_ca_table td.syu_table{
  width:66.6%;
}
.teaching_calendar_pop table.ca_table_area tbody{
  color:#4c556e;
}
.teaching_calendar_pop table.syuunichi_ca_table td,.teaching_calendar_pop table.ca_table_area td{
  width: calc(100%/7);
  height: 5vh;
  padding: 0.52vw;
  font-size: 1vw;
  text-align: center;
  background: #fff;
  border-right: 1px solid #c3c3c3;
  border-bottom: 1px solid #c3c3c3;
}
.teaching_calendar_pop table.syuunichi_ca_table td button{
  margin: 0;
  padding: 0;
}
.teaching_calendar_pop table.syuunichi_ca_table td button img{
  height: 2.9vh;
}

/* 非表示の週のスタイル */
.teaching_calendar_pop .hidden-week {
  opacity: 0;
  transition: opacity 0.2s ease;
}

/* 第～週のテキストの非表示スタイル */
.teaching_calendar_pop .hidden-week th p {
  opacity: 0;
  transition: opacity 0.2s ease;
}

#teaching-modal button.btn_modal_send {
  width: 4.9vw;
  height: 4.9vw;
  padding-bottom: 1.0vw;
}

#teaching-modal button.btn_modal_send::before {
  width: 4.9vw;
  height: 4.9vw;
}

#teaching-modal #modal_send {
  padding: 1.5vw 0 0 0;
}

#teaching-modal .modal_row.modal_row_center.all_children_check{
  padding: 0.5vw;
}

@media screen and (max-width: 1280px) {
  #teaching-modal .modal_row.modal_row_center.all_children_check{
    padding-top: 0;
    padding-bottom: 1vw;
  }
}
