@charset "utf-8";



/**************************************************/
/********** Responsive Base Font Setting **********/
/**************************************************/

@media print, screen and ( min-width: 769px ) {
  html {
    font-size: 62.5%;
  }
}
@media screen and ( max-width: 768px ) {
  html {
    font-size: 56.3%;
  }
}
@media screen and (max-width: 480px) {
  html {
    font-size: 50.0%;
  }
}



/*******************************************************/
/********** Responsive Contents Setting (480) **********/
/*******************************************************/

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



/****************************************/
/********** Base Setting (480) **********/
/****************************************/

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

.alignleft,
.alignright,
.aligncenter {
  width: 100%;
  display: block!important;
  margin: 20px auto!important;
  text-align: center!important;
}



/****************************/
/********** Header **********/
/****************************/

header {
  width: 100%;
  margin: 0 auto;
  padding: 0;
  position: relative;
  background-color: #205EA9;
}
header #first-section {
  width: 100%;
  margin: 0 auto;
  padding: 0;
  border-bottom: 1px solid #074494;
  position: relative;
  z-index: 7777;
}
header #first-section a {
  color: #FFFFFF;
  text-decoration: none;
}
header #first-section a:hover,
header #first-section .current a {
  text-decoration: underline;
}
header #first-section .wrapper {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: center;
  margin: 0 auto;
  padding: 0;
}
header #first-section .univ {
  padding: 10px;
  width: 100%;
  border-bottom: 1px solid #074494;
}
header #first-section nav {
  display: flex;
  margin: 0 auto;
  padding: 10px;
}
header #first-section nav ul {
  display: flex;
  margin: 0 auto;
  padding: 0;
}
header #first-section nav ul li {
  font-size: 1.2rem;
  margin: 0 6px;
}
header #first-section .language {
  font-size: 1.2rem;
  margin: 0 6px;
}
header #first-section aside {
  border-top: 1px solid #074494;
  width: 100%;
  margin: auto;
  padding: 10px;
}
header #first-section aside ul {
  display: flex;
  justify-content: center;
  margin: 0 auto;
  padding: 0;
}
header #first-section aside ul li {
  margin: 0 12px;
}

header #second-section {
  width: 100%;
  margin: 0 auto;
  padding: 10px;
  position: relative;
  z-index: 7777;
}
header #second-section .wrapper {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: center;
  margin: 0 auto;
  padding: 0;
}
header #second-section h1 {
  margin: 0;
  padding: 0;
  white-space: nowrap;
}
header #second-section h1 a {
  font-size: 1.6rem;
  font-weight: 800;
  text-decoration: none;
  color: #FFFFFF;
  line-height: 80%;
  transition: all 0.3s ease;
}
header #second-section h1 a small {
  font-family: 'Roboto';
  font-size: 1.0rem;
  font-weight: 300;
}
header #second-section h1 a:hover,
header #second-section h1 a:hover:before {
  opacity: 0.7;
  transition: all 0.3s ease;
}
header #second-section h1 a:before {
  content: "";
  display: inline-block;
  width: 27px;
  height: 30px;
  background-image: url("../images/logo-school01.png");
  background-size: contain;
  background-repeat: no-repeat;
  vertical-align: middle;
  margin: 5px 8px 0 0;
  transition: all 0.3s ease;
  float: left;
}
header #second-section .searchform {
  margin: 10px 0;
  padding: 4px;
  background-color: rgba(255,255,255,0.1);
}
header #second-section .searchform input[type="text"]:focus,
header #second-section .searchform button[type="submit"]:focus {
  outline: 0;
}
header #second-section .searchform .searchfield {
  margin: 0;
  padding: 4px;
  color: #CCCCCC;
  font-size: 1.4rem;
  border: none;
  background: none;
  width: 180px;
}
header #second-section .searchform .searchsubmit {
  border: none;
  background: none;
  color: #FFFFFF;
}



/****************************************/
/********** Respomsive Swicher **********/
/****************************************/

#trigger {
  position: fixed;
  z-index: 7777;
  right: 10px;
  top: 9px;
}
#trigger-close {
  position: fixed;
  z-index: 9999;
  right: 10px;
  top: 9px;
}
#trigger a,
#trigger-close a {
  display: block;
  color: #FFFFFF;
  text-decoration: none;
  font-size: 1.2rem;
  background: rgba(0,0,0,0.3);
  border-radius: 3px;
  padding: 2px 10px;
}
#modal-window {
  display: none;
}

#modal-window ul {
  margin: 0;
  padding: 0;
}
#modal-window ul li {
  margin: 0;
  padding: 10px 20px;
  font-size: 1.6rem;
  border-bottom: 1px solid #205EA9;
  background-color: #CCE4ED;
  cursor: pointer;
}
#modal-window ul li .level-icon {
  display: block;
  font-size: 2.0rem;
  float: right;
  color: #205EA9;
  padding: 0;
}

#modal-window ul li > ul {
  display: none;
  margin: 0;
  padding: 10px 0;
}
#modal-window ul li > ul li {
  margin: 0;
  padding: 10px;
  font-size: 1.4rem;
}

#modal-window ul li > ul li > ul {
  display: none;
  margin: 0;
  padding: 10px 0;
}
#modal-window ul li > ul li > ul li {
  margin: 0;
  padding: 10px;
  font-size: 1.4rem;
}

#pageslide {
  display: none;
  position: fixed;
  left: 0;
  top: 0;
  right: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
  overflow: auto;
  z-index: 9999;
  margin: 0;
  padding: 40px 0 0 0;
  background-color: #CCE4ED;
  color: #205EA9;
}



/********************************/
/********** Main Image **********/
/********************************/

#main-image {
  margin: 0 auto;
  padding: 0;
  text-align: center;
  width: 100%;
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
  height: 240px;
  position: relative;
  overflow: hidden;
}
#main-image img {
  width: 177px;
  height: auto;
}
#main-image .wrapper {
  margin: 0 auto;
  padding: 0 40px;
  width: 1080px;
  text-align: left;
}
#main-image .wrapper .contents {
  margin: 0;
  padding: 0;
  text-align: left;
}
#main-image .swiper-slide {
  display: flex;
  align-items: center;
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
  overflow: hidden;
}
#main-image .swiper-slide a {
  display: flex;
  align-items: center;
  color: #FFFFFF;
  text-decoration: none;
  width: 100%;
  height: 100%;
  position: absolute;
  z-index: 1000;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
}

#main-image .swiper-button-white {
  opacity: 0.6;
  transition: opacity 0.3s;
}
#main-image .swiper-button-white:hover {
  opacity: 1;
  filter: alpha(opacity=70);
  transition: opacity 0.3s;
  backface-visibility: hidden;
}
#main-image .swiper-button-prev {
  margin-left: 0;
}
#main-image .swiper-button-next {
  margin-right: 0;
}

#main-image .swiper-pagination {
  bottom: 10px;
  left: 0;
  width: 100%;
  z-index: 7777;
}
#main-image .swiper-pagination-bullet {
  width: 10px;
  height: 10px;
  background-color: #FFFFFF;
  border: 2px solid #CCCCCC;
  opacity: 1;
}
#main-image .swiper-pagination-bullet-active {
  background-color: #205EA9;
  opacity: 1;
}
#main-image .swiper-pagination-bullet {
  margin: 0 7px;
}
#main-image .swiper-button-prev,
#main-image .swiper-button-next {
  z-index: 7777;
}

#main-image .screen-overlay {
  background-color: rgba(0,0,0,0.4);
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  content: "";
}
#main-image .screen-logo {
  width: 100%;
  margin: 0 auto;
  padding: 0;
  text-align: center;
  position: absolute;
  z-index: 6666;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
}
#main-image .screen-logo p {
  font-size: 1.8rem;
  font-weight: 300;
  line-height: 140%;
  color: #FFFFFF;
  width: 100%;
  margin: 20px auto 0 auto;
  padding: 0;
  text-align: center;
}
#main-image .screen-logo p small {
  font-family: 'Roboto';
  font-size: 1.2rem;
  font-weight: 300;
}



/****************************/
/********** Footer **********/
/****************************/

footer {
  width: 100%;
  margin: 30px auto 0 auto;
  padding: 0;
  background-color: #FFFFFF;
  border-top: 1px solid #205EA9;
}
footer #pagetop {
  margin: -20px auto 0 auto;
  padding: 0;
  text-align: center;
}
footer #pagetop a {
  display: block;
  margin: 0 auto;
  width: 45px;
  height: 42px;
  line-height: 42px;
  background-color: #205EA9;
}
footer #pagetop img {
  width: 70%;
  height: auto;
}
footer .footer-nav {
  display: none;
}
footer hr {
  display: none;
}
footer .content {
  margin: 40px 20px 20px 20px;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.home footer address {
  margin: 40px auto 30px auto;
  padding: 0 10px;
  text-align: center;
  font-size: 1.6rem;
}
.page footer address {
  margin: auto;
  padding: 0;
  text-align: center;
  font-size: 1.4rem;
  white-space: nowrap;
  order: 2;
}
footer aside {
  margin: auto;
  padding: 0;
}
footer aside ul {
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  width: 100%;
}
footer aside ul li {
  width: 49%;
  margin: 0 2% 2% 0;
  border: 10px solid #EEEEEE;
}
footer aside ul li:nth-child(even) {
  margin: 0 0 2% 0;
}
footer aside ul li img {
  max-width: 100%;
  height: auto;
}
footer #copyright {
  text-align: center;
  background-color: #205EA9;
  color: #FFFFFF;
  margin: 0 auto;
  padding: 10px;
  width: 100%;
}



/**************************/
/********** Main **********/
/**************************/

main {
  display: block;
  margin: 0 auto;
  padding: 10px;
  flex: 1;
  background-color: #FFFFFF;
  width: 100%;
}



/*****************************/
/********** Content **********/
/*****************************/

#content {
  margin: 0;
  padding: 0;
}



/*****************************/
/********** Sidebar **********/
/*****************************/

#sidebar {
  margin: 20px 0;
  padding: 10px;
  border: 1px solid #C5D2E2;
  border-radius: 3px;
}
#sidebar a:hover {
  text-decoration: none;
}
#sidebar h2 {
  font-size: 1.4rem;
  margin-bottom: 0;
  padding: 6px 10px;
  background-color: #205EA9;
  color: #FFFFFF;
}
#sidebar h2 a {
  display: block;
  font-size: 1.4rem;
  color: #FFFFFF;
  margin: 0;
  padding: 0;
}
#sidebar ul {
  margin: 0
  padding: 0;
}
#sidebar ul li {
  margin: 0;
  padding: 0;
  font-size: 1.4rem;
  color: #205EA9;
  background-color: #FFFFFF;
  border-bottom: 1px solid #205EA9;
}
#sidebar ul li span {
  display: block;
  text-decoration: none;
  margin: 0;
  padding: 6px 12px;
}
#sidebar ul li a {
  display: block;
  text-decoration: none;
  margin: 0;
  padding: 6px 12px;
}
#sidebar ul li a:hover,
#sidebar ul li.current a,
#sidebar ul li.current a:hover,
#sidebar ul li ul li.current a {
  background-color: #C5D2E2;
}

#sidebar ul li > ul {
  margin: 0;
  padding: 0;
}
#sidebar ul li > ul li,
#sidebar ul li.current > ul li a {
  margin: 0;
  padding: 0;
  font-size: 1.4rem;
  color: #205EA9;
  background-color: #FFFFFF;
  border-bottom: none;
}
#sidebar ul li > ul li a,
#sidebar ul li > ul li span,
#sidebar ul li.current > ul li a {
  display: block;
  text-decoration: none;
  border: none;
  margin: 0;
  padding: 3px 0 3px 24px;
}

#sidebar ul li > ul li > ul {
  margin: 0;
  padding: 0;
}
#sidebar ul li > ul li > ul li,
#sidebar ul li.current > ul li > ul li a {
  margin: 0;
  padding: 0;
  font-size: 1.3rem;
  color: #205EA9;
  background-color: #FFFFFF;
  border-bottom: none;
}
#sidebar ul li > ul li > ul li,
#sidebar ul li > ul li > ul li span,
#sidebar ul li.current > ul li > ul li a {
  display: block;
  text-decoration: none;
  border: none;
  margin: 0;
  padding: 0 0 0 24px;
}



/*********************************/
/********** Breadcrumbs **********/
/*********************************/

#breadcrumbs {
  margin: 5px auto;
  padding: 0;
}
#breadcrumbs ul {
  margin: 0 auto;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
}
#breadcrumbs ul li {
  margin: 0 12px 0 0;
  font-size: 1.4rem;
  color: #205EA9;
}
#breadcrumbs ul li:after {
  content: "/";
  margin: 0 0 0 12px;
  font-size: 1.2rem;
}
#breadcrumbs ul li:last-child:after {
  content: none;
}



/**************************/
/********** Home **********/
/**************************/

.home h2 {
  border-bottom: 1px solid #205EA9;
  padding: 10px 0;
}
.home h2 span {
  position: absolute;
  right: 0;
}
.home h2 span a {
  font-size: 1.4rem;
  color: #000000;
  transition: opacity 0.3s;
}
.home h2 span a:hover {
  text-decoration: none;
  opacity: 0.7;
  filter: alpha(opacity=70);
  transition: opacity 0.3s;
}
.home h2 span a:before {
  font-family: 'Font Awesome 5 Free';
  content: "\f138";
  margin: 0 4px 0 0;
  font-size: 1.6rem;
  font-weight: 800;
  color: #BFBFBF;
}

.home #important {
  margin: 0;
  padding: 20px;
  width: 100%;
  border: 2px solid #DE0000;
  border-radius: 10px;
}
.home #important h2 {
  border: none;
  margin: 0 0 10px 0;
  padding: 0;
  color: #DE0000;
  font-size: 1.8rem;
  font-weight: 800;
  text-align: center;
}
.home #important dl {
  margin: 0 0 15px 0;
  padding: 0 0 15px 0;
  border-bottom: 1px solid #205EA9;
  width: 100%;
}
.home #important dl:last-child {
  margin-bottom: 0;
  padding-bottom: 0;
  border: none;
}
.home #important dl dt {
  margin: 0 50px 0 0;
  padding: 0;
}
.home #important dl dt time {
  font-size: 1.5rem;
  font-weight: 800;
  color: #205EA9;
  white-space: nowrap;
}
.home #important dl dd {
  margin: 0;
  padding: 0;
}
.home #important dl dd .title,
.home #important dl dd .title a {
  font-size: 1.6rem;
  font-weight: 800;
  letter-spacing: 0.1rem;
}
.home #important dl dd .description,
.home #important dl dd .description a {
  font-size: 1.4rem;
  margin: 14px 0 0 0;
}

.home #whats-new {
  margin: 20px 0;
  padding: 0;
  width: 100%;
}
/*
.home #whats-new .intro-movie h2 {
  display: none;
}
.home #whats-new .intro-movie {
  position: relative;
  padding-bottom: 56.25%;
  height: 0;
  overflow: hidden;
  margin: 0 auto 20px auto;
}
.home #whats-new .intro-movie iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border: none;
}
*/

.home #whats-new .tabs {
  overflow: hidden;
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  margin: 0 0 15px 0;
  padding: 0;
}
.home #whats-new .tabs li {
  margin: 0 0.5% 0.5% 0;
  border: 1px solid #205EA9;
  border-radius: 4px;
  padding: 4px;
  color: #205EA9;
  font-size: 1.2rem;
  cursor: pointer;
  width: 33%;
  text-align: center;
}
.home #whats-new .tabs li:nth-child(3n) {
  margin: 0 0 0.5% 0;
}
.home #whats-new .tabs li.select {
  background-color: #205EA9;
  color: #FFFFFF;
}
.home #whats-new .hide {
  display: none;
}



/* for home tab */
.home #whats-new ul.tab_content li.hide{
  display: none;
}

.home #whats-new dl {
  display: flex;
  align-items: center;
  margin: 0 0 10px 0;
  padding: 0 0 10px 0;
  border-bottom: 1px dotted #205EA9;
  width: 100%;
}
.home #whats-new dl dt {
  display: flex;
  align-items: center;
  flex-direction: column;
  margin: 0 0 0 20px;
  padding: 0;
  order: 2;
}
.home #whats-new dl dt time {
  font-size: 1.4rem;
  font-weight: 800;
  color: #205EA9;
  white-space: nowrap;
}
.home #whats-new dl dt span {
  display: block;
  text-align: center;
  white-space: nowrap;
  margin: 0;
  padding: 2px 0;
  border-radius: 4px;
  font-size: 1.2rem;
  width: 75px;
}
.home #whats-new dl dt span.cat-news {
  background-color: #00BBD3;
  color: #FFFFFF;
}
.home #whats-new dl dt span.cat-event {
  background-color: #FF9700;
  color: #FFFFFF;
}
.home #whats-new dl dt span.cat-student {
  background-color: #8BC349;
  color: #FFFFFF;
}
.home #whats-new dl dt span.cat-campus {
  background-color: #9D9D9D;
  color: #FFFFFF;
}
.home #whats-new dl dt span.cat-recruitment {
  background-color: #EC68B7;
  color: #FFFFFF;
}
.home #whats-new dl dd {
  margin: 0;
  padding: 0;
  width: 100%;
  order: 1;
}

.home #latest-research {
  margin: 20px 0;
  padding: 0;
  width: 100%;
}
.home #latest-research ul {
  display: flex;
  flex-wrap: wrap;
  margin: 0;
  padding: 0;
}
.home #latest-research ul li {
  width: 48%;
  margin: 0 2% 2% 0;
  background-color: #F8F8F8;
  outline: 1px solid #EEEEEE;
  outline-offset: -1px;
}
.home #latest-research ul li:nth-child(even) {
  margin: 0 0 2% 0;
}
.home #latest-research ul li a {
  display: flex;
  flex-direction: column;
  width: 100%;
  height: 100%;
  font-weight: 700;
  color: #000000;
}
.home #latest-research ul li a:hover {
  text-decoration: none;
  color: #666666;
}
.home #latest-research ul li p {
  margin: 0;
  padding: 14px;
  font-size: 1.4rem;
  font-weight: 500;
}
.home #latest-research ul li span {
  display: inline-block;
  margin: auto 0 0 0;
  padding: 0 14px 14px 14px;
  font-family: "Roboto";
  font-size: 1.2rem;
  font-weight: 400;
  letter-spacing: 0.04rem;
}
.home #latest-research ul li img {
  max-width: 100%;
  width: 100%;
  height: auto;
}

.home #laboratory-list {
  margin: 0 auto;
  padding: 0;
  text-align: center;
  width: 100%;
  background-image: url("../images/laboratory-list.jpg");
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
  height: 100px;
}
.home #laboratory-list a {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
  margin: 0 auto;
  padding: 0;
  text-align: center;
  color: #FFFFFF;
  font-size: 2.4rem;
  font-weight: 800;
  transition: opacity 0.3s;
}
.home #laboratory-list i {
  margin: 0 0 0 20px;
}
.home #laboratory-list a:hover {
  text-decoration: none;
  opacity: 0.7;
  filter: alpha(opacity=70);
  transition: opacity 0.3s;
}

.home #web-lecture-series {
  margin: 10px auto 0 auto;
  padding: 0;
  text-align: center;
  width: 100%;
  background-image: url("../images/web-lecture-series.jpg");
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
  height: 100px;
}
.home #web-lecture-series a {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
  margin: 0 auto;
  padding: 0;
  text-align: center;
  color: #FFFFFF;
  font-size: 2.0rem;
  font-weight: 800;
  transition: opacity 0.3s;
}
.home #web-lecture-series a span {
  font-family: 'Roboto';
  font-size: 2.0rem;
  font-weight: 400;
  margin: 0 0 0 8px;
}
.home #web-lecture-series i {
  margin: 0 0 0 20px;
}
.home #web-lecture-series a:hover {
  text-decoration: none;
  opacity: 0.7;
  filter: alpha(opacity=70);
  transition: opacity 0.3s;
}

.home #banners {
  margin: 20px 0;
  padding: 0;
}
.home #banners ul {
  display: flex;
  flex-wrap: wrap;
  margin: 0 auto;
  padding: 0;
}
.home #banners ul li {
  width: 50%;
  text-align: center;
  padding: 5px;
  background-color: #EEEEEE;
  border: 5px solid #FFFFFF;
}



/***************************/
/********** Pages **********/
/***************************/

.page h2 {
  margin: 0;
  padding: 0;
}

.page div.cat-image.cat-logo {
  background-image: url("../images/cat-image-logo.png");
}

.page .panel-style01 ul {
  display: flex;
  margin: 0;
  padding: 0;
}
.page .panel-style01 ul li {
  width: 180px;
  margin: 0 10px 0 0;
}
.page .panel-style01 ul li:last-child {
  margin: 0;
}
.page .panel-style01 ul li img {
  margin: 0 0 8px 0;
  width: 100%;
  height: auto;
}

.page .panel-style02 {
  display: flex;
  flex-wrap: wrap;
  margin: 20px 0;
  padding: 0;
}
.page .panel-style02 div {
  width: 100%;
  display: flex;
  align-items: center;
  background-color: #E6F1F7;
  margin: 10px 0;
}
.page .panel-style02 div a {
  display: block;
  width: 100%;
  padding: 20px;
}
.page .panel-style02 div.cat-image a {
  display: block;
  width: 100%;
  padding: 20px 200px 20px 20px;
}
.page .panel-style02 div.cat-image {
  background-repeat: no-repeat;
  background-position: right center;
  background-size: 180px auto;
}

.page .panel-style03 {
  display: flex;
  flex-wrap: wrap;
  margin: 20px 0;
  padding: 0;
}
.page .panel-style03 div {
  width: 100%;
  border-top: 1px solid #0076A5;
  border-bottom: 1px solid #0076A5;
  display: flex;
  align-items: center;
  margin: 10px 0;
}
.page .panel-style03 div a {
  display: block;
  width: 100%;
  padding: 10px 0;
}

.page .panel-style05 {
  display: flex;
  flex-wrap: wrap;
  margin: 20px 0;
  padding: 0;
}
.page .panel-style05 div:nth-child(1) {
  width: 100%;
  display: flex;
  align-items: center;
  background-color: #E6F1F7;
  margin: 10px 0;
}
.page .panel-style05 div:nth-child(1) a {
  display: block;
  width: 100%;
  padding: 20px 200px 20px 20px;
}
.page .panel-style05 div:nth-child(1) {
  background-repeat: no-repeat;
  background-position: right center;
  background-size: 180px auto;
}
.page .panel-style05 div:nth-child(2) {
  width: 100%;
  border-top: 1px solid #0076A5;
  border-bottom: 1px solid #0076A5;
  display: flex;
  align-items: center;
  margin: 10px 0;
}
.page .panel-style05 div:nth-child(2) a {
  display: block;
  width: 100%;
  padding: 10px 0;
}

.page .panel-style06 {
  margin: 20px 0;
  padding: 20px;
  width: 100%;
  display: flex;
  flex-direction: column;
  background-color: #E6F1F7;
}
.page .panel-style06 div {
  width: 100%;
  display: flex;
  align-items: center;
  background-color: #E6F1F7;
  margin: 0;
  padding: 2px 0;
  color: #205EA9;
  border-bottom: 1px solid #205EA9;
}
.page .panel-style06 ul {
  margin: 10px;
  padding: 0;
}
.page .panel-style06 ul li {
  margin: 0;
  padding: 0;
}
.page .panel-style06 ul li a {
  font-size: 1.3rem;
}
.page .panel-style06 ul li a:before {
  font-family: 'Font Awesome 5 Free';
  content: "\f105";
  margin: 0 4px 0 0;
  font-size: 1.2rem;
  font-weight: 800;
}

.page #whats-new {
  margin: 20px 0;
  padding: 0;
  width: 100%;
}
.page #whats-new .tabs {
  display: none;
}
.page #whats-new dl {
  display: flex;
  align-items: center;
  margin: 0 0 15px 0;
  padding: 0 0 15px 0;
  border-bottom: 1px solid #205EA9;
  width: 100%;
}
.page #whats-new dl dt {
  display: flex;
  align-items: center;
  flex-direction: column;
  margin: 0 0 0 20px;
  padding: 0;
  order: 2;
}
.page #whats-new dl dt time {
  font-size: 1.4rem;
  font-weight: 800;
  color: #205EA9;
  white-space: nowrap;
}
.page #whats-new dl dt span {
  display: block;
  text-align: center;
  white-space: nowrap;
  margin: 0;
  padding: 2px 0;
  border-radius: 4px;
  font-size: 1.2rem;
  width: 75px;
}
.page #whats-new dl dt span.cat-news {
  background-color: #00BBD3;
  color: #FFFFFF;
}
.page #whats-new dl dt span.cat-event {
  background-color: #FF9700;
  color: #FFFFFF;
}
.page #whats-new dl dt span.cat-student {
  background-color: #8BC349;
  color: #FFFFFF;
}
.page #whats-new dl dt span.cat-campus {
  background-color: #9D9D9D;
  color: #FFFFFF;
}
.page #whats-new dl dt span.cat-recruitment {
  background-color: #EC68B7;
  color: #FFFFFF;
}
.page #whats-new dl dd {
  margin: 0;
  padding: 0;
  width: 100%;
  order: 1;
}

.page #latest-research {
  margin: 0;
  padding: 0;
}
.page #latest-research ul {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 20px auto 0 auto;
  padding: 0;
}
.page #latest-research ul li {
  width: 48%;
  background-color: #F8F8F8;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  margin: 0 auto 20px auto;
}
.page #latest-research ul li:empty {
  background-color: #FFFFFF;
}
.page #latest-research ul li a {
  font-weight: 800;
  color: #000000;
}
.page #latest-research ul li img {
  min-width: 100%;
  height: auto;
}
.page #latest-research ul li p {
  margin: 0;
  padding: 10px;
  font-size: 1.4rem;
  font-weight: 800;
  flex-grow: 1;
}
.page #latest-research ul li  cite {
  margin: 0 10px 10px 10px;
  padding: 10px 0 0 0;
  border-top: 1px solid #205EA9;
  color: #205EA9;
  line-height: 140%;
  font-size: 1.2rem;
  font-style: normal;
  font-weight: 800;
}



}



/***********************************************************/
/********** Responsive Contents Setting (480-768) **********/
/***********************************************************/

@media screen and ( min-width: 481px ) and ( max-width: 768px ) {



/*****************************************/
/********** Base Setting (768) **********/
/*****************************************/

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

.alignleft,
.alignright,
.aligncenter {
  width: 100%;
  display: block!important;
  margin: 20px auto!important;
  text-align: center!important;
}



/****************************/
/********** Header **********/
/****************************/

header {
  width: 100%;
  margin: 0 auto;
  padding: 0;
  position: relative;
  background-color: #205EA9;
}
header #first-section {
  width: 100%;
  margin: 0 auto;
  padding: 0;
  border-bottom: 1px solid #074494;
  position: relative;
  z-index: 7777;
}
header #first-section a {
  color: #FFFFFF;
  text-decoration: none;
}
header #first-section a:hover,
header #first-section .current a {
  text-decoration: underline;
}
header #first-section .wrapper {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: center;
  margin: 0 auto;
  padding: 0;
}
header #first-section .univ {
  padding: 10px;
  width: 100%;
  border-bottom: 1px solid #074494;
}
header #first-section nav {
  display: flex;
  margin: 0 auto;
  padding: 10px;
}
header #first-section nav ul {
  display: flex;
  margin: 0 auto;
  padding: 0;
}
header #first-section nav ul li {
  font-size: 1.3rem;
  margin: 0 7px;
}
header #first-section .language {
  font-size: 1.3rem;
  margin: 0 7px;
}
header #first-section aside {
  border-top: 1px solid #074494;
  width: 100%;
  margin: auto;
  padding: 10px;
}
header #first-section aside ul {
  display: flex;
  justify-content: center;
  margin: 0 auto;
  padding: 0;
}
header #first-section aside ul li {
  margin: 0 12px;
}

header #second-section {
  width: 100%;
  margin: 0 auto;
  padding: 10px;
  position: relative;
  z-index: 7777;
}
header #second-section .wrapper {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: center;
  margin: 0 auto;
  padding: 0;
}
header #second-section h1 {
  margin: 0;
  padding: 0;
  white-space: nowrap;
}
header #second-section h1 a {
  font-size: 1.8rem;
  font-weight: 800;
  text-decoration: none;
  color: #FFFFFF;
  line-height: 80%;
  transition: all 0.3s ease;
}
header #second-section h1 a small {
  font-family: 'Roboto';
  font-size: 1.2rem;
  font-weight: 300;
  letter-spacing: 0.1rem;
}
header #second-section h1 a:hover,
header #second-section h1 a:hover:before {
  opacity: 0.7;
  transition: all 0.3s ease;
}
header #second-section h1 a:before {
  content: "";
  display: inline-block;
  width: 33px;
  height: 36px;
  background-image: url("../images/logo-school01.png");
  background-size: contain;
  background-repeat: no-repeat;
  vertical-align: middle;
  margin: 5px 10px 0 0;
  transition: all 0.3s ease;
  float: left;
}
header #second-section .searchform {
  margin: 10px 0;
  padding: 4px;
  background-color: rgba(255,255,255,0.1);
}
header #second-section .searchform input[type="text"]:focus,
header #second-section .searchform button[type="submit"]:focus {
  outline: 0;
}
header #second-section .searchform .searchfield {
  margin: 0;
  padding: 4px;
  color: #CCCCCC;
  font-size: 1.4rem;
  border: none;
  background: none;
  width: 180px;
}
header #second-section .searchform .searchsubmit {
  border: none;
  background: none;
  color: #FFFFFF;
}



/****************************************/
/********** Respomsive Swicher **********/
/****************************************/

#trigger {
  position: fixed;
  z-index: 7777;
  right: 10px;
  top: 9px;
}
#trigger-close {
  position: fixed;
  z-index: 9999;
  right: 10px;
  top: 9px;
}
#trigger a,
#trigger-close a {
  display: block;
  color: #FFFFFF;
  text-decoration: none;
  font-size: 1.2rem;
  background: rgba(0,0,0,0.3);
  border-radius: 3px;
  padding: 2px 10px;
}
#modal-window {
  display: none;
}

#modal-window ul {
  margin: 0;
  padding: 0;
}
#modal-window ul li {
  margin: 0;
  padding: 10px 20px;
  font-size: 1.6rem;
  border-bottom: 1px solid #205EA9;
  background-color: #CCE4ED;
  cursor: pointer;
}
#modal-window ul li .level-icon {
  display: block;
  font-size: 2.0rem;
  float: right;
  color: #205EA9;
  padding: 0;
}

#modal-window ul li > ul {
  display: none;
  margin: 0;
  padding: 10px 0;
}
#modal-window ul li > ul li {
  margin: 0;
  padding: 10px;
  font-size: 1.4rem;
}

#modal-window ul li > ul li > ul {
  display: none;
  margin: 0;
  padding: 10px 0;
}
#modal-window ul li > ul li > ul li {
  margin: 0;
  padding: 10px;
  font-size: 1.4rem;
}

#pageslide {
  display: none;
  position: fixed;
  left: 0;
  top: 0;
  right: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
  overflow: auto;
  z-index: 9999;
  margin: 0;
  padding: 40px 0 0 0;
  background-color: #CCE4ED;
  color: #205EA9;
}



/********************************/
/********** Main Image **********/
/********************************/

#main-image {
  margin: 0 auto;
  padding: 0;
  text-align: center;
  width: 100%;
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
  height: 320px;
  position: relative;
  overflow: hidden;
}
#main-image img {
  width: 240px;
  height: auto;
}
#main-image .wrapper {
  margin: 0 auto;
  padding: 0 40px;
  width: 1080px;
  text-align: left;
}
#main-image .wrapper .contents {
  margin: 0;
  padding: 0;
  text-align: left;
}
#main-image .swiper-slide {
  display: flex;
  align-items: center;
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
  overflow: hidden;
}
#main-image .swiper-slide a {
  display: flex;
  align-items: center;
  color: #FFFFFF;
  text-decoration: none;
  width: 100%;
  height: 100%;
  position: absolute;
  z-index: 1000;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
}

#main-image .swiper-button-white {
  opacity: 0.6;
  transition: opacity 0.3s;
}
#main-image .swiper-button-white:hover {
  opacity: 1;
  filter: alpha(opacity=70);
  transition: opacity 0.3s;
  backface-visibility: hidden;
}
#main-image .swiper-button-prev {
  margin-left: 0;
}
#main-image .swiper-button-next {
  margin-right: 0;
}

#main-image .swiper-pagination {
  bottom: 10px;
  left: 0;
  width: 100%;
  z-index: 7777;
}
#main-image .swiper-pagination-bullet {
  width: 11px;
  height: 11px;
  background-color: #FFFFFF;
  border: 2px solid #CCCCCC;
  opacity: 1;
}
#main-image .swiper-pagination-bullet-active {
  background-color: #205EA9;
  opacity: 1;
}
#main-image .swiper-pagination-bullet {
  margin: 0 7px;
}
#main-image .swiper-button-prev,
#main-image .swiper-button-next {
  z-index: 7777;
}

#main-image .screen-overlay {
  background-color: rgba(0,0,0,0.4);
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  content: "";
}
#main-image .screen-logo {
  width: 100%;
  margin: 0 auto;
  padding: 0;
  text-align: center;
  position: absolute;
  z-index: 6666;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
}
#main-image .screen-logo p {
  font-size: 2.0rem;
  font-weight: 300;
  line-height: 140%;
  color: #FFFFFF;
  width: 100%;
  margin: 30px auto 0 auto;
  padding: 0;
  text-align: center;
}
#main-image .screen-logo p small {
  font-family: 'Roboto';
  font-size: 1.6rem;
  font-weight: 300;
}



/****************************/
/********** Footer **********/
/****************************/

footer {
  width: 100%;
  margin: 40px auto 0 auto;
  padding: 0;
  background-color: #FFFFFF;
  border-top: 1px solid #205EA9;
}
footer #pagetop {
  margin: -25px auto 0 auto;
  padding: 0;
  text-align: center;
}
footer #pagetop a {
  display: block;
  margin: 0 auto;
  width: 55px;
  height: 52px;
  line-height: 52px;
  background-color: #205EA9;
}
footer #pagetop img {
  width: 80%;
  height: auto;
}
footer .footer-nav {
  display: none;
}
footer hr {
  display: none;
}
footer .content {
  margin: 40px 20px 20px 20px;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.home footer address {
  margin: 40px auto 30px auto;
  padding: 0 10px;
  text-align: center;
  font-size: 1.6rem;
}
.page footer address {
  margin: auto;
  padding: 0;
  text-align: center;
  font-size: 1.4rem;
  white-space: nowrap;
  order: 2;
}
footer aside {
  margin: auto;
  padding: 0;
}
footer aside ul {
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  width: 100%;
}
footer aside ul li {
  width: 32%;
  margin: 0 2% 2% 0;
  border: 10px solid #EEEEEE;
}
footer aside ul li:nth-child(3n) {
  margin: 0 0 2% 0;
}
footer aside ul li img {
  max-width: 100%;
  height: auto;
}
footer #copyright {
  text-align: center;
  background-color: #205EA9;
  color: #FFFFFF;
  margin: 0 auto;
  padding: 10px;
  width: 100%;
}



/**************************/
/********** Main **********/
/**************************/

main {
  display: block;
  margin: 0 auto;
  padding: 10px;
  flex: 1;
  background-color: #FFFFFF;
  width: 100%;
}



/*****************************/
/********** Content **********/
/*****************************/

#content {
  margin: 0;
  padding: 0;
}



/*****************************/
/********** Sidebar **********/
/*****************************/

#sidebar {
  margin: 20px 0;
  padding: 10px;
  border: 1px solid #C5D2E2;
  border-radius: 3px;
}
#sidebar a:hover {
  text-decoration: none;
}
#sidebar h2 {
  font-size: 1.4rem;
  margin-bottom: 0;
  padding: 6px 10px;
  background-color: #205EA9;
  color: #FFFFFF;
}
#sidebar h2 a {
  display: block;
  font-size: 1.4rem;
  color: #FFFFFF;
  margin: 0;
  padding: 0;
}
#sidebar ul {
  margin: 0
  padding: 0;
}
#sidebar ul li {
  margin: 0;
  padding: 0;
  font-size: 1.4rem;
  color: #205EA9;
  background-color: #FFFFFF;
  border-bottom: 1px solid #205EA9;
}
#sidebar ul li span {
  display: block;
  text-decoration: none;
  margin: 0;
  padding: 6px 12px;
}
#sidebar ul li a {
  display: block;
  text-decoration: none;
  margin: 0;
  padding: 6px 12px;
}
#sidebar ul li a:hover,
#sidebar ul li.current a,
#sidebar ul li.current a:hover,
#sidebar ul li ul li.current a {
  background-color: #C5D2E2;
}

#sidebar ul li > ul {
  margin: 0;
  padding: 0;
}
#sidebar ul li > ul li,
#sidebar ul li.current > ul li a {
  margin: 0;
  padding: 0;
  font-size: 1.4rem;
  color: #205EA9;
  background-color: #FFFFFF;
  border-bottom: none;
}
#sidebar ul li > ul li a,
#sidebar ul li > ul li span,
#sidebar ul li.current > ul li a {
  display: block;
  text-decoration: none;
  border: none;
  margin: 0;
  padding: 3px 0 3px 24px;
}

#sidebar ul li > ul li > ul {
  margin: 0;
  padding: 0;
}
#sidebar ul li > ul li > ul li,
#sidebar ul li.current > ul li > ul li a {
  margin: 0;
  padding: 0;
  font-size: 1.3rem;
  color: #205EA9;
  background-color: #FFFFFF;
  border-bottom: none;
}
#sidebar ul li > ul li > ul li,
#sidebar ul li > ul li > ul li span,
#sidebar ul li.current > ul li > ul li a {
  display: block;
  text-decoration: none;
  border: none;
  margin: 0;
  padding: 0 0 0 24px;
}



/*********************************/
/********** Breadcrumbs **********/
/*********************************/

#breadcrumbs {
  margin: 5px auto;
  padding: 0;
}
#breadcrumbs ul {
  margin: 0 auto;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
}
#breadcrumbs ul li {
  margin: 0 12px 0 0;
  font-size: 1.4rem;
  color: #205EA9;
}
#breadcrumbs ul li:after {
  content: "/";
  margin: 0 0 0 12px;
  font-size: 1.2rem;
}
#breadcrumbs ul li:last-child:after {
  content: none;
}



/**************************/
/********** Home **********/
/**************************/

.home h2 {
  border-bottom: 1px solid #205EA9;
  padding: 10px 0;
}
.home h2 span {
  position: absolute;
  right: 0;
}
.home h2 span a {
  font-size: 1.4rem;
  color: #000000;
  transition: opacity 0.3s;
}
.home h2 span a:hover {
  text-decoration: none;
  opacity: 0.7;
  filter: alpha(opacity=70);
  transition: opacity 0.3s;
}
.home h2 span a:before {
  font-family: 'Font Awesome 5 Free';
  content: "\f138";
  margin: 0 4px 0 0;
  font-size: 1.6rem;
  font-weight: 800;
  color: #BFBFBF;
}

.home #important {
  margin: 0;
  padding: 20px;
  width: 100%;
  border: 2px solid #DE0000;
  border-radius: 10px;
}
.home #important h2 {
  border: none;
  margin: 0 0 10px 0;
  padding: 0;
  color: #DE0000;
  font-size: 1.8rem;
  font-weight: 800;
  text-align: center;
}
.home #important dl {
  margin: 0 0 15px 0;
  padding: 0 0 15px 0;
  border-bottom: 1px solid #205EA9;
  width: 100%;
}
.home #important dl:last-child {
  margin-bottom: 0;
  padding-bottom: 0;
  border: none;
}
.home #important dl dt {
  margin: 0 50px 0 0;
  padding: 0;
}
.home #important dl dt time {
  font-size: 1.5rem;
  font-weight: 800;
  color: #205EA9;
  white-space: nowrap;
}
.home #important dl dd {
  margin: 0;
  padding: 0;
}
.home #important dl dd .title,
.home #important dl dd .title a {
  font-size: 1.6rem;
  font-weight: 800;
  letter-spacing: 0.1rem;
}
.home #important dl dd .description,
.home #important dl dd .description a {
  font-size: 1.4rem;
  margin: 14px 0 0 0;
}

.home #whats-new {
  margin: 20px 0;
  padding: 0;
  width: 100%;
}
/*
.home #whats-new .intro-movie h2 {
  display: none;
}
.home #whats-new .intro-movie {
  position: relative;
  padding-bottom: 56.25%;
  height: 0;
  overflow: hidden;
  margin: 0 auto 20px auto;
}
.home #whats-new .intro-movie iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border: none;
}
*/

.home #whats-new .tabs {
  overflow: hidden;
  display: flex;
  justify-content: center;
  margin: 0 0 20px 0;
  padding: 0;
  border-bottom: 1px solid #205EA9;
}
.home #whats-new .tabs li {
  border-left: 1px solid #205EA9;
  border-top: 1px solid #205EA9;
  border-right: 1px solid #205EA9;
  border-top-left-radius: 6px;
  border-top-right-radius: 6px;
  padding: 4px;
  color: #205EA9;
  font-size: 1.2rem;
  cursor: pointer;
  width: 16.25%;
  text-align: center;
}
.home #whats-new .tabs li+li {
  margin: 0 0 0 0.5%;
}
.home #whats-new .tabs li.select {
  background-color: #205EA9;
  color: #FFFFFF;
}
.home #whats-new .hide {
  display: none;
}



.home #whats-new dl {
  display: flex;
  align-items: center;
  margin: 0 0 10px 0;
  padding: 0 0 10px 0;
  border-bottom: 1px dotted #205EA9;
  width: 100%;
}
.home #whats-new dl dt {
  display: flex;
  align-items: center;
  flex-direction: column;
  margin: 0 0 0 20px;
  padding: 0;
  order: 2;
}
.home #whats-new dl dt time {
  font-size: 1.4rem;
  font-weight: 800;
  color: #205EA9;
  white-space: nowrap;
}
.home #whats-new dl dt span {
  display: block;
  text-align: center;
  white-space: nowrap;
  margin: 0;
  padding: 2px 0;
  border-radius: 4px;
  font-size: 1.2rem;
  width: 80px;
}
.home #whats-new dl dt span.cat-news {
  background-color: #00BBD3;
  color: #FFFFFF;
}
.home #whats-new dl dt span.cat-event {
  background-color: #FF9700;
  color: #FFFFFF;
}
.home #whats-new dl dt span.cat-student {
  background-color: #8BC349;
  color: #FFFFFF;
}
.home #whats-new dl dt span.cat-campus {
  background-color: #9D9D9D;
  color: #FFFFFF;
}
.home #whats-new dl dt span.cat-recruitment {
  background-color: #EC68B7;
  color: #FFFFFF;
}
.home #whats-new dl dd {
  margin: 0;
  padding: 0;
  width: 100%;
  order: 1;
}

.home #latest-research {
  margin: 20px 0;
  padding: 0;
  width: 100%;
}
.home #latest-research ul {
  display: flex;
  flex-wrap: wrap;
  margin: 0;
  padding: 0;
}
.home #latest-research ul li {
  width: 48%;
  margin: 0 2% 2% 0;
  background-color: #F8F8F8;
  outline: 1px solid #EEEEEE;
  outline-offset: -1px;
}
.home #latest-research ul li:nth-child(even) {
  margin: 0 0 2% 0;
}
.home #latest-research ul li a {
  display: flex;
  flex-direction: column;
  width: 100%;
  height: 100%;
  font-weight: 700;
  color: #000000;
}
.home #latest-research ul li a:hover {
  text-decoration: none;
  color: #666666;
}
.home #latest-research ul li p {
  margin: 0;
  padding: 14px;
  font-size: 1.4rem;
  font-weight: 500;
}
.home #latest-research ul li span {
  display: inline-block;
  margin: auto 0 0 0;
  padding: 0 14px 14px 14px;
  font-family: "Roboto";
  font-size: 1.2rem;
  font-weight: 400;
  letter-spacing: 0.04rem;
}
.home #latest-research ul li img {
  max-width: 100%;
  width: 100%;
  height: auto;
}

.home #laboratory-list {
  margin: 0 auto;
  padding: 0;
  text-align: center;
  width: 100%;
  background-image: url("../images/laboratory-list.jpg");
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
  height: 100px;
}
.home #laboratory-list a {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
  margin: 0 auto;
  padding: 0;
  text-align: center;
  color: #FFFFFF;
  font-size: 2.6rem;
  font-weight: 800;
  transition: opacity 0.3s;
}
.home #laboratory-list i {
  margin: 0 0 0 20px;
}
.home #laboratory-list a:hover {
  text-decoration: none;
  opacity: 0.7;
  filter: alpha(opacity=70);
  transition: opacity 0.3s;
}

.home #web-lecture-series {
  margin: 20px auto 0 auto;
  padding: 0;
  text-align: center;
  width: 100%;
  background-image: url("../images/web-lecture-series.jpg");
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
  height: 100px;
}
.home #web-lecture-series a {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
  margin: 0 auto;
  padding: 0;
  text-align: center;
  color: #FFFFFF;
  font-size: 2.6rem;
  font-weight: 800;
  transition: opacity 0.3s;
}
.home #web-lecture-series a span {
  font-family: 'Roboto';
  font-size: 2.4rem;
  font-weight: 400;
  margin: 0 0 0 10px;
}
.home #web-lecture-series i {
  margin: 0 0 0 20px;
}
.home #web-lecture-series a:hover {
  text-decoration: none;
  opacity: 0.7;
  filter: alpha(opacity=70);
  transition: opacity 0.3s;
}

.home #banners {
  margin: 20px 0;
  padding: 0;
}
.home #banners ul {
  display: flex;
  flex-wrap: wrap;
  margin: 0 auto;
  padding: 0;
}
.home #banners ul li {
  width: 50%;
  text-align: center;
  padding: 10px;
  background-color: #EEEEEE;
  border: 10px solid #FFFFFF;
}



/***************************/
/********** Pages **********/
/***************************/

.page h2 {
  margin: 0;
  padding: 0;
}

.page div.cat-image.cat-logo {
  background-image: url("../images/cat-image-logo.png");
}

.page .panel-style01 ul {
  display: flex;
  margin: 0;
  padding: 0;
}
.page .panel-style01 ul li {
  width: 180px;
  margin: 0 10px 0 0;
}
.page .panel-style01 ul li:last-child {
  margin: 0;
}
.page .panel-style01 ul li img {
  margin: 0 0 8px 0;
  width: 100%;
  height: auto;
}

.page .panel-style02 {
  display: flex;
  flex-wrap: wrap;
  margin: 20px 0;
  padding: 0;
}
.page .panel-style02 div {
  width: 100%;
  display: flex;
  align-items: center;
  background-color: #E6F1F7;
  margin: 10px 0;
}
.page .panel-style02 div a {
  display: block;
  width: 100%;
  padding: 20px;
}
.page .panel-style02 div.cat-image a {
  display: block;
  width: 100%;
  padding: 20px 200px 20px 20px;
}
.page .panel-style02 div.cat-image {
  background-repeat: no-repeat;
  background-position: right center;
  background-size: 180px auto;
}

.page .panel-style03 {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  margin: 20px 0;
  padding: 0;
}
.page .panel-style03 div {
  width: 48%;
  border-top: 1px solid #0076A5;
  border-bottom: 1px solid #0076A5;
  display: flex;
  align-items: center;
  margin: 10px 0;
}
.page .panel-style03 div a {
  display: block;
  width: 100%;
  padding: 10px 0;
}

.page .panel-style05 {
  display: flex;
  flex-wrap: wrap;
  margin: 20px 0;
  padding: 0;
}
.page .panel-style05 div:nth-child(1) {
  width: 100%;
  display: flex;
  align-items: center;
  background-color: #E6F1F7;
  margin: 10px 0;
}
.page .panel-style05 div:nth-child(1) a {
  display: block;
  width: 100%;
  padding: 20px 200px 20px 20px;
}
.page .panel-style05 div:nth-child(1) {
  background-repeat: no-repeat;
  background-position: right center;
  background-size: 180px auto;
}
.page .panel-style05 div:nth-child(2) {
  width: 100%;
  border-top: 1px solid #0076A5;
  border-bottom: 1px solid #0076A5;
  display: flex;
  align-items: center;
  margin: 10px 0;
}
.page .panel-style05 div:nth-child(2) a {
  display: block;
  width: 100%;
  padding: 10px 0;
}

.page .panel-style06 {
  margin: 20px 0;
  padding: 20px;
  width: 100%;
  display: flex;
  flex-direction: column;
  background-color: #E6F1F7;
}
.page .panel-style06 div {
  width: 100%;
  display: flex;
  align-items: center;
  background-color: #E6F1F7;
  margin: 0;
  padding: 2px 0;
  color: #205EA9;
  border-bottom: 1px solid #205EA9;
}
.page .panel-style06 ul {
  margin: 10px;
  padding: 0;
}
.page .panel-style06 ul li {
  margin: 0;
  padding: 0;
}
.page .panel-style06 ul li a {
  font-size: 1.3rem;
}
.page .panel-style06 ul li a:before {
  font-family: 'Font Awesome 5 Free';
  content: "\f105";
  margin: 0 4px 0 0;
  font-size: 1.2rem;
  font-weight: 800;
}

.page #whats-new {
  margin: 20px 0;
  padding: 0;
  width: 100%;
}
.page #whats-new .tabs {
  display: none;
}
.page #whats-new dl {
  display: flex;
  align-items: center;
  margin: 0 0 15px 0;
  padding: 0 0 15px 0;
  border-bottom: 1px solid #205EA9;
  width: 100%;
}
.page #whats-new dl dt {
  display: flex;
  align-items: center;
  flex-direction: column;
  margin: 0 0 0 20px;
  padding: 0;
  order: 2;
}
.page #whats-new dl dt time {
  font-size: 1.4rem;
  font-weight: 800;
  color: #205EA9;
  white-space: nowrap;
}
.page #whats-new dl dt span {
  display: block;
  text-align: center;
  white-space: nowrap;
  margin: 0;
  padding: 2px 0;
  border-radius: 4px;
  font-size: 1.2rem;
  width: 80px;
}
.page #whats-new dl dt span.cat-news {
  background-color: #00BBD3;
  color: #FFFFFF;
}
.page #whats-new dl dt span.cat-event {
  background-color: #FF9700;
  color: #FFFFFF;
}
.page #whats-new dl dt span.cat-student {
  background-color: #8BC349;
  color: #FFFFFF;
}
.page #whats-new dl dt span.cat-campus {
  background-color: #9D9D9D;
  color: #FFFFFF;
}
.page #whats-new dl dt span.cat-recruitment {
  background-color: #EC68B7;
  color: #FFFFFF;
}
.page #whats-new dl dd {
  margin: 0;
  padding: 0;
  width: 100%;
  order: 1;
}

.page #latest-research {
  margin: 0;
  padding: 0;
}
.page #latest-research ul {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 20px auto 0 auto;
  padding: 0;
}
.page #latest-research ul li {
  width: 48%;
  background-color: #F8F8F8;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  margin: 0 auto 20px auto;
}
.page #latest-research ul li:empty {
  background-color: #FFFFFF;
}
.page #latest-research ul li a {
  font-weight: 800;
  color: #000000;
}
.page #latest-research ul li img {
  min-width: 100%;
  height: auto;
}
.page #latest-research ul li p {
  margin: 0;
  padding: 10px;
  font-size: 1.4rem;
  font-weight: 800;
  flex-grow: 1;
}
.page #latest-research ul li  cite {
  margin: 0 10px 10px 10px;
  padding: 10px 0 0 0;
  border-top: 1px solid #205EA9;
  color: #205EA9;
  line-height: 140%;
  font-size: 1.2rem;
  font-style: normal;
  font-weight: 800;
}


}



/************************************************************/
/********** Responsive Contents Setting (768-1104) **********/
/************************************************************/

@media screen and ( min-width: 769px ) and ( max-width: 1104px ) {



/*********************************************/
/********** Base Setting (768-1104) **********/
/*********************************************/

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

.alignleft,
.alignright,
.aligncenter {
  width: 100%;
  display: block!important;
  margin: 20px auto!important;
  text-align: center!important;
}



/****************************/
/********** Header **********/
/****************************/

header {
  width: 100%;
  margin: 0 auto;
  padding: 0;
  position: relative;
  background-color: #205EA9;
}
header #first-section {
  width: 100%;
  margin: 0 auto;
  padding: 0;
  border-bottom: 1px solid #074494;
  position: relative;
  z-index: 7777;
}
header #first-section a {
  color: #FFFFFF;
  text-decoration: none;
}
header #first-section a:hover,
header #first-section .current a {
  text-decoration: underline;
}
header #first-section .wrapper {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin: 0 auto;
  padding: 0;
}
header #first-section .univ {
  flex: 1;
  padding: 10px;
  order: 1;
}
header #first-section nav {
  display: flex;
  margin: 0 auto;
  padding: 0 90px 0 0;
  order: 3;
}
header #first-section nav ul {
  display: flex;
  margin: 0 auto;
  padding: 10px;
  border-left: 1px solid #074494;
  border-right: 1px solid #074494;
}
header #first-section nav ul li {
  font-size: 1.2rem;
  margin: 0 8px;
}
header #first-section .language {
  font-size: 1.2rem;
  margin: 0 auto;
  padding: 10px 14px;
  border-right: 1px solid #074494;
}
header #first-section aside {
  order: 2;
  margin: auto;
  padding: 10px;
  border-left: 1px solid #074494;
}
header #first-section aside ul {
  display: flex;
  margin: 0 auto;
  padding: 0;
}
header #first-section aside ul li {
  margin: 0 8px;
}

header #second-section {
  width: 100%;
  margin: 0 auto;
  padding: 10px;
  position: relative;
  z-index: 7777;
}
header #second-section .wrapper {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin: 0 auto;
  padding: 12px 0;
}
header #second-section h1 {
  margin: 0;
  padding: 0;
  flex: 1;
}
header #second-section h1 a {
  font-size: 2.0rem;
  font-weight: 800;
  text-decoration: none;
  color: #FFFFFF;
  line-height: 90%;
  transition: all 0.3s ease;
}
header #second-section h1 a small {
  font-family: 'Roboto';
  font-size: 1.4rem;
  font-weight: 300;
  letter-spacing: 0.08rem;
}
header #second-section h1 a:hover,
header #second-section h1 a:hover:before {
  opacity: 0.7;
  transition: all 0.3s ease;
}
header #second-section h1 a:before {
  content: "";
  display: inline-block;
  width: 38px;
  height: 42px;
  background-image: url("../images/logo-school01.png");
  background-size: contain;
  background-repeat: no-repeat;
  vertical-align: middle;
  margin: 4px 12px 0 0;
  transition: all 0.3s ease;
  float: left;
}
header #second-section .searchform {
  margin: 10px 0;
  padding: 4px;
  background-color: rgba(255,255,255,0.1);
}
header #second-section .searchform input[type="text"]:focus,
header #second-section .searchform button[type="submit"]:focus {
  outline: 0;
}
header #second-section .searchform .searchfield {
  margin: 0;
  padding: 4px;
  color: #CCCCCC;
  font-size: 1.4rem;
  border: none;
  background: none;
  width: 180px;
}
header #second-section .searchform .searchsubmit {
  border: none;
  background: none;
  color: #FFFFFF;
}



/****************************************/
/********** Respomsive Swicher **********/
/****************************************/

#trigger {
  position: fixed;
  z-index: 7777;
  right: 10px;
  top: 9px;
}
#trigger-close {
  position: fixed;
  z-index: 9999;
  right: 10px;
  top: 9px;
}
#trigger a,
#trigger-close a {
  display: block;
  color: #FFFFFF;
  text-decoration: none;
  font-size: 1.2rem;
  background: rgba(0,0,0,0.3);
  border-radius: 3px;
  padding: 2px 10px;
}
#modal-window {
  display: none;
}

#modal-window ul {
  margin: 0;
  padding: 0;
}
#modal-window ul li {
  margin: 0;
  padding: 10px 20px;
  font-size: 1.6rem;
  border-bottom: 1px solid #205EA9;
  background-color: #CCE4ED;
  cursor: pointer;
}
#modal-window ul li .level-icon {
  display: block;
  font-size: 2.0rem;
  float: right;
  color: #205EA9;
  padding: 0;
}

#modal-window ul li > ul {
  display: none;
  margin: 0;
  padding: 10px 0;
}
#modal-window ul li > ul li {
  margin: 0;
  padding: 10px;
  font-size: 1.4rem;
}

#modal-window ul li > ul li > ul {
  display: none;
  margin: 0;
  padding: 10px 0;
}
#modal-window ul li > ul li > ul li {
  margin: 0;
  padding: 10px;
  font-size: 1.4rem;
}

#pageslide {
  display: none;
  position: fixed;
  left: 0;
  top: 0;
  right: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
  overflow: auto;
  z-index: 9999;
  margin: 0;
  padding: 40px 0 0 0;
  background-color: #CCE4ED;
  color: #205EA9;
}



/********************************/
/********** Main Image **********/
/********************************/

#main-image {
  margin: 0 auto;
  padding: 0;
  text-align: center;
  width: 100%;
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
  height: 400px;
  position: relative;
  overflow: hidden;
}
#main-image .wrapper {
  margin: 0 auto;
  padding: 0 40px;
  width: 1080px;
  text-align: left;
}
#main-image .wrapper .contents {
  margin: 0;
  padding: 0;
  text-align: left;
}
#main-image .swiper-slide {
  display: flex;
  align-items: center;
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
  overflow: hidden;
}
#main-image .swiper-slide a {
  display: flex;
  align-items: center;
  color: #FFFFFF;
  text-decoration: none;
  width: 100%;
  height: 100%;
  position: absolute;
  z-index: 1000;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
}

#main-image .swiper-button-white {
  opacity: 0.6;
  transition: opacity 0.3s;
}
#main-image .swiper-button-white:hover {
  opacity: 1;
  filter: alpha(opacity=70);
  transition: opacity 0.3s;
  backface-visibility: hidden;
}
#main-image .swiper-button-prev {
  margin-left: 0;
}
#main-image .swiper-button-next {
  margin-right: 0;
}

#main-image .swiper-pagination {
  bottom: 10px;
  left: 0;
  width: 100%;
  z-index: 7777;
}
#main-image .swiper-pagination-bullet {
  width: 12px;
  height: 12px;
  background-color: #FFFFFF;
  border: 2px solid #CCCCCC;
  opacity: 1;
}
#main-image .swiper-pagination-bullet-active {
  background-color: #205EA9;
  opacity: 1;
}
#main-image .swiper-pagination-bullet {
  margin: 0 7px;
}
#main-image .swiper-button-prev,
#main-image .swiper-button-next {
  z-index: 7777;
}

#main-image .screen-overlay {
  background-color: rgba(0,0,0,0.4);
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  content: "";
}
#main-image .screen-logo {
  width: 100%;
  margin: 0 auto;
  padding: 0;
  text-align: center;
  position: absolute;
  z-index: 6666;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
}
#main-image .screen-logo p {
  font-size: 2.2rem;
  font-weight: 300;
  line-height: 140%;
  color: #FFFFFF;
  width: 100%;
  margin: 40px auto 0 auto;
  padding: 0;
  text-align: center;
}
#main-image .screen-logo p small {
  font-family: 'Roboto';
  font-size: 1.6rem;
  font-weight: 300;
}



/****************************/
/********** Footer **********/
/****************************/

footer {
  width: 100%;
  margin: 50px auto 0 auto;
  padding: 0;
  background-color: #FFFFFF;
  border-top: 1px solid #205EA9;
}
footer #pagetop {
  margin: -30px auto 0 auto;
  padding: 0;
  text-align: center;
}
footer #pagetop a {
  display: block;
  margin: 0 auto;
  width: 65px;
  height: 62px;
  line-height: 62px;
  background-color: #205EA9;
}
footer .footer-nav {
  display: none;
}
footer hr {
  display: none;
}
footer .content {
  margin: 40px 20px 20px 20px;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.home footer address {
  margin: 40px auto 30px auto;
  padding: 0 10px;
  text-align: center;
  font-size: 1.6rem;
}
.page footer address {
  margin: auto;
  padding: 0;
  text-align: center;
  font-size: 1.4rem;
  white-space: nowrap;
  order: 2;
}
footer aside {
  margin: auto;
  padding: 0;
}
footer aside ul {
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  width: 100%;
}
footer aside ul li {
  width: 32%;
  margin: 0 2% 2% 0;
  border: 10px solid #EEEEEE;
}
footer aside ul li:nth-child(3n) {
  margin: 0 0 2% 0;
}
footer aside ul li img {
  max-width: 100%;
  height: auto;
}
footer #copyright {
  text-align: center;
  letter-spacing: 0.1rem;
  background-color: #205EA9;
  color: #FFFFFF;
  margin: 0 auto;
  padding: 10px;
  width: 100%;
}



/**************************/
/********** Main **********/
/**************************/

main {
  display: block;
  margin: 0 auto;
  padding: 10px;
  flex: 1;
  background-color: #FFFFFF;
  width: 100%;
}



/*****************************/
/********** Content **********/
/*****************************/

#content {
  margin: 0;
  padding: 0;
}



/*****************************/
/********** Sidebar **********/
/*****************************/

#sidebar {
  margin: 20px 0;
  padding: 10px;
  border: 1px solid #C5D2E2;
  border-radius: 3px;
}
#sidebar a:hover {
  text-decoration: none;
}
#sidebar h2 {
  font-size: 1.4rem;
  margin-bottom: 0;
  padding: 6px 10px;
  background-color: #205EA9;
  color: #FFFFFF;
}
#sidebar h2 a {
  display: block;
  font-size: 1.4rem;
  color: #FFFFFF;
  margin: 0;
  padding: 0;
}
#sidebar ul {
  margin: 0
  padding: 0;
}
#sidebar ul li {
  margin: 0;
  padding: 0;
  font-size: 1.4rem;
  color: #205EA9;
  background-color: #FFFFFF;
  border-bottom: 1px solid #205EA9;
}
#sidebar ul li span {
  display: block;
  text-decoration: none;
  margin: 0;
  padding: 6px 12px;
}
#sidebar ul li a {
  display: block;
  text-decoration: none;
  margin: 0;
  padding: 6px 12px;
}
#sidebar ul li a:hover,
#sidebar ul li.current a,
#sidebar ul li.current a:hover,
#sidebar ul li ul li.current a {
  background-color: #C5D2E2;
}

#sidebar ul li > ul {
  margin: 0;
  padding: 0;
}
#sidebar ul li > ul li,
#sidebar ul li.current > ul li a {
  margin: 0;
  padding: 0;
  font-size: 1.4rem;
  color: #205EA9;
  background-color: #FFFFFF;
  border-bottom: none;
}
#sidebar ul li > ul li a,
#sidebar ul li > ul li span,
#sidebar ul li.current > ul li a {
  display: block;
  text-decoration: none;
  border: none;
  margin: 0;
  padding: 3px 0 3px 24px;
}

#sidebar ul li > ul li > ul {
  margin: 0;
  padding: 0;
}
#sidebar ul li > ul li > ul li,
#sidebar ul li.current > ul li > ul li a {
  margin: 0;
  padding: 0;
  font-size: 1.3rem;
  color: #205EA9;
  background-color: #FFFFFF;
  border-bottom: none;
}
#sidebar ul li > ul li > ul li,
#sidebar ul li > ul li > ul li span,
#sidebar ul li.current > ul li > ul li a {
  display: block;
  text-decoration: none;
  border: none;
  margin: 0;
  padding: 0 0 0 24px;
}



/*********************************/
/********** Breadcrumbs **********/
/*********************************/

#breadcrumbs {
  margin: 5px auto;
  padding: 0;
}
#breadcrumbs ul {
  margin: 0 auto;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
}
#breadcrumbs ul li {
  margin: 0 12px 0 0;
  font-size: 1.4rem;
  color: #205EA9;
}
#breadcrumbs ul li:after {
  content: "/";
  margin: 0 0 0 12px;
  font-size: 1.2rem;
}
#breadcrumbs ul li:last-child:after {
  content: none;
}



/**************************/
/********** Home **********/
/**************************/

.home h2 {
  border-bottom: 1px solid #205EA9;
  padding: 10px 0;
}
.home h2 span {
  position: absolute;
  right: 0;
}
.home h2 span a {
  font-size: 1.4rem;
  color: #000000;
  transition: opacity 0.3s;
}
.home h2 span a:hover {
  text-decoration: none;
  opacity: 0.7;
  filter: alpha(opacity=70);
  transition: opacity 0.3s;
}
.home h2 span a:before {
  font-family: 'Font Awesome 5 Free';
  content: "\f138";
  margin: 0 4px 0 0;
  font-size: 1.6rem;
  font-weight: 800;
  color: #BFBFBF;
}

.home #important {
  margin: 0;
  padding: 30px 40px;
  width: 100%;
  border: 2px solid #DE0000;
  border-radius: 10px;
}
.home #important h2 {
  border: none;
  margin: 0 0 20px 0;
  padding: 0;
  color: #DE0000;
  font-size: 1.8rem;
  font-weight: 800;
  text-align: center;
}
.home #important dl {
  display: flex;
  margin: 0 0 15px 0;
  padding: 0 0 15px 0;
  border-bottom: 1px solid #205EA9;
  width: 100%;
}
.home #important dl:last-child {
  margin-bottom: 0;
  padding-bottom: 0;
  border: none;
}
.home #important dl dt {
  margin: 0 50px 0 0;
  padding: 0;
}
.home #important dl dt time {
  font-size: 1.5rem;
  font-weight: 800;
  color: #205EA9;
  white-space: nowrap;
}
.home #important dl dd {
  margin: 0;
  padding: 0;
}
.home #important dl dd .title,
.home #important dl dd .title a {
  font-size: 1.6rem;
  font-weight: 800;
  letter-spacing: 0.1rem;
}
.home #important dl dd .description,
.home #important dl dd .description a {
  font-size: 1.4rem;
  margin: 14px 0 0 0;
}

.home #whats-new {
  margin: 20px 0;
  padding: 0;
  width: 100%;
}
/*
.home #whats-new .intro-movie h2 {
  display: none;
}
.home #whats-new .intro-movie {
  margin: auto;
  text-align: center;
}
.home #whats-new .intro-movie iframe {
  border: none;
}
*/

.home #whats-new .tabs {
  overflow: hidden;
  display: flex;
  justify-content: center;
  margin: 0 0 20px 0;
  padding: 0;
  border-bottom: 1px solid #205EA9;
}
.home #whats-new .tabs li {
  border-left: 1px solid #205EA9;
  border-top: 1px solid #205EA9;
  border-right: 1px solid #205EA9;
  border-top-left-radius: 6px;
  border-top-right-radius: 6px;
  padding: 4px;
  color: #205EA9;
  font-size: 1.3rem;
  cursor: pointer;
  width: 16.25%;
  text-align: center;
}
.home #whats-new .tabs li+li {
  margin: 0 0 0 0.5%;
}
.home #whats-new .tabs li.select {
  background-color: #205EA9;
  color: #FFFFFF;
}
.home #whats-new .hide {
  display: none;
}



.home #whats-new dl {
  display: flex;
  align-items: center;
  margin: 0 0 10px 0;
  padding: 0 0 10px 0;
  border-bottom: 1px dotted #205EA9;
  width: 100%;
}
.home #whats-new dl dt {
  display: flex;
  align-items: center;
  flex-direction: column;
  margin: 0 0 0 20px;
  padding: 0;
  order: 2;
}
.home #whats-new dl dt time {
  font-size: 1.4rem;
  font-weight: 800;
  color: #205EA9;
  white-space: nowrap;
}
.home #whats-new dl dt span {
  display: block;
  text-align: center;
  white-space: nowrap;
  margin: 0;
  padding: 2px 0;
  border-radius: 4px;
  font-size: 1.2rem;
  width: 90px;
}
.home #whats-new dl dt span.cat-news {
  background-color: #00BBD3;
  color: #FFFFFF;
}
.home #whats-new dl dt span.cat-event {
  background-color: #FF9700;
  color: #FFFFFF;
}
.home #whats-new dl dt span.cat-student {
  background-color: #8BC349;
  color: #FFFFFF;
}
.home #whats-new dl dt span.cat-campus {
  background-color: #9D9D9D;
  color: #FFFFFF;
}
.home #whats-new dl dt span.cat-recruitment {
  background-color: #EC68B7;
  color: #FFFFFF;
}
.home #whats-new dl dd {
  margin: 0;
  padding: 0;
  width: 100%;
  order: 1;
}

.home #latest-research {
  margin: 20px 0;
  padding: 0;
  width: 100%;
}
.home #latest-research ul {
  display: flex;
  flex-wrap: wrap;
  margin: 0;
  padding: 0;
}
.home #latest-research ul li {
  width: 32%;
  margin: 0 2% 2% 0;
  background-color: #F8F8F8;
  outline: 1px solid #EEEEEE;
  outline-offset: -1px;
}
.home #latest-research ul li:nth-child(3n) {
  margin: 0 0 2% 0;
}
.home #latest-research ul li a {
  display: flex;
  flex-direction: column;
  width: 100%;
  height: 100%;
  font-weight: 700;
  color: #000000;
}
.home #latest-research ul li a:hover {
  text-decoration: none;
  color: #666666;
}
.home #latest-research ul li p {
  margin: 0;
  padding: 15px;
  font-size: 1.5rem;
  font-weight: 500;
}
.home #latest-research ul li span {
  display: inline-block;
  margin: auto 0 0 0;
  padding: 0 15px 15px 15px;
  font-family: "Roboto";
  font-size: 1.3rem;
  font-weight: 400;
  letter-spacing: 0.04rem;
}
.home #latest-research ul li img {
  max-width: 100%;
  width: 100%;
  height: auto;
}

.home #laboratory-list {
  margin: 0 auto;
  padding: 0;
  text-align: center;
  width: 100%;
  background-image: url("../images/laboratory-list.jpg");
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
  height: 100px;
}
.home #laboratory-list a {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
  margin: 0 auto;
  padding: 0;
  text-align: center;
  color: #FFFFFF;
  font-size: 2.8rem;
  font-weight: 800;
  transition: opacity 0.3s;
}
.home #laboratory-list i {
  margin: 0 0 0 20px;
}
.home #laboratory-list a:hover {
  text-decoration: none;
  opacity: 0.7;
  filter: alpha(opacity=70);
  transition: opacity 0.3s;
}

.home #web-lecture-series {
  margin: 20px auto 0 auto;
  padding: 0;
  text-align: center;
  width: 100%;
  background-image: url("../images/web-lecture-series.jpg");
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
  height: 100px;
}
.home #web-lecture-series a {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
  margin: 0 auto;
  padding: 0;
  text-align: center;
  color: #FFFFFF;
  font-size: 2.8rem;
  font-weight: 800;
  transition: opacity 0.3s;
}
.home #web-lecture-series a span {
  font-family: 'Roboto';
  font-size: 2.6rem;
  font-weight: 400;
  margin: 0 0 0 12px;
}
.home #web-lecture-series i {
  margin: 0 0 0 20px;
}
.home #web-lecture-series a:hover {
  text-decoration: none;
  opacity: 0.7;
  filter: alpha(opacity=70);
  transition: opacity 0.3s;
}

.home #banners {
  margin: 20px 0;
  padding: 0;
}
.home #banners ul {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-around;
  margin: 0 auto;
  padding: 0;
}
.home #banners ul li {
  text-align: center;
  margin: 10px;
  padding: 10px;
  background-color: #EEEEEE;
}



/***************************/
/********** Pages **********/
/***************************/

.page h2 {
  margin: 0;
  padding: 0;
}

.page div.cat-image.cat-logo {
  background-image: url("../images/cat-image-logo.png");
}

.page .panel-style01 ul {
  display: flex;
  margin: 0;
  padding: 0;
}
.page .panel-style01 ul li {
  width: 180px;
  margin: 0 10px 0 0;
}
.page .panel-style01 ul li:last-child {
  margin: 0;
}
.page .panel-style01 ul li img {
  margin: 0 0 8px 0;
  width: 100%;
  height: auto;
}

.page .panel-style02 {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  margin: 20px 0;
  padding: 0;
}
.page .panel-style02 div {
  width: 48%;
  display: flex;
  align-items: center;
  background-color: #E6F1F7;
  margin: 10px 0;
}
.page .panel-style02 div a {
  display: block;
  width: 100%;
  padding: 20px;
}
.page .panel-style02 div.cat-image a {
  display: block;
  width: 100%;
  padding: 20px 200px 20px 20px;
}
.page .panel-style02 div.cat-image {
  background-repeat: no-repeat;
  background-position: right center;
  background-size: 180px auto;
}

.page .panel-style03 {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  margin: 20px 0;
  padding: 0;
}
.page .panel-style03 div {
  width: 48%;
  border-top: 1px solid #0076A5;
  border-bottom: 1px solid #0076A5;
  display: flex;
  align-items: center;
  margin: 10px 0;
}
.page .panel-style03 div a {
  display: block;
  width: 100%;
  padding: 10px 0;
}

.page .panel-style05 {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  margin: 20px 0;
  padding: 0;
}
.page .panel-style05 div:nth-child(1) {
  width: 48%;
  display: flex;
  align-items: center;
  background-color: #E6F1F7;
  margin: 10px 0;
}
.page .panel-style05 div:nth-child(1) a {
  display: block;
  width: 100%;
  padding: 20px 200px 20px 20px;
}
.page .panel-style05 div:nth-child(1) {
  background-repeat: no-repeat;
  background-position: right center;
  background-size: 180px auto;
}
.page .panel-style05 div:nth-child(2) {
  width: 48%;
  border-top: 1px solid #0076A5;
  border-bottom: 1px solid #0076A5;
  display: flex;
  align-items: center;
  margin: 10px 0;
}
.page .panel-style05 div:nth-child(2) a {
  display: block;
  width: 100%;
  padding: 10px 0;
}

.page .panel-style06 {
  margin: 20px 0;
  padding: 20px;
  width: 100%;
  display: flex;
  flex-direction: column;
  background-color: #E6F1F7;
}
.page .panel-style06 div {
  width: 100%;
  display: flex;
  align-items: center;
  background-color: #E6F1F7;
  margin: 0;
  padding: 2px 0;
  color: #205EA9;
  border-bottom: 1px solid #205EA9;
}
.page .panel-style06 ul {
  margin: 10px;
  padding: 0;
}
.page .panel-style06 ul li {
  margin: 0;
  padding: 0;
}
.page .panel-style06 ul li a {
  font-size: 1.3rem;
}
.page .panel-style06 ul li a:before {
  font-family: 'Font Awesome 5 Free';
  content: "\f105";
  margin: 0 4px 0 0;
  font-size: 1.2rem;
  font-weight: 800;
}

.page #whats-new {
  margin: 20px 0;
  padding: 0;
  width: 100%;
}
.page #whats-new .tabs {
  display: none;
}
.page #whats-new dl {
  display: flex;
  align-items: center;
  margin: 0 0 15px 0;
  padding: 0 0 15px 0;
  border-bottom: 1px solid #205EA9;
  width: 100%;
}
.page #whats-new dl dt {
  display: flex;
  align-items: center;
  flex-direction: column;
  margin: 0 0 0 20px;
  padding: 0;
  order: 2;
}
.page #whats-new dl dt time {
  font-size: 1.4rem;
  font-weight: 800;
  color: #205EA9;
  white-space: nowrap;
}
.page #whats-new dl dt span {
  display: block;
  text-align: center;
  white-space: nowrap;
  margin: 0;
  padding: 2px 0;
  border-radius: 4px;
  font-size: 1.2rem;
  width: 90px;
}
.page #whats-new dl dt span.cat-news {
  background-color: #00BBD3;
  color: #FFFFFF;
}
.page #whats-new dl dt span.cat-event {
  background-color: #FF9700;
  color: #FFFFFF;
}
.page #whats-new dl dt span.cat-student {
  background-color: #8BC349;
  color: #FFFFFF;
}
.page #whats-new dl dt span.cat-campus {
  background-color: #9D9D9D;
  color: #FFFFFF;
}
.page #whats-new dl dt span.cat-recruitment {
  background-color: #EC68B7;
  color: #FFFFFF;
}
.page #whats-new dl dd {
  margin: 0;
  padding: 0;
  width: 100%;
  order: 1;
}

.page #latest-research {
  margin: 0;
  padding: 0;
}
.page #latest-research ul {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 20px auto 0 auto;
  padding: 0;
}
.page #latest-research ul li {
  width: 48%;
  background-color: #F8F8F8;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  margin: 0 auto 20px auto;
}
.page #latest-research ul li:empty {
  background-color: #FFFFFF;
}
.page #latest-research ul li a {
  font-weight: 800;
  color: #000000;
}
.page #latest-research ul li img {
  min-width: 100%;
  height: auto;
}
.page #latest-research ul li p {
  margin: 0;
  padding: 10px;
  font-size: 1.4rem;
  font-weight: 800;
  flex-grow: 1;
}
.page #latest-research ul li  cite {
  margin: 0 10px 10px 10px;
  padding: 10px 0 0 0;
  border-top: 1px solid #205EA9;
  color: #205EA9;
  line-height: 140%;
  font-size: 1.2rem;
  font-style: normal;
  font-weight: 800;
}



}



/********************************************************/
/********** Responsive Contents Setting (1104) **********/
/********************************************************/

@media print, screen and ( min-width: 1105px ) {



/****************************/
/********** Header **********/
/****************************/

header {
  width: 100%;
  margin: 0 auto;
  padding: 0;
  position: relative;
  background-color: #205EA9;
}
header #first-section {
  width: 100%;
  margin: 0 auto;
  padding: 0;
  border-bottom: 1px solid #074494;
  position: relative;
  z-index: 7777;
}
header #first-section a {
  color: #FFFFFF;
  text-decoration: none;
}
header #first-section a:hover,
header #first-section .current a {
  text-decoration: underline;
}
header #first-section .wrapper {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin: 0 auto;
  padding: 0;
  width: 1080px;
}
header #first-section .univ {
  flex: 1;
  padding: 10px 0;
  order: 1;
}
header #first-section nav {
  display: flex;
  margin: 0 auto;
  padding: 0;
  order: 3;
}
header #first-section nav ul {
  display: flex;
  margin: 0 auto;
  padding: 10px;
  border-left: 1px solid #074494;
  border-right: 1px solid #074494;
}
header #first-section nav ul li {
  font-size: 1.4rem;
  margin: 0 8px;
}
header #first-section .language {
  margin: 0 auto;
  padding: 10px 14px;
  border-right: 1px solid #074494;
  font-size: 1.4rem;
  letter-spacing: 0.1rem;
}
header #first-section aside {
  order: 2;
  margin: auto;
  padding: 10px;
  border-left: 1px solid #074494;
}
header #first-section aside ul {
  display: flex;
  margin: 0 auto;
  padding: 0;
}
header #first-section aside ul li {
  margin: 0 12px;
  position: relative;
}

header #second-section {
  width: 100%;
  margin: 0 auto;
  padding: 10px 0;
  position: relative;
  z-index: 7777;
}
header #second-section .wrapper {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin: 0 auto;
  padding: 12px 0;
  width: 1080px;
}
header #second-section h1 {
  margin: 0;
  padding: 0;
  flex: 1;
}
header #second-section h1 a {
  font-size: 2.2rem;
  font-weight: 800;
  text-decoration: none;
  color: #FFFFFF;
  line-height: 100%;
  transition: all 0.3s ease;
}
header #second-section h1 a small {
  font-family: 'Roboto';
  font-size: 1.6rem;
  font-weight: 300;
  letter-spacing: 0.06rem;
}
header #second-section h1 a:hover,
header #second-section h1 a:hover:before {
  opacity: 0.7;
  transition: all 0.3s ease;
}
header #second-section h1 a:before {
  content: "";
  display: inline-block;
  width: 42px;
  height: 46px;
  background-image: url("../images/logo-school01.png");
  background-size: contain;
  background-repeat: no-repeat;
  vertical-align: middle;
  margin: 3px 14px 0 0;
  transition: all 0.3s ease;
  float: left;
}
header #second-section .searchform {
  margin: 0;
  padding: 4px;
  background-color: rgba(255,255,255,0.1);
}
header #second-section .searchform input[type="text"]:focus,
header #second-section .searchform button[type="submit"]:focus {
  outline: 0;
}
header #second-section .searchform .searchfield {
  margin: 0;
  padding: 4px;
  color: #CCCCCC;
  font-size: 1.4rem;
  border: none;
  background: none;
  width: 180px;
}
header #second-section .searchform .searchsubmit {
  border: none;
  background: none;
  color: #FFFFFF;
}



/********************************/
/********** Global Nav **********/
/********************************/

.global-nav {
  margin: 0 auto;
  padding: 0;
  position: relative;
  z-index: 9999;
  width: 100%;
  text-align: center;
}
.global-nav .fas {
  display: none;
}
.global-nav ul li:hover {
  cursor: default;
}

.global-nav nav:nth-child(1) {
  margin: 0 auto;
  padding: 0;
  background-color: #074494;
}
.global-nav nav:nth-child(1) ul {
  margin: 0 auto;
  padding: 0;
  display: table;
  table-layout: fixed;
  width: 1080px;
}
.global-nav nav:nth-child(1) ul li {
  display: table-cell;
  vertical-align: middle;
  font-size: 1.6rem;
  color: #FFFFFF;
  background-color: #074494;
  position: relative;
  z-index: 9999;
  border-left: 1px solid #205EA9;
}
.global-nav nav:nth-child(1) ul li:last-child {
  border-right: 1px solid #205EA9;
}
.global-nav nav:nth-child(1) ul li a {
  display: block;
  color: #FFFFFF;
  text-decoration: none;
  padding: 10px 0;
}
.global-nav nav:nth-child(1) ul li a:hover,
.global-nav nav:nth-child(1) ul li.current a {
  background-color: #043874;
  color: #FFFFFF;
}

.global-nav nav:nth-child(1) ul li > ul {
  display: none;
  position: absolute;
  top: 42px;
  left: 0;
  width: 100%;
}
.global-nav nav:nth-child(1) ul li:hover > ul {
  display: block;
}
.global-nav nav:nth-child(1) ul li:hover > ul li {
  display: flex;
  flex-direction: column;
  font-size: 1.4rem;
  line-height: 140%;
  text-align: left;
  border-bottom: 1px solid #C5D2E2;
  border-left: none;
  border-right: none;
  background-color: #EEEEEE;
  color: #205EA9;
}
.global-nav nav:nth-child(1) ul li:hover > ul li:last-child {
  border-bottom: none;
}
.global-nav nav:nth-child(1) ul li > ul li a,
.global-nav nav:nth-child(1) ul li span,
.global-nav nav:nth-child(1) ul li.current > ul li a {
  display: block;
  background-color: #EEEEEE;
  color: #205EA9;
  text-decoration: none;
  font-size: 1.4rem;
  line-height: 140%;
  text-align: left;
  padding: 4px 12px;
}

.global-nav nav:nth-child(1) ul li > ul li > ul {
  display: none;
  position: absolute;
  top: 0;
  left: 216px;
  width: 100%;
}
.global-nav nav:nth-child(1) ul li:last-child > ul li > ul {
  display: none;
  position: absolute;
  top: 0;
  left: -216px;
  width: 100%;
}
.global-nav nav:nth-child(1) ul li > ul li:hover > ul {
  display: flex;
  flex-direction: column;
}
.global-nav nav:nth-child(1) ul li > ul li > ul li {
  color: #FFFFFF;
  font-size: 1.4rem;
  line-height: 140%;
  text-align: left;
  border-bottom: 1px solid #C5D2E2;
  background-color: #EEEEEE;
  color: #205EA9;
}
.global-nav nav:nth-child(1) ul li > ul li > ul li:first-child {
  border-top: none;
}
.global-nav nav:nth-child(1) ul li > ul li > ul li a,
.global-nav nav:nth-child(1) ul li.current > ul li > ul li a {
  display: block;
  background-color: #EEEEEE;
  color: #205EA9;
  text-decoration: none;
  font-size: 1.4rem;
  line-height: 140%;
  text-align: left;
  padding: 4px 12px;
}

.global-nav nav:nth-child(1) ul li > ul li a:hover,
.global-nav nav:nth-child(1) ul li > ul li.current a,
.global-nav nav:nth-child(1) ul li > ul li span:hover,
.global-nav nav:nth-child(1) ul li > ul li.current span,
.global-nav nav:nth-child(1) ul li > ul li > ul li a:hover,
.global-nav nav:nth-child(1) ul li > ul li > ul li.current a,
.global-nav nav:nth-child(1) ul li > ul li > ul li span:hover,
.global-nav nav:nth-child(1) ul li > ul li > ul li.current span {
  color: #205EA9;
  background-color: #C5D2E2;
}



.global-nav nav:nth-child(2) {
  margin: 0 auto;
  padding: 0;
  background-color: #FFFFFF;
  border-bottom: 1px solid #C5D2E2;
}
.global-nav nav:nth-child(2) ul {
  margin: 0 auto;
  padding: 0;
  display: table;
  table-layout: fixed;
  width: 1080px;
}
.global-nav nav:nth-child(2) ul li {
  display: table-cell;
  vertical-align: middle;
  font-size: 1.4rem;
  color: #205EA9;
  position: relative;
  z-index: 7777;
  border-left: 1px solid #C5D2E2;
}
.global-nav nav:nth-child(2) ul li:last-child {
  border-right: 1px solid #C5D2E2;
}
.global-nav nav:nth-child(2) ul li a {
  display: block;
  color: #205EA9;
  text-decoration: none;
  padding: 5px 0;
}
.global-nav nav:nth-child(2) ul li a:hover,
.global-nav nav:nth-child(2) ul li.current a {
  background-color: #205EA9;
  color: #FFFFFF;
}

.global-nav nav:nth-child(2) ul li > ul {
  display: none;
  position: absolute;
  top: 32px;
  left: 0;
  width: 100%;
}
.global-nav nav:nth-child(2) ul li:hover > ul {
  display: block;
}
.global-nav nav:nth-child(2) ul li:hover > ul li {
  display: flex;
  flex-direction: column;
  font-size: 1.4rem;
  line-height: 140%;
  text-align: left;
  border-bottom: 1px solid #C5D2E2;
  border-left: none;
  border-right: none;
  background-color: #EEEEEE;
  color: #205EA9;
}
.global-nav nav:nth-child(2) ul li:hover > ul li:last-child {
  border-bottom: none;
}
.global-nav nav:nth-child(2) ul li > ul li a,
.global-nav nav:nth-child(2) ul li span,
.global-nav nav:nth-child(2) ul li.current > ul li a {
  display: block;
  background-color: #EEEEEE;
  color: #205EA9;
  text-decoration: none;
  font-size: 1.4rem;
  line-height: 140%;
  text-align: left;
  padding: 4px 12px;
}

.global-nav nav:nth-child(2) ul li > ul li > ul {
  display: none;
  position: absolute;
  top: 0;
  left: 180px;
  width: 100%;
}
.global-nav nav:nth-child(2) ul li:last-child > ul li > ul {
  display: none;
  position: absolute;
  top: 0;
  left: -180px;
  width: 100%;
}
.global-nav nav:nth-child(2) ul li > ul li:hover > ul {
  display: flex;
  flex-direction: column;
}
.global-nav nav:nth-child(2) ul li > ul li > ul li {
  color: #FFFFFF;
  font-size: 1.4rem;
  line-height: 140%;
  text-align: left;
  border-bottom: 1px solid #C5D2E2;
  background-color: #EEEEEE;
  color: #205EA9;
}
.global-nav nav:nth-child(2) ul li > ul li > ul li:first-child {
  border-top: none;
}
.global-nav nav:nth-child(2) ul li > ul li > ul li a,
.global-nav nav:nth-child(2) ul li.current > ul li > ul li a,
.global-nav nav:nth-child(2) ul li.current > ul li > ul li span {
  display: block;
  background-color: #EEEEEE;
  color: #205EA9;
  text-decoration: none;
  font-size: 1.4rem;
  line-height: 140%;
  text-align: left;
  padding: 4px 12px;
}

.global-nav nav:nth-child(2) ul li > ul li a:hover,
.global-nav nav:nth-child(2) ul li > ul li.current a,
.global-nav nav:nth-child(2) ul li > ul li span:hover,
.global-nav nav:nth-child(2) ul li > ul li.current span,
.global-nav nav:nth-child(2) ul li > ul li > ul li a:hover,
.global-nav nav:nth-child(2) ul li > ul li > ul li.current a,
.global-nav nav:nth-child(2) ul li > ul li > ul li span:hover,
.global-nav nav:nth-child(2) ul li > ul li > ul li.current span {
  color: #205EA9;
  background-color: #C5D2E2;
}



/********************************/
/********** Main Image **********/
/********************************/

#main-image {
  margin: 0 auto;
  padding: 0;
  text-align: center;
  width: 100%;
  height: 480px;
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
  position: relative;
  overflow: hidden;
}
#main-image .wrapper {
  margin: 0 auto;
  padding: 0 40px;
  width: 1080px;
  text-align: left;
}
#main-image .wrapper .contents {
  margin: 0;
  padding: 0;
  text-align: left;
}
#main-image .swiper-slide {
  display: flex;
  align-items: center;
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
  overflow: hidden;
/*
  height: 0;
  padding-top: 40%;
*/
}
#main-image .swiper-slide a {
  display: flex;
  align-items: center;
  color: #FFFFFF;
  text-decoration: none;
  width: 100%;
  height: 100%;
  position: absolute;
  z-index: 1000;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
}

#main-image .swiper-button-white {
  opacity: 0.6;
  transition: opacity 0.3s;
}
#main-image .swiper-button-white:hover {
  opacity: 1;
  filter: alpha(opacity=70);
  transition: opacity 0.3s;
  backface-visibility: hidden;
}
#main-image .swiper-button-prev {
  margin-left: 20px;
}
#main-image .swiper-button-next {
  margin-right: 20px;
}

#main-image .swiper-pagination {
  bottom: 10px;
  left: 0;
  width: 100%;
  z-index: 7777;
}
#main-image .swiper-pagination-bullet {
  width: 12px;
  height: 12px;
  background-color: #FFFFFF;
  border: 2px solid #CCCCCC;
  opacity: 1;
}
#main-image .swiper-pagination-bullet-active {
  background-color: #205EA9;
  opacity: 1;
}
#main-image .swiper-pagination-bullet {
  margin: 0 7px;
}
#main-image .swiper-button-prev,
#main-image .swiper-button-next {
  z-index: 7777;
}

#main-image .screen-overlay {
  background-color: rgba(0,0,0,0.4);
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  content: "";
}
#main-image .screen-logo {
  width: 100%;
  margin: 0 auto;
  padding: 0;
  text-align: center;
  position: absolute;
  z-index: 6666;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
}
#main-image .screen-logo p {
  font-size: 2.2rem;
  font-weight: 300;
  line-height: 140%;
  color: #FFFFFF;
  width: 100%;
  margin: 40px auto 0 auto;
  padding: 0;
  text-align: center;
}
#main-image .screen-logo p small {
  font-family: 'Roboto';
  font-size: 1.6rem;
  font-weight: 300;
}



/****************************/
/********** Footer **********/
/****************************/

footer {
  width: 100%;
  margin: 60px auto 0 auto;
  padding: 0;
  background-color: #FFFFFF;
  border-top: 1px solid #205EA9;
}
footer #pagetop {
  margin: -30px auto 0 auto;
  padding: 0;
  text-align: center;
}
footer #pagetop a {
  display: block;
  margin: 0 auto;
  width: 65px;
  height: 62px;
  line-height: 62px;
  background-color: #205EA9;
}
footer .footer-nav {
  margin: 0 auto;
  padding: 0;
  width: 1080px;
  font-size: 1.4rem;
}
footer .footer-nav ul {
  display: flex;
  justify-content: space-between;
  margin: 0 auto;
  padding: 0;
}
footer .footer-nav ul li {
  width: 49%;
}
footer .footer-nav ul li h3 {
  background: none;
  color: #205EA9;
  border-bottom: 1px solid #205EA9;
  margin: 10px 0;
  padding: 10px 0;
  font-size: 1.6rem;
  font-weight: 800;
}
footer .footer-nav ul li .wrapper {
  display: flex;
  justify-content: space-between;
  width: 100%;
}
footer .footer-nav ul li ul {
  display: inline;
  margin: 0 auto;
  padding: 0;
  width: 100%;
}
footer .footer-nav ul li ul li {
  margin: 2px 0;
  padding: 0;
  width: 100%;
}
footer .footer-nav ul li ul li a {
  font-size: 1.4rem;
  font-weight: 800;
  color: #333333;
}
footer .footer-nav ul li ul li:before {
  font-family: 'Font Awesome 5 Free';
  content: "\f138";
  margin: 0 6px 0 0;
  font-size: 1.4rem;
  font-weight: 800;
  color: #518FD7;
}
footer .content {
  margin: 40px auto;
  padding: 0;
  width: 1080px;
  display: flex;
  gap: 40px;
}
.home footer address {
  margin: 40px auto;
  padding: 0;
  text-align: center;
  font-size: 1.6rem;
}
.page footer address {
  margin: auto;
  padding: 0;
  text-align: center;
  font-size: 1.4rem;
  white-space: nowrap;
}
footer aside {
  margin: auto;
  padding: 0;
}
footer aside ul {
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  width: 100%;
}
footer aside ul li {
  width: 32%;
  margin: 0 2% 2% 0;
  border: 10px solid #EEEEEE;
}
footer aside ul li:nth-child(3n) {
  margin: 0 0 2% 0;
}
footer aside ul li img {
  max-width: 100%;
  height: auto;
}
footer #copyright {
  text-align: center;
  letter-spacing: 0.1rem;
  background-color: #205EA9;
  color: #FFFFFF;
  margin: 0 auto;
  padding: 10px;
  width: 100%;
}



/****************************************/
/********** Respomsive Swicher **********/
/****************************************/

#trigger {
  display: none;
}
#trigger-close {
  display: none;
}



/**************************/
/********** Main **********/
/**************************/

main {
  display: block;
  margin: 0 auto;
  padding: 0;
  flex: 1;
  background-color: #FFFFFF;
  width: 100%;
}
main .wrapper {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 0 auto;
  padding: 0;
  width: 1080px;
}



/*****************************/
/********** Content **********/
/*****************************/

#content {
  margin: 0;
  padding: 0;
  flex: 1;
  order: 2;
  width: 100%;
}



/*****************************/
/********** Sidebar **********/
/*****************************/

#sidebar {
  order: 1;
  margin: 0 35px 0 0;
  padding: 0;
  width: 275px;
}
#sidebar a:hover {
  text-decoration: none;
}
#sidebar h2 {
  font-size: 1.4rem;
  margin-bottom: 0;
  padding: 6px 12px;
  background-color: #205EA9;
  color: #FFFFFF;
}
#sidebar h2 a {
  display: block;
  font-size: 1.4rem;
  color: #FFFFFF;
  margin: 0;
  padding: 0;
}
#sidebar ul {
  margin: 0;
  padding: 0;
}
#sidebar ul li {
  margin: 0;
  padding: 0;
  font-size: 1.4rem;
  color: #205EA9;
  background-color: #FFFFFF;
  border-bottom: 1px solid #205EA9;
}
#sidebar ul li span {
  display: block;
  text-decoration: none;
  margin: 0;
  padding: 6px 12px;
}
#sidebar ul li a {
  display: block;
  text-decoration: none;
  margin: 0;
  padding: 6px 12px;
}
#sidebar ul li a:hover,
#sidebar ul li.current a,
#sidebar ul li.current a:hover,
#sidebar ul li ul li.current a {
  background-color: #C5D2E2;
}

#sidebar ul li > ul {
  margin: 0;
  padding: 0;
}
#sidebar ul li > ul li,
#sidebar ul li.current > ul li a {
  margin: 0;
  padding: 0;
  font-size: 1.4rem;
  color: #205EA9;
  background-color: #FFFFFF;
  border-bottom: none;
}
#sidebar ul li > ul li a,
#sidebar ul li > ul li span,
#sidebar ul li.current > ul li a {
  display: block;
  text-decoration: none;
  border: none;
  margin: 0;
  padding: 3px 0 3px 24px;
}

#sidebar ul li > ul li > ul {
  margin: 0;
  padding: 0;
}
#sidebar ul li > ul li > ul li,
#sidebar ul li.current > ul li > ul li a {
  margin: 0;
  padding: 0;
  font-size: 1.3rem;
  color: #205EA9;
  background-color: #FFFFFF;
  border-bottom: none;
}
#sidebar ul li > ul li > ul li,
#sidebar ul li > ul li > ul li span,
#sidebar ul li.current > ul li > ul li a {
  display: block;
  text-decoration: none;
  border: none;
  margin: 0;
  padding: 0 0 0 24px;
}



/*********************************/
/********** Breadcrumbs **********/
/*********************************/

#breadcrumbs {
  margin: 10px auto;
  padding: 0;
}
#breadcrumbs ul {
  margin: 0 auto;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  width: 1080px;
}
#breadcrumbs ul li {
  margin: 0 12px 0 0;
  font-size: 1.4rem;
  color: #205EA9;
}
#breadcrumbs ul li:after {
  content: "/";
  margin: 0 0 0 12px;
  font-size: 1.2rem;
}
#breadcrumbs ul li:last-child:after {
  content: none;
}



/**************************/
/********** Home **********/
/**************************/

.home h2 {
  border-bottom: 1px solid #205EA9;
  padding: 0 0 5px 0;
  font-size: 2.4rem;
}
.home h2 span {
  position: absolute;
  right: 0;
}
.home h2 span a {
  font-size: 1.4rem;
  color: #000000;
  transition: opacity 0.3s;
}
.home h2 span a:hover {
  text-decoration: none;
  opacity: 0.7;
  filter: alpha(opacity=70);
  transition: opacity 0.3s;
}
.home h2 span a:before {
  font-family: 'Font Awesome 5 Free';
  content: "\f138";
  margin: 0 4px 0 0;
  font-size: 1.6rem;
  font-weight: 800;
  color: #BFBFBF;
}

.home #important {
  margin: 40px 0 0 0;
  padding: 30px 40px;
  width: 100%;
  border: 2px solid #DE0000;
  border-radius: 10px;
}
.home #important h2 {
  border: none;
  margin: 0 0 20px 0;
  padding: 0;
  color: #DE0000;
  font-size: 1.8rem;
  font-weight: 800;
  text-align: center;
}
.home #important dl {
  display: flex;
  margin: 0 0 15px 0;
  padding: 0 0 15px 0;
  border-bottom: 1px solid #205EA9;
  width: 100%;
}
.home #important dl:last-child {
  margin-bottom: 0;
  padding-bottom: 0;
  border: none;
}
.home #important dl dt {
  margin: 0 50px 0 0;
  padding: 0;
}
.home #important dl dt time {
  font-size: 1.5rem;
  font-weight: 800;
  color: #205EA9;
  white-space: nowrap;
}
.home #important dl dd {
  margin: 0;
  padding: 0;
}



.home #whats-new {
  margin: 20px 0;
  padding: 0;
  width: 100%;
  position: relative;
}
/*
.home #whats-new .intro-movie {
  margin: 0 30px 0 0;
  text-align: center;
}
.home #whats-new .intro-movie h2 {
  text-align: left;
}
.home #whats-new .intro-movie iframe {
  width: 321px;
  height: 180px;
  margin: 30px 0;
  border: none;
}
*/

.home #whats-new .tabs {
  overflow: hidden;
  display: flex;
  justify-content: flex-end;
  margin: 0 0 20px 0;
  padding: 0;
  border-bottom: 1px solid #205EA9;
}
.home #whats-new .tabs li {
  margin: 0 1px;
  border-left: 1px solid #205EA9;
  border-top: 1px solid #205EA9;
  border-right: 1px solid #205EA9;
  border-top-left-radius: 6px;
  border-top-right-radius: 6px;
  padding: 4px;
  color: #205EA9;
  font-size: 1.4rem;
  cursor: pointer;
  width: 13.25%;
  text-align: center;
}
.home #whats-new .tabs li.select {
  background-color: #205EA9;
  color: #FFFFFF;
}
.home #whats-new .hide {
  display: none;
}

.home #whats-new dl {
  display: flex;
  align-items: center;
  margin: 0 0 10px 0;
  padding: 0 0 10px 0;
  border-bottom: 1px dotted #205EA9;
  width: 100%;
}
.home #whats-new dl:last-child {
  margin-bottom: 0;
}
.home #whats-new dl dt {
  display: flex;
  align-items: center;
  margin: 0;
  padding: 0;
}
.home #whats-new dl dt time {
  font-size: 1.5rem;
  font-weight: 800;
  color: #205EA9;
  white-space: nowrap;
}
.home #whats-new dl dt span {
  display: block;
  text-align: center;
  white-space: nowrap;
  margin: 0 20px;
  padding: 2px 0;
  border-radius: 4px;
  font-size: 1.2rem;
  min-width: 90px;
}
.home #whats-new dl dt span.cat-news {
  background-color: #00BBD3;
  color: #FFFFFF;
}
.home #whats-new dl dt span.cat-event {
  background-color: #FF9700;
  color: #FFFFFF;
}
.home #whats-new dl dt span.cat-student {
  background-color: #8BC349;
  color: #FFFFFF;
}
.home #whats-new dl dt span.cat-campus {
  background-color: #9D9D9D;
  color: #FFFFFF;
}
.home #whats-new dl dt span.cat-recruitment {
  background-color: #EC68B7;
  color: #FFFFFF;
}
.home #whats-new dl dd {
  margin: 0;
  padding: 0;
  flex: 1;
}

.home #latest-research {
  margin: 20px 0;
  padding: 0;
  width: 100%;
}
.home #latest-research ul {
  display: flex;
  flex-wrap: wrap;
  margin: 0;
  padding: 0;
}
.home #latest-research ul li {
  width: 23.5%;
  margin: 0 2% 2% 0;
  background-color: #F8F8F8;
  outline: 1px solid #EEEEEE;
  outline-offset: -1px;
}
.home #latest-research ul li:nth-child(4n) {
  margin: 0 0 2% 0;
}
.home #latest-research ul li a {
  display: flex;
  flex-direction: column;
  width: 100%;
  height: 100%;
  font-weight: 700;
  color: #000000;
}
.home #latest-research ul li a:hover {
  text-decoration: none;
  color: #666666;
}
.home #latest-research ul li p {
  margin: 0;
  padding: 15px;
  font-size: 1.5rem;
  font-weight: 500;
}
.home #latest-research ul li span {
  display: inline-block;
  margin: auto 0 0 0;
  padding: 0 15px 15px 15px;
  font-family: "Roboto";
  font-size: 1.3rem;
  font-weight: 400;
  letter-spacing: 0.04rem;
}
.home #latest-research ul li img {
  max-width: 100%;
  width: 100%;
  height: auto;
}

.home #laboratory-list {
  margin: 20px 0;
  padding: 0;
  width: 100%;
  background-image: url("../images/laboratory-list.jpg");
  background-repeat: no-repeat;
  background-position: center center;
  background-size: contain;
  height: 100px;
}
.home #laboratory-list a {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
  margin: 0 auto;
  padding: 0;
  text-align: center;
  color: #FFFFFF;
  font-size: 3.0rem;
  font-weight: 800;
  transition: opacity 0.3s;
}
.home #laboratory-list i {
  margin: 0 0 0 20px;
}
.home #laboratory-list a:hover {
  text-decoration: none;
  opacity: 0.7;
  filter: alpha(opacity=70);
  transition: opacity 0.3s;
}

.home #web-lecture-series {
  margin: 20px 0;
  padding: 0;
  width: 100%;
  background-image: url("../images/web-lecture-series.jpg");
  background-repeat: no-repeat;
  background-position: center center;
  background-size: contain;
  height: 100px;
}
.home #web-lecture-series a {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
  margin: 0 auto;
  padding: 0;
  text-align: center;
  color: #FFFFFF;
  font-size: 3.0rem;
  font-weight: 800;
  transition: opacity 0.3s;
}
.home #web-lecture-series a span {
  font-family: 'Roboto';
  font-size: 2.8rem;
  font-weight: 400;
  margin: 0 0 0 12px;
}
.home #web-lecture-series i {
  margin: 0 0 0 20px;
}
.home #web-lecture-series a:hover {
  text-decoration: none;
  opacity: 0.7;
  filter: alpha(opacity=70);
  transition: opacity 0.3s;
}

.home #banners {
  margin: 20px 0;
  padding: 0;
  width: 100%;
}
.home #banners ul {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 0 auto;
  padding: 0;
}
.home #banners ul li {
  margin: 10px 0;
  padding: 10px;
  background-color: #EEEEEE;
}



/***************************/
/********** Pages **********/
/***************************/

.page div.cat-image.cat-logo {
  background-image: url("../images/cat-image-logo.png");
}

.page .panel-style01 ul {
  display: flex;
  margin: 0;
  padding: 0;
}
.page .panel-style01 ul li {
  width: 180px;
  margin: 0 10px 0 0;
}
.page .panel-style01 ul li:last-child {
  margin: 0;
}
.page .panel-style01 ul li img {
  margin: 0 0 8px 0;
  width: 100%;
  height: auto;
}

.page .panel-style02 {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  margin: 20px 0;
  padding: 0;
}
.page .panel-style02 div {
  width: 48%;
  display: flex;
  align-items: center;
  background-color: #E6F1F7;
  margin: 10px 0;
}
.page .panel-style02 div a {
  display: block;
  width: 100%;
  padding: 20px;
}
.page .panel-style02 div.cat-image a {
  display: block;
  width: 100%;
  padding: 20px 200px 20px 20px;
}
.page .panel-style02 div.cat-image {
  background-repeat: no-repeat;
  background-position: right center;
  background-size: 180px auto;
}

.page .panel-style03 {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  margin: 20px 0;
  padding: 0;
}
.page .panel-style03 div {
  width: 48%;
  border-top: 1px solid #0076A5;
  border-bottom: 1px solid #0076A5;
  display: flex;
  align-items: center;
  margin: 10px 0;
}
.page .panel-style03 div a {
  display: block;
  width: 100%;
  padding: 10px 0;
}

.page .panel-style05 {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  margin: 20px 0;
  padding: 0;
}
.page .panel-style05 div:nth-child(1) {
  width: 48%;
  display: flex;
  align-items: center;
  background-color: #E6F1F7;
  margin: 10px 0;
}
.page .panel-style05 div:nth-child(1) a {
  display: block;
  width: 100%;
  padding: 20px 200px 20px 20px;
}
.page .panel-style05 div:nth-child(1) {
  background-repeat: no-repeat;
  background-position: right center;
  background-size: 180px auto;
}
.page .panel-style05 div:nth-child(2) {
  width: 48%;
  border-top: 1px solid #0076A5;
  border-bottom: 1px solid #0076A5;
  display: flex;
  align-items: center;
  margin: 10px 0;
}
.page .panel-style05 div:nth-child(2) a {
  display: block;
  width: 100%;
  padding: 10px 0;
}

.page .panel-style06 {
  margin: 20px 0;
  padding: 20px;
  width: 100%;
  display: flex;
  flex-direction: column;
  background-color: #E6F1F7;
}
.page .panel-style06 div {
  width: 100%;
  display: flex;
  align-items: center;
  background-color: #E6F1F7;
  margin: 0;
  padding: 2px 0;
  color: #205EA9;
  border-bottom: 1px solid #205EA9;
}
.page .panel-style06 ul {
  margin: 10px;
  padding: 0;
}
.page .panel-style06 ul li {
  margin: 0;
  padding: 0;
}
.page .panel-style06 ul li a {
  font-size: 1.3rem;
}
.page .panel-style06 ul li a:before {
  font-family: 'Font Awesome 5 Free';
  content: "\f105";
  margin: 0 4px 0 0;
  font-size: 1.2rem;
  font-weight: 800;
}

.page #whats-new {
  margin: 20px 0;
  padding: 0;
  width: 100%;
  position: relative;
}
.page #whats-new .tabs {
  display: flex;
  margin: 0;
  padding: 0;
  position: absolute;
  top: 33px;
  left: 240px;
}
.page #whats-new .tabs li {
  margin: 0 1px;
  border-left: 1px solid #205EA9;
  border-top: 1px solid #205EA9;
  border-right: 1px solid #205EA9;
  border-top-left-radius: 6px;
  border-top-right-radius: 6px;
  padding: 4px 24px;
  color: #205EA9;
  font-size: 1.4rem;
  cursor: pointer;
}
.page #whats-new .tab_item.active {
  background-color: #205EA9;
  color: #FFFFFF;
}
.page #whats-new .hide {
  display: none;
}
.page #whats-new dl {
  display: flex;
  align-items: center;
  margin: 0 0 15px 0;
  padding: 0 0 15px 0;
  border-bottom: 1px solid #205EA9;
  width: 100%;
}
.page #whats-new dl:last-child {
  margin-bottom: 0;
}
.page #whats-new dl dt {
  display: flex;
  align-items: center;
  margin: 0;
  padding: 0;
  width: 30%;
}
.page #whats-new dl dt time {
  font-size: 1.5rem;
  font-weight: 800;
  color: #205EA9;
  white-space: nowrap;
}
.page #whats-new dl dt span {
  display: block;
  text-align: center;
  white-space: nowrap;
  margin: 0 30px;
  padding: 2px 0;
  border-radius: 4px;
  font-size: 1.2rem;
  min-width: 90px;
}
.page #whats-new dl dt span.cat-news {
  background-color: #00BBD3;
  color: #FFFFFF;
}
.page #whats-new dl dt span.cat-event {
  background-color: #FF9700;
  color: #FFFFFF;
}
.page #whats-new dl dt span.cat-student {
  background-color: #8BC349;
  color: #FFFFFF;
}
.page #whats-new dl dt span.cat-campus {
  background-color: #9D9D9D;
  color: #FFFFFF;
}
.page #whats-new dl dt span.cat-recruitment {
  background-color: #EC68B7;
  color: #FFFFFF;
}
.page #whats-new dl dd {
  margin: 0;
  padding: 0;
  width: 70%;
}

.page #latest-research {
  margin: 0;
  padding: 0;
}
.page #latest-research ul {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 20px auto 0 auto;
  padding: 0;
}
.page #latest-research ul li {
  width: 48%;
  background-color: #F8F8F8;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  margin: 0 auto 20px auto;
}
.page #latest-research ul li:empty {
  background-color: #FFFFFF;
}
.page #latest-research ul li a {
  font-weight: 800;
  color: #000000;
}
.page #latest-research ul li img {
  min-width: 100%;
  height: auto;
}
.page #latest-research ul li p {
  margin: 0;
  padding: 10px;
  font-size: 1.4rem;
  font-weight: 800;
  flex-grow: 1;
}
.page #latest-research ul li  cite {
  margin: 0 10px 10px 10px;
  padding: 10px 0 0 0;
  border-top: 1px solid #205EA9;
  color: #205EA9;
  line-height: 140%;
  font-size: 1.2rem;
  font-style: normal;
  font-weight: 800;
}



}



/* for home tabs */
@media screen and ( max-width: 1104px ) {
.home #whats-new .hide {
  display: none;
}
}





/* 追記 - 2025/12*/
.page #prof-ctn { width: 100%; margin: 0; padding: 0;}
.page #prof-ctn #prof-1 { display: block; width: 100%; padding: 10px 0 80px;}
.page #prof-ctn #prof-2 { display: block; width: 100%; padding: 80px 0px; border-top: dashed 1px #C5D2E2;}
.page #prof-ctn #prof-3 { display: block; width: 100%; padding: 80px 0px; border-top: dashed 1px #C5D2E2;}
.page #prof-ctn #prof-4 { display: block; width: 100%; padding: 80px 0px; border-top: dashed 1px #C5D2E2;}
.page #prof-ctn .flex { display: flex; justify-content: space-between; width: 100%; margin: 0 0 0 auto;}

.page #prof-ctn .ctn-L { width: 150px;}
.page #prof-ctn .ctn-R { width: calc( 100% - 180px );}
.page #prof-ctn .ctn-L figure img { width: 100%;}
.page #prof-ctn .ctn-L dl dt { margin-bottom: 8px; font-size: 14px;}
.page #prof-ctn .ctn-L dl dt span { display: block;}
.page #prof-ctn .ctn-L dl dt span.name { font-size: 22px; font-weight: 700;}
.page #prof-ctn .ctn-L dl dt span.eng { color: #315da4;}
.page #prof-ctn .ctn-L dl dd { margin: 0; padding: 0; font-size: 15px; line-height: 1.8;}
.page #prof-ctn .ctn-R h3 { margin: 0px; padding: 0 0 12px; background: none; color: #315da4; font-weight: 700; border-bottom: solid 1px #315da4;}
.page #prof-ctn .ctn-R .txt { padding-bottom: 12px;}
.page #prof-ctn .ctn-R .txt figure {}
.page #prof-ctn .ctn-R .txt figure img { width: 100%;}
.page #prof-ctn .ctn-R .txt figure img.w200 { max-width: 200px;}
@media screen and ( max-width: 480px ) {
	.page #prof-ctn #prof-1 { padding: 10px 0 40px;}
	.page #prof-ctn #prof-2 { padding: 40px 0px;}
	.page #prof-ctn #prof-3 { padding: 40px 0px;}
	.page #prof-ctn #prof-4 { padding: 40px 0px;}
	.page #prof-ctn .ctn-L { width: 100px;}
	.page #prof-ctn .ctn-R { width: calc( 100% - 120px );}
	.page #prof-ctn .ctn-L dl dt { margin-bottom: 4px; font-size: 12px;}
	.page #prof-ctn .ctn-L dl dt span.name { font-size: 16px;}
	.page #prof-ctn .ctn-L dl dd { font-size: 11px; line-height: 1.65;}
	.page #prof-ctn .ctn-R h3 { padding-bottom: 8px;}
	.page #prof-ctn .ctn-R .txt { padding-bottom: 8px;}
	.page #prof-ctn .ctn-R .txt p { margin: 12px 0;}
}


#ifa ul { margin-bottom: 30px; list-style: none;}
#ifa ul li { position: relative; margin: 0; padding: 4px 0;}
#ifa ul li span { display: inline-block; vertical-align: top;}
#ifa ul li span.country { width: 140px;}
#ifa ul li span.univ { width: 160px;}
#ifa ul li span.course{ width: 330px; padding-right: 10px;}
#ifa ul li span.start { width: 120px;}
@media screen and (max-width: 480px) {
	#ifa ul li span.country,
	#ifa ul li span.univ,
	#ifa ul li span.course{ display: block; width: 100%; padding-right: 10px;}
}