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


#mainImg {
	padding-bottom: 3%;
}

.loadYoutube {
	position: relative;
	width: 66%;
	padding-top: calc(.66 * 56.25%);
	margin: 0 auto;
}

.loadYoutube iframe {
	position: absolute;
	top: 0;
	right: 0;
	width: 100% !important;
	height: 100% !important;
}

.accessories .copy {
	margin-top: 6rem;
	text-align: center;
}

.keyCapsSet .copy {
	margin-top: 0;
	text-align: left;
}

.accessories h2 {
	font-size: 4rem;
	line-height: 1.3;
	font-weight: 500;
	color: #fff;
	margin-top: 0;
	margin-bottom: .2em !important;
	padding: 0;
	border-bottom: none;
}

.keyCapsSet h2 {
	font-size: 2.4rem;
	margin-top: 1.5em;
	margin-bottom: .5em !important;
}

.keyCapsSet h2:first-of-type {
	margin-top: 0;
}

.accessories .copy p {
	font-size: 1.14em;
	font-weight: 500;
}

.keyCapsSet .copy p {
	font-size: 1em;
	font-weight: 400;
}

.newColor {
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
	justify-content: center;
}

.newColor li {
	width: 30%;
	text-align: center;
	margin: 1.66%;
}

.newColor dl {
	width: 100%;
	max-width: 400px;
	margin: 0 auto;
}

.newColor dd {
	margin: 1.2em 0 0;
	font-size: 1em;
}

.newColor dd h5 {
	font-weight: 600;
	font-size: inherit;
	color: inherit;
	margin: 0.25em 0;
}

.newColor dd p {
	margin: 0;
	text-align: justify;
	font-weight: 300;
}


@media screen and (min-width: 1100px) {
	.accessories h2 {
		font-size: 5rem;
	}

	.keyCapsSet h2 {
		font-size: 4rem;
	}
}


@media screen and (max-width: 800px) {

	.newColor {
		display: block;
		width: 84%;
		margin: 0 auto;
	}

	.newColor li {
		width: 100%;
		margin-top: 1.6em;
	}

	.newColor img {
		width: 51%;
	}

	.newColor dd {
		margin-top: 0.75em;
	}
}


@media screen and (max-width: 600px) {

	.newColor img {
		width: 72%;
		min-width: 250px;
	}
}


@media screen and (max-width: 350px) {

	.newColor img {
		width: 95%;
		min-width: auto;
	}
}


.accessories h3 {
	font-size: 4rem;
	font-weight: 700;
	color: #fff;
	margin: 2em 0 0;
	position: relative;
	z-index: 1;
}

.hrBorder::after {
	z-index: -1;
}


.target {
	font-size: 2rem;
	margin: 2.5em 0 .2em;
	position: relative;
}

.target::after {
	content: "";
	display: block;
	position: absolute;
	bottom: -.5em;
	position: absolute;
	left: 0;
	width: 1.5em;
	height: .3em;
	background: #d60000;
}

.target strong {
	color: #fff;
	font-weight: 600;
}

.target + p {
	margin: 1.5em 0 -0.5em;
}

.itemLineUp {
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
}

.itemLineUp h4 {
    font-size: 2.1rem;
    font-weight: 600;
    color: #fff;
    margin: 0;
}



.item {
	width: 48%;
	margin: 4% 4% 0 0;
	box-sizing: border-box;
	background: #1c1c1c;
	padding: 2.5%;
}

.item:nth-of-type(2n) {
	margin-right: 0;
}

.itemImgSet {
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-start;
}

.itemImg {
	position: relative;
	display: flex;
	flex-direction: column;
	flex-wrap: wrap;
	width: 400px;
	max-width: 100%;
	margin-bottom: 1.6em;
}

.object {
	display: block;
	height: 0;
	position: relative;
	font-size: 0;
}

.longKey .object {
	padding-top: min(38.88%, 156px);
	/*幅に対する縦の比率, 最大=幅400pxの時の縦px*/
}

.typeKey .object,
.tenkey .object {
	padding-top: min(32.5%, 130px);
	/*幅に対する縦の比率, 最大=幅400pxの時の縦px*/
}

.popup:first-of-type {
	margin-bottom: 2.2em;
}

.tkl .popup {
	/*aspect-ratio: 712/360;*/
	width: 81.2%;
	max-width: 317px;
}

.object img,
.popup img {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
}

.imgTtl {
	margin: 0.25em 0 1em;
}

.imgTtl::before {
	content: "";
	display: inline-block;
	width: 0.24em;
	height: 1em;
	background: #d60000;
	margin-right: 0.5em;
	vertical-align: middle;
}

.item strong {
	font-weight: 400;
	color: #fff;
}

.itemContents {
	padding-left: 1.5em;
	list-style-type: disc;
}


/* Magnific Popup */

.mfp-content {
	max-width: 85% !important;
}

.mfp-arrow-left:before,
.mfp-arrow-right:before {
	border: none !important;
}

.mfp-title {
	padding-right: 5em !important;
}

.mfp-figure:after {
	top: 4em !important;
	bottom: 4em !important;
}

img.mfp-img {
	padding: 4em 0 !important;
}

.mfp-bottom-bar {
	margin-top: -3.4em !important;
}

/* overlay at start */
.mfp-fade.mfp-bg {
  opacity: 0;

  -webkit-transition: all 0.3s ease-out;
  -moz-transition: all 0.3s ease-out;
  transition: all 0.3s ease-out;
}
/* overlay animate in */
.mfp-fade.mfp-bg.mfp-ready {
  opacity: 0.9;
}
/* overlay animate out */
.mfp-fade.mfp-bg.mfp-removing {
  opacity: 0;
}

/* content at start */
.mfp-fade.mfp-wrap .mfp-content {
  opacity: 0;

  -webkit-transition: all 0.3s ease-out;
  -moz-transition: all 0.3s ease-out;
  transition: all 0.3s ease-out;
}
/* content animate it */
.mfp-fade.mfp-wrap.mfp-ready .mfp-content {
  opacity: 1;
}
/* content animate out */
.mfp-fade.mfp-wrap.mfp-removing .mfp-content {
  opacity: 0;
}


@media screen and (min-width: 1800px) {

	.newColor {
		justify-content: space-between;
	}

	.newColor li {
		width: 18.4%;
		margin-left: 0;
		margin-right: 0;
	}
}


@media screen and (min-width: 1600px) {

	.itemImg:first-of-type {
		margin-right: 1.6em;
	}
}


@media screen and (max-width: 900px) {

	br.forMob {
		display: none;
	}
}


@media screen and (max-width: 600px) {

	.itemLineUp {
		display: block;
	}

	.item {
		width: 100%;
		padding: 5%;
	}
}