@charset "UTF-8";
/*
 * CONTENT STYLESHEET.
 *
################################################################################
 */
@import url(https://maxcdn.bootstrapcdn.com/font-awesome/4.7.0/css/font-awesome.min.css);
@import url(https://fonts.googleapis.com/css?family=Noto+Sans);
/* ========================================================================== *
 * component.
.* ========================================================================== */
/* component: トップページコンテンツ.
 * -------------------------------------------------------------------------- */
/* メインビジュアル. */
.mainvisual {
	margin-bottom:64px;
}

.mainvisual img {
	width:100%;
	height:auto;
	vertical-align:top;
}

.mainvisual .slick-arrow {
	padding:0;
	border:none;
	position:absolute;
	top:0;
	bottom:0;
	width:18%;
	overflow:hidden;
	z-index:1;
	color:rgba(0, 0, 0, .25);
	-webkit-appearance:none;
	   -moz-appearance:none;
	        appearance:none;
	text-indent:-7659px;
	-webkit-transition:color .2s linear 0s;
	        transition:color .2s linear 0s;
	cursor:pointer;
}

@media (max-width: 769px) {
	.mainvisual .slick-arrow {
		background:transparent;
	}
}

@media (min-width: 770px) {
	.mainvisual .slick-arrow {
		background:url(../common_img/pattern-check_wh80.png);
		background-size:2px;
	}
}

@media (min-width: 770px) {
	.mainvisual .slick-arrow:hover {
		color:#ff8500;
	}
}

.mainvisual .slick-arrow:focus,
.mainvisual .slick-arrow:active {
	color:rgba(0, 0, 0, .25) !important;
}

@media (min-width: 770px) {
	.mainvisual .slick-arrow:focus:hover {
		color:#ff8500 !important;
	}
}

.mainvisual .slick-arrow::before {
	margin-top:-30px;
	display:block;
	position:absolute;
	top:50%;
	height:60px;
	line-height:60px;
	font-family:"themify";
	font-style:normal;
	font-weight:400;
	font-variant:normal;
	text-align:center;
	text-transform:none;
	speak:none;
	text-indent:0;
	box-sizing:border-box;
}

@media (max-width: 769px) {
	.mainvisual .slick-arrow::before {
		margin-left:-.5em;
		left:50%;
		font-size:32px;
	}
}

@media (min-width: 770px) {
	.mainvisual .slick-arrow::before {
		font-size:40px;
	}
}

.mainvisual .slick-prev {
	left:0;
}

@media (min-width: 770px) {
	.mainvisual .slick-prev {
		border-right:1px solid #fff;
	}
}

.mainvisual .slick-prev::before {
	content:"\e65e";
}

@media (min-width: 770px) {
	.mainvisual .slick-prev::before {
		right:8px;
	}
}

.mainvisual .slick-next {
	right:0;
}

@media (min-width: 770px) {
	.mainvisual .slick-next {
		border-left:1px solid #fff;
	}
}

.mainvisual .slick-next::before {
	content:"\e65d";
}

@media (min-width: 770px) {
	.mainvisual .slick-next::before {
		left:8px;
	}
}

.mainvisual .slick-dots {
	margin:0;
	padding-top:8px;
	padding-left:0;
	position:absolute;
	top:100%;
	right:0;
	width:100%;
	list-style-type:none;
	text-align:center;
}

.mainvisual .slick-dots > li {
	line-height:1px;
	display:inline-block;
}

.mainvisual .slick-dots > li button {
	margin-right:4px;
	margin-left:4px;
	padding:8px 0 0;
	border:none;
	width:40px;
	height:0;
	vertical-align:top;
	background:#000 url(../common_img/pattern-check_wh.png);
	background-size:2px;
	-webkit-appearance:none;
	   -moz-appearance:none;
	        appearance:none;
	text-indent:-9854px;
}

.mainvisual .slick-dots > li.slick-active button {
	background-color:#ff8500;
}

/* メインビジュアル下2バナー. */
.top-lead-bnr ul {
	margin-right:auto;
	margin-left:auto;
	padding-left:0;
	max-width:704px;
	position:relative;
	list-style-type:none;
}

.top-lead-bnr ul:after {
	display:block;
	clear:both;
	content:"";
}

.top-lead-bnr ul > li {
	float:left;
}

.top-lead-bnr ul > li:first-child {
	margin-left:0 !important;
}

.top-lead-bnr ul > li:last-child {
	margin-right:0 !important;
}

@media (max-width: 769px) {
	.top-lead-bnr ul > li {
		width:50%;
	}
	.top-lead-bnr ul > li a {
		border-left:0;
		border-right:0;
	}
	.top-lead-bnr ul > li:first-child a {
		padding-right:0;
		border-right:1px solid #b2b2b2;
	}
}

@media (min-width: 770px) {
	.top-lead-bnr ul > li {
		margin-left:2.27273%;
		width:48.86364%;
	}
}

.top-lead-bnr a {
	border:1px solid #b2b2b2;
	padding:1px;
	display:block;
}

.top-lead-bnr img {
	width:100%;
	height:auto;
	vertical-align:top;
}

/* センターバナー. */
.top-mid-bnr p {
	margin-right:auto;
	margin-left:auto;
  position:relative;
	max-width:400px;
}

.top-mid-bnr a {
	border:1px solid #b2b2b2;
  display:block;
  padding: 3%;
}

.top-mid-bnr img {
  width:96%;
	height:auto;
	vertical-align:top;
}

/* トップ新着情報. */
.top-news {
	padding-top:20px;
	padding-bottom:20px;
	background:#ebebeb;
}

.top-news .top-news-inner {
	margin-right:auto;
	margin-left:auto;
	position:relative;
	max-width:1000px;
	z-index:0;
}

.top-news .top-news-more {
	margin:0;
	position:absolute;
	top:0;
	right:0;
}

@media (max-width: 769px) {
	.top-news .top-news-more {
		margin-top:3px;
	}
}

@media (max-width: 769px) {
	.top-news .top-news-more .button {
		font-size:10px;
	}
}

.top-news .top-news-body {
	margin-top:20px;
	padding-top:30px;
	padding-bottom:30px;
	background:#fff;
}

.top-news .top-news-items {
	margin:0;
	padding:2px 0;
	border-left:4px solid #ff8500;
	list-style-type:none;
	overflow-y:scroll;
	-webkit-overflow-scrolling:touch;
}

.top-news .top-news-item a {
	margin-right:20px;
	margin-left:20px;
	padding-top:15px;
	padding-bottom:15px;
	border-bottom:1px dotted #ff8500;
	display:block;
	color:#333;
	text-decoration:none;
}

.top-news .top-news-item:first-child a {
	padding-top:0;
}

.top-news .top-news-item dl {
	margin:0;
}

.top-news .top-news-date {
	margin-right:1em;
	float:left;
	color:#ff8500;
}

@media (min-width: 770px) {
	.top-news .top-news-date {
		font-size:14px;
	}
}

.top-news .top-news-title {
	margin-left:0;
	overflow:hidden;
}

@media (min-width: 770px) {
	.top-news .top-news-title {
		font-size:14px;
	}
}

/* トップ最下部大バナー. */
.top-panels .panels-foot .button {
	font-size:18px;
}

@media (max-width: 769px) {
	.top-panels .panels-foot .button {
		padding-top:.5em;
		padding-bottom:.5em;
	}
}

/* component: 対応端末から探す.
 * -------------------------------------------------------------------------- */
/* media-itemsだけアイコンを大きくする. */
.media-items .header-bilingual .fa {
	width:32px;
	height:32px;
	line-height:32px;
	font-size:42px;
}

.media-items .banners-foot .button {
	font-size:18px;
}

@media (max-width: 769px) {
	.media-items .banners-foot .button {
		padding-top:.5em;
		padding-bottom:.5em;
	}
}

@media (min-width: 770px) {
	.media-items .banners-foot .button {
		margin-right:auto;
		margin-left:auto;
		padding-top:1em;
		padding-bottom:1em;
		width:420px;
	}
}

/* component: シリーズ・キャラクターから探す.
 * -------------------------------------------------------------------------- */
/* series-itemsだけスマホのテキストを小さく. */
@media (max-width: 769px) {
	.series-items .header-bilingual [lang="ja"] {
		font-size:17px;
		letter-spacing:-1px;
	}
}

.series-items .banners-foot .button {
	font-size:18px;
}

@media (max-width: 769px) {
	.series-items .banners-foot .button {
		padding-top:.5em;
		padding-bottom:.5em;
	}
}

@media (min-width: 770px) {
	.series-items .banners-foot .button {
		margin-right:auto;
		margin-left:auto;
		padding-top:1em;
		padding-bottom:1em;
		width:420px;
	}
}

/* component: 新着情報.
 * -------------------------------------------------------------------------- */
.news .container {
	max-width:960px;
}

.news .news-item {
	border-bottom:1px solid #ccc;
}

@media (max-width: 769px) {
	.news .news-item {
		padding-top:8px;
		padding-bottom:24px;
	}
}

@media (min-width: 770px) {
	.news .news-item {
		padding-top:16px;
		padding-bottom:32px;
	}
}

.news .news-date {
	margin-top:16px;
	margin-bottom:24px;
	color:#ff8500;
	font-size:14px;
	font-size:1.4rem;
}

.news .news-title {
	margin-top:-20px;
	margin-bottom:24px;
	position:relative;
	font-size:20px;
	font-size:2rem;
}

.news .news-body {
	border-top:1px dashed #ccc;
	font-size:14px;
	font-size:1.4rem;
}

@media (max-width: 769px) {
	.news .news-body {
		padding-top:16px;
	}
}

@media (min-width: 770px) {
	.news .news-body {
		padding-top:24px;
	}
}

.news .news-media {
	margin-right:auto;
	margin-left:auto;
	max-width:600px;
}

@media (max-width: 769px) {
	.news .news-media:not(:last-child) {
		margin-bottom:16px;
	}
}

@media (min-width: 770px) {
	.news .news-media:not(:last-child) {
		margin-bottom:32px;
	}
}

.news .news-media img {
	width:100%;
	height:auto;
}

.news-pagination .container {
	max-width:960px;
}

/* component: 商品一覧.
 * -------------------------------------------------------------------------- */
/* 上部商品検索. */
.productsearch {
	background:#ebebeb;
}

.productsearch a {
	text-decoration:none;
}

.productsearch .container {
	max-width:1100px;
}

.productsearch .productsearch-head {
	margin:0;
	padding-top:16px;
	padding-bottom:16px;
	text-align:center;
}

@media (max-width: 769px) {
	.productsearch .productsearch-head {
		font-size:16px;
	}
}

@media (min-width: 770px) {
	.productsearch .productsearch-head {
		font-size:18px;
	}
}

.productsearch .productsearch-head a {
	color:#000;
	-webkit-transition:color .2s linear 0s;
	        transition:color .2s linear 0s;
}

@media (min-width: 770px) {
	.productsearch .productsearch-head a:hover {
		color:#ff8500;
	}
}

.productsearch .productsearch-head a:active,
.productsearch .productsearch-head a:focus {
	color:#000;
}

@media (min-width: 770px) {
	.productsearch .productsearch-head a:active:hover,
	.productsearch .productsearch-head a:focus:hover {
		color:#ff8500;
	}
}

.productsearch .productsearch-head a::after {
	margin-left:.25em;
	display:inline-block;
	content:"\f0fe";
	font-family:"FontAwesome";
}

.productsearch .productsearch-head a.is-active::after {
	content:"\f146";
}

.productsearch .productsearch-list {
	margin:0;
	padding:16px 0 24px;
	border-top:1px dotted #ccc;
	list-style-type:none;
}

.productsearch .productsearch-list .header-bilingual .fa {
	text-align:center;
}

.productsearch .productsearch-device {
	margin-bottom:16px;
}

/* productsearch-deviceだけアイコンを大きくする. */
.productsearch .productsearch-device .header-bilingual .fa {
	width:32px;
	height:32px;
	line-height:32px;
	font-size:48px;
}

@media (max-width: 769px) {
	.productsearch .productsearch-device .productsearch-modalinput {
		margin-top:8px;
	}
}

@media (min-width: 770px) {
	.productsearch .productsearch-device .productsearch-modalinput {
		width:68%;
	}
}

.productsearch .productsearch-keyword {
	margin-bottom:16px;
}

@media (min-width: 770px) {
	.productsearch .productsearch-keyword {
		width:68%;
		float:left;
	}
}

@media (min-width: 770px) {
	.productsearch .productsearch-keyword input[type="text"] {
		padding:.5em;
		line-height:1.4;
		font-size:18px;
		letter-spacing:normal;
	}
}

.productsearch .productsearch-group {
	margin-bottom:16px;
}

@media (min-width: 770px) {
	.productsearch .productsearch-group {
		float:right;
		margin-left:2%;
		width:30%;
	}
}

@media (min-width: 770px) {
	.productsearch .productsearch-group .productsearch-select {
		margin-right:0;
		width:100%;
		line-height:1.4;
		font-size:18px;
	}
	.productsearch .productsearch-group .productsearch-select select {
		padding:.5em;
		line-height:1.4;
	}
}

.productsearch .productsearch-character {
	margin-bottom:16px;
}

@media (min-width: 770px) {
	.productsearch .productsearch-character {
		clear:both;
	}
}

.productsearch .productsearch-point {
	margin-bottom:16px;
}

.productsearch .productsearch-category {
	margin:0;
}

.productsearch .productsearch-category > dt {
	margin-bottom:8px;
}

.productsearch .productsearch-category > dd {
	margin-left:0;
}

@media (min-width: 770px) {
	.productsearch .productsearch-category > dd {
		letter-spacing:-.40em;
	}
}

@media (min-width: 770px) {
	.productsearch .productsearch-select {
		margin-right:2%;
		display:inline-block;
		width:30%;
		vertical-align:middle;
		letter-spacing:normal;
	}
}

.productsearch .productsearch-modalinput {
	margin:0;
}

@media (min-width: 770px) {
	.productsearch .productsearch-modalinput {
		display:inline-table;
		width:100%;
		vertical-align:middle;
		letter-spacing:normal;
	}
}

.productsearch .productsearch-modalinput .productsearch-modalinput-inner {
	margin-left:0;
}

@media (min-width: 770px) {
	.productsearch .productsearch-modalinput .productsearch-modalinput-inner {
		border:1px solid #d5d5d5;
		display:table-cell;
		vertical-align:middle;
		background:#f5f5f5;
		letter-spacing:-.40em;
	}
}

@media (min-width: 770px) {
	.productsearch .productsearch-array {
		margin-right:2%;
		width:73%;
		min-height:34px;
		display:inline-block;
		vertical-align:middle;
		letter-spacing:normal;
	}
}

@media (max-width: 769px) {
	.productsearch .productsearch-array input[type="text"] {
		margin-bottom:4px;
		border-color:#d5d5d5;
		background:#f5f5f5;
	}
	.productsearch .productsearch-array input[type="text"]:focus {
		border-color:#d5d5d5;
	}
}

@media (min-width: 770px) {
	.productsearch .productsearch-array input[type="text"] {
		border:none;
		background:transparent;
	}
}

.productsearch .productsearch-modalwindow {
	display:none;
}

@media (max-width: 769px) {
	.productsearch .productsearch-submitwrap p {
		margin-top:8px;
		margin-bottom:0;
	}
}

@media (min-width: 770px) {
	.productsearch .productsearch-submitwrap p {
		margin-top:0;
		margin-bottom:0;
		font-size:18px;
		text-align:center;
	}
}

.productsearch .productsearch-submitwrap p .button {
	line-height:1.5;
}

@media (max-width: 769px) {
	.productsearch .productsearch-submit {
		display:block;
		width:100%;
	}
}

@media (min-width: 770px) {
	.productsearch .productsearch-submit {
		width:440px;
	}
}

.productsearch .productsearch-submit.blink {
	position:relative;
	-webkit-animation-iteration-count:4;
	        animation-iteration-count:4;
	-webkit-animation-timing-function:linear;
	        animation-timing-function:linear;
	-webkit-animation-duration:.7s;
	        animation-duration:.7s;
	-webkit-animation-name:flash;
	        animation-name:flash;
}

.productsearch-modalwindow {
	margin-right:auto;
	margin-left:auto;
	position:relative;
	max-width:940px;
}

.productlist-toggle {
	padding-top:24px;
	padding-bottom:0;
	text-align:center;
}

@media (max-width: 769px) {
	.productlist-toggle {
		display:none;
	}
}

.productlist-toggle ul {
	margin:0;
	padding:2px;
	border:1px solid #ccc;
	border-radius:23px;
	display:inline-block;
	background:#d5d5d5;
	text-decoration:none;
	letter-spacing:-.40em;
	box-shadow:inset 0 0 0 2px #ebebeb;
}

.productlist-toggle li {
	display:inline-block;
}

.productlist-toggle a,
.productlist-toggle span {
	padding-right:40px;
	padding-left:40px;
	border-radius:20px;
	display:block;
	line-height:40px;
	font-size:16px;
	letter-spacing:normal;
	text-decoration:none;
}

.productlist-toggle a {
	color:#000;
	-webkit-transition:color .2s linear 0s;
	        transition:color .2s linear 0s;
}

.productlist-toggle a:hover {
	color:#666;
}

.productlist-toggle span {
	color:#fff;
	background:#898989;
	cursor:default;
}

/* リスト下バナー. */
.product-bnr p {
	margin-right:auto;
	margin-left:auto;
	position:relative;
	max-width:400px;
}

.product-bnr a {
	border:1px solid #b2b2b2;
  display:block;
  padding: 3%;
}

.product-bnr img {
	width:96%;
	height:auto;
	vertical-align:top;
}

/* JAN一覧. */
@media (max-width: 769px) {
	.product-jan .jantable,
	.product-jan .pager {
		display:none;
	}
}

@media (min-width: 770px) {
	.product-jan .blank {
		display:none;
	}
}

/* 印刷ボタン. */
#printpage {
	margin-top:24px;
	text-align:center;
}

@media (max-width: 769px) {
	#printpage {
		display:none;
	}
}

#printpage .button {
	font-size:22px;
}

/* component: 商品詳細.
 * -------------------------------------------------------------------------- */
.productdetail .productdetail-head {
	background:#ebebeb;
}

@media (max-width: 769px) {
	.productdetail .productdetail-head {
		margin-bottom:24px;
		padding-top:16px;
		padding-bottom:16px;
	}
}

@media (min-width: 770px) {
	.productdetail .productdetail-head {
		margin-bottom:32px;
		padding-top:24px;
		padding-bottom:24px;
	}
}

@media (min-width: 770px) {
	.productdetail .productdetail-head-inner {
		display:table;
		width:100%;
	}
}

.productdetail .productdetail-name {
	padding:0;
}

@media (max-width: 769px) {
	.productdetail .productdetail-name {
		margin:0;
		font-size:16px;
	}
}

@media (min-width: 770px) {
	.productdetail .productdetail-name {
		padding-right:1em;
		display:table-cell;
		vertical-align:middle;
		font-size:24px;
	}
}

.productdetail .productdetail-id {
	padding:0;
}

@media (max-width: 769px) {
	.productdetail .productdetail-id {
		margin:8px 0 0;
		padding-top:8px;
		border-top:1px dotted #aaa;
		font-size:12px;
		text-align:right;
	}
}

@media (min-width: 770px) {
	.productdetail .productdetail-id {
		padding-left:1em;
		border-left:1px dotted #aaa;
		display:table-cell;
		width:20%;
		vertical-align:middle;
		font-size:14px;
		text-align:right;
		white-space:nowrap;
	}
}

.productdetail .productdetail-lead {
	margin-right:auto;
	margin-left:auto;
	max-width:940px;
}

.productdetail .productdetail-lead:after {
	display:block;
	clear:both;
	content:"";
}

.productdetail .productdetail-thumb {
	margin-bottom:.5em;
	float:left;
}

@media (max-width: 769px) {
	.productdetail .productdetail-thumb {
		margin-right:3%;
		width:48.5%;
		max-width:333px;
	}
}

@media (min-width: 770px) {
	.productdetail .productdetail-thumb {
		margin-right:2em;
		width:333px;
	}
}

.productdetail .productdetail-thumb a {
	display:block;
}

.productdetail .productdetail-thumb a.js-imgmodal {
	position:relative;
	cursor:zoom-in;
}

.productdetail .productdetail-thumb a.js-imgmodal::after {
	position:absolute;
	right:0;
	bottom:0;
	color:#fff;
	background:rgba(0, 0, 0, .5);
	content:"\f00e";
	width:1.2em;
	height:1.2em;
	line-height:1.2;
	text-align:center;
	font-family:"FontAwesome";
	font-size:20px;
	-webkit-transition:opacity .2s linear 0s;
	        transition:opacity .2s linear 0s;
}

.productdetail .productdetail-thumb a.js-imgmodal:hover::after {
	filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=75);
	opacity:.75;
}

.productdetail .productdetail-thumb img {
	width:100%;
	height:auto;
	vertical-align:top;
}

.productdetail .productdetail-txt {
	overflow:hidden;
}

@media (min-width: 770px) {
	.productdetail .productdetail-txt {
		font-size:116.66667%;
	}
}

@media (min-width: 770px) {
	.productdetail .productdetail-share {
		width:50%;
		float:left;
	}
}

.productdetail .productdetail-share dl {
	margin:0;
	border:1px solid #ccc;
	display:table;
}

.productdetail .productdetail-share dt,
.productdetail .productdetail-share dd {
	padding:8px 0;
	display:table-cell;
	vertical-align:middle;
}

.productdetail .productdetail-share dt {
	width:50%;
	font-weight:700;
}

@media (max-width: 769px) {
	.productdetail .productdetail-share dt {
		font-size:16px;
	}
}

@media (min-width: 770px) {
	.productdetail .productdetail-share dt {
		font-size:18px;
	}
}

.productdetail .productdetail-share dt .fa {
	width:30%;
	color:#ccc;
	font-weight:400;
	text-align:center;
}

.productdetail .productdetail-share dd {
	margin-left:0;
	width:50%;
}

.productdetail .productdetail-share ul {
	margin:0;
	padding-left:0;
	list-style-type:none;
	width:100%;
	display:table;
	table-layout:fixed;
}

.productdetail .productdetail-share ul > li {
	display:table-cell;
	text-align:center;
}

.productdetail .productdetail-share #share-facebook {
	color:#3b5998;
}

.productdetail .productdetail-share #share-twitter {
	color:#55acee;
}

.productdetail .productdetail-share #share-mail {
	color:#dd4b39;
}

.productdetail .productdetail-share .fa {
	display:inline-block;
	font-size:32px;
	vertical-align:middle;
}

@media (max-width: 769px) {
	.productdetail .productdetail-store {
		margin-top:16px;
	}
	.productdetail .productdetail-store .text {
		margin:0;
		border:solid 1px #ff8500;
		text-align:center;
		line-height:3.0;
		vertical-align:middle;
		font-size: 16px;
		color:#ff8500;
	}
}

@media (min-width: 770px) {
	.productdetail .productdetail-store {
		width:50%;
		float:right;
		text-align:right;
	}
	.productdetail .productdetail-store .text {
		display: inline-block;
		margin:0;
		padding: 0 5em;
		border:solid 1px #ff8500;
		text-align:center;
		line-height:3.0;
		vertical-align:middle;
		font-size: 16px;
		color:#ff8500;
	}
}

.productdetail .productdetail-store .button {
	font-size:16px;
	line-height:3;
}

@media (max-width: 769px) {
	.productdetail .productdetail-store .button {
		padding:0;
		display:block;
		text-align:center;
	}
}

@media (min-width: 770px) {
	.productdetail .productdetail-store .button {
		margin-top:1px;
		margin-bottom:1px;
		padding:0 3em;
	}
}

.productdetail .productdetail-store .button .fa {
	margin-right:4px;
	padding-right:0;
	padding-left:0;
	top:-4px;
	position:relative;
	display:inline-block;
	font-size:24px;
	vertical-align:middle;
}

.productdetail .productdetail-points ul {
	margin:0;
	padding-left:0;
	list-style-type:none;
}

.productdetail .productdetail-points li {
	margin-bottom:1em;
}

.productdetail .productdetail-points dl {
	margin:0;
}

@media (min-width: 770px) {
	.productdetail .productdetail-points dl {
		display:table;
		width:100%;
	}
}

@media (min-width: 770px) {
	.productdetail .productdetail-points dt,
	.productdetail .productdetail-points dd {
		display:table-cell;
	}
}

.productdetail .productdetail-points dt {
	font-size:14px;
}

@media (min-width: 770px) {
	.productdetail .productdetail-points dt {
		width:222px;
		vertical-align:top;
	}
}

.productdetail .productdetail-points dt img {
	border:1px solid #ccc;
}

.productdetail .productdetail-points dt .points-dt-inner {
	display:table;
}

.productdetail .productdetail-points dt .points-dt-img {
	display:table-cell;
	width:79px;
	vertical-align:middle;
}

.productdetail .productdetail-points dt .points-dt-txt {
	padding-left:.5em;
	display:table-cell;
	vertical-align:middle;
	font-weight:700;
}

.productdetail .productdetail-points dd {
	margin-left:0;
}

@media (max-width: 769px) {
	.productdetail .productdetail-points dd {
		margin-top:4px;
	}
}

@media (min-width: 770px) {
	.productdetail .productdetail-points dd {
		padding-left:1em;
		vertical-align:middle;
		font-size:14px;
	}
}

@media (min-width: 770px) {
	.productdetail .productdetail-freetext .productdetail-freetext-media {
		margin-right:1em;
		float:left;
		width:222px;
	}
}

.productdetail .productdetail-freetext .productdetail-freetext-media a {
	display:block;
}

.productdetail .productdetail-freetext .productdetail-freetext-media a.js-imgmodal {
	position:relative;
	cursor:zoom-in;
}

.productdetail .productdetail-freetext .productdetail-freetext-media a.js-imgmodal::after {
	position:absolute;
	right:0;
	bottom:0;
	color:#fff;
	background:rgba(0, 0, 0, .5);
	content:"\f00e";
	width:1.2em;
	height:1.2em;
	line-height:1.2;
	text-align:center;
	font-family:"FontAwesome";
	font-size:20px;
	-webkit-transition:opacity .2s linear 0s;
	        transition:opacity .2s linear 0s;
}

.productdetail .productdetail-freetext .productdetail-freetext-media a.js-imgmodal:hover::after {
	filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=75);
	opacity:.75;
}

.productdetail .productdetail-freetext .productdetail-freetext-media img {
	width:100%;
	height:auto;
}

@media (min-width: 770px) {
	.productdetail .productdetail-freetext .productdetail-freetext-body {
		overflow:hidden;
		font-size:116.66667%;
	}
}

.productdetail .productdetail-cmnspec ul {
	margin:0;
	padding-left:0;
	list-style-type:none;
}

.productdetail .productdetail-cmnspec li {
	padding-top:16px;
	padding-bottom:16px;
	border-bottom:1px dotted #b5b5b5;
}

.productdetail .productdetail-cmnspec li:first-child {
	padding-top:8px;
}

.productdetail .productdetail-cmnspec dl {
	margin:0;
	display:table;
	width:100%;
}

.productdetail .productdetail-cmnspec dt,
.productdetail .productdetail-cmnspec dd {
	display:table-cell;
}

.productdetail .productdetail-cmnspec dt {
	vertical-align:top;
}

@media (max-width: 769px) {
	.productdetail .productdetail-cmnspec dt {
		width:5.5em;
	}
}

@media (min-width: 770px) {
	.productdetail .productdetail-cmnspec dt {
		padding-left:10px;
		width:300px;
		font-size:16px;
		font-size:1.6rem;
	}
}

@media (max-width: 769px) {
	.productdetail .productdetail-cmnspec dt span {
		font-size:10px;
	}
}

@media (min-width: 770px) {
	.productdetail .productdetail-cmnspec dt span {
		font-size:12px;
	}
}

.productdetail .productdetail-cmnspec dd {
	margin-left:0;
	padding-left:1em;
	vertical-align:middle;
}

@media (min-width: 770px) {
	.productdetail .productdetail-cmnspec dd {
		font-size:14px;
	}
}

.productdetail .productdetail-colorspec .productdetail-colorspec-jantoggle {
	margin-top:-1.25em;
	padding:0;
	display:block;
	position:absolute;
	top:50%;
	right:.5em;
	line-height:2.5em;
	width:168px;
	letter-spacing:normal;
	font-size:12px;
	font-weight:400;
	text-decoration:none;
	text-align:center;
}

.productdetail .productdetail-colorspec .container-inner {
	padding-bottom:1px;
}

@media (min-width: 770px) {
	.productdetail .productdetail-attention .productdetail-attention-body {
		font-size:116.66667%;
	}
}

@media (min-width: 770px) {
	.productdetail .productdetail-download .productdetail-download-txt {
		font-size:16px;
	}
}

.productdetail .productdetail-download .productdetail-download-btn {
	margin-top:12px;
	text-align:center;
}

.productdetail .productdetail-download .productdetail-download-btn .button {
	padding:.25em 64px .25em 12px;
	font-size:18px;
	text-align:left;
}

.productdetail .productdetail-download .productdetail-download-btn .button span {
	display:block;
	font-size:12px;
}

.productdetail .productdetail-download .productdetail-download-btn .button .fa {
	margin-top:-.5em;
	position:absolute;
	top:50%;
	right:12px;
	font-size:32px;
}

/* component: ray-outについて.
 * -------------------------------------------------------------------------- */
.about:first-child {
	margin-top:24px;
}

.about .about-head {
	margin-bottom:1em;
	padding-left:3em;
	position:relative;
}

@media (max-width: 769px) {
	.about .about-head {
		font-size:20px;
	}
}

@media (min-width: 770px) {
	.about .about-head {
		font-size:28px;
		letter-spacing:2px;
	}
}

.about .about-head .roman {
	margin-top:-1em;
	border:1px solid #ff8500;
	display:block;
	position:absolute;
	top:50%;
	left:0;
	width:2em;
	height:2em;
	line-height:2;
	color:#ff8500;
	text-align:center;
	letter-spacing:normal;
	box-sizing:border-box;
	font-family:"Times New Roman",serif;
}

@media (max-width: 769px) {
	.about .about-head .roman {
		font-size:24px;
	}
}

@media (min-width: 770px) {
	.about .about-head .roman {
		font-size:26px;
	}
}

@media (min-width: 770px) {
	.about .about-body p {
		line-height:1.75;
		font-size:16px;
		font-size:1.6rem;
	}
}

.about .about-img > img {
	width:100%;
	height:auto;
}

/* component: よくある質問.
 * -------------------------------------------------------------------------- */
.faq:first-child {
	padding-top:24px;
}

.faq > .container-inner {
	border:1px solid #ccc;
}

.faq .faq-head {
	margin:0;
	padding-top:.75em;
	padding-bottom:.75em;
	padding-left:3.25em;
	padding-right:2.5em;
	position:relative;
	line-height:1.5;
}

@media (max-width: 769px) {
	.faq .faq-head {
		font-size:16px;
	}
}

@media (min-width: 770px) {
	.faq .faq-head {
		font-size:18px;
	}
}

.faq .faq-head::after {
	margin-top:-.5em;
	position:absolute;
	top:50%;
	right:12px;
	content:"\f0fe";
	width:1em;
	height:1em;
	line-height:1;
	color:#ff8500;
	font-family:"FontAwesome";
	font-weight:400;
}

.faq .faq-head.is-active::after {
	color:#aaa;
	content:"\f146";
}

.faq .faq-head .q {
	border:1px solid #ff8500;
	position:absolute;
	top:.275em;
	left:.3em;
	display:block;
	width:1.5em;
	height:1.5em;
	line-height:1.4;
	color:#ff8500;
	text-align:center;
	letter-spacing:normal;
	box-sizing:border-box;
	font-family:"Times New Roman",serif;
	font-weight:700;
}

@media (max-width: 769px) {
	.faq .faq-head .q {
		font-size:24px;
	}
}

@media (min-width: 770px) {
	.faq .faq-head .q {
		font-size:26px;
	}
}

@media (max-width: 769px) {
	.faq .faq-body {
		padding:0 7px 7px;
	}
}

@media (min-width: 770px) {
	.faq .faq-body {
		padding:0 8px 8px;
	}
}

.faq .faq-inner {
	padding-top:12px;
	border-top:1px dashed #d5d5d5;
	position:relative;
	padding-right:1em;
}

@media (max-width: 769px) {
	.faq .faq-inner {
		padding-left:3.25em;
	}
}

@media (min-width: 770px) {
	.faq .faq-inner {
		padding-left:4.2em;
	}
}

.faq .faq-inner::before {
	border:1px solid #999;
	position:absolute;
	left:0;
	display:block;
	width:1.5em;
	height:1.5em;
	line-height:1.4;
	color:#999;
	text-align:center;
	letter-spacing:normal;
	box-sizing:border-box;
	content:"A";
	font-family:"Times New Roman",serif;
	font-weight:700;
}

@media (max-width: 769px) {
	.faq .faq-inner::before {
		top:18px;
		font-size:24px;
	}
}

@media (min-width: 770px) {
	.faq .faq-inner::before {
		top:18px;
		font-size:26px;
	}
}

.faq .faq-inner p,
.faq .faq-inner ul,
.faq .faq-inner ol,
.faq .faq-inner dl {
	font-size:14px;
	font-size:1.4rem;
}

.faq .faq-inner dl > dt {
	margin-top:2.5em;
	padding-top:1em;
	padding-bottom:.5em;
	border-top:1px dotted #ccc;
	font-weight:700;
}

.faq .faq-inner dl > dd {
	margin-left:0;
	margin-bottom:.75em;
}

.faq .faq-inner .faq-imglist {
	margin:0;
	padding-left:0;
	list-style-type:none;
}

.faq .faq-inner .faq-imglist:after {
	display:block;
	clear:both;
	content:"";
}

.faq .faq-inner .faq-imglist img {
	width:100%;
}

@media (max-width: 769px) {
	.faq .faq-inner .faq-imglist > li {
		margin-top:8px;
	}
	.faq .faq-inner .faq-imglist > li:first-child {
		margin-top:0;
	}
	.faq .faq-inner .faq-imglist > li img {
		max-width:450px;
	}
}

@media (min-width: 770px) {
	.faq .faq-inner .faq-imglist > li {
		margin-left:2%;
		width:32%;
		float:left;
	}
	.faq .faq-inner .faq-imglist > li:first-child {
		margin-left:0;
	}
}

@media (min-width: 770px) {
	.faq .faq-inner .faq-imglist.faq-imglist_large > li {
		margin-left:0;
		width:100%;
		float:none;
	}
}

@media (min-width: 770px) {
	.faq .faq-inner .faq-imglist.faq-imglist_large img {
		width:auto;
	}
}

/* component: 会社案内.
 * -------------------------------------------------------------------------- */
.company .company-head {
	margin-top:1em;
	margin-bottom:1.5em;
	padding-bottom:.5em;
	position:relative;
	text-align:center;
}

@media (max-width: 769px) {
	.company .company-head {
		font-size:20px;
	}
}

@media (min-width: 770px) {
	.company .company-head {
		font-size:24px;
	}
}

.company .company-head::after {
	margin-right:-40px;
	position:absolute;
	top:100%;
	right:50%;
	display:block;
	width:80px;
	height:1px;
	background:#ff8500;
	content:"";
}

@media (max-width: 769px) {
	.company .company-tablehead {
		width:5em;
	}
}

@media (min-width: 770px) {
	.company .company-tablehead {
		width:31.91489%;
	}
}

.company .tablesimple ul {
	margin-top:0;
	margin-bottom:0;
}

@media (min-width: 770px) {
	.company .company-column:after {
		display:block;
		clear:both;
		content:"";
	}
}

.company .company-photo {
	height:0;
	background:url(../company/images/company.jpg) right bottom no-repeat;
	background-size:cover;
}

@media (max-width: 769px) {
	.company .company-photo {
		margin-bottom:24px;
		padding-top:80%;
	}
}

@media (min-width: 770px) {
	.company .company-photo {
		padding-top:45%;
		float:right;
		width:31.91489%;
	}
}

@media (max-width: 769px) {
	.company .company-map {
		text-align:center;
	}
}

@media (min-width: 770px) {
	.company .company-map {
		float:left;
		width:63.82979%;
	}
}

@media (max-width: 769px) {
	.company .company-map iframe {
		width:300px;
	}
}

@media (min-width: 770px) {
	.company .company-map iframe {
		width:100%;
	}
}

.company .company-access > dt {
	margin-bottom:.5em;
	font-size:16px;
	font-weight:700;
}

.company .company-access > dd {
	margin-left:0;
}

@media (max-width: 769px) {
	.company .company-access > dd {
		font-size:12px;
	}
}

@media (min-width: 770px) {
	.company .brand-column:after {
		display:block;
		clear:both;
		content:"";
	}
}

@media (min-width: 770px) {
	.company .brand-logo {
		float:left;
		width:31.91489%;
	}
}

.company .brand-img {
	/*border:1px solid #ccc;*/
	box-sizing:border-box;
	text-align: center;
}

.company .brand-img > img {
width:80%;
height:auto;
}
.brand-info{text-align: center;}
@media (min-width: 770px) {
	.company .brand-info {
		float:right;
		width:63.82979%;
	}
	.company .brand-img > img {
	width:100%;
	height:auto;
	}
	.brand-info{text-align: initial;}
}

.company .brand-name {
	margin-top:0;
	margin-bottom:0;
}

@media (max-width: 769px) {
	.company .brand-name {
		font-size:32px;
	}
}

@media (min-width: 770px) {
	.company .brand-name {
		font-size:40px;
	}
}

.company .brand-name span {
	white-space:nowrap;
}

@media (max-width: 769px) {
	.company .brand-name span {
		font-size:14px;
	}
}

@media (min-width: 770px) {
	.company .brand-name span {
		margin-left:1em;
		vertical-align:5%;
		font-size:18px;
	}
}

.company .brand-description {
	margin-top:0;
}

@media (max-width: 769px) {
	.company .brand-description {
		font-size:12px;
	}
}

.company .brand-lineup {
	border:1px solid #ccc;
	padding:16px 24px;
}

.company .brand-lineup > dt {
	font-weight:700;
}

@media (min-width: 770px) {
	.company .brand-lineup > dt {
		font-size:16px;
	}
}

.company .brand-lineup > dd {
	margin-left:0;
}

/* component: プライバシーポリシー.
 * -------------------------------------------------------------------------- */
.privacy .document-head .fa {
	-webkit-transform:scale(1.35);
	        transform:scale(1.35);
}

/* component: お問い合わせ.
 * -------------------------------------------------------------------------- */
/* リードコンテンツ */
@media (min-width: 770px) {
	.contact-lead {
		line-height:2.5;
		text-align:center;
	}
}

/* お問い合わせフォーム */
.contact-form .container {
	max-width:960px;
}

.contact-form .contact-form-list {
	margin:0;
	padding-left:0;
	list-style-type:none;
}

@media (min-width: 770px) {
	.contact-form .contact-form-list:after {
		display:block;
		clear:both;
		content:"";
	}
}

.contact-form .contact-form-list > li {
	margin-top:6px;
	margin-bottom:6px;
}

@media (min-width: 770px) {
	.contact-form .contact-form-list > li {
		float:left;
		width:50%;
	}
}

.contact-form .contact-form-name {
	border-bottom:0;
}

.contact-form .contact-form-address .zip {
	margin-right:.5em;
	margin-left:.5em;
	width:6em;
}

.contact-form .contact-form-foot {
	padding-top:1em;
	text-align:center;
}


.contact-form .contact-form-foot input[type="button"],
.contact-form .contact-form-foot input[type="submit"] {
	max-width: 360px;
	height: 50px;
	margin-right:  10px;
	margin-left:   10px;
	margin-bottom: 10px;
	border: 0 none !important;
	color: #fff;
	-webkit-transition: background .2s;
			transition: background .2s;
	cursor: pointer;
}

.contact-form .contact-form-foot input[type="button"]{
	background-color: #898989;
}
.contact-form .contact-form-foot input[type="button"]:hover {
	background-color: #a3a3a3;
}

.contact-form .contact-form-foot input[type="submit"] {
	background-color: #ff8500;
	cursor: pointer;
}
.contact-form .contact-form-foot input[type="submit"]:hover {
	background-color: #ff9d33;
}
.contact-form .contact-form-foot input[type="submit"]:disabled {
	background-color: #ebebeb !important;
	cursor: default;
}


@media (max-width: 769px) {
	.contact-form .contact-form-foot label {
		font-size:13px;
	}
}

.contact-form .contact-form-foot p {
	margin-bottom:2em;
	font-size:12px;
}

.contact-form .contact-form-foot .button {
	font-size:20px;
	font-weight:700;
}

@media (max-width: 769px) {
	.contact-form .contact-form-foot .button {
		display:block;
		width:100%;
	}
}

@media (min-width: 770px) {
	.contact-form .contact-form-foot .button {
		margin-right:.5em;
		margin-left:.5em;
		padding:1em 4em;
	}
}

@media (max-width: 769px) {
	.contact-form .contact-form-foot .button.button_c-gy {
		margin-bottom:1em;
		font-size:14px;
	}
}




/* component: 汎用ケース、汎用タブレット対応機種一覧表.
 * -------------------------------------------------------------------------- */
.tokusyu:first-child {
	margin-top:24px;
}

.tokusyu .tokusyu-head {
	margin-bottom:1em;
	position:relative;
}
.tokusyu .tokusyu-head dt{
	float: left;
	color: #ff8500;
	border: 1px solid #ff8500;
	text-align: center;
	margin-right: 20px;
	padding: 0 10px;
	font-weight: bold;
}
.tokusyu .tokusyu-head dd{
	font-weight: bold;
	line-height: 44px;
}
.tokusyu ul,
.tokusyu li{
	list-style: none;
	margin: 0 0 20px;
	padding: 0;
}
.tokusyu .acd ul{
  display: none;
	margin: 0;
	padding: 0;
}
.tokusyu .acd li {
	position: relative;
	cursor: pointer;
	padding: 0 0 0 10px;
	font-size: 16px;
	font-size: 1.6rem;
}
.tokusyu .acd li::before {
	position: absolute;
	content: '';
	display: block;
	top: 22px;
	right: 20px;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 6px 0 6px 12px;
	border-color: transparent transparent transparent #ccc;
	transition: All 0.3s ease;
	-webkit-transition: All 0.3s ease;
	-moz-transition: All 0.3s ease;
	-o-transition: All 0.3s ease;
}
.tokusyu .acd li.selected::before {
	border-width: 12px 6px 0 6px;
	border-color: #fff transparent transparent transparent;
}
.tokusyu .acd span {
	display: block;
	padding: 15px;
	border: 1px solid #ccc;
	transition: All 0.3s ease;
	-webkit-transition: All 0.3s ease;
	-moz-transition: All 0.3s ease;
	-o-transition: All 0.3s ease;
}
.tokusyu .acd .selected span {
	display: block;
	padding: 15px;
	border: 1px solid #ff8400;
	background: #ff8400;
	color: #fff;
}
.tokusyu .acd .selected ul {
	margin: 20px 0;
}
.tokusyu .acd .selected .selected ul {
	margin: 10px 0;
}
.tokusyu .acd li li {
	font-size: 14px;
	font-size: 1.4rem;
	line-height: 40px;
	margin-bottom: 0;
	padding-left: 30px;
	border-bottom: 1px dashed #ccc;
}

.tokusyu .acd li li li{
	border-bottom: none;
}

.tokusyu .acd li li::before {
	top: 15px;
	right: auto;
	left: 15px;
	border-width: 3px 0 3px 6px;
}
.tokusyu .acd li li.selected::before {
	border-width: 6px 3px 0 3px;
	border-color: #ff8400 transparent transparent transparent;
}
.tokusyu .smp li li li,
.tokusyu .tbl li li,
.tokusyu .multi li li li {
	border: none;
	line-height: 32px;
}
.tokusyu .smp li li li::before,
.tokusyu .tbl li li::before,
.tokusyu .multi li li li::before {
	top: 13px;
	border: none;
	width: 4px;
	height: 4px;
	background: #ccc;
}

@media (max-width: 769px) {
	.tokusyu .tokusyu-head {
		font-size:20px;
	}
	.tokusyu .tokusyu-head dt{
		float: none;
		margin-right: 0;
	}
	.tokusyu .tokusyu-head dd{
		margin: 0;
		text-align: center;
	}
}

@media (min-width: 770px) {
	.tokusyu .tokusyu-head {
		font-size:28px;
		letter-spacing:2px;
	}
	.tokusyu .tokusyu-body p {
		line-height:1.75;
		font-size:16px;
		font-size:1.6rem;
	}
}

/* Shadowverse（シャドウバース）スマホケース
 * -------------------------------------------------------------------------- */
.future.container {
	max-width: 1400px;
	box-sizing: border-box;
	padding-right: 0;
	padding-left: 0;
}

.future:first-child {
	margin-top:24px;
}

.future .future-head {
	margin: 0;
	font-size: 20px;
}

.future figure.top {
	margin: 0 0 80px;
}

.future .outer {
	max-width: 1280px;
	margin: 0 auto 80px;
	padding-right: 10px;
	padding-left: 10px;
}

.future .outer:nth-of-type(even) {
	flex-direction: row-reverse;
}

.future .outer:nth-of-type(odd) .col figure {
	text-align: left;
	margin-right: 30px;
}

.future .outer:nth-of-type(even) .col figure {
	text-align: right;
	margin-left: 30px;
}

.future .outer .col {
	width: 50%;
}

.future .outer .col .lead {
	flex-grow: 1;
}

.future .outer .col figure {
	margin: 0;
}

.future figure img {
	max-width: 100%;
}

@media (max-width: 769px) {

	.future.container {
		padding-right: 3.125%;
		padding-left: 3.125%;
	}

	.future figure.top img {
		width: 100%;
	}

	.future .future-head {
		font-size: 16px;
	}

	.future .outer {
		display: block;
		margin-bottom: 50px;
		padding-right: 0;
		padding-left: 0;
	}

	.future .outer .col {
		display: block;
		width: 100%;
		margin: 0;
	}

	.future .outer .col figure {
		margin: 0 0 15px;
	}
	.future .outer:nth-of-type(odd) .col figure {
		margin-right: 0;
	}
	.future .outer:nth-of-type(even) .col figure {
		margin-left: 0;
	}

	.future .outer .col figure img {
		width: 100%;
	}

}

@media (min-width: 770px) {

}

