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


/*320px（最小）
640px未満 @media screen and (max-width: 639px) {...}
1024px未満 @media screen and (max-width: 1023px) {...}*/


/**
 * Setting
 * -----------------------------------------------------------------------------
 */

@import url("https://fonts.googleapis.com/css?family=Noto+Sans+JP:400,500,700,900&display=swap&subset=japanese"); @import url("https://fonts.googleapis.com/css?family=IBM+Plex+Sans:400,500,700&display=swap"); 
/**
 * Mixin
 * -----------------------------------------------------------------------------
 */

.slick-next { right: 10px !important; }
.slick-prev { left: 10px !important; z-index: 99; }
.slick-slide { position: relative; }
.slick-slide:before { padding-top: calc(1/1.6*100%); display: block; content: ""; }
.slick-slide img { width: 100%; margin: 0 auto; height: 100%; -o-object-fit: cover; object-fit: cover; font-family: "object-fit: cover"; position: absolute; top: 50%; left: 50%; -webkit-transform: translate(-50%, -50%); -ms-transform: translate(-50%, -50%); transform: translate(-50%, -50%); }
.footerCva { margin-top: 0; }
.contents { padding-top: 100px; padding-bottom: 120px; background-color: #fff; }
.lisTtl { font-size: 3.2rem; margin-top: 50px; }
.searchHead { margin-bottom: 50px; }

@media only screen and (max-width: 768px) { .searchHead { margin-bottom: 30px; }
}
.searchBoxToggle { display: none; }

@media only screen and (max-width: 768px) { .searchBoxToggle { display: block;  text-align: center;  font-size: 1.6rem;  margin-top: 30px;  border: 1px solid #ccc;  padding: 10px;  cursor: pointer; }
}
.searchBoxToggle__txt { position: relative; }
.searchBoxToggle__txt::before { content: ""; position: absolute; top: 50%; right: -24px; height: 2px; width: 10px; background-color: #333; -webkit-transform: translate(0, -50%); -ms-transform: translate(0, -50%); transform: translate(0, -50%); }
.searchBoxToggle__txt::after { content: ""; position: absolute; top: 50%; right: -20px; height: 10px; width: 2px; background-color: #333; -webkit-transform: translate(0, -50%); -ms-transform: translate(0, -50%); transform: translate(0, -50%); }
.on .searchBoxToggle__txt::after { display: none; }
.searchBox { margin: 30px auto 0; text-align: center; }

@media only screen and (max-width: 768px) { .searchBox { display: block !important;  display: none !important;  margin: 20px auto 0; }
}
.searchBox select { /* styling */
 background-color: #fff; display: inline-block; font: inherit; line-height: 1.5em; height: 50px; -webkit-box-sizing: content-box; box-sizing: content-box; border: 2px solid #ccc; border-radius: 0; padding: 0.5em 3.5em 0.5em 1em; /* reset */
 margin: 0; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; -webkit-appearance: none; -moz-appearance: none; background-image: -webkit-linear-gradient(45deg, transparent 50%, gray 50%), -webkit-linear-gradient(315deg, gray 50%, transparent 50%), -webkit-linear-gradient(left, #ccc, #ccc); background-image: -o-linear-gradient(45deg, transparent 50%, gray 50%), -o-linear-gradient(315deg, gray 50%, transparent 50%), -o-linear-gradient(left, #ccc, #ccc); background-image: linear-gradient(45deg, transparent 50%, gray 50%), linear-gradient(135deg, gray 50%, transparent 50%), linear-gradient(to right, #ccc, #ccc); background-position: calc(100% - 20px) calc(20px + 2px), calc(100% - 15px) calc(20px + 2px), calc(100% - 40px) 2.5px; background-size: 5px 5px, 5px 5px, 1px 40px; background-repeat: no-repeat; }

@media only screen and (max-width: 768px) { .searchBox select { border-width: 1px;  width: 100% !important;  height: 36px;  background-position: calc(100% - 20px) calc(13px + 2px), calc(100% - 15px) calc(13px + 2px), calc(100% - 40px) 2px;  background-size: 5px 5px, 5px 5px, 1px 30px; }
}

@media only screen and (max-width: 768px) { .searchBox select+select { margin-top: 5px !important; }
}
.searchBoxToggle.on+.searchBox { display: block !important; }
.searchBox__btnBox { margin-top: 30px; }

@media only screen and (max-width: 768px) { .searchBox__btnBox { margin-top: 20px !important; }
}
.searchBox__btnBox button { cursor: pointer; -webkit-box-sizing: border-box; box-sizing: border-box; height: 50px; font-size: 1.6rem; }

@media only screen and (max-width: 768px) { .searchBox__btnBox button { height: 36px; }
}
.searchBox__btnBox .searchBox__btn--search { width: 250px; background: #01adf5; color: #fff; border: none; }

@media only screen and (max-width: 768px) { .searchBox__btnBox .searchBox__btn--search { width: 60%; }
}
.searchBox__btnBox .searchBox__btn--reset { width: 180px; border: #ccc 2px solid; background: #eee; }

@media only screen and (max-width: 768px) { .searchBox__btnBox .searchBox__btn--reset { width: 38%; }
}
.listItem, .programWrap { margin: 0 auto; background: #fff; padding: 30px 40px; }
.listItem { border: 1px solid #ccc; }
.listItem+.listItem, .programWrap+.listItem { margin-top: 40px; }

@media only screen and (max-width: 768px) {
.programWrap { padding: 30px 0; }
 .listItem+.listItem, .programWrap+.listItem { margin-top: 20px; }
}

@media only screen and (max-width: 768px) { .listItem, .programWrap, .inner { width: 94%; }
}
.listItem__ttl { font-size: 2.0rem; padding: 5px; border-bottom: 2px solid #748993; margin-top: 5px; margin-bottom: 20px; }

@media only screen and (max-width: 768px) { .listItem__ttl { font-size: 1.8rem;  margin-bottom: 10px; }
}
.listItem__contents { display: -webkit-box; display: -ms-flexbox; display: flex; }

@media only screen and (max-width: 768px) { .listItem__contents { display: block; }
}
.listItem__img { width: 30%; margin-right: 40px; position: relative; }

@media only screen and (max-width: 768px) {
.listItem__img { width: 100%; }
}
.programItem{width: 1000px!important; }
.programCountry { display: -webkit-box; display: -ms-flexbox; display: flex; }
.programCountry .programCountry__txt { padding-left: 5px; color: #748993; font-weight: bold; }
.programCountry .programCountry__img { height: 30px; width: auto; border: 1px solid #999; display: inline-block; }
.programCountry .programCountry__img+.programCountry__img { margin-left: 3px; }
.listItem__dsc { -webkit-box-flex: 1; -ms-flex: 1; flex: 1; }
.listItem__date { display: -webkit-box; display: -ms-flexbox; display: flex; margin-top: 10px; }
.listItem__date li { margin-right: 10px; }
.listItem__date span { font-weight: bold; }
.program__label { display: -webkit-box; display: -ms-flexbox; display: flex; }
.program__label li { padding: 3px 10px; background: #eee; }
.program__label li+li { margin-left: 10px; }
.program__label .paid { background: #3ba1ee; color: #fff; }
.program__label .unpaid { background: #f94407; color: #fff; }
.program__label .industry { background: #fff; }
.program__catchcopy { font-weight: bold; font-size: 1.8rem; margin-top: 10px; }

@media only screen and (max-width: 768px) {
.program__catchcopy { font-size: 1.6rem; }
.programItem{width: 100%!important; }



}
.program__txt { margin-top: 10px; }
.list__table { width: 100%; margin-top: 10px; border-top: 1px solid #ccc; }
.list__table th, .list__table td { padding: 5px; border-bottom: 1px solid #ccc; width: 25%; font-size: 1rem; }
.list__table th { background: #fafafa; border-right: 1px dotted #ccc; }
.listPoint__item { font-size: 1.6rem; padding-left: 24px; position: relative; }

@media only screen and (max-width: 768px) { .listPoint__item { font-size: 1.6rem; }
}
.listPoint__item+.listPoint__item { margin-top: 10px; }
.listPoint__item:before { width: 0.8em; height: 0.8em; top: calc(1em * 1.8 / 2 - 0.4em); left: 0; content: ""; display: block; position: absolute; background: url(../img/icon/icon-point.svg) no-repeat; background-size: contain; }

@media only screen and (max-width: 768px) { .listPoint__item:before { top: calc(1em * 1.6 / 2 - 0.4em); }
}
.listItem__btn { margin: 30px auto 0; width: 320px; height: 50px; line-height: 50px; display: block; text-align: center; color: #fff; display: block; background: #748993; font-weight: bold; }

@media only screen and (max-width: 768px) { .listItem__btn { width: 100%;  margin: 20px auto 0; }
}
.pagination { text-align: center; margin-top: 40px; }
.pagination span, .pagination a { padding: 10px; background: #eee; }
.pagination .current { background: #748993; color: #fff; }
.program { padding-bottom: 120px; }
.programTtl { font-size: 2.4rem; }

@media only screen and (max-width: 768px) {
.programTtl { font-size: 1.8rem; margin-bottom: 10px; }
}

.program-1 { display: -webkit-box; display: -ms-flexbox; display: flex; margin-top: 30px; }

@media only screen and (max-width: 768px) { .program-1 { display: block;  margin-top: 10px; }
 .program-1>div { width: 100%; }
}
.programSlide { width: 40%; margin-right: 40px; }
.programSlide img { width: 100%; }
.programDsp { -webkit-box-flex: 1; -ms-flex: 1; flex: 1; }

@media only screen and (max-width: 768px) {
.programDsp { margin-top: 20px; }
}

.gaiyo_txt { margin-top: 10px; }
.program_pv{width: 100%; aspect-ratio: 16 / 9; margin: 20px 0;}
.program_pv iframe {width: 100%; height: 100%; border-radius: 10px;}
.programBox { margin: 20px 0 50px 0;}
.program_detailBox{ display: flex; justify-content: space-around;}
.programBox_left{width:49%; padding: 15px; margin: 0 2% 0 0;}
.programBox_left h3{margin-bottom: 5px; font-size: 2rem;}
.programBox_right{width: 49%; padding: 15px; display: flex; flex-wrap: wrap; justify-content: space-around; align-content: flex-start; }
.programBox_right img{width: 48%; height: 160px; margin-bottom: 1.5%; object-fit: cover;}
.programBox_right .map{ position: relative; width: 100%; height: 0; padding-top: 75%;}
.programBox_right .map iframe { position: absolute; top: 0; left: 0; width: 100%; height: 100%;}
.programBox_pics{display: flex; justify-content: space-around; margin: 20px 0; padding: 0 15px;}
.programBox_pics img{width:24%; margin-bottom: 10px; max-height: 200px; object-fit: cover;}

@media only screen and (max-width: 768px) {
.gaiyo_txt { text-align: justify;}
.programBox { margin-top: 30px; }
.program_detailBox{ display: block;}
.programBox_left{width:100%;}
.programBox_left p{ text-align: justify;}
.programBox_right{width:100%;}
.programBox_right img{margin-bottom: 5px;}
.programBox_pics{flex-wrap: wrap;}
.programBox_pics img{width:49%; margin-bottom: 5px;}
}
.programSubttl { position: relative; padding: 0.5em; background: #FFD500; color: #000; text-align: center; margin: 0 0 30px 0; }
.programSubttl::before { position: absolute; content: ''; top: 100%; left: 0; border: none; border-bottom: solid 15px transparent; border-right: solid 20px rgb(149, 158, 155);}

@media only screen and (max-width: 768px) {
.programSubttl {font-size: 2rem; margin-bottom: 10px; }
}

.programSubttl2 { padding: 5px 0; border-bottom: 1px dotted #748993; font-size: 1.8rem; margin-bottom: 20px; }
p+.programSubttl2 { margin-top: 40px; }
.programTbl { width: calc(100% - 30px); border-top: 1px solid #ccc; margin: 0 auto; }
.programTbl th, .programTbl td { padding: 10px; border-bottom: 1px solid #ccc; width: 25%; }
.programTbl th { background: #fafafa; border-right: 1px dotted #ccc; }
.programTbl+.programTbl--spBlock { border-top: none; }
.programTbl--spBlock td { width: 75%; }

.program_recommend{width:100%; border: 5px solid #00A0CF; border-radius: 10px; margin: 30px 0;}
.program_recommend h2{width: 100%; padding: 10px 0; text-align: center; background:#00A0CF; color: #fff; }
.program_recommend p {padding: 20px; line-height: 200%; font-size: 18px; font-weight: bold;}

@media only screen and (max-width: 768px) {
.programTbl { margin: 30px auto; }
.programTbl--spBlock th, .programTbl--spBlock td, .programTbl--spBlock tr { display: block;  width: 100%; text-align: justify;}
.program_recommend h2{font-size: 2rem;  }
.program_recommend p {font-size: 1.6rem;}
}
.programColorBox { background-color: #e9f8ff; border: 1px solid #01adf5; padding: 20px 30px; margin-top: 40px; }

@media only screen and (max-width: 768px) { .programColorBox { margin-top: 20px;  padding: 10px; }
}
.programColorBox+.programColorBox { margin-top: 20px; }

@media only screen and (max-width: 768px) { .programColorBox+.programColorBox { margin-top: 10px; }
}
.programColorBox__ttl { font-size: 1.5rem; }

@media only screen and (max-width: 768px) { .programColorBox__ttl { font-style: 1.3rem; }
}
.program_syuhen__item { display: -webkit-box; display: -ms-flexbox; display: flex; }
.program_syuhen__img { width: 35%; }
.program_syuhen__txt { margin-left: 30px; -webkit-box-flex: 1; -ms-flex: 1; flex: 1; }

@media only screen and (max-width: 768px) { .program_syuhen__item { display: block; }
 
 .program_syuhen__img { width: 100%; }
 .program_syuhen__txt { margin-left: 0;  margin-top: 10px; }
 .program_syuhen__item + .program_syuhen__item{ margin-top: 20px; }
}
.program-2 { display: -webkit-box; display: -ms-flexbox; display: flex; }
.program-2 .programBox { -webkit-box-flex: 1; -ms-flex: 1; flex: 1; }
.program-2 .program-2__move { margin-left: 30px; }

@media only screen and (max-width: 768px) {
 .program-2 { display: block; }
 
 
 .program-2 .program-2__move { margin-left: 0; }
}
.programInline { position: relative; padding-bottom: 56.25%; height: 0; overflow: hidden; }
.programInline iframe { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }
.programBox__dlLink { border-bottom: 1px solid; padding-bottom: 3px; }
.programContact { margin-top: 80px; text-align: center; border-top: 1px solid #ccc; padding-top: 40px; padding-bottom: 40px; font-size: 1.8rem; }

@media only screen and (max-width: 768px) { .programContact { font-size: 1.6rem; }
}
.programContact__btn { border-top: none; border-left: none; border-right: none; background-image: none; font-weight: bold; margin: 40px auto 0; max-width: 300px; width: 100%; height: 60px; font-size: 1.6rem; line-height: 60px; background: #ff5a1a; color: #fff; display: block; text-align: center; }

@media only screen and (max-width: 768px) { .programContact__btn { font-size: 1.4rem;  margin: 20px auto 0; }
}
.kanren { margin-top: 80px; margin-top: 40px; }
.kanren__ttl { position: relative; padding: 12px 8px; font-size: 1.8rem; color: #fff; text-align: center; font-weight: bold; }
.kanren__ttl:before { position: absolute; bottom: -12px; left: 50%; margin-left: -10px; content: ""; display: inline-block; line-height: 0; border-left: 10px solid transparent; border-right: 10px solid transparent; border-left-color: rgba(255, 255, 255, 0); border-right-color: rgba(255, 255, 255, 0); }
.kanrenWrap { display: -ms-grid; display: grid; -ms-grid-columns: (32%)[3]; grid-template-columns: repeat(3, 32%); -webkit-box-pack: justify; -ms-flex-pack: justify; justify-content: space-between; grid-row-gap: 16px; margin-top: 30px; }

@media only screen and (max-width: 768px) { .kanrenWrap { -ms-grid-columns: (49%)[2];  grid-template-columns: repeat(2, 49%); }
}
.kanrenItem { padding: 20px 40px; background: #fff; border: 1px solid #ccc; }

@media only screen and (max-width: 768px) { .kanrenItem { padding: 10px; }
}
.kanrenItem__country { display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-align: center; -ms-flex-align: center; align-items: center; }
.kanrenItem__country p { font-size: 1.2rem; margin-left: 5px; color: #748993; font-weight: bold; }
.kanrenItem__flg { width: 30px; height: auto; }
.kanrenItem__ttl { font-weight: bold; font-size: 1.6rem; margin-top: 5px; }

@media only screen and (max-width: 768px) { .kanrenItem__ttl { font-size: 1.4rem; }
}
.kanrenItem__img { position: relative; margin-top: 5px; }
.kanrenItem__img:before { padding-top: calc(1/1.6*100%); display: block; content: ""; }
.kanrenItem__img img { height: 100%; width: 100%; max-width: inherit; -o-object-fit: cover; object-fit: cover; font-family: "object-fit: cover"; position: absolute; top: 50%; left: 50%; -webkit-transform: translate(-50%, -50%); -ms-transform: translate(-50%, -50%); transform: translate(-50%, -50%); }
.kanrenItem__date { margin-top: 10px; }
.kanrenItem__date li { font-size: 1.2rem; }
.kanrenItem__date li+li { margin-right: 5px; }
.kanrenItem__date span { font-weight: bold; }
.kanrenItem__btn { margin: 10px auto 0; width: 100%; height: 30px; line-height: 30px; font-size: 1.4rem; display: block; text-align: center; color: #fff; display: block; background: #748993; font-weight: bold; }