@charset "UTF-8";
/* CSS Document */

/* headerArea
------------------------------------------- */

#page-top #headerArea {
	position: relative;
	background: #E1F3FC;
	padding-bottom: 49px;
}

#page-top #headerArea .header_wave {
	position: absolute;
	bottom: -46px;
	width: 100vw;
	z-index: 1;
}

/* mainvisual
------------------------------------------- */

#page-top #mainvisual {
	position: relative;
	z-index: 2;
}

#page-top #mainvisual h2 {
	position: absolute;
	top: 15%;
	left: 7%;
	width: 50%;
	z-index: 7;
	font-size: 3rem;
	background: rgba(255,255,255,0.42);
	padding: 20px;
}

#page-top #mainvisual .img01 {
	text-align: right;
	position: relative;
	z-index: 5;
}

#page-top #mainvisual .img02 {
	position: absolute;
	bottom: 10%;
	left: 5%;
	z-index: 4;
}

#page-top #mainvisual .img02 img {
	width: 38vw;
}

#page-top #mainvisual .hd_time {
	max-width: 390px;
	background: #fff;
	border-radius: 30px;
	padding: 2px 13px 13px 13px;
	box-shadow: 5px 5px 18px 0px rgba(0, 0, 0, 0.3);
	font-size: 1.4rem;
	position: absolute;
	left: 10%;
	bottom: 5%;
	z-index: 7;
}

#page-top #mainvisual .hd_time table caption {
	font-size: 1.6rem;
	font-weight: 600;
	margin-bottom: 10px;
	padding-top: 1.3em;
	background-image: url("../img/top/ic_time.png");
	background-position: left 65% top;
	background-repeat: no-repeat;
}

#page-top #mainvisual .hd_time table th,
#page-top #mainvisual .hd_time table td {
	padding: 5px;
}

#page-top #mainvisual .hd_time table td {
	vertical-align: middle;
	text-align: center;
}

#page-top #mainvisual .hd_time table tbody td,
#page-top #mainvisual .hd_time table tbody th {
	border-top: 1px solid #999;
	border-bottom: 1px solid #999;
}

#page-top #mainvisual .hd_time table tbody th {
	padding-right: 20px;
}

#page-top #mainvisual .hd_bnr {
	max-width: 1000px;
	width: 100%;
	margin: 0 auto;
	display: flex;
	justify-content: space-around;
	margin-top: 50px;
}

#page-top #mainvisual .hd_bnr li:hover img {
	opacity: 0.7;
}

@media screen and (max-width: 960px) {
	#page-top #mainvisual h2 {
		position: absolute;
		top: auto;
		bottom: 0;
		left: 50%;
		transform: translateX(-50%);
		-webkit-transform: translateX(-50%);
		-ms-transform: translateX(-50%);
		width: 90%;
		font-size: clamp(1rem, 0.636rem + 1.82vw, 2rem);
		background: rgba(255,255,255,0.6);
	}
	
	#page-top #mainvisual .img02 {
		position: absolute;
		bottom: 0;
		left: 3%;
		z-index: 4;
	}
	
	#page-top #mainvisual .img02 img {
		width: 45vw;
	}
	
	#page-top #mainvisual .hd_time {
		display: none;
	}
}

@media screen and (max-width: 767px) {
	#page-top #mainvisual h2 {
		bottom: -50px;
	}
}


/* wrap_greeting
------------------------------------------- */

#page-top #wrap_greeting {
	padding: 5vh 0 0 0;
	background-image: url("../img/top/greeting_img_cloud_01.png"),url("../img/top/greeting_img_cloud_02.png");
	background-position: right top,left bottom;
	background-repeat: no-repeat;
}

#page-top #wrap_greeting_in {
	display: flex;
	justify-content: space-between;
	flex-direction: row-reverse;
}

#page-top #wrap_greeting_in.unitBlock {
	margin-bottom: 5vh;
}

#page-top #wrap_greeting_in .text {
	flex-basis: 70%;
}

#page-top #wrap_greeting_in .img {
	flex-basis: 30%;
	margin-right: 30px;
}

#page-top #wrap_greeting_in .img img {
	border-radius: 30px;
}

#page-top #wrap_greeting_in h2 {
	font-size: clamp(2rem, 1.782rem + 1.09vw, 2.6rem);
	color: #0071bc;
	margin-bottom: 5vh;
}

@media screen and (max-width: 767px) {
	#page-top #wrap_greeting {
		background-size: 250px,260px;
	}
}

@media screen and (max-width: 640px) {
	#page-top #wrap_greeting_in {
		flex-wrap: wrap;
		justify-content: flex-end;
	}
	
	#page-top #wrap_greeting_in .text {
		flex-basis: 100%;
	}

	#page-top #wrap_greeting_in .img {
		flex-basis: 100%;
		margin-right: 0;
	}
	
	#page-top #wrap_greeting_in .img img {
		max-width: 300px;
		width: 100%;
	}
}

/* wrap_flow
------------------------------------------- */

#page-top #wrap_contact {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	grid-template-rows: 1fr auto;
	grid-column-gap: 0px;
	grid-row-gap: 0px;
	border: 1px solid #ccc;
	border-radius: 30px;
	position: relative;
	margin-top: 10vh;
}

#page-top #wrap_contact .box_01 {
	grid-area: 1 / 1 / 2 / 3;
	border-bottom: 1px solid #ccc;
	display: flex;
	justify-content: center;
	align-items: center;
	padding: 30px;
}

#page-top #wrap_contact .box_01 div:nth-child(1) {
	font-size: clamp(2rem, 1.818rem + 0.91vw, 2.5rem);
	font-weight: 700;
	color: #0071bc;
	white-space: nowrap;
	padding-right: 2em;
}

#page-top #wrap_contact .box_02 {
	grid-area: 2 / 1 / 3 / 2;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-wrap: wrap;
	height: 100%;
	padding: 30px;
}

#page-top #wrap_contact .box_02 div {
	background: url("../img/beginner/contact_tel.png") left center no-repeat;
	background-size: 50px auto;
	padding-left: 60px;
}

#page-top #wrap_contact .box_02 strong {
	color: #0071bc;
	font-size: clamp(2rem, 1.455rem + 2.73vw, 3.5rem);
	letter-spacing: 0.1em;
	line-height: 1;
	font-family: "Noto Sans JP", sans-serif;
	font-optical-sizing: auto;
	font-weight: 500;
	font-style: normal;
}

#page-top #wrap_contact .box_02 span {
	letter-spacing: 0.3em;
	font-size: 1.3rem;
	padding-right: 0.5em;
	width: 100%;
}

#page-top #wrap_contact .box_03 {
	grid-area: 2 / 2 / 3 / 3;
}

#page-top #wrap_contact .box_03 a {
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 0 0 30px 0;
	background: #e9ad94;
	padding: 30px;
}

#page-top #wrap_contact .box_03 a:hover {
	background: #db7d5d;
}

#page-top #wrap_contact .box_03 a span {
	font-size: clamp(2rem, 1.782rem + 1.09vw, 2.6rem);
	font-weight: 700;
	color: #fff;
	background: url("../img/beginner/contact_web_epark.png") right center no-repeat;
	background-size: 65px auto;
	padding: 10px 75px 10px 0;
	display: block;
}

#page-top #wrap_contact .box_img {
	position: absolute;
	right: 30px;
	top: -32px;
}

@media screen and (max-width: 640px) {
	#page-top #wrap_contact {
		display: block;
	}
	
	#page-top #wrap_contact .box_01 {
		flex-wrap: wrap;
	}
	
	#page-top #wrap_contact .box_01 div:nth-child(1) {
		width: 100%;
		margin-bottom: 3vh;
	}
	
	#page-top #wrap_contact .box_03 a {
		border-radius: 0 0 30px 30px;
	}
}

/* wrap_flow
------------------------------------------- */

#page-top #wrap_flow {
	position: relative;
}

#page-top #wrap_flow .flow_wave {
    position: absolute;
    top: 50px;
    left: 0;
    width: 100%;
    overflow: hidden;
    line-height: 0;
    transform: rotate(180deg);
	z-index: -1;
}

#page-top #wrap_flow .flow_wave svg {
    position: relative;
    display: block;
    width: calc(100% + 1.3px);
    height: 150px;
}

#page-top #wrap_flow .flow_wave .shape-fill {
    fill: #fffce0;
}

#page-top #wrap_flow h2 {
	text-align: center;
	background: url("../img/top/beginner_img_01.png") center top no-repeat;
	padding-top: 90px;
	margin-bottom: 7vh;
	font-size: clamp(2rem, 1.782rem + 1.09vw, 2.6rem);
}

#page-top #wrap_flow h2 span {
	color: #f7931e;
}

#page-top #wrap_flow_in {
	background: #fffce0;
	padding-bottom: 1vh;
}

#page-top #wrap_flow_in h3 {
	font-size: clamp(2rem, 1.782rem + 1.09vw, 2.6rem);
	text-align: center;
	color: #f7931e;
	margin-bottom: 5vh;
}

#page-top #wrap_flow_box div:first-of-type {
	display: flex;
	justify-content: space-between;
	align-items: center;
}

#page-top #wrap_flow_box figure {
	text-align: center;
	position: relative;
	padding-right: 20px;
}

#page-top #wrap_flow_box figure::after {
	content: "";
	width: 0;
	height: 0;
	border-style: solid;
	border-top: 7px solid transparent;
	border-bottom: 7px solid transparent;
	border-left: 10px solid #f7931e;
	border-right: 0;
	display: block;
	position: absolute;
	top: calc(50% - 13px);
	right: 0;
}

#page-top #wrap_flow_box figure:last-child {
	padding-right: 0;
}

#page-top #wrap_flow_box figure:last-child::after {
	display: none;
}

#page-top #wrap_flow_box .btn {
	margin-top: 5vh!important;
}

@media screen and (max-width: 640px) {
	#page-top #wrap_flow_box div:first-of-type {
		justify-content: center;
		flex-wrap: wrap;
	}
	
	#page-top #wrap_flow_box figure {
		width: 33%;
	}
}

/* wrap_concept
------------------------------------------- */

@media screen and (min-width: 768px) {
	#page-top #wrap_concept {
		background-image: url("../img/top/concept_img_02.png");
		background-position: left top;
		background-repeat: no-repeat;
		background-size: cover;
		display: flex;
		justify-content: center;
		align-items: center;
		position: relative;
		padding: 10vh 0;
	}

	#page-top #wrap_concept_in h2 {
		position: absolute;
		top: 50%;
		left: 50%;
		transform: translate(-50%, -50%);
		-webkit-transform: translate(-50%, -50%);
		-ms-transform: translate(-50%, -50%);
		z-index: 5;
	}

	#page-top #wrap_concept_in {
		position: relative;
		padding: 0px;
		margin: 0px;
		width: 54em;
		height: 53em;
		list-style: none;
	}
	#page-top #wrap_concept_in > div {
		display: flex;
		justify-content: center;
		align-items: center;
		align-content: center;
		flex-wrap: wrap;
		position: absolute;
		width: 29.5em;
		height: 29.5em;
		box-sizing: border-box;
		border-radius: 50%;
		background-color: rgba(253,242,247,0.5);
	}
	#page-top #wrap_concept_in .text01 {
		top: 0px;
		left: 50%;
		transform: translateX(-50%);
		padding: 0px 0.5em;
	}
	#page-top #wrap_concept_in .text02 {
		bottom: 0px;
		left: 0px;
		padding: 0px 2.5em 0px 0.5em;
	}
	#page-top #wrap_concept_in .text03 {
		bottom: 0px;
		right: 0px;
		padding: 0px 0.5em 0px 2.5em;
	}

	#page-top #wrap_concept_in h3 {
		color: #d4145a;
		text-align: center;
		font-size: 2.2rem;
		margin-bottom: 5vh;
		width: 100%;
	}

	#page-top #wrap_concept_in .text01 h3 {
		margin-top: -50px;
	}

	#page-top #wrap_concept_in p {
		width: 60%;
		text-shadow: 0px 0px 10px rgba(255, 255, 255, 1);
	}
}

@media screen and (max-width: 767px) {
	#page-top #wrap_concept {
		background-image: url("../img/top/concept_img_02.png");
		background-position: center center;
		background-repeat: no-repeat;
		background-size: cover;
		position: relative;
		padding: 10vh 5vw;
	}
	
	#page-top #wrap_concept_in {
		margin: 0 auto;
		text-align: center;
	}
	
	#page-top #wrap_concept_in h2 {
		position: relative;
	}
	
	#page-top #wrap_concept_in > div {
		display: flex;
		justify-content: center;
		align-items: center;
		align-content: center;
		flex-wrap: wrap;
		width: 70%;
		aspect-ratio: 1/1;
		box-sizing: border-box;
		border-radius: 50%;
		background-color: rgba(255,255,255,0.7);
		margin: 20px auto 0;
	}
	
	#page-top #wrap_concept_in h3 {
		color: #d4145a;
		text-align: center;
		font-size: 2.2rem;
		margin-bottom: 2vh;
		width: 100%;
	}

	#page-top #wrap_concept_in p {
		width: 60%;
		text-shadow: 0px 0px 10px rgba(255, 255, 255, 1);
	}
}

/* wrap_concept
------------------------------------------- */

#page-top #wrap_equipment {
	background: #fffce0;
	padding: 10vh 0;
}

#page-top #wrap_equipment_in {
	background: url("../img/top/equipment_bg_mask.png") center center no-repeat;
	background-size: 90% 100%;
	padding: 10vh 0 7vh;
	position: relative;
}

#page-top #wrap_equipment_in h2 {
	margin-bottom: 5vh;
	font-size: clamp(2rem, 1.782rem + 1.09vw, 2.6rem);
	text-align: center;
	color: #0071bc;
}

#page-top #wrap_equipment_in > p {
	width: 60%;
	margin: 0 auto 5vh;
	text-align: center;
}

#page-top #wrap_equipment_in .swiper-wrapper {
	width: 80%;
}



/* 前へ次への矢印カスタマイズ */
.swiper-button-prev::after,
.swiper-button-next::after,
.swiper-button-prev::before,
.swiper-button-next::before {
  bottom: 0;
  content: ""!important;
  height: 0;
  margin: auto;
  position: absolute;
  top: 0;
  width: 0;
}

.swiper-button-prev::before,
.swiper-button-next::before{
   width: 80px!important;
	height: 80px!important;
	-webkit-border-radius: 50%;
	border-radius: 50%;
	background: rgba(255,255,255,0.7)!important;
}

.swiper-button-next::after{
    right: calc(20% + 30px);
	width: 20px;
	height: 20px;
	border-top: 3px solid #0071bc;
	border-right: 3px solid #0071bc;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
}

.swiper-button-next::before {
	right: 20%;
}

.swiper-button-prev::after{
    left: calc(20% + 30px);
	width: 20px;
	height: 20px;
	border-top: 3px solid #0071bc;
	border-right: 3px solid #0071bc;
	-webkit-transform: rotate(-135deg);
	transform: rotate(-135deg);
}

.swiper-button-prev::before {
	left: 20%;
}


#page-top #wrap_equipment_in ul {
	width: 100%;
	margin: 0 auto;
}

#page-top #wrap_equipment_in ul li h3 {
	text-align: center;
	margin: 10px 0;
	font-size: 2rem;
	font-weight: 700;
	color: #0071bc;
}

#page-top #wrap_equipment_in ul li p {
	width: 80%;
	margin: 0 auto;
}

#page-top #wrap_equipment_in ul li img {
	width: 100%;
	border-radius: 30px;
}

#page-top #wrap_equipment_in .btn {
	margin-top: 5vh!important;
}

#page-top #wrap_equipment_in .img01 {
	position: absolute;
	top: 0;
	right: 7%;
}

#page-top #wrap_equipment_in .img02 {
	position: absolute;
	top: 0;
	left: 7%;
}

#page-top #wrap_equipment_in .img03 {
	position: absolute;
	bottom: 0;
	right: 10%;
}

@media screen and (max-width: 767px) {
	#page-top #wrap_equipment_in {
		background: url("../img/top/equipment_bg_mask_sp.png") center center no-repeat;
		background-size: 95% 100%;
	}
	
	#page-top #wrap_equipment_in .img01 {
		right: 0;
		width: 100px;
	}
	#page-top #wrap_equipment_in .img02 {
		top: 10%;
		left: 0;
		width: 110px;
	}
	#page-top #wrap_equipment_in .img03 {
		right: 5%;
		width: 70px;
	}
}

/* wrap_service
------------------------------------------- */

#page-top #wrap_service dl {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
}

#page-top #wrap_service dl dt {
	text-align: center;
	font-size: clamp(2rem, 1.891rem + 0.55vw, 2.3rem);
	color: #736357;
	font-weight: 700;
	margin-bottom: 10px;
}

#page-top #wrap_service dl dt img {
	display: block;
	margin: 0 auto 3vh;
}

#page-top #wrap_service dl a {
	display: block;
	padding: 30px;
	position: relative;
	overflow: hidden;
	width: 100%;
	height: 100%;
}

#page-top #wrap_service dl a::before,
#page-top #wrap_service dl a::after {
  content: "";
  display: block;
  position: absolute;
  margin: auto;
  top: 0;
  left: 0;
  margin: auto;
  transition: .3s cubic-bezier(0.45, 0, 0.55, 1);
  opacity: 0;
}
#page-top #wrap_service dl a::before {
  background: rgba(0,113,188,.6);
  width: 100%;
  height: 100%;
}
#page-top #wrap_service dl a::after {
  color: #fff;
  content: "Read More";
  font-size: 22px;
  font-weight: bold;
  display: flex;
  text-align: center;
  justify-content: center;
  align-items: center;
  bottom: 0;
  right: 0;
}
 
#page-top #wrap_service dl a:hover::before,
#page-top #wrap_service dl a:hover::after {
  opacity: 1;
}

#page-top #wrap_service dl div:nth-child(odd) {
	background: #d3edfb;
}

#page-top #wrap_service dl div:nth-child(even) {
	background: #e8f5fa;
}

@media screen and (max-width: 640px) {
	#page-top #wrap_service dl {
		display: grid;
		grid-template-columns: repeat(2, 1fr);
	}
	
	#page-top #wrap_service dl div:nth-child(odd) {
	background: #d3edfb;
}

	#page-top #wrap_service dl div:nth-child(even) {
		background: #d3edfb;
	}
	
	#page-top #wrap_service dl div:nth-child(2) {
		background: #e8f5fa;
	}
	
	#page-top #wrap_service dl div:nth-child(3) {
		background: #e8f5fa;
	}
	
	#page-top #wrap_service dl div:nth-child(6) {
		background: #e8f5fa;
	}
	
	#page-top #wrap_service dl div:nth-child(7) {
		background: #e8f5fa;
	}
}

/* wrap_news
------------------------------------------- */

#page-top #wrap_news {
	position: relative;
	margin-top: 10vh;
	width: 50%;
}

#page-top #wrap_news.unitBlock {
	margin-bottom: 10px;
}

#page-top #wrap_news h2 {
	font-size: clamp(2rem, 1.782rem + 1.09vw, 2.6rem);
	font-weight: 700;
	text-align: center;
	background-position: right center;
	background-repeat: no-repeat;
	background-size: auto 100%;
	margin-bottom: 7vh;
	color: #a274aa;
}

#page-top #wrap_news h2::after {
	content: url("../img/top/ic_news.png");
	display: inline-block;
}

#page-top #wrap_news dl div {
	margin-bottom: 20px;
	border-bottom: 1px dotted #ccc;
	padding-bottom: 1em;
}

#page-top #wrap_news dl dd a {
  position: relative;
  display: block;
  overflow: hidden;
  transition: 0.5s;
  color: #0071bc;
  padding-right: 35px;
}

#page-top #wrap_news dl dd a::before,
#page-top #wrap_news dl dd a::after {
  content: "";
  position: absolute;
  top: calc(50% - 1.5px);
  right: 10px;
  width: 16px;
  height: 3px;
  border-radius: 9999px;
  background-color: #999999;
  transform-origin: calc(100% - 1.5px) 50%;
  transition: all 0.2s;
}

#page-top #wrap_news dl dd a::before {
  transform: rotate(45deg);
}

#page-top #wrap_news dl dd a::after {
  transform: rotate(-45deg);
}

#page-top #wrap_news dl dd a:hover:before,
#page-top #wrap_news dl dd a:hover:after {
  right: 0;
}

@media screen and (max-width: 960px) {
	#page-top #wrap_news {
		width: 80%;
	}
}

@media screen and (max-width: 767px) {
	#page-top #wrap_news {
		width: 96%;
	}
}
