@charset "utf-8";

/*  +++++++++++++++++++++++++ common +++++++++++++++++++++++++ */

body,
html {
  min-width: 100% !important;
}

body {
  word-wrap: break-word;
}

.entry-content pre {
  overflow: scroll;
  word-wrap: normal;
}

input,
textarea,
select {
  font-size: 16px;
}

.pc {
  display: none !important;
}

.sp {
  display: block !important;
}

.pctL,
.pctR {
  float: none;
  margin-left: 0;
  margin-right: 0;
  text-align: center;
}

.pctL.no {
  float: left;
  margin-bottom: 15px;
  margin-right: 15px;
  text-align: left;
}

.pctR.no {
  float: right;
  margin-bottom: 15px;
  margin-left: 15px;
  text-align: left;
}

img {
  max-width: 100%;
}

.wide {
  height: auto;
  width: 100% !important;
}


.w30 {
  margin: auto;
  width: 30%!important;
}
.w40 {
  margin: auto;
  width: 40%!important;
}

.w50 {
  margin: auto;
  width: 50%!important;
}

.w60 {
  margin: auto;
  width: 60%!important;
}

.w70 {
  margin: auto;
  width: 70%!important;
}

.w80 {
  margin: auto;
  width: 80%!important;
}

.w90 {
  margin: auto;
  width: 90%!important;
}

/*------------------------------------*\
$header
\*------------------------------------*/

header {
  position: relative;
  width: 100%;
}

header h1 {
  padding: 20px;
  text-align: left;
}

/*------------------------------------*\
$main
\*------------------------------------*/
#main {
  margin: 0 auto;
  position: relative;
  width: 100%;
}

#mainTitle.open > .inner{
	padding:0}
	
	#co.full #mainContents #intro{
		width:auto;
background-size: auto auto;
background-color: rgba(228, 255, 229, 1);
background-image: repeating-linear-gradient(135deg, transparent, transparent 10px, rgba(205, 255, 223, 1) 10px, rgba(205, 255, 223, 1) 20px );
}

#intro h2{
	font-size:8vw;}
	#intro h2 span{
		font-size:4vw;}
	#co.full #mainContents #intro .coInner{
		background:transparent;
		width:auto;
		margin:0 1em}
#main video {
  width: 100%;
}

#main h2 {
  left: 50%;
  margin: auto;
  position: absolute;
  top: 5%;
  transform: translateY(0%) translateX(-50%);
  width: 50%;
}

#main p {
  bottom: 5%;
  left: 50%;
  position: absolute;
  top: auto;
  transform: translateY(0%) translateX(-50%);
  width: 50%;
}

#co #mainContents.campusPage .intro .btn-entry a{
	padding: .4em 0;
	width:90%;
	font-size:8vw;
}

/*------------------------------------*\
$Co
\*------------------------------------*/
#Co {
  padding: 0;
  text-align: left;
}

#Co h2 {
  margin-bottom: 30px;
}

/*------------------------------------*\
$firstBox
\*------------------------------------*/

#firstBox {
  box-sizing: border-box;
  margin: 0 auto;
  padding: 0 10px;
  text-align: left;
  width: 100%;
}

#firstBoxInner {
  background: #ffffff;
  box-sizing: border-box;
  margin: 0 auto;
  padding: 30px 10px;
  position: relative;
  text-align: left;
  width: 100%;
  z-index: 100;
}

#firstBox h3 {
  margin: 0 0 30px 0;
}

#firstBox h4 {
  margin: 0 0 30px 0;
}

#firstBox h5 {
  margin: 0 auto 30px auto;
  text-align: center;
}

#firstBox .box05 {
  justify-content: center;
}

#firstBox .box05 li {
  margin: 0 2.7% 15px 0;
		padding:10px;
  width: 31.5%;
}

#firstBox .box05 li:nth-child(3n) {
  margin: 0 0 15px 0;
  width: 31.5%;
}


/*------------------------------------*\
$sectionInner
\*------------------------------------*/

.sectionInner {
  box-sizing: border-box;
  padding: 30px 10px;
  width: 100%;
}

.sectionInner .box02,
#footermovie .box02 {
  margin: 0 auto 0 auto;
  width: 100%;
}
.sectionInner .box02{
	display:block}
	
.sectionInner h3.catch,
#footer-open h3 {
  font-size: 4vw;
  margin: 0 auto 30px auto;
  padding: 0 40px;
}

.sectionInner h3.catch:before,
#footer-open h3:before {
  width: 50px;
}

.sectionInner h3.catch:after,
#footer-open h3:after {
  width: 50px;
}

.sectionInner .box02 h4 {
  font-size: 1.8rem;
  line-height: 140%;
  margin-bottom: 20px;
}


.box03 .box03Inner,
.box03 li,
.box04 .box04Inner,
.box04 li,
.box05 .box05Inner,
.box05 li {
  display: block;
  margin-bottom: 10px;
  width: 48.5%;
}

.sectionInner .submenu {
  margin-top: 100px;
  position: relative;
}

.sectionInner .submenu .box03,
.sectionInner .submenu .box04 {
  margin: 0 auto;
  width: 100%;
}

.sectionInner .submenu .box03 li,
.sectionInner .submenu .box04 li {
  margin: 0;
  width: 50%;
}

.sectionInner .submenu .hukidashi {
  left: -10px;
  position: absolute;
  top: -80px;
  width: 28%;
  z-index: 100;
}

#sideMunu {
  bottom: 0 !important;
  position: fixed;
  top: auto;
}

#sideMunu ul {
  background-color: rgba(255,255,255,.7);
  box-sizing: border-box;
  display: flex;
  padding: 10px;
  width: 100%;
  z-index: 200;
}

#sideMunu li {
  margin: 0;
}

#sideMunu li:last-child {
  margin: 0 0 0 10px !important;
}
/**/
.open-top .box02 .box02Inner.chapterBox h5{
	font-size:5vw}

/*------------------------------------*\
$section01
\*------------------------------------*/

#footer-open,
#section01{
	opacity:1!important}
#section01 .box02 .box02Inner ul li {
  font-size: 1.2rem;
  padding: 5px 15px;
  width: 100%;
}

#section01 .box02 .box02Inner:first-child ul li:first-child {
  margin-bottom: 10px;
  margin-right: 0;
  width: 100%;
}

#section01 .box02 .box02Inner:first-child ul li:last-child {
  margin-bottom: 0;
  margin-right: 0;
  width: 100%;
}

#section01 .box02 {
  display: block;
}

#section01 .box02 .box02Inner {
  width: 86%;
		padding: 0 0 1.6em;
		margin:auto;
}
.sectionInner .box02 h4{
	font-size:6vw;
	margin: -1.8em 0 .6em;}

#section01 .box02 .box02Inner.chapterBox h5 {
  font-size: 1.8rem;
}

#section01 .box02 .box02Inner.chapterBox p {
  font-size: 1.4rem;
  margin-bottom: 10px;
}


#section01 .box02 .box02Inner .chapter {
  margin-bottom: 15px;
}

#section01 .box02 .box02Inner .chapter li {
  margin-bottom: 12px;
  padding: 0;
}

#section01 .box02 .box02Inner .chapter li a {
  font-size: 1.4rem;
}


#section01 .box02 .box02Inner.chapterBox .point li {
  float: left;
  font-size: 1.4rem;
  line-height: 1.6;
  margin: 0 8px 8px 0;
  padding: 0;
  width: auto;
}

#section01 .box02 .box02Inner.chapterBox .point li:last-child {
  margin-right: 0;
}

.open-top .box02 .box02Inner .chapter li a{
	font-size:3.4vw}



/**/
#section02 .box02 .box02Inner li{
	font-size:4.4vw}
#section02 .box02 .box02Inner{
	padding: 1em;
	background:url(web-opencampus/images/bg_hukidashi_01.png) no-repeat center bottom / 90% 90%;
	width:100%}
	.sectionInner ul.box02{
		display:flex;
		justify-content:space-between;}
		
		
	.sectionInner ul.box02 li{
		width:48.6%}
		
/*------------------------------------*\
$section03
\*------------------------------------*/
#section03 .viewBox {
  margin-top: 30px;
}

#section03 .viewBox_sp .viewBox.last  li img {
  margin-bottom: 10px;
}

#section03 .viewBox_sp .viewBox li {
  font-size: 1.4rem;
  font-weight: 900;
  text-align: center;
}

#section03 .viewBox_sp .viewBox li:last-child {
  margin: 0 auto;
}

#section03 .viewBox_sp .viewBox li a {
  color: #0076ac;
}

#section03 .submenu {
  position: relative;
}
#section03 .submenu .hukidashi{
	top:-60px;
	left:30%;
}

#section03 .note {
  font-size: 1.2rem;
  margin-bottom: 20px;
  padding: 0 10px;
}
/**/
.box05 li{
	padding: 0}

/*------------------------------------*\
$section04
\*------------------------------------*/
#section04 h3 {
  margin-bottom: 50px;
}

#section04 .box02 {
  display: block;
}

#section04 .box02 .box02Inner .box02 {
  display: flex;
  flex-wrap: wrap;
  -webkit-justify-content: space-between;
          justify-content: space-between;
  width: 100%;
}

#section04 .box02 .box02Inner {
  width: 100%;
}

#section04 .box02 .box02Inner:first-child {
  margin-bottom: 100px;
}

#section04 .box02 .box02Inner h3 {
  margin: 0 auto 20px auto;
  width: 35%;
}

#section04 .box02 .box02Inner:after {
  background: url(web-opencampus/images/bg_hukidashi_01.png) no-repeat 0 60px;
  background-size: auto;
  background-size: contain;
  content: "";
  display: inline-block;
  height: 390px;
  left: 50%;
  margin: auto;
  position: absolute;
  top: 50%;
  transform: translateY(-50%) translateX(-50%);
  vertical-align: middle;
  width: 100%;
  z-index: -1;
}
#section04 .box02 .box02Inner:last-child:after {
  background: url(web-opencampus/images/bg_hukidashi_02.png) no-repeat 0 60px;
  background-size: auto;
  background-size: contain;
  content: "";
  display: inline-block;
  height: 390px;
  left: 50%;
  margin: auto;
  position: absolute;
  top: 50%;
  transform: translateY(-50%) translateX(-50%);
  vertical-align: middle;
  width: 100%;
  z-index: -1;
}


/*------------------------------------*\
$section05
\*------------------------------------*/

#section05 .submenu .hukidashi {
  left: -10px;
  position: absolute;
  top: -70px;
  width: 28%;
  z-index: 100;
}

#section05 .box02 .box02Inner {
  margin-bottom: 10px;
}

#section05 .submenu .box05 li {
  margin-bottom: 0;
}


/*------------------------------------*\
$footer
\*------------------------------------*/

#footermovie #footermovieInner {
  background-position: 1% 1%, 99% 1%, 1% 99%, 99% 99%;
  background-repeat: no-repeat;
  background-size: 6px 6px;
  box-sizing: border-box;
  padding: 30px 10px 20px 10px;
  width: 100%;
}

#footermovie #footermovieInner .title {
  font-size: 2em;
  font-weight: 900;
  padding-top: 0;
  text-align: center;
}

#footermovie #footermovieInner .box02 {
  display: block;
}

#footermovie #footermovieInner .box02 .box02Inner {
  width: 100%;
}

#footermovie #footermovieInner .box02 .box02Inner:first-child {
  margin-bottom: 20px;
}

#footersocial {
  box-sizing: border-box;
  padding: 30px 10px;
}

.footersocialInner {
  width: 100%;
}

#footer-open h3 {
  font-size: 3.4vw;
  margin-bottom: 20px;
}

#footer-open #footersocial .footersocialInner span {
  display: none;
}

#footer-open #footersocial .footersocialInner #line {
  font-size: 5vw;
  font-weight: 900;
  text-align: center;
}

#footer-open #footersocial .footersocialInner #line .ss {
  font-size: 1.6rem;
}

#footer-open #footersocial .footersocialInner #line:before {
  background-image: url(web-opencampus/images/ico_line.png);
  background-size: contain;
  content: "";/*何も入れない*/
  display: inline-block;/*忘れずに！*/
  height: 30px;/*画像の高さ*/
  margin-right: 10px;
  vertical-align: middle;
  width: 30px;/*画像の幅*/
}

#footer-open #footersocial .footersocialInner #fb,
#footer-open #footersocial .footersocialInner #twitter {
  font-size: 1.4rem;
  font-weight: 900;
  text-align: center;
}

#footer-open #footersocial .footersocialInner #fb:before {
  background-image: url(web-opencampus/images/ico_fb.png);
  background-repeat: no-repeat;
  background-size: contain;
  content: "";/*何も入れない*/
  display: inline-block;/*忘れずに！*/
  height: 24px;/*画像の高さ*/
  margin-right: 10px;
  vertical-align: middle;
  width: 24px;/*画像の幅*/
}

#footer-open #footersocial .footersocialInner #twitter:before {
  background-image: url(web-opencampus/images/ico_twitter.png);
  background-repeat: no-repeat;
  background-size: contain;
  content: "";/*何も入れない*/
  display: inline-block;/*忘れずに！*/
  height: 24px;/*画像の高さ*/
  margin-right: 10px;
  vertical-align: middle;
  width: 22px;/*画像の幅*/
}

#footer-open #footercontact {
  box-sizing: border-box;
  padding: 30px 10px 20px 10px;
}

#footer-open #footercontact h4 {
  font-size: 4vw;
}

#footer-open #footercontact h4 span {
  border-bottom: 1px solid #727171;
  padding-bottom: 15px;
}

#footer-open #footercontact p {
  font-size: 3.2vw;
  line-height: 160%;
  padding-top: 40px;
}
#co.full #mainContents .coInner.movie{

padding-bottom:1em;
	margin:0}
/*---------------------
pagetop
---------------------*/

#pagetop {
  bottom: 70px;
  right: 10px;
}


#modal {
  max-height: 90vh;
  max-width: 90vw;
  width: 90vw;
}
.openschool #btnFixBox{
	bottom:100px;
}
.openschool #footer{
	padding-bottom:5em}