@charset "utf-8";

/*====================================================
university
====================================================*/

main .main-v .h-text_box h2 {
  text-shadow: 2px 2px 0 white, -2px 2px 0 white, 2px -2px 0 white, -2px -2px 0 white;
}

.university_ttl {
  color: #fff;
  background-color: #0E0854;
  font-size: 24px;
  font-weight: 600;
  margin-bottom: 20px;
  padding: 0 0.6em;
}

.hero_img {
  margin-bottom: 25px;
}

.hero_ttl {
  font-size: 19px;
  font-weight: 600;
  margin-bottom: 5px;
  text-indent: -0.6em;
}

.hero_txt {
  line-height: 1.64;
}

/*====================================================
 merit
====================================================*/

.merit {
  padding: 30px 0 30px;
}

.merit__list {
  display: flex;
  flex-wrap: wrap;
  row-gap: 15px;
  justify-content: space-between;
}

.merit__item {
  border: 5px solid #5E981D;
  border-radius: 18px;
  overflow: hidden;
}

.merit__head {
  font-size: 18px;
  font-weight: 600;
  color: #fff;
  background-color: #5E981D;
  text-align: center;
  padding: 0.31em;
}

.merit__body {
  padding: 12px 5%;
  gap: 20px 5%;
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.merit__list li {
  box-sizing: border-box;
}

.merit__img {
  text-align: center;
}

.merit__list li:first-of-type {
  width: 100%;
}

.merit__list li:nth-of-type(2) {
  border-color: #EC4808;
}

.merit__list li:nth-of-type(2) .merit__head {
  background-color: #EC4808;
}

.merit__list li:nth-of-type(3) {
  border-color: #458CBF;
}

.merit__list li:nth-of-type(3) .merit__head {
  background-color: #458CBF;
}

@media only screen and (min-width: 800px){
  .merit__txt {
    flex: 1;
  }

  .merit__list li {
    width: 49%;
  }

  .merit__list li:first-of-type .merit__body {
      display: flex;
      flex-direction: row;
      flex-wrap: wrap;
      align-items: center;
      justify-content: center;
      padding: 25px 2%;
      gap: 20px 5%;
    }

  .merit__list li:first-of-type {
    width: 100%;
  }

  .merit__list li:first-of-type .merit__img {
    flex: 1;
    max-width: 306px;
    padding-right: 2%;
    min-width: 250px;
  }

  .merit__list li:first-of-type .merit__txt {
      flex: 1;
      min-width: 300px;
  }

}

/*====================================================
 schedule
====================================================*/

.schedule {
  padding: 30px 0 30px;
}

.schedule_list {
  margin-bottom: 20px;
}

.schedule_list li {
  background-color: #F6EEED;
  border-radius: 7px;
  padding: 0.55em;
  font-size: 18px;
  font-weight: 600;
  text-align: center;
  margin-bottom: 33px;
  position: relative;
}

.schedule_list li::after {
  content: "";
  width: 0;
  height: 0;
  border-style: solid;
  border-right: 11px solid transparent;
  border-left: 11px solid transparent;
  border-top: 19px solid #0e0854;
  border-bottom: 0;
  position: absolute;
  top: calc(100% + 7px);
  left: 50%;
  transform: translateX(-50%);
}

.schedule_item {
  display: block;
  margin: 0 auto;
  max-width: 441px;
  text-align: left;
  display: flex;
  flex-direction: column;
  text-align: center;
}

.schedule_list li span {
  color: #CF3181;
}

.schedule_item_passed {
  font-size: 14px;
  font-weight: 600;
  background-color: #E8F40C;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 43px;
  height: 22px;
  text-align: center;
  position: absolute;
  top: calc(100% + 5px);
  left: 53%;
}

.schedule_list li:last-of-type {
  margin-bottom: 0;
}

.schedule_list li:last-of-type .schedule_item {
  text-align: center;
  justify-content: center;
}

.schedule_list li:last-of-type::after {
  content: none;
}

@media only screen and (min-width: 800px){
  .schedule_item {
    flex-direction: row;
    gap: 20px;
  }
}


/*====================================================
 qualification
====================================================*/

.qualification {
  padding: 30px 0 30px;
}

.qualification__ttl {
  color: #F63272;
  text-align: center;
  font-size: 19px;
  font-weight: 600;
  margin-bottom: 7px;
  display: flex;
  justify-content: center;
  align-items: flex-end;
}

.qualification__ttl::before {
  content: "＼";
}

.qualification__ttl::after {
  content: "／";
}


/*====================================================
 reason
====================================================*/

.reason {
  padding: 30px 0 30px;
}


.award_list {
	margin-bottom: 5px;
}

.award_list li {
	width: 251px;
	margin: 0 auto;
	position: relative;
	background: url(../img/university/deco_award.png) no-repeat;
	background-size: contain;
}

.award_list li::after {
	content: "※2";
	color: #4C2814;
	font-size: 13px;
	font-weight: 500;
	position: absolute;
	top: 42%;
	right: 14%;
}

.award_list li:first-of-type::after {
	content: "※1";
}

.award_ttl {
	font-size: 22px;
	color: #4C2814;
	text-align: center;
	font-weight: 600;
	line-height: 1.3;
	padding: 30px 0;
}

.award_ttl span {
	font-size: 19px;
}

.award_ttl span.num {
	font-size: 35px;
	font-weight: 600;
}

.award_note {
	font-size: 10px;
	color: #4C2814;
	text-align: center;
	text-align: center;
}

@media screen and (min-width: 801px) {

	.award_list {
		display: flex;
		justify-content: center;
		margin-bottom: 5px;
		gap: 20px;
    max-width: 700px;
    margin: 0 auto;
	}

	.award_list li {
		margin: 0;
	}
}

.reason__list {
  padding: 30px 0 0;
}

.reason__list li {
  margin-bottom: 21px;
  background-color: #F6EEED;
  border-radius: 8px;
  padding: 1.0em 1em;
  line-height: 1.45;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 10px;
}

.reason__ttl {
  font-size: 18px;
  font-weight: 600;
  color: #CF3181;
}

.reason__btn {
    display: flex;
    align-items: center;
    width: 199px;
    color: #fff;
    font-size: 13px;
    background-color: #E43D6E;
    border-radius: 13px;
    padding: 0.25em 2em 0.25em 1.25em;
    box-sizing: border-box;
    position: relative;
}

.reason__btn::after {
  content: "";
  display: block;
  content: '';
  width: 7px;
  height: 7px;
  border-top: solid 2px #ffff;
  border-right: solid 2px #fff;
  position: absolute;
  right: 10px;
  top: 50%;
  transform:  translateY(-50%) rotate(45deg);
}

/*====================================================
 course
====================================================*/

.course_txt {
  text-align: center;
  margin-bottom: 15px;
}

.course_ttl {
  font-size: 20px;
  font-weight: 600;
  text-align: center;
  margin-bottom: 30px;
}


.program {
	padding: 30px 15px;
    background: url(/assets/img/top/bg05.png) repeat left top;
}

.program-ttl {
	display: flex;
	flex-direction: column;
	align-items: center;
    font-size: min(7.5vw, 30px);
	font-weight: 800;
	letter-spacing: 0.014em;
	margin-bottom: 9px;
}

.program-ttl::before {
	content: "";
	display: block;
	width: 65px;
	height: 45px;
	background: url(../img/common/icon_hat.png) no-repeat;
	background-size: contain;
}

.program-lead {
	text-align: center;
    font-size: min(6vw, 20px);
	font-weight: 600;
	letter-spacing: 0.014em;
	margin-bottom: 37px;
}

.program-list {
	display: flex;
	flex-wrap: wrap;
	gap: 20px;
}

.program-list > li {
	background-color: #fff;
	border-radius: 20px;
	overflow: hidden;
}

.program-content {
	padding: 16px 5%;
	display: flex;
	flex-direction: column;
	flex: 1;
}

.program-tag-list {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin-bottom: 13px;
}

.program-tag {
	color: #fff;
	background-color:#EF88B0;
	font-size: 14px;
	border-radius: 0.357em;
    padding: 0.1em 0.7em;
	letter-spacing: 0.014em;
}

.program-tag.program-tag--online {
	color: #363635;
	background-color: #F0F0F0;
}

.program-name {
    font-size: min(7vw, 17px);
	font-weight: 600;
	letter-spacing: 0.014em;
	line-height: 1.6;
	text-align: center;
	margin-bottom: 5px;
}

.program-name span {
	color: #EC5F83;
	font-size: 13px;
	font-weight: 500;
	display: block;
	letter-spacing: 0.014em;
}

.program-txt {
	font-size: 13px;
	letter-spacing: 0.014em;
	line-height: 1.35;
	text-align: center;
	margin-bottom: 27px;
}

.program-btn {
	display: block;
	font-size: 14px;
	color: #fff;
	background-color: #EC5F82;
	letter-spacing: 0.014em;
	border-radius: 2.143em;
	text-align: center;
	position: relative;
    padding: 0.28em;
	transition: opacity 0.3s;
	margin-top: auto;
}

.program-btn::after {
	content: "";
	display: block;
	border-bottom: 1px solid #fff;
    border-right: 1px solid #fff;
    height: 8px;
    width: 8px;
	position: absolute;
	top: 50%;
	right: 19px;
	transform: translateY(-50%) rotate(-45deg);
}

.program-btn:hover {
	opacity: 0.7;
	text-decoration: none;
}

.program-tag.program-tag--practical {
	background-color: #59BBAB;
}

.program--practical .program-name span {
	color: #59BBAB;
}

.program--practical .program-btn {
	background-color: #59BBAB;
}

.button {
    font-size: 15px;
    font-weight: bold;
    text-align: center;
    margin: calc(2% + 30px) auto 0;
    padding: 0.45em 3em;
    border-radius: 10px;
    background: #1fbeaa url(/assets/img/top/arrow-right-white.png) no-repeat 1em center;
    color: #fff;
    display: table;
}

@media screen and (min-width: 801px) {
  .program {
    margin: 0 -1.5%;
  }
	.program-list {
		display: flex;
		flex-wrap: wrap;
		display: grid;
		grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
		gap: 20px 2%;
		max-width: 1100px;
		margin: 0 auto;
	}

	.program-list > li {
		display: flex;
		flex-direction: column;
	}
}