@charset "UTF-8";

/* --------------------------------------------------------------------------------------
	プロダクト一覧
--------------------------------------------------------------------------------------- */

.wrap {
	background-image: url(../img/service/product/main_bg.png);
	background-position: center 1520px;
	overflow-x: clip;
}

.product-wrap {
	margin-top: 90px;
	position: relative;
	z-index: 1;
}

.product-wrap .tab-section { margin-top: 56px; }

.product-wrap .tab-section .head { text-align: center; }

.product-wrap .tab-section .head span,
.product-wrap .tab-section .head strong {
	display: block;
	font-family: var(--font-UD-ShinGo-DeBold);
}

.product-wrap .tab-section .head span { font-size: 2.4rem; }

.product-wrap .tab-section .head strong {
	font-size: 3.2rem;
	margin-top: 8px;
}

.product-wrap .tab-section .head strong span { display: inline-block; }

.product-wrap .tab-section .anchor-navi {
	font-size: 0;
	margin-top: 50px;
	text-align: center;
}

.product-wrap .tab-section .anchor-navi li {
	border-left: 1px solid var(--border-color);
	display: inline-block;
}

.product-wrap .tab-section .anchor-navi li:last-of-type { border-right: 1px solid var(--border-color); }

.product-wrap .tab-section .anchor-navi li a {
	color: var(--color-deep-blue);
	display: block;
	font-family: var(--font-UD-ShinGo-DeBold);
	font-size: 1.8rem;
	padding: 0 44px;
	position: relative;
}

.product-wrap .tab-section .anchor-navi li a::after {
	border-bottom: 4px solid var(--color-deep-blue);
	border-right: 4px solid var(--color-deep-blue);
	content: '';
	display: block;
	height: 14px;
	margin: 8px auto auto;
	transform: rotate(45deg);
	width: 14px;
}

.product-wrap .tab-section .sub-head {
	font-family: var(--font-UD-ShinGo-DeBold);
	font-size: 3.2rem;
	margin-top: 64px;
	text-align: center;
}

.product-wrap .tab-section .lead {
	margin-top: 48px;
	position: relative;
}

.product-wrap .tab-section .lead .image { float: right; }

.product-wrap .tab-section .text {
	max-width: 49%;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	width: 100%;
}

.product-wrap .tab-section .text h3 {
	color: var(--color-deep-blue);
	font-family: var(--font-UD-ShinGo-DeBold);
	font-size: 2.4rem;
	line-height: 1.8;
	margin-bottom: 24px;
}

.product-wrap .tab-section .text > p {
	font-family: var(--font-UD-ShinGo-DeBold);
	font-size: 1.9rem;
	line-height: 1.9;
}

.product-wrap .tab-section .text > p span { color: var(--color-deep-blue); }

.product-wrap .tab-section .text > span {
	display: block;
	font-size: 1.4rem;
	margin-top: 24px;
}

.product-wrap .payment-diagram { margin-top: 20px; }

.product-wrap .payment-diagram .rframe {
	margin-top: 0;
}

.product-wrap .payment-diagram .rframe02 {
	margin: 0 0 80px 0;
	padding: 0;
}

.product-wrap .payment-diagram .rframe p{
	background-color: #4a4a4a;
	border-radius: 10px;
	color: #fff;
	font-family: var(--font-UD-ShinGo-Bold);
	font-size: 2rem;
	margin: 0;
	padding: 5px 25px 5px 25px;
}

.product-wrap .payment-diagram .rframe02 p{
	background-color: #4a4a4a;
	border-radius: 10px;
	color: #fff;
	font-family: var(--font-UD-ShinGo-Bold);
	font-size: 2rem;
	margin: 0 0 20px 0;
	padding: 5px 25px 5px 25px;
}

.product-wrap .payment-diagram .rframe02 .pc{
	margin: auto;
	padding: 0;
	text-align: center;
}

.product-wrap .payment-diagram .rframe02 .sp{
	margin: auto;
	padding: 0;
	text-align: center;
}

.product-wrap .payment-diagram .rframe .f-description{
	font-size: 1.6rem;
	margin: 20px;
	padding: 0 5px 25px 15px;
}

.product-wrap .payment-diagram .rframe .f-description span{
	color: #387cbe;
	font-family: var(--font-UD-ShinGo-Bold);
}

.product-wrap .payment-diagram .rframe .f-description .pc{
	margin: 20px 20px 10px 20px;
	padding: 10px;
}

.product-wrap .payment-diagram .rframe .f-description .sp{
	margin: 15px 0 10px 0;
	padding: 10px 0;
}





.product-wrap .merit {
	background-color: #fff;
	border: 2px solid var(--border-color);
	border-radius: 16px;
	margin-top: 32px;
	padding: 30px;
}

.product-wrap .merit .details {
	float: left;
	max-width: 61%;
	width: 100%;
}

.product-wrap .merit .details section:nth-of-type(n+2) { margin-top: 23px; }

.product-wrap .merit .details section h3 {
	background: url(../img/common/icon_check.svg) no-repeat left 7px;
	font-family: var(--font-UD-ShinGo-DeBold);
	font-size: 2rem;
}

.product-wrap .merit .details section p { margin-top: 7px; }

.product-wrap .merit .details section h3,
.product-wrap .merit .details section p { padding-left: 36px; }

.product-wrap .merit .details section .brand_logo { margin: 7px 7px 7px 35px; }



.product-wrap .merit .popup {
	background-color: var(--color-gray-white);
	border-radius: 16px;
	float: right;
	max-width: 30.8999%;
	padding: 40px 24px;
	position: relative;
	width: 100%;
}

.product-wrap .merit .popup::before {
	background: url(../img/service/product/icon_merit.svg) no-repeat;
	content: '';
	height: 77px;
	left: -28px;
	position: absolute;
	top: 0px;
	width: 85px;
}

.product-wrap .merit .popup h3 {
	color: var(--color-deep-blue);
	font-family: var(--font-UD-ShinGo-DeBold);
	text-align: center;
}

.product-wrap .merit .popup ul {
	font-size: 1.4rem;
	margin-top: 20px;
}

.product-wrap .merit .popup li {
	line-height: 1.8;
	margin-left: 1em;
	text-indent: -1em;
}

.product-wrap .merit .popup li:nth-of-type(n+2) { margin-top: 2px; }



.box_red {
	background-color: #ffe8e8;
	border: 10px solid #ffe8e8;
	border-radius: 10px;
	color: #c72c2d;
	font-family: var(--font-UD-ShinGo-Regular);
	font-size: 1.4rem;
	margin: 0 auto;
	padding: 5px 7px;
	text-align: left;
	width: 700px;
}

.box_red .date {
	color: #e25a5b;
	font-family: var(--font-UD-ShinGo-DeBold);
	font-size: 1.2rem;
	margin-top: 10px;
}



.box_red .red-link {
	color: #e25a5b;
	font-family: var(--font-UD-ShinGo-DeBold);
	font-size: 1.4rem;
	margin-top: 0;
}

.box_red .red-link a:link {
	color: #e25a5b;
}

.box_red .red-link a:visited {
	color: #e25a5b;
}

.box_red .red-link a:active {
	color: #e25a5b;
}

.box_red .red-link a:focus {
	color: #e25a5b;
}


.text .box_links {
	font-size: 110%;
	margin-top: 50px;
}

.text .news_links a {
	background: url(../img/common/icon_arrow.svg) no-repeat right center;
	padding-right: 66px;
	transition: var(--transition);
}

.over { transition: var(--transition);}

.text .news_links a:hover {
	background-position: right 10px center;
}

.text .news_links {
	margin-top: 10px;
}



.sh1frame{
	float: left;
	height: 100px;
	margin-top: 40px;
	padding-top: 20px;
	width: 490px;
}
.sh2frame{
	float: left;
	height: 100px;
	margin-top: 60px;
	padding-top: 40px;
	text-align: center;
	width: 50px;
}
.sh3frame{
	float: left;
	height: 150px;
	margin-top: 50px;
	text-align: right;
	width: 530px;
}

.sh1frame h3 {
	color: #0b3c8b;
	font-family: var(--font-UD-ShinGo-DeBold);
	font-size: 2.4rem;
	line-height: 1.8;
}

.sh1frame > p {
	color: #000;
	font-family: var(--font-UD-ShinGo-DeBold);
	font-size: 1.8rem;
}

.sh1frame .txt-link {
	color: #0b3c8b;
	font-family: var(--font-UD-ShinGo-DeBold);
	font-size: 1.9rem;
	margin-top: 10px;
}

.sh1frame .txt-link a:link {
	color: #0758da;
}

.sh1frame .txt-link a:visited {
	color: #0758da;
}

.sh1frame .txt-link a:active {
	color: #0758da;
}

.sh1frame .txt-link a:focus {
	color: #0758da;
}

.product-wrap .features { margin-top: 64px; }

.product-wrap .features .features-item.no-head section h4 {
	font-size: 2.4rem;
	margin-top: 0;
}

.product-wrap .tab-content .tab-section .features-item .bg-comment {
	background-image: url(../img/service/product/bg_comment.svg);
	background-position: top;
	background-repeat: no-repeat;
	background-size: contain;
	height: 200px;
	margin-top: 20px;
}

.product-wrap .tab-content .tab-section .features-item .bg-comment p {
	color: #0c62b5;
	font-size: 1.8rem;
	margin-top: 20px 20px 20px 20px;
	padding: 25px 40px 20px 70px;
}

.flow-wrap .features-item02 {
	display: none;
}




.product-wrap .features-item section .text-banner {
	bottom: 22px;
	position: absolute;
	right: 22px;
}

.product-wrap .payment { margin-top: 60px; }

.product-wrap .payment h2 {
	font-family: var(--font-UD-ShinGo-DeBold);
	font-size: 2.4rem;
}

.product-wrap .payment-inner {
	font-size: 0;
	left: -25px;
	margin-top: 32px;
	position: relative;
	top: -20px;
	width: calc(100% + 25px);
}

.product-wrap .payment section {
	background-color: #fff;
	border-radius: 8px;
	box-shadow: 0px 0px 16px 0px rgba(213, 213, 213, .46);
	display: inline-block;
	margin-left: 25px;
	margin-top: 20px;
	max-width: 530px;
	padding: 28px 32px 32px;
	position: relative;
	transition: all .3s ease-in-out;
	vertical-align: top;
	width: 100%;
}

.product-wrap .payment section h3 {
	border-bottom: 1px solid var(--border-color-thin);
	font-family: var(--font-UD-ShinGo-DeBold);
	font-size: 2rem;
	padding-bottom: 8px;
}

.product-wrap .payment section h3 span {
	font-family: var(--font-UD-ShinGo-Regular);
	font-size: 80%;
}

.product-wrap .payment section .image {
	margin-top: 16px;
	position: relative;
	width: 100%;
}

.product-wrap .payment section .image .row {
	font-size: 0;
	position: relative;
}

.product-wrap .payment section .image .row:nth-of-type(n+2) { margin-top: 10px; }

.product-wrap .payment section .image .row > div {
	display: inline-block;
	vertical-align: middle;
}

.product-wrap .payment section .card .row,
.product-wrap .payment section .cb .row {
	left: -9%;
	width: 109%;
}

.product-wrap .payment section .card .row > div,
.product-wrap .payment section .cb .row > div {
	margin-left: 9%;
	width: 16%;
}

.product-wrap .payment section .card .row > div img,
.product-wrap .payment section .cb .row > div img { max-width: 70px; }

.product-wrap .payment section .card .row .square img,
.product-wrap .payment section .cb .row .square img { max-width: 50px; }


.product-wrap .payment section .electronic .row {
	left: -1%;
	width: 102%;
}

.product-wrap .payment section .electronic .row > div {
	margin-left: 4%;
	max-width: 15.6%;
}

.product-wrap .payment section .electronic .row > div img { max-height: 52px; }

.product-wrap .payment section .qr .row {
	left: -8%;
	min-height: 40px;
	width: 123%;
}

.product-wrap .payment section .qr .row > div {
	margin-left: 6%;
	width: 16%;
}

.product-wrap .payment section .qr .row > div img {
	max-height: 240px;
	min-width: 45px;
}

.product-wrap .payment section .j-debit .row > div img { max-width: 100px; }
.product-wrap .payment section .house .row > div img { min-width: 133px; }

.product-wrap .payment section .text-banner {
	margin-top: 30px;
	text-align: right;
}

.product-wrap .payment section .text-banner a { font-size: 1.6rem; }

.product-wrap .scene { margin-top: 56px; }

.product-wrap .use-cases { margin-top: 96px; }

.product-wrap .use-cases .slider-wrap { overflow: inherit; }


.tab-content-w {
	background-color: #fff;
	width: 100%;
}

.product-wrap .terminal-list {
	background-color: #fff;
	margin-left: auto;
	margin-right: auto;
	margin-top: 96px;
	padding-left: 0;
	padding-right: 0;
	padding-top: 30px;
	width: 100%;
}



.product-wrap .terminal-list > h2 {
	font-family: var(--font-UD-ShinGo-DeBold);
	font-size: 3.2rem;
	text-align: center;
}

.terminal-list .terminal-item { margin-top: 42px; }

.terminal-list .terminal-item .head-ttl { margin-bottom: 32px; }

.terminal-list .terminal-item .product {
	float: left;
	max-width: 350px;
	width: 100%;
}

.terminal-list .terminal-item .product .banner-image { margin-top: 20px; }

.terminal-list .terminal-item .details {
	float: right;
	max-width: 708px;
	width: 100%;
}

.terminal-list .terminal-item .details > ul { margin-bottom: 32px; }

.terminal-list .terminal-item .details > ul li {
	margin-left: 1em;
	text-indent: -1em;
}

.terminal-list .terminal-item .details .spec-wrap {
	display: table;
	width: 100%;
}

.terminal-list .terminal-item .details .spec-wrap  dl {
	display: table-row;
	font-size: 1.419999rem;
	width: 100%;
}

.terminal-list .terminal-item .details .spec-wrap dt,
.terminal-list .terminal-item .details .spec-wrap dd,
.terminal-list .terminal-item .details .spec-wrap dd li { padding: 20px 0; }

.terminal-list .terminal-item .details .spec-wrap dt {
	border-bottom: 1px solid var(--border-color-thin);
	display: table-cell;
	font-family: var(--font-UD-ShinGo-DeBold);
	white-space: nowrap;
}

.terminal-list .terminal-item .details .spec-wrap dd {
	border-bottom: 1px solid var(--border-color-thin);
	display: table-cell;
	padding-left: 24px;
}

.terminal-list .terminal-item .details .spec-wrap dd li { border-bottom: 1px solid var(--border-color-thin); }
.terminal-list .terminal-item .details .spec-wrap dd li:first-of-type { padding-top: 0; }

.terminal-list .terminal-item .details .spec-wrap dd li:last-of-type {
	border-bottom: none;
	padding-bottom: 0;
}

.terminal-list .terminal-item .banner-area {
	clear: both;
	font-size: 0;
	padding-top: 32px;
	text-align: center;
}

.terminal-list .terminal-item .banner-area li,
.product-wrap .option .list {
	display: inline-block;
	vertical-align: top;
	width: 100%;
}

.terminal-list .terminal-item .banner-area li:nth-of-type(n+2) { margin-left: 22px; }
.product-wrap .option .list:nth-of-type(n+2) { margin-left: 30px; }

.product-wrap .option {
	border-bottom: 1px solid var(--border-color);
	margin-top: 88px;
	padding-bottom: 80px;
}

.product-wrap .option2 {
	/*border-bottom: 1px solid var(--border-color);*/
	margin-top: 88px;
	padding-bottom: 80px;
}

.product-wrap .option h3 {
	font-family: var(--font-UD-ShinGo-DeBold);
	font-size: 3.2rem;
	text-align: center;
}

.product-wrap .option2 h3 {
	font-family: var(--font-UD-ShinGo-DeBold);
	font-size: 3.2rem;
	text-align: center;
}

.product-wrap .option .banner-option {
	font-size: 0;
	margin-top: 42px;
}

.product-wrap .option2 .banner-option {
	font-size: 0;
	margin-top: 42px;
}

.product-wrap .option .list { max-width: 535px; }

.product-wrap .option .list-one { margin: auto; }

.product-wrap .option2 .list-one { margin: auto; }

.product-wrap .option .list p {
	font-size: 1.4rem;
	margin-bottom: 26px;
}

.product-wrap .option .list-one p {
	font-size: 1.4rem;
	margin-bottom: 26px;
}

.product-wrap .option2 .list-one p {
	font-size: 1.4rem;
	margin-bottom: 26px;
}

.product-wrap .option .list-one .banner {
	margin: auto;
	text-align: center;
}

.product-wrap .option2 .list-one .banner {
	margin: auto;
	text-align: center;
}

.product-wrap .banner-download { margin: 64px auto 0; }

.product-wrap .flow { margin-top: 64px; }

.product-wrap .flow-text { margin-top: 30px; }
.product-wrap .flow-wrap .flow-inner li { max-width: 32.111111%; }

.product-wrap .flow-wrap .flow-inner li:not(:last-of-type)::after {
	right: -6%;
	width: 6%;
}

.flow-wrap .pc, .sp{text-align: center;}


.product-wrap .faq { margin-top: 64px; }

.product-wrap .faq .column {
	border-bottom: 1px solid var(--border-color-thin);
	padding-bottom: 20px;
}

.product-wrap .faq .column:first-of-type { border-top: none; }

.product-wrap .faq .column label,
.product-wrap .faq .column-inner {padding-left: 26px; }

.product-wrap .faq .column label {
	border-bottom: none;
	padding-bottom: 0;
}

.product-wrap .faq .column label::before {
	color: var(--color-deep-blue);
	content: 'Q';
	left: 0;
	position: absolute;
}

.product-wrap .faq .column label::after { top: 50%; }
.product-wrap .faq .column input:checked + label::after { top: calc(50% + 7px); }

.product-wrap .faq .column-inner {
	margin-top: 20px;
	position: relative;
}

.product-wrap .faq .column-inner::before {
	color: var(--color-deep-blue);
	content: 'A';
	font-family: var(--font-UD-ShinGo-DeBold);
	font-size: 2rem;
	left: 0;
	position: absolute;
	top: -3px;
}

.product-wrap .application {
	background-color: var(--color-deep-blue);
	margin-top: 80px;
	padding: 60px 0 65px;
}

.product-wrap .application h2 {
	color: #fff;
	font-family: var(--font-UD-ShinGo-DeBold);
	font-size: 3rem;
}

.product-wrap .application ol {
	font-size: 0;
	left: -40px;
	margin-top: 40px;
	max-width: 1150px;
	position: relative;
}

.product-wrap .application li {
	display: inline-block;
	margin-left: 40px;
	min-width: 535px;
	vertical-align: top;
}

.product-wrap .application li a { border-color: #fff; }

.product-wrap .card-payment { margin-bottom: -104px; }




.rframe .table-scroll { margin-top: 40px; }

.rframe .table-scroll .table-scroll-inner table {
	font-size: 1.4rem;
	width: 100%;
}

.rframe .table-scroll .table-scroll-inner thead th {
	background-color: var(--border-color);
	border-bottom: 2px solid #fff;
	border-right: 1px solid #fff;
	color: #fff;
	font-family: var(--font-UD-ShinGo-DeBold);
	padding: 12px 34px;
	text-align: center;
	vertical-align: middle;
	white-space: nowrap;
}

.rframe .table-scroll .table-scroll-inner thead tr:first-of-type th:first-of-type {
	border-bottom: none;
	border-left: 1px solid var(--border-color);
}

/* .rframe .table-scroll .table-scroll-inner thead tr:last-of-type th { border-bottom: none; } */

.rframe .table-scroll .table-scroll-inner tbody th {
	background-color: gray;
	border-bottom: 1px solid #fff;
	border-left: 1px solid var(--border-color);
	border-top: 1px solid #fff;
	color: #fff;
	font-family: var(--font-UD-ShinGo-DeBold);
	padding: 8px 20px;
	vertical-align: middle;
	white-space: nowrap;
}

/*.rframe .table-scroll .table-scroll-inner thead th:last-of-type,
.rframe .table-scroll .table-scroll-inner tbody td:last-of-type { border-right: 1px solid var(--border-color); }*/

.rframe .table-scroll .table-scroll-inner tbody td {
	background-color: #fff;
	border-bottom: 1px solid var(--border-color);
	border-left: 1px solid var(--border-color);
	border-right: 1px solid var(--border-color);
	padding: 10px 20px;
	text-align: center;
	vertical-align: middle;
	width: 28%;
}

.rframe .table-scroll .table-scroll-inner tbody td sup { font-size: 60%; }

.rframe .table-scroll .table-scroll-inner thead .active {
	background-color: #99adca;
	border-bottom: 2px solid #3a7bbd;
	border-left: 2px solid #3a7bbd;
	border-right: 2px solid #3a7bbd;
	position: relative;
}

.rframe .table-scroll .table-scroll-inner thead .active::before {
	background-color: #3a7bbd;
	content: '';
	display: block;
	height: 2px;
	left: 0;
	position: absolute;
	top: -2px;
	width: 100%;
}

.rframe .table-scroll .table-scroll-inner tbody .active {
	background-color: #f0f5f9;
	border-left: 2px solid #0b3c8b;
	border-right: 2px solid #0b3c8b;
}

.rframe .table-scroll .table-scroll-inner tbody tr:last-of-type .active { border-bottom: 2px solid #0b3c8b; }


.rframe .table-scroll .table-scroll-inner tbody th .none {
	padding: 12px 34px;
	text-align: center;
	vertical-align: middle;
	white-space: nowrap;

}

.rframe .table-scroll .table-scroll-inner tbody .none {
	background: none;
	border: #fff;
	padding: 10px 20px;
	text-align: center;
	vertical-align: middle;
}

.rframe .table-scroll .table-scroll-inner tbody .txt-b {
	background: none;
	border: #fff;
	color: #387cbe;
	font-family: var(--font-UD-ShinGo-Bold);
	font-size: 1.25vw;
	padding: 10px 0 0 0;
	text-align: center;
	vertical-align: middle;
}







@media (max-width: 768px) {

	.wrap {
		background-image: url(../img/service/product/main_bg_sp_top.png), url(../img/service/product/main_bg_sp_bottom.png);
		background-position: center 447.733vw , center bottom;
		background-repeat: 100% auto;
	}

	.product-wrap {
		margin: 11.2vw 0 0;
		width: auto;
	}

	.product-wrap .tab-section {margin-left: 3vw;margin-right: 3vw; margin-top: 9.6vw; }

	.product-wrap .tab-section .head span { font-size: 5.333vw; }
	.product-wrap .tab-section .head strong { font-size: 7.467vw; }

	.product-wrap .tab-section .lead { width: auto; }

	.product-wrap .tab-section .lead .image { float: none; }

	.product-wrap .tab-section .text {
		margin-top: 5.333vw;
		max-width: 100%;
		position: relative;
		top: auto;
		transform: translateY(0);
	}

	.product-wrap .tab-section .text h3 {
		font-size: 5.233vw;
		margin-bottom: 4.267vw;
	}

	.product-wrap .tab-section .text > p {
		color: #000;
		font-family: var(--font-UD-ShinGo-Regular);
		font-size: 4.8vw;
	}

	.product-wrap .tab-section .text > span {
		font-size: 3.333vw;
		margin-top: 1.867vw;
	}


	.box_red {
		background-color: #ffe8e8;
		border: 20px solid #ffe8e8;
		border-radius: 20px;
		color: #c72c2d;
		font-family: var(--font-UD-ShinGo-Regular);
		font-size: 1.4rem;
		margin: 0 auto;
		padding: 10px 10px;
		text-align: left;
		width: auto;
	}



	.tab-section .text .box_links {
		font-size: 1.7rem;
		margin-top: 50px;
	}

	.tab-section .box_links .news_links a {
		background: none;
		color: #0758da;
		text-decoration: underline;
	}


	.sh1frame{
		height: auto;
		margin-bottom: 10px;
		margin-top: 30px;
		width: auto;
	}
	.sh2frame{
		display: none;
	}
	.sh3frame{
		margin-bottom: 20px;
		margin-top: 10px;
		text-align: center;
		width: auto;
	}

	.sh1frame h3 {
		color: #0b3c8b;
		font-family: var(--font-UD-ShinGo-DeBold);
		font-size: 5.5vw;
		line-height: 1.8;
		margin-bottom: 0px;
		padding-bottom: 0px;
	}

	.sh1frame > p {
		color: #000;
		font-family: var(--font-UD-ShinGo-Regular);
		font-size: 4vw;
	}

	.sh1frame .txt-link {
		color: #0b3c8b;
		font-family: var(--font-UD-ShinGo-DeBold);
		font-size: 1.9rem;
		margin-top: 10px;
	}

	.sh1frame .txt-link a:link {
		color: #0758da;
	}

	.sh1frame .txt-link a:visited {
		color: #0758da;
	}

	.sh1frame .txt-link a:active {
		color: #0758da;
	}

	.sh1frame .txt-link a:focus {
		color: #0758da;
	}








	.product-wrap .features {
		margin-top: 10.667vw;
		width: auto;
	}

	.product-wrap .features .features-item.no-head section h4 {
		font-size: 5.6vw;
		min-height: 23.333vw !important;
		top: 6.667vw;
	}

	.product-wrap .features .features-item section h4 {
		margin-right: 10px;
		padding: 0 10px 0 0;
	}

	.product-wrap .payment {
		margin-top: 8vw;
		width: auto;
	}

	.product-wrap .payment h2 { font-size: 5.333vw; }

	.product-wrap .payment-inner {
		left: auto;
		margin-top: 4vw;
		top: auto;
		width: auto;
	}

	.product-wrap .payment section {
		border-radius: 1.067vw;
		margin-left: 0;
		margin-top: 0;
		max-width: 100%;
		min-height: inherit !important;
		padding: 6.4vw 4vw;
	}

	.product-wrap .payment section:nth-of-type(n+2) { margin-top: 3.2vw; }

	.product-wrap .payment section h3 {
		font-size: 4.267vw;
		padding-bottom: 1.867vw;
	}

	.product-wrap .payment section .image {
		margin-top: 4.267vw;
		min-height: inherit !important;
	}

	.product-wrap .payment section .text-banner { margin-top: 4vw; }

	.product-wrap .scene {
		margin-top: 13.333vw;
		width: auto;
	}

	.product-wrap .use-cases { margin: 16vw -5.333vw 0; }

	.product-wrap .terminal-list {
		margin-top: 16.667vw;
		width: auto;
	}

	.product-wrap .terminal-list > h2 { font-size: 7.467vw; }

	.terminal-list .terminal-item { margin-top: 7.467vw; }
	.terminal-list .terminal-item .head-ttl { margin-bottom: 4.267vw; }

	.terminal-list .terminal-item .product {
		float: none;
		max-width: 100%;
		text-align: center;
	}

	.terminal-list .terminal-item .details {
		float: none;
		margin-top: 4.267vw;
	}

	.terminal-list .terminal-item .details > ul { margin-bottom: 5.867vw; }

	.terminal-list .terminal-item .details .spec-wrap dl { font-size: 3.467vw; }

	.terminal-list .terminal-item .details .spec-wrap dt,
	.terminal-list .terminal-item .details .spec-wrap dd,
	.terminal-list .terminal-item .details .spec-wrap dd li { padding: 3.733vw 0; }

	.terminal-list .terminal-item .details .spec-wrap dd { padding-left: 7.733vw; }

	.terminal-list .terminal-item .banner-area { padding-top: 7.467vw; }

	.terminal-list .terminal-item .banner-area li:nth-of-type(n+2) {
		margin-left: 0;
		margin-top: 2.667vw;
	}

	.product-wrap .option {
		border-bottom: none;
		margin-top: 17.333vw;
		padding-bottom: 0;
		width: auto;
	}

	.product-wrap .option h3 { font-size: 7.467vw; }
	.product-wrap .option .banner-option { margin-top: 8vw; }

	.product-wrap .option .list p {
		font-size: 3.467vw;
		margin-bottom: 4.267vw;
		min-height: inherit !important;
	}

	.product-wrap .option .list:nth-of-type(n+2) {
		margin-left: 0;
		margin-top: 15.933vw;
	}

	.product-wrap .banner-download { margin-top: 17.067vw; }

	.product-wrap .tab-section .anchor-navi { margin-top: 8vw; }

	.product-wrap .tab-section .anchor-navi li {
		max-width: 44.533vw;
		width: 100%;
	}

	.product-wrap .tab-section .anchor-navi li a {
		font-size: 3.2vw;
		padding: 0;
	}

	.product-wrap .tab-section .anchor-navi li a::after {
		margin-top: 1.067vw;
		transform: scale(.6) rotate(45deg);
	}

	.product-wrap .tab-section .sub-head {
		font-size: 7.467vw;
		margin-top: 9.867vw;
	}

	.product-wrap .card-payment { margin-bottom: -19.2vw; }

	.product-wrap .card-payment .lead { margin-top: 6.933vw; }
	.product-wrap .card-payment .text { margin-top: 4.267vw; }

	.product-wrap .payment-diagram {
		background-color: #fff;
		margin-top: 10.667vw;
		padding-top: 6.333vw;
	}

	.product-wrap .merit {
		border-radius: 2.133vw;
		margin-top: 10vw;
		padding: 7.733vw 4vw 8.267vw;
		width: auto;
	}

	.product-wrap .merit .details {
		float: none;
		max-width: 100%;
	}

	.product-wrap .merit .details section:nth-of-type(n+2) { margin-top: 4.8vw; }

	.product-wrap .merit .details section h3 { background-size: 5.733vw auto; }

	.product-wrap .merit .details section h3,
	.product-wrap .merit .details section p { padding-left: 8.333vw; }

	.product-wrap .merit .popup {
		float: none;
		margin-top: 6.133vw;
		max-width: 100%;
		padding: 10.667vw 6.4vw 8vw;
	}

	.product-wrap .merit .popup::before {
		background-size: 100% auto;
		height: 18.533vw;
		left: 0;
		width: 20.4vw;
	}

	.product-wrap .flow {
		margin-top: 13.333vw;
		width: auto;
	}

	.product-wrap .flow-text { margin-top: 4.267vw; }

	.product-wrap .faq {
		margin-top: 13.333vw;
		width: auto;
	}

	.product-wrap .faq .column label::after { top: 57%; }

	.product-wrap .application {
		margin: 13.333vw -5.333vw 0;
		padding: 12.533vw 5.333vw 14vw;
	}

	.product-wrap .application h2 { font-size: 6.667vw; }

	.product-wrap .application ol {
		left: 0;
		margin-top: 6.4vw;
		max-width: 100%;
	}

	.product-wrap .application li {
		margin-left: 0;
		min-width: 100%;
	}

	.product-wrap .application li:nth-of-type(n+2) { margin-top: 2.933vw; }

	.product-wrap .payment section .qr .row { min-height: inherit; }

	.product-wrap .features-item section .text-banner {
		bottom: auto;
		position: relative;
		right: auto;
	}


	.flow-wrap .features-item {
		display: none;
	}


	.flow-wrap .features-item02 {
		display: block;
		font-size: 0;
		margin-left: -2%;
		margin-top: calc(48px - 2%);
		width: 102%;
	}

	.flow-wrap .features-item02 section {
		background-color: #fff;
		border: 1px solid var(--border-color-thin);
		flex-direction: column;
		margin-left: 2%;
		margin-top: 2%;
		padding: 22px;
		text-align: center;
		vertical-align: top;
		width: 100%;
	}

	.flow-wrap .features-item02 section h4 {
		font-family: var(--font-UD-ShinGo-DeBold);
		font-size: 2rem;
		margin: 10px;
		padding: 0;
	}

	.flow-wrap .features-item02 section .bg-comment {
		background-image: url(../img/service/product/bg_comment.svg);
		background-position: top;
		background-repeat: no-repeat;
		background-size: contain;
		clear: both;
		height: 170px;
	}

	.flow-wrap .features-item02 section .bg-comment p {
		color: var(--color-deep-blue);
		font-size: 1.8rem;
		line-height: 1.6;
		margin: 30px 0 0 50px;
		padding: 30px 0 0 80px;
		text-align: left;
	}

}