@charset "utf-8";
/* CSS Document */
html {
  min-height: 100%;
  position: relative;
}
body{
	margin: 0 auto;
	padding: 0;
	font-family:Shin Maru Go Regular,'メイリオ', 'Meiryo','ＭＳ ゴシック','Hiragino Kaku Gothic ProN','ヒラギノ角ゴ ProN W3',sans-serif;
	font-size: 100%;
	font-weight: normal;
	line-height: 1.75;
	width: 100%;
 	background-color: #FFFFFF;
	color: #231815;
}
.both { clear: both; }
.mt20 { margin-top: 20px; }
.mr15r { margin-right: 15rem!important;}
.pc { display: none;}
.tc { text-align: center; }
.sp90 {
	display: block;
	width: 90%;
	margin: 0 auto;
}
.pagetop {
    display: none;
    position: fixed;
    bottom: 120px;
    right: 0;
	z-index: 5;
}
.pagetop a {
	display: block;
    text-indent: -9999px;
    width: 50px;
    background-image: url(../img02/pagetop.png);
    background-repeat: no-repeat;
    background-position: center;
    padding: 50px;
    background-size: contain;
    opacity: 0.8;
}
/* ヘッダー */
h1 { 
	background-color: #fff; 
	width: calc(100% - 80px);
	float: left;
	height: 80px;
}
h1 img {
	display: block;
    max-width: 320px;
    width: calc(100% - 80px);
    margin: 20px 0 0 1rem;
}
.icon, .icon_op {
   position: fixed;
   width: 100%;
   bottom: 0px;
   font-size: 0;
   z-index: 99;
}
.head_wrap { 
    width: 100%;
    position: fixed;
    z-index: 150;
}
.head_wrap { 
    width: 100%;
    position: fixed;
    z-index: 150;
	background-image: url(../img02/head/bg_top.png);
}

@media screen and (max-width: 1340px) {
	.h_nav { display: none;}
}
.navi_inner { padding-top: 50px; } 
.navi {
    padding: 0 5%;
    font-size: 2rem;
}
/* トップ */
.about_link {
    width: 168px;
    display: block;
    margin: 0 auto;
}
.cp_arrows .cp_arrow { height: 7px; }

.course_wrap {
	width: 100%;
	position: static;
	padding: 0 5%;
}
.course {
	width: 100%;
	background-color: #fff;
	border-radius: 12px;
	border: 1px #000 solid;
	padding: 50px 5%;
	box-sizing: border-box;
}
.course h3 { text-align: center; }
h3 {
	font-size: 3rem;
	font-weight: bold;
	text-align: center;
	color: #48B9DB;
}
.en { 
	text-align: center;
    display: block;
    margin: -2rem auto 2rem;
    color: #48B9DB;
    text-decoration: underline;
	text-underline-offset: 0.5em;
    font-size: 1.8rem;	
}
.sp_til img {
	width: 100%;
    max-width: 150px;
    margin: 0 auto 20px;
    display: block;
}
.cpr_arrows .cpr_arrow { width: 10px; }
.cpr_arrows { margin: -6.5rem auto 7rem; }

.bu {
	background-image: url(../img02/top/business.jpg);
    padding: 30px;
    background-size: 130%;
    background-repeat: no-repeat;
    margin: 0 auto 20px;
}

.ko {
	background-image: url(../img02/top/kodomo.jpg);
    padding: 30px;
    background-size: 130%;
    background-repeat: no-repeat;
    margin: 0 auto 20px;
}

.co01 {
	width: 100%;
    margin: 50% auto 0
}

.co02 {

}

.co02 img {
    width: 100%;
    height: auto;
}

.cou_tit {
	float: left;
	margin: 0 4% 0 5%;
	width: 6%;
}
.course h2 {
	text-align: center;
	margin-top: 2rem;
	font-size: 2.5rem;
}

.course p, .read_oc p { font-size: 2rem; }
/* visit list */
.visit_list {
	width: 100%;
	max-width: 820px;
	margin: 50px auto 0;
}
.visit_list ul {
	justify-content: center;
	padding: 50px 0;
}
.visit_list ul li {
	margin: 0 5%;
}
.visit_list ul li img { width: 100%;}

/* topics */
.topics { 
	background-color: rgba(72, 185, 219, 0.2);
	padding: 50px 5%;
}
.topics_list {
	width: 100%;
	max-width: 820px;
	margin: 0 auto;
}
.topics_title {
	float: left;
	width: 100%;
}
.info_tab { 
	font-size: 1.6rem;
}
.info_tab ul { margin-bottom: 1.5rem; }
.info_tab li{
	float: left;
	display: inline-block;
    background: #fff;
    cursor: pointer;
    position: relative;
    padding: 0.5rem 1rem;
    border-radius: 2rem;
    margin: 0.5rem;
    box-sizing: border-box;
    color: #000;
}

.info_tab li.select { 
	color: #fff; 
	background:#000;
	box-sizing: border-box;
}
.info_wrap {
	width: 100%;
	margin: 50px auto;
}
.content_area ul {
  flex-wrap: wrap;
}
.content_area ul li:before{
  content: "";
  display: block;
  padding-top: 100%;
}
.content_area ul li {
    box-sizing: border-box;
    background-color: #fff;
    border: 2px #000 solid;
    border-radius: 20px;
    position: relative;
    margin: 0 1%;
	padding-bottom: 20px;
	height: 420px;
	margin-bottom: 50px;
    font-size: 2rem;
}
.eyecatch {
  position: absolute;
  width: 265px;
  height: 200px;
  top: 20px;
  right: 0;
  left: 0;
  margin: auto;
  object-fit: cover;
  border-radius: 10px;
}
.date {
	position: absolute;
    top: 240px;
    left: 30px;
	color: #0081A2;
}

.cate {
	position: absolute;
    top: 240px;
    right: 30px;
	border: 1px solid #0081A2;
	box-sizing: border-box;
	padding: 0 0.5rem;
	color: #0081A2;
}
.event { background-color: #ffb94c; }
.in_fo { background-color: #ff92bd; }
.new_list { float: right; }
.til {
    position: absolute;
    top: 315px;
    padding: 0 2rem
}

.view_more h2 {
    text-align: right;
    margin-right: 7rem;
    font-size: 2rem;
    color: #000;
}
/*  sns */
.sns_wrap {
	width: 100%;
	padding: 20px 0 50px;
}
.sns { 
	width: 100%;
	max-width: 1400px;
	margin: 0 auto;
}
.sns h3 {
	display: block;
	margin: 0 auto 2rem;
	width: 100%;
}

.sns_til img {
	width: 100%;
	max-width: 750px;
	display: block;
	margin: -20px auto 50px;
}
.insta {
    width: 96%;
    margin: -100px 2% 100px;
    background-color: #fff;
    background-repeat: no-repeat;
    background-size: 100%;
    padding: 50px 5% 20px;
	border: 1px solid #231815;
	box-sizing: border-box;
}
.insta_list, .tubelist {
	width: 100%;
	max-width: 820px;
	margin: 0 auto;
}
.insta_list li {
	margin: 10px 1%;
	width: 98%; 
}
.thumb img {
	width: 100%;
    height: 250px;
    object-fit: cover;
    border-radius: 10px;
    border: 10px solid #000;
    box-sizing: border-box;
}
.youtube {
    width: 96%;
    margin: -100px 2% 100px;
    background-color: #fff;
    background-repeat: no-repeat;
    background-size: 100%;
    padding: 50px 5% 20px;
	border: 1px solid #231815;
	box-sizing: border-box;
}
.tubelist li {
	margin: 10px 1%;
	width: 98%; 
}
.tubelist li iframe {
	width: 100%;
	height: 250px;
	object-fit: cover;
    border-radius: 10px;
    border: 10px solid #000;
    box-sizing: border-box;	
}
.va01 { 
	margin: 30px auto; 
	display: block;
	width: 100%;
	max-width: 580px;
}
.va01 img { width: 100%; }
.goods { margin: 30px auto;}
.goods_l1 {
	width: 100%;
	background-color: #FFC800;
}
.goods_l2 {
	width: 100%;
	background-color: #FC262A;
	margin-top: -10px;
}
.goods_l1 ul {
    width: 100%;
    display: flex;
    justify-content: center;
	padding-top: 10px;
}
.goods_l1 ul li {
    width: 33%;
    margin-left: -1.75%;
} 
.goods_l1 ul li img, .goods_l2 ul li img { width: 100%; }
.goods_l2 ul {
    width: 100%;
    display: flex;
    justify-content: center;
}
.goods_l2 ul li {
    width: 33%;
    margin-right: -1.75%;
} 


.cont_list { width: 100%;}
.cont_list h3, .content h3 {
	display: block;
	margin: 0 auto 50px;
	width: 100%;
}
.cont_list h3 img, .topics_title h3 img, .content h3 img, .course h3 img, .sns h3 img, .visit_list h3 img { 
	max-width: 450px;
	width: 100%;
    display: block;
    margin: 0 auto 20px;
}
.cont_list ul {
	display: flex;
	width: 100%;
	max-width: 1500px;
	margin: 0 auto;
}
.cont_list ul li { width: 50%; }
.cont_list ul li img {
	width: 100%;
	max-width: 750px;
}

/* コンテンツ紹介　*/
.content { 
	padding: 50px 0; 
	background-color: rgba(255, 200, 0, 0.2);
}

/* コンテンツスライダー */
  .l-section {
    padding-top: 2rem;
    padding-bottom: 2rem;
  }

  [class*=swiper]:focus {
    outline: none;
  }

  .slide-media,
  .thumb-media {
    position: relative;
    overflow: hidden;
  }
  .slide-media img,
  .thumb-media img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
  }

  .swiper-button-prev, .swiper-button-next {
    display: grid;
    place-content: center;
    width: 6.4rem;
    height: 6.4rem;
    cursor: pointer;
    -webkit-transition: var(--transition);
    transition: var(--transition);
  }
  .swiper-button-prev::before, .swiper-button-next::before {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    content: "";
    border-radius: 50%;
    -webkit-box-shadow: var(--box-shadow);
            box-shadow: var(--box-shadow);
  }
  .swiper-button-prev::after, .swiper-button-next::after {
    width: 1.2rem;
    height: 1.2rem;
    content: "";
    border: solid var(--color-gray);
    border-width: 3px 3px 0 0;
  }
  .swiper-button-prev::after {
    margin-left: 0.4rem;
    -webkit-transform: rotate(-135deg);
            transform: rotate(-135deg);
  }
  .swiper-button-next::after {
    margin-right: 0.4rem;
    -webkit-transform: rotate(45deg);
            transform: rotate(45deg);
  }
  .swiper-button-disabled {
    pointer-events: none;
    opacity: 0;
  }

  .card05 {
    overflow: hidden;
	  padding-bottom: 50px;
  }
  .card05 .swiper {
    overflow: visible;
  }
  .card05 .swiper-wrapper {
    -webkit-transition-timing-function: linear !important;
            transition-timing-function: linear !important;
  }
  .card05 .swiper-slide {
    width: -webkit-max-content;
    width: -moz-max-content;
    width: max-content;
  }
  .card05 .slide {
    overflow: hidden;
    width: 18rem;
    border-radius: 4px;
  }
  .card05 .slide-media {
    padding-top: 100%;
  }
  .card05 .slide-media img {
    height: calc(100% + 16px);
    -webkit-transform: translateY(-16px);
            transform: translateY(-16px);
  }
  .card05 .slide-content { text-align: center; }
  .card05 .slide-title {
    line-height: 1.6;
    display: -webkit-box;
    overflow: hidden;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    height: 3.2em;
    margin-top: 1.6rem;
	  font-size: 1.8rem;
  }

  @media only screen and (max-width: 1024px) {
    html {
      -webkit-text-size-adjust: 100%;
    }
    .l-inner {
      padding: 0 4rem;
    }
    .pc {
      display: none !important;
    }
  }

  @media only screen and (max-width: 599px) {
    html {
      font-size: 50%;
    }
    .pc-tab {
      display: none !important;
    }
    .card05 .slide {
      width: 35rem;
    }
  }

  @media only screen and (min-width: 1025px) {
    .tab-sp {
      display: none !important;
    }
    .swiper-button-prev::before, .swiper-button-next::before {
      -webkit-transition: var(--transition);
      transition: var(--transition);
    }
    .swiper-button-prev:hover::before, .swiper-button-next:hover::before {
      -webkit-transform: scale(1.2);
              transform: scale(1.2);
    }
    .card05 .slide {
      -webkit-transition: var(--transition);
      transition: var(--transition);
    }
    .card05 .slide img {
      -webkit-transition: var(--transition);
      transition: var(--transition);
    }
    .card05 .slide:hover {
      -webkit-transform: translateY(-16px);
              transform: translateY(-16px);
      -webkit-box-shadow: var(--box-shadow-hover);
              box-shadow: var(--box-shadow-hover);
    }
    .card05 .slide:hover img {
      -webkit-transform: translateY(0);
              transform: translateY(0);
    }
    .card05 .swiper:hover .slide:not(:hover) {
      opacity: 0.3;
    }
  }
footer {
	background-color: #fff;
	margin-bottom: 80px;
}
map { display: none; }
map iframe {
  display: block;
}
.foot_r {
	font-size: 2rem;
}

address { padding: 20px 4% 10px; }
.copy {
	display: block;
	color: #fff;
	background-color: #16346C;
	text-align: center;
	padding-bottom: 80px;	
}

/* オープンキャンパス */
.opencampus h2 {
	background-image: url(../img02/hero/oc.jpg);
	padding-top: 25%;
}
.opencampus h3 {
	width: 100%;
	max-width: 480px;
    display: block;
    margin: 30px auto;
}
.about {
	padding: 50px 0;
}
.fs2tc {
	font-size: 2rem;
	text-align: center;
}
.fs15tc {
	text-align: center;
	font-weight: bold;
}
.about p { 
	text-align: center;
	line-height: 2;
}
.program {
	width: 100%;
	max-width: 1200px;
	margin: 0 auto;
	color: #fff;
	text-align: center;
}
.program h3 img {
	width: 100%;
	max-width: 480px;
    display: block;
    margin: 30px auto;
}
.flg {
	position: absolute;
	top: 0;
	right: 0;
	border-top: 70px solid #3FA9F5;
	border-left: 140px solid transparent;
}
.end {
	position: absolute;
	top : -60px;
	left : -70px;
	color : #ffffff;
	width : 80px;
	height : 20px;
	line-height: 20px;
	text-align: center;
}

.lt {
	position: relative;
	float: left;
	width: 32%;
	padding: 2rem 2%;
	margin-bottom: 2rem;
}
.cen {
	position: relative;
	float: left;
	width: 32%;
	margin-right: 2%;
	margin-left: 2%;
	padding: 2rem 2%;	
	margin-bottom: 2rem;
}
.rt {
	position: relative;
	float: left;
	width: 32%;
	padding: 2rem 2%;		
	margin-bottom: 2rem;
}
.oc_b {	background-color: #01a4a9; }
.oc_c { background-color: #EA5442; }
.oc_w { background-color: #FCB400; }
/*モーダルウィンドウ：hideエリアをはじめは非表示*/
.hide-area{
	display: none;
}

/*全て共通：モーダルのボタンの色を変更したい場合*/
.modaal-close:after, 
.modaal-close:before{
	background:#ccc;	
}

.modaal-close:focus:after,
.modaal-close:focus:before,
.modaal-close:hover:after,
.modaal-close:hover:before{
	background:#666;
}
.gallery {
	display: block;
	width: 100%;
}
/*アコーディオン全体*/
.accordion-area{
    list-style: none;
    width: 96%;
    max-width: 900px;
    margin:0 auto;
}

.accordion-area li{
    margin: 10px 0;
}

.accordion-area section {
	border: 1px solid #ccc;
}

/*アコーディオンタイトル*/
.title {
    position: relative;/*+マークの位置基準とするためrelative指定*/
    cursor: pointer;
    font-weight: normal;
    padding: 3% 3% 3% 50px;
    transition: all .5s ease;
}

/*アイコンの＋と×*/
.title::before,
.title::after{
    position: absolute;
    content:'';
    width: 15px;
    height: 2px;
    background-color: #333;
    
}
.title::before{
    top:48%;
    left: 15px;
    transform: rotate(0deg);
    
}
.title::after{    
    top:48%;
    left: 15px;
    transform: rotate(90deg);

}

/*　closeというクラスがついたら形状変化　*/

.title.close::before{
	transform: rotate(45deg);
}

.title.close::after{
	transform: rotate(-45deg);
}

/*アコーディオンで現れるエリア*/
.box {
    display: none;/*はじめは非表示*/
    background: #f3f3f3;
	margin:0 3% 3% 3%;
    padding: 3%;
}
/* サブぺージ */
.sub_wrap {	
	padding-bottom: 100px;
}

.sub_wrap h3 img {
	width: 100%;
	max-width: 820px;
	margin: 0 auto;
	display: block;
	padding: 50px 0;
}
.sub_con {
	width: 100%;
    max-width: 820px;
    margin: 0px auto;
    padding: 0 3% 76px;
	font-size: 2rem;
}
.sub_con h4 img {
	width: 100%;
	max-width: 200px;
	margin: 0 auto;
	display: block;
	padding-top: 50px;
}
/* オープンキャンパス */
.oc_link { 
	width: 100%;
	max-width: 820px;
	margin:0 auto;
}
.oc_link ul {
    display: flex;
    justify-content: flex-end;
    align-items: center;
    list-style: none;
    padding: 0 9px 0 66px;
}
.oc_link ul li { 
	background-color: #16346C;
	width: 150px;
	padding: 1rem 0;
	border-radius: 10px 10px 0 0;
	box-sizing: border-box;
	border: 1px #000 solid;	
}
.oc_link ul li a { 
	text-align: center;
	color: #fff;
	display: block;
	font-size: 2rem;
}
.now { background-color: #fff!important; }
.now a { color: #000!important; }
.nittei ul { margin: 20px auto; }
.nittei ul li {
	margin: 0 5%;
}
.nittei ul li img { width: 100%; }
.taiken dl {
	line-height: 2.5;
}
.taiken dt { padding-left: 2%; }
.taiken dd { 
	padding-left: 10%;
	border-bottom: 1px #000 dotted;
}
.taiken_lt, .taiken_rt, .taiken_ct { width: 80%; }
.taiken_lt { margin: 10px 10%; }
.taiken_rt { margin: 10px 10%; }
.taiken_ct { margin: 10px 10%; }
.taiken img {
	width: 100%;
	margin: 0 auto;
	display: block;
}
.taiken p { margin: 20px 0;}
.entry img {
	display: block;
	width: 100%;
	max-width: 200px;
	margin: 20px auto;
}
/* ローディング */
.c-optext>span {font-size: 2rem; }

.c-optext>span+span { margin-left: 0; }

.c-optext img {
	display: block;
	width: 100%;
	margin: 0 auto;
}
.pic100 { width: 100%; }
.mt50 { padding-top: 50px; }
.mt0 { margin-top: 0;}
.butt {
	max-width: 250px;
	width: 100%;
	margin: 30px auto 29px;
	display: block;
}
.oc {
	width: 85%;
	max-width: 820px;
	margin: 0 auto;
	color: #231815;
}
.oc img {
	width: 100%;
	max-width: 820px;
	margin: 0 auto;
	display: block;
}
.about_oc { 
	margin-top: 50px; 
}
.about_oc ul li img { width: 100%; }
.about_oc ul li {
	width: 90%;
	margin: 20px 5%;		
}
/* オープンキャンパスfaq */
.oneArea {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
  max-width: 1024px;
  margin: 50px auto;
}
.oneArea .onebox {
  width: 100%;
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
}
.oneArea .onebox:nth-child(even) {
  flex-direction: row-reverse;
  margin: 50px auto;
}
.oneArea .onebox .imgArea {
  width: 16%;
  position: relative;
	margin-top: 20px;
}
.oneArea .onebox:nth-child(odd) .imgArea img {
  width: 100%;
  max-width: 130px;
  position: absolute;
  top: -20px;
  left: 0;
  padding-right: 30px;
}
.oneArea .onebox:nth-child(even) .imgArea img {
  width: 100%;
  max-width: 130px;
  position: absolute;
  top: -20px;
  left: auto;
  right: 0;
  padding-left: 30px;
}
.oneArea .onebox .fukiArea {
  width: 75%;
}
.oneArea .onebox .fukidasi {
  width: 100%;
  position: relative;
  padding: 25px;
  background-color: #FFC800;
  color: #231815;
  border-radius: 12px;
  box-sizing: border-box;
}
.oneArea .onebox .fukidasi::before {
  content: '';
  position: absolute;
  display: block;
  width: 0;
  height: 0;
  border-radius: 50%;
  transform: rotate(45deg);
  top: 22px;
  border-right: 25px solid transparent;
  border-bottom: 25px solid transparent;
}
.oneArea .onebox .fukidasi::after {
  content: '';
  position: absolute;
  display: block;
  width: 0;
  height: 0;
  border-radius: 50%;
  transform: rotate(45deg);
  top: 40px;
  border-right: 25px solid transparent;
  border-bottom: 25px solid transparent;
}
.oneArea .onebox:nth-child(odd) .fukidasi::before {
  left: -15px;
  border-left: 25px solid #FFC800;
  border-top: 25px solid transparent;
}
.oneArea .onebox:nth-child(odd) .fukidasi::after {
  left: -25px;
  border-left: 25px solid #ffffff;
  border-top: 25px solid transparent;
}
.oneArea .onebox:nth-child(even) .fukidasi {
  background-color: #16346C;
}
.oneArea .onebox:nth-child(even) .fukidasi::before {
  left: auto;
  right: -15px;
  border-left: 25px solid transparent;
  border-top: 25px solid #16346C;
}
.oneArea .onebox:nth-child(even) .fukidasi::after {
  left: auto;
  right: -25px;
  border-left: 25px solid transparent;
  border-top: 25px solid #ffffff;
}
.fwh { color: #fff; }
.bg_cover { background-size: cover!important; }

@media screen and (max-width: 1024px) {
  .oneArea .onebox .fukidasi {
    padding: 15px;
  }
  .oneArea .onebox .fukidasi::before {
    top: 8px;
  }
  .oneArea .onebox .fukidasi::after {
    top: 20px;
  }
}
@media screen and (max-width: 420px) {
  .oneArea {
    margin: 30px auto;
  }
  .oneArea .onebox:nth-child(even) {
    margin-top: 15px;
  }
  .oneArea .onebox .imgArea {
    width: 25%;
  }
  .oneArea .onebox .fukidasi {
    padding: 10px 15px;
  }
}
.oshi {
	width: 100%;
	max-width: 820px; 
	margin: 50px auto 0;
	padding-bottom: 50px;
}
.oshi ul  {
    width: 100%;
}
.oshi ul li {
    width: 90%;
	margin: 0 auto 1rem;
	max-width: 480px;
} 
.oshi ul li img { width: 100%; }
/* サブぺージ 背景地味 */
.sub2_wrap {	
	background-color: rgba(72, 185, 219, 0.2);
	padding-bottom: 100px;
	font-size: 2rem;
}
.sub2_wrap h3 img {
	width: 100%;
	max-width: 1200px;
	margin: 0 auto;
	display: block;
	padding-top: 80px;
}
.sub2_con {
	width: 100%;
	max-width: 1400px;
	margin: 0px auto;
	padding: 50px 5%;
	background-color: #fff;
}
.sub2_con h4 img {
	width: 100%;
	max-width: 300px;
	margin: 0 auto;
	display: block;
	padding-top: 50px;
}
.sub2_con video {
	width: 100%;
}

.kadomaru {
-webkit-border-radius:15px;
-moz-border-radius:15px;
border-radius:15px;
}
/* 教員紹介 */
.tearch_list {
	width: 100%;
	max-width: 820px;
	margin: 0 auto;
	padding: 20px 0;
}
.tearch {
	background-color: #fff;
	padding: 30px 20px;
	width: 90%;
	float: left;
	margin: 20px 5%;
}
.tearch_list img {
	width: 100%;
}
.tearch_list li {
	line-height: 2;
	text-align: center;
}
.pic280 {
	width: 100%;
	max-width: 200px;
	margin: 1rem auto;
}
.profile { font-size: 2rem; }
.con_l {
	width: 100%;
	padding: 5%;
}
.pic_l { 
	width: 90%;
	margin: 10px auto;
}
.pic_l img { 
	width: 100%;
	max-width: 400px;
}
.prof_r {
	width: 96%;
	margin: 0 auto;
	box-sizing: border-box;
}
.prof_r dl {
  	display: flex;
  	flex-wrap: wrap;
  	width: 100%;
}
.prof_r dl dt {
	display: flex;
  	align-items: center;
  	width: 30%;
  	padding: 20px;
  	background-color: rgba(255, 200, 0, 0.2);
  	border-bottom: 1px solid #999;	
}
.prof_r dl dd {
	display: flex;
  	align-items: center;
 	width: 70%;
  	margin-left: 0;
  	padding: 20px;
  	background-color: #fff;
  	border-bottom: 1px solid #999;
}
.con_r {
	width: 96%;
	margin: 0 auto;
}
.con_r h4 {
    font-size: 2.5rem;
}
.profile h5 {
	font-size: 2.2rem;
	border-left: 5px solid #16346C;
	border-bottom: 1px solid #16346C;
	box-sizing: border-box;
	padding-left: 1rem;	
}
.profile ul { 
	padding: 2rem;
	list-style-type: none;
}
.profile ul li {
  	position: relative;
  	padding-left: 1em;
  	margin-bottom: 10px;
}
.profile ul li:before {
  	position: absolute;
  	top: 0.6em; /* 要素によって要調整 */
  	left: 0;
  	content: '';
  	display: inline-block;
  	width: 0;
  	height: 0;
  	border-style: solid;
  	border-width: 6px 0 6px 8px;
  	border-color: transparent transparent transparent #16346C;
}
.bg_wrap {
	padding-top: 20px;
	width: 100%;
	background-color: rgba(234, 85, 46, 0.2);
}
.pb { padding-bottom: 2rem; }
.fvana {
	width: 90%;
	max-width: 820px;
	margin: 0 auto 20px;
}
.pic120 {
	width: 100%;
	display: block;
	margin: 0 auto;
}
.read_oc { padding: 2rem; }
.read_oc img {
	width: 100%;
	max-width: 820px;
	margin: 0 auto;
	display: block;
}
.ic_d, .ic_c { 
	float: left;
	width: 25%;
}
.ic { 
	float: right;
	width: 25%;
}
.ic_d { background-color: #48B9DB; }
.ic_c { background-color: #FFC800; }
.ic_o {
	float: left;
	width: 50%;
	background-color: #16346C;
}
.icon img { 
	width: 100%;
	display: block;
	max-height: 80px;
}
.icon_op img { 
	width: 100%;
	display: block;
}
/* パンフレット　資料請求バナー */
.pamph_wrap {
	width: 100%;
	position: static;
	background-color: #fff;
	padding: 20px 0;
}
/* 背景ブルー */
.bg_bl { background-color: rgba(72, 185, 219, 0.2); }
/* トップ　オープンキャンパス */
.read_ocp {
	padding: 5rem 0;
}
.read_ocph {
	width: 90%;
    margin: 1rem auto;
}
.read_ocph img { width: 100%;}
.event_list ul {
}
.event_list ul li {
	width: 90%;
    margin: 1rem auto;
}
.event_list ul li img { width: 100%; }
/* オープンキャンパス　スケジュール */
/*
.sch_list{ 
	margin: 1rem auto;
	width: 85%;  
}
.sch_list .list{ border:#3FA9F5 solid 1px; }
.sch_list .list:not(:last-child){ margin-bottom:20px; }
.sch_list dt{
	border-bottom:#3FA9F5 solid 1px;
	background:#FFFFDC;
	display: flex;
	align-items: center;
	padding:0 25px;
	height:80px;
}
.sch_list .sc_date{ width:120px; }
.sch_list .sc_date span{ font-size:2.8rem; }
.sch_list .sc_date span.maru {
	border-width: 1px;
	border-style: solid;
	border-radius: 50%;
	font-size: 1.8rem;
	display: inline-block;
	line-height: 1;
	vertical-align: middle;
	margin-left: .05em;
	margin-bottom: .23em;
	padding: .25em .2em .2em;
}
.sch_list .sc_date .sun { color:#FF64B4; }
.sch_list .sc_date .sat { color:#14AAD2; }
.sch_list .sc_date .sun span.maru { border-color:#FF64B4; }
.sch_list .sc_date .sat span.maru { border-color:#14AAD2; }
.sch_list .time{ width:calc(100% - 120px); }
.sch_list .time span{ font-size:2rem; }
.sch_list .time span:not(:last-child){ margin-right:1em; }
.sch_list .text{ padding:20px; }
.sch_list .text .ttl{
	font-size:2.25rem;
	padding-bottom: 1rem;
	color: #2222FF;
	display: block;
}
.sch_list .text p{
	font-size:2rem;
	line-height:1.75;
}
.mg50 { margin: 20px 5%; }
.req { 
        background-color: #16346C;
        border-radius: 20px;
        color: #fff;
        padding: 0.5rem 1rem;
        margin: 2rem auto 1rem;
       width: 120px;
        display: block;
        text-align: center;
}
*/
.pt4rem { padding-top: 4rem; } 
.mt1b2 { margin: -1rem auto 2.5rem;}
.half { margin-bottom: 50px; }
/* オープンキャンパススケジュール*/
.ocdate {
    display: flex;
    flex-direction: column;
    height: auto;
    gap: 24px;
    padding: 34px 40px;
    background-color: rgba(72, 185, 219, 0.2);
    margin-bottom: 20px;
}

.ocDate_left {
    max-width: 340px;
    width: 100%;
}

.ocdate_dateWrap {
    display: flex;
    align-items: flex-end;
    gap: 4px;
    margin-bottom: 20px;
}
.ocdate_date {
    font-size: 3rem;
    font-weight: 500;
    line-height: 1;
}
.ocdate_dow {
    font-size: 1.6rem;
    line-height: 1;
}
.ocdate_time { font-size: 2rem; }
.ocdate_txt { font-size: 2rem; }
.ocdate_right {
    margin-left: auto;
    display: flex;
    justify-content: space-between;
    flex-direction: column;
    max-width: 360px;
    width: 100%;
}
.ocdate_btn {
    width: 100%;
    height: 48px;
    border-radius: 4px;
    color: #fff;
    font-size: 2rem;
    background-color: #1C4491;
    position: relative;
	margin-bottom: 2rem;
}
.ocdate_btn::after {
    content: "";
    width: 6px;
    height: 6px;
    margin-top: -5px;
    border-top: solid 1px #fff;
    border-right: solid 1px #fff;
    transform: rotate(45deg);
    position: absolute;
    top: 50%;
    right: 20px;
}
.ocdate_btn span {
    width: 100%;
    height: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
}
.fs2tcbb {
	font-size: 2rem;
	text-align: center;
    text-decoration: underline;
	text-underline-offset: 0.5em;
	display: block;
	padding-bottom: 2rem;
}
.mt-4 { margin-top: -3.5rem;}
.breadcrumbs, .breadcrumbs2 { display: none; }
/* サブぺージヘロ */
.hero {
	width: 100%;
	padding-top: 60px;
	margin-bottom: 30px;
	position: relative;
}
.hero img { width: 100%; }
/* 大学案内 */
.objective {
	width: 100%;
	padding: 100px 5%;
}
.objective ul {
	margin: 20px auto;
	border: 3px solid #48B9DB;
	font-weight: bold;
	padding: 2rem 0;
/*    background-color: #fff;
	border-radius: 50px;
	padding: 50px; */
	font-size: 2rem;
}
.objective ul li { 
	list-style: disc;
	list-style-position: inside;
	padding: 0 5rem;
}
.fs125 {
	padding: 1.5rem;
	background-color: #fff;
	font-size: 2rem;
	position: absolute;
	width: 88%;
	bottom: -32px;
	border: 1px #000 solid;
	margin: 0 6% 0;
}

.menu_list { 
	width: 90%;
	margin: 50px auto 0;
}
.menu_list ul {
}
.menu_list ul li {
	margin: 0 2% 40px;
	position: relative
}
.menu_list ul li img { width: 100%; }
.menutext_list ul {
	width: 90%;
	margin: 0 auto;
}
.menutext_list ul li {
	padding: 1.5rem;
	background-color: #fff;
	width: 85%;
	border: 1px #000 solid;
	margin: 2rem auto;
	font-size: 2rem;
	position: relative;	
}
.sub3_wrap {
	width: 100%;
	background-image: url(../img02/bg_bdot_sp.jpg);
}
.cy { color: rgb(249, 229, 50);}
.fbb { font-weight: bold; }
.fcko { color: #C1272D; }
.fcbu { color: #1B1464; }
.spfs3 { font-size: 3rem; }
.spfs25 { font-size: 2.5rem; }
/* よりみちオープンキャンパス */
.read_yoriocp {
	padding: 0;
}
.read_yoriocp p { font-size: 2rem; }
.dpamph_wrap {
	width: 100%;
	background-image: url(../img02/bg_tanitan.jpg); 
}
.dpamph {
	width: 100%;
	margin: 0 auto;
	padding: 50px 0 100px;
}
.dpamph img { 
	width: 90%; 
	margin: 0 auto;
	display: block;
}
.dpamph p {
	text-align: center;
	padding: 1rem 0;
	font-size: 2rem;
}
.spmb50 { margin-bottom: 50px!important; }
/* 大学について */
.con_c h3 { margin: 2rem auto ; }
.con_box { font-size: 2rem; }
.box_l, .box_r { 
	width: 90%;
	margin: 0 auto 50px;
}
.box_r ol, .box_l ol {
  counter-reset: my-counter;
  list-style: none;
  padding: 0;
}
 
.box_r ol li, .box_l ol li {
  margin-bottom: 10px;
  padding-left: 30px;
  position: relative;
}
.box_r ol li:before, .box_l ol li:before {
  content: counter(my-counter);
  counter-increment: my-counter;
  background-color: #1C4491;
  color: #fff;
  display: block;
  float: left;
  line-height: 22px;
  margin-left: -30px;
  text-align: center;
  height: 22px;
  width: 22px;
  border-radius: 50%;
}
.box_r dl, .box_l dl {
	width: 100%;
	margin-bottom: 20px;
}
.box_r dt, .box_l dt {
	padding: 0.5rem;
	background-color: #1C4491;
	color: #fff;
}

.box_r dd, .box_l dd {
	padding: 0.5rem;
	background-color: #F3F3F3;
}
.bgb {
	background-color: #1C4491;
	color: #fff;
	padding: 0.5rem 0.25rem;
	display: block;
}
.pd05 { padding: 0.5rem; }
.con_c {
	width: 100%;
	margin: 0 auto 50px;
	padding: 0 5%;
	font-size: 2rem;
}

.name_r { 
	float: right;
    margin: 20px;
}
.greeting_l {
	margin: 0 auto;
	width: 80%;
}
.greeting_l img { width: 100%; }
.greeting_r { margin:  0 auto; }
.pt5rem { padding-top: 5rem; }
.bgw {
	background-color: #fff;
	padding: 20px 0;
}
.yazirusi, .yazirusi2, .yazirusi3, .yazirusi4 {
	display: flex;
	position: absolute;
}
.yazirusi {
	right: 37px;
	bottom: -11px;
}

.yazirusi2 {
	right: 17px;
	bottom: 22px;
} 

.yazirusi3 {
	right: 40px;
	top: 25px;
} 
.yazirusi4 {
	right: 15px;
	bottom: 27px;
} 

.yazirusi::after, .yazirusi2::after, .yazirusi3::after, .yazirusi4::after {
	content: '';
	width: 30px;
	height: 10px;
	border-bottom: solid 1px;
	border-right: solid 2px;
	transform: skew(45deg);
}
.vana {
	position: relative;
	width: 100%;
	max-width: 600px;
	margin: 0 auto;
}
.vanaw {
	padding: 1.5rem;
	background-color: #fff;
	position: absolute;
	width: 80%;
	border: 1px #000 solid;
	margin: 20px 10% 0;
	font-size: 2rem;
}
.tlp5 {
	text-align: left!important;
	padding: 1rem 1.25rem!important;
}
.su_read {
	width: 100%;
	max-width: 820px;
	margin: 0 auto;
	padding: 0 5%;
	font-size: 2rem;
}
.su_read h4 { 
	text-align: center;
	font-weight: bold;
	font-size: 2.25rem;
}
.su_read p { padding: 1rem 0; }
.pt30 { padding-top: 30px!important; }
.bgbu {
	background-color: #1C4491;
	color: #fff;
	padding: 0.5rem 0.5rem;
	display: block;
	margin-bottom: 1rem;
}
.con_box90 {
	margin: 0 auto;
	width: 90%;
	font-size: 2rem;
}
.box_1, .box_2, .box_3, .box_4 {
	margin: 10px .5%;
	border: 1px #1c4491 solid;
}
.bbbu { padding: 1rem; }
.interview {
	width: 100%;
	max-width: 820px;
	margin: 30px auto;
	padding: 0 5%;
}
.interview_wrap {
	width: 100%;
	background-color: #fff;
	margin-bottom: 30px;
}
.interview_picl, .interview_picr { margin: 1rem 5% 0; }
.interview_readl, .interview_readr { 
	padding: 0 2rem 1rem; 
	font-size: 2rem;
}
/* カリキュラム */
.curriculum {
	width: 90%;
	margin: 20px auto;
	font-size: 2rem;
}

.curriculum_l, .curriculum_r {
	border-right:solid 1px #ddd;
	border-left:solid 1px #ddd;
}
.curriculum_c {
	border-right:solid 1px #ddd;
	border-left:solid 1px #ddd;
	border-bottom: solid 1px #ddd;
}
.dpamph video {
	width: 100%;
	padding: 0 5%;
}

.kadomaru {
-webkit-border-radius:15px;
-moz-border-radius:15px;
border-radius:15px;
}
.pb50 { padding-bottom: 30px!important;}
.spmt30 { padding-top: 30px; }
.con_c dl dt { font-size: 2.5rem; }
.spfs2, .con_c dl dd { 
	font-size: 2rem;
	width: 90%;
	text-align: left;
	margin: 0 auto;
}
.con_c dl dt { font-size: 1.5rem; }
.con_c ol li { 
	list-style: decimal; 
	list-style-position: inside;
}
.mt1rem { margin-top: 1rem; }
.ko_bg { background-color: rgba(247, 115, 100, 0.2); }
.bgko {
	background-color: #f77364;
	color: #fff;
	padding: 0.5rem 0.25rem;
	display: block;
}
.box_1_1, .box_1_2, .box_1_3 {
	margin: 0.5%;
	border: 1px #f77364 solid;
}
.box_1_1 img, .box_1_2 img, .box_1_3 img { width: 100%; }
.fs125tc { 
	text-align: center; 
	display: block;
}
/* こども学科 */
.interview dl { 
	display: flex;
	flex-wrap: wrap;
	width: 100%;
	border: 1px solid;
	border-bottom: none;
}
.interview dt {
	width: 100%;
	background-color: #fcffcf;
	padding: 1rem;
	border-bottom: 1px solid;
}

.interview dd {
	width: 100%;
	padding: 1rem;
	background-color: #F3F3F3;
	border-bottom: 1px solid;
}
.mx1200 { max-width: 1200px; }
.sub4_wrap {	
	background-color: rgba(247, 115, 100, 0.2);
}
.sub4_wrap h3 {
	color: #f77364;
}
.ko_movie {
	width: 100%;
	background-image: url(../img02/bg_kodomo.jpg); 
}
.risyu {
	width: 90%;
	max-width: 820px;
	margin: 0 auto;
	font-size: 2rem;
}
.risyu h4 { 
	text-align: center;
	font-weight: bold;
	font-size: 2.5rem;
}
.risyu dl { 
	display: flex;
	flex-wrap: wrap;
	width: 100%;
	border: 1px solid;
	border-bottom: none;
	margin: 20px auto;
}
.risyu dt {
	width: 100%;
	background-color: #ffffcf;
	padding: 1rem;
	border-bottom: 1px solid;
}

.risyu dd {
	width: 100%;
	padding: 1rem;
	background-color: #F3F3F3;
	border-bottom: 1px solid;
}
.box_r ul, .box_l ul, .con_c ul { margin-bottom: 0.5rem; }
.box_l ul li, .con_c ul li, .box_r ul li { padding: 0 1rem; }
.mb05 { margin-bottom: 1rem; }
.plr1 { padding: 0 1rem; }
.vana22w {
	padding: 1.5rem;
	background-color: #fff;
	position: absolute;
	width: 70%;
	border: 1px #000 solid;
	margin: 20px 10% 0;
	font-size: 2rem;
}
.pb50 { padding-bottom: 50px; }
.spt60 { padding-top: 60px; }
.disclosure {
	max-width: 820px;
	margin: 0 auto;
	padding: 0 5% 60px; 
}
.disclosure ol { margin: 2rem 0;}
.disclosure ol li {
	list-style: decimal;
	line-height: 3;
	border-bottom: 1px solid #ccc;
	list-style-position: inside;
}
.disclosure ol li ul li, .disclosure ul li ul li {
	list-style: disc;
	list-style-position: inside;
	padding: 0 2rem;
	border-bottom: 1px dotted #ccc;
}
.disclosure ol li ul li:last-child, .disclosure ul li ul li:last-child { border: none; }
.bgy { 
	background: rgba(204, 204, 204, 0.2); 
	padding-bottom: 2rem;
}
.fs15pt12 {
	font-size: 2.5rem;
	padding-top: 60px;
	display: block;
}
.disclosure ul li {
	list-style: disc;
	list-style-position: inside;
	line-height: 3;
	border-bottom: 1px solid #ccc;
}
.nolist { list-style-type: none!important; }
.spbgw { background-color: #fff; }
.spfs325 { font-size: 3.25rem; }
.fw600 { font-weight: 600; }
/* 沿革 */
.enkaku {
	width: 90%;
	max-width: 820px;
	margin: 50px auto 0;
	padding-bottom: 50px;
}
.enkaku dl {
  	width: 100%;
	margin: 50px auto;
	background-color: #fff;
  	border-top: 1px solid #999;
}
.enkaku dl dt { 
	padding: 0.5rem 1rem ;
	color: #5984B6;
	font-weight: bold;
}
.enkaku dl dd {
	padding: 0 1.5rem 1rem ;
  	background-color: #fff;
  	border-bottom: 1px solid #999;
}
.enkaku img {
	display: block;
	width: 100%;
	margin: 0 auto;
}
.grp { border: 1px solid #23457E; }
.grp h4 {
	font-size: 2.5rem;
	text-align: center;
	padding-top: 0.5rem;
	background-color: #5984B6;
	font-weight: bold;
	color: #fff;
}

.grp dl { margin: 0 auto;}
.grp dt {
	text-align: center;
	font-weight: 700;
}
.grp dd { border-bottom: 1px dotted #999;}
.butta {
	font-size: 2rem;
	position: relative;
	display: block;
	font-weight: bold;
	margin-top: -0.5rem;
    box-sizing: border-box;	
	background-color: rgba(255, 200, 0, 0.2);
	border-radius: 30px;
	padding: 16px 30px;
}
.butta::after {
  content: "";
  width: 10px;
  height: 10px;
  border-top: solid 1px #333;
  border-right: solid 1px #333;
  transform: rotate(45deg);
  position: absolute;
  margin-top: -5px;
  top: 50%;
  right: 20px;
}
.menu_list3 { 
	width: 90%;
	margin: 50px auto 0;
}
.menu_list3 ul {
}
.menu_list3 ul li {
	margin: 0 2% 40px;
	position: relative
}
.menu_list3 ul li img { width: 100%; }
.kiyou {
	width: 90%;
	max-width: 820px;
	margin: 50px auto 0;
	padding: 50px 0;
}
.kiyou h4 { 
	text-align: center;
	font-weight: bold;
	font-size: 2.5rem;
}
.kiyou h5 { font-size: 2.2rem; }
.kiyou dl { 
	width: 100%;
	border: 1px solid;
	border-bottom: none;
	margin: 20px auto;
}
.kiyou dt {
	background-color: #ffffcf;
	padding: 1rem;
	border-bottom: 1px solid;
	text-align: center;
}

.kiyou dd {
	padding: 1rem;
	background-color: #F3F3F3;
	border-bottom: 1px solid;
	text-align: center;
}
.ki_detail { 
	padding: 20px 0 ; 
	border-bottom: 1px dotted #ccc;
}
.ki_title {

}
.ki_author {
	padding-top: 1.5rem;
	text-align: right;
}
.pt3r { padding-top: 1.5rem; }
.pt2r { padding-top: 1.5rem; }
/* オープン教育リソース */
.open_educational {
	width: 90%;
	max-width: 820px;
	margin: 50px auto 0;
	padding: 50px 0;
}
.pic_op {
	max-width: 480px;
	width: 100%;
	margin: 15px auto;
	display: block;
}
.pic_op img { width: 100%; }

.open_educational ul { }
.open_educational ul li { 
	border-bottom: 1px solid #ccc;
    padding: 1rem 0;
}
.open_educational ul li img { width: 100%; }
/* 子育て・教育セーフティーネット */
.safenet {
	width: 90%;
	max-width: 820px;
	margin: 50px auto;
}
.safenet ul { 
	padding: 2rem 0;
	list-style-type: none;
}
.safenet ul li {
  	position: relative;
  	padding-left: 1em;
  	margin-bottom: 10px;
}
.safenet ul li:before {
  	position: absolute;
  	top: 0.35em; /* 要素によって要調整 */
  	left: 0;
  	content: '';
  	display: inline-block;
  	width: 0;
  	height: 0;
  	border-style: solid;
  	border-width: 6px 0 6px 8px;
  	border-color: transparent transparent transparent #16346C;
}
.safenet_l {
}
.safenet_r {
}
.safenet dl {
  	width: 100%;
	margin: 50px auto;
	background-color: #fff;
}
.safenet dl dt { padding: 0.5rem 1rem ; }
.safenet dl dd {
	padding: 0 1.5rem 1rem ;
  	background-color: #fff;
  	border-bottom: 1px solid #999;
}
.safenet dl dd a { margin-top: 1.5rem; }
.sppb50 { padding-bottom: 50px; }
/*　オープンキャンパス申込フォーム　*/
form#mailformpro dl {
	border-right: 1px solid #ccc;
	border-bottom: 1px solid #ccc;
	border-left: 1px solid #fff;
}
form#mailformpro dl dt {
	padding: 1.5rem 1rem ;
	text-align: left;
	background-color: #48B9DB;
	margin: 0px;
	box-sizing: border-box;
	color: #fff;
}
form#mailformpro dl dd {
    border-top: solid 1px #CCC;
    border-left: 1px solid #ccc;
  	align-items: center;
	padding: 1.5rem 1rem ;
    text-align: left;
	background: #fff;
	box-sizing: border-box;
}
form#mailformpro select { padding: 0.5rem 1rem; }
form#mailformpro input { 
	padding: 0.5rem 1rem; 
	margin: 0.5rem 1rem;
}
form#mailformpro textarea { width: 100%; }
.radio_b ul { float: left; }
.radio_b li, .check_b li {
        float: left !important;
}
.ptb2 { padding: 2rem 0; }
div.mfp_buttons button {
	margin: 0px 1rem;
	padding: 1rem;
	background-color: #48B9DB;
	border-radius: 30px;
	color: #fff;
	border: none!important;
}
.spfss2 { font-size: 2rem; }