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

.innerHead {
  background: url(../img/wave.webp) no-repeat 0 bottom #f2f9ed;
  background-size: 100%;
  padding-bottom: max(370px,42.5%);
  max-width: 100%;
  overflow: hidden;
}
.innerHead .headWrap h1 img {
  max-width: 363px;
}
.navList {
  max-width: 1040px;
  margin: 104px auto 0;
  display: flex;
  justify-content: space-between;
}
.navList .box {
  width: 19.2%;
  letter-spacing: 0.04em;
}
.navList .box a {
  display: flex;
  flex-direction: column;
  padding: 0 5% 25px;
  border: 1px dashed #293855;
  border-radius: 10px;
}
.navList .box figure {
  max-width: 104px;
  margin: 0 auto;
  position: relative;
  z-index: 2;
  top: 0;
  aspect-ratio: 16 / 19;
  transform: translateY(-59%);
  margin-bottom: -32%;
}
.navList .box .department {
  font-size: 1.5rem;
  font-size: clamp(1.2rem,1.17vw,1.5rem);
  line-height: 1.667;
  text-align: center;
  font-weight: 700;
  letter-spacing: 0.04em;
  min-height: min(5.3vw,50px);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 16px;
}
.navList .box .meta {
  display: flex;
  justify-content: center;
  line-height: 1.786;
  margin-bottom: 20px;
  font-size: clamp(0.9rem,1.09vw,1.4rem);
}
.navList .box .btn {
  margin-top: auto;
}
.navList .box .btn p {
  display: flex;
  justify-content: center;
  align-items: center;
  line-height: 1;
  min-height: 35px;
  font-size: 1.2rem;
  font-size: clamp(0.8rem,0.93vw,1.2rem);
  font-weight: 700;
  border: 1px solid #293855;
  background: #293855;
  border-radius: 10px;
  color: #fff;
  transition: all .25s ease-in;
}
.navList .box .btn p::after {
  content: "";
  mask-image: url('data:image/svg+xml;charset=utf8,%3C%3Fxml%20version%3D%221.0%22%20encoding%3D%22UTF-8%22%3F%3E%3Csvg%20id%3D%22_%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_1%22%20data-name%3D%22%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_1%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20version%3D%221.1%22%20viewBox%3D%220%200%20512%20512%22%3E%20%3Cpath%20d%3D%22M96%2C208c0%2C45.9%2C14.9%2C88.3%2C40%2C122.7L9.4%2C457.4c-12.5%2C12.5-12.5%2C32.8%2C0%2C45.3s32.8%2C12.5%2C45.3%2C0l126.6-126.7c34.4%2C25.1%2C76.8%2C40%2C122.7%2C40%2C114.9%2C0%2C208-93.1%2C208-208S418.9%2C0%2C304%2C0%2C96%2C93.1%2C96%2C208ZM304%2C352c-79.5%2C0-144-64.5-144-144S224.5%2C64%2C304%2C64s144%2C64.5%2C144%2C144-64.5%2C144-144%2C144Z%22%2F%3E%3C%2Fsvg%3E');
  mask-repeat: no-repeat;
  mask-size: contain;
  background: #fff;
  width: 12px;
  height: 12px;
  margin-left: 4px;
  transition: all .25s ease-in;
}
.navList .box a:hover {
  background: #fff;
  opacity: 1;
}
.navList .box a:hover .btn p {
  color: #293855;
  background: #fff;
}
.navList .box a:hover .btn p::after {
  background: #293855;
}
.innerHead .caution {
  letter-spacing: 0.04em;
  color: #b6b7b4;
  max-width: 1040px;
  margin: 10px auto 0;
  text-align: right;
}
.anchor {
  padding-top: 65px;
  position: relative;
  top: -65px;
  margin-bottom: -65px;
}
.contentBlock {
  position: relative;
  margin-top: -26.1%;
}
.contentBlock::before {
  background: #fff;
}
.contentWrap {
  padding: 18px 3% 60px;
  position: relative;
  z-index: 2;
  line-height: 1.563;
  letter-spacing: 0.06em;
  font-size: 1.6rem;
  background: #fff;
}
.contentWrap .block {
  border: 1px solid #293855;
  box-shadow: 0 -6px 18px rgba(33, 26, 26, .25), 0 -14px 34px rgba(33, 26, 26, .18);
  max-width: 1040px;
  margin: 0 auto 20px;
  border-radius: 30px;
  line-height: 1.563;
  letter-spacing: 0.06em;
  font-size: 1.6rem;
  background: #fff;
  padding: 27px 5% 65px;
}
.contentWrap .block .profile {
  display: flex;
  justify-content: space-between;
  margin-bottom: 35px;
}
.contentWrap .block .profile .imgBox {
  width: 20.8%;
}
.contentWrap .block .profile .txtBox {
  width: 76%;
  padding-top: 4%;
  font-size: clamp(1.3rem,1.25vw,1.6rem);
}
.contentWrap .block .profile .txtBox .department {
  font-weight: 700;
  margin-bottom: 10px;
}
.contentWrap .block .profile .txtBox .meta {
  display: flex;
  margin-bottom: 10px;
}
.contentWrap .block .profile .txtBox .meta li {
  margin-right: 22px;
}
.contentWrap .block table {
  width: 100%;
  border: 1px solid #293855;
  border-right: none;
  text-align: center;
  height: 100%;
}
.contentWrap .block table th {
  background: #f2f9ed;
  vertical-align: middle;
}
.contentWrap .block table td {
  border-right: 1px dashed rgba(96, 100, 99, 0.5);
  background: #f2f9ed;
}
.contentWrap .block table td.lastLine,
.contentWrap .block table thead td:last-of-type {
  border-right: 1px solid #293855;
}
.contentWrap .block table thead tr {
  border-bottom: 1px solid #293855;
}
.contentWrap .block table thead th {
  border-right: 1px solid rgba(96, 100, 99, 0.5);
}
.contentWrap .block table thead th,
.contentWrap .block table thead td {
  font-size: 1.6rem;
  font-size: clamp(1.3rem,1.25vw,1.6rem);
  font-weight: 700;
  height: 3.22em;
  vertical-align: middle;
  width: 12.5%;
}
.contentWrap .block table tbody tr {
  position: relative;
  border-bottom: 1px dashed rgba(96, 100, 99, 0.5);
}
/*.contentWrap .block table tbody tr::after {
  content: "";
  width: 100%;
  height: 1px;
  border-bottom: 1px dashed rgba(96, 100, 99, 0.5);
  position: absolute;
  left: 0;
  bottom: 0;
  z-index: 4;
}
.contentWrap .block table tbody tr:last-of-type::after {
  display: none;
}*/
.contentWrap .block table tbody th {
  font-size: 1.7rem;
  font-size: clamp(1.4rem,1.32vw,1.7rem);
  font-family: "numberfont", sans-serif;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  height: 3.78em;
  border-right: 1px solid #293855;
}
.contentWrap .block table tbody td {
  padding: 4px;
  background: #f3f3f3;
  height: 100%;
  vertical-align: middle;
  position: relative;
}
.contentWrap .block table tbody td.halfBox {
  vertical-align: top;
}
.contentWrap .block table tbody td .box {
  display: flex;
  position: relative;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  background: #293855;
  border-radius: 5px;
}
.contentWrap .block table tbody td .box.half {
  height: calc(50% - 4px);
  margin-bottom: 4px;
}
.contentWrap .block table tbody td .box.halfBtm {
  position: absolute;
  top: calc(50% + 4px);
  left: 4px;
  width: calc(100% - 8px);
  outline: 3px solid #f3f3f3;
  height: calc(350% - 4px);
  z-index: 2;
}
.contentWrap .block table tbody td .box.halfTop {
  position: absolute;
  top: calc(0px - 50%);
  left: 4px;
  width: calc(100% - 8px);
  height: calc(450% - 1px);
  z-index: 2;
  outline: 3px solid #f3f3f3;
}
.contentWrap .block table tbody td .box.half2 {
  position: absolute;
  left: 4px;
  width: calc(100% - 8px);
  z-index: 2;
}
.contentWrap .block table tbody td .box.half:last-of-type {
  margin-bottom: 0;
}
.contentWrap .block table tbody td .box.modalTrigger {
  cursor: pointer;
}
.contentWrap .block table tbody td .box.modalTrigger::before {
  content: "";
  width: 20px;
  height: 20px;
  background: url('data:image/svg+xml;charset=utf8,%3C%3Fxml%20version%3D%221.0%22%20encoding%3D%22UTF-8%22%3F%3E%3Csvg%20id%3D%22_%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_1%22%20data-name%3D%22%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_1%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20version%3D%221.1%22%20viewBox%3D%220%200%2040%2040%22%3E%20%3Cdefs%3E%20%3Cstyle%3E%20.st0%20%7B%20fill%3A%20%23c92634%3B%20%7D%20.st0%2C%20.st1%20%7B%20fill-rule%3A%20evenodd%3B%20%7D%20.st1%20%7B%20fill%3A%20%23fff%3B%20%7D%20%3C%2Fstyle%3E%20%3C%2Fdefs%3E%20%3Cpath%20class%3D%22st0%22%20d%3D%22M20.5%2C0c11.3%2C0%2C19.5%2C9%2C19.5%2C20s-8.2%2C20-19.5%2C20S0%2C31%2C0%2C20%2C9.2%2C0%2C20.5%2C0Z%22%2F%3E%20%3Cpolygon%20class%3D%22st1%22%20points%3D%2229.6%2018.6%2021.4%2018.6%2021.4%2010.4%2018.6%2010.4%2018.6%2018.6%2010.4%2018.6%2010.4%2021.4%2018.6%2021.4%2018.6%2029.6%2021.4%2029.6%2021.4%2021.4%2029.6%2021.4%2029.6%2018.6%22%2F%3E%3C%2Fsvg%3E') no-repeat;
  background-size: contain;
  position: absolute;
  right: -2px;
  top: -2px;
}
.contentWrap .block table tbody td .box p {
  color: #fff;
  font-size: 1.2rem;
  font-size: clamp(0.8rem,0.93vw,1.2rem);
  letter-spacing: 0;
  line-height: 1.3;
}
.contentWrap .block table tbody td .box p.small {
  font-size: clamp(0.6rem,0.85vw,1rem);
}
.contentWrap .block table tbody td .box p.small2 {
  font-size: clamp(0.6rem,0.7vw,0.9rem);
}
.contentWrap .block table tbody td .box span {
  display: block;
  padding-top: 20px;
}
.contentWrap .block table tbody td.outside .box,
.contentWrap .block table tbody td .box.outside {
  background: #b8d8da;
}
.contentWrap .block table tbody td.outside .box p,
.contentWrap .block table tbody td .box.outside p {
  color: #293855;
}
.contentWrap .block table tbody td.off .box,
.contentWrap .block table tbody td .box.off {
  background: #fff;
}
.contentWrap .block table tbody td.off .box p,
.contentWrap .block table tbody td .box.off p {
  color: #293855;
}
.modalWrap {
  position: relative;
  z-index: -1;
  opacity: 0;
  transition: all .25s ease-in;
  visibility: hidden;
}
.modalWrap.isActive {
  z-index: 999;
  opacity: 1;
  visibility: visible;
}
.modalWrap .modalBg {
  width: 100%;
  height: 100%;
  position: fixed;
  background: rgba(41, 56, 85, 0.9);
  top: 0;
  left: 0;
}
.modalWrap .modalBlock {
  width: 93%;
  max-height: 92vh;
  max-width: 775px;
  z-index: 2;
  border-radius: 20px;
  position: fixed;
  margin: auto;  
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  letter-spacing: 0.06em;
  border: 1px solid #293855;
  background: #fff;
}
.modalWrap .closeBtn {
  width: 46px;
  height: 46px;
  position: absolute;
  top: -4%;
  right: -2%;
  z-index: 2;
  background: url('data:image/svg+xml;charset=utf8,%3C%3Fxml%20version%3D%221.0%22%20encoding%3D%22UTF-8%22%3F%3E%3Csvg%20id%3D%22_%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_1%22%20data-name%3D%22%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_1%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20version%3D%221.1%22%20viewBox%3D%220%200%2092%2092%22%3E%20%3Cdefs%3E%20%3Cstyle%3E%20.st0%20%7B%20fill%3A%20%23e60033%3B%20%7D%20.st0%2C%20.st1%20%7B%20fill-rule%3A%20evenodd%3B%20stroke%3A%20%23fff%3B%20stroke-width%3A%202px%3B%20%7D%20.st1%20%7B%20fill%3A%20%231e1c1c%3B%20%7D%20%3C%2Fstyle%3E%20%3C%2Fdefs%3E%20%3Cpath%20class%3D%22st0%22%20d%3D%22M46%2C1.8c24.4%2C0%2C44.2%2C19.8%2C44.2%2C44.2s-19.8%2C44.2-44.2%2C44.2S1.8%2C70.4%2C1.8%2C46%2C21.6%2C1.8%2C46%2C1.8Z%22%2F%3E%20%3Cpath%20class%3D%22st1%22%20d%3D%22M31.1%2C32l.8-.8%2C28.9%2C28.9-.8.8-28.9-28.9Z%22%2F%3E%20%3Cpath%20class%3D%22st1%22%20d%3D%22M60%2C31.1l.8.8-28.9%2C28.9-.8-.8%2C28.9-28.9Z%22%2F%3E%3C%2Fsvg%3E') no-repeat;
  background-size: contain;
  cursor: pointer;
}
.modalWrap .modalDetails {
  overflow: auto;
  width: 100%;
  line-height: 1.563;
  letter-spacing: 0.06em;
  font-size: 1.6rem;
  padding: 40px 3%;
}
.modalWrap .modalDetails figure {
  max-width: 432px;
  margin: 0 auto 32px;
}
.modalWrap .modalDetails .txtBox {
  max-width: 500px;
  margin: 0 auto;
}
.modalWrap .modalDetails .txtBox h3 {
  font-size: 2rem;
  font-weight: 700;
  color: #c92634;
  margin-bottom: 20px;
}
@media only screen and (max-width:749px) {
  .innerHead {
    padding-bottom: 42%;
  }
  .innerHead .headWrap h1 img {
    max-width: 90.26vw;
  }
  .navList {
    max-width: none;
    margin: 16.2% auto 0;
    display: block;
  }
  .navList .box {
    width: 96.6%;
    margin: 0 0 4.2% auto;
  }
  .navList .box a {
    flex-wrap: wrap;
    justify-content: space-between;
    flex-direction: row;
    align-items: center;
    padding: 7% 0 9%;
  }
  .navList .box figure {
    max-width: 31%;
    left: -3vw;
    margin: 0;
    top: 0;
    transform: translateY(0);
    margin-bottom: 0;
  }
  .navList .box .notes {
    width: 66%;
  }
  .navList .box .department {
    font-size: 4.26vw;
    text-align: left;
    min-height: 0;
    display: block;
    margin-bottom: 3%;
  }
  .navList .box .meta {
    display: block;
    margin-bottom: 0;
    font-size: 3.73vw;
  }
  .navList .box .btn {
    padding: 6% 7% 0;
    width: 100%;
  }
  .navList .box .btn p {
    min-height: 9.33vw;
    font-size: 1.2rem;
    font-size: 4vw;
  }
  .navList .box .btn p::after {
    width: 3.2vw;
    height: 3.2vw;
    margin-left: 1.06vw;
  }
  .innerHead .caution {
    text-align: center;
    max-width: none;
    font-size: 3.73vw;
    margin: 0;
  }
  .anchor {
    padding-top: 12vw;
    top: -12vw;
    margin-bottom: -12vw;
  }
  .contentBlock {
    position: relative;
    margin-top: -1.3%;
  }
  .contentWrap {
    padding: 0;
    margin-bottom: -17vw;
    font-size: 4.26vw;
    top: -11vw;
  }
  .contentWrap .block {
    max-width: none;
    margin: 0 auto 5.4%;
    font-size: 4.26vw;
    padding: 9.5% 0;
  }
  .contentWrap .block .profile {
    margin: 0 7.5% 11.7%;
    display: block;
  }
  .contentWrap .block .profile .imgBox {
    width: 44.5%;
    float: left;
    margin-right: 5%;
  }
  .contentWrap .block .profile .txtBox {
    width: auto;
    padding-top: 9%;
    font-size: 4.26vw;
  }
  .contentWrap .block .profile .txtBox .department {
    margin-bottom: 5%;
  }
  .contentWrap .block .profile .txtBox .meta {
    display: block;
    margin-bottom: 10px;
    font-size: 3.73vw;
  }
  .contentWrap .block .profile .txtBox .meta li {
    margin: 0 0 1.5%;
  }
  .contentWrap .block .profile .txtBox .meta li:nth-child(3) {
    margin-bottom: 0;
  }
  .contentWrap .block .profile .txtBox .note {
    width: 92%;
    margin: 13% auto 0;
  }
  .tableBlock {
    padding-left: 5vw;
    overflow: hidden;
  }
  .contentWrap .block .tableWrap {
    overflow-x: auto;
    padding: 0 0 3% 0;
    position: relative;
  }
  .contentWrap .block .tableWrap .scroll-hint-icon {
    left: calc(50% - 20.7vw);
    width: 41.4vw;
    background: rgba(41, 56, 85, 0.8);
  }
  .contentWrap .block .tableWrap .scroll-hint-text {
    font-size: 3.46vw;
  }
  .contentWrap .block table {
    width: calc(892px + 5vw);
    border-left: none;
    margin-right: 5vw;
  }
  .contentWrap .block table th {
    position: sticky;
    left: 0;
    z-index: 3;
  }
  .contentWrap .block table th::before,
  .contentWrap .block table th::after {
    content: "";
    position: absolute;
    top: 0;
    width: 1px;
    height: 100%;
    background: #293855;
  }
  .contentWrap .block table thead th::before,
  .contentWrap .block table thead th::after {
    background: rgba(96, 100, 99, 0.5);
  }
  .contentWrap .block table th::before {
    left: 0;
  }
  .contentWrap .block table th::after {
    right: 0;
  }
  .contentWrap .block table thead th,
  .contentWrap .block table thead td {
    font-size: 1.6rem;
    height: 40px;
    width: 116px;
  }
  .contentWrap .block table thead th {
    width: 80px;
    border-right: none;
  }
  .contentWrap .block table tbody th {
    font-size: 1.7rem;
    border-right: none;
  }
  .contentWrap .block table tbody td .box p {
    color: #fff;
    font-size: 1.2rem;
  }
  .contentWrap .block table tbody td .box p.small {
    font-size: 1rem;
  }
  .contentWrap .block table tbody td .box p.small2 {
    font-size: 0.8rem;
  }
  .modalWrap .modalBg {
    width: 100%;
    height: 100%;
    position: fixed;
    background: rgba(41, 56, 85, 0.9);
    top: 0;
    left: 0;
  }
  .modalWrap .modalBlock {
    width: 100%;
    max-height: calc(var(--vh, 1vh) * 91);
    max-width: none;
  }
  .modalWrap .closeBtn {
    width: 11.73vw;
    height: 11.73vw;
    position: absolute;
    top: -4%;
    right: 3%;
  }
  .modalWrap .modalDetails {
    font-size: 4.26vw;
    padding: 14% 5%;
  }
  .modalWrap .modalDetails figure {
    max-width: none;
    margin: 0 auto 9%;
  }
  .modalWrap .modalDetails .txtBox {
    max-width: 87%;
    margin: 0 auto;
  }
  .modalWrap .modalDetails .txtBox h3 {
    font-size: 5.06vw;
    margin-bottom: 5%;
    line-height: 1.316;
  }
}