@charset "UTF-8";

/* メイン
***************************************************************************************/
/* キービジュアル */
#mv {
	background-image: url("../noc-bpo/images/img_bg_mv.png");
	background-position: center bottom;
	background-repeat: no-repeat;
	background-size: cover;
}

#visual {
	width: 1000px;
	margin: auto;
	background-image: url(../noc-bpo/images/img_mv_over.svg);
	background-repeat: no-repeat;
	background-position: right bottom;
	background-size: 352px;
	padding: 80px 0 110px;
}

#visual p {
	font-size: 28px;
	font-weight: bold;
	color: #fff;
	margin: 0;
	line-height: 1.8;
}

#visual p span {
	color: #FFC524;
}

#visual h1 {
	font-size: 56px;
	color: #fff;
	line-height: 1.1;
	margin: 45px 0 0;
	font-weight: 700;
  text-shadow: 1px 1px 5px #6a6a6a;
}


.stage01 {
	padding: 100px 0;
}

.stage01 h2 {
	text-align: center;
}

.stage01 ul {
	list-style: none;
	margin: 60px auto 0;
	padding: 50px 95px;
	background-color: #F4F4F4;
	width: 800px;
	border-radius: 10px;
	font-size: 24px;
	font-weight: bold;
	position: relative;
}

.stage01 ul::after {
	content: "";
	position: absolute;
	display: block;
	bottom: -52px;
	left: 0;
	right: 0;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 52px 122px 0 122px;
	border-color: #F4F4F4 transparent #F4F4F4 transparent;
	margin: auto;
}

.stage01 ul li {
	background-image: url(../noc-bpo/images/icon_worries.svg);
	background-position: left center;
	background-size: 44px;
	background-repeat: no-repeat;
	padding: 7px 0 7px 60px;
	margin: 0;
}

.stage01 ul li+li {
	margin-top: 40px;
}

.stage01 p {
	font-size: 30px;
	font-weight: bold;
	text-align: center;
	color: #ff6450;
	margin: 100px 0 0;
}

.stage01 p img {
	width: 180px;
	vertical-align: baseline;
	margin: 0 20px 0 30px;
}

.stage02 {
	padding: 80px 0 100px;
}

.stage02 h2 {
	font-size: 30px;
	text-align: center;
	line-height: 1.8;
}

.stage02 p {
	text-align: center;
	font-weight: 500;
	font-size: 18px;
	margin: 30px 0 0;
}

.stage02 p+p {
	margin-top: 40px;
}



.stage03 {
	padding: 100px 0;
}

.stage03 h2 {
	text-align: center;
	font-size: 30px;
	line-height: 1.8;
}

.stage03 h2+p {
	margin: 40px 0 0;
}


.stage04 {
	padding: 120px 0;
	background-color: #e0eaf2;
	position: relative;
	z-index: 2;
}

.stage04::before {
	content: "";
	position: absolute;
	display: block;
	top: 0;
	left: 0;
	right: 0;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 190px 25vw 0 25vw;
	border-color: #fff transparent #fff transparent;
	margin: auto;
}

.stage04 h2 {
	text-align: center;
	font-size: 30px;
	margin: 0;
	z-index: 3;
	position: relative;
}

.stage04 .fbox {
	margin: 100px 0 0;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}

.stage04 .fbox>div {
	width: 483px;
	border: 4px solid #2F72AB;
	border-radius: 10px;
	padding: 20px;
	background-color: #fff;
	position: relative;
}

.stage04 .fbox>div:nth-child(2) {
	border-color: #e07d00;
}

.stage04 .fbox>div:last-of-type {
	width: 100%;
	border-color: #e83817;
	margin: 80px 0 0;
}

.stage04 .fbox h3 {
	position: absolute;
	top: 0;
	left: 50%;
	margin: 0;
	background-color: #2F72AB;
	color: #fff;
	padding: 10px 0;
	width: 230px;
	transform: translate(-50%, -50%);
	text-align: center;
	font-size: 20px;
	font-weight: bold;
	border-radius: 50px;
}

.stage04 .fbox>div:nth-child(2) h3 {
	background-color: #e07d00;
}

.stage04 .fbox>div:last-of-type h3 {
	width: 333px;
	background-color: #e83817;
}

.stage04 .fbox dl {
	margin: 40px 0 0;
	padding: 0;
}

.stage04 .fbox dl dt {
	font-size: 20px;
	margin: 0;
	font-weight: bold;
	color: #2F72AB;
}

.stage04 .fbox>div:nth-child(2) dt {
	color: #e07d00;
}

.stage04 .fbox>div:last-of-type dt {
	color: #e83817;
}

.stage04 .fbox dl dd+dt {
	margin-top: 35px;
}

.stage04 .fbox dl dd {
	margin: 5px 0 0;
	padding: 0;
}

.stage04 .fbox dl dd ul {
	list-style: none;
	margin: 0;
	padding: 0;
}

.stage04 .fbox dl dd li {
	position: relative;
	display: flex;
	align-items: center;
}

.stage04 .fbox dl dd li::before {
	content: "";
	width: 12px;
	height: 12px;
	display: inline-block;
	background-color: #000;
	border-radius: 50%;
	margin: 0 4px 3px 0;
	flex-basis: 12px;
}

.stage04 .fbox dl dd dl {
	margin: 0;
	display: flex;
	flex-wrap: wrap;
}

.stage04 .fbox dl dd dl dt {
	font-size: 16px;
	color: #000;
	font-weight: 500;
	position: relative;
	width: 22%;
}

.stage04 .fbox dl dd dl dt::before {
	content: "";
	width: 12px;
	height: 12px;
	display: inline-block;
	background-color: #000;
	border-radius: 50%;
	margin: 0 4px 0 0;
	flex-basis: 12px;
}

.stage04 .fbox dl dd dl dt::after {
	content: "：";
	position: absolute;
	right: 0;
	top: 0;
}

.stage04 .fbox dl dd dl dd {
	width: 70%;
	margin: 0;
}

.stage04 .fbox dl dd dl dd+dt {
	margin: 0;
}



.stage05 {
	padding: 120px 0 0;
}

.stage05 h2 {
	text-align: center;
	font-size: 30px;
}

.stage05 h3 {
	font-size: 30px;
	font-weight: bold;
	text-align: center;
	margin: 50px 0 0;
}

.stage05 .fbox {
	display: flex;
	justify-content: space-between;
	margin: 70px 0 0;
}

.stage05 .fbox>div {
	width: 278px;
}

.stage05 .fbox>div p {
	font-size: 20px;
	font-weight: bold;
	color: #2F72AB;
	text-align: center;
	margin: 20px 0 0;
}

.stage05 .fbox>div p:first-of-type {
	width: 125px;
	margin: auto;
}

.stage05 .fbox>div p:last-of-type {
	color: #000;
	text-align: left;
	font-size: 14px;
	font-weight: normal;
}










/* タブレット
***************************************************************************************
***************************************************************************************
***************************************************************************************
***************************************************************************************/
@media screen and (max-width:1080px) {
/* メイン
***************************************************************************************/
/* キービジュアル */
#visual {
	width: auto;
  background-position: right 20px bottom;
	background-size: 30%;
	padding: 80px 20px 110px;
}


.stage01 ul {
	padding: 50px 80px;
  width: auto;
}


.stage04 {
	padding: 80px 0;
	background-color: #e0eaf2;
	position: relative;
	z-index: 2;
}

.stage04::before {
	border-width: 16vmin 25vw 0 25vw;
}

.stage04 .fbox>div {
	width: 48%;
}



.stage05 .fbox>div {
	width: 30%;
}

}

/* スマホ用
***************************************************************************************
***************************************************************************************
***************************************************************************************
***************************************************************************************/
@media screen and (max-width:767px) {


/* メイン
***************************************************************************************/
/* キービジュアル */
#mv {
	background-image: url("../noc-bpo/images/img_bg_mv.png");
	background-position: center bottom;
	background-repeat: no-repeat;
	background-size: cover;
}

#visual {
	width: auto;
	background-position: right bottom;
  background-size: 36vmin;
  padding: 10.66vmin 2.6666vmin 14.66vmin;
}

#visual p {
  font-size: 3.7333vmin;
}

#visual h1 {
  font-size: 9.3333vmin;
  margin: 6vmin 0 0;
}


.stage01 {
	padding: 13.333vmin 0;
}


.stage01 ul {
	margin: 8vmin auto 0;
	padding: 6.6666vmin 2.6666vmin;
	width: auto;
	border-radius: 10px;
	font-size: 3.2vmin;
}

.stage01 ul::after {
	bottom: -6.93333vmin;
	border-style: solid;
	border-width: 6.93333vmin 16.26666vmin 0 16.26666vmin;
	border-color: #F4F4F4 transparent #F4F4F4 transparent;
}

.stage01 ul li {
	background-size: 5.86666vmin;
	padding: 1vmin 0 1vmin 8vmin;
}

.stage01 ul li+li {
	margin-top: 5.3333vmin;
}

.stage01 p {
	font-size: 4vmin;
	margin: 13.333vmin 0 0;
}

.stage01 p img {
	width: 24vmin;
	margin: 0 2.6666vmin 0 4vmin;
}

.stage02 {
	padding: 10.666vmin 0 13.333vmin;
}

.stage02 h2 {
	font-size: 4vmin;
}

.stage02 p {
	font-size: 2.4vmin;
	margin: 4vmin 0 0;
}

.stage02 p+p {
	margin-top: 5.3333vmin;
}



.stage03 {
	padding: 13.333vmin 0;
}

.stage03 h2 {
	font-size: 4vmin;
}

.stage03 h2+p {
	margin: 5.333vmin 0 0;
}


.stage04 {
	padding: 16vmin 0;
}

.stage04::before {
	border-width: 14.333vmin 18vmin 0 18vmin;
}

.stage04 h2 {
	font-size: 4vmin;
}

.stage04 .fbox {
	margin: 13.333vmin 0 0;
  flex-direction: column;
}

.stage04 .fbox>div {
	width: auto;
	padding: 2.666vmin;
}

.stage04 .fbox>div:nth-child(2){
margin-top: 10.666vmin;
}
.stage04 .fbox>div:last-of-type {
	width: auto;
	margin: 10.666vmin 0 0;
}

.stage04 .fbox h3 {
	padding: 1.333vmin 0;
	width: 50.666vmin;
	font-size: 2.66666vmin;
}

.stage04 .fbox>div:last-of-type h3 {
	width: 50.666vmin;
}

.stage04 .fbox dl {
	margin: 5.3333vmin 0 0;
}

.stage04 .fbox dl dt {
	font-size: 2.6666vmin;
}

.stage04 .fbox dl dd+dt {
	margin-top: 4.6666vmin;
}

.stage04 .fbox dl dd {
	margin: .6666vmin 0 0;
}
.stage04 .fbox dl dd li {
	font-size: 2.13333vmin;
}
.stage04 .fbox dl dd li::before {
	width: 1.6vmin;
	height: 1.6vmin;
	margin: 0 .5333vmin .4vmin 0;
	flex-basis: 1.6vmin;
}

.stage04 .fbox dl dd dl {
	margin: 0;
	display: flex;
	flex-wrap: wrap;
}

.stage04 .fbox dl dd dl dt {
	font-size: 2.13333vmin;
	width: 16%;
}
.stage04 .fbox dl dd dl dd {
	font-size: 2.13333vmin;
}

.stage04 .fbox dl dd dl dt::before {
	width: 1.6vmin;
	height: 1.6vmin;
	margin: 0 .5333vmin .4vmin 0;
	flex-basis: 1.6vmin;
	margin: 0 .5333vmin 0 0;
	flex-basis: 1.6vmin;
}


.stage05 {
	padding: 16vmin 0 0;
}

.stage05 h2 {
	font-size: 4vmin;
}

.stage05 h3 {
	font-size: 4vmin;
	margin: 6.6666vmin 0 0;
}

.stage05 .fbox {
	margin: 9.333vmin 0 0;

}

.stage05 .fbox>div {
	width: 29vmin;
}
.stage05 .fbox>div+div{
  margin-top: 0;
}

.stage05 .fbox>div p {
	font-size: 2.6666vmin;
	margin: 2.666vmin 0 0;
}

.stage05 .fbox>div p:first-of-type {
	width: 16.6666vmin;
	margin: auto;
}

.stage05 .fbox>div p:last-of-type {
	font-size: 1.86666vmin;
}


}
