@charset "utf-8";
/* CSS Document */
/* ページ共通------------------------------------
----------------------------------------------*/
@media screen and (min-width:768px) {
	#banner {
		top: 115px;
	}
}
@media screen and (max-width:767px) {
	#banner {
		display: none;
	}
}
/* Section */
.section-inner {
	margin-left: auto;
	margin-right: auto;
	max-width: 1000px;
	width: calc(100% - 10px);
}
.section-inner.small {
	max-width: 786px;
}
/* Font Size */
.font-size-xs {
	line-height: 1.8;
	letter-spacing: 0.039em;
}
.font-size-xl {
	line-height: 1.95;
	letter-spacing: 0.055em;
}
.bold {
	font-weight: bold;
}
@media screen and (min-width:768px) {
	.font-size-xs {
		font-size: 12px;
	}
	.font-size-xl {
		font-size: 22px;
	}
}
@media screen and (max-width:767px) {
	.font-size-xs {
		font-size: 10px;
	}
	.font-size-xl {
		font-size: 14px;
	}
}
/* Page Header */
.page-header {
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
	text-align: center;
}
.page-header img {
	vertical-align: middle;
}
@media screen and (min-width:768px) {
	.page-header {
		background-image: url("../img/common/bg_page_header.jpg");
	}
}
@media screen and (max-width:767px) {
	.page-header {
		background-image: url("../img/common/bg_page_header_sp.jpg");
	}
}
/* Page Content */
.page-content {
	padding-bottom: 140px;
}
/* img */
img {
	max-width: 100%;
	height: auto;
}

/* guide---------------------------------------
----------------------------------------------*/
.guide-page-content {
	padding-bottom: 165px;
}
.guide-center {
	text-align: center;
	margin-left: auto;
	margin-right: auto;
	padding-bottom: 60px;
}
.guide-item-box {
	background: #fff;
	max-width: 940px;
	margin-left: auto;
	margin-right: auto;
	overflow: hidden;
	display: flex;
	flex-wrap: wrap;
	padding: 50px 45px;
}
.guide-item-icon {
	width: 26%;
	float: left;
	box-sizing: border-box;
	position: relative;
}
.guide-item-text {
	width: 74%;
	float: left;
	box-sizing: border-box;
	position: relative;
	padding-left: 55px;
}
.guide-arrow {
	text-align: center;
	margin-left: auto;
	margin-right: auto;
	padding: 20px 0;
}
.guide-red-ttl {
	color: #E60012;
	font-size: 20px;
	padding-top: 30px;
	font-weight: bold;
	line-height: 1.625em;
}
.guide-item-box p{
	font-size: 14px;
	padding-top: 20px;
}
.guide-btn {
	text-align: center;
	margin-left: auto;
	margin-right: auto;
	padding-top: 85px;
}
@media screen and (min-width:768px) {
	.guide-content {
		background-image: url("../img/faq/back_img.png");
		background-repeat: no-repeat;
		background-size: cover;
		width: 100%;
		max-width: 1100px;
		margin: 80px auto 0;
		padding: 76px 0 90px;
	}
	.guide-inner {
		padding: 0 7.3%;
	}
}
@media screen and (max-width:767px) {
	.guide-box {
		background-image: url("../img/faq/back_img_sp.png");
		background-repeat: no-repeat;
		background-size: cover;
	}
	.guide-inner {
		padding: 50px 20px 60px;
	}
	.guide-center {
		text-align: center;
		margin-left: auto;
		margin-right: auto;
		padding-bottom: 40px;
	}
	.guide-item-box {
		padding: 30px 40px;
	}
	.guide-item-icon {
		width: 100%;
		float: none;
		text-align: center;
		margin-left: auto;
		margin-right: auto;
	}
	.guide-item-text {
		width: 100%;
		float: none;
		padding-left: 0px;
		text-align: center;
		margin-left: auto;
		margin-right: auto;
		padding-top: 20px;
	}
	.guide-red-ttl {
		color: #E60012;
		font-size: 20px;
		padding-top: 20px;
		line-height: 1.5em;
	}
	.guide-arrow {
		padding: 15px 0;
	}
	.guide-btn {
		padding-top: 20px;
		max-width: 664px;
		width: 90%;
	}
	.guide-btn-inner {
		padding: 30px 20px 0;
	}
	.guide-page-content {
		padding-bottom: 65px;
	}
}
/* privacypolicy---------------------------------------
----------------------------------------------*/
.privacypolicy-page-content{
	padding-bottom: 140px;
}
.privacypolicy-page-content p {
	line-height: 1.5em;
}
.privacypolicy-ttl{
	font-size: 20px;
	padding-top: 50px;
	padding-bottom: 20px;
}
.privacypolicy-page-content ol{
	padding: 15px 0 0 30px;
	font-size: 14px;
	line-height: 1.3em;
	list-style-type: decimal;
}
.privacypolicy-page-content li{
	display: list-item;
	text-align: -webkit-match-parent;
	padding-bottom: 10px;
}
.privacypolicy-page-content table{
	margin:10px 0;
	border-collapse:collapse;
	display: table;
	border-spacing: 2px;
	border-color: #e0e0e0;
	margin-bottom: 20px;
}
.privacypolicy-page-content tbody{
	display: table-row-group;
	vertical-align: middle;
	border-color: inherit;
}
.privacypolicy-page-content tr{
	display: table-row;
	vertical-align: inherit;
	border-color: inherit;
}
.privacypolicy-page-content td{
	padding: 10px;
	border: 1px solid #e0e0e0;
}
.privacypolicy-page-content-p p{
	padding-bottom: 10px;
}
.privacypolicy-page-content table td a{
	text-decoration: none;
	color: #000;
}
.privacypolicy-page-content-6{
	padding: 0 0 0 30px;
	font-size: 14px;
	line-height: 1.3em;
}
.privacypolicy-page-content-p .mt10{
	margin-top: 10px;
}
.privacypolicy-page-content .dl_box{
	width: 80%;
	background: #DFDFDF;
	border: 1px solid #e0e0e0;
	overflow: hidden;
	display: flex;
	flex-wrap: wrap;
	padding: 10px;
}
.dl_box-item-img{
	width: 5%;
	float: left;
	box-sizing: border-box;
	position: relative;
}
.dl_box-item-text{
	width: 90%
}
.dl_box-item-ARimg{
	width: 21%;
	float: left;
	box-sizing: border-box;
	position: relative;
}
.dl_box-item-ARtext{
	width: 75%
}
.privacypolicy-page-content a:visited {
    color: #3E3A39;
    text-decoration: none;
}
.dl-ttl{
	padding-top: 10px;
}
@media screen and (min-width:768px) {
.privacypolicy-page-content{
	margin: 80px auto 0;
    width: 100%;
}
}
@media screen and (max-width:767px) {
	.privacypolicy-page-content{
		padding-top: 50px;
		padding-bottom: 50px;
	}
	.privacypolicy-page-content .dl_box{
		width: 95%;
}
	.privacypolicy-page-content tr{
		box-sizing:border-box;
}
	.privacypolicy-page-content table td{
		margin: 5px 0 0 10px;
		display: table;
		content: "&#149;";
		width: 100%!important;
	}
	.privacypolicy-page-content table td{
		border: none;
	}
	.privacypolicy-page-content table td:before {
		content: "・";
	}
	.privacypolicy-page-content table tr:last-child td:last-child:before {
		content: none;
	}
	.dl_box-item-img{
		width: 12%;
}
	.dl_box-item-text{
		width: 85%
}
	.dl_box-item-ARimg{
		width: 40%;
}
	.dl_box-item-ARtext{
		width: 95%
}
}
/* device---------------------------------------
----------------------------------------------*/
.device-inner {
	background-size: cover;
	background-repeat: no-repeat;
	padding: 60px 50px 100px;
}
.device-table table {
	border-collapse: collapse;
	border-spacing: 0;
	width: 100%;
}
.device-table th,
.device-table td {
	background: #fff;
	border: 1px solid #e0e0e0;
	letter-spacing: 0.099em;
	line-height: 2;
	vertical-align: middle;
}
.device-table th {
	width: 244px;
}
.device-chipset {
	background: #fff;
}
@media screen and (min-width:768px) {
	#device .page-content {
		margin: 83px auto 0;
		max-width: 1100px;
		width: 100%;
	}
	.device-inner {
		padding: 60px 50px 100px;
		background-image: url("../img/device/page_content_bg.png");
	}
	.device-table {
		padding: 74px 45px 0;
	}
	.device-table th,
	.device-table td {
		padding: 20px 30px;
		font-size: 16px;
	}
	.device-chipset {
		max-width: 910px;
		padding-top: 10px;
		padding-bottom: 25px;
		margin-top: 70px;
		margin-left: auto;
		margin-right: auto;
		box-sizing: border-box;
	}
	.device-chipset-inner {
		margin-top: 50px;
	}
}
@media screen and (max-width:767px) {
	#device .page-content {
		padding-bottom: 50px;
	}
	.device-inner {
		background-image: url("../img/device/page_content_bg_sp.png");
		padding: 70px 20px;
	}
	.device-table {
		padding-top: 30px;
		padding: 20px 0 0;
	}
	.device-table th,
	.device-table td {
		width: 100%;
		display: block;
		box-sizing: border-box;
		border-bottom: none;
		font-size: 14px;
		padding: 24px 30px;
	}
	.device-table th {
		text-align: left;
		padding-bottom: 5px;
		font-weight: bold;
	}
	.device-table td {
		padding-top: 0;
		border-top: none;
	}
	.device-chipset {
		margin-top: 20px;
		padding-top: 5px;
		padding-bottom: 30px;
	}
	.device-chipset-inner {
		margin-top: 30px;
	}
	.device-chipset-inner img {
		width: 100%;
	}
}
/* 表---------------------------------------
----------------------------------------------*/
.page-inner{
	margin-left: auto;
	margin-right: auto;
	max-width: 1000px;
	width: calc(100% - 20px);
}
.page-table table {
	border-collapse: collapse;
	border-spacing: 0;
	width: 100%;
}
.page-table th,
.page-table td {
	background: #fff;
	border: 1px solid #e0e0e0;
	letter-spacing: 0.099em;
	line-height: 2;
	vertical-align: middle;
}
.page-table th {
	width: 244px;
}
@media screen and (min-width:768px) {
	.page-content {
		margin: 80px auto 0;
		width: 100%;
	}
	.page-table {
		padding: 74px 45px 0;
	}
	.page-table th,
	.page-table td {
		padding: 20px 30px;
		font-size: 16px;
	}
}
@media screen and (max-width:767px) {
	.page-content {
		padding-bottom: 50px;
	}
	.page-table {
		padding-top: 30px;
		padding: 50px 0 0;
	}
	.page-table table{
		border-top: 1px solid #e0e0e0;
	}
	.page-table th,
	.page-table td {
		width: 100%;
		display: block;
		box-sizing: border-box;
		border-bottom: none;
		font-size: 14px;
		padding: 24px 30px;
	}
	.page-table th {
		text-align: left;
		padding-bottom: 5px;
		font-weight: bold;
		border-top: none;
	}
	.page-table td {
		padding-top: 0;
		border-top: none;
		border-bottom: none;
	}
	.page-table td:last-child{
		border-bottom: 1px solid #e0e0e0;
	}
}


/* special -----------------------------------
----------------------------------------------*/
.int-content {
	background-size: cover;
	background-repeat: no-repeat;
	background-position: top;
}
.int-box {
	background: #fff;
}
.int-box-title {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
}
.int-box-text,
.int-box-video-text {
	font-weight: bold;
	text-align: center;
}

.int-box-video-text {
	font-size: 20px;
}
.int-point-title {
	margin-left: auto;
	margin-right: auto;
}
/* モーダル内 */
.int-modal-content {
	position: relative;
	padding-bottom: 56.25%;
	height: 0;
	overflow: hidden;
}
.int-modal-content iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}
.mfp-fade button.mfp-close {
	font-size: 0;
	opacity: 1;
}
.mfp-fade button.mfp-close::before {
	position: absolute;
	content: '';
	background-image: url('../img/special/close.png');
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
	z-index: 10000;
}
.mfp-fade.mfp-bg {
    opacity: 0;
    -webkit-transition: all 0.15s ease-out; 
    -moz-transition: all 0.15s ease-out; 
    transition: all 0.15s ease-out;
}
.mfp-fade.mfp-bg.mfp-ready {
    opacity: 0.8;
}
.mfp-fade.mfp-bg.mfp-removing {
    opacity: 0;
}

.mfp-fade.mfp-wrap .mfp-content {
    opacity: 0;
    -webkit-transition: all 0.15s ease-out; 
    -moz-transition: all 0.15s ease-out; 
    transition: all 0.15s ease-out;
	background-color: rgba(35, 24, 21, 0.7);
}
.mfp-fade.mfp-wrap.mfp-ready .mfp-content {
    opacity: 1;
}
.mfp-fade.mfp-wrap.mfp-removing .mfp-content {
    opacity: 0;
}
@media screen and (min-width:768px) {
	.int-header {
		background-image: url('../img/special/bg_header.png');
		background-repeat: no-repeat;
		background-position: center;
		background-size: cover;
		text-align: center;
	}
	.int-header-image {
		width: 100%;
		max-width: 1016px;
		margin-left: auto;
		margin-right: auto;
		vertical-align: bottom;
	}
	.int-content {
		padding-top: 45px;
		padding-bottom: 95px;
		background-image: url('../img/special/back_img.png');
		margin-bottom: 80px;
	}
	.int-box {
		max-width: 1100px;
		margin-top: 35px;
		margin-left: auto;
		margin-right: auto;
	}
	.int-box-content {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-ms-flex-wrap: wrap;
		flex-wrap: wrap;
		padding-top: 60px;
		padding-right: 135px;
		padding-left: 65px;
		padding-bottom: 60px;
		box-sizing: border-box;
	}
	.int-box-title,
	.int-box-video {
		-ms-flex-preferred-size: 50%;
		flex-basis: 50%;
	}
	.int-box-title img {
		max-width: 222px;
	}
	.int-box-video a img,
	.int-box-list-item a img,
	.int-point-video a img {
		transition: opacity 0.2s ease;
	}
	.int-box-video a:hover img,
	.int-box-list-item a:hover img,
	.int-point-video a:hover img {
		opacity: 0.75;
	}
	.int-box-video-text {
		margin-top: 20px;
	}
	.int-box-list {
		margin-top: -20px;
		padding-left: 84px;
		padding-right: 84px;
		padding-bottom: 40px;
	}
	.int-box-list-inner {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-ms-flex-wrap: wrap;
		flex-wrap: wrap;
		margin-left: -10px;
		margin-right: -10px;
	}
	.int-box-list-item {
		flex-basis: calc(25% - 20px);
		max-width: calc(25% - 20px);
		margin-left: 10px;
		margin-right: 10px;
	}
	.int-box-text {
		margin-top: 10px;
		font-size: 14px;
		line-height: 1.6;
	}
	.int-box-tvcm {
		margin-top: 80px;
	}
	.int-point {
		margin-top: 35px;
	}
	.int-point-content {
		padding: 20px;
	}
	.int-point-title {
		margin-top: 50px;
		max-width: 792px;
	}
	.int-point-box {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-ms-flex-wrap: wrap;
		flex-wrap: wrap;
		padding-top: 40px;
		margin-left: -10px;
		margin-right: -10px;
	}
	.int-point-video {
		width: calc(50% - 20px);
		margin-left: 10px;
		margin-right: 10px;
		margin-top: 20px;
	}
	.mfp-fade button.mfp-close::before {
		width: 38px;
		height: 38px;
		cursor: pointer;
		top: 40px;
		right: 40px;
	}
	.mfp-fade .mfp-iframe-holder .mfp-content {
		max-width: 46.875%;
	}
}
@media screen and (max-width:767px) {
	.int-header-image {
		vertical-align: bottom;
		width: 100%;
	}
	.int-content {
		padding: 15px 20px 60px;
		background-image: url('../img/special/back_img_sp.png');
		margin-bottom: 50px;
	}
	.int-box {
		margin-top: 25px;
	}
	.int-box-title {
		padding-top: 25px;
		padding-bottom: 25px;
	}
	.int-box-title img {
		max-width: 142px;
	}
	.int-box-video img {
		vertical-align: bottom;
	}
	.int-box-video-text {
		margin-top: 15px;
	}
	.int-box-list {
		max-width: 67.1875%;
		margin-left: auto;
		margin-right: auto;
	}
	.int-box-list-inner {
		padding-top: 10px;
		padding-bottom: 30px;
	}
	.int-box-text {
		margin-top: 10px;
		line-height: 1.5;
	}
	.int-box-list-item {
		margin-top: 30px;
	}
	.int-box-tvcm {
		margin-top: 45px;
	}
	.int-point {
		margin-top: 10px;
	}
	.int-point-content {
		padding: 10px;
	}
	.int-point-title {
		margin-top: 15px;
		max-width: 235px;
	}
	.int-point-box {
		margin-top: 15px;
	}
	.int-point-video {
		margin-top: 10px;
	}
	.int-point-video img {
		width: 100%;
	}
	.mfp-fade button.mfp-close::before {
		width: 38px;
		height: 38px;
		cursor: pointer;
		top: 20px;
		right: 20px;
	}
	.mfp-fade .mfp-iframe-holder .mfp-content {
		max-width: 89.687%;
	}
}

/* econnect -----------------------------------
----------------------------------------------*/
.econnect-page-content {
	padding-bottom: 165px;
}
.econnect-item,
.econnect-item-body {
	box-sizing: border-box;
}
.econnect-item {
	background: #fff;
}
.econnect-title {
	margin-left: auto;
	margin-right: auto;
}
.econnect-item-body-title {
	font-weight: bold;
}
.econnect-item-body-title {
	font-size: 24px;
}
.econnect-item-body-text {
	line-height: 2;
	font-size: 14px;
}
.econnect-item-body-app-btn img {
	vertical-align: bottom;
}
.econnect-item-btn {
	position: relative;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	background: #000;
	color: #fff;
	font-weight: bold;
	text-decoration: none;
	letter-spacing: 1px;
}
.econnect-item-btn::before {
	position: absolute;
	content: '';
	display: block;
	background-image: url('../img/econnect/arrow_wh.png');
	background-repeat: no-repeat;
	background-size: contain;
	margin: auto;
	top: 0;
	bottom: 0;
}
.econnect-item-my-page {
	font-weight: bold;
}

@media screen and (min-width:768px) {
	.econnect-content {
		background-image: url("../img/econnect/back_img.png");
		background-repeat: no-repeat;
		background-size: cover;
		width: 100%;
		max-width: 1100px;
		margin: 80px auto 0;
		padding-top: 90px;
		padding-bottom: 90px;
	}
	.econnect-title-01 {
		max-width: 746px;
	}
	.econnect-title-02 {
		margin-top: 110px;
		max-width: 437px;
	}
	.econnect-item {
		max-width: 900px;
		padding-right: 50px;
		padding-left: 85px;
		padding-bottom: 70px;
		margin-top: 60px;
		margin-left: auto;
		margin-right: auto;
	}
	.econnect-item-box {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-align: start;
		-ms-flex-align: start;
		align-items: flex-start;
		padding-top: 70px;
	}
	.econnect-item-head {
		width: 16.993%;
	}
	.econnect-item-body {
		width: 83.007%;
		padding-left: 60px;
	}
	.econnect-item-body-text {
		margin-top: 15px;
	}
	.econnect-item-body-app {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-align: center;
		-ms-flex-align: center;
		align-items: center;
		margin-left: -10px;
		margin-right: -10px;
		margin-top: 20px;
	}
	.econnect-item-body-app-btn {
		margin-left: 10px;
		margin-right: 10px;
		transition: opacity 0.2s ease;
	}
	.econnect-item-body-app-btn:nth-child(1) {
		width: 180px;
	}
	.econnect-item-body-app-btn:nth-child(2) {
		width: 224px;
	}
	.econnect-item-body-app-btn:hover {
		opacity: 0.75;
	}
	.econnect-item-btn {
		max-width: 266px;
		height: 58px;
		border-radius: 29px;
		margin-top: 15px;
		transition: opacity 0.2s ease;
	}
	.econnect-item-btn:hover {
		opacity: 0.75;
	}
	.econnect-item-btn::before {
		right: 27px;
		width: 5px;
		height: 9px;
	}
	.econnect-item-btn-content {
		display: inline-block;
		padding-right: 16px;
	}
	.econnect-item-my-page {
		margin-top: 15px;
	}
}
@media screen and (max-width:767px) {
	.econnect-content {
		background-image: url("../img/econnect/back_img_sp.png");
		background-repeat: no-repeat;
		background-size: cover;
		padding-bottom: 70px;
	}
	.econnect-page-content {
		padding-bottom: 65px;
	}
	.econnect-title-01 {
		padding-top: 60px;
		max-width: 165px;
	}
	.econnect-title-02 {
		margin-top: 70px;
		max-width: 145px;
	}
	.econnect-item {
		margin-left: 20px;
		margin-right: 20px;
		margin-top: 35px;
		padding-left: 30px;
		padding-right: 30px;
		padding-bottom: 45px;
	}
	.econnect-item-box:not(:first-child) {
		margin-top: 60px;
	}
	.econnect-item-head {
		width: 82px;
		margin-left: auto;
		margin-right: auto;
	}
	.econnect-item-body {
		margin-top: 35px;
	}
	.econnect-item-body-title {
		line-height: 1.6;
	}
	.econnect-item-body-text {
		margin-top: 16px;
	}
	.econnect-item-body-app {
		max-width: 260px;
		margin-top: 5px;
		margin-left: auto;
		margin-right: auto;
	}
	.econnect-item-body-app-btn {
		display: inline-block;
		margin-top: 10px;
	}
	.econnect-item-btn {
		max-width: 260px;
		height: 48px;
		border-radius: 24px;
		margin-top: 20px;
		margin-left: auto;
		margin-right: auto;
	}
	.econnect-item-btn::before {
		right: 17px;
		width: 5px;
		height: 8px;
	}
	.econnect-item-my-page {
		font-size: 16px;
		margin-top: 15px;
		padding-bottom: 5px;
	}
}
