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

/*----------------------------------------------------
  #サポート
----------------------------------------------------*/
.support_txt {
	margin-top: 50px;
	text-align: center;
}
@media (max-width: 768px) {
	.support_txt {
		margin-top: 20px;
	}
}
.support_conts {
	margin-top: 30px;
}
@media (max-width: 768px) {
	.support_conts {
		margin-top: 20px;
	}
}
.faq_btn {
	margin-top: 30px;
	text-align: center;
}
.faq_btn a {
	background: #007bff;
	border-radius: 25px;
	border-width: 1px;
	border-style: solid;
	position: relative;
	display: inline-block;
	max-width: 100%;
	padding-top: 6px;
	padding-bottom: 6px;
	text-decoration: none !important;
	text-align: center;
	cursor: pointer;
	-webkit-transition: all ease 0.3s;
	-o-transition: all ease 0.3s;
	transition: all ease 0.3s;
	vertical-align: bottom;
	background-color: #007bff;
	border-color: #fff;
	color: #fff;
	padding-right: 48px;
	padding-left: 48px;
}
.faq_btn a:hover {
	background-color: #80b5dd;
	color: #fff !important;
}
.faq_btn a span {
	line-height: 1;
	letter-spacing: 0em;
	font-weight: bold;
	overflow-wrap: break-word;
	word-break: break-all;
}
.apn_setting {
	margin-top: 50px;
	text-align: center;
}
@media (max-width: 768px) {
	.apn_setting {
		margin-top: 20px;
	}
}
.setting_ttl {
	background: #80b5dd;
	border-radius: 3px 3px 0 0;
	padding: 16px;
	line-height: 1;
	overflow-wrap: break-word;
	word-break: break-all;
	font-weight: bold;
	font-size: 2.0rem;
	color: #fff;
}
@media (max-width: 768px) {
	.setting_ttl {
		padding: 8px;
		font-size: 1.8rem;
	}
}
.setting_detail {
	padding: 16px;
	background-color: #ffffff;
	border-style: solid;
	border-color: #80b5dd;
	border-width: 2px;
	border-radius: 0 0 3px 3px;
}
@media (max-width: 768px) {
	.setting_detail {
		padding: 8px;
	}
}
.apn_btn {
	margin-top: 20px;
}
.apn_btn a {
	background: #007bff;
	border-radius: 25px;
	border-width: 1px;
	border-style: solid;
	position: relative;
	display: inline-block;
	max-width: 100%;
	padding-top: 6px;
	padding-bottom: 6px;
	text-decoration: none !important;
	text-align: center;
	cursor: pointer;
	-webkit-transition: all ease 0.3s;
	-o-transition: all ease 0.3s;
	transition: all ease 0.3s;
	vertical-align: bottom;
	background-color: #007bff;
	border-color: #fff;
	color: #fff;
	padding-right: 48px;
	padding-left: 48px;
}
.apn_btn a:hover {
	background-color: #80b5dd;
	color: #fff !important;
}
.apn_btn a span {
	line-height: 1;
	letter-spacing: 0em;
	font-weight: bold;
	overflow-wrap: break-word;
	word-break: break-all;
}
.support_contact {
	margin-top: 50px;
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: flex;
	flex-wrap: nowrap;
}
@media (max-width: 768px) {
	.support_contact {
		margin-top: 20px;
		display: block;
	}
}
.contact_box {
	flex-basis: 0;
	flex-grow: 1;
	min-width: 0;
	word-break: break-word;
	overflow-wrap: break-word;
	border-style: solid;
	border-width: 2px;
	border-color: #80b5dd;
	padding-top: 24px;
	padding-bottom: 24px;
	padding-left: 14px;
	padding-right: 14px;
	background-color: #f3f6fa;
	border-radius: 3px;
	-webkit-box-shadow: 0 1px 3px 1px rgba(0,0,0,0.08);
	box-shadow: 0 1px 3px 1px rgba(0,0,0,0.08);
	margin-left: 20px;
	text-align: center;
}
@media (max-width: 768px) {
	.contact_box {
		padding: 10px;
		margin-left: 0;
		margin-top: 10px;
	}
}
.contact_box:first-child {
	margin-left: 0;
}
.contact_ttl {
	background: #80b5dd;
	padding: 8px;
	color: #fff;
	text-align: center;
	font-weight: bold;
	border-radius: 3px;
	font-size: 1.8rem;
}
.contact_txt {
	margin-top: 20px;
}
.contact_request {
	margin-top: 20px;
}
.contact_request a {
	background: #007bff;
	border-radius: 25px;
	border-width: 1px;
	border-style: solid;
	position: relative;
	display: inline-block;
	max-width: 100%;
	padding-top: 6px;
	padding-bottom: 6px;
	text-decoration: none !important;
	text-align: center;
	cursor: pointer;
	-webkit-transition: all ease 0.3s;
	-o-transition: all ease 0.3s;
	transition: all ease 0.3s;
	vertical-align: bottom;
	background-color: #007bff;
	border-color: #fff;
	color: #fff;
	padding-right: 48px;
	padding-left: 48px;
}
.contact_request a:hover {
	background-color: #80b5dd;
	color: #fff !important;
}
.contact_request a span {
	line-height: 1;
	letter-spacing: 0em;
	font-weight: bold;
	overflow-wrap: break-word;
	word-break: break-all;
}



/*----------------------------------------------------
  #apn
----------------------------------------------------*/
.apn_conts {
	margin-top: 30px;
}
.apn_flow_img {
	margin-top: 30px;
}
@media (max-width: 768px) {
	.apn_flow_img {
		width: auto;
	}
}
.apn_flow_img img {
	width: 1000px;
}
.apn_ttl {
	background: #80b5dd;
	font-size: 2.4rem;
	line-height: 2.6rem;
	padding: 20px 0;
	text-align: center;
	color: #fff;
	margin-top: 30px;
}
.apn_sim_img {
	text-align: center;
	margin-top: 30px;
}
.apn_txt {
	margin-top: 30px;
	text-align: center;
}
.apn_subttl {
	margin-top: 30px;
}
.apn_flowtxt {
	margin-top: 30px;
}
.apn_try {
	margin-top: 30px;
}
.apn_try ul {
	display: flex;
	justify-content: center;
}
.apn_try ul li {
	background: #dde7ed;
	border-radius: 3px;
	padding: 16px;
	margin: 0 10px;
}
.apn_try ul li img {
	vertical-align: top;
	margin-right: 10px;
}
@media (max-width: 768px) {
	.apn_try ul {
		display: block;
	}

	.apn_try ul li {
		margin: 0 0 10px;
	}

	.apn_try ul li img {
		width: 20px;
	}
}
.ios_dl {
	margin-top: 20px;
	text-align: center;
	font-weight: bold;
	border: 3px solid #5FBD0D;
	background-color: #fff;
	-webkit-box-shadow: 1px 2px 5px 0 rgba(0,0,0,0.35);
	-moz-box-shadow: 1px 2px 5px 0 rgba(0,0,0,0.35);
	box-shadow: 1px 2px 5px 0 rgba(0,0,0,0.35);
}
.ios_dl a {
	display: block;
	padding: 20px;
	color: #000;
	text-decoration: none;
	font-size: 19px;
}

.apn_android_img img {
	width: 1000px;
}
@media (max-width: 768px) {
	.apn_android_img img {
		width: auto;
	}
	.apn_ios_img img {
		width: auto;
	}
}
.apn_ios_img img {
	width: 1000px;
}

/*----------------------------------------------------
  #動作確認端末
----------------------------------------------------*/
.devices_txt {
	margin-top: 30px;
	text-align: center;
}
.devices_conts {
	margin-top: 30px;
}
.device_listview {
	width: 100%;
	margin: 0 auto;
	box-sizing: border-box;
	position: relative;
}
.devices_head {
	background: #dde7ed;
	display: -webkit-box;
	display: flex;
	border: 1px solid #ccc;
	font-weight: 700;
	font-size: 14px;
}
@media (max-width: 768px) {
	.devices_head {
		display: none;
	}
}
.dv-annotation,
.devices_maker,
.devices_name,
.devices_size,
.devices_ante,
.devices_voice,
.devices_tethe {
	display: -webkit-box;
	display: flex;
	-webkit-box-flex: 0;
	flex-grow: 0;
	flex-shrink: 0;
	padding: 3px 3px 3px 8px;
	box-sizing: border-box;
	-webkit-box-align: center;
	align-items: center;
	-webkit-box-pack: justify;
	justify-content: space-between;
}
@media (max-width: 768px) {
	.dv-annotation,
	.devices_maker,
	.devices_name,
	.devices_size,
	.devices_ante,
	.devices_voice,
	.devices_tethe {
		justify-content: flex-start;
		-webkit-box-pack: center;
	}
}
.devices_name,
.devices_size,
.devices_ante,
.devices_voice,
.devices_tethe {
	border-left: 1px solid #ccc;
}
@media (max-width: 768px) {
	.devices_name,
	.devices_size,
	.devices_ante,
	.devices_voice,
	.devices_tethe {
		border-left: 0;
	}
}
.devices_maker {
	flex-basis: 160px;
	flex-shrink: 3;
	-webkit-box-flex: 1;
	flex-grow: 1;
}
@media (max-width: 768px) {
	.dv-row .devices_maker {
		flex-basis: auto;
		text-align: center;
		font-size: 1.8rem;
		font-weight: bold;
		justify-content: center;
		padding-top: .5em;
		line-height: 1.4;
	}
}
.devices_name {
	flex-basis: 200px;
	-webkit-box-flex: 2;
	flex-grow: 2;
}
@media (max-width: 768px) {
	.devices_name {
		flex-basis: auto;
		font-weight: 700;
		line-height: 1.4;
		flex-basis: auto;
	}
}
.devices_size {
	flex-basis: 120px;
	text-align: center;
}
@media (max-width: 768px) {
	.devices_size {
		flex-basis: auto;
		max-width: 300px;
		margin: 0 auto 0 0;
	}
}
.devices_ante {
	flex-basis: 98px;
}
@media (max-width: 768px) {
	.devices_ante {
		flex-basis: auto;
		max-width: 300px;
		margin: 0 auto 0 0;
	}
}
.devices_voice {
	flex-basis: 68px;
	text-align: center;
}
@media (max-width: 768px) {
	.devices_voice {
		flex-basis: auto;
		max-width: 300px;
		margin: 0 auto 0 0;
	}
}
.devices_info {
	background: #fff;
	display: -webkit-inline-box;
	display: inline-flex;
	width: 16px;
	height: 16px;
	flex-basis: 16px;
	flex-shrink: 0;
	-webkit-box-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	align-items: center;
	border-radius: 50%;
	border: 1px solid #666;
	color: #666;
	-webkit-user-select: none;
	-moz-user-select: none;
	-ms-user-select: none;
	user-select: none;
	cursor: pointer;
}
.devices_info:hover + .devices_info-box {
    display: block;
    -webkit-animation: fade .5s linear 0s;
    animation:fade .5s linear 0s
}
.devices_info-box {
	display: none;
	position: absolute;
	background: #fff;
	border: 1px solid #333;
	padding: 1em;
	top: 2em;
	right: 0;
	max-width: 75vw;
	text-align: left;
	line-height: 1.3;
}
.devices_info-ttl {
	font-size: 1.2em;
	margin: 0;
}
.devices_info-box ul {
	padding-left: 2em;
	text-indent: -2em;
	list-style-type: none;
	font-weight: 400;
	margin: 0;
}
.devices_tethe {
	flex-basis: 100px;
	text-align: center;
}
@media (max-width: 768px) {
	.devices_tethe {
		flex-basis: auto;
		max-width: 300px;
		margin: 0 auto 0 0;
	}
}
.devices_conts {

}
.dv-item {
	background: #fff;
	border: 1px solid #ccc;
	page-break-inside: avoid;
}
@media (max-width: 768px) {
	.dv-item {
		margin-top: 20px;
	}
}
.dv-row {
	display: -webkit-box;
	display: flex;
	min-height: 3em;
}
@media (max-width: 768px) {
	.dv-row {
		display: block;
		min-height: 0;
	}
}
.dv-annotation {
	background: #f6f6f6;
	flex-basis: 100%;
	font-size: 1.2rem;
	display: block;
	border-top: 1px dashed #ccc;
	padding: .8em 3px .8em 8px;
	line-height: 1.5;
}
@media (max-width: 768px) {
	.dv-annotation {
		word-break: break-all;
	}
}
.devices_conts .sp {
	display: none;
}
@media (max-width: 768px) {
	.devices_conts .sp {
		display: block;
	}
}
.apn_setting .red {
	background: #dd809d;
}
.setting_detail_red {
	padding: 16px;
	background-color: #ffffff;
	border-style: solid;
	border-color: #dd809d;
	border-width: 2px;
	border-radius: 0 0 3px 3px;
}
.read_txt {
	text-align: center;
	margin-top: 20px;
}
.payment_conts {
	text-align: center;
	margin-top: 50px;
}
@media (max-width: 768px) {
	.payment_conts {
		margin-top: 25px;
	}
}
.payment_subttl {
	line-height: 2;
	letter-spacing: 0.05em;
	text-align: center;
	font-size: 2.5rem;
	padding-top: 50px;
}
@media (max-width: 768px) {
	.payment_subttl {
		font-size: 1.7rem;
		padding-top: 20px;
	}
}
.payment_flowimg {
	margin-top: 30px;
}
@media (max-width: 768px) {
	.payment_flowimg {
		margin-top: 10px;
	}
}
.payment_flowimg img {
	width: 1000px;
	border: 2px dotted #ff0000;
}
@media (max-width: 768px) {
	.payment_flowimg img {
		width: auto;
	}
}
.payment_flowtxt {
	margin-top: 20px;
	font-size: 1.8rem;
	font-weight: bold;
}
@media (max-width: 768px) {
	.payment_flowtxt {
		font-size: 1.4rem;
	}
}
.triangle_icon {
	margin-top: 30px;
	text-align: center;
}
@media (max-width: 768px) {
	.triangle_icon {
		margin-top: 20px;
	}
	.triangle_icon img {
		width: auto;
	}
}
/*--追加--*/
.ios_explanation_contsOut {
	display: flex;
	flex-wrap: wrap;
	margin: 0 -15px 0 -15px;
}

.ios_explanation_conts {
	margin-top: 30px;
	flex: 0 0 auto;
  width: calc(100% / 3 - 30px);
  padding: 0 15px 0 15px;
}
.apn_explanation_img {
	width: 100%;
}

.apn_explanation_img img {
	width: 100%;
}

@media (max-width: 768px) {
	.apn_explanation_img img {
		width: 200px;
	}
	.ios_explanation_conts {
		margin-top: 30px;
		flex: 0 0 auto;
	  width: calc(100% / 2 - 30px);
	  padding: 0 15px 0 15px;
	}
}
.apn_explanation_txt {
	width: 100%; padding: 1em 0 0 0;
	line-height: 1.8em;
}
