@import url('https://fonts.googleapis.com/css?family=Barlow:400,600,600i');

body {
  font-family: 'Yu Gothic', YuGothic, 游ゴシック体, 'ヒラギノ角ゴシック Pro', 'Hiragino Kaku Gothic Pro', メイリオ, Meiryo, Osaka, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
  color: #545454;
  background-color: #f8f9fa;
}
a {
  color: #545454;
}
a:hover {
  text-decoration: none;
  color: #545454;
}
a:focus, a:hover {
  color: #545454;
  text-decoration: none;
}
#Wrap {
  background-image: url(../img/bg_left.png), url(../img/bg_right.png);
  background-position: left top, right top;
  background-repeat: no-repeat, no-repeat;
  background-size: 12% auto, 12% auto;
  background-attachment: fixed, fixed;
}

/* error */
.radio-text.error::before, .error select,select.error, input[type=email].error, input[type=text].error, textarea.error {
  border-color: #ff251e !important;
}
.check-text.error::before {
  border: 1px solid #ff251e !important;
}

/*ヘッダー*/
header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  box-shadow: 0 0 6px #ddd;
  height: 90px;
  background-color: #fff;
  position: fixed;
  z-index: 3;
  width: 100%;
}
#contact_form {
  position: relative;
}
.tophead .logo {
  width: 300px;
  margin-left: 30px;
}
.tophead .logo h1 {
  margin: 0;
}
.tophead .logo img {
  width: 100%;
  display: block;
}
.nav ul {
  display: flex;
  justify-content: space-between;
  list-style: none;
  margin-bottom: 0;
  padding-left: 0;
  align-items: center;
  font-size: 14px;
  font-weight: bold;
  height: 90px;
}
.nav ul li {
  margin-left: 19px;
}
.nav ul li.contact {
  height: 100%;
}
.nav ul .contact a {
  display: flex;
  justify-content: space-between;
  align-items: center;
  color: #fff;
  background:url(../img/contact_button.png) no-repeat right center/contain;
  z-index: -1;
  min-width: 134px;
  height: 100%;
  width: 240px;
  padding-left: 80px;
}
.nav ul .contact a:hover {
  opacity: .8;
}
.navToggle, .globalnavSp {
  display: none;
}
.head_sponsor {
  margin-right: 30px;
  display: -webkit-flex;
  display: flex;
}
.head_sponsor span:first-of-type {
  margin-right: 15px;
}

/*メイン画像（スライダー一枚用）*/
.fes-mainImg {
  width: 100%;
  padding: 90px 0 0;
}
.fes-mainImg img {
  width: 100%;
}

/*スライダー*/
.swiper-container {
  width: 100%;
  padding: 90px 0 40px;
}
.swiper-container img {
  width: 100%;
}
.pc_slide {
  display: block;
}
.sp_slide {
  display: none;
}
.swiper-container-horizontal>.swiper-pagination-bullets {
  bottom: 0;
}
.swiper-container-horizontal>.swiper-pagination-bullets .swiper-pagination-bullet {
  margin: 0px 6px;
}
.swiper-pagination-bullet {
  background: transparent;
  border: 2px solid #000;
  opacity: 1;
  width: 12px;
  height: 12px;
  vertical-align: middle;
}
.swiper-pagination-bullet-active {
  background: #000;
  width: 16px;
  height: 16px;
}

.text-border {
  display: inline;
  padding: 5px;
  background: #c7fa8b;
  line-height: 2.4;
}

.catch-wrap {
  text-align: center;
  margin-bottom: 70px;
}

/*section*/
.content_bgwrap {
  padding-top: 60px;
}
section {
  width: 70vw;
  max-width: 1000px;
  box-shadow: 0 0 8px rgba(77,77,77,0.26);
  margin: 0 auto 60px;
  background-color: #fff;
  padding: 15vh 7vw;
  box-sizing: border-box;
  background-image: linear-gradient(45deg, #397741 3vw, transparent 0) /*左下*/,
                    linear-gradient(-45deg, #50c5ca 3vw, transparent 0) /*右下*/,
                    linear-gradient(135deg, #69d193 3vw, transparent 0) /*左上*/,
                    linear-gradient(-135deg, #97d64d 3vw, transparent 0) /*右上*/;
}
.lead_wrap {
  box-shadow: none;
  background-color: inherit;
  padding: 5vh 0;
  box-sizing: inherit;
  background-image: none;
  text-align: center;
}
.lead_wrap p {
  font-size: 15px;
  font-weight: bold;
}
.apply-wrap {
  padding: 15vh 0;
}
.apply-wrap h1,
.apply-wrap .contact-wrap {
  padding: 0 7vw;
}
.apply-wrap .apply_title {
  width: 116px;
} 
.apply-wrap .apply-cont {
  padding: 0 7vw 3vw;
}
.apply-wrap .apply-inner-cont::before {
  display: block;
  content: '';
  width: 100%;
  height: 5px;
  background: url(../img/dot.png);
  background-repeat: repeat-x;
  background-position: top left;
  background-size: 10px;
}
.apply-wrap .apply-inner-cont::after {
  display: block;
  content: '';
  width: 100%;
  height: 5px;
  background: url(../img/dot.png);
  background-repeat: repeat-x;
  background-position: top left;
  background-size: 10px;
}
.apply-wrap .apply-cont h2 {
  padding-top: 3vw;
  color: #e4007f;
  font-size: 2.2vw;
  line-height: 1.3;
  font-feature-settings: "palt";
}
.apply-wrap .apply-cont h2 span {
  display: inline;
  font-size: 126%;
}
.apply-wrap .apply-cont-box {
  background: #53cdd3;
  border-radius: 10px;
  color: #fff;
  padding: 50px 80px;
  margin-bottom: 3vw;
  font-feature-settings: "palt";
}
.apply-wrap .apply-cont-box .top-cont {
  border-bottom: 2px solid #fff;
  padding-bottom: 20px;
  margin-bottom: 10px;
  font-weight: bold;
}
.apply-wrap .apply-cont-box .top-cont .top-text {
  display: block;
  font-size: 21px;
  margin-bottom: 10px;
}
.apply-wrap .apply-cont-box .top-cont .border-bottom {
  display: inline;
  background: linear-gradient(transparent 70%, #7ee2e6 0%);
  z-index: 1;
  font-size: 22px;
  letter-spacing: 0.01em;
}
.apply-wrap .apply-cont-box .top-cont .yen {
  color: #e4007f;
  font-size: 150%;
}
.apply-wrap .apply-cont-box .date-limit {
  font-size: 15px;
  letter-spacing: 0.1rem;
}
.apply-wrap .apply-cont-box .date-limit .numb {
  font-size: 20px;
}
.apply-wrap .movie-cont {
  padding: 8vh 0;
  background: #f8f9fa;
}
.apply-wrap .movie-inner-cont {
  padding: 0 7vw;
}
.apply-wrap .movie-cont h2 {
  padding: 10px 0;
  color: #50c5ca;
  border-top: solid 2px #50c5ca;
  border-bottom: solid 2px #50c5ca;
}
.apply-wrap .movie-cont .movie-wrap {
  display: flex;
  list-style: none;
  padding: 0;
  margin-bottom: 0;
}
.apply-wrap .movie-cont .movie-wrap li {
  width: 46%;
}
.apply-wrap .movie-cont .movie-wrap li:not(:last-child) {
  margin-right: 8%;
}
.apply-wrap .movie-cont .movie-wrap li p {
  margin: 40px 0 0;
  font-size: 15px;
  font-weight: bold;
  line-height: 1.5;
}
.apply-wrap .movie-cont .movie-wrap .shadow_box {
  position: relative;
  display: block;
  box-shadow: 15px 15px #e3e6e9;
}
.apply-wrap .movie-cont .movie-wrap .shadow_box::after {
  position: absolute;
  content: '';
  top: 50%;
  left: 50%;
  display: block;
  transform: translate(-50%, -50%);
  width: 50px;
  height: 50px;
  background: url(../img/video/joho_video_Icon.png)no-repeat top/contain;
}
.apply-wrap .movie-cont .movie-wrap .youtube {
  position: relative;
  width: 100%;
  height: 0px;
  padding-bottom: 50.25%;
  box-shadow: 15px 15px #e3e6e9;
}
.apply-wrap .movie-cont .movie-wrap .youtube iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.apply-wrap .contact-wrap .btn-contact {
  margin-top: 8vh;
  max-width: 100%;
}
section h1,
.contact_heading {
  color: #50c5ca;
  font-size: 1.8rem;
  font-weight: bold;
  text-align: center;
  margin-bottom: 2em;
}
section h1 span,
.contact_heading span {
  font-family: 'Barlow Semi Condensed', sans-serif;
  font-size: 1.2rem;
  color: #c5c5c5;
  display: block;
  margin-top: 0.5em;
}
section h2 {
  font-size: 1.5rem;
  font-weight: bold;
  text-align: center;
  /*line-height: 1;*/
  margin-bottom: 1.5em;
}
section h2 span {
  font-size: 1.2rem;
  display: block;
  margin-top: 0.5em;
}
section p {
  margin-bottom: 2em;
  line-height: 2em;
  letter-spacing: 0.04em;
  font-size: 1.1vw;
}
section p:last-of-type {
  margin-bottom: 22px;
}
.section01_p.sp_img {
  display: none;
}
.section01_p {
  list-style: none;
  display: -webkit-flex;
  display: flex;
  padding: 0;
  margin: 3em 0 0;
}
.section01_p li:not(:last-of-type) {
  margin-right: .5em;
}
section img {
  width: 100%;
}
.section01_block {
  margin-top: 60px;
}
.section01_block_title {
  display: block;
  text-align: center;
  font-size: 25px;
  font-weight: bold;
  color: #49459a;
  margin-bottom: 1em;
}
.section01_box {
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: space-between;
  justify-content: space-between;
}
.section01_box div:first-child {
  width: 35%;
}
.section01_box div:last-child {
  width: 60%;
}
.section01_box dl {
  display: -webkit-flex;
  display: flex;
  font-size: 14px;
  margin-bottom: .3rem;
}
.section01_box dl dt {
  color: #49459a;
}
.section01_box dl span {
  font-size: 12px;
}
.section02_box_wrap {
  position: relative;
}
.section02_box {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 100%;
}
.section02_box h2 {
  width: 23.3vw;
  margin: auto;
  padding: 0 0 3rem;
}
.section02_box div.pconly {
  display: block;
}
.section02_box p {
  text-align: center;
  color: #FFF;
}
.section02_box_img {
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  margin-top: 60px;
}
.section02_box_img div:first-child {
  margin-right: 2%;
}
.section02_box_link {
  text-align: center;
  margin-top: 2rem;
}
a.text_link {
  color: #50c5ca;
  text-decoration: underline;
  font-size: 1.1vw;
}
.section03_box,
.photobox {
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: space-between;
  justify-content: space-between;
}
.section03_box {
  padding: 0;
  list-style: none;
  margin: 0;
}
.section03_box li {
  width: 48%;
  padding: .5em;
  box-sizing: border-box;
}
.photobox {
  margin-bottom: 1.5rem;
}
.photobox div:first-of-type {
  width: 55%;
}
.photobox div:last-of-type {
  width: 40%;
}
.section03_box li:first-of-type .photobox div:last-of-type {
  background: url(../img/mogi_en.png) no-repeat top right;
  background-size: auto 100%;
}
.section03_box li:last-of-type .photobox div:last-of-type {
  background: url(../img/toyama_en.png) no-repeat top right;
  background-size: auto 100%;
}
.photobox p {
  font-size: 1.5rem;
  font-weight: bold;
  line-height: 1.1;
  margin-top: 2em;
}
.section04_box {
  background: #f8f9fa;
  border-radius: 10px;
  box-shadow: 7px 10px 1px rgba(0,0,0,0.25);
  padding: 5vh 4vw;
}
.section04_box h5 {
  text-align: center;
  color: #50c5ca;
  font-size: 25px;
  margin-top: 0;
  margin-bottom: 1.3em;
}
.section04_box h5 .theme {
  position: relative;
  display: inline-block;
  margin-bottom: 10px;
  padding: 0 55px;
  font-size: 60%;
  color: #69d193;
}
.section04_box h5 .theme::before,
.section04_box h5 .theme::after {
  content: '';
  position: absolute;
  top: 50%;
  display: inline-block;
  width: 47px;
  height: 1px;
  background-color: #69d193;
}
.section04_box h5 .theme:before {
  left: 0;
}
.section04_box h5 .theme:after {
  right: 0;
}
.section04_box h5 span {
  font-size: inherit
}
.black-border .text_link {
  color: #69d193;
}
.lec_ttl {
  color: #fff;
  font-weight: bold;
  font-size: 2vw;
  background: #3d3d3d;
  margin: 0 auto 2vh !important;
  text-align: center;
  width: 85%;
  position: relative;
}
.lec_ttl::before,
.lec_ttl::after {
  content: '';
  width: 9px;
  height: 9px;
  background: #fff;
  border-radius: 50%;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
}
.lec_ttl::before {
  left: 3%;
}
.lec_ttl::after {
  right: 3%;
}
.lec_ttl span {
  color: #50c5ca;
  margin-right: .5em;
}
.section04_box .lec_date {
  display: block;
  width: 60%;
  margin: 0 auto 2vh;
}
.lec_theme {
  padding: 1rem 2rem 2rem;
}
.section04_box h5 {
  margin-bottom: 1em;
}
.lec_thema_img {
  width: 90%;
  margin: auto;
}
.lec_thema_img.is_section02 {
  width: 85%;
}
.lec_thema_img.is_section03 {
  width: 70%;
}
.lec_person_wrap {
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: center;
  justify-content: center;
  flex-wrap: wrap;
  -webkit-flex-wrap : wrap;
  margin: 2rem 0 .5rem;
}
.lec_person_wrap div {
  width: 47%;
}
.lec_person_wrap div:first-child {
  margin-right: 6%;
}
.lec_person_wrap.is_session02 {
  flex-wrap: wrap-reverse;
  -webkit-flex-wrap : wrap-reverse;
}
.lec_person_wrap.is_session02 div {
  width: auto;
}
.lec_person_wrap.is_session02 div:first-child {
  margin-right: auto;
}
.lec_person_wrap.is_session02 .order-wrap {
  display: -webkit-flex;
  display: flex;
}
.lec_person_wrap.is_session02 .lec_person-block {
  width: 47%;
}
.lec_person_wrap.is_session02 .order-wrap .lec_person-block:first-of-type {
  margin-right: 6%;
}
.lec_person_name {
  display: block;
  margin-bottom: 1rem;
  text-align: center;
  font-weight: bold;
  font-size: 1.6rem;
  color: #3d3d3d;
}
.lec_person_name .nema_line {
  position: relative;
  display: inline;
  z-index: 1;
}
.lec_person_name .nema_line::after {
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 120%;
  height: 9px;
  background: #7ee2e6;
  content: '';
  z-index: -1;
}
.lec_person_name .nema_line .small_name {
  font-size: 60%;
}
.lec_person_name .ruby {
  display: block;
  font-size: 50%;
}
.section04_box h2 {
  text-align: left;
  font-size: 1.25rem;
  margin-bottom: 1em;
}
.section04_p {
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-justify-content: center;
  justify-content: center;
  padding: 0;
  margin: 2em 0 0;
  list-style: none;
}
.section04_p li {
  width: 32%;
  text-align: center;
  font-size: 1.1vw;
  font-weight: bold;
}
.section04_p li:not(:nth-of-type(3n)) {
  margin-right: 2%;
}
.sponly {
  display: none;
}
.pconly {
  display: inline-block;
}
.font_pink {
  color: #e4007f;
}
.font_mini {
  font-size: 80%;
}
.section04_box .contact-wrap {
  background: #fff;
  padding: 40px 50px;
}
.section04_box .contact-wrap .contact-title {
  width: 100%;
}
.section04_box .contact-wrap h2 {
  color: #50c5ca;
  margin-bottom: 40px;
  font-size: 1.4rem;
}
.section04_box .lec_person_name {
  margin-bottom: .5rem;
}
.section04_box .contact-wrap p {
  font-size: 1.1vw;
}
.section04_box .contact-wrap dl {
  display: -webkit-flex;
  display: flex;
  margin-bottom: 0;
  font-size: 1.1vw;
  line-height: 1.8rem;
}
.section04_box .contact-wrap dl dt {
  white-space: nowrap;
}

/*応募フォーム*/
.top_formbg {
  background: #000 no-repeat top left;
  background-size: 100%;
  color: #fff;
  text-align: center;
  padding: 0 8vw;
}
.top_formbg h2 {
  font-size: 1.5rem;
  font-weight: bold;
  margin-bottom: 1em;
}
.top_formbg p {
  font-size: 1.1vw;
}
.formbox {
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  flex-wrap: wrap;
  max-width: 1000px;
  margin: 4em auto 0;
}
.caption_box {
  position: relative;
  width: 48%;
  margin-bottom: 2em;
  height: auto;
  padding: 3em 2em 2em;
  border: 1px solid #fff;
  /* 代わりにlinear-gradient()で実装 */
  border-top: none;
  box-sizing: border-box;
  /*  caption用空間を持った枠線を作る */
  background: linear-gradient(to right,
              #fff 25%, transparent 25%,
              transparent 75%, #fff 75%) 0 0 / 100% 1px;
  background-repeat: no-repeat;
  text-align: left;
  line-height: 2.5;
}
.caption_box::before {
  content: attr(data-caption);
  position: absolute;
  top: 0;
  left: 50%;
  /*width: 5em;*/
  height: auto;
  text-align: center;
  transform: translate(-50%,-50%);
  font-weight: bold;
  line-height: 1.1;
}
.caption_box.next100 {
  position: relative;
  margin-bottom: 2em;
  height: auto;
  padding: 3em 2em 2em;
  border: 2px solid #69d193;
  /* 代わりにlinear-gradient()で実装 */
  border-top: none;
  box-sizing: border-box;
  /*  caption用空間を持った枠線を作る */
  background: linear-gradient(to right, #69d193 25%, transparent 25%, transparent 75%, #69d193 75%) 0 0 / 100% 2px;
  background-repeat: no-repeat;
  text-align: left;
  line-height: 2.5;
}
.formlinkbtn {
  margin-bottom: 0;
}
.formlinkbtn a {
  width: 100%;
  display: block;
  padding: .2em 0;
  background: #fff;
  color: #000;
  font-weight: bold;
  font-size: 1.2vw;
  border-radius: 3px;
  text-align: center;
}
.formlinkbtn a:hover {
  opacity: 0.8;
}

/*お問い合わせページ*/
.basic_info {
  margin: 50px auto;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-align-items: center;
  align-items: center;
  font-size: 1.1vw;
}
.basic_info dt {
  width: 30%;
}
.basic_info dd {
  width: 70%;
}
.basic_info dt:not(:last-of-type),
.basic_info dd:not(:last-of-type) {
  margin-bottom: 2rem;
}
.basic_info .font_pink {
  font-size: 90%;
}
.basic_info input,
.basic_info textarea {
  -webkit-appearance: none;
  background: #f2f3f4;
  border: 1px solid #dcdcdc;
  padding: 0.5em;
  border-radius: 3px;
}
.basic_info select{
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  padding: 0;
  margin: 0;
  background: transparent;
  position: relative;
  z-index: 1;
  padding: 0.5em 40px;
  border: 1px solid #dcdcdc;
  color: #8a8f94;
  border-radius: 3px;
}
select::-ms-expand {
    display: none;
}
.selectWrap{
    position: relative;
    display: inline-block;
}
.selectWrap::before{
    content: '';
    position: absolute;
    z-index: 0;
    top: 0;
    right: 0;
    background: #f2f3f4;
    height: 100%;
    width: 100%;
    border-radius: 3px;
}
.selectWrap::after{
    content: '';
    position: absolute;
    z-index: 0;
    top: 50%;
    right: 10px;
    transform: translateY(-50%);
    width: 0;
    height: 0;
    /*color: #545454;*/
    border-style: solid;
    border-width: 10px 6px 0 6px;
    border-color: #545454 transparent transparent transparent;
}
.form_text01 {
  width: 100%;
}
.form_text02 {
  width: 20%;
}
.form_text03 {
  width: 25%;
}
.radio-text {
  padding-left: 25px;
  position: relative;
  margin-right: 1em;
}
.radio-text::before{
  content: '';
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 20px;
  height: 20px;
  border: 1px solid #dcdcdc;
  border-radius: 50%;
  background: #f2f3f4;
}
.radio-text::after{
  content: '';
  display: block;
  position: absolute;
  top: 3px;
  left: 3px;
  width: 11px;
  height: 11px;
  background: #50c5ca;
  border-radius: 50%;
  opacity: 0;
}
.radio-text input[type=radio] {
  background: #f2f3f4;
  border: 0;
  border-radius: 50%;
  position: absolute;
  top: 3px;
  left: 3px;
  width: 11px;
  height: 11px;
}
.radio-text input[type=radio]:checked {
  background: #50c5ca;
}

.mid_info {
  border-top: 1px solid #dbe0e4;
  padding-top: 50px;
}
.mid_info h2 {
  font-size: 1.1vw;
  font-weight: bold;
  text-align: left;
  margin-bottom: 2em;
}
.mid_info h2:not(:first-of-type) {
  margin-top: 50px;
}
.mid_info h2 .font_pink {
  display: inline-block;
  font-size: 90%;
  margin-top: 0;
}
.mid_info .basic_info {
  margin: 0 auto;
}
.mid_info .basic_info.title_wrap {
  margin: 0 auto 1rem;
}
.mid_info .basic_info.title_wrap dt {
  width: 10%;
}
.mid_info .basic_info.title_wrap dd {
  width: 90%;
}
.mid_info .basic_info.title_wrap .form_text02 {
  width: 100%;
}
.mid_info .basic_info.textarea_wrap dd {
  width: 100%;
}
.mid_info .basic_info textarea {
  width: 100%;
  resize: none;
}
.mid_info .basic_info.textarea_wrap .attention_text {
  font-size: 1.1vw;
  margin-bottom: 0;
}
.mid_info p:last-of-type {
  margin-bottom: 1.5em;
}
.attention_info {
  padding-top: 50px;
}
.attention_info h2 {
  font-size: 1.1vw;
  font-weight: bold;
  text-align: left;
}
.check-text {
  padding-left: 25px;
  position: relative;
  display: flex;
  font-size: 1.1vw;
}
.check-text input[type=checkbox] {
  -webkit-appearance:none;
  -moz-appearance:none;
  appearance:none;
  display: none;
}
.check-text::before {
  position: absolute;
  content: '';
  top: 40%;
  left: 0;
  width: 20px;
  height: 20px;
  margin-top: -8px;
  background: #fff;
  border: 1px solid #dcdcdc;
  border-radius: 3px;
  background: #f2f3f4;
}
.check-text input[type=checkbox]:checked {
  display: block;
  position: absolute;
  content: '';
  top: 40%;
  left: 0;
  width: 20px;
  height: 20px;
  margin-top: -8px;
  border-radius: 3px;
  border: 2px solid #50c5ca;
  background: #50c5ca;
}
.check-text input[type=checkbox]:checked::after {
  display: block;
  position: absolute;
  content: '';
  top: 4px;
  left: 2px;
  width: 12px;
  height: 6px;
  border-left: 2px solid #fff;
  border-bottom: 2px solid #fff;
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg);
}
.check-text .text {
  position: relative;
  left: 5px;
}
.attention {
  width: 70vw;
  margin: 50px auto;
  font-size: 1vw;
  color: #999;
}
.attention a {
  color: #50c5ca;
  text-decoration: underline;
}
.attention a:hover {
  text-decoration: none;
}
.formbtn {
  text-align: center;
  margin: 50px auto 0;
}
input[type=submit] {
  background: #397741;
  color: #fff;
  width: 55vw;
  padding: 1em 0;
  border: none;
  cursor: pointer;
  font-family: inherit;
  font-size: 150%;
  font-weight: bold;
}
input[type=submit]:hover {
  opacity: 0.8;
}

/*フッター*/
.footer-default {
  background-color: #000;
  /*height: 176px;*/
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  -webkit-align-items: center;
  align-items: center;
  text-align: center;
  padding: 60px 8vw;
}
.footer-logo {
}
.footer-logo img {
  width: 23vw;
}
.footer-other {
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  -webkit-align-items: center;
  align-items: center;
}
.copyright {
  font-size: 10px;
  font-family: 'Barlow', sans-serif;
  color: #fff;
  white-space: nowrap;
  letter-spacing: 0.12em;
  margin-right: 3em;
}
.pagetop_wrap {
  width: 54px;
}
.pagetop_wrap img {
  width: 100%;
}
#pagetop:hover {
  opacity: 0.8;
}
.pc_none {
  display: none;
}

/* .coming-soon {
  font-weight: bold;
  font-family: 'Barlow', sans-serif;
  background-color: #ecf0f3;
  font-size: 1.8em;
  color: #b8c3cc;
  padding: 4em 0;
} */

.coming-soon {
  text-align: center;
  font-size: 1.3em;
  margin: 40px 0;
}

.btn-contact:visited,
.btn-contact:focus,
.btn-contact {
  font-size: 1.4vw;
  padding: 1.5rem;
  max-width: 470px;
  width: 100%;
  background: #50c5ca;
  color: #fff;
  font-weight: bold;
  border-radius: 3px;
  text-align: center;
}

.btn-contact:active,
.btn-contact:hover {
  text-decoration: none;
  color: #545454;
  background: #fff;
  border: 1px solid #000;
  position: relative;
}
.btn-closed {
  font-size: 1.4vw;
  padding: 1rem;
  max-width: 470px;
  width: 100%;
  font-weight: bold;
  border-radius: 3px;
  text-align: center;
  color: #fff;
  background: #3d3d3d;
}

.catch-text {
  text-align: center;
  font-size: 100%;
}
h5 {
  font-size: 1.2rem;
  font-family: 'Barlow', sans-serif;
  font-weight: bold;
  letter-spacing: 0.2rem;
  margin-top: 22px;
  /*margin-bottom: 32px;*/
  margin-bottom: 22px;
}

.black-border {
  padding: 0;
  border: 6px solid #3d3d3d;
}

h5 span {
  font-size: 80%;
}
section#Lecture h2.catch-head,
section#Theme h2 {
  font-size: 30px;
}
.js-more {
  overflow: hidden;
}
.sponsor-wrap .img-fluid {
  width: 200px;
}
.sponsor-wrap div.row {
  width: 300px;
}

/* フッター上バナー */
.banners_wrap {
  width: 70vw;
  max-width: 1000px;
  margin: 100px auto 60px;
}
.banners_wrap .banners_list {
  display: flex;
  justify-content: center;
  list-style-type: none;
  padding: 0;
}
.banners_wrap .banners_list li {
  width: 18.4%;
}
.banners_wrap .banners_list li:not(:last-child) {
  margin-right: 2%;
}
.banners_wrap .banners_list li a {
  display: flex;
  justify-content: center;
  align-items: center;
  max-width: 132px;
  height: 88px;
  padding: 15px;
  margin: auto;
  -webkit-transition: all 0.2s ease-out 0s;
  -o-transition: all 0.2s ease-out 0s;
  transition: all 0.2s ease-out 0s;
}
.banners_wrap .banners_list li a:hover {
  opacity: .6;
}
.banners_wrap .banners_list li img {
  width: 100%;
}

@media screen and (max-width: 768px) {
  section {
    margin: 0 auto 40px;
  }
  #Wrap {
    background-image: none;
  }
  /*SPヘッダー*/
  .tophead {
    height: 60px;
  }
  .tophead .logo {
    width: 200px;
    margin-left: 20px;
  }
  .nav {
    display: none;
  }
  .navToggle {
    display: block;
    width: 70px;
    height: 100%;
    z-index: 3;
    text-align: center;
    display: -webkit-flex;
    display: flex;
    -webkit-justify-content: center;
    justify-content: center;
    -webkit-align-items: center;
    align-items: center;
  }
  .toggleinner {
    position: relative;
    width: 30px;
    height: 17px;
  }
  .toggleinner, .toggleinner span {
    display: inline-block;
    transition: all .4s;
    box-sizing: border-box;
  }
  .toggleinner span {
    position: absolute;
    left: 0;
    width: 100%;
    height: 2px;
    background-color: #000;
    border-radius: 4px;
  }
  .toggleinner span:nth-of-type(1) {
    top: 5px;
  }
  .toggleinner span:nth-of-type(2) {
    top: 9px;
  }
  .toggleinner span:nth-of-type(3) {
    top: 13px;
  }
  .navToggle.active span:nth-child(1) {
    top: 30%;
    left: 10%;
    width: 80%;
    -webkit-transform: rotate(-45deg);
    transform: rotate(-45deg);
  }
  .navToggle.active span:nth-child(2),
  .navToggle.active span:nth-child(3) {
    top: 30%;
    left: 10%;
    width: 80%;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
  }
  .head_sponsor {
    margin-right: 20px;
    width: calc((100% - 200px - 40px) * 0.6);
    -webkit-justify-content: space-between;
    justify-content: space-between;
    -webkit-align-items: center;
    align-items: center;
  }
  .head_sponsor span:first-of-type {
    margin-right: 0.5em;
  }
  .head_sponsor img {
    width: 100%;
  }
  /*SPグロナビ*/
  .globalnavSp {
    display: block;
    position: fixed;
    top: 0;
    left: 0;
    margin-top: 60px;
    background: rgba(80,197,202,.8);
    width: 100%;
    height: 100%;
    transform: translateX(100%);
    transition: all .6s;
    z-index: 2;
  }
  .globalnavSp ul {
    list-style: none;
    padding: 0;
    margin-top: 110px;
    text-align: center;
    font-size: 18px;
  }
  .globalnavSp ul li {
    padding: 10px 0;
  }
  .globalnavSp ul li a {
    color: #fff;
  }
  .contact_button_wrapper {
    display: flex;
    justify-content: center;
  }
  .gnavSp-contact {
    display: inline-block;
    background: #fff;
    padding: 15px 30px;
    border-radius: 4px;
    font-size: 14px;
    font-weight: bold;
    width: 80%;
    text-align: center;
    position: relative;
    margin-top: 10px;
  }
  .gnavSp-contact .contact {
    color: #58c7cc;
    font-size: 10px;
    position: absolute;
    top: 40%;
    right: 10px;
  }
  .globalnavSp.active {
    transform: translateX(0%);
  }
  /*SPスライダー*/
  /*メイン画像（スライダー一枚用）*/
  .fes-mainImg {
    width: 100%;
    padding: 60px 0 0;
  }
  .fes-mainImg img {
    width: 100%;
  }
  .swiper-container {
    padding: 60px 0 40px;
  }
  .pc_slide {
    display: none;
  }
  .sp_slide {
    display: block;
  }
  /*SP section*/
  .content_bgwrap {
    padding-top: 2rem;
    background: none;
  }
  section {
    width: 90vw;
    padding: 4rem 1.5rem;
    box-shadow: -4px -4px 8px rgba(77,77,77,0.26);
    background-image: linear-gradient(45deg, #397741 10vw, transparent 0) /*左下*/,
                      linear-gradient(-45deg, #50c5ca 10vw, transparent 0) /*右下*/,
                      linear-gradient(135deg, #69d193 10vw, transparent 0) /*左上*/,
                      linear-gradient(-135deg, #97d64d 10vw, transparent 0) /*右上*/;
  }
  section h1,
  .contact_heading {
    font-size: 6.4vw;
  }
  .contact_heading {
    margin-bottom: 1em;
  }
  section h1 span,
  .contact_heading span,
  section h2 span,
  .lec_person_wrap p,
  .section04_box .contact-wrap p,
  .section04_box .contact-wrap dl,
  .section04_box .contact-wrap dl a.text_link,
  .lead_wrap p,
  .apply-wrap .movie-cont .movie-wrap li p,
  .apply-wrap .apply-cont-box .top-cont .top-text {
    font-size: 3.47vw;
  }
  section h2 {
    font-size: 5.3vw;
  }
  section#Lecture h2.catch-head {
    font-size: 6.0vw;
  }
  section p,
  a.text_link {
    font-size: 3.73vw;
  }
  .section01_p.pc_img {
    display: none;
  }
  .section01_p.sp_img {
    display: -webkit-flex;
    display: flex;
  }
  .section01_p {
    -webkit-justify-content: space-between;
    justify-content: space-between;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
  }
  .section01_p li:not(:last-of-type) {
    margin-right: 0;
    margin-bottom: .2rem;
    width: 49.5%;
  }
  .section01_p li:last-of-type {
    width: 100%;
  }
  .section01_block {
    margin-top: 3em;
  }
  .section01_block_title {
    font-size: 20px;
  }
  .section01_box {
    flex-wrap: wrap-reverse;
  }
  .section01_box div:first-child {
    width: 100%;
  }
  .section01_box div:last-child {
    width: 100%;
  }
  .section01_box dl {
    display: block;
    margin-bottom: 2em;
  }
  .section02_box_wrap {
    background: none;
  }
  .section02_box h2 {
    width: auto;
    margin: 0 0 2rem;
    padding: 0;
  }
  .section02_box {
    position: static;
    top: auto;
    left: auto;
    transform: none;
    width: auto;
    display: block;
    margin: 0;
  }
  .section02_box div.pconly {
    display: none;
  }
  .section02_box p {
    text-align: left;
    color: inherit;
  }
  .section02_box_img {
    display: block;
    margin-top: 50px;
  }
  .section02_box_img div:first-child {
    margin-right: 0;
  }
  .section02_box div {
    width: 100%;
    margin-bottom: 1em;
  }
  .section02_box_link {
    margin-top: 30px;
    font-size: 3.73vw;
  }
  .section03_box {
    display: block;
  }
  .section03_box li {
    width: 100%;
  }
  .section03_box li:first-of-type {
    margin-bottom: 2em;
  }
  .photobox p {
    font-size: 6.4vw;
  }
  .lec_ttl {
    font-size: 4.27vw;
  }
  .section04_box {
    padding: 5vh 5vw;
    box-shadow: 3px 5px 1px rgba(0,0,0,0.25);
  }
  .section04_box h2 {
    font-size: 5.06vw;
  }
  .section04_p {
    -webkit-justify-content: space-between;
    justify-content: space-between;
  }
  .section04_p li {
    font-size: 3.47vw;
    width: 48%;
  }
  .section04_p li:not(:nth-of-type(3n)) {
    margin-right: 0;
  }
  .lec_theme {
    padding: 80% 0 0;
  }
  .section04_box h5 {
    margin-bottom: .8em;
  }
  .section04_box h5 .theme {
    padding: 0 33px;
    font-size: 3vw;
  }
  .section04_box h5 .theme::before,
  .section04_box h5 .theme::after {
    width: 27px;
  }
  .sponly {
    display: block;
  }
  .pconly {
    display: none;
  }
  .lec_person_wrap {
    flex-wrap: wrap;
    -webkit-flex-wrap: wrap; 
  }
  .lec_person_wrap div {
    width: 100%;
    margin-bottom: 1rem;
  }
  .lec_person_wrap.is_session02 .lec_person-block {
    width: 100%;
  }
  .lec_person_wrap.is_session02 .order-wrap {
    flex-wrap: wrap;
    -webkit-flex-wrap: wrap; 
  }
  .lec_person_wrap.is_session02 .order-wrap .lec_person-block:first-of-type {
    margin-right: 0;
  }
  .lec_person_name .nema_line::after {
    width: 110%;
    height: 5px;
  }
  .lec_person_name .nema_line .small_name {
    font-size: 50%;
  }
  .section04_box .lec_date {
    width: 82%;
  }
  .section04_box .js-more {
    margin-bottom: 10px;
  }
  .section04_box .contact-wrap {
    padding: 20px;
  }
  .section04_box .contact-wrap h2 {
    margin-bottom: 20px;
  }
  .section04_box .contact-wrap dl {
    flex-wrap: wrap;
    margin-bottom: 15px;
    line-height: 1.6em;
  }
  .black-border {
    position: relative;
    padding: 3px 0;
    border-top: 3px solid #3d3d3d;
    border-bottom: 3px solid #3d3d3d;
    border-right: none;
    border-left: none;
  }
  hr {
    border-top: 1px solid #3d3d3d;
  }
  hr.border-top {
    position: relative;
    margin: 0 0 30px;
    z-index: 1;
  }
  hr.border-bottom {
    margin: 30px 0 0;
  }
  .lec_person_img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
  }
  .lec_thema_img {
    width: 90%;
    margin: auto;
  }
  .lec_thema_img.is_section02 {
    width: 95%;
  }
  .lec_thema_img.is_section03 {
    width: 95%;
  }
  .lec_person_img_txt {
    font-size: 10px;
  }
  /* SP情報銀行 */
  .lead_wrap {
    padding: 0;
    text-align: left;
  }
  .lead_wrap p {
    font-weight: normal;
  }
  .apply-wrap {
    padding: 8vh 0;
  }
  .apply-wrap h1 {
    margin-bottom: 1em;
  }
  .apply-wrap .apply-cont {
    padding: 0 7vw 8vw;
  }
  .apply-wrap .apply-cont h2 {
    padding-top: 5vw;
    margin-bottom: 5vw;
    font-size: 4.6vw;
  }
  .apply-wrap .apply-cont-box {
    padding: 30px;
    margin-bottom: 5vw;
  }
  .apply-wrap .apply-cont-box .top-cont {
    margin-bottom: 0;
  }
  .apply-wrap .apply-cont-box .top-cont .border-bottom {
    background: linear-gradient(transparent 70%, #7ee2e6 0%);
    font-size: 4.2vw;
    line-height: .3;
  }
  .apply-wrap .apply-cont-box .top-cont .border-bottom:first-child {
    margin-bottom: 10px;
  }
  .apply-wrap .apply-cont-box .top-cont .bottom-text {
    display: block;
    margin-top: 7px;
  }
  .apply-wrap .apply-inner-cont::before,
  .apply-wrap .apply-inner-cont::after {
    background-size: 7px;
  }
  .apply-wrap .apply-cont-box .date-limit {
    font-size: 3.47vw;
  }
  .apply-wrap .movie-cont {
    padding: 8vw 0;
  }
  .apply-wrap .movie-cont h2 {
    font-size: 4.6vw;
    line-height: 1.3;
  }
  .apply-wrap .movie-cont .movie-wrap {
    flex-wrap: wrap;
  }
  .apply-wrap .movie-cont .movie-wrap li {
    width: 100%;
  }
  .apply-wrap .movie-cont .movie-wrap li:not(:last-child) {
    margin-right: 0;
    margin-bottom: 30px;
  }
  .apply-wrap .movie-cont .movie-wrap li p {
    margin: 30px 0 0;
    font-weight: normal;
  }
  .apply-wrap .movie-cont .movie-wrap .youtube,
  .apply-wrap .movie-cont .movie-wrap .shadow_box {
    box-shadow: 10px 10px #e3e6e9;
  }
  .apply-wrap .contact-wrap .btn-contact {
    margin-top: 5vh;
  }
  /*SP応募フォーム*/
  .top_formbg {
    background: #000 no-repeat top 0 left 29%;
    background-size: 220%;
  }
  .top_formbg h2 {
    font-size: 5.07vw;
  }
  .top_formbg p {
    font-size: 3.2vw;
  }
  .caption_box {
    font-size: 3.47vw;
  }
  .caption_box::before {
    font-size: 6.13vw;
    line-height: 1.1;
    width: 80%;
  }
  .formlinkbtn a {
    font-size: 4.27vw;
  }
  .formbox {
    display: block;
    margin-top: 3em;
  }
  .caption_box {
    width: calc(90vw - 3rem);
    margin: 0 auto 3em;
  }
  /*SPお問い合わせページ*/
  .basic_info {
    display: block;
  }
  .basic_info dt,
  .basic_info dd {
    width: 100%;
  }
  .basic_info dt,
  .mid_info h2,
  .attention_info h2,
  .check-text .text {
    font-size: 4vw;
  }
  .basic_info dd {
    font-size: 3.73vw;
  }
  .basic_info dt:not(:last-of-type) {
    margin-bottom: 0;
  }
  .basic_info .font_pink,
  .mid_info p,
  .attention p,
  .mid_info h2 .font_pink,
  .mid_info .basic_info.textarea_wrap .attention_text {
    font-size: 2.67vw;
  }
  .mid_info p {
    line-height: 1.6;
  }
  .mid_info .basic_info.title_wrap {
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
  }
  .mid_info .basic_info.title_wrap dt,
  .mid_info .basic_info.title_wrap dd,
  .mid_info .basic_info.title_wrap .form_text02 {
    width: 100%;
  }
  .attention,
  input[type=submit] {
    width: calc(90vw - 3rem);
  }
  .formbtn {
    margin-top: 2em;
  }
  input[type=submit] {
    font-size: 4.53vw;
    padding: 1.5em 0;
  }
  /*SPフッター*/
  .footer-default {
    display: block;
  }
  .footer-logo {
    width: 100%;
    margin-bottom: 3rem;
  }
  .footer-logo img {
    width: 60vw;
    margin: 0 auto;
  }
  .footer-other {
    -webkit-flex-direction: column-reverse;
    flex-direction: column-reverse;
  }
  .pagetop_wrap {
    margin-bottom: 3rem;
    width: 100%;
  }
  .pagetop_wrap span {
    margin: 0 0.5rem;
  }
  .pagetop_wrap img {
    height: 3.5vh;
    width: auto;
  }
  #pagetop {
    margin-left: 1.5rem;
  }
  #pagetop img {
    height: 7vh;
    width: auto;
  }
  .copyright {
    margin-right: 0;
  }
  .pc_none {
    display: inline-block;
  }

  .btn-contact {
    width: 100%;
    font-size: 4.27vw;
  }
  .btn-closed {
    width: 100%;
    font-size: 4.27vw;
  }
  
  .catch-wrap {
    text-align: left;
  }

  .catch-text {
    text-align: justify;
    font-weight: bold;
    font-size: 90%;
  }
  h5{
    line-height: 1.1;
    color: inherit;
    font-size: 1.2rem;
    font-family: 'Barlow', sans-serif;
    font-weight: bold;
    letter-spacing: 0.2rem;
    margin-top: 20px;
    margin-bottom: 24px;
  }
  .lecture-man {
    margin-bottom: 20px;
  }
  .sponsor-wrap .img-fluid {
    height: auto;
  }
  .sponsor-wrap div.row {
    width: auto;
  }
  
  .btn-contact:visited,
  .btn-contact:focus,
  .btn-contact {
    padding: 1rem;
  }
  
  /* フッター上バナー */
  .banners_wrap {
    width: 90vw;
    margin: 40px auto;
  }
  .banners_wrap .banners_list {
    flex-wrap: wrap;
  }
  .banners_wrap .banners_list li {
    width: 100%;
  }
  .banners_wrap .banners_list li:not(:last-child) {
    margin-right: 0;
  }
  .banners_wrap .banners_list li a {
    margin: auto;
  }
}

@media screen and (max-width: 414px) {
  .lec_theme {
    padding: 76% 0 0;
  }
  .session5_box .lec_theme {
    padding: 85% 0 0;
  }
}

@media screen and (min-width:1024px) {
  section h1, .contact_heading {
    font-size: 29px;
  }
  section h1 span,
  .contact_heading span,
  section h2 span {
    font-size: 19px;
  }
  section h2,
  .photobox p,
  .top_formbg h2 {
    font-size: 24px;
  }
  section#Lecture h2.catch-head,
  section#Theme h2 {
    font-size: 40px;
  }
  a.text_link {
    font-size: 16px;
  }
  #About p,
  .lec_theme p,
  .black-border .text_link {
    font-size: 15px;
  }
  .section02_box p,
  .section04_box .contact-wrap p,
  .section04_box .contact-wrap dl,
  .section04_box .contact-wrap dl a.text_link,
  .basic_info,
  .mid_info h2,
  .attention_info h2,
  .check-text .text {
    font-size: 14px;
  }
  .lec_ttl {
    font-size: 21px;
  }
  .section04_box h2 {
    font-size: 20px;
  }
  .formlinkbtn a {
    font-size: 15px;
  }
  .attention,
  .lec_person_wrap p {
    font-size: 13px;
  }
  .mid_info .basic_info.textarea_wrap .attention_text {
    font-size: 12px !important;
  }
}

@media screen and (min-width:1432px) {
  .apply-wrap .apply-cont h2 {
    font-size: 30px;
  }
}
