@charset "utf-8";
/* -------------------------------------
     sp CSS
 (c) Copyright 2020 Sketches of Design
     version 2020-12-26
------------------------------------- */

/* 1360
--------------------------------------*/
@media screen and (max-width: 1360px) {
  header .inner,
  #main-pic .inner{
    margin: 0 4%;
  }
  #news-area{
    margin: 60px 4% 40px 4%;
  }
  #content #menuarea{
    margin: 60px 4%;
  }
  main section .inner{
    padding: 40px 4%;
  }
  #content .box.info{
    margin: 40px 4% !important;
  }
  #main-pic .flex .data::after{
    left: calc((96vw - 100vw));
    width: calc((100vw - 96vw));
  }

}
/* 1280
--------------------------------------*/
@media screen and (max-width: 1280px) {

  #content #menuarea li{
    margin: 0 15px;
    font-size: 1.4rem;
  }
  .menu > ul > li > div{
    padding: 20px 0;
  }
  #content #menuarea li a::after{
    bottom: 5px;
  }
  #main-pic .flex .date em{
    font-size: 4.0rem;
  }
  h2{
    font-size: 2.8rem;
  }
  #main-pic .flex .date,
  h3{
    font-size: 2.0rem;
  }
  #timetable .detail .time,
  #timetable .list .block .time,
  #ucinfo-area h3{
    font-size: 1.8rem;
  }
  #main-pic .flex.place,
  #timetable .detail .recommend ul li,
  #content dl,
  #content ul,
  #content p{
    font-size: 1.4rem;
  }
  /*
  #main-pic .inner{
    padding-top: 100px;
  }
  #qa-area dt::before,
  #qa-area dd::before{
    width: 26px;
    height: 26px;
    line-height: 26px;
    font-size: 1.6rem;
  }
  #qa-area dt,
  #qa-area dd{
    padding: 0 0 0 36px;
  }
  #qa-area dt{
    line-height: 26px;
  }
  #timetable .detail,
  #timetable .detail .recommend,
  #timetable .detail .recommend.half,
  #about .ucinfo .block,
  #qa-area .box{
    padding: 20px;
  }
  #timetable .detail .recommend.half{
    width:100%;
    margin:5px 0;
    font-size: 1.4rem;
  }
  #timetable .list .block div a{
    padding: 15px;
  }
  #timetable .detail .title-area{
    margin: 0 0 20px 0;
  }
  #timetable .list .block .time{
    width: 170px;
  }
  #timetable .list .block > div{
    width: calc(100% - 170px);
  }
  */
  #main-pic{
  }
  #main-pic .flex .data{
    width: 360px;
  }
  #main-pic .flex .company-list{
    width: calc(100% - 400px);
  }
  #main-pic .text-area h1{
    font-size: 8.0rem;
  }
  #main-pic .inner > .flex{
    margin: 60px 0 20px 0;
  }
  #main-pic .flex .company-list .company .text{
    margin: 10px;
  }
  #main-pic .mainpicbtn{
    width: 130px;
  }
  #main-pic .mainpicbtn .btn {
    width: 130px;
    height: 130px;
  }


}
/*  1024
--------------------------------------*/
@media screen and (max-width: 1024px) {
  #about .text{
    width: 100%;
  }
  #main-pic .inner{
    padding-top: 20px;
  }
/*  #main-pic .tag-area{
    position: static;
    margin-bottom: 20px;
  }
  #main-pic .tag-area{
    display: flex;
    flex-wrap: wrap;
  }
  #main-pic .tag-area ul:first-child{
    margin-bottom: 0;
  }*/
  #timetable .detail .tag span{
    font-size: 1.2rem;
  }
  #timetable .wrap .time{
    font-size: 1.3rem;
  }
  #main-pic .mainpicbtn .btn a,
  #main-pic .inner > .flex{
    font-size: 1.6rem;
  }
  #timetable .detail .speakers .name,
  #main-pic .text-area .event{
    font-size: 1.8rem;
  }
  #main-pic .text-area .catch span{
    font-size: 2.0rem;
  }
  #main-pic .text-area .catch{
    font-size: 4.4rem;
  }
  #main-pic .text-area h1 {
    font-size: 7.0rem;
  }
  #main-pic .text-area h1{
    margin: 20px 0;
  }
  #main-pic .company-list{
    margin-top: 20px;
  }
  #main-pic{
    padding: 90px 0 70px 0;
  }
  /*  #js-slick .slide .pic img{
      max-height: 180px;
    }
    #js-slick .slide .pic{
      height: 182px;
    }
    #about .ucinfo .block{
      width: calc(50% - 10px);
    }
  */
  #timetable .time{
    width: 150px;
  }
  #timetable .col2,
  #timetable .detail{
    width: calc(100% - 150px);
  }
  #timetable .detail .speakers .image,
  #timetable .detail .speakers .image img{
    width: 100px !important;
  }
  #timetable .detail .speakers .namearea {
    width: calc(100% - 120px);
  }
  #timetable .detail{
    padding: 20px;
  }
  #news-area{
    margin: 80px 4% 40px 4%;
  }

}
/*  960
--------------------------------------*/
@media screen and (max-width: 960px) {

  /* font */
  h1{
    font-size: 4.0rem;
  }
  #qa-area .link span,
  h2{
    font-size: 2.0rem;
  }
  #content .link a,
  h3{
    font-size: 1.6rem;
  }
  main p,
  main dl,
  main table,
  main ul,
  #hdmenu nav ul li{
    font-size: 1.3rem;
  }

  /* menu */
  header .inner{
    margin: 0;
  }
  header .inner,
  header{
    height: 60px;
  }
  #hdmenu{
    position: fixed;
    top: 0;
    margin-top: 0;
    padding: 0;
    width: 100%;
  }
  #hdmenu #b-logo{
    position: absolute;
    left: 0;
    right: 0;
    top: 15px;
    margin: auto;
    width: 108px;
    z-index: 1000;
  }
  header #b-logo img{
    width: auto;
    height: 30px;
  }
  .login{
    position: absolute;
    right: 4%;
    z-index: 1000;
    height: 60px;
  }
  #mobile-head{
    position: absolute;
    top: 0;
    background: #fff;
    transition: top 0.65s ease-in;
    -webkit-transition: top 0.65s ease-in;
    -moz-transition: top 0.65s ease-in;
    width: 100%;
    height: 60px;
    z-index: 999;
  }
  #hdmenu nav{
    position: absolute;
    top: -896px;
    width: 100%;
    padding: 0;
    -webkit-transition: .5s ease-in-out;
    -moz-transition: .5s ease-in-out;
    transition: .5s ease-in-out;
  }
  #hdmenu nav ul,
  #hdmenu nav ul li{
    position: static;
  }
  #hdmenu nav ul{
    list-style: none;
    right: 0;
    bottom: 0;
  }
  #hdmenu nav ul > li{
    margin: 0;
    width: 100%;
    background: rgba(255,255,255,.9);
    border-bottom: 1px solid #ccc;
  }
  #hdmenu nav .menu-container{
    padding-top: 0;
  }
  #hdmenu .menu > ul{
    padding: 0;
  }
  #hdmenu .menu > ul > li > div{
    position: static;
    padding: 0 20px 10px 20px !important;
    background: none;
  }
  #hdmenu .menu > ul > li > div ul{
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-start;
  }
  #hdmenu .menu > ul > li > div ul li{
    background: none;
    border: none;
    margin: 0 !important;
  }
  #hdmenu .menu > ul > li > div ul a{
    font-size: 1.2rem;
  }
  #hdmenu .menu > ul > li > div ul a::before{
    right: auto;
    left: 0;
  }
  .toggle_title{
    pointer-events: none;
  }
  #hdmenu .menu > ul > li{
    line-height: 1.5;
  }
  #hdmenu nav ul li a{
    width: 100%;
    display: block;
    padding: 10px;
    line-height: 1.5;
    height: auto;
  }
  #nav-toggle,
  #nav-toggle span {
    position: absolute;
  }
  #nav-toggle {
    display: block;
    left: 4%;
    top: 15px;
    width: 30px;
    height: 30px;
    cursor: pointer;
    z-index: 101;
  }
  #nav-toggle div {
    position: relative;
  }
  #nav-toggle span {
      display: block;
      height: 2px;
      width: 100%;
      background: #1E1F1E;
      left: 0;
      -webkit-transition: .35s ease-in-out;
      -moz-transition: .35s ease-in-out;
      transition: .35s ease-in-out;
  }
  #nav-toggle span:nth-child(1) {
    top: 6px;
  }
  #nav-toggle span:nth-child(2) {
    top: 50%;
  }
  #nav-toggle span:nth-child(3) {
    bottom: 4px;
  }
  .open #nav-toggle span:nth-child(1) {
    top: 14px;
    -webkit-transform: rotate(315deg);
    -moz-transform: rotate(315deg);
    transform: rotate(315deg);
  }
  .open #nav-toggle span:nth-child(2) {
    width: 0;
    left: 50%;
  }
  .open #nav-toggle span:nth-child(3) {
    top: 14px;
    -webkit-transform: rotate(-315deg);
    -moz-transform: rotate(-315deg);
    transform: rotate(-315deg);
  }
  .open nav {
    -moz-transform: translateY(956px);
    -webkit-transform: translateY(956px);
    transform: translateY(956px);
  }
  #hdmenu .active::after{
    display: none;
  }

  /**/
  #main-pic {
    padding: 0 0 50px 0;
  }
  #main-pic .tag-area ul{
    font-size: 1.0rem;
  }
  #main-pic .tag-area li{
    margin: 2px 5px 2px 0;
  }
  #main-pic .flex .date em {
    font-size: 4.0rem;
  }
  #main-pic .flex .date{
    font-size: 2.4rem;
  }
  #news-area h2{
    justify-content: center;
    padding: 15px;
    width: 100px;
  }
  #news-area h2 em{
    margin: 0 0 5px 0;
    font-size: 1.6rem;
  }
  #news-area h2 span{
    font-size: 1.2rem;
    color: #1e1f1e;
  }
  #news-area dl{
    width: calc(100% - 100px) ;
  }
  #news-area{
    padding-right: 0;
  }
  /*
  #js-slick .slide .pic img {
    max-height: 140px;
  }
  #js-slick .slide .pic {
    height: 142px;
  }
  #ucinfo-area h5,
  #js-slick .slide .title{
    font-size: 1.6rem;
  }
  .slick-slide {
    margin: 10px;
  }
  #content #menuarea a{
    padding: 15px 13px 15px 0;
  }
  #content #menuarea li a::after{
    width: 4px;
    height: 4px;
    border-top: 1px solid #fff;
    border-right: 1px solid #fff;
  }
  #timetable .detail h3{
    margin: 5px 0;
  }
  #ucinfo-area h4{
    padding: 0 0 5px 0;
  }
  #about .ucinfo .block,
  #ucinfo-area #after,
  #ucinfo-area #before{
    width: 100%;
  }
  #ucinfo-area p:first-child br{
    display: none;
  }
  #about .ucinfo .block{
    margin-bottom: 20px;
  }
  */
  /**/
  #about .ucinfo .block,
  #timetable .col2 .detail{
    width: 100%;
  }
  #about .ucinfo .block{
    margin-bottom: 20px;
  }







}
/*  768
--------------------------------------*/
@media screen and (max-width: 768px) {

/* diagram */
.diagram .sp{
  display: block !important;
}
.diagram .image{
  display: none;
}
.diagram{
  position: relative;
}
.diagram span{
  display: block;
  position: absolute;
  width: 30px !important;
  height: 30px !important;
  right: 10px;
  margin: -40px 0 0 0;
}
.diagram img{
  max-width: 100%;
  height: auto;
  width /***/:100%;
}

/**/
br.sp{
  display: block;
}
h2 {
  margin: 0 0 20px 0;
}
#main-pic .tag-area a{
  padding: 2px 5px;
}
#main-pic .text-area h1{
  font-size: 9.8vw;
}
#main-pic .text-area .catch {
  font-size: 4.8vw;
}
h4,
#ucinfo-area h3{
  font-size: 1.5rem;
}
#ucinfo-area h5,
#main-pic .text-area .event {
  font-size: 1.4rem;
}
#content p,
#content ul,
#ucinfo-area #after p{
  font-size: 1.3rem;
}
#timetable .detail .flex .image,
#timetable .detail .flex .text,
#timetable .detail .speakers,
#main-pic .flex .company-list,
#main-pic .company-list{
  width: 100%;
}
#content #menuarea{
  padding: 10px 20px;
}
#content #menuarea a {
  padding: 5px 13px 5px 0;
}
/*#timetable .detail .speakers h4 .logo{
  margin: 0 0 20px 0;
}
#timetable .detail .speakers h4 span{
  display: block;
  width: 100%;
}
#timetable .detail .speakers .image{
  width: 120px;
}
#timetable .detail .speakers .text{
  width: calc(100% - 140px);
}
#timetable .detail {
  margin: 0 0 30px 0;
}
#timetable .list .block .time{
  margin-bottom: 10px;
}
#timetable .list .block .title{
  margin-top: 10px;
}
#qa-area dt {
  margin: 15px 0 10px 0;
}
#qa-area dd{
  padding-bottom: 10px;
}
.slick-prev{
  left: 10px !important;
}
.slick-next{
  right: 10px !important;
}*/





}
/*  667
--------------------------------------*/
@media screen and (max-width: 667px) {
/*
  #main-pic .text-area h1{
    font-size: 6.4rem;
  }*/
  #main-pic .flex .company-list img {
    max-height: 130px;
  }
  #timetable .detail .timearea > .flex,
  #timetable .list .block.timeline-02 div.flex div{
    width: 100%;
  }
  #timetable .list .block.timeline-02 div.flex div:first-child{
    margin-bottom: 10px;
  }
  #timetable .detail .calendar{
    justify-content: end;
    margin: 10px 0 0 0;
  }

}
/*  480
--------------------------------------*/
@media screen and (max-width: 480px) {

  img{
    max-width: 100%;
    height: auto;
    width /***/:auto;
  }
/*  #main-pic .flex .company-list ul{
    padding: 10px;
  }*/
  #main-pic .flex .company-list li{
    margin: 15px;
  }
   #main-pic .flex .date {
    font-size: 1.8rem;
  }
  #main-pic .btn a{
    padding: 10px 15px 10px 20px;
    font-size: 1.4rem;
  }
  #main-pic .mainpicbtn{
    width: 110px;
  }
  #main-pic .mainpicbtn .btn {
    width: 110px;
    height: 110px;
  }
  #timetable .time {
    width: 100px;
  }
  #timetable .col2, #timetable .detail {
    width: calc(100% - 100px);
  }
  #timetable .detail .flex .image,
  #timetable .detail .speakers .namearea{
    width: 100% !important;
  }
  #timetable .detail .flex .image{
    text-align: center;
    margin-bottom: 10px;
  }
  #content .link a{
    padding: 10px;
    width: 100%;
  }
  /*
  #about .ucinfo .block div,
  #timetable .detail .speakers .text{
    width: 100%;
  }
  #about h2 br,
  #about .ucinfo .block div br{
    display: none;
  }
  #timetable .detail .speakers h4 .logo{
    margin: 20px;
  }
  #timetable .detail .speakers .image{
    margin: 0 auto;
    width: 200px;
    text-align: center;
  }*/

  #about .ucinfo .ucabout .images{
    margin: 0 auto 20px auto;
    width: 200px;
  }
  #about .ucinfo .block div{
    width: 100%;
  }
  #about .ucinfo .ucabout p br{
    display: none;
  }
/*  #qa-area .box {
    padding: 20px 20px 10px 20px;
  }
  #qa-area .qa-list ul li{
    margin: 0 20px 10px 0;
  }
  .slick-prev {
    left: 5px !important;
  }
  .slick-next {
    right: 5px !important;
  }
  #js-slick .slide .link{
    width: 100%;
  }
  #news-area dl{
    padding: 10px;
  }
  #news-area dl dd{
    margin: 0 0 10px 0;
    padding: 0 0 10px 0;
  }
  #content #menuarea li{
    font-size: 1.2rem;
  }
  #content #menuarea li {
    margin: 0 15px 0 0;
  }
  #timetable .list .block div a{
    padding: 10px;
  }
  #ucinfo-area .application,
  #timetable .list .block{
    padding: 15px;
  }
  #timetable .list .block .title {
    margin-top: 5px;
  }
  #timetable .list .block .time {
    margin-bottom: 5px;
  }
  #ucinfo-area .application {
    margin-bottom: 10px;
  }
  #ucinfo-area p:first-child{
    text-align: left;
  }
  #about .btn a{
    font-size: 1.6rem;
  }*/

}
/*  375
--------------------------------------*/
@media screen and (max-width: 375px) {
  /*
  #main-pic{
    background: url("../img/p-main-pic_sp.png") no-repeat scroll center center;
    background-size: cover;
    background-attachment: scroll;
  }
  #main-pic::before{
    display: none;
  }
  #main-pic .text-area h1{
    line-height: 1;
    font-size: 5.2rem;
  }
  #main-pic .text-area .catch {
    margin: 10px 0 0 0;
    font-size: 2.0rem;
  }
  #main-pic .text-area .catch span{
    font-size: 1.6rem;
  }
  #main-pic .text-area .event {
    font-size: 1.2rem;
    letter-spacing: 0;
  }
  #main-pic .flex .date em {
    font-size: 3.0rem;
  }
  #main-pic .flex .date {
    font-size: 2.0rem;
  }
  #main-pic .flex .deadline em {
    font-size: 2.4rem;
  }
  #main-pic .flex .company-list img {
    max-height: 130px;
  }
  #js-slick .slide .title{
    line-height: 1.5;
  }
*/

}
