@charset "utf-8";

/*--------------------------------------------------------------------------------------------------

   page

--------------------------------------------------------------------------------------------------*/


/*------------------------------------------------------------------------------------------------
  index
--------------------------------------------------------------------------------------------------*/
.indexHeader .lead {
	position: absolute;
	top: calc( 50% - 115px);
	left: 5%;
	animation: fadeIn 1.5s forwards;
	animation-delay: 0.5s;
	opacity: 0;
}

#indexAbout {
	background-image: url(../image/index-01.png), url(../image/index-02.png);
	background-repeat: no-repeat;
	background-position: 0 100%, 100% 0;
}

#indexAbout .cont {
	padding: 120px 0;
	text-align: center;
}

#indexAbout .cont h2 {
	margin: 0 0 30px;
	font-size: 36px;
	font-weight: bold;
	line-height: 1.4;
}

#indexAbout .cont p {
	font-size: 18px;
	font-weight: bold;
	line-height: 3;
}

#indexIntroduction {
	position: relative;
}

#indexIntroduction:before {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 360px;
	content: "";
	background: linear-gradient(to right, #0068B7 20%, #142382 80%);
	z-index: -2;
}

#indexIntroduction:after {
	position: absolute;
	background: url(../image/back-01.png) no-repeat 0 0;
	width: 743px;
	height: 347px;
	z-index: -1;
	content: "";
	top: 0;
	left: 5%;
}

#indexIntroduction .cont {
	width: 1100px;
	margin: 0 auto;
	padding: 100px 0;
}

#indexIntroduction .cont h2 {
	font-size: 48px;
	font-weight: bold;
	color: #FFF;
	text-align: center;
	letter-spacing: 0.06em;
}

#indexIntroduction .cont p.lead {
	margin: 0 0 50px;
	font-size: 24px;
	font-weight: bold;
	color: #FFF;
	text-align: center;
}

#indexIntroduction .cont .ryouiki {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}

#indexIntroduction .cont .ryouiki div {
	width: 320px;
	margin: 0 0 50px;
}

#indexIntroduction .cont .ryouiki div a {
	display: block;
	color: #000;
	text-decoration: none;
}

#indexIntroduction .cont .ryouiki div h3 {
	margin: 10px 0;
	padding: 2px 0 0;
	font-size: 22px;
	line-height: 36px;
	background: url(../image/arrow-03.png) no-repeat 100% 0;
	letter-spacing: 0.06em;
	border-bottom: 1px dashed #CCC;
}

#indexMenu {
	position: relative;
}

#indexMenu:before {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 530px;
	content: "";
	background: linear-gradient(to right, #0068B7 20%, #142382 80%);
	z-index: -2;
}

#indexMenu:after {
	position: absolute;
	content: "";
	top: 0;
	right: 0;
	width: 743px;
	height: 347px;
	z-index: -1;
	background: url(../image/back-01.png) no-repeat 100% 0;
}


#indexMenu .cont {
	width: 1220px;
	margin: 0 auto;
	padding: 10px 0 0;
}

#indexMenu .cont h2 {
	font-size: 72px;
	font-weight: bold;
	color: #FFF;
}

#indexMenu .cont h2 span {
	font-size: 18px;
	font-weight: normal;
	margin-left: 20px;
}

#indexMenu .cont ul {
	margin: 0;
	padding: 0;
	list-style: none;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}

#indexMenu .cont ul li {
	margin: 0 0 60px;
	padding: 0;
	width: 580px;
}

#indexMenu .cont ul li a {
	display: block;
	position: relative;
	overflow: hidden;
}

#indexMenu .cont ul li a::before {
 background-color: #fff;
 content: "";
 display: block;
 position: absolute;
 top: -100px;
 left: 0;
 width: 30px;
 height: 100%;
 opacity: 0;
 transition: cubic-bezier(0.32, 0, 0.67, 0);
}

#indexMenu .cont ul li a:hover::before {
 animation: kira 0.5s linear 1;
}
 
@keyframes kira {
  0% {
    transform: scale(2) rotate(45deg);
    opacity: 0;
  }
  20% {
    transform: scale(20) rotate(45deg);
    opacity: 0.6;
  }
  40% {
    transform: scale(30) rotate(45deg);
    opacity: 0.4;
  }
  80% {
    transform: scale(45) rotate(45deg);
    opacity: 0.2;
  }
  100% {
    transform: scale(50) rotate(45deg);
    opacity: 0;
  }
}

#indexExaminee {
	position: relative;
	height: 330px;
	margin: 0 0 100px;
}

#indexExaminee:before {
	position: absolute;
	content: "";
	background-color: #cde298;
	width: 50%;
	height: 100%;
	z-index: -1;
}

#indexExaminee .cont {
	width: 1100px;
	margin: 0 auto;
	background: url(../image/index-09.png) no-repeat #cde298 60% 100%;
}

#indexExaminee .cont a {
	display: block;
	color: #FFF;
	text-decoration: none;
	background: url(../image/arrow-04.png) no-repeat 92% center;
	height: 330px;
}

#indexExaminee .cont a:hover {
	color: #142382;
	background: url(../image/arrow-05.png) no-repeat 92% center;
}

#indexExaminee .cont p {
	font-size: 48px;
	padding: 110px 0 0 ;
}

#indexExaminee .cont p span {
	font-size: 18px;
	display: block;
}

#indexMovie {
	position: relative;
}

#indexMovie:before {
	position: absolute;
	width: 1220px;
	margin: 0 auto;
	left: 0;
	right: 0;
	top: 150px;
	height: calc( 100% - 200px);
	z-index: -2;
	background-color: #FAFAFA;
	content: "";
}

#indexMovie:after {
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	height: 200px;
	content: "";
	background: linear-gradient(to right, #0068B7 20%, #142382 80%);
	z-index: -1;
}

#indexMovie .cont {
	padding: 0 0 60px;
}

#indexMovie .cont h2 {
	width: 1100px;
	margin: 0 auto 20px;
}

#indexMovie .cont p {
	width: 1100px;
	margin: 0 auto 30px;
	font-size: 30px;
	font-weight: bold;
	position: relative;
}

#indexMovie .cont p span {
	display: inline-block;
	background-color: #FAFAFA;
	padding-right: 20px;
}

#indexMovie .cont p:before {
	position: absolute;
	content: "";
	top: 50%;
	left: 0;
	width: 60%;
	height: 1px;
	background-color: #000;
	z-index: -1;
}

.slide-movie {
	width: 700px;
	margin: 0 auto;
	padding: 0;
	list-style: none;
}

.slide-movie li {
 width: 100%;
 aspect-ratio: 16 / 9;
	margin: 0;
	padding: 0;
}

.slide-movie iframe {
 width: 100%;
 height: 100%;
}

.slick-prev, .slick-next {
	width: 98px !important;
	height: 98px !important;
	z-index: 10;
	top: 55% !important;
}

.slick-prev:before {
	position: absolute;
	background: url(../image/arrow-06.png) no-repeat 0 0 !important;
	content: "" !important;
	width: 98px !important;
	height: 98px !important;
	top: 0;
	left: 0;
	opacity: 1 !important;
}

.slick-next:before {
	position: absolute;
	background: url(../image/arrow-07.png) no-repeat 0 0 !important;
	content: "" !important;
	width: 98px !important;
	height: 98px !important;
	left: 0;
	top: 0;
	opacity: 1 !important;
}

.slick-prev {
	left: -120px !important;
}

.slick-next {
	right: -120px !important;
}

#indexNews .cont {
	width: 1100px;
	margin: 0 auto;
	padding: 60px 0;
}

#indexNews .cont h2 {
	font-size: 48px;
	font-weight: bold;
	text-align: center;
	line-height: 1.4;
	margin: 0 0 20px;
}

#indexNews .cont h2 span {
	font-size: 24px;
	display: block;
}

.newsList {
	margin: 0 0 40px;
	padding: 0;
	list-style: none;
}

.newsList li {
	margin: 0;
	padding: 0;
	border-bottom: 1px solid #CCC;
}

.newsList li a {
	padding: 28px 40px 22px;
	display: flex;
	text-decoration: none;
	color: #000;
}

.newsList li a:hover {
	background-color: #FBFBFD;
}

.newsList li a .date {
	font-size: 18px;
	width: 140px;
	line-height: 1.4;
}

.newsList li a .date span {
	font-size: 14px;
	margin-right: 10px;
}

.newsList li a .text {
	width: calc( 100% - 140px);
}


/*------------------------------------------------------------------------------------------------
  introduction
--------------------------------------------------------------------------------------------------*/
.intro01 {
	background: url(../image/intro-01.jpg) no-repeat center 0;
	background-size: cover;
}

.intro01 .cont {
	width: 1100px;
	margin: 0 auto;
	padding: 80px 0;
	font-size: 18px;
	line-height: 3;
}

.intro01 .cont .lead {
	font-size: 36px;
	font-weight: bold;
}

.intro02 {
	background-color: #f1f7ff;
}

.intro02 .cont {
	width: 1100px;
	margin: 0 auto;
	padding: 80px 0;
	font-size: 18px;
	text-align: center;
	line-height: 2;
}

.intro02 .cont .lead {
	font-size: 36px;
	font-weight: bold;
}

.intro03 {
	width: 100%;
	margin: 0;
	padding: 160px 0;
	background: url(../image/intro-03.jpg) no-repeat center center;
	background-size: cover;
}

.intro04 {
	padding: 60px 0 0;
}

.intro04 .cont {
	width: 1100px;
	margin: 0 auto;
}

.intro04 .cont .ryouiki {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}

.intro04 .cont .ryouiki div {
	width: 320px;
	margin: 0 0 50px;
}

.intro04 .cont .ryouiki div a {
	display: block;
	color: #000;
	text-decoration: none;
}

#second .intro04 .cont .ryouiki div h3 {
	margin: 10px 0;
	padding: 2px 0 0;
	font-size: 22px;
	line-height: 36px;
	background: url(../image/arrow-03.png) transparent no-repeat 100% 0;
	letter-spacing: 0.06em;
}

.fieldMenu {
	padding: 20px 0 60px;
}

.fieldMenu dt {
 position: relative;
	background-color: #E3EDE2;
	padding: 20px;
	text-align: center;
	border-radius: 20px;
	font-weight: bold;
	margin: 0 0 30px;
}

.fieldMenu dt:after {
 position: absolute;
 bottom: -9px;
 left: calc( 50% - 20px);
 width: 0;
 height: 0;
 content: '';
 border-width: 20px 20px 0 20px;
 border-style: solid;
 border-color: #E3EDE2 transparent transparent transparent;
}

.fieldMenu dd ul {
	margin: 0 20px;
	padding: 0;
	list-style: none;
	display: flex;
	justify-content: space-between;
}

.fieldMenu dd ul li {
	margin: 0;
	padding: 0;
}

.fieldMenu dd ul li a {
	display: block;
	width: 160px;
	padding: 8px 0;
	text-align: center;
	border: 1px solid #CCC;
	box-shadow: 3px 3px 0 #E3EDE2;
	text-decoration: none;
	color: #000;
}

.fieldMenu dd ul li a:hover {
	background-color: #659960;
	color: #FFF;
}


/*------------------------------------------------------------------------------------------------
  laboratories
--------------------------------------------------------------------------------------------------*/
.labMenu {
	margin: 0 0 60px;
	padding: 0;
	list-style: none;
	display: flex;
	justify-content: space-between;
	position: relative;
}

.labMenu:before {
	position: absolute;
	top: 50%;
	left: 0;
	width: 100%;
	height: 4px;
	background-color: #E5F0F8;
	content: "";
	z-index: -1;
}

.labMenu li {
	margin: 0;
	padding: 0;
}

.labMenu li a {
	display: block;
	width: 160px;
	text-align: center;
	text-decoration: none;
	color: #000;
	border: 2px solid #142382;
	border-radius: 20px;
	padding: 6px 0;
	background-color: #FFF;
}

.labMenu li a:hover {
	background-color: #142382;
	color: #FFF;
}

.labBox {
	margin: 0 0 40px;
	display: flex;
	justify-content: center;
}

.labBox .inner {
	width: 44%;
	margin: 0 3% 30px;
}

.wideWrap .labBox {
	width: 1100px;
	margin: 0 auto;
}

.labBox .image img {
	max-width: 100%;
	height: auto;
	border: 1px solid #CCC;
}

.labBox .image img:hover {
    opacity: 0.8;
	border: 1px solid #0068B7;
}

.labBox .text {
}

.labBox .text h3 {
	position: relative;
	top: -20px;
	left: -20px;
	font-size: 20px;
	margin: 0 40px 0 0 !important;
	padding: 6px 8px !important;
	background: linear-gradient(to right, #0068B7 20%, #142382 80%);
	color: #FFF;
}

.labBox .text dl {
	display: flex;
	justify-content: flex-end;
	font-size: 20px;
}

.labBox .text dl dt {
	margin: 0 30px 0 0;
}

.labDetailBox {
	
}

.labDetailBox .lead {
	position: relative;
	width: 80%;
	margin: 0 auto 40px;
	padding: 40px;
	border: 3px solid #EEE;
}

.labDetailBox .lead p {
	margin: 0 !important;
}

.labDetailBox .lead::before,
.labDetailBox .lead::after {
	position: absolute;
	content: "";
	width: 40px;
	height: 40px;
}

.labDetailBox .lead::before {
	top: -3px;
	left: -3px;
	border-top: 3px solid #0068B7;
	border-left: 3px solid #142382;
}

.labDetailBox .lead::after {
	bottom: -3px;
	right: -3px;
	border-bottom: 3px solid #0068B7;
	border-right: 3px solid #142382;
}

.labDetailBox .info {
	display: flex;
	justify-content: space-between;
	width: 80%;
	margin: 0 auto 40px;
}

.labDetailBox .info .text {
	width: 540px;
}

.labDetailBox .info .text .position {
	margin: 0 !important;
	font-weight: bold;
	font-size: 18px;
}

#second .labDetailBox .info .text h3 {
	background-color: transparent;
	padding: 0;
	margin: 0 0 20px;
	font-size: 28px;
	line-height: 1.4;
	font-weight: bold;
	border-bottom: none;
}

#second .labDetailBox .info .text h3 span {
	font-size: 20px;
	font-weight: normal;
	margin-left: 20px;
}

#second .labDetailBox .info dl {
	margin: 0 0 20px;
}

#second .labDetailBox .info dl dt {
	font-weight: bold;
}

#second .labDetailBox .info dl dd {
	border-bottom: 1px dotted #CCC;
	margin: 0 0 8px;
	padding: 0 8px 4px;
}

.labDetailBox .info .photo {
	width: 300px;
	position: relative;
	text-align: right;
}

.labDetailBox .info .photo img {
	max-width: 100%;
	height: auto;
}

/*.labDetailBox .info .photo:before {
	position: absolute;
	width: 60px;
	height: 60px;
	right: -30px;
	top: -10px;
	background-color: #CCE1FF;
	content: "";
	z-index: -1;
	transform: rotate(-45deg);
}*/

.labDetailBox .detail p {
	margin-bottom: 60px !important;
}

.labDetailBox .detail ul {
	margin-bottom: 60px;
}

.labDetailBox .detail ul li {
	margin-bottom: 16px;
}

.movieWrap {
	width: 640px;
	margin: 0 auto 60px;
}

.youtube {
 position: relative;
 width: 100%;
 height: 0;
 padding-bottom: 56.25%;
 overflow: hidden;
}

.youtube iframe {
 width: 100%;
 height: 100%;
 position: absolute;
 top: 0;
 left: 0;
}

.poster {
	margin: 0 auto 60px;
	text-align: center;
}

.poster img {
	max-width: 80%;
	height: auto;
}



/*------------------------------------------------------------------------------------------------
  course
--------------------------------------------------------------------------------------------------*/
.courseList {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	padding: 20px 0;
}

.courseList div.box {
	width: 46%;
	position: relative;
	margin: 0 0 40px;
}

.courseList div.box:before {
	position: absolute;
	font-family: Arial, Helvetica, sans-serif;
	font-weight: bold;
	font-size: 38px;
	color: #EEE;
	right: 0;
	top: -2px;
}

.courseList div.box:nth-child(1):before {
	content: "example 01";
}

.courseList div.box:nth-child(2):before {
	content: "example 02";
}

.courseList div.box:nth-child(3):before {
	content: "example 03";
}

.courseList div.box:nth-child(4):before {
	content: "example 04";
}

.courseList div.box p.kind {
	margin: 0 0 10px !important;
	font-size: 24px;
	font-weight: bold;
	color: #142382;
	position: relative;
	border-bottom: 4px solid #EEE;
}

.courseList div.box p.kind:before {
	position: absolute;
	bottom: -4px;
	left: 0;
	width: 80px;
	height: 4px;
	background-color: #0068B7;
	content: "";
}

.courseList div.text {
	display: flex;
	align-items: center;
}

.courseList div.text p {
	margin: 0 20px 0 0 !important;
}

.courseHistory {
    margin: 0 20px 40px;
    padding: 0;
    list-style:none;
    display: flex;
    flex-wrap: wrap;
}

.courseHistory li {
    width: 32%;
    margin: 0 0 10px;
    padding: 8px;
    background-color: #DDF0FF;
}

.courseHistory li:nth-child(3n-1) {
    margin: 0 2% 10px;
}



/*------------------------------------------------------------------------------------------------
  examinee
--------------------------------------------------------------------------------------------------*/
.year2022 {
	margin: 20px 0 60px;
	padding: 20px 20px 10px;
	background-color: #FBEAEB;
}

#second .year2022 h2 {
	position: relative;
	top: -40px;
	text-align: left;
	display: inline-block;
	margin: 0 0 -40px;
}

#second .year2022 h2:before {
	width: 100%;
	background-color: #DE5057;
	left: 0;
}

#second .year2022 .atten {
	color: #666;
	font-size: 15px;
}

.examList {
	margin-bottom: 60px;
}

.examList li {
	margin: 0 0 12px;
}

.life {
	display: flex;
	position: relative;
	z-index: 2;
	padding: 0 0 40px;
}

.life:before {
	position: absolute;
	content: "";
	width: 8px;
	height: 100%;
	z-index: -1;
	top: 0;
	left: 110px;
	background-color: #659960;
}

.life:last-child:before {
	display: none;
}

.life:last-child {
	margin: 0 0 -60px;
	padding: 0;
}

.life .title {
	margin: 0 40px 0 0;
	width: 240px;
}

.life .title p {
	color: #FFF;
	background-color: #659960;
	padding: 8px;
	text-align: center;
	border-radius: 20px;
	font-size: 18px;
	font-weight: 500;
	letter-spacing: 0.05em;
}

.life .detail {
	width: calc( 100% - 240px);
	padding: 8px 0;
}

.life .detail img.single {
    width: 320px;
    height: auto;
}

.life .detail ul.lifePhoto {
    margin: 0;
    padding: 0;
    list-style: none;
    display: flex;
    justify-content: start;
}

.life .detail ul.lifePhoto li {
    margin: 0 10px 20px;
    padding: 0;
    list-style: none;
    position: relative;
}

.life .detail ul.lifePhoto li:before {
    position: absolute;
    background-color: #DE5057;
    color: #FFF;
    width: 80px;
    height: 80px;
    line-height: 80px;
    border-radius: 100%;
    text-align: center;
    top: -20px;
    left: -10px;
    transform: rotate(-10deg);
}

.life .detail ul.lifePhoto li img {
    width: 320px;
    height: auto;
}

.life .detail ul.lifePhoto li.lp01:before {
    content: "たんぽぽ";
}

.life .detail ul.lifePhoto li.lp02:before {
    content: "コンビニ";
}

.life .detail ul.lifePhoto2 {
    margin: 0;
    padding: 0;
    list-style: none;
    display: flex;
    flex-wrap: wrap;
    justify-content: start;
}

.life .detail ul.lifePhoto2 li {
    width: 320px;
    margin: 0 10px 20px;
}


.life .detail ul.lifePhoto2 li img {
    max-width: 100%;
    height: auto;
}

.pageMenu {
    margin: 0 0 80px;
    padding: 0;
    list-style: none;
    display: flex;
    justify-content: center;
}

.pageMenu li {
    margin: 0 10px;
    padding: 0;
    position: relative;
}

.pageMenu li a {
    display: block;
    width: 240px;
    padding: 6px;
    border: 2px solid #142382;
    border-radius: 20px;
    text-align: center;
    text-decoration: none;
    color: #000;
}

.pageMenu li a:hover {
    color: #FFF;
    background-color: #142382;
}

.pageMenu li:nth-child(3):before {
    position: absolute;
    top: -30px;
    right: -20px;
    content: "Check!";
    width: 60px;
    height: 60px;
    border-radius: 100%;
    background-color: #B80068;
    transform: rotate(15deg);
    color: #FFF;
    font-weight: 700;
    line-height: 60px;
    text-align: center;
}

.torikumiWrap {
    background-color: #FCFCC5;
    padding: 40px 20px 20px;
    border-radius: 20px;
}

.torikumi {
    background-color: #FFF;
    margin: 0 0 40px;
    padding: 20px;
    position: relative;
}

.torikumi:before {
    position: absolute;
    width: 94px;
    height: 30px;
    background: url(../image/arrow-08.png);
    content: "";
    bottom: -30px;
    left: calc( 50% - 47px);
}

.torikumi:nth-child(5):before {
    display: none;
}

#second .torikumi h3 {
    font-weight: 500;
    position: relative;
}

#second .torikumi h3 span {
    display: inline-block;
    background-color: #0068B7;
    color: #FFF;
    padding: 4px 10px;
    margin-left: 20px;
    border-radius: 12px;
}

#second .torikumi h3:before {
    position: absolute;
    right: 0;
    top: -50px;
    font-size: 60px;
    font-family: Arial;
    font-weight: bold;
    color: #DDD;
    font-style: italic;
}

#second .torikumi:nth-child(1) h3:before {
    content: "Efforts01";
}

#second .torikumi:nth-child(2) h3:before {
    content: "Efforts02";
}

#second .torikumi:nth-child(3) h3:before {
    content: "Efforts03";
}

#second .torikumi:nth-child(4) h3:before {
    content: "Efforts04";
}

#second .torikumi:nth-child(5) h3:before {
    content: "Efforts05";
}

#second .torikumi p.lead {
    color: #0068B7;
    font-size: 18px;
    font-weight: bold;
    margin-left: 12px;
}

#second .torikumi ul li {
    margin: 0 0 16px;
}

#second .torikumi img {
    width: 290px;
    height: auto;
    box-shadow: 6px 6px 0 #CAE0FF;
}

/*------------------------------------------------------------------------------------------------
  news
--------------------------------------------------------------------------------------------------*/
.newsDetail {
	margin: 0 20px 40px;
}

.newsDetail p.date {
	position: relative;
	display: inline-block;
	color: #FFF;
	line-height: 28px;
	padding: 0 10px;
}

.newsDetail p.date:before {
	position: absolute;
	content: "";
	width: 100%;
	height: 100%;
	background: linear-gradient(to right, #142382 20%, #0068B7 80%);
	z-index: -1;
	top: 0;
	left: 0;
}

#second .newsDetail h2 {
	text-align: left;
	font-size: 20px;
	padding: 8px 0;
}

#second .newsDetail h2:before {
	top: -20px;
	left: 20px;
	width: 4px;
	height: 24px;
}


/*------------------------------------------------------------------------------------------------
  qualification
--------------------------------------------------------------------------------------------------*/
.qualification01 {
    margin-bottom: 40px;
}

.qualification01 dt {
	display: inline-block;
	color: #FFF;
	padding: 8px;
	font-size: 20px;
	font-weight: bold;
	letter-spacing: 0.05em;
	background-color: #0068B7;
}

.qualification01 dd {
	position: relative;
	top: -20px;
	border: 1px solid #0068B7;
	padding: 50px 40px 10px;
	z-index: -1;
}

.qualification02 {
    display: flex;
    flex-wrap: wrap;
}

.qualification02 dt {
    width: 22%;
    margin: 0 0 20px;
    padding: 8px 20px;
    background-color: #D0EBFF;
}

.qualification02 dd {
    width: 78%;
    margin: 0 0 20px;
    border-bottom: 1px dotted #CCC;
    padding: 8px 20px;
    background-color: #FFF;
}

/*------------------------------------------------------------------------------------------------
  curriculum
--------------------------------------------------------------------------------------------------*/
.curriculumTb {
	width: 100%;
	margin: 0 0 40px;
}

.curriculumTb thead th {
	border: 1px solid #CCC;
	border-bottom: 2px solid #CCC;
	padding: 10px;
	background-color: #0068B7;
	color: #FFF;
}

.curriculumTb tbody th {
	padding: 10px;	
	border: 1px solid #CCC;
	background-color: #E3EDE2;
	vertical-align: top;
}

.curriculumTb tbody td {
	padding: 10px;	
	border: 1px solid #CCC;
	vertical-align: top;
}

.sentaku {
	text-align: right;
}

.colorBlue {
	color: #0068B7;
}

.colorRed {
	color: #F00;
}

.curriH3 {
	background-color: #FFF !important;
	font-weight: 500;
	color: #0068B7;
}

.modelTb {
	width: 100%;
	line-height: 2;
	margin: 0 0 20px;
}

.modelTb th {
	border: 1px solid #CCC;
	border-bottom: 2px solid #CCC;
	padding: 10px;
	background-color: #0068B7;
	color: #FFF;
	width: 20%;
}

.modelTb th:nth-of-type(2n) {
	width: 5%;
}

.modelTb td {
	padding: 10px;
	background-color: #FFF;
	border-bottom: 1px solid #CCC;
	vertical-align: top;
	font-size: 15px;
}

.modelTb td:nth-of-type(2n) {
	text-align: right;
	border-left: 1px dashed #CCC;
	border-right: 1px solid #CCC;
}

.modelTb td:nth-of-type(3),
.modelTb td:nth-of-type(4),
.modelTb td:nth-of-type(7),
.modelTb td:nth-of-type(8) {
	background-color: #F3F2F1;
}


.modelTb2 {
	width: 100%;
	line-height: 2;
	margin: 0 0 60px;
}

.modelTb2 thead th {
	border: 1px solid #CCC;
	border-bottom: 2px solid #CCC;
	padding: 10px;
	background-color: #0068B7;
	color: #FFF;
	width: 20%;
}

.modelTb2 th:nth-of-type(1) {
	width: 80px;
}

.modelTb2 tbody th {
 -ms-writing-mode: tb-rl;
 writing-mode: vertical-rl;
	background-color: #E3EDE2;
	text-align: left;
	padding: 10px 4px;
	border-bottom: 1px solid #CCC;
}

.modelTb2 td {
	padding: 10px;
	background-color: #FFF;
	border-bottom: 1px solid #CCC;
	vertical-align: top;
	font-size: 15px;
}

.modelTb2 th:nth-of-type(3),
.modelTb2 th:nth-of-type(5),
.modelTb2 th:nth-of-type(7),
.modelTb2 th:nth-of-type(9) {
	width: 5%;
}

.modelTb2 td:nth-of-type(2n) {
	text-align: right;
	border-left: 1px dashed #CCC;
	border-right: 1px solid #CCC;
}

.modelTb2 td:nth-of-type(3),
.modelTb2 td:nth-of-type(4),
.modelTb2 td:nth-of-type(7),
.modelTb2 td:nth-of-type(8)	{
 background-color: #F3F2F1;
}


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

/*------------------------------------------------------------------------------------------------
  index
--------------------------------------------------------------------------------------------------*/
.indexHeader .lead {
 position: absolute;
 top: 60%;
 left: 0%;
 transform: translateY(-60%);
 -webkit-transform: translateY(-60%);
 -ms-transform: translateY(-60%);
	margin-left: 20px;
}

.indexHeader .lead img {
	width: 290px;
	height: 115px;
}

#indexAbout {
	background-image: url(../image/index-01.png), url(../image/index-02.png);
	background-repeat: no-repeat;
	background-position: 0 100%, 100% 0;
	background-size: 20%;
	font-feature-settings: 'palt' 1;
	-webkit-font-feature-settings: 'palt' 1;
}

#indexAbout .cont {
	width: 90%;
	margin: 0 auto;
	padding: 60px 0 70px;
}

#indexAbout .cont h2 {
	font-size: 24px;
}

#indexAbout .cont p {
	text-align: left;
	line-height: 1.8;
	text-shadow: #FFF 1px 1px 2px, #FFF -1px 1px 2px, #FFF 1px -1px 2px, #FFF -1px -1px 2px;
}

#indexIntroduction:before {
	height: 260px;
}

#indexIntroduction:after {
    width: 100%;
    left: 0;
}

#indexIntroduction .cont {
	width: 90%;
	padding: 60px 0;
}

#indexIntroduction .cont h2 {
	font-size: 24px;
}

#indexIntroduction .cont p.lead {
	font-size: 20px;
}

#indexIntroduction .cont .ryouiki div {
	width: 48%;
}

#indexIntroduction .cont .ryouiki div h3 {
	font-size: 20px;
	background-size: 18px;
	background-position: 100% center;
	font-weight: bold;
}

#indexMenu:before {
	height: 200px;
}

#indexMenu .cont {
	width: 90%;
	padding: 0 0 30px;
}

#indexMenu .cont h2 {
	font-size: 30px;
	margin: 0 0 10px;
	padding: 10px 0 0;
}

#indexMenu .cont ul li {
	margin: 0 0 20px;
}

#indexMenu .cont h2 span {
	display: block;
	margin: -8px 0 0;
}

#indexExaminee {
	height: 160px;
	margin: 0 0 60px;
}

#indexExaminee .cont {
	width: 100%;
	background-size: 273px;
	background-position: 100% 100%
}

#indexExaminee .cont a {
	height: 160px;
	background-size: 30px;
}

#indexExaminee .cont p {
	font-size: 30px;
	padding: 50px 0 0 20px;
	font-weight: bold;
}

#indexMovie:before {
    width: 100%;
}
    
#indexMovie .cont h2 {
	width: 80%;
}

#indexMovie .cont p {
	width: 80%;
	font-size: 16px;
}

.slide-movie {
	width: 86%;
}

.slick-prev, .slick-next {
	display: none !important;
}

.slick-dots li button:before {
	font-size: 50px !important;
	color: #FFF !important;
}

.slick-dots {
	bottom: -40px !important;
}

.slick-dots li {
	margin: 0 10px !important;
}

#indexNews .cont {
	width: 90%;
}

#indexNews .cont h2 {
	font-size: 30px;
}

#indexNews .cont h2 span {
	font-size: 18px;
}

.newsList li a {
	display: block;
	padding: 28px 20px 22px;
}

.newsList li a .text {
	width: 100%;
}


/*------------------------------------------------------------------------------------------------
  news
--------------------------------------------------------------------------------------------------*/
.newsDetail {
	margin: 0 0 40px;
}

#second .newsDetail h2 {
	line-height: 1.4;
}

/*------------------------------------------------------------------------------------------------
  introduction
--------------------------------------------------------------------------------------------------*/
.intro01 .cont .lead {
	font-size: 24px;
	line-height: 1.4;
}

.intro01 {
	background-image: none;
}

.intro01 p {
	line-height: 1.6;
}

.intro02 .cont {
	padding-top: 40px !important;
	text-align: left;
}

.intro02 .cont .lead {
	margin-bottom: 20px !important;
	font-size: 24px;
	line-height: 1.4;
}

.intro02 .cont p {
	margin-bottom: 0 !important;
}

.intro03 {
	background-size: contain;
	padding: 80px 0;
	margin: -40px 0;
}

.intro04 .cont .ryouiki div {
	width: 46%;
}

#second .intro04 .cont .ryouiki div h3 {
	background-size: 18px;
	background-position: 100% 50%;
}

#second .intro04 .cont {
	padding-bottom: 0;
}

.fieldMenu dt {
	padding: 10px 20px;
}

.fieldMenu dd ul {
	flex-wrap: wrap;
}

.fieldMenu dd ul li {
	width: 46%;
	margin-bottom: 20px;
}

.fieldMenu dd ul li a {
	width: 100%;
}

/*------------------------------------------------------------------------------------------------
  curriculum
--------------------------------------------------------------------------------------------------*/
.modelTb td, .modelTb2 td {
	font-size: 13px;
}


/*------------------------------------------------------------------------------------------------
  laboratories
--------------------------------------------------------------------------------------------------*/
.labMenu {
	flex-wrap: wrap;
}

.labMenu:before {
	display: none;
}

.labMenu li {
	width: 48%;
	margin: 0 0 20px;
}

.labMenu li a {
	width: 100%;
	padding: 12px 6px;
	border-radius: 30px;
}

.labBox {
	display: block;
}

.labBox .inner {
	width: 80%;
	margin: 0 auto 30px;
}

#second h3 {
	padding: 6px 10px;
}

.labBox .text dl {
	margin: 0;
}

.wideWrap .labBox {
	width: 90%;
	margin: 0 auto;
}

.labDetailBox .lead {
	width: 100%;
}

.labDetailBox .info {
	width: 100%;
	flex-wrap: wrap;
}

.labDetailBox .info .photo {
	width: 70%;
	margin: 0 auto 20px;
	order: 1;
	text-align: center;
}

.labDetailBox .info .text {
	width: 100%;
	order: 2;
}

#second .labDetailBox .info .text h3 span {
	display: block;
	margin: 0;
}

.labDetailBox .detail p {
	margin-bottom: 40px !important;
}

.labDetailBox .detail ul {
 padding: 0 0 0 24px;
}

.movieWrap {
	width: 100%;
	margin: 0 0 40px;
}

.poster img {
	max-width: 100%;
}

/*------------------------------------------------------------------------------------------------
  course
--------------------------------------------------------------------------------------------------*/
.courseList {
	display: block;
}

.courseList div.box {
	width: 100%;
}

.courseList div.text div:nth-of-type(1) {
	width: calc( 100% - 80px);
}

.courseList div.text div:nth-of-type(2) {
	width: 62px;
}

.courseHistory {
    margin: 0 10px 40px;
    padding: 0;
    list-style:none;
    display: block;
}

.courseHistory li {
    width: 100%;
    margin: 0 0 10px;
    padding: 8px;
    background-color: #DDF0FF;
}

.courseHistory li:nth-child(3n-1) {
    margin: 0 0 10px;
}



/*------------------------------------------------------------------------------------------------
  examinee
--------------------------------------------------------------------------------------------------*/
#second .year2022 h2 {
	font-size: 20px;
}

.life {
	display: block;
	padding: 0;
}

.life .title {
	width: 100%;
	font-size: 18px;
	font-weight: bold;
}

.life:before {
	left: 40px;
}

.life .detail {
	width: calc( 100% - 80px);
	margin-left: 80px;
}

.life:last-child:before {
	display: block;
}

.pageMenu {
    margin: 0 0 60px;
    padding: 0;
    list-style: none;
    display: block;
    justify-content: unset;
}

.pageMenu li {
    margin: 0 10px 40px;
    padding: 0;
    position: relative;
}

.pageMenu li a {
    display: block;
    width: 100%;
    padding: 12px 6px;
    border: 2px solid #142382;
    border-radius: 30px;
    text-align: center;
    text-decoration: none;
    color: #000;
}

.pageMenu li a:hover {
    color: #FFF;
    background-color: #142382;
}

.pageMenu li:nth-child(3):before {
    position: absolute;
    top: calc( 50% - 30px);
    right: 10px;
    content: "Check!";
    width: 60px;
    height: 60px;
    border-radius: 100%;
    background-color: #B80068;
    transform: rotate(15deg);
    color: #FFF;
    font-weight: 700;
    line-height: 60px;
    text-align: center;
}

#second .torikumi h3 span {
    padding: 0 10px;
}

#second .torikumi h3:before {
    font-size: 30px;
    right: -40px;
    top: -40px;
}

.life .detail img.single {
    max-width: 100%;
    height: auto;
}

.life .detail ul.lifePhoto {
    display: block;
}

.life .detail ul.lifePhoto li {
    margin: 0 0 30px;
}
    
.life .detail ul.lifePhoto li img {
    max-width: 100%;
    height: auto;
}

.life .detail ul.lifePhoto2 {
    margin: 0;
    padding: 0;
    list-style: none;
    display: block;
    flex-wrap: wrap;
    justify-content: start;
}

.life .detail ul.lifePhoto2 li {
    width: 100%;
    margin: 0 0 20px;
}


.life .detail ul.lifePhoto2 li img {
    max-width: 100%;
    height: auto;
}


/*------------------------------------------------------------------------------------------------
  qualification
--------------------------------------------------------------------------------------------------*/

.qualification02 {
    margin-bottom: 40px;
    display: block;
    flex-wrap: wrap;
}

.qualification02 dt {
    width: 100%;
    margin: 0;
    padding: 8px 10px;
    background-color: #D0EBFF;
}

.qualification02 dd {
    width: 100%;
    margin: 0 0 20px;
    border-bottom: 1px dotted #CCC;
    padding: 8px 10px;
}

}
