@charset "utf-8";

@media screen and (max-width:1140px) {


  /* lecturer　講師紹介
  -----------------------------------*/
  .lecturer {
    padding-bottom: 400px;
  }
  .lecturer_inner {
    padding: 30px 30px 50px;
    margin-right: auto;
    max-width: 100%;
  }
  .lecturer h2 {
    width: 137px;
    margin: 0 auto 30px;
  }
  .lecturer_inner dt {
    position: static;
    margin-bottom: 30px;
  }
  .lecturer_inner figure {
    position: static;
    float: right;
    padding: 0px 0 10px 10px;;
  }
  .lecturer_inner::after {
    width: 280px;
    height: 248px;
    left: 0;
    bottom: auto;
    top: 100%;
    margin-top: -40px;
  }
  /* schedule　当日のタイムスケジュール
  -----------------------------------*/
  .schedule {
    margin-top: -300px;
  }
}


@media screen and (max-width:1040px) {
  /* content
  -----------------------------------*/
  .content_inner figure {
    width: 260px;
    top: 60px;
  }
  .info_cont02_state01 {
    width: 300px;
  }
  .info_cont02_text01, .info_cont02_text02 {
    text-shadow: 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff;
  }
  .content .content_inner p br {
    display: none;
  }

  .content_inner figure {
    position: relative;
    margin: auto;
    width: 50%;
  }
  .content h2::after {
    display: none;
  }
}


@media screen and (max-width:800px) {

header .pc {
  display: none;
}

header .sp {
  display: block;
}
  body {
    width: auto;
    min-width: auto;
  }

* {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}

img {
  max-width: 100%;
  height: auto;
}

.sp {
  display: block;
}

header {
  max-width: 100%;
}

.top {
  padding-top: 0;
}

header h1 {
  width: 100%;
}

header .top_link {
  max-width: 90%;
}

header .top_link a {
  border-radius: 5px;
  font-size: 1.5em;
  padding: 1em;
  line-height: 1;
  border: none;
  box-shadow: 0 5px 0 #007924;
}

header .top_link a:hover {
  text-decoration: none;
    background: #20a964;
}

.info {
  padding-bottom: 50px;
}

.info ul {
  padding: 0;
}

.info ul.pc {
  display: none;
}
.info .info_cont h2 {
  width: 100%;
  position: relative;
  left:0;
  top: 0;
  text-align: center;
  margin: 0 auto;
    -webkit-transform: translate(0, 0);
  transform: translate(0, 0);
}

.info ul.sp li {
  width: 100%;
  background: #FFF100;
  color: #222;
  border: 2px solid #222;
  position: relative;
  float: none;
  margin-bottom: 1em;
  padding: 1em;

}

.info_cont02::before {
  border: none;
  background: none;
}

.info_cont02Wrap {
  padding: 0;
  box-shadow: 0 0 5px rgba(0, 0, 0, 0.3);
}

.info_cont02Wrap p {
  font-size: 0.8em;
  font-weight: normal;
  text-align: justify;
}

.info_cont02 p+p {
  margin: 0 0 1em;
}

.info_cont02Wrap .font24 {
  font-size: 1em;
}

.info_cont02Wrap .font33 {
  font-size: 1.2em;
}

.info_cont02Wrap .info_cont02 {
  max-width: 100%;
  padding: 10px;
}

.info_cont02Wrap .info_cont02 .info_cont02_text01 {
  width: auto;
}

.info_cont02Wrap .info_cont02 .info_cont02_text01 br {
  display: none;
}

.info_cont02Wrap .info_cont02 .info_cont02_text02 {
  width: 100%;
}

.info_cont02Wrap .info_cont02 .info_cont02_text02 br {
  display: none;
}

.info_cont02Wrap .info_cont02_state01 {
  display: none;
  float: none;
  position: relative;
  left: 0;
  top: 0;
  width: 80%;
  margin: 0 auto;
}

.info_cont02Wrap .info_cont02_state02 {
  float: none;
  position: relative;
  display: block;
  width: 80%;
  margin: 0 auto;
}

.info_cont02Wrap .info_cont02_oka {
  position: relative;
  text-align: center;
  left: 0;
  width: 80%;
  margin: 0 auto;
}

.content {
  padding-top: 0;
}

.content .content_inner {
  max-width: 100%;
}

.content h2 {
  width: 70%;
}

.content h2::after {
  display: none;
}

.content .content_inner_present {
  max-width: 100%;
}

.content .content_inner p {
  font-size: 0.8em;
  line-height: 2;
  text-align: justify;
  font-weight: normal;
}

.content .content_inner p br {
  display: none;
}

.content .content_inner .underLine {
  padding-bottom: 0;

}

.content .content_inner figure {
  position: relative;
  top: 0;
  left: 0;
  margin: 2em auto ;
  width: 80%;
}

.lecturer .lecturer_inner {
  border: 2px solid #222;
  padding: 2em 1em;
}

.lecturer .lecturer_inner figure {
  float: none;
  margin: 0 auto;
  top: 0;
  left: 0;
  text-align: center;
}

.lecturer .lecturer_inner dl {
  text-align: center;
}

.lecturer .lecturer_inner dl dt {
  font-size: 5vw;
  text-align: center;
  padding: 0;
  margin: 1em 0;
}

.lecturer .lecturer_inner dl dt span {
  font-size: 5vw;
}


.lecturer .lecturer_inner dl dd {
  font-size: 0.8em;
  line-height: 2;
  text-align: justify;
  font-weight: normal;
}

.lecturer .lecturer_inner::after {
  margin: 1em auto 0;
  width: 200px;
}

body .schedule {
  margin-top: -250px;
}

.schedule h2 {
  width: 70%;
}

.schedule dl {
  width: 100%;
}

.schedule dl dt {
  background-image: none !important;
  width: 20%;
  font-size: 4vw;
}

.schedule dl dd {
  font-weight: normal;
  width: 80%;
  font-size: 4vw;
}

.schedule dt:nth-of-type(even), .schedule dd:nth-of-type(even) {
  background-color: #f3f3f3;
}

.schedule dl::before {
  right: 0;
  width: 120px;
  height: 120px;
}

.summary h2 {
  width: 50%;
}

.summary dl {
  font-size: 1em;
  width: 100%;
}

.summary dl dt {
  width: 20%;
  text-align: left;
  padding-left: 0.5em;
}

.summary dl dd {
  margin: 0;
  width: 80%;
  padding-left: 10px;
  font-weight: normal;
}

.summary dl dd span {
  font-size: 1em;
  font-weight: bold;
}

.summary dl dd img {
  max-width: 70%;
}

.summary .summary_link {
  margin-top: 2em;
}

.summary .summary_link a {
  font-size: 6vw;
  padding: 1em;
  border-radius: 5px;
  line-height: 1;
  font-weight: normal;
}

.access {
  padding-left: 1em;
  padding-right: 1em;
}

.access .access_read {
  font-size: 1em;
  text-align: justify;
}

.access .map_wrapper iframe {
  height: 350px;
}

.access dl {
  width: 100%;
}

.access dl dd {
  text-align: justify;
  font-size: 1em;
  font-weight: normal;
  line-height: 1.8;
}

.access dl dd:nth-of-type(2) {
  background-image: none;
  padding-left: 0;
}

.access ul li {
  width: 50%;
}

.form {
  padding-left: 1em;
  padding-right: 1em;
}

.form h3 {
  font-size: 5vw;
  padding: 1em -0px;
}

.form h3+div {
  text-align: justify;
  font-weight: normal;
  font-size: 1em;
}

.form h3+div br {
  display: none;
}

.form form input, .form form textarea {
  background: #eee;
  border: none;
  border-radius: 5px;
}


section.form#form form div button[type=submit] {
  max-width: 100%;
  font-size: 8vw;
  line-height: 1;
  padding: 1em;
  border-radius: 5px;
  border: none;
  box-shadow: 0 5px 0 #007924;
}

section.form#form form div button[type=submit]:hover {
    background: #20a964;
}

footer {
  background: #f9f4e9;
  padding: 1em 0;
}
















}






