@charset "utf-8";

/*--------------------------------------
　Header
---------------------------------------*/
.header_home {
	position: absolute;
	top: 0;
	left: 0;
	z-index: 1;
}





/*--------------------------------------
　リンク
---------------------------------------*/
.contents_top .btn-link a {
	margin: 2rem 0 0;
}

/* SP ------------------------------*/
@media screen and (max-width: 768px) {
	.contents_top .btn-link {
		text-align: right;
	}
	.contents_top .btn-link a {
		margin: 1.5rem 0 0;
	}
}





/*--------------------------------------
　page_link
---------------------------------------*/
.page_link {
	position: fixed;
	top: 70px;
	right: 0;
	z-index: 1;
}

.page_link li {
	width: 65px;
	margin: 0 0 0.5rem;
}
.page_link li:last-child {
	margin: 0 0 0;
}
.page_link li a {
	display: flex;
	align-items: center;
	background: #fff;
	width: 100%;
	padding: 3rem 1.5rem 3rem;
	box-sizing: border-box;
	font-size: 1.2vh;
	font-weight: bold;
	line-height: 1.4;
	border: 4px solid #f89231;
	border-right: none;
	border-radius: 8px 0 0 8px;
	-webkit-writing-mode: vertical-rl;
	-moz-writing-mode: vertical-rl;
	-ms-writing-mode: tb-rl;
	-ms-writing-mode: vertical-rl;
	writing-mode: vertical-rl;
	position: relative;
    font-family: sans-serif;
}
.page_link li a:after {
	content: "";
	position: absolute;
	bottom: 10px;
	left: 0;
	right: 0;
	background: url("img/linkarrow_02.png") center bottom no-repeat;
	background-size: 100% auto;
	width: 14px;
	height: 14px;
	margin: auto;
}
.page_link li span {
	display: block;
	position: absolute;
	top: 10px;
	left: 15px;
	right: 15px;
	background: #f89231;
	padding: 0.3rem 0;
	box-sizing: border-box;
	color: #fff;
	font-size: 1rem;
	font-weight: bold;
	text-align: center;
	line-height: 1;
	-webkit-writing-mode: horizontal-tb;
	-moz-writing-mode: horizontal-tb;
	-ms-writing-mode: lr-tb;
	-ms-writing-mode: horizontal-tb;
	writing-mode: horizontal-tb;
	border-radius: 5px;
}

/* SP ------------------------------*/
@media screen and (max-width: 768px) {
	.page_link {
		display: none;
	}
}





/*--------------------------------------
　Main Index
---------------------------------------*/
.contents_top {
	width: 100%;
	min-width: 900px;
	margin: auto;
	box-sizing: border-box;
	overflow: hidden;
}
.sec {
	width: 100%;
	min-width: 900px;
	margin: auto;
	box-sizing: border-box;
	position: relative;
}
.sec .inner {
	max-width: 900px;
	margin: auto;
	box-sizing: border-box;
}

/* SP ------------------------------*/
@media screen and (max-width: 768px) {
	.contents_top {
		min-width: 100%;
	}
	.sec {
		min-width: 100%;
	}
	.sec .inner {
		max-width: 100%;
	}
}





/*--------------------------------------
　MV
---------------------------------------*/
.top_mv {
	background: url("img/top_mv_bg.jpg") center bottom no-repeat;
	background-size: cover;
	width: 100%;
	min-width: 900px;
	padding: 5rem 0 0;
	box-sizing: border-box;
	position: relative;
	z-index: -1;
	overflow: hidden;
}

.top_mv .mv_inner {
	max-width: 900px;
	margin: auto;
	box-sizing: border-box;
}

.top_mv .mv_ttl_wrap {
	max-width: 590px;
	margin: auto;
	text-align: center;
}

.top_mv .mv_ttl {
	font-size: 4.8rem;
	font-weight: bold;
}
.top_mv .mv_ttl span {
	font-weight: bold;
}
.top_mv .mv_ttl .sb {
	display: block;
	background: #fff;
	margin: 0 0 1.5rem;
	padding: 1rem 2rem;
	box-sizing: border-box;
	color: #eb821e;
	font-size: 2.6rem;
	border: 6px solid #f78a23;
	border-radius: 100px;
	position: relative;
}
.top_mv .mv_ttl .sb:before {
  content: "";
  position: absolute;
  bottom: -20px;
  left: 50%;
  margin-left: -8px;
  border: 8px solid transparent;
  border-top: 12px solid #fff;
  z-index: 2;
}
.top_mv .mv_ttl .sb:after {
  content: "";
  position: absolute;
  bottom: -32px;
  left: 50%;
  margin-left: -10px;
  border: 10px solid transparent;
  border-top: 16px solid #f78a23;
  z-index: 1;
}
.top_mv .mv_ttl .spn01 {
	color: #eb821e;
}

.top_mv .mv_txt_box {
	background: #fff;
	max-width: 590px;
	margin: 3rem auto 0;
	padding: 4rem 4rem;
	box-sizing: border-box;
	position: relative;
	z-index: 1;
}
.top_mv .mv_txt_box:before,
.top_mv .mv_txt_box:after {
	content: "";
	position: absolute;
	top: -100px;
	background: url("img/top_mv_wifi.gif") left top no-repeat;
	background-size: 100% auto;
	width: 194px;
	height: 363px;
}
.top_mv .mv_txt_box:before {
	right: 100%;
	margin: 0 3rem 0 0;
}
.top_mv .mv_txt_box:after {
	left: 100%;
	margin: 0 0 0 3rem;
	-webkit-transform: rotate(180deg);
	transform: rotate(180deg);
}

.top_mv .mv_txt {
	margin: 2rem 0 0;
	font-size: 1.7rem;
	font-weight: bold;
	line-height: 2;
}
.top_mv .mv_txt span {
	color: #eb821e;
	font-weight: bold;
}


.illust01 {
	position: absolute;
	bottom: 0;
	left:0;
	width: 590px;
	pointer-events: none;
}
.illust02 {
	position: absolute;
	bottom: 0;
	right:0;
	width: 590px;
	pointer-events: none;
}

@keyframes illust01 {
	0% {
			right: 100%;
	}

	100% {
			right: calc(50% - 295px);
	}
}
@keyframes illust02 {
	0% {
			left: 100%;
	}

	100% {
			left: calc(50% - 295px);
	}
}

/* SP ------------------------------*/
@media screen and (max-width: 768px) {
	.top_mv {
		background: url("img/top_mv_bg.jpg") center bottom no-repeat;
		background-size: cover;
		width: 100%;
		min-width: 100%;
		padding: 10rem 0 0;
	}

	.top_mv .mv_inner {
		max-width: 100%;
	}

	.top_mv .mv_ttl_wrap {
		max-width: 100%;
	}

	.top_mv .mv_ttl {
		font-size: 2.4rem;
	}
	.top_mv .mv_ttl .sb {
		display: inline-block;
		margin: 0 0 1rem;
		padding: 1rem 2rem;
		font-size: 1.4rem;
		border: 3px solid #f78a23;
	}
	.top_mv .mv_ttl .sb:before {
		bottom: -16px;
		margin-left: -6px;
		border: 6px solid transparent;
		border-top: 10px solid #fff;
	}
	.top_mv .mv_ttl .sb:after {
		bottom: -24px;
		margin-left: -8px;
		border: 8px solid transparent;
		border-top: 14px solid #f78a23;
	}

	.top_mv .mv_txt_box {
		max-width: 60%;
		margin: 1.5rem auto 0;
		padding: 1.5rem 1.5rem 1.5rem;
	}
	.top_mv .mv_txt_box:before,
	.top_mv .mv_txt_box:after {
		top: -10px;
		background: url("img/top_mv_wifi.gif") left top no-repeat;
		background-size: contain;
		width: 25%;
		height: 0;
		padding-top: calc(25%*363/194);
	}
	.top_mv .mv_txt_box:before {
		right: 100%;
		margin: 0 0.5rem 0 0;
	}
	.top_mv .mv_txt_box:after {
		left: 100%;
		margin: 0 0 0 0.5rem;
	}

	.mv_txt.sp_only {
		padding: 3rem 1.5rem;
		box-sizing: border-box;
		line-height: 1.8;
	}
	.mv_txt.sp_only span {
		color: #eb821e;
		font-weight: bold;
	}


	.illust01 {
		width: 50%;
	    left: -32vw;
	}
	.illust02 {
		width: 50%;
	    right: -32vw;
	}
}

@keyframes illust01_sp {
	0% {
			right: 100%;
	}

	100% {
			right: 20%;
	}
}
@keyframes illust02_sp {
	0% {
			left: 100%;
	}

	100% {
			left: 20%;
	}
}






/*--------------------------------------
　Title
---------------------------------------*/
.main_ttl01 {
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
}
.main_ttl01 .icon {
	width: 260px;
	margin: -3rem 0 0 -6rem;
	box-sizing: border-box;
}
.main_ttl01 .ttl {
	width: calc(100% - 200px);
	box-sizing: border-box;
	font-size: 3.8rem;
}


.main_ttl02 {
	text-align: center;
}
.main_ttl02 .ttl {
	color: #f89231;
	font-size: 5.2rem;
	position: relative;
}
.main_ttl02 .ttl:before {
	content: "";
	display: block;
	background: url("img/icon_03.png") left top no-repeat;
	background-size: 100% auto;
	width: 108px;
	height: 58px;
	margin: 0 auto 2rem;
}
.main_ttl02 .ttl span {
	display: block;
	font-size: 3.6rem;
}
.main_ttl02 .ttl a {
	display: inline-block;
	padding: 0 6rem;
	box-sizing: border-box;
	color: #f89231;
	position: relative;
}
.main_ttl02 .ttl a:after {
	content: "";
	position: absolute;
	top: 50%;
	right: 0;
	transform: translate(0,-50%);
	background: url("img/linkarrow_02.png") left top no-repeat;
	background-size: 100% auto;
	width: 26px;
	height: 26px;
}

/* SP ------------------------------*/
@media screen and (max-width: 768px) {
	.main_ttl01 {
		display: block;
	}
	.main_ttl01 .icon {
		width: 40%;
		margin: 0 auto 0 auto;
		position: relative;
		top: -10rem;
	}
	.main_ttl01 .ttl {
		width: 100%;
		margin: -8rem 0 0;
		font-size: 6vw;
	}
	
	
	.main_ttl02 .ttl {
		font-size: 2.6rem;
	}
	.main_ttl02 .ttl:before {
		background: url("img/icon_03.png") left top no-repeat;
		background-size: 100% auto;
		width: 54px;
		height: 29px;
		margin: 0 auto 1rem;
	}
	.main_ttl02 .ttl span {
		font-size: 1.8rem;
	}
	.main_ttl02 .ttl a {
		padding: 0 3rem;
	}
	.main_ttl02 .ttl a:after {
		background: url("img/linkarrow_02.png") left top no-repeat;
		background-size: 100% auto;
		width: 18px;
		height: 18px;
	}
}





/*--------------------------------------
　テキスト
---------------------------------------*/
.txt {
	font-size: 1.7rem;
	line-height: 2;
	text-align: justify;
}
.txt span {
	color: #eb821e;
	font-weight: bold;
}

.lead {
	margin: 4rem 0 0 0;
	font-size: 1.7rem;
	line-height: 2;
}

/* SP ------------------------------*/
@media screen and (max-width: 768px) {
	.txt {
		line-height: 1.8;
	}

	.lead {
		margin: 2rem 0 0 0;
		line-height: 1.8;
	}
}





/*--------------------------------------
　table_parts
---------------------------------------*/
.table_parts table {
	background: none;
  width: 100%;
  margin: 0 0 0;
  border: none;
	border-collapse: separate;
	border-spacing: 10px;
}
.table_parts table th {
	background: #eb821e;
	text-align: left;
	font-size: 1.7rem;
	border-left: none;
	border-bottom: none;
	border-radius: 8px;
}
.table_parts thead th:nth-child(1) {
	background: none;
}
.table_parts table td {
	text-align: left;
	font-size: 1.4rem;
	border-left: none;
	border-bottom: none;
	border-radius: 8px;
}

.table_parts .caption {
	margin: 0.5rem 0 0;
	text-align: right;
}

/* SP ------------------------------*/
@media screen and (max-width: 768px) {
	.table_parts table {
		border-spacing: 5px;
	}
	.table_parts table th {
		font-size: 3.4vw;
		border-radius: 4px;
	}
	.table_parts table td {
		font-size: 1.3rem;
		border-radius: 4px;
	}
	
	.table_parts .caption {
		margin: 0.3rem 0 0;
		font-size: 7px;
	}
}





/*--------------------------------------
　arrow
---------------------------------------*/
.arrow {
	width: 54px;
	margin: auto;
}

/* SP ------------------------------*/
@media screen and (max-width: 768px) {
	.arrow {
		width: 30px;
	}
}





/*--------------------------------------
　toc_parts
---------------------------------------*/
.contents_top .toc_parts {
	max-width: 900px;
	margin: 8rem auto 8rem;
}

/* SP ------------------------------*/
@media screen and (max-width: 768px) {
	.contents_top .toc_parts {
		max-width: calc(100% - 3rem);
		margin: 2rem auto 6rem;
	}
}





/*--------------------------------------
　sec01
---------------------------------------*/
.sec01 {
	padding: 0 0 15rem;
}

.sec01_block .box {
	display: flex;
	justify-content: space-between;
	align-items: center;
	flex-wrap: wrap;
	margin: 0 0 6rem;
}
.sec01_block .box:last-child {
	margin: 0 0 0;
}

.sec01_block .txt_box {
	width: calc(100% - 322px);
	padding: 0 5rem 0 0;
	box-sizing: border-box;
}
.sec01_block .box:nth-child(even) .txt_box {
	order: 2;
	padding: 0 0 0 5rem;
}

.sec01_block .sub {
	display: inline-block;
	background: #4da9f0;
	padding: 0.8rem 4rem;
	color: #fff;
	font-size: 1.8rem;
	font-weight: bold;
	border-radius: 50px 50px 50px 0;
}

.sec01_block .c_name {
	margin: 2rem 0 0;
	font-size: 3.8rem;
}

.sec01_block .btn-link {
	text-align: left;
}

.sec01_block .txt {
	margin: 2rem 0 0;
}

.sec01_block .img_box {
	width: 322px;
	box-sizing: border-box;
}
.sec01_block .box:nth-child(even) .img_box {
	order: 1;
}

/* SP ------------------------------*/
@media screen and (max-width: 768px) {
	.sec01 {
		padding: 0 1.5rem 10rem;
	}
	
	.sec01_block .box {
		display: block;
		margin: 0 0 4rem;
	}

	.sec01_block .txt_box {
		width: 100%;
		padding: 0 0 0 0;
	}
	.sec01_block .box:nth-child(even) .txt_box {
		padding: 0 0 0 0;
	}

	.sec01_block .sub {
		padding: 0.5rem 2rem;
		font-size: 1.2rem;
	}

	.sec01_block .c_name {
		margin: 1rem 0 0;
		font-size: 2.6rem;
	}

	.sec01_block .btn-link {
		text-align: right;
	}

	.sec01_block .txt {
		margin: 1.5rem 0 0;
	}

	.sec01_block .img_box {
		width: 55%;
		margin: 2rem auto 0;
	}
}





/*--------------------------------------
　sec02
---------------------------------------*/
.sec02 {
	background: #f0eee7;
	padding: 0 0 10rem;
	z-index: 0;
	position: relative;
}
.sec02:before {
	content: "";
	position: absolute;
	top: 30px;
	left: 0;
	background: url("img/eng_difference.png") left top no-repeat;
	background-size: 100% auto;
	width: 130px;
	height: 1100px;
	z-index: -1;
}
.sec02:after {
	content: "";
	position: absolute;
	top: 60px;
	right: 30px;
	background: url("img/sec02_bg01.png") left top no-repeat;
	background-size: 100% auto;
	width: 196px;
	height: 272px;
	z-index: -1;
}

.sec02_block {
	margin: 5rem 0 0;
}


.sec02_block .table_parts {
	margin: 0 0 2rem;
}

.sec02_block .table_box thead th {
	width: 21.25%;
	padding: 1.5rem 0.5rem 1.5rem 1rem;
	font-size: 0;
}
.sec02_block .table_box thead th:nth-child(1) {
	width: 15%;
}
.sec02_block .table_box thead th img {
	display: inline-block;
	vertical-align: middle;
	width: 35px;
	box-sizing: border-box;
}
.sec02_block .table_box thead th .th_txt {
	display: inline-block;
	vertical-align: middle;
	width: calc(100% - 35px);
	padding: 0 0 0 0.5rem;
	box-sizing: border-box;
	font-size: 1.7rem;
	font-weight: bold;
}
.sec02_block .table_box table td {
	background: #fff;
}
.sec02_block .table_box .spn01 {
	color: #4da9f0;
	font-size: 1.7rem;
	font-weight: bold;
}
.sec02_block .table_box .spn02 {
	font-size: 1rem;
}


.sec02_bottom {
	background: #fff;
	margin: -2rem 0 0;
	padding: 4rem 8rem;
	box-sizing: border-box;
	border-radius: 20px;
}

.sec02_bottom .ttl01 {
	font-size: 2.8rem;
	text-align: center;
}
.sec02_bottom .ttl01 span {
	font-size: 3rem;
}

.sec02_bottom .txt {
	margin: 2rem 0 0;
}

/* SP ------------------------------*/
@media screen and (max-width: 768px) {
	.sec02 {
		padding: 0 0 14rem;
	}
	.sec02:before {
		display: none;
	}
	.sec02:after {
		top: 30px;
		right: 15px;
		background: url("img/sec02_bg01.png") right top no-repeat;
		background-size: contain;
		width: 30%;
		height: 0;
		padding-top: calc(30%*272/196);
	}

	.sec02 .main_ttl01 {
		padding: 0 1.5rem;
	}

	.sec02 .lead {
		padding: 0 1.5rem;
	}

	.sec02_block {
		margin: 2rem 0 0;
	}


	.sec02_block .table_parts {
		margin: 0 0 2rem;
	}
	
	.sec02_block .sp_txt {
		margin: 0 0 1rem;
		font-size: 1.4rem;
		text-align: center;
	}
	
	.sec02_block .table_box {
		margin: 0 0 1.5rem;
		overflow-x: scroll;
		-webkit-overflow-scrolling: touch;
		overflow-scrolling: touch;
	}
	.sec02_block .table_box::-webkit-scrollbar{
		height: 8px;
	}
	.sec02_block .table_box::-webkit-scrollbar-track{
		background: #fff;
		margin: 0 1rem;
		border: none;
		border-radius: 10px;
		box-shadow: none;
	}
	.sec02_block .table_box::-webkit-scrollbar-thumb {
		background: #c7c7c7;
		border-radius: 10px;
		box-shadow: none;
	}
	
	.sec02_block .table_box table {
		min-width: 768px;
		margin: 0 0 1rem;
	}
	.sec02_block .table_box table th {
		display: table-cell;
	}
	.sec02_block .table_box thead th {
		padding: 1.2rem 1rem 1.2rem 1rem;
	}
	.sec02_block .table_box thead th img {
		width: 25px;
	}
	.sec02_block .table_box thead th .th_txt {
		width: calc(100% - 25px);
		font-size: 3.4vw;
	}
	.sec02_block .table_box table td {
		display: table-cell;
	}
	.sec02_block .table_box .spn01 {
		font-size: 1.4rem;
	}
	.sec02_block .table_box .spn02 {
		font-size: 0.8rem;
	}

	.sec02_block .table_parts .caption {
		padding: 0 1.5rem;
	}


	.sec02_bottom {
		width: calc(100% - 3rem);
		margin: -1.5rem auto 0;
		padding: 3rem 2rem;
		border-radius: 10px;
	}

	.sec02_bottom .ttl01 {
		font-size: 1.7rem;
	}
	.sec02_bottom .ttl01 span {
		font-size: 1.7rem;
	}

	.sec02_bottom .txt {
		margin: 1rem 0 0;
	}
	
	
	.sec02 .btn-link {
		width: calc(100% - 3rem);
		margin: auto;
	}
}





/*--------------------------------------
　sec03
---------------------------------------*/
.sec03 {
	background: #fff;
	padding: 0 0 10rem;
	z-index: 0;
	position: relative;
}
.sec03:before {
	content: "";
	position: absolute;
	top: 30px;
	left: 0;
	background: url("img/eng_md.png") left top no-repeat;
	background-size: 100% auto;
	width: 130px;
	height: 1350px;
	z-index: -1;
}
.sec03:after {
	content: "";
	position: absolute;
	top: 60px;
	right: 0;
	background: url("img/sec03_bg01.png") left top no-repeat;
	background-size: 100% auto;
	width: 250px;
	height: 206px;
	z-index: -1;
}

.sec03_block {
	margin: 5rem 0 0;
}


.sec03_block .table_parts {
	margin: 0 0 2rem;
}

.sec03_block .table_box thead th {
	width: 26.66%;
	padding: 1.5rem 1rem 1.5rem 1rem;
	text-align: center;
	font-size: 0;
}
.sec03_block .table_box thead th:nth-child(1) {
	width: 20%;
}
.sec03_block .table_box thead th img {
	display: inline-block;
	vertical-align: middle;
	width: 45px;
	box-sizing: border-box;
}
.sec03_block .table_box thead th .th_txt {
	display: inline-block;
	vertical-align: middle;
	padding: 0 0 0 1rem;
	box-sizing: border-box;
	font-size: 1.7rem;
	font-weight: bold;
}
.sec03_block .table_box tbody th {
	font-size: 0;
}
.sec03_block .table_box tbody th img {
	display: inline-block;
	vertical-align: middle;
	width: 40px;
	box-sizing: border-box;
}
.sec03_block .table_box tbody th .th_txt {
	display: inline-block;
	vertical-align: middle;
	width: calc(100% - 40px);
	padding: 0 0 0 0.5rem;
	box-sizing: border-box;
	font-size: 1.7rem;
	font-weight: bold;
}
.sec03_block .table_box table td {
	background: #ffefa3;
}


.sec03_block .comment_parts {
	margin: 3rem 0 0;
}

.sec03_block .comment_parts_block {
	margin: 0 0 3rem;
}


.sec03_block .voice_block {
	margin: 3rem 0 0;
	padding: 0 6rem;
}

.sec03_block .ttl_wrap {
	text-align: center;
}
.sec03_block .voice_ttl {
	display: inline-block;
	padding: 0 8rem;
	font-size: 3.2rem;
	font-weight: bold;
	position: relative;
}
.sec03_block .voice_ttl:before,
.sec03_block .voice_ttl:after {
	content: "";
	display: inline-block;
	position: absolute;
	top: 50%;
	background: #fff;
	width: 60px;
	height: 4px;
	border-radius: 10px;
}
.sec03_block .voice_ttl:before {
	left: 0;
	-webkit-transform: rotate(60deg);
	transform: rotate(60deg);
}
.sec03_block .voice_ttl:after {
	right: 0;
	-webkit-transform: rotate(-60deg);
	transform: rotate(-60deg);
}

.sec03_block .voice_block_inner {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	margin: 3rem 0 0;
}

.sec03_block .voice_box {
	background: #fff;
	width: calc(50% - 1.5rem);
	padding: 4rem 4rem;
	box-sizing: border-box;
	border-radius: 20px;
	position: relative;
}
.sec03_block .voice_box:after {
	content: "";
	position: absolute;
	top: 100%;
	width: 0;
	height: 0;
	border-style: solid;
}
.sec03_block .voice_box:nth-child(odd):after {
	right: 60px;
	border-width: 0 40px 40px 0;
	border-color: transparent #fff transparent transparent;
}
.sec03_block .voice_box:nth-child(even):after {
	left: 60px;
	border-width: 0 0 40px 40px;
	border-color: transparent transparent  transparent #fff;
}

.sec03_block .voice_box .cc {
	margin: 0 0 0;
	color: #333;
	font-size: 2.2rem;
}

.sec03_block .voice_box .txt {
	margin: 2rem 0 0;
}

.sec03_block .btn-web a {
	max-width: 480px;
	margin: 8rem auto 0;
	padding: 2.2rem 8rem;
}

/* SP ------------------------------*/
@media screen and (max-width: 768px) {
	.sec03 {
		padding: 0 1.5rem 14rem;
	}
	.sec03:before {
		display: none;
	}
	.sec03:after {
		top: 30px;
		right: 15px;
		background: url("img/sec03_bg01.png") left top no-repeat;
		background-size: 100% auto;
		width: 30%;
		height: 0;
		padding-top: calc(30%*206/250);
	}

	.sec03_block {
		margin: 2rem 0 0;
	}
	
	
	.sec03_block .table_parts {
		margin: 0 0 1.5rem;
	}
	
	.sec03_block .sp_table_box table {
		margin: 0 0 1.5rem;
	}
	.sec03_block .sp_table_box table:last-child {
		margin: 0 0 0;
	}
	.sec03_block .sp_table_box table th {
		display: table-cell;
	}
	.sec03_block .sp_table_box thead th {
		width: 100%;
		padding: 1.2rem 1rem 1.2rem 1rem;
		text-align: center;
	}
	.sec03_block .sp_table_box thead th:nth-child(1) {
		background: #eb821e;
		width: 100%;
	}
	.sec03_block .sp_table_box thead th img {
		display: inline-block;
		vertical-align: middle;
		width: 35px;
		box-sizing: border-box;
	}
	.sec03_block .sp_table_box thead th .th_txt {
		display: inline-block;
		vertical-align: middle;
		padding: 0 0 0 0.5rem;
		box-sizing: border-box;
		font-size: 3.4vw;
		font-weight: bold;
	}
	.sec03_block .sp_table_box tbody th {
		width: 35%;
		padding: 1.2rem 0.5rem 1.2rem 0.5rem;
		font-size: 0;
	}
	.sec03_block .sp_table_box tbody th img {
		display: inline-block;
		vertical-align: middle;
		width: 25px;
		box-sizing: border-box;
	}
	.sec03_block .sp_table_box tbody th .th_txt {
		display: inline-block;
		vertical-align: middle;
		width: calc(100% - 25px);
		padding: 0 0 0 0.5rem;
		box-sizing: border-box;
		font-size: 3.4vw;
		font-weight: bold;
	}
	.sec03_block .sp_table_box table td {
		display: table-cell;
		background: #ffefa3;
	}


	.sec03_block .comment_parts {
		margin: 2rem 0 0;
	}

	.sec03_block .comment_parts_block {
		margin: 0 0 2rem;
	}


	.sec03_block .voice_block {
		margin: 2rem 0 0;
		padding: 0 2rem;
	}

	.sec03_block .voice_ttl {
		display: block;
		padding: 0 2rem;
		font-size: 1.8rem;
	}
	.sec03_block .voice_ttl:before,
	.sec03_block .voice_ttl:after {
		width: 40px;
		height: 2px;
	}
	.sec03_block .voice_ttl:before {
		left: -10px;
	}
	.sec03_block .voice_ttl:after {
		right: -10px;
	}

	.sec03_block .voice_block_inner {
		display: block;
		margin: 2rem 0 0;
	}

	.sec03_block .voice_box {
		width: 100%;
		margin: 0 0 2rem;
		padding: 2rem 2rem;
		border-radius: 10px;
	}
	.sec03_block .voice_box:last-child {
		margin: 0 0 0;
	}
	.sec03_block .voice_box:after {
		display: none;
	}

	.sec03_block .voice_box .cc {
		font-size: 1.8rem;
	}

	.sec03_block .voice_box .txt {
		margin: 1rem 0 0;
	}

	.sec03_block .btn-web a {
		max-width: 85%;
		margin: 3rem auto 0;
		padding: 1.8rem 4rem;
	}

	.sec03_block .btn-tel a {
		margin: 1.5rem auto 0;
	}
}





/*--------------------------------------
　toc_parts
---------------------------------------*/
.sec04 {
	background: #bbe0ea;
	padding: 0 0 10rem;
	z-index: 0;
	position: relative;
}
.sec04:before {
	content: "";
	position: absolute;
	top: 30px;
	left: 0;
	background: url("img/eng_trouble.png") left top no-repeat;
	background-size: 100% auto;
	width: 130px;
	height: 828px;
	z-index: -1;
}

.sec04 .upper {
	width: calc(100% - 162px);
	box-sizing: border-box;
	position: relative;
}

.sec04 .upper_img {
	position: absolute;
	top: 70px;
	left: 95%;
	width: 162px;
}


.sec04_block {
	margin: 5rem 0 0;
}

.sec04_block .box {
	background: #fff;
	margin: 0 0 3rem;
	padding: 4rem 6rem;
	box-sizing: border-box;
	border-radius: 20px;
	position: relative;
}
.sec04_block .box:last-child {
	margin: 0 0 0;
}
.sec04_block .box:before {
	content: "";
	position: absolute;
	top: -10px;
	left: -20px;
	background: url("img/icon_02.png") left top no-repeat;
	background-size: 100% auto;
	width: 68px;
	height: 74px;
}

.sec04_block .ttl01 {
	color: #004ba2;
	font-size: 2.4rem;
}

.sec04_block .item_wrap {
	margin: 3rem 0 0;
}

.sec04_block .item {
	margin: 0 0 3rem;
	padding: 3rem 4rem;
	box-sizing: border-box;
	border-radius: 20px;
}
.sec04_block .item:nth-child(1) {
	background: #f0eee7;
}
.sec04_block .item:nth-child(2) {
	background: #ffefa3;
	margin: 0 0 0;
}

.sec04_block .item_ttl {
	font-size: 1.9rem;
	font-weight: bold;
	text-align: center;
}

.sec04_block .txt {
	margin: 1.6rem 0 0;
}

/* SP ------------------------------*/
@media screen and (max-width: 768px) {
	.sec04 {
		padding: 0 1.5rem 5rem;
	}
	.sec04:before {
		display: none;
	}

	.sec04 .upper {
		width: 100%;
	}

	.sec04 .main_ttl01 .ttl {
		width: 80%;
	}

	.sec04 .upper_img {
		top: 20%;
		left: inherit;
		right: -10px;
		width: 22%;
	}


	.sec04_block {
		margin: 2rem 0 0;
	}

	.sec04_block .box {
		margin: 0 0 1.5rem;
		padding: 2rem 2rem;
		border-radius: 10px;
	}
	.sec04_block .box:before {
		top: -5px;
		left: -15px;
		background: url("img/icon_02.png") left top no-repeat;
		background-size: 100% auto;
		width: 34px;
		height: 37px;
	}

	.sec04_block .ttl01 {
		font-size: 1.7rem;
	}

	.sec04_block .item_wrap {
		margin: 2rem 0 0;
	}

	.sec04_block .item {
		width: 100%;
		margin: 0 0 1rem;
		padding: 2rem 2rem;
		border-radius: 6px;
	}
	.sec04_block .item:last-child {
		margin: 0 0 0;
	}

	.sec04_block .item_ttl {
		font-size: 1.8rem;
		line-height:1.5;
	}

	.sec04_block .txt {
		margin: 1rem 0 0;
	}
}





/*--------------------------------------
　sec05
---------------------------------------*/
.sec05 {
	padding: 8rem 0 14rem;
}

.sec05 .lead {
	width: 80%;
	margin: 4rem auto 0;
}


.sec05_block {
	margin: 5rem 0 0;
}


.sec05_slider {
	position: relative;
	z-index: 0;
}

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

.sec05_slider .slick-list {
	overflow: visible;
}

.sec05_slider .slick-slide {
	width: 380px;
	box-sizing: border-box;
	margin: 0 1.5rem;
}

.sec05_slider .slick-slide a {
	display: block;
	background: #ffefa3;
	padding: 3rem 3rem;
	box-sizing: border-box;
	border-radius: 20px;
}

.sec05_slider .ttl01 {
	display: flex;
	align-items: center;
	padding: 0 3rem 0 0;
	font-size: 2.2rem;
	position: relative;
}
.sec05_slider .ttl01:after {
	content: "";
	position: absolute;
	top: 50%;
	right: 0;
	transform: translate(0,-50%);
	background: url("img/linkarrow_02.png") left top no-repeat;
	background-size: 100% auto;
	width: 16px;
	height: 16px;
}

.sec05_slider .img_box {
	margin: 1.5rem 0 0;
}

.sec05_slider .txt {
	margin: 1.5rem 0 0;
	line-height: 1.8;
}

.sec05_slider .link_wrap {
	text-align: right;
}
.sec05_slider .btn-link {
	display: inline-block;
	margin: 2rem 0 0;
	padding: 0 2rem 0 0;
	font-weight: bold;
	text-decoration: underline;
	text-underline-offset: 8px;
	text-decoration-color: #f89231!important;
	text-decoration-thickness: 2px!important;
	position: relative;
}
.sec05_slider .btn-link:after {
	content: "";
	position: absolute;
	top: 50%;
	right: 0;
	transform: translate(0,-50%);
	margin: -0.2rem 0 0;
	background: url("img/linkarrow_02.png") left top no-repeat;
	background-size: 100% auto;
	width: 16px;
	height: 16px;
}


button {
  margin: 0;
  padding: 0;
  background: none;
  border: none;
  border-radius: 0;
  outline: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}

/* arrow */
.slide-arrow {
	display: block;
	position: absolute;
	top: 50%;
	transform: translate(0,-50%);
	width: 48px;
	height: 48px;
	cursor: pointer;
	z-index: 1;
}
.prev-arrow {
	left: -190px;
	background: url("img/arrow_prev.png") left top no-repeat;
	background-size: 100% auto;
}
.next-arrow {
	right: -190px;
	background: url("img/arrow_next.png") left top no-repeat;
	background-size: 100% auto;
}

.slick-slide a:focus {
  outline: none;
}
.slick-slide {
  display: none;
}
.slick-initialized .slick-slide {
  display: block;
}

/* SP ------------------------------*/
@media screen and (max-width: 768px) {
	.sec05 {
		padding: 4rem 1.5rem 5rem;
	}

	.sec05 .lead {
		width: 100%;
		margin: 2rem auto 0;
	}

	
	.sec05_block {
		margin: 2rem 0 0;
	}


	.sec05_slider .slick-list {
		overflow: hidden;
	}

	.sec05_slider .slick-slide {
		width: 100%;
		margin: 0 0.5rem;
	}

	.sec05_slider .slick-slide a {
		padding: 2rem 2rem;
		border-radius: 10px;
	}

	.sec05_slider .ttl01 {
		padding: 0 2rem 0 0;
		font-size: 2rem;
	}
	.sec05_slider .ttl01:after {
		background: url("img/linkarrow_02.png") left top no-repeat;
		background-size: 100% auto;
		width: 14px;
		height: 14px;
	}

	.sec05_slider .img_box {
		margin: 1rem 0 0;
	}

	.sec05_slider .txt {
		margin: 1rem 0 0;
	}

	.sec05_slider .btn-link {
		margin: 1.5rem 0 0;
		text-underline-offset: 5px;
		text-decoration-thickness: 1px!important;

	}
	.sec05_slider .btn-link:after {
		background: url("img/linkarrow_02.png") left top no-repeat;
		background-size: 100% auto;
		width: 14px;
		height: 14px;
	}


	/* arrow */
	.slide-arrow {
		width: 40px;
		height: 40px;
	}
	.prev-arrow {
		left: -10px;
	}
	.next-arrow {
		right: -10px;
	}
}





/*--------------------------------------
　sec06
---------------------------------------*/
.sec06 {
	background: #f0eee7;
	padding: 0 0 10rem;
	position: relative;
	z-index: 0;
}
.sec06:before {
	content: "";
	position: absolute;
	bottom: 200px;
	left: 0;
	background: url("img/eng_interview.png") left top no-repeat;
	background-size: 100% auto;
	width: 130px;
	height: 960px;
	z-index: -1;
}
.sec06:after {
	content: "";
	position: absolute;
	top: 30px;
	right: 30px;
	background: url("img/sec06_bg01.png") left top no-repeat;
	background-size: 100% auto;
	width: 198px;
	height: 170px;
	z-index: -1;
}

.sec06 .comment_parts {
	background: #f0eee7;
	margin: 0 0 3rem;
	padding: 0 0 0;
	border-radius: 0;
}


.sec06 .iv_block {
	margin: 3rem 0 0;
}

.sec06 .iv_ttl {
	padding: 0 0 0 11rem;
	font-size: 4rem;
	font-weight: bold;
	line-height: 1.4;
	position: relative;
}
.sec06 .iv_ttl:before {
	content: "";
	position: absolute;
	bottom: 0;
	left: 0;
	background: url("img/icon_04.png") left top no-repeat;
	background-size: 100% auto;
	width: 96px;
	height: 76px;
}

.sec06 .iv_block_inner {
	background: #fff;
	margin: 4rem 0 0;
	padding: 7rem 0 7rem 8rem;
	box-sizing: border-box;
	border-radius: 20px 0 0 20px;
	position: relative;
}
.sec06 .iv_block_inner:after {
	content: "";
	position: absolute;
	top: 0;
	left: 100%;
	background: #fff;
	width: 100%;
	height: 100%;
}

.sec06 .iv_box {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin: 0 0 5rem;
}
.sec06 .iv_box:last-child {
	margin: 0 0 0;
}

.sec06 .iv_box .img_box {
	width: 192px;
	box-sizing: border-box;
}

.sec06 .iv_box .txt_box {
	width: calc(100% - 192px);
	padding: 0 0 0 6rem;
	box-sizing: border-box;
}

.sec06 .iv_box .ttl01 a {
	display: inline-block;
	padding: 0 4rem 0 0;
	color: #4da9f0;
	font-size: 2.8rem;
	position: relative;
}
.sec06 .iv_box .ttl01 a:after {
	content: "";
	position: absolute;
	top: 50%;
	right: 0;
	transform: translate(0,-50%);
	background: url("img/linkarrow_04.png") left top no-repeat;
	background-size: 100% auto;
	width: 20px;
	height: 20px;
}

.sec06 .iv_box .cc {
	margin: 2rem 0 0;
	font-size: 2rem;
}

.sec06 .iv_box .txt {
	margin: 2rem 0 0;
}

.sec06 .iv_box .btn-link a {
	margin: 2rem 0 0;
}

/* SP ------------------------------*/
@media screen and (max-width: 768px) {
	.sec06 {
		padding: 0 1.5rem 5rem;
	}
	.sec06:before {
		display: none;
	}
	.sec06:after {
		display: none;
	}

	.sec06 .comment_parts {
		margin: 0 0 2rem;
	}
	
	.sec06 .comment_parts .comment_parts_block {
		padding: 0 0;
	}


	.sec06 .iv_block {
		margin: 2rem 0 0;
	}

	.sec06 .iv_ttl {
		padding: 0 0 0 6rem;
		font-size: 2.3rem;
	}
	.sec06 .iv_ttl:before {
		top: 50%;
		bottom: inherit;
		transform: translate(0,-50%);
		background: url("img/icon_04.png") left top no-repeat;
		background-size: 100% auto;
		width: 48px;
		height: 38px;
	}

	.sec06 .iv_block_inner {
		margin: 2rem 0 0;
		padding: 3rem 0 5rem 3rem;
		border-radius: 10px 0 0 10px;
	}

	.sec06 .iv_box {
		display: block;
		margin: 0 0 3rem;
	}

	.sec06 .iv_box .img_box {
		width: 20%;
	}

	.sec06 .iv_box .txt_box {
		width: 100%;
		padding: 0 0 0 0;
	}
	
	.sec06 .iv_box .ttl_box {
		display: flex;
		justify-content: space-between;
		align-items: center;
	}
	
	.sec06 .iv_box .ttl01 {
		width: 80%;
		padding: 0 0 0 4rem;
		box-sizing: border-box;
	}
	.sec06 .iv_box .ttl01 a {
		display: block;
		padding: 0 3rem 0 0;
		font-size: 1.7rem;
	}
	.sec06 .iv_box .ttl01 a:after {
		background: url("img/linkarrow_04.png") left top no-repeat;
		background-size: 100% auto;
		width: 14px;
		height: 14px;
	}

	.sec06 .iv_box .cc {
		margin: 1.5rem 0 0;
		font-size: 1.7rem;
	}

	.sec06 .iv_box .txt {
		margin: 1rem 0 0;
	}

	.sec06 .iv_box .btn-link a {
		margin: 1rem 0 0;
	}
}





/*--------------------------------------
　sec07
---------------------------------------*/
.sec07 {
	padding: 8rem 0 0;
}

.sec07 .lead {
	width: 80%;
	margin: 4rem auto 0;
}

.sec07_block {
	margin: 5rem 0 0;
}


.sec07_block .table_parts {
	margin: 0 0 2rem;
}

.sec07_block .table_box thead th {
	width: 26.66%;
	text-align: center;
}
.sec07_block .table_box thead th:nth-child(1) {
	width: 20%;
}
.sec07_block .table_box tbody th {
	text-align: center;
}
.sec07_block .table_box table td {
	background: #ffefa3;
}
.sec02_block_o .table_box table td {
	background: #ffefa3;
}

.sec07_block .comment_parts {
	background: #f0eee7;
	margin: 3rem 0 0;
	border-radius: 0;
	position: relative;
	z-index: 0;
}
.sec07_block .comment_parts:before,
.sec07_block .comment_parts:after {
	content: "";
	position: absolute;
	top: 0;
	background: #f0eee7;
	width: 100%;
	height: 100%;
	z-index: -1;
}
.sec07_block .comment_parts:before {
	right: 100%;
}
.sec07_block .comment_parts:after {
	left: 100%;
}

/* SP ------------------------------*/
@media screen and (max-width: 768px) {
	.sec07 {
		padding: 4rem 1.5rem 0;
	}

	.sec07 .lead {
		width: 100%;
		margin: 2rem auto 0;
	}

	.sec07_block {
		margin: 2rem 0 0;
	}


	.sec07_block .table_parts {
		margin: 0 0 1.5rem;
	}
	
	.sec07_block .sp_table_box table {
		margin: 0 0 1.5rem;
	}
	.sec07_block .sp_table_box table:last-child {
		margin: 0 0 0;
	}
	.sec07_block .sp_table_box table th {
		display: table-cell;
	}
	.sec07_block .sp_table_box thead th {
		width: 100%;
		text-align: center;
	}
	.sec07_block .sp_table_box thead th:nth-child(1) {
		background: #eb821e;
		width: 100%;
	}
	.sec07_block .sp_table_box tbody th {
		width: 35%;
		text-align: center;
	}
	.sec07_block .sp_table_box table td {
		display: table-cell;
		background: #ffefa3;
	}


	.sec07_block .comment_parts {
		margin: 2rem 0 0;
	}
	
	.sec07_block .comment_parts .comment_parts_block {
		padding: 0 0;
	}
}





/*--------------------------------------
　sec08
---------------------------------------*/
.sec08 {
	background: #fff;
	padding: 8rem 0 8rem;
}


.sec08_block {
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.sec08_block .txt_box {
	width: calc(100% - 288px);
	padding: 0 4rem 0 0;
	box-sizing: border-box;
}

.sec08_block .ttl a {
	padding: 0 4rem 0 0;
	color: #4da9f0;
	font-size: 3rem;
	position: relative;
}
.sec08_block .ttl a:after {
	content: "";
	position: absolute;
	top: 70%;
	right: 0;
	background: url("img/linkarrow_04.png") left top no-repeat;
	background-size: 100% auto;
	width: 20px;
	height: 20px;
}
.sec08_block .ttl a span {
	display: inline-block;
	background: #4da9f0;
	margin: 0 0 1.5rem;
	padding: 0.8rem 4rem;
	color: #fff;
	font-size: 2rem;
	border-radius: 50px 50px 50px 0;
}

.sec08_block .txt {
	margin: 2rem 0 0;
}

.sec08_block .btn-link {
	text-align: left;
}

.sec08_block .img_box {
	width: 288px;
	box-sizing: border-box;
}

/* SP ------------------------------*/
@media screen and (max-width: 768px) {
	.sec08 {
		padding: 4rem 1.5rem 5rem;
	}


	.sec08_block {
		display: block;
	}

	.sec08_block .txt_box {
		width: 100%;
		padding: 0 0 0 0;
	}

	.sec08_block .ttl a {
		display: inline-block;
		padding: 0 3rem 0 0;
		font-size: 2.2rem;
	}
	.sec08_block .ttl a:after {
		background: url("img/linkarrow_04.png") left top no-repeat;
		background-size: 100% auto;
		width: 14px;
		height: 14px;
	}
	.sec08_block .ttl a span {
		margin: 0 0 1rem;
		padding: 0.5rem 2rem;
		font-size: 1.2rem;
	}

	.sec08_block .txt {
		margin: 1rem 0 0;
	}

	.sec08_block .btn-link {
		text-align: right;
	}

	.sec08_block .img_box {
		width: 50%;
		margin: 2rem auto 0;
	}
}





/*--------------------------------------
　sec10
---------------------------------------*/
.sec10 {
	background: #fff;
	padding: 8rem 0 8rem;
}


.sec10_block {
	display: flex;
	justify-content: space-between;
	align-items: center;
	background: url("img/sec10_bg01.png") right top no-repeat;
	background-size: 120px auto;
}

.sec10_block .img_box {
	width: 286px;
	box-sizing: border-box;
}

.sec10_block .txt_box {
	width: calc(100% - 286px);
	padding: 0 0 0 4rem;
	box-sizing: border-box;
}

.sec10_block .ttl a {
	display: inline-block;
	padding: 0 4rem 0 0;
	color: #f89231;
	font-size: 3rem;
	position: relative;
}
.sec10_block .ttl a:after {
	content: "";
	position: absolute;
	top: 50%;
	right: 0;
	transform: translate(0,-50%);
	background: url("img/linkarrow_02.png") left top no-repeat;
	background-size: 100% auto;
	width: 20px;
	height: 20px;
}

.sec10_block .txt {
	margin: 2rem 0 0;
}

.sec10_block .btn-link {
	text-align: left;
}

/* SP ------------------------------*/
@media screen and (max-width: 768px) {
	.sec10 {
		background: url("img/sec10_bg01.png") left 15px top 15px no-repeat;
		background-size: 25% auto;
		padding: 4rem 1.5rem 5rem;
	}


	.sec10_block {
		display: block;
		background: none;
	}

	.sec10_block .img_box {
		width: 50%;
		margin: 2rem auto 0;
	}

	.sec10_block .txt_box {
		width: 100%;
		padding: 0 0 0 0;
	}

	.sec10_block .ttl a {
		display: block;
		padding: 0 3rem 0 0;
		font-size: 2.2rem;
	}
	.sec10_block .ttl a:after {
		background: url("img/linkarrow_02.png") left top no-repeat;
		background-size: 100% auto;
		width: 14px;
		height: 14px;
	}

	.sec10_block .txt {
		margin: 1rem 0 0;
	}

	.sec10_block .btn-link {
		text-align: right;
	}
}
