/* sction businessInformation */
.businessInformation {
  position: relative;
  background: #E9F5F5;
}
.businessInfoLogo {
  position: relative;
}
.businessInfoLogo .logoTextArea {
  display: flex;
  position: absolute;
  width: 100%;
  top: 17%;
  color: #333333;
}
.businessInfoLogo .logoTextLeft {
  margin: 0 13%;
}
.businessInfoLogo .logoTextRight {
  margin: 0 5%;
}
@media screen and (max-width: 1025px) {
  .businessInfoLogo {
    margin: 0 auto 30px;
  }
  .subTitle {
    width: fit-content;
    margin: 10px auto;
    font-size: 4.4vw;
    font-weight: bold;
  }
  .subNote {
    margin: 5% 5% 0;
  }
}
@media screen and (min-width: 1025px) {
  .businessInformation .sectionNote {
    width: 615px;
  }
  .businessInfoLogo {
    display: none;
  }
  .subTitle {
    width: fit-content;
    margin: 10px auto;
    font-size: 25px;
    font-weight: bold;
  }
  .subNote {
    margin: 5% 5% 0;
    font-size: 20px;
  }
}
.frameArea {
  border-radius: 30px;
  margin: 20% 0 10%;
  padding: 2%;
}
@media screen and (min-width: 1025px) {
  .businessInfo {
    display: flex;
    width: 967px;
    margin-left: auto;
    margin-right: auto;
  }
  .businessInfo1, 
  .businessInfo2 {
    display: flex;
    flex-direction: column;
    width: 466px;
    margin: 0 10px;
  }
  .frameArea {
    display: flex;
    flex-direction: column;
    flex-grow: 1;
  }
  .frameInner {
    flex-grow: 1;
  }
}
.businessInfo1 .frameArea {
  background-image: repeating-linear-gradient(45deg, #07c0d533, #07c0d533 4px, transparent 4px, transparent 9px);
}
.businessInfo2 .frameArea {
  background-image: repeating-linear-gradient(45deg, #d5ac0733, #d5ac0733 4px, transparent 4px, transparent 9px);
}
.frameInner {
  background-color: #FFF;
  border-radius: 30px;
  padding: 5% 0 25%;
  position: relative;
}
.businessInfo1 .frameInner img {
  width: 30%;
  position: absolute;
  top: -21%;
  left: 33%;
}
.businessInfo2 .frameInner img {
  width: 30%;
  position: absolute;
  top: -20%;
  left: 33%;
}
.noteitems {
  margin: 5%;
}
.linkBtn {
  width: fit-content;
  margin: 0 auto;
  border-radius: 30px;
  padding: 5% 17%;
  color: #FFF;
  position: absolute;
  left: 0;
  right: 0;
  bottom: 23px;
}
.businessInfo .subTitle {
  position: relative;
}
.businessInfo .subTitle:before {
  content: "";
  position: absolute;
  bottom: -10px;
  left: 0;
  background: repeating-linear-gradient(45deg, #FFF 6px 7px, #DBEBFF 0 11px);
  width: 100%;
  min-width: 26px;
  height: 10px;
}
.businessInfo2 .subTitle:before {
  background: repeating-linear-gradient(45deg, #FFF 6px 7px, #FFDC85 0 11px)
}
.businessInfo1 .linkBtn {
  background-color: #1C529B;
}
.businessInfo2 .linkBtn {
  background-color: #F5AF2A;
}
/*
.businessInformation::before, .businessInformation::after {
  content: "";
  display: block;
  position: absolute;
  border-radius: 100% 50%;
}
.businessInformation::before {
  width: 18em;
  height: 5em;
  background-color: #E9F5F5;
  right: -5em;
  top: -3em;
}
.businessInformation::after {
  width: 18em;
  height: 5em;
  background-color: #E9F5F5;
  left: -5em;
  bottom: -3em;
}
.subVisual::after {
  content: "";
  display: block;
  position: absolute;
  border-radius: 100% 50%;
  width: 18em;
  height: 5em;
  background-color: #FFF;
  left: -5em;
  top: -3em;
}
*/

/* sction transition */
@media screen and (max-width: 1025px) {
  .transition {
    background: #F8F8F8 url(../img/iconTran.svg) 118% 0.5% / 58% auto no-repeat;
  }
  .transition .sectionTitle, 
  .continuation .sectionTitle {
    margin-left: 5vw;
  }
  .transition .sectionNote {
    text-align: initial;
    max-width: 75vw;
    margin-left: 5vw;
  }
  .sectionList {
    font-size: 3.4vw;
  }
  .sectionListItem {
    margin: 20px 0;
    padding: 10px;
    background: #FFF;
  }
}
@media screen and (min-width: 1025px) {
  .transition {
    background: #F8F8F8 url(../img/iconTran.svg) 95% 0.5% / 461px auto no-repeat;
  }
  .transition .sectionTitle, 
  .continuation .sectionTitle {
    margin-left: 0;
  }
  .transition .sectionNote {
    text-align: initial;
    max-width: 750px;
  }
  .sectionList {
    font-size: 20px;
  }
  .sectionListItem {
    margin: 20px 0;
    padding: 70px 100px;
    background: #FFF;
  }
}
.sectionToggle {
  position: relative;
  display: flex;
  align-items: center;
  font-size: 4vw;
}
@media screen and (min-width: 1025px) {
  .sectionToggle {
    font-size: 20px;
  }
}
.toggleText {
  width: 100%;
  padding: 0 6px;
  text-align: left;
  vertical-align: middle;
  position: relative;
}
.transition .toggleText:before,
.continuation .toggleText:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  background: repeating-linear-gradient(45deg, #FFF 6px 7px, #DBEBFF 0 11px);
  width: 10px;
  height: 100%;
  min-height: 26px;
}
.continuation .toggleText:before {
  background: repeating-linear-gradient(45deg, #FFF 6px 7px, #FFDC85 0 11px);
}
.toggleText > span {
  display: block;
  width: calc(100% - 15px);
  margin-left: 15px;
}
.toggleText .mainText {
  font-size: 4vw;
  font-weight: bold;
}
.toggleText .subText {
  font-size: 3.4vw;
}
@media screen and (min-width: 1025px) {
  .toggleText .mainText {
    font-size: 25px;
  }
  .toggleText .subText {
    font-size: 20px;
  }
}
.toggleBtn {
  text-align: center;
}
.minusBtn, 
.plusBtn {
  display: block;
  width: 6vw;
  height: 6vw;
  line-height: 6vw;
  border-radius: 6vw;
  background: #1C529B;
  color: #FFFFFF;
}
@media screen and (min-width: 1025px) {
  .minusBtn, 
  .plusBtn {
    display: block;
    width: 39px;
    height: 39px;
    line-height: 39px;
    border-radius: 39px;
    background: #1C529B;
    color: #FFFFFF;
    font-size: 20px;
  }
}
.continuation .minusBtn, 
.continuation .plusBtn {
  background: #F5AF2A;
}
.menuClose .minusBtn, 
.menuOpen .plusBtn {
  display: none;
}
.menuClose + .FAQToggleList {
  display: none;
}

.sectionToggle:before {
  width: 5px;
  height: 21px;
  background-image: url(./img/sectionToggleImg.svg);
}
.sectionToggle.menuClose .minusBtn, 
.sectionToggle.menuOpen .plusBtn {
  display: none;
}
.sectionToggle.menuClose + .toggleList {
  display: none;
}
@media screen and (max-width: 1025px) {
  .toggleList {
    background-color: #FFF;
    padding: 10px;
  }
  .toggleListItem {
    display: table;
    margin: 10px 0;
  }
}
@media screen and (min-width: 1025px) {
  .toggleList {
    background-color: #FFF;
    padding: 50px 0;
  }
  .toggleListItem {
    display: table;
    margin: 20px 0;
  }
}
.toggleListItem span {
  vertical-align: middle;
}
.toggleListItem .noLabel {
  display: table-cell;
  width: 30px;
  font-size: 32px;
  padding-right: 10px;
  text-align: center;
}
@media screen and (min-width: 1025px) {
  .toggleListItem .noLabel {
    width: 55px;
    font-size: 52px;
  }
}
.transition .noLabel {
  color: #1C529B;
}
.toggleListItem .itemText {
  display: table-cell;
}
@media screen and (max-width: 1025px) {
  .workFlow {
    max-width: min(90vw, 1420px);
    margin-left: auto;
    margin-right: auto;
    background: #E9F5F5;
    border-radius: 10px;
  }
}
@media screen and (min-width: 1025px) {
  .workFlow {
    max-width: 882px;
    margin-left: auto;
    margin-right: auto;
    background: #E9F5F5;
    border-radius: 10px;
  }
}
.workFlow .subTitle {
  margin: 5% 2%;
  color: #1C529B;
}
.workFlow .subNote {
  margin: 5% 2%;
}
.flowInfo {
  position: relative;
  font-size: 3.4vw;
}
@media screen and (min-width: 1025px) {
  .flowInfo {
    font-size: 20px;
  }
}
.flowImg {
  width: 40%;
  margin: 10px 20px;
}
.flowSec1,
.flowSec2,
.flowSec3,
.flowSec4 {
  position: absolute;
  left: 47%;
  width: 50%;
  text-indent: -1em;
  padding-left: 1em;
}
.flowSec1 {
  top: 5%;
}
.flowSec2 {
  top: 31%;
}
.flowSec3 {
  top: 53%;
}
.flowSec4 {
  top: 77%;
}
.weekProgram {
  display: table;
  width: 100%;
  font-size: 13px;
}
@media screen and (min-width: 1025px) {
  .weekProgram {
    font-size: 20px;
  }
}
.weekProgramNote {
  margin: 10px;
}
.tableRow {
  display: table-row;
}
.tableCell {
  display: table-cell;
  width: 42%;
  height: 58px;
  background: #E9F5F5;
  border-radius: 10px;
  text-align: center;
  vertical-align: middle;
  border: solid 2px rgba(255, 255, 255, 1);
}
@media screen and (min-width: 1025px) {
  .tableCell {
    border: solid 4px rgba(255, 255, 255, 1);
  }
}
.tableRow:first-child .tableCell,
.tableCell:first-child {
  background: #5D9DF4;
  color: #fff;
}
.tableCell:first-child {
  width: 16%;
}
.tableRow:first-child .tableCell:first-child{
  background: none;
}
.oneDayFlowNote {
  margin: 20px 0;
  display: table;
  background: #DBEBFF;
  padding: 10px;
  font-size: 12px;
  font-weight: bold;
}
@media screen and (min-width: 1025px) {
  .oneDayFlowNote {
    font-size: inherit;
  }
}
.oneDayFlowNote > span {
  vertical-align: top;
}
.oneDayFlowNote .noteImage {
  display: table-cell;
  width: 30%;
}
.oneDayFlowNote .noteText {
  display: table-cell;
  width: 60%;
  padding-left: 5%;
}
.curriculumList {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}
.curriculum {
  display: flex;
  flex-direction: column;
  width: 30%;
  max-width: 200px;
  margin: 5% 1%;
}
.curriculumInner {
  display: flex;
  flex-direction: column;
  flex-grow: 1;
}
.curriculumList.row2 .curriculum {
  width: 45%;
}
.curriculumImage {
  position: relative;
}
.curriculumImage .rightArrow {
  position: absolute;
  bottom: 10px;
  right: 6px;
}
@media screen and (max-width: 1025px) {
  .curriculumImage img {
    height: calc(25vw * 1.1);
    object-fit: cover;
    border-radius: 10px;
  }
}
@media screen and (min-width: 1025px) {
  .curriculumImage img {
    widht: 162px;
    height: 226px;
    object-fit: cover;
    border-radius: 10px;
  }
}
.transition .curriculumText {
    display: flex;
    flex-grow: 1;
    justify-content: center;
    align-items: center;
    text-align: center;
    background: #DBEBFF;
    border-radius: 5px;
    margin: 8% 0 0;
    padding: 6% 0;
    font-size: 13px;
    font-weight: bold;
}
.continuation .curriculumText {
    display: flex;
    flex-grow: 1;
    align-items: center;
    border-left: #FFDC85;
    border-left: 6px solid #FFDC85;
    padding-left: 8px;
    height: 40px;
}
.practicalWorkNote {
  margin: 4% 0;
}
@media screen and (max-width: 1025px) {
  .continuation {
    background: #FFF7E8 url(../img/iconCon.svg) 142% -1.5% / 68% auto no-repeat;
  }
  .continuation .sectionNote {
    text-align: initial;
    width: 67%;
    margin-left: 5vw;
  }
  .continuation .sectionSubTitle {
    font-size: 20px;
    color: #808080;
  }
  .sectionImg {
    width: 90%;
    margin: 5% auto;
    position: relative;
    color: #3A3A3A;
  }
}
@media screen and (min-width: 1025px) {
  .continuation {
    background: #FFF7E8 url(../img/iconCon.svg) 95% 0.5% / 461px auto no-repeat;
  }
  .continuation .sectionNote {
    text-align: initial;
    width: 80%;
  }
  .continuation .sectionSubTitle {
    font-size: 40px;
    color: #808080;
  }
  .sectionImg {
    width: 522px;
    margin: 30px auto 50px;
    position: relative;
  }
}
.sectionImg .sectionImgText {
  position: absolute;
  bottom: 14%;
  left: 0;
  right: 0;
  width: 70%;
  margin: 0 auto;
}
.sectionImg .sectionImgText.top {
  top: 14%;
  width: 80%;
  font-size: 4.4vw;
  font-weight: bold;
}
@media screen and (min-width: 1025px) {
  .sectionImg .sectionImgText.top {
    font-size: 25px;
  }
}
.continuation .noLabel {
  color: #FFD483;
}
.recreationList {
  margin: 20px 0;
  padding: 15px 20px;
  width: fit-content;
  font-size: 12px;
  border: 3px solid #DFDFDF;
  border-radius: 15px;
}
@media screen and (min-width: 1025px) {
  .recreationList {
    font-size: 20px;
  }
}
.recreationItem {
  display: table;
}
.recreationItem > span {
  display: table-cell;
  vertical-align: middle;
}
.recreationItem > span:nth-child(n+3) {
  padding-left: 10px;
}
.recreationText {
  width: 8%;
  text-align: center;
}
.recreationIcon {
  width: 10%;
}
.workStepList {
  display: table;
  margin: 5% 0;
  position: relative;
}
.workStepItem {
  display: table-row;
}
.workStepItem > span {
  display: table-cell;
  vertical-align: top;
}
.workStepIcon {
  width: 20%;
  text-align: center;
  text-align: -webkit-center;
}
.workStepIcon .circleBack {
  display: flex;
  justify-content: center;
  background: #FFEEC3;
  width: 14vw;
  max-width: 100px;
  height: 14vw;
  max-height: 100px;
  border-radius: 50%;
}
.workStepList:before {
  content: "";
  position: absolute;
  top: 1%;
  left: 9.7%;
  background: #FFEEC3;
  width: 1%;
  height: 75%;
  z-index: 0;
}
.circleBack img {
  width: unset;
  z-index: 1;
}
.workStepInfo {
  padding-left: 3%;
  padding-bottom: 5%;
}
.workStepInfoLabel {
  font-weight: bold;
  margin: 0 5%;
}
.workStepInfoText {
  border: 3px solid #DFDFDF;
  border-radius: 10px;
  padding: 5%;
  margin-top: 5%;
}
.jobDescription {
  background-color: #E9F5F5;
}
@media screen and (min-width: 1025px) {
  .jobDescription .sectionInner,
  .staffIntroduction .sectionInner {
    width: 662px;
  }
}
.jobDescription .sectionTitle {
  text-align: center;
}
.disIconArea {
  display: flex;
  flex-wrap: wrap;
}
.disIcon {
  width: 31%;
  padding: 1%;
  position: relative;
}
.disIcon .iconText {
  width: fit-content;
  margin: 0 auto;
  font-size: 3.4vw;
  position: absolute;
  bottom: 21%;
  left: 0;
  right: 0;
}
@media screen and (min-width: 1025px) {
  .disIcon .iconText {
    font-size: 20px;
  }
}
.workList {
  width: 100%;
  display: flex;
  flex-wrap: wrap;
}
.workItem {
  width: 43%;
  margin: 2% 3.5%;
  position: relative;
}
.workItemLabel {
  position: absolute;
  bottom: 11%;
  left: 0;
  right: 0;
  width: fit-content;
  margin: 0 auto;
  display: flex;
  align-items: center;
}
.workItemText {
  font-size: 3.4vw;
  margin-right: 5px;
}
@media screen and (min-width: 1025px) {
  .workItemText {
    font-size: 25px;
  }
}
.staffIntroduction {
  background: #F8F8F8;
}
.staffGroupLabel {
  margin: 0 auto 20px;
  text-align: center;
  margin-bottom: 20px;
}
.staffGroup {
  margin-bottom: 20px;
}
.staffMember {
  position: relative;
}
.staffGroup.row1 .staffMember {
  width: 100%;
}
@media screen and (max-width: 1025px) {
  .staffImage {
    margin: 2% auto 0;
    width: 24vw;
  }
  .staffImage img {
    border-radius: 24vw;
  }
}
@media screen and (min-width: 1025px) {
  .staffImage {
    margin: 2% auto 0;
    width: 155px;
  }
  .staffImage img {
    border-radius: 155px;
  }
}
.staffName, 
.staffSuppl {
  width: 100%;
  font-size: 3vw;
  text-align: center;
}
@media screen and (min-width: 1025px) {
  .staffName, 
  .staffSuppl {
    font-size: inherit;
    text-align: center;
  }
}
.staffName {
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: bold;
}
.staffName .rightArrow {
  margin-left: 5px;
}
.staffGroup.row2, 
.staffGroup.row3 {
  display: flex;
  flex-wrap: wrap;
}
.staffGroup.row2 .staffMember {
  width: 48%;
}
.staffGroup.row3 .staffMember {
  width: 33%;
}
.staffNote {
  margin: 10px 0;
}
.detailModal {
  display: none;
  width: 84vw;
  max-width: 800px;
  background-color: #fff;
  border-radius: 10px;
  margin: 0 auto;
  padding: 20px;
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translateX(-50%) translateY(-50%);
  z-index: 20;
  font-size: 3.4vw;
}
.detailModal.modalOpen {
  display: block;
}
.modalClose {
  position: absolute;
  top: 20px;
  right: 20px;
}
.detailModalLabel {
  margin: 0 auto 20px;
  width: fit-content;
  font-size: 4vw;
  font-weight: bold;
  text-align: center;
}
.detailModalSI {
  font-size: initial;
  font-weight: normal;
}
.detailModalInfo {
  font-size: 15px;
  font-weight: bold;
  margin: 2% 0;
}
.detailModalList {
  font-size: 15px;
}
.detailModalComment {
  font-size: 15px;
  margin: 3% 0;
}
.detailModal .staffName, 
.detailModal .staffSuppl,
.detailModal .staffNote,
.detailModal .staffCare {
  font-size: inherit;
}
@media screen and (min-width: 500px) {
  .detailModal {
    font-size: 20px;
  }
  .detailModalBox {
    display: table;
  }
  .detailModalLeft {
    display: table-cell;
    max-width: 500px;
  }
  .detailModalLeft img:not(.staffImage img) {
    max-height: 60vh;
  }
  .detailModalRight {
    display: table-cell;
    padding-left: 20px;
    vertical-align: middle;
  }
  .detailModalLabel {
    font-size: 20px;
  }
  .detailModal .staffImage {
    width: 280px;
  }
  .detailModal .staffName, 
  .detailModal .staffSuppl {
    text-align: initial;
    justify-content: initial;
  }
  .staffIntroduction .detailModalLeft {
    width: 280px;
  }
}
.accessMap {
    background: #E9F5F5;
}
@media screen and (max-width: 1025px) {
  .sectionBox .sectionNote, 
  .sectionBox .enquiriesLink {
    display: block;
  }
  .sectionBox + .sectionNote,
  .sectionBox ~ .enquiriesLink {
    display: none;
  }
  .accessInfo {
    background: #FFF;
    padding: 20px;
    font-size: 3.4vw;
  }
}
@media screen and (min-width: 1025px) {
  .accessMap .sectionInner {
    width: 1070px;
  }
  .sectionBox {
    display: flex;
  }
  .sectionBoxLeft, 
  .sectionBoxRight {
    display: flex;
    flex-direction: column;
    width: 50%;
    padding: 10px;
  }
  .accessInfo {
    background: #FFF;
    padding: 20px;
    font-size: 20px;
    flex-grow: 1;
  }
  .sectionBox .sectionNote, 
  .sectionBox .enquiriesLink {
    display: none;
  }
  .sectionBox + .sectionNote,
  .sectionBox ~ .enquiriesLink {
    display: block;
  }
}
.accessInfoItem {
    width: 100%;
}
.accessInfoItem span {
    float: right;
}
.FAQ {
  background-color: #F8F8F8;
}
.FAQListItem {
  background: #DBEBFF;
  margin: 10px 0;
  padding: 10px;
}
.FAQListItem .sectionToggle {
  font-size: 3.4vw;
}
@media screen and (min-width: 1025px) {
  .FAQListItem .sectionToggle {
    font-size: 25px;
  }
}
.iconQ {
  color: #1C529B;
}
.iconA {
  color: #FF3838;
}
.iconQ, 
.iconA {
  font-size: 6vw;
  font-weight: bold;
  margin-right: 2%;
}
@media screen and (min-width: 1025px) {
  .iconQ, 
  .iconA {
    font-size: 40px;
  }
}
.FAQToggleList {
  background-color: #FFF;
  margin-top: 10px;
  padding: 10px;
  font-size: 3.4vw;
}
@media screen and (min-width: 1025px) {
  .FAQToggleList {
    font-size: 20px;
  }
}
.companyInformation {
  background-color: #E9F5F5;
}
@media screen and (min-width: 1025px) {
  .companyInformation .sectionInner {
    width: 1070px;
  }
}
.companyInformation table {
  width: 98%;
  max-width: 648px;
  margin: 0 auto 5%;
  border: 1px solid rgba(0, 0, 0, 0.2);
  border-spacing: 0;
  border-radius: 10px;
  background-color: #FFF;
  font-size: 3.4vw;
}
@media screen and (min-width: 1025px) {
  .companyInformation table {
    font-size: 20px;
  }
}
.companyInformation table td {
  padding: 12px 20px;
  vertical-align: middle;
  text-align: left;
  position: relative;
}
.companyInformation table tr td:first-child {
  width: 30%;
}
.companyInformation table tr:not(:first-child) td {
  border-top: 1px solid rgba(0, 0, 0, 0.2);
}
.companyInformation table td:not(:first-child) {
  border-left: 1px solid rgba(0, 0, 0, 0.2);
}
.iconHeartful {
  position: absolute;
  top: 0;
  right: 2%;
  width: 43px;
}
.companyInformation .enquiriesLink {
  width: fit-content;
  height: auto;
  background-color: #F5AF2A;
  margin: 0 auto 10%;
  border-radius: 10px;
  padding: 20px 60px;
  color: #FFF;
}
