@charset "UTF-8";

/*   プラン情報（plan.css）   */


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

Plan__BG（ページ背景色）

------------------------------------------------- */
.Plan__BG {
	width: 100%;
	height: 100%;
	background-color: #9DDCDC;
	border-bottom: 1px solid #ffffff;
}

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

Main

------------------------------------------------- */
#Main,#Main02,#Main03 {
	width: 100%;
}
#Main .Section,
#Main02 .Section,
#Main03 .Section {
	/*margin: 0 0 120px;*/
	margin: 60px 0 0;
	position: relative;
}
/*#Main .Section:first-child {
	margin: 80px 0 120px;
	position: relative;
}*/
@media screen and (max-width: 898px)  {
#Main .Section,
#Main02 .Section,
#Main03 .Section {
	margin: 40px 0 0;
}
/*#Main .Section {
	margin: 0 0 100px;
}*/
/*#Main .Section:first-child {
	margin: 40px 0 100px;
}*/
}
@media screen and (max-width: 480px)  {
/*#Main .Section {
	margin: 0 0 80px;
}*/
/*#Main .Section:first-child {
	margin: 40px 0 80px;
}*/
}
@media print {
#Main .Section,
#Main02 .Section,
#Main03 .Section {
	overflow:visible;
}
#Main .Section:last-child,
#Main02 .Section:last-child,
#Main03 .Section:last-child {
	padding-bottom: 100px;
}
/*#Main .Section {
	overflow:visible;
}
#Main .Section:last-child {
	padding-bottom: 120px;
}*/
}


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

PageTitle__Plan__wrp

------------------------------------------------- */
/* ページタイトル（プラン情報）
================================================== */
.PageTitle__PlanImg__wrp{
	width: 100%;
	padding: 30px 0 0;
 position: relative;
}
.PageTitle__PlanImg__Box {
	max-width: 1200px;
	width: 100%;
	margin: 0 auto;
}
@media screen and (max-width: 1250px)  {
.PageTitle__PlanImg__wrp{
	padding: 25px 2% 0;
}
}
@media screen and (max-width: 898px)  {
.PageTitle__PlanImg__wrp{
	padding: 20px 2% 0;
}
}
@media screen and (max-width: 768px)  {
.PageTitle__PlanImg__wrp{
	padding: 15px 2% 0;
}
}


/* サブタイトル（プラン情報）
================================================== */
.PageTitle__Plan__wrp{
	width: 100%;
	padding: 40px 0 0;
 position: relative;
}
.PageTitle__Plan__Box {
	max-width: 1200px;
	width: 100%;
	height: 380px;
	background-color: #ffffff;
	border-radius: 25px;
	margin: 0 auto;
	padding: 15px;
 position: relative;
	display: flex;
	justify-content: center;
	align-items: center;
}
@media screen and (max-width: 1250px)  {
.PageTitle__Plan__wrp{
	padding: 40px 2% 0;
}
}
@media screen and (max-width: 898px)  {
.PageTitle__Plan__wrp{
	padding: 30px 2% 0;
}
}
@media screen and (max-width: 768px)  {
.PageTitle__Plan__wrp{
	padding: 25px 2% 0;
}
.PageTitle__Plan__Box {
	height: 300px;
	border-radius: 20px;
	padding: 10px;
}
}
@media screen and (max-width: 480px)  {
.PageTitle__Plan__wrp{
	padding: 15px 2% 0;
}
.PageTitle__Plan__Box {
	height: 220px;
	border-radius: 14px;
	padding: 5px;
}
}
@media screen and (max-width: 375px)  {
.PageTitle__Plan__Box {
	height: 180px;
}
}

.PageTitle__Plan__inner01 {
	max-width: 1170px;
	width: 100%;
	height: 100%;
	border: 4px solid #272343;
	border-radius: 25px;
	padding: 25px;
}
.PageTitle__Plan__inner02 {
	max-width: 1110px;
	width: 100%;
	height: 100%;
	margin: 0 auto;
	background-color: rgba(255,255,255,0.9);
	border-radius: 25px;
	display: flex;
	justify-content: center;
	align-items: center;
	position: relative;
}
.PageTitle__Plan__inner02 .macho {
	position: relative;
}
.icon_macho {
	width: 100px;
	position: absolute;
	right: -14px;
	bottom: -48px;
}

@media screen and (max-width: 898px)  {
.PageTitle__Plan__inner02 {
	padding: 25px;
}
.icon_macho {
	width: 80px;
	right: 20px;
	bottom: -25px;
}
}
@media screen and (max-width: 768px)  {
.PageTitle__Plan__inner01 {
	border-radius: 20px;
	padding: 10px;
}
.PageTitle__Plan__inner02 {
	border-radius: 20px;
}
.icon_macho {
	width: 80px;
	right: -10px;
	bottom: -10px;
}
}
@media screen and (max-width: 480px)  {
.PageTitle__Plan__inner01 {
	border: 2px solid #272343;
	border-radius: 14px;
	padding: 10px;
}
.PageTitle__Plan__inner02 {
	border-radius: 14px;
	padding: 10px;
}
.icon_macho {
	width: 40px;
	right: 10px;
	bottom: -10px;
}
}

.Plan__BG_koko {		/*  高校生  */
	background-image: url("../images/plan/bg_plan01.png");
	background-position: center center;
}
.Plan__BG_daigaku {		/*  大学生等  */
	background-image: url("../images/plan/bg_plan02.png");
	background-position: center center;
}
.Plan__BG_tanki {		/*  短期  */
	background-image: url("../images/plan/bg_plan03.png");
	background-position: center center;
}
@media screen and (max-width: 768px)  {
.Plan__BG_koko {		/*  高校生  */
	background-size: 96px;
}
.Plan__BG_daigaku {		/*  大学生等  */
	background-size: 96px;
}
.Plan__BG_tanki {		/*  短期  */
	background-size: 96px 158px;
}
}
@media screen and (max-width: 480px)  {
.Plan__BG_koko {		/*  高校生  */
	background-size: 64px;
}
.Plan__BG_daigaku {		/*  大学生等  */
	background-size: 64px;
}
.Plan__BG_tanki {		/*  短期  */
	background-size: 64px 105px;
}
}


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

Plan__wrp

------------------------------------------------- */
.Plan__wrp	{
	max-width: 1000px;
	width: 100%;
	/*margin: 0 auto 100px;*/
	margin: 0 auto 60px;
	position: relative;
}
.frame_w	{		/*  白枠  */
	max-width: 760px;
	width: 100%;
	margin: 0 auto 80px;
	background-color: #ffffff;
	border-radius: 25px;
	font-size: 2.2rem;
	line-height: 2;
}
.frame_w.koko	{
	padding: 40px 70px;
}
.frame_w.daigaku	{
	padding: 40px 60px;
}
.frame_w.tanki	{
	padding: 40px;
}

@media screen and (max-width: 1250px)  {
.Plan__wrp	{
	width: 95%;
}
}
@media screen and (max-width: 768px)  {
.Plan__wrp	{
	/*padding-bottom: 30px;*/
}
.frame_w	{		/*  白枠  */
	margin: 0 auto;
	font-size: 2rem;
	line-height: 2;
	border-radius: 20px;
}
}
@media screen and (max-width: 640px)  {
.Plan__wrp	{
	/*margin: 0 auto 80px;*/
	margin: 0 auto 60px;
}
.frame_w	{		/*  白枠  */
	font-size: 1.6rem;
	line-height: 1.7;
}
.frame_w.koko	{
	padding: 30px;
}
.frame_w.daigaku	{
	padding: 30px;
}
.frame_w.tanki	{
	padding: 30px;
}
}


/* Plan__Box
================================================== */
.Plan__Box	{
	display: flex;
	justify-content:space-between;
}
.Plan__Box .Plan__Box_Left {
	max-width: 400px;
	width: 100%;
}
.Plan__Box .Plan__Box_Right {
	max-width: 500px;
	width: 100%;
}
@media screen and (max-width: 1000px)  {
.Plan__Box .Plan__Box_Right {
	margin-left: 25px;
}
}
@media screen and (max-width: 898px)  {
.Plan__Box	{
	flex-direction: column;
	align-items: center;
}
.Plan__Box .Plan__Box_Left {
	max-width:500px;
}
.Plan__Box .Plan__Box_Right {
	max-width: 500px;
	margin-left: 0px;
}
}
@media screen and (max-width: 768px)  {
}
@media screen and (max-width: 480px)  {
}

/* 料金等（右側）
================================================== */
.frame_w_BG	{		/*  白枠  */
	width: 100%;
	margin-bottom: 30px;
	background-color: #ffffff;
	border-radius: 25px;
	position: relative;
	background-image: url("../plan/images/bg_waku.svg");
	background-position: top left;
	background-repeat: no-repeat;
}
.frame_blue_BG	{		/*  青枠  */
	width: 100%;
	margin-bottom: 30px;
	background-color: #7ec2c2;
	border-radius: 25px;
	position: relative;
}
.frame_yellow_BG	{		/*  黄枠  */
	width: 100%;
	padding: 50px;
	margin-bottom: 30px;
	background-color: #fff4e1;
	border-radius: 25px;
	position: relative;
}
@media screen and (max-width: 1000px)  {
.frame_w_BG	{		/*  白枠  */
	background-image: url("../plan/images/bg_waku.svg");
	background-position: top 0 left -30px;
}
}
@media screen and (max-width: 768px)  {
.frame_w_BG	{		/*  白枠  */
	background-position: top -10px left -30px;
}
}
@media screen and (max-width: 480px)  {
.frame_w_BG	{		/*  白枠  */
	background-position: top -25px left -30px;
	margin-bottom: 15px;
}
.frame_yellow_BG	{		/*  黄枠  */
	padding: 30px;
}
}
@media screen and (max-width: 374px)  {
.frame_w_BG	{		/*  白枠  */
	background-position: top -25px left -40px;
}
}
@media screen and (max-width: 320px)  {
.frame_w_BG	{		/*  白枠  */
	background-position: top -25px left -46px;
}
}

.Plan__telBox	{
	position: relative;
	width: 100%;
	padding: 40px;
	display:flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
}
@media screen and (max-width: 480px)  {
.Plan__telBox	{
	padding: 20px 0;
}
}

.Price__Box	{
	position: relative;
	width: 100%;
	padding: 25px;
}
.Price__EN	{
	display: flex;
	justify-content: center;
	align-items: center;
	font-family: "Noto Serif", serif;
	font-size: 3.6rem;
	font-weight: 500;
	line-height: 1;
	letter-spacing: 0.05em;
	color: #272343;
	text-shadow: -4px 4px 0px rgba(157,220,220,0.8);
	margin-bottom: 20px;
}
@media screen and (max-width: 768px)  {
.Price__EN	{
	font-size: 3rem;
}
}
@media screen and (max-width: 480px)  {
.Price__Box	{
	padding: 18px;
}
.Price__EN	{
	font-size: 2.4rem;
}
}

.Price	{
	width: 306px;
	padding: 50px 0px 30px;
	margin: 0 auto;
}
.favor	{
	width: 310px;
	padding: 30px 0px 10px;
	margin: 0 auto;
}
@media screen and (max-width: 768px)  {
.Price	{
	width: 275px;
	padding: 50px 0px 30px;
}
.favor	{
	width: 310px;
	padding: 30px 0px 10px;
}
}
@media screen and (max-width: 480px)  {
.Price	{
	width: 230px;
	padding: 20px 0px 10px;
}
.favor	{
	width: 250px;
	padding: 10px 0px 0px;
}
}

.PriceInner	{
	display:flex;
	align-items:baseline;
	margin-bottom: 20px;
}
.PriceInner > :not(.tax)	{
	font-size: 3.6rem;
	font-weight: 600;
	line-height: 1;
	margin-right: 10px;
}
.PriceInner > div:nth-child(1)	{
	width: 50px;
}
.PriceInner > div:nth-child(2)	{
	width: 180px;
}
.PriceInner > .tax	{
	font-size: 1.4rem !important;
}
@media screen and (max-width: 768px)  {
.PriceInner > :not(.tax)	{
	font-size: 3rem;
}
.PriceInner > div:nth-child(1)	{
	width: 40px;
}
.PriceInner > div:nth-child(2)	{
	width: 150px;
}
}
@media screen and (max-width: 480px)  {
.PriceInner > :not(.tax)	{
	font-size: 2.4rem;
}
.PriceInner > div:nth-child(1)	{
	width: 30px;
}
.PriceInner > div:nth-child(2)	{
	width: 110px;
}
.PriceInner > .tax	{
	font-size: 1.2rem;
}
}

.sinsa	{
	font-size: 1.4rem;
	font-weight: 600;
	margin-top: -20px;
}
@media screen and (max-width: 480px)  {
.sinsa	{
	font-size: 1.2rem;
}	
}

.PriceInner02	{
	display:flex;
	align-items:baseline;
	margin-top: 20px;
}
.PriceInner02 > :not(.tax)	{
	font-size: 2rem;
	font-weight: 500;
	line-height: 1;
	margin-right: 10px;
}
.PriceInner02 > .tax	{
	font-size: 1.4rem;
}
@media screen and (max-width: 768px)  {
.PriceInner02 > :not(.tax)	{
	font-size: 2rem;
}
}
@media screen and (max-width: 480px)  {
.PriceInner02 > :not(.tax)	{
	font-size: 1.6rem;
}
.PriceInner02 > .tax	{
	font-size: 1.2rem;
}
}


/* asterisk 箇条書き（※印）
================================================== */
dl.asterisk	{
	width: 100%;
	display: flex;
	flex-flow: row wrap;
	align-items: center;
	font-weight: 500; 
	font-size: 2rem;
}
dl.asterisk dt	{
	flex-basis: 26px;
	font-size: 1.4rem !important;
	font-weight:normal;
	padding:3px 0;
 margin: 0;
}
dl.asterisk dd	{
	padding:3px 0;
 flex-basis: calc(100% - 26px); 
}
@media screen and (max-width: 768px)  {
dl.asterisk	{
	font-size: 2rem;
}
}
@media screen and (max-width: 480px)  {
dl.asterisk	{
	font-size: 1.6rem;
}
dl.asterisk dt	{
	flex-basis: 23px;
	font-size: 1.1rem !important;
}
dl.asterisk dd	{
 flex-basis: calc(100% - 23px); 
}
}


/* 入校手順（左側）
================================================== */
.Plan_process	{
	width: 100%;
	padding: 35px;
	background-color: #ffffff;
	border-radius: 20px;
	position:relative;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	margin-bottom: 50px;
}
.Plan_process::after {
	content: "";
	width: 15px;
	height: 50px;
	background: #ffffff;
	display: block;
	position: absolute;
	bottom:-50px;
	left: 50%;
 transform: translateX(-50%);
}
.Plan__Box .Plan__Box_Left .Plan_process:last-child::after {
	display: none;
}
@media screen and (max-width: 480px)  {
.Plan_process	{
	padding: 35px 20px;
	margin-bottom: 30px;
}
}


.Heading__h2_process	{
	font-weight:500;
	font-size:2.4rem;
	color: #272343;
	line-height: normal;
	position:absolute;
	background-color:#E67A7A;
	display: inline-block;
	text-align: center;
	width: 240px;
	padding: 5px 0px;
	top:-30px;
	left: 50%;
 transform: translateX(-50%);
	box-shadow: 5px 5px 0px 0px rgba(0, 0, 0, 0.1);
}

@media screen and (max-width: 480px)  {
.Heading__h2_process	{
	font-size:2rem;
	width: 160px;
	top:-20px;
}
}

.Heading__h3_process	{
	font-weight:600;
	font-size:2.4rem;
	color:#E67A7A;
	line-height: normal;
	text-align: center;
	margin: 0 0 15px;
}
.Heading__h3_process div	{
	font-weight:600;
	font-size:1.8rem;
	color:#E67A7A;
	line-height: normal;
}
@media screen and (max-width: 480px)  {
.Heading__h3_process	{
	font-size:2rem;
	margin: 0 0 15px;
}
.Heading__h3_process div	{
	font-size:1.6rem;
}
}

/* free_dial__wrap（電話）
================================================== */
.free_dial__wrap	{
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
}
.free_dial a	{
	display:inline-flex;
	align-items: center;
	font-family: "Noto Serif", serif;
	font-size: 3rem;
	line-height: 1;
	margin-bottom: 20px;
}
.rec_hours	{
	font-weight: 500;
	font-size: 1.4rem;
}
@media screen and (max-width: 768px)  {
.free_dial a	{
	font-size: 3rem;
}
}
@media screen and (max-width: 480px)  {
.free_dial__wrap	{
	margin: 0 0 0 0px;
}
.free_dial a	{
	font-size: 2.4rem;
	margin-bottom: 10px;
}
.rec_hours	{
	font-size: 1.4rem;
	margin-left: 0px;
}
}

/* 箇条書き（点）
================================================== */
.point_disc ul	{
 padding: 0.2em 0.5em 0.2em 2em;/*ボックス内の余白*/
 list-style:disc;
	font-size: 2rem;
	margin-bottom: 15px;
}
.point_disc ul li	{
 padding-bottom: 0px !important;
}
@media screen and (max-width: 480px)  {
.point_disc ul	{
 padding: 0.2em 0.2em 0.2em 2em;/*ボックス内の余白*/
	font-size: 1.7rem;
}
}


/* 手順（内枠）
================================================== */
.Plan__comment	{
	width: 90%;
	margin: 0 auto 10px;
}
.Plan__comment .left	{
	float: left;
}
.Plan__comment .right	{
	float: right;
}
@media screen and (max-width: 898px)  {
.Plan__comment .left	{
	clear:both;
}
.Plan__comment .right	{
	clear:both;
}
}

.Plan__comment02	{
	width: 90%;
	margin: auto;
	display: flex;
	justify-content: space-between;
	align-items:flex-end;
}
.Plan__comment03	{
	width: 90%;
	margin: 20px auto 0;
	display: flex;
	justify-content: space-between;
	align-items:center;
}
@media screen and (max-width: 898px)  {
.Plan__comment03	{
	justify-content: center;
}
}

.icon_harinezumi	{
	margin-left: 5px;
}
.icon_bus	{
	width: 150px;
	margin-right: 10px;
}
@media screen and (max-width: 898px)  {
.icon_bus	{
	margin-right: 20px;
}
}
@media screen and (max-width: 480px)  {
.icon_bus	{
	width: 100px;
}
}
	
	
/* 吹き出し
================================================== */
.speechBubble_Right {
  position: relative;
  margin-right: 16px;
  padding: 16px 25px;
  border-radius: 30px;
  background-color: #b4c7e7;
  text-align: left;
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 1.5;
  color: #272343;
		width: 200px;
		margin-bottom: 10px;
}
.speechBubble_Right::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 2px;
  border-style: solid;
  border-width: 8px 0 8px 16px;
  border-color: transparent transparent transparent #b4c7e7;
  translate: 100% -50%;
}
@media screen and (max-width: 480px)  {
.speechBubble_Right {
  padding: 10px 20px;
  font-size: 1.4rem;
}
}

.speechBubble_Left {
  position: relative;
  margin-left: 16px;
  padding: 16px 25px;
  border-radius: 30px;
  background-color: #dae3f3;
  text-align: left;
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 1.5;
  color: #272343;
		width: 200px;
}
.speechBubble_Left::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 2px;
  border-style: solid;
  border-width: 8px 16px 8px 0;
  border-color: transparent #dae3f3 transparent transparent;
  translate: -100% -50%;
}
@media screen and (max-width: 480px)  {
.speechBubble_Left {
  padding: 10px 15px;
  font-size: 1.4rem;
}
.speechBubble_Left br {
	display: none;
}
}

.speechBubble_Right02 {
  position: relative;
  display: inline-block;
  margin-right: 16px;
  padding: 16px;
  border-radius: 12px;
  background-color: #9ddcdc;
  text-align: left;
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 1.5;
  color: #272343;
}
.speechBubble_Right02::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 0;
  border-style: solid;
  border-width: 8px 0 8px 16px;
  border-color: transparent transparent transparent #9ddcdc;
  translate: 100% -50%;
}
@media screen and (max-width: 480px)  {
.speechBubble_Right02 {
  padding: 10px;
  font-size: 1.4rem;
}
}

.speechBubble_Right03 {
  position: relative;
  font-size: 1.8rem;
  font-weight: 500;
  line-height: 1.5;
  color: #272343;
		margin-left: 20px;
		max-width: 165px;
		width: 100%;
}
@media screen and (max-width: 480px)  {
.speechBubble_Right03 {
  font-size: 1.5rem;
		margin-left: 0px;
		max-width: 140px;
}
}
	
	

.orange	{
	color: #f45d48;
}

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

文字サイズ

------------------------------------------------- */
.fs20,.fs18,.fs14	{
	font-weight: 400;
}
.fs24	{
	font-size: 2.4rem;
	font-weight: 500;
}
.fs24_NS	{
	font-size: 2.4rem;
	line-height: 1;
	font-family: "Noto Serif", serif;
	letter-spacing: 0.08em;
}

.fs20	{
	font-size: 2rem;
	line-height: 2;
}
.fs18	{
	font-size: 1.8rem;
	line-height: 2;
}
.fs16	{
	font-size: 1.6rem;
}
.fs14	{
	font-size: 1.4rem;
}
@media screen and (max-width: 768px)  {
.fs24	{
	font-size: 2rem;
}
.fs18	{
	font-size: 1.6rem;
	line-height: 1.8;
}
}
@media screen and (max-width: 480px)  {
.fs24	{
	font-size: 1.7rem;
}
.fs24_NS	{
	font-size: 1.8rem;
}
.fs20	{
	font-size: 1.7rem;
	line-height: 1.7;
}
.fs18	{
	font-size: 1.5rem;
	line-height: 1.6;
}
.fs16	{
	font-size: 1.4rem;
}
}


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

文字間

------------------------------------------------- */
.spacing	{
	letter-spacing:0.12em !important;
	text-indent: 0.12em !important;
}


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

余白

------------------------------------------------- */
.mt_10px	{
	margin: 10px 0 0;
}
.mt_30px	{
	margin: 20px 0 0;
}
@media screen and (max-width: 768px)  {

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

}

.tag {
 position: relative;
}
.tag_inner {
 padding: 0.7em 1.5em 0.7em;
 background: #FFC000;
 position: absolute;
	transform:rotate(-30deg);
	top:10px;
	left: -50px;
	line-height: 1;
	letter-spacing: 0.2em;
	font-size: 2rem;
	font-weight: 500;
	color: #272343;
	box-shadow: 5px 5px 0px 0px rgba(0, 0, 0, 0.1);
}
@media screen and (max-width: 768px)  {
.tag_inner {
	font-size: 1.8rem;
}
}
@media screen and (max-width: 568px)  {
.tag_inner {
	top:-8px;
	left: -20px;
}
}
@media screen and (max-width: 480px)  {
.tag_inner {
 padding: 0.7em 1.1em 0.7em;
	transform:rotate(-20deg);
	top:-20px;
	left: -5px;
	letter-spacing: 0.1em;
	font-size: 1.6rem;
}
}

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

文字下線

------------------------------------------------- */
.under {
  background: linear-gradient(transparent 70%, #ffc000 70%);
}
