@charset "UTF-8";abbr,address,article,aside,audio,b,blockquote,body,canvas,caption,cite,code,dd,del,details,dfn,div,dl,dt,em,fieldset,figcaption,figure,footer,form,h1,h2,h3,h4,h5,h6,header,hgroup,html,i,iframe,img,ins,kbd,label,legend,li,mark,menu,nav,object,ol,p,pre,q,samp,section,small,span,strong,sub,summary,sup,table,tbody,td,tfoot,th,thead,time,tr,ul,var,video{margin:0;padding:0;border:0;outline:0;font-size:100%;vertical-align:baseline;background:transparent}body{line-height:1}article,aside,details,figcaption,figure,footer,header,hgroup,menu,nav,section{display:block}nav ul{list-style:none}blockquote,q{quotes:none}blockquote:after,blockquote:before,q:after,q:before{content:'';content:none}a{margin:0;padding:0;font-size:100%;vertical-align:baseline;background:transparent}ins{text-decoration:none}ins,mark{background-color:#ff9;color:#000}mark{font-style:italic;font-weight:700}del{text-decoration:line-through}abbr[title],dfn[title]{border-bottom:1px dotted;cursor:help}table{border-collapse:collapse;border-spacing:0}hr{display:block;height:1px;border:0;border-top:1px solid #ccc;margin:1em 0;padding:0}input,select{vertical-align:middle}*{-webkit-box-sizing:border-box;-moz-box-sizing:border-box;-o-box-sizing:border-box;-ms-box-sizing:order-box;box-sizing:border-box}ul{list-style: none;}

html{
  width: 100%;
  height: 100%;
  font-size: 62.5%;
}
body{
  position: relative;
  width: 100%;
  font-size: 1.6rem;
  line-height: 2.6rem;
  font-family : YakuHanJP, 'DIN Next™ W01', 'YuGothic', '游ゴシック', "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", 'Meiryo', sans-serif;
  font-weight: 700;
  color: #0000ff;
  min-height: 100%;
  height: auto !important;
  height: 100%;
  padding-bottom: 80px;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
main{
  display: block;
  max-width: calc(960px - (12px*2));
  margin: auto;
}
a{
  text-decoration: none;
}
header{
  position: relative;
  width: 100vw;
  height: 100vh;
  margin-bottom: 24px;
}
header h1{
  position: fixed;
  top: 8px;
  left: 12px;
}
.header-image{
  position: absolute;
  top:0;
  left: 0;
  right: 0;
  bottom: 0;
  max-width: calc(1120px - (12px*2));
  height: 470px;
  margin: auto;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}
.header-image::after{
  content: '';
  display: block;
  clear: both;
}
.header-image div{
  width: 50%;
  height: 100%;
  float: left;
  text-align: center;
}
.header-image div img{
  height: 100%;
}
.header-image-l{
  border-right: solid 1px #0000ff;
}
.header-image-r{
  border-left: solid 1px #0000ff;
}
.header-image-r img{
  margin: auto;
}
.header-image-r .pc{
  display: block;
}
.header-image-r .sp{
  display: none;
}
.lead{
  margin-bottom: 110px;
  text-align: justify;
  padding: 0 12px;
}
.lead p{
  margin-bottom: 18px;
}
section {
  padding: 0 12px;
  margin-bottom: 54px;
}
section#requirements{
  margin-bottom: 80px;
}
section::before{
  content: '';
  display: block;
  width: 24px;
  height: 1px;
  border-top: solid 1px #0000ff;
  margin-bottom: 36px;
}
section#archive{
  margin-bottom: 120px;
}
section h1{
  font-size: 3.2rem;
  line-height: 3.6rem;
  font-weight: 400;
  margin-bottom: 2px;
  font-feature-settings : "palt";
}
section h2{
  font-family :'Yu Gothic StdN W50 E', 'YuGothic', '游ゴシック', "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", 'Meiryo', sans-serif;
  font-size: 6.4vw;
  line-height: 1em;
  font-feature-settings : "palt";
  margin-left: -4px;
  letter-spacing: -0.02em;
}
section h2 br{
  display: none;
}
.form{
  width: 100%;
  margin-bottom: 80px;
  text-align: center;
}
.form a,
.form p{
  display: inline-block;
  margin: auto;
  background-color: #0000ff;
  color: #ffffff;
  font-size: 2.2rem;
  line-height: 1em;
  padding: 18px 24px;
  border: solid 2px #0000ff;
}
.form a:hover{
  background-color: #ffffff;
  color: #0000ff;
}
.lecturer-box{
  position: relative;
  margin-bottom: 60px;
}
.lecturer-box::after{
  content: '';
  display: block;
  clear: both;
}
.lecturer-thumb{
  width: 120px;
  height: 180px;
  margin-right: 12px;
  float: left;
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center;
}
.lecturer-box-inner{
  width: calc(100% - 132px);
  float: left;
  margin-top: -5px;
}
.lecturer-name {
  font-size: 4.2rem;
  line-height: 1em;
}
.lecturer-name .ja{
  font-family :'Yu Gothic StdN W50 E', 'YuGothic', '游ゴシック', "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", 'Meiryo', sans-serif;
  font-feature-settings : "palt";
  letter-spacing: -0.02em;
  margin-right: 4px;
}
.lecturer-name .en{
  font-size: 1.6rem;
  /*vertical-align: 1.2em;*/
}
.lecturer-role{
  font-size: 2.8rem;
  line-height: 3.2rem;
  font-weight: 400;
  margin-bottom: 4px;
  font-feature-settings : "palt";
  letter-spacing: -0.02em;
}
.lecturer-prof{
  font-size: 1.4rem;
  line-height: 2.2rem;
  text-align: justify;
}
.lecturer-date{
  position: absolute;
  display: inline-block;
  font-size: 1.8rem;
  line-height: 1em;
  border: solid 1px #0000ff;
  padding: 4px 6px;
  top: 0;
  right: 0;
}
#requirements a{
  text-decoration: underline;
  color: #0000ff;
}
#requirements a:hover{
  color: #00ffff;
}
.requirements-list{
  border-bottom: solid 1px #0000ff;
}
.requirements-list li{
  border-top: solid 1px #0000ff;
  margin-bottom: 18px;
}
.requirements-list li::after{
  content: '';
  display: block;
  clear: both;
}
.requirements-list li div{
  display: inline-block;
}
.requirements-list li .head{
  width: 130px;
  float: left;
}
.requirements-list li .info{
  width: calc(100% - 130px);
  float: left;
}
.archive-list{
  width: 100%;
  border-bottom: solid 1px #0000ff;
}
.archive-list li{
  width: 100%;
  border-top: solid 1px #0000ff;
}
.archive-list li a{
  display: inline-block;
  width: 100%;
  font-size: 1.8rem;
  line-height: 3.0rem;
  padding: 8px 0;
  color: #0000ff;
}
.archive-list li a:hover{
  color: #ffffff;
  background-color: #0000ff;
  padding: 8px 4px;
}
footer{
  position: absolute;
  width: 100%;
  height: 80px;
  padding: 24px 0;
  bottom: 0;
  font-size: 1.2rem;
  line-height: 2.0rem;
  letter-spacing: 0.04em;
  text-align: center;
}
#bg{
  position: fixed;
  width: 100vw;
  height: 100vh;
  top: 0;
  left: 0;
  padding: 0 24px;
  z-index: -1;
  background-size: 86%;
  background-repeat: no-repeat;
  background-position: center;
  background-image: url(images/map.svg);
}
#bg div{
  position: absolute;
  top:0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
}
#bg div.bg-line{
  max-width: calc(1120px - (12px*2));
  height: 470px;
  border-left: solid 2px #0000ff;
  border-right: solid 2px #0000ff;
}
#bg div.bg-marker{
  width: 32px;
  height: 32px;
  border: solid 8px #aaaaff;
  border-radius: 50%;
  opacity: 0.5;
}
#bg div.bg-marker-name{
  display: inline-block;
  width: 220px;
  height: 50px;
  font-size: 4.2rem;
  line-height: 1em;
  letter-spacing: 0.05em;
  color: #aaaaff;
  opacity: 0.5;
  transform: translateX(60%);
}
@media all and (-ms-high-contrast: none){
  .header-image{
    width: 1144px;
  }
  #bg div.bg-line{
    width: 1144px;
  }
  #bg{
    background-size: contain;
  }
}
@media screen and (min-width: 1280px) {
  section h2{
    font-size: 8.4rem;
  }
}
@media screen and (max-width: 960px) {
  body{
    font-size: 1.4rem;
    line-height: 2.4rem;
    font-family : YakuHanJP, 'DIN Next™ W01', "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", 'Meiryo', sans-serif;
    font-weight: 700;
  }
  header h1{
    display: none;
  }
  .header-image{
    max-width: 100%;
    height: 90%;
    margin: auto;
  }
  .header-image::after{
    content: '';
    display: block;
    clear: both;
  }
  .header-image div{
    width: 100%;
    height: 50%;
    float: none;
    text-align: center;
  }
  .header-image div img{
  }
  .header-image-l{
    border-right: none;
    margin-bottom: 12px;
  }
  .header-image-r{
    border-left: none;
  }
  .header-image-r .pc{
    display: none;
  }
  .header-image-r .sp{
    display: inline-block;
  }
  .lead p{
    margin-bottom: 12px;
  }
  .lead{
    margin-bottom: 48px;
  }
  section {
    margin-bottom: 24px;
  }
  section#requirements{
    margin-bottom: 48px;
  }
  section#archive{
    margin-bottom: 60px;
  }
  section::before{
    margin-bottom: 18px;
  }
  .form{
    margin-bottom: 48px;
  }
  .form a,
  .form p{
    font-size: 1.8rem;
    line-height: 1em;
    padding: 16px 20px;
  }
  section h1{
    font-size: 2.8rem;
    line-height: 3.2rem;
    font-weight: 200;
  }
  section h2{
    font-size: 11.4vw;
    line-height: 1.1em;
    margin-left: 0;
    font-weight: 400;
  }
  section h2 br{
    display: block;
  }
  .lecturer-box{
    margin-bottom: 36px;
  }
  .lecturer-thumb{
    width: 72px;
    margin-right: 8px;
    float: left;
    background-size: contain;
    background-repeat: no-repeat;
    background-position: top;
  }
  .lecturer-box-inner{
    width: calc(100% - 80px);
    margin-top: 0;
  }
  .lecturer-name {
    font-size: 2.8rem;
  }
  .lecturer-name .ja{
    display: inline-block;
    font-weight: 400;
  }
  .lecturer-name .en{
    font-size: 1.2rem;
  }
  .lecturer-role{
    font-size: 2.0rem;
    line-height: 2.6rem;
    font-weight: 200;
    margin-bottom: 4px;
  }
  .lecturer-prof{
    font-size: 1.2rem;
    line-height: 2.0rem;
  }
  .lecturer-date{
    font-size: 1.2rem;
    top: 4px;
  }
  #bg{
    background-size: cover;
  }
  #bg div.bg-line{
    display: none;
  }
  #bg div.bg-marker{
    width: 18px;
    height: 18px;
    border: solid 4px #aaaaff;
  }
  #bg div.bg-marker-name{
    display: inline-block;
    width: 220px;
    height:26px;
    font-size: 2.2rem;
    line-height: 1em;
    transform: translateX(55%);
  }
  .requirements-list li .head{
    width: 100%;
    margin-bottom: 6px;
  }
  .requirements-list li .info{
    width: 100%;
  }
  .archive-list li a{
    font-size: 1.6rem;
    line-height: 2.6rem;
  }
  footer{
    font-size: 1.0rem;
  }
}