
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100;300;400;500;700;900&family=Roboto:ital,wght@0,100;0,300;0,400;0,500;0,700;0,900;1,100;1,300;1,400;1,500;1,700;1,900&display=swap');
.noto {
	font-family: 'Noto Sans JP', sans-serif;
}

html {
	-webkit-overflow-scrolling: touch;
}

body {
	background: #f9f9f9;
}

.nw {
	white-space: nowrap;
}

.gemsmobile {
	padding: 60px 0;
	/*border-bottom: 1px solid #e9e9e9;*/
}

.gemsmobile .center {
	text-align: center;
}

.gemsmobile h2 {
	padding: 5px 0;
	font-size: 42px;
	font-weight: 700;
	line-height: 1.2em;
}

.gemsmobile h3 {
	padding: 5px 0;
	font-size: 32px;
	font-weight: 700;
}

.gemsmobile h4 {
	font-size: 24px;
	font-weight: 700;
	letter-spacing: 1px;
}

.gemsmobile h5 {
	font-size: 19px;
	font-weight: 400;
}

.gemsmobile a {
	color: royalblue;
}

.gemsmobile .wire-box {
	display: inline-block;
	padding: 16px;
	font-size: 20px;
	font-weight: 200;
	line-height: 30px;
	color: #444;
	border: 5px solid #eee;
	border-radius: 10px;
}

.gemsmobile .wire-box.left {
	text-align: left;
}

.gemsmobile .title-label {
	display: inline-block;
	padding: 1px 18px;
	margin-bottom: 4px;
	font-size: 0.9em;
	background: #ddd;
	color: #333;
}

.gemsmobile .title-label.darkorange {
	background: rgba(240,90,50,1);
	color: #fff;
}

.gemsmobile .title-label.red {
	background: rgba(240,70,50,1);
	color: #fff;
}

.gemsmobile .title-label.heavy {
	font-size: 1.7em;
	font-weight:700;
}




.gemsmobile .videolist-wrap {
	padding: 10px;
	background-color: rgba(60,150,240,0.1);
	border-radius: 6px;
}
.gemsmobile .videolist-wrap h4 {
	display: inline-block;
	padding: 3px 22px;
	margin-top: 3px;
	font-size: 14px;
	/*font-family: roboto;*/
	color: #0090FF;
	background-color: #fff;
	border: 3px solid #0090FF;
	border-radius: 20px;
}

.gemsmobile .videolist-wrap ul {
	padding: 10px 8px;
	margin: 0;
	text-align: left;
}

.gemsmobile .videolist-wrap li {
	background: url(../images/button-play.png) left center/20px no-repeat;
	padding: 4px 0 4px 26px;
	font-size: 18px;
	font-weight: 400;
}


.gemsmobile .button-wrap {
	padding: 20px 0 0;
}

.gemsmobile .button-wrap a {
	display: inline-block;
	flex-grow: 1;
	padding: 10px 2em 11px;
	border-radius: 2px;
	background: #e0e0e0;
	color: #000;
	font-size: 18px;
	line-height: 20px;
}



.gemsmobile .index {
	border: 1px solid #aaa;
	border-radius: 6px;
	overflow: hidden;
}

.gemsmobile .index .product-inner {
}

.gemsmobile .index .button-wrap {
	padding: 10px 0 0;
}
.gemsmobile .index .button-wrap a {
	display: block;
	margin: 0 10px;
}


#all-lineup {
	display: none;
}

.gemsmobile .store-title {
	display: block;
	background: rgb(255,245,0);
	padding: 30px 20px;
	margin: 20px auto 80px;
	font-size: 26px;
	font-weight: 700;
	text-align: center;
}

.gemsmobile .product-recommend {
	display: inline-block;
	font-size: 26px;
	border: 1px solid #f00;
	background: #f00;
	color: #ff9;
	padding: 8px 3em;
	margin: 100px 0 50px;
}

.gemsmobile .product-series {
	display: inline-block;
	font-size: 22px;
	border: 1px solid #999;
	padding: 8px 1em;
	margin: 100px 0 50px;
}

.gemsmobile .product-series.first-series {
	margin-top: 0;
}

.gemsmobile .product-inner {
	background-color: #fff;
	padding: 10px;
	text-align: center;
}
.gemsmobile .product-inner h4 {
	font-size: 20px;
	line-height: 1.2em;
}
.gemsmobile .product-inner h5 {
	font-size: 14px;
	line-height:1.2em;
	padding: 12px 0;
	color: #444;
}
.gemsmobile .product-inner h4 span,
.gemsmobile .product-inner h5 span{
	display: inline-block;
	white-space: nowrap;
}

.gemsmobile .product-item-bottom {
	display: flex;
	flex-direction: column;
	margin-top: auto;
	padding-top: 20px;
	border-top: 1px solid #e9e9e9;
}

.gemsmobile .product-price {
	display: flex;
	justify-content: center;
	align-items: center;
	text-align: left;
	font-size: 19px;
	letter-spacing: 1px;
	margin: auto 0 2px;
}

.gemsmobile .product-price .product-price-label-wrap {
	display: flex;
	flex-direction: column;
}

.gemsmobile .product-price .product-price-label-wrap.product-sale-price {
	color: red;
}

.gemsmobile .product-price .product-price-label {
	font-size: 9px;
	font-weight: 400;
	color: #555;
	line-height: 1.1em;
}
.gemsmobile .product-price .product-price-label-wrap.product-sale-price .product-price-label {
	font-size: 11px;
	color: red;
}
.gemsmobile .product-price .product-price-label-wrap.product-sale-price .sale-price {
	font-size: 20px;
	font-weight: 700;
}

.gemsmobile .product-price.coupon-wrap {
	background: rgba(255,240,0,0.1);
	padding: 6px 0;
	margin-top: 4px;
}
.gemsmobile .product-price .coupon-label {
	font-size: 12px;
	color: rgb(255,100,0);
}
.gemsmobile .product-price .coupon {
	font-size: 19px;
	font-weight: bold;
	color: rgb(255,100,0);
}

.gemsmobile .product-price .ar {
	background: url(../images/sale/pricedown.png) center center no-repeat;
	background-size: contain;
	opacity: .2;
	display: inline-block;
	width: 40px;
	height: 40px;
	/*
	color: rgba(245,245,245,1);
	font-size: 40px;
	font-family: 'Font Awesome 5 Free';
	font-weight: 900;
	letter-spacing: 0px;
	*/
	margin: 0 43px 0 37px;
}
.gemsmobile .product-price .ar i {
	font-style: normal;
}

.gemsmobile .off-wrap {
	position: relative;
	width: 40%;
	color: #fff;
}
.gemsmobile .off-wrap::before {
	content: " ";
	position: absolute;
	left: 0;
	bottom: 0;
	width: 100%;
	height: 145%;
	background: url(../images/sale/off-bg.png) center center no-repeat;
	background-size: contain;
}
.gemsmobile .off-up {
	position: relative;
	display: flex;
	justify-content: center;
	align-items: baseline;
	font-family: 'Roboto';
	margin-bottom: -3px;
	z-index: 2;
}
.gemsmobile .off-up::before {
	content: " ";
	position: absolute;
	width: 60%;
	height: 2px;
	bottom: -1px;
	left: 20%;
	border-bottom: 1px solid rgb(255,150,150);
}

.gemsmobile .off-percent-num {
	font-size: 36px;
	font-weight: 900;
	letter-spacing: -1px;
}
.gemsmobile .off-right-wrap {
	position: relative;
}
.gemsmobile .off-percent {
	position: absolute;
	left: 3px;
	bottom: 17px;
	font-size: 20px;
	font-weight: 700;
	line-height: 20px;
}
.gemsmobile .off-off {
	position: relative;
	left: 3px;
	bottom: 0;
	font-size: 14px;
	font-weight: 700;
	line-height: 14px;
}
.gemsmobile .off-down {
	position: relative;
	display: block;
	text-align: center;
	font-size: 13px;
	z-index: 2;
}


.gemsmobile .button-wrap a.cart {
	display: block;
	background-color: darkorange;
	color: #fff;
	margin: 0 10px 10px;
}

.gemsmobile .button-wrap .os-edition {
	font-size: 0.9em;
	margin-left: 3px;
}


/*  product list
*/

.gemsmobile .sale-title {
}
.gemsmobile .sale-title img {
	border-radius: 6px;
}

.gemsmobile .product-item-wrap {
	margin-bottom: 30px;
}

.gemsmobile .product-item {
	font-feature-settings: "palt" 1;
	border: 1px solid #ececec;
	border-radius: 4px;
	overflow: hidden;
}

.gemsmobile .product-item .en {
	margin-left: 3px;
	font-size: 0.85em;
}

.gemsmobile .product-item .product-inner {
}
.gemsmobile .product-item .button-wrap {
	padding: 0;
}
.gemsmobile .product-item .button-wrap a {
	display: block;
	margin: 6px 0 0;
}

.gemsmobile .product-item .button-wrap a.cart {
	padding: 6px 5px 7px;
	font-size: 16px;
}

.gemsmobile .btn-more {
	display: inline-block;
	border: 3px solid royalblue;
	border-radius: 6px;
	color: royalblue;
	padding: 8px 2.5em 9px;
	font-size: 16px;
	margin-bottom: 20px;
}

.gemsmobile .btn-link {
	display: inline-block;
	border-radius: 6px;
	color: royalblue;
	padding: 8px 2.5em 9px;
	font-size: 16px;
	margin-bottom: 20px;
	text-decoration: none;
}
.gemsmobile .btn-link:hover {
	color: #fff;
	background: royalblue;
}


#store-text {
	display: inline-block;
}
#store-text h2 {
	text-align: left;
	font-size: 18px;
	font-weight: 700;
	line-height: 24px;
	margin-top: 20px;
}
#store-text h3 {
	text-align: left;
	font-size: 13px;
	font-weight: 700;
	line-height: 16px;
	margin-top: 20px;
}

#store-wrap {
	width: calc(100% + 20px);
	height: 24vw;
	background: url(https://gemsoft.jp/wp-content/uploads/2017/10/stores_20171017.png) 50% 50%;
	background-size: calc(100% + 20px) auto;
	padding: 0;
	margin: 20px -10px;
}
#store-inner {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-content: space-between;
	width: 100%;
	height: 100%;
	padding: 2% 3%;
}
#store-wrap .store-item {
	width: calc(100% / 5 - 1.8%);
	height: calc(100% / 3 - 4.5%);
}


#copyright-logo {
	display: inline-block;
	width: 200px;
}
#copyright-text {
	display: block;
	color: #fff;
	font-size: 14px;
	line-height: 1.2em;
	white-space: nowrap;
	margin: 10px 0 0;
}


@media screen and (max-width: 480px) {
	.menu-item-4pc {
		display: none!important;
	}

	.forpc,
	.gemsmobile .forpc,
	.gemsmobile .sale-title-4pc {
		display: none;
	}
	.formobile,
	.gemsmobile .formobile,
	.gemsmobile .sale-title-4mobile {
		display: block;
	}

	.gemsmobile.product-list .container {
		padding: 0 32px;
	}

	#sale-amazon-table {
		display: none;
	}
}
								/* for PC **********************************************/
@media screen and (min-width: 960px) {

	.menu-item-4mobile {
		display: none!important;
	}

	.forpc,
	.gemsmobile .forpc,
	.gemsmobile .sale-title-4pc {
		display: block;
	}
	.formobile,
	.gemsmobile .formobile,
	.gemsmobile .sale-title-4mobile {
		display: none;
	}

	.gemsmobile .product-series {
		padding: 8px 2em;
	}

	.gemsmobile .product-item {
		display: flex;
		flex-direction: column;
		height: 100%;
		transition: 300ms ease-in;
	}

	.gemsmobile .product-item:hover {
		box-shadow: 0 1px 5px rgba(0,0,0,.3);
	}

	.gemsmobile .product-item .product-inner {
		padding: 10px;
		height: 100%;
		display: flex;
		flex-direction: column;
	}

	.gemsmobile .product-item .product-inner > :last-child {
		margin-top: auto;
	}

	.gemsmobile .product-item .product-inner h4 {
		font-size: 17px;
	}
	.gemsmobile .product-item .product-inner h5 {
		font-size: 13px;
		line-height: 1.4em;
	}

	.gemsmobile .product-item .product-price {
		font-size: 16px;
	}

	.gemsmobile .product-item .product-price .ar {
	}

	.gemsmobile .button-wrap {
		display: flex;
		margin: 2px -4px 0;
	}

	.gemsmobile .button-wrap a {
		flex-grow: 1;
		margin: 0 4px;
	}

	.gemsmobile .product-item .button-wrap a.cart {
		display: block;
		background-color: #eee;
		color: #333;
		padding: 4px 5px 5px;
		margin: 0 4px;
		font-size: 15px;
	}
	.gemsmobile .product-item .button-wrap a.cart:hover {
		background-color: darkorange;
		color: #fff;
	}

	#main-nav {
		margin-left: 50px;
	}
	#main-nav .menu-main {
		color: #333;
		font-size: 16px;
	}

	.gemsmobile #btn-showall,
	.gemsmobile #btn-hideall {
		font-size: 18px;
	}


	#all-items.gemsmobile .product-item img{
		filter: grayscale(0%)
	}

	.section-slider .tp-caption.tp-resizeme.text-white.font-heading.font-weight-600.ls-close {
	    letter-spacing: 4px !important;
	}

	#store-text {
	}
	#store-text h2 {
		font-size: 22px;
		line-height: 28px;
		margin-top: 20px;
	}
	#store-text h3 {
		font-size: 14px;
		line-height: 28px;
		margin-top: 20px;
	}

	#store-wrap {
		display: inline-block;
		width: 900px;
		height: calc(900 / 1100 * 260px);
		background-size: 900px calc(900 / 1100 * 260px);
		margin: 0 auto;
	}
	#store-inner {
		padding: 2% 5.5%;
	}
	#store-wrap .store-item {
	}

	#copyright-logo {
	}
	#copyright-text {
		display: inline-block;
		margin: 0 0 0 2em;
	}




}
								/* for PC **************************************** end */

.gemsmobile h3.hikaku {
	position: relative;
	font-size: 20px;
	background-color: rgba(240,220,60,1);
	padding: 16px 0;
	margin-bottom: 16px;
}
	.gemsmobile h3.hikaku::after {
		content: '';
		display: inline-block;
		position: absolute;
		bottom: -28px;
		left: calc(50% - 32px / 2);
		width: 16px;
		height: 12px;
		border: 12px solid transparent;
		border-top: 16px solid rgba(240,220,60,1);
	}
.gemsmobile h3.try-and-buy {
	position: relative;
	font-size: 20px;
	background-color: rgba(255,173,123,1);
	padding: 16px 0;
	margin-bottom: 16px;
}
	.gemsmobile h3.try-and-buy::after {
		content: '';
		display: inline-block;
		position: absolute;
		bottom: -28px;
		left: calc(50% - 32px / 2);
		width: 16px;
		height: 12px;
		border: 12px solid transparent;
		border-top: 16px solid rgba(255,173,123,1);
	}
.gemsmobile .tryandbuy {
	text-align: left;
	font-size: 12px;
	line-height: 1.4em;
	display: inline-block;
	color: #400;
	background: rgba(240,220,60,.2);
	padding: 0.8em 3em;
	border-radius: 6px;"
}
.gemsmobile .tryandbuy h4 {
	font-size: 19px;
	font-weight: 700;
	color: #400;
	margin-bottom: 5px;
}
.gemsmobile h3.spec {
	position: relative;
	font-size: 20px;
	background-color: rgba(180,210,240,1);
	padding: 16px 0;
}
	.gemsmobile h3.spec::after {
		content: '';
		display: inline-block;
		position: absolute;
		bottom: -28px;
		left: calc(50% - 32px / 2);
		width: 16px;
		height: 12px;
		border: 12px solid transparent;
		border-top: 16px solid rgba(180,210,240,1);
	}
.gemsmobile .spec-text {
	display: inline-block;
	text-align: left;
	line-height: 1.5em;
}

.gemsmobile h3.buy-gemsoftstore {
	position: relative;
	font-size: 20px;
	color: #fff;
	background-color: rgb(255, 140, 0);
	padding: 16px 0;
	margin-bottom: -15px;
	text-align: center;
}
	.gemsmobile h3.buy-gemsoftstore::after {
		content: '';
		display: inline-block;
		position: absolute;
		bottom: -28px;
		left: calc(50% - 32px / 2);
		width: 16px;
		height: 12px;
		border: 12px solid transparent;
		border-top: 16px solid rgb(255, 140, 0);
	}


/*  amazon sale table
*/

.ws-nowrap {
	white-space: nowrap;
}

.saletable {
	border: 1px solid #ccc;
	border-radius: 4px;
	margin-bottom: 10px;
}
.saletable > a {
	display: flex;
	align-items: center;
	padding: 7px 20px;
}
.saletable > a:hover {
	background-color: rgba(65,105,255,0.1);
}
.saletable > a > span:last-of-type {
	margin-left: auto;
}
.saletable .product-title {
	word-break: keep-all;
	font-weight: 700;
	line-height: 1.6em;
}
.saletable .sale-info {
	display: flex;
	line-height: 1.4em;
}
.saletable .sale-info > span {
	margin-right: 20px;
	padding-left: 20px;
	border-left: 1px solid #f3f3f3;
}
.saletable .label {
	font-size: 9px;
	font-weight: 400;
	color: #555;
	line-height: 10px;
}
.saletable .sale-info s {
	color: rgba(65,105,255,0.6);
}
.saletable .sale-info s .list-price {
	color: rgba(65,105,255,1);
}
.saletable .second {
	font-size: 0.85em;
}
.saletable .en {
	margin-left: 3px;
	font-size: 0.85em;
}

@media screen and (max-width: 480px) {
	.saletable > a {
		align-items: center;
		flex-direction: column;
		padding: 7px 10px;
	}
	.saletable > a > span:last-of-type {
		margin-top: 10px;
		margin-left: 0;
		font-size: 13px;
	}
	.saletable .product-title {
		line-height: 1.3em;
	}
	.saletable .sale-info {
		justify-content: space-between;
		width: 100%;
	}
	.saletable .sale-info > span {
		margin: 0;
		padding: 0;
		border: 0px;
	}
	.saletable .sale-info > span:nth-of-type(2) {
		margin: 0 10px;
		padding: 0 10px;
		border-right: 1px solid #e3e3e3;
		border-left: 1px solid #e3e3e3;
	}
}


.item-inlinebox {
	display: box;
	margin: 10px 0;
}
.item-inlinebox li {
	display: inline-block;
	white-space: nowrap;
	padding: 5px 1.5em;
	margin: 4px;
}
.item-inlinebox.red li {
	background-color: rgba(220,30,30,1);
	color: #fff;
}

hr.blank {
	height: 0px;
}
hr.blank-double {
	height: 0px;
	margin: 20px 0 40px;
}

hr.middle {
	margin: 10px 0;
}

.box-work .image-box {
	margin: 15px -12px;
}


.balloon {
	position: relative;
	background-color: #fff;
	min-width: 120px;
	max-width: 100%;
}

.balloon:before {
	content: "";
	position: absolute;
	top: 100%;
	left: 50%;
	margin-left: -30px;
	border: 30px solid transparent;
	border-top: 30px solid #fff;
}


/* switch-tab
*/

.switch-box {
  flex-wrap: wrap;
  display: flex;
  justify-content: flex-end;
}
 
.switch-label {
  background-color: #f3f3f3;
  padding: 0 1.5em;
  line-height: 2em;
  text-align: center;
  display: inline-block;
  order: -1;
}
 
input.switch-radio {
  display: none;
}
 
input:checked + .switch-label {
  background-color: rgba(255,168,0,0.6);
}
 
.switch-body {
  display: none;
  width: 100%;
}
 
input:checked + .switch-label + .switch-body {
  display: block;
}


.btn-detail {
	display: flex;
	justify-content: flex-end;
}
.btn-detail a,
.btn-detail p {
	background-color: #e0e0e0;
	padding: 0.3em 1.5em;
	color: #333;
}





.detail-layer {
	z-index: 20000;
	position: absolute;
	top: 0;
	left: 0;
	padding: 20px;
	background-color: rgba(0,0,0,0.4);
}

.top-layer-close {
	display: flex;
	justify-content: flex-end;
	opacity: 0.4;
	padding-bottom: 20px;
}

.button-w100 {
	display: block;
	text-align: center;
	padding: 20px;
}
.button-close,
.button-close:hover,
.button-close:active {
	margin-top: 50px;
	color: #000;
	background-color: darkorange;
	font-size: 16px;
	font-weight: 700;
}


.button-db {
	position: absolute;
	display: inline-block;
	bottom: 0;
	left: 0;
	width: 100px;
	height: 20px;
}
.button-db.cld {
	background-color: rgba(100,200,200,0.5);
}



/* acordeon
*/

ul.acordeon {
	margin-left: 0;
}
ul.acordeon input,
ul.acordeon i {
	display: none;
}
ul.acordeon li {
	margin: 1.5em 0;
}

/*
.transition, ul.acordeon .acordeon-body, ul.acordeon li i:before, ul.acordeon li i:after {
	transition: all 0.25s ease-in-out; }

.flipIn, ul.acordeon li {
	animation: flipdown 0.5s ease both; }

ul.acordeon {
	list-style: none;
	perspective: 900;
	padding: 0;
	margin: 0;
	border-top: 1px dotted #666; }
	ul.acordeon li {
		position: relative;
		padding: 0;
		margin: 0;
		padding-top: 14px;
		padding-bottom: 14px;
		border-bottom: 1px dotted #666; }
		ul.acordeon li:nth-of-type(1) {
			animation-delay: 0.5s; }
		ul.acordeon li:nth-of-type(2) {
			animation-delay: 0.75s; }
		ul.acordeon li:nth-of-type(3) {
			animation-delay: 1s; }
		ul.acordeon li:last-of-type {
			padding-bottom: 0; }
		ul.acordeon li i {
			position: absolute;
			transform: translate(-6px, 0);
			margin-top: 16px;
			right: 0; }
			ul.acordeon li i:before, ul.acordeon li i:after {
				content: "";
				position: absolute;
				background-color: #ff6873;
				width: 3px;
				height: 9px; }
			ul.acordeon li i:before {
				transform: translate(-2px, 0) rotate(45deg); }
			ul.acordeon li i:after {
				transform: translate(2px, 0) rotate(-45deg); }
		ul.acordeon li input[type=checkbox] {
			position: absolute;
			cursor: pointer;
			width: 100%;
			height: 100%;
			z-index: 1;
			opacity: 0; }
			ul.acordeon li input[type=checkbox]:checked ~ .acordeon-body {
				margin-top: 0;
				max-height: 0;
				opacity: 0;
				transform: translate(0, 50%); }
			ul.acordeon li input[type=checkbox]:checked ~ i:before {
				transform: translate(2px, 0) rotate(45deg); }
			ul.acordeon li input[type=checkbox]:checked ~ i:after {
				transform: translate(-2px, 0) rotate(-45deg); }

		ul.acordeon .acordeon-body {
			padding-bottom: 20px; }


@keyframes flipdown {
	0% {
		opacity: 0;
		transform-origin: top center;
		transform: rotateX(-90deg); }
	5% {
		opacity: 1; }
	80% {
		transform: rotateX(8deg); }
	83% {
		transform: rotateX(6deg); }
	92% {
		transform: rotateX(-3deg); }
	100% {
		transform-origin: top center;
		transform: rotateX(0deg); } }
*/






/* 20231116
*/

.or-banners {
	display: block;
}
.or-banner-margin {
	margin-top: 10px;
}















