<html><head><meta name="color-scheme" content="light dark"></head><body><pre style="word-wrap: break-word; white-space: pre-wrap;">@charset "utf-8";
/* CSS Document */

/*＝＝＝＝＝スタイルのリセット＝＝＝＝＝＝*/

html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed, 
figure, figcaption, footer, header, hgroup, 
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
margin: 0;
padding: 0;
border: 0;
font-size: 100%;
font: inherit;
}
/* HTML5 display-role reset for older browsers */	
article, aside, details, figcaption, figure, 
footer, header, hgroup, menu, nav, section {
display: block;
}
body {
	margin: 0;
	line-height: 1;
}
ol, ul {
list-style: none;
}
blockquote, q {
quotes: none;
}
blockquote:before, blockquote:after,
q:before, q:after {
content: '';
content: none;
}
table {
border-collapse: collapse;
border-spacing: 0;
}
a{
	text-decoration: none;
	color: #333;
}
/*＝＝＝＝＝スタイルのリセット＝＝＝＝＝＝*/

body{
	background: #fff;
	line-height: 1.6;
	color: #454545;
	font-size:18px;
	font-family: "Noto Sans Japanese",sans-serif;
	font-weight: 300;
}
body header{
	background:#ffffff;
	padding:10px;
	border-bottom: 1px solid #ddd;
	overflow: hidden;
}
body header div{
	margin:0 auto;
}
body header div h1{display: inline-block;margin: 0;}
body header div h1 img{
	width:120px;
}
body header div&gt;a{
	
}
body header div&gt;img{
	height: 50px;
	float:right;
	display: inline-block;
}

body div.main_image{
	text-align: center;
	/*font-size: 0;*/
	background: #f6f6f6;
	padding-bottom: 15px;
}
body div.main_image_cpn{
	font-size: 0 !important;
}
body div.main_image img.top_cpn{
	width: 100%;
	max-width: 1200px;
}

body .desc_top_text #book_text{
	padding: 10px 15px;
}

body div.top_text .desc_top_text{
	margin-top: 20px;
	line-height: 1.6;
	display: flex;
}


body #cpn{
	clear: both;
	margin:40px auto 20px;
	width: 100%;
	max-width: 1200px;
	position: relative;
}

body #cpn .cpn_box{
	border:2px solid #4a7cd3;
	padding: 10px;
	background: #fff;
}	
body #cpn .cpn_box .cpn_title{
	color: #4a7cd3;
	text-align: center;
	font-size:22px; 
	font-weight: 400;
	line-height: 2;
}	

body #cpn .cpn_box table {
	width: 100%;
	font-size:14px; 
	line-height:1.6;
	text-align: left;
}
body #cpn .cpn_box table td {
	border-top: 1px dotted #A1A1A1;
	vertical-align: middle;
	padding:10px 0; 
}
body #cpn .cpn_box table td .item {
	line-height:1.5;
	font-weight: 400;
	white-space:nowrap;
}


body #cpn .cpn_box table td .item_content {
}

.item_content:first-line{
	font-size:16px; 
}
body #cpn .cpn_box table .item_content .date{
	font-size:16px; 
	color:#4a7cd3;
	font-weight: 400;
}

body #cpn .cpn_box table td em {
	font-weight: 400;
}

body #cpn .cpn_box table td .cap_text{
	color: #E3373A;
	font-size:11px;
	vertical-align:text-top;
}


body #cpn img{
	     position: absolute;
    bottom: 70px;
    right: -29px;
    width: 340px;

}



.btn_top{
	display:block;
	box-sizing: border-box;
	background:#d30b23;
	color: #fff;
	border-radius: 4px;
	font-weight:400;
	padding: 10px;
	text-align: center;
	margin: 10px 0;
	box-shadow:3px 3px 0px 3px #9f0b26;
	font-size: 24px;
	/*▼表示用*/
	position:relative;
	/*hover用*/
	/*outline: none;*/
	border: 2px solid #9f0b26;
	
	
	
}
.btn_set{
	background:#00a0c6;
	box-shadow:3px 3px 0px 3px #108ba8;
	border: 2px solid #108ba8;
}

.btn_top:after{
	/*▼表示用*/
	-moz-border-bottom-colors: none;
    -moz-border-left-colors: none;
    -moz-border-right-colors: none;
    -moz-border-top-colors: none;
    border-color: transparent transparent transparent #FFF;
	border-image: none;
    border-style: solid;
	border-width: 7px 7px 7px 9px;
	content: "";
    height: 0;
    position: absolute;
    right: 20px;
    top: 22px;
    width: 0;
	z-index: 1;
}

/*hover用*/
.btn_top::before,
.btn_top::after {
  position: absolute;
  z-index: 2;
  display: block;
  content: '';
}
.btn_top,
.btn_top::before,
.btn_top::after {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  -webkit-transition: all .3s;
  transition: all .3s;
}

.btn_top:hover {
  background-color: #fff;
	color: #d30b23;
	z-index: 3;
	border: 2px solid #d30b23;
	box-shadow:3px 3px 0px 3px #d30b23;
}
.btn_set:after{
	top:22px; 
}
.btn_set:hover{
	background-color: #fbf8be;
	color: #108ba8;
	border: 2px solid #108ba8;
	box-shadow:3px 3px 0px 3px #108ba8;
}
.btn_set:hover:after{
	border-color: transparent transparent transparent #108ba8 !important; 
}

.btn_top:hover:after{
	border-color: transparent transparent transparent #d30b23; 
}


.btn_center{
	margin:10px auto 0;
}

body div.main_contents .hensyu p{
	padding-bottom: 20px;
}

body div.main_image&gt;div div.main_desc{
	clear: both;
	padding-top: 15px;
}

body div.top_text{
	width: 100%;
	max-width:1200px;
	margin: 0 auto;
	font-size: 18px;
}

body div.top_text p.desc{
	font-size: 28px;
    font-weight: 400;
    line-height: 1.4;
    padding: 40px 0 10px;
    border-bottom: 1px dashed #ddd;
    text-align: center;
    color: #4a7cd3;
}
body div.top_text p.desc_second{
	border-bottom: 1px dashed #ddd;
	padding-bottom: 10px;
}

body div.top_text .desc_top_text p.new_add{
	border: 1px solid #ccc;
    border-radius: 5px;
    padding: 10px 15px;
    font-size: 14px;
    color: #808080;
}



body div.top_text .desc_top_text p em{
	    color: #4a7cd3;
    padding: 1px 5px;
}

body div.top_text p.desc span{
	font-size:20px;
	font-weight: 200;
}

body div div.wrapper_price{
	/*background: rgb(26,173,197,.05);*/
	background: #fbfbfb;
    padding: 10px;
    overflow: hidden;
    border-radius: 10px;
    box-sizing: border-box;
}

body div div.wrapper_price .btn_center{
	margin-bottom: 20px;
}
.text_link{
	text-decoration: underline;
	margin-top: -5px;
	padding-bottom: 5px;
	display: block;
}
body div.main_image&gt;div p.price em{
	font-size: 26px;
	font-weight:400;
}

body div.main_image&gt;div p.point,
div.top_text p.point{
	font-size: 18px;
}
body div.main_image&gt;div p.point span,
div.top_text p.point span,
body div.main_contents #special_price&gt;div span,
body div.main_image&gt;div div.main_item p.tokuten span,
body div.main_image_pc&gt;div div.main_item p.tokuten span{
	color:#d30b23;
	font-weight:400;
}
div.top_text p.point{
	text-align: center;
}

body div.main_image&gt;div&gt;div.main_desc{
}
body div.main_contents{
	width: 100%;
	max-width: 1200px;
	padding: 20px;
	margin:0 auto;
	clear: both;
}

body div.main_contents h2{
	margin-top: 30px;
    margin-bottom: 20px;
    padding: 0 0 3px 10px;
    border-left: 4px solid #284457;
    border-bottom: 1px solid #284457;
    font-weight:600;
	color: #284457;
    font-size: 160%;
}
body div.main_contents #contents table{
	margin-bottom: 20px;
}
body div.main_contents #contents table td,
body div.main_contents #contents table th{
	padding:10px;
	border:1px solid #ccc;
	vertical-align: middle;
	font-size: 16px;
}

body div.main_contents #contents table th {
    background: #f6f6f6;
    font-weight: 700;
    text-align: left;
	font-size: 18px;
}
body div.main_contents #contents table td.order{
	background: #f6f6f6;
	text-align: center;
	width:90px;
}




body div.main_contents #set_item h3{
	    font-weight: 600;
    font-size: 120%;
    margin-bottom: 20px;
    padding: 15px;
    /* border-bottom: 1px dashed #ddd; */
    color: #00bcd4;
    background: #f6f6f6;
	
}

body div.main_contents #set_item .text_box {
	display: block;
	text-align: right;
	font-size: 14px;
	padding-bottom: 5px;
}
body div.main_contents #function h3{
	margin:10px 0 10px;
	
}
body div.main_contents #function .func_contents{
	overflow: hidden;
	font-size: 16px;
}

body div.main_contents #function p{
		overflow: hidden;
		padding: 0 10px;
		/*width: calc(100% - 105px);*/
		float: left;
	}

body div.main_contents #revision{
	font-size: 18px;
	margin: 5px;
}
body div.main_contents #revision h3{
	padding-bottom: 5px;
	
}

body div.main_contents #comment table{
	width: 100%;
}
body div.main_contents #comment table span{
	font-weight: 500;
	color: #4a7cd3;
	/*color: #0a3d62;*/
	/*background: linear-gradient(transparent 60%, #ffff66 20%);*/
}
body div.main_contents #comment table p{
	margin-bottom: 5px;
}
body div.main_contents #comment table p em{
	color: #f99e29;
	font-weight: 400;
	font-size: 150%;
}
body div.main_contents #comment table img{
	width: 60px;
	
}
body div.main_contents #comment table th,body div.main_contents #comment table td{
	border-bottom: 1px solid #ddd;
	padding: 20px;
}
body div.main_contents #comment table td{
	padding: 10px;
	font-size: 85%;
}

body div.main_contents #set_item p span{
	font-weight: 400;
	color: #ff4444;
}
body div.main_contents #set_item div&gt;a&gt;p{
	text-align: center;
	font-size: 12px;
    line-height: 150%;
}
body div.main_contents ul{
	padding-left: 25px;
	padding-right: 10px;
}
body div.main_contents li{
	list-style:disc;
}

body div.main_contents #special_price{
}
body div.main_contents #special_price p{
	font-size: 24px;
	margin-bottom: 20px;
	text-align: center;
}
body div.main_contents #special_price p&gt;span.p_line{
	text-decoration: line-through;
	display: inline-block;
	color: #333;
	
}
body div.main_contents #special_price p span.p_sp_price,
body div.main_contents #special_price span.p_sp_price{
	color: #d30b23;
}
body div.main_contents #special_price p span em{
	color: #d30b23;
	font-size: 28px;
	font-weight:400;
}
body div.main_contents #special_price div,
body div.main_image&gt;div p.point, div.top_text p.point{
	text-align: center;
	margin-bottom: 10px;
	font-size: 17px;
}





.set_item{
	width:50%;
	float:left;
}

body div.main_contents #set_item .item_container{
	display: flex;
	justify-content: left;
    flex-wrap: wrap;
}
body div.main_contents #set_item .pre_container .item img{
	width: 210px;
}
body div.main_contents #set_item .pre_item_description{
	padding: 20px;
}
body div.main_contents #set_item h5{
	color: #454545;
	font-size: 16px;
	font-weight: 500;
	padding: 15px 0;
}
body div.main_contents #set_item .pre_item_description .price{
	padding: 30px 0 0;
}

body div.main_contents #set_item .pre_item_description .price span.price_down{
	background-color:#ff4444; 
	color: #fff;
	padding: 2px 15px;
	font-size: 18px;
	font-weight: bold;
}
body div.main_contents #set_item .pre_container h4{
	font-size:18px;
}



body div.main_contents #set_item .pre_item_description .price p{
	text-align: left;
	padding-top: 5px;
	font-size: 16px;
	font-weight: 400;

}
body div.main_contents #set_item .pre_item_description .price p:nth-child(3){
	font-size: 22px;
	padding-top: 0;
	color: #ff4444;
}
body div.main_contents #set_item .pre_item_description .price p span{
	font-size: 14px;
	color: #454545!important;
	font-weight: normal;
}

body div.main_contents #set_item .pre_item_description .price em{
	font-size: 14px;
	color: #454545;
	font-weight: normal;
}
body div.main_contents #set_item .pre_item_description ul{
	list-style: disc;
	line-height: 1.8;
	padding-left: 20px;
	font-size: 15px;
}
body div.main_contents #set_item .pre_item_description ul a{
	text-decoration: underline;
	color: #00a4bf;
}

/*body div.main_contents #set_item&gt;div{
	border-bottom: 1px dashed #ccc;
	margin-bottom: 20px;
}*/
body div.main_contents #set_item h3 a{
	display: block;
}



body div.main_contents #set_item table td{
	padding: 10px 3px;
	vertical-align: top;
}
body div.main_contents #set_item table.pre td{
	text-align: center;
}
body div.main_contents #set_item table td.price_set div{
	/*border:2px solid #d30b23;*/
	padding:5px 10px;
	font-size:16px;
	text-align: center;
	line-height: 1.5;
	background-color:hsla(57,88%,73%,.5);
	border-radius: 5px;
}
body div.main_contents #set_item table td.price_set div span.now{
	font-weight:500; color:#d30b23; font-size:20px;
}
body div.main_contents #set_item table td.price_set div em{font-size:24px;}
body div.main_contents #set_item table td.price_set div span.off{
	display: inline-block; background-color: #d30b23; color: #fff; padding: 5px 8px; vertical-align: top;}


body .main_image_pc{
	margin-top: 40px;
}
body .main_image_pc&gt;div{
	 background: #FFF;
}
body .main_image_pc&gt;div&gt;div&gt;div&gt;span{
	color: #d30b23;
    font-weight:400;
}

body #function h4{
    padding: 8px;
    border-radius: 5px;
    font-weight: 400;
	font-size: 20px;
}
.gamen{
	overflow: hidden;
	padding:40px 0 20px;
	margin: 0 auto;
}

.gamen a{
	width: 133px;
	float: left;
	padding-right: 20px;
	
}
.gamen a p{
	text-align: center;
}
.gamen a img{
	/*width: 133px;*/
	border: 1px solid #ccc;
}

#feature{
	overflow: hidden;
}
#feature .heightLineParent{
	display: flex;
	flex-wrap: wrap;
}
.box_f{
    width: 33%;
    box-sizing: border-box;
    margin-bottom: 20px;
    padding: 15px;
	position: relative;
}

.box_f img{
	margin-right: 10px;
	width: 84px;
	border: 1px solid #ccc;
}
.box_f_img{
	margin-right: 10px;
    width: 84px;
    border: 1px solid #ccc;
    display: block;
    float: left;
}
.box_f p{
	font-size: 14px;
    display: block;
}

.box_f .fig_expansion{
	width: 40px;
    position: absolute;
    left: 60px;
    top: 170px;
	border: none;
}

.box_f .fig_expansion_2{
	width: 40px;
    position: absolute;
    left: 60px;
    top: 190px;
	border: none;
}
body div.main_contents .cap_r_text{
	text-align: right;
	display: block;
	font-size: 14px;
}

body div.main_contents .box_f h3{
	background: none;
    color: #4a7cd3;
    margin: 0;
    line-height: 1.4;
    padding: 0;
    border-bottom: 1px solid #ccc;
    margin-bottom: 10px;
    padding-bottom: 5px;
	font-size: 120%;
    font-weight: 500;
}

body div.main_contents .box_f .cap_text{
	font-size: 12px;
	display: block;
	margin-top: 5px;
}

body div.main_image_pc{
	background: #f6f6f6;
	background-position: center left;
	background-size:cover cover;
	padding: 30px 20px;
}

body div.main_image_pc&gt;div{
	background: #FFF;
	padding: 30px;
	border-radius: 5px;
	box-sizing: border-box;
	margin: 0 auto;
	box-shadow:1px 1px 3px 1px #dde3e6;
	overflow: hidden;
	background: rgba(255,255,255,1);
}

body div.main_image_pc&gt;div img{
	margin:0 24px 0 10px;
	display: block;
	width: 230px;
	float: left;
/*	border:1px solid #ccc;*/
	/*box-shadow: 1px 1px 3px 1px #dde3e6;*/
}
body div.main_image_pc&gt;div div.main_item{
	padding: 0 0 0 10px;
	float: left;
}

body div.main_image_pc&gt;div div.main_item p.title{
	color: #4a7cd3;
	font-size: 34px;
	font-weight:400;
	line-height:1.4;
    border-bottom: 1px dashed #cccccc;
    padding: 0 0 10px;
	margin: 0 0 10px;
}

body div.main_image_pc&gt;div div.main_item p.title{
	color: #4a7cd3;
	font-size: 34px;
	font-weight:400;
	line-height:1.4;
	margin-bottom: 20px;
    border-bottom: 1px dashed #cccccc;
    padding: 0 0 10px;
	margin: 0;
}
body div.main_image_pc&gt;div div.main_item p.title span{
	background: #4a7cd3;
	color: #fff;
	padding: 3px 6px 5px;
	font-size: 22px;
	margin-left: 8px;
	margin-bottom: 3px;
	border-radius: 3px;
	display: inline-block;
}
.pc_desc span{
	    color: #4a7cd3;
	font-weight: 500;
	display: block;
	font-size: 110%;
	margin: 10px 0;	
}
body div.main_image_pc&gt;div div.main_item p.title em{
	font-size: 20px;
}

body div.main_image_pc&gt;div div.main_item p.price{
	margin: 0;
}
div.main_image_pc p.price{
	font-size: 26px;
	line-height:1.4;
}

body div.main_image&gt;div div.main_item p.price em,
div.top_text p.price em,
body div.main_image_pc&gt;div div.main_item p.price em{
	font-size: 30px;
	font-weight:400;
}

.other_voice {
	margin-top: 20px;
	background: #f6f6f6;
	padding: 10px;
	font-size: 100%;
	color: #4a7cd3;
	text-decoration: underline;
}

 #comment .voices a{
	    color: #00a4bf;
    text-decoration: underline;
	 padding: 10px;
}
#comment h2 a{
	color: #00a4bf;
    text-decoration: underline;
	 padding: 10px;
	font-size: 60%;
}

 #comment .voice{
	padding: 10px;
   
    font-size: 75%;
    border-bottom: 1px dashed #ddd;
}
#comment .voice:nth-child(4n){
	border-right: none;
}

 #comment .voice em{
	color: #f99e29;
    font-weight: 400;
    font-size: 150%;
}





/*ーーーーーーーセット商品部分ーーーーーーーーーー
（セット商品LPと同じ）*/
.app_category{
	overflow:hidden;
	padding-top: 15px;
}
div.preitem{
	/*width:100% !important;*/
}
div.preitem .book_image img{
	width: 220px;
}
div.item{
	margin-bottom: 25px;
}
div.item h4:hover,
div.item .book_image:hover{
	opacity: 0.8;
}

div.main_contents#ebook div.item{
	border-right:solid 1px #eee;
}
div.main_contents#ebook div.item:nth-child(3n+1){
	border-right:none;
}

div.item h4{
	border-left:solid 7px #00bcd4;
	padding:10px 0 10px 5px;
	font-size: 15px;
	font-weight: 500;
}
div.item h4 span{
	color: #808080;
	font-size: 13px;
	display: block;
	margin-top: 5px;
	font-weight: 200;
}
div.item a &gt;p{
	margin: 5px 0;
}
ul.navi li a{
	vertical-align: top;
	position: relative;
}
div.item h4&gt;em{
	text-decoration: underline;
	line-height: 1.3;
	color: #00a4bf;
}
div.item h4 span em,
.releasedate em{
	background: #ff4444;
    color: #fff;
    padding: 2px 4px;
    display: inline-block;
    margin: 0 2px;
    border-radius: 2px;
    font-size: 12px;
    font-weight: 200;
}

div.item p{
	text-align: center;
}
#magazine div.item .book_image{
	width: 100%;
}

#ebook div.item .book_image img{
	height: 175px;
}
div.item table.only_teika{
	width: 200px;
}


div.item table{
	width: 256px;
	margin: 0 auto;
	line-height: 1.2;
}
div.item table td {
	
}
div.item table td span{
	font-size: 12px;
	display: block;
}
div.item table td:nth-child(2){
	font-weight: 700;
}
div.item table td:nth-child(3){
	color: #ff4444;
	font-weight: 500;
	font-size: 18px;
}
div.item table td:nth-child(3) em,
div.item table td:nth-child(3) span{
	color: #454545;
	font-weight: 300;
	font-size: 12px;
}
div.item table td em{
	font-size: 12px;
}

div.item .ac{
	background: #f6f6f6;
	padding: 5px;
	box-sizing: border-box;
	
}
div.item a.link_pdf{
	color: #00bcd4;
	text-decoration: underline;
	margin: 10px;
	text-align: center;
	display: block;
	box-sizing: border-box;
	line-height: 1.3;
}
div.item a.link_pdf img{
	margin-left: 4px;
}
div.item .tokuten{
	border:1px solid #e6e6e6;
	border-radius: 3px;
	box-sizing: border-box;
	margin-bottom: 10px;
	margin-top: 5px;
	padding: 5px;
	font-size: 14px;
	line-height:1.4;
	
}
div.item .tokuten span{
	display: inline-block;
	font-size: 12px;
	color: #fff;
	background: #00bcd4;
	padding: 2px 5px;
	border-radius: 2px;
	margin-right: 3px;
	margin-bottom: 2px;
	
	
}
div.item .tokuten hr{
	margin: 5px 0;
}
div.item .tokuten.red{
	border:1px solid #ff4444;
	color: #ff4444;
}
div.item .tokuten.red span{
	background: #ff4444;
}
div.item .tokuten.red em{
	color: #454545;
}
div.item .tokuten em{
	font-size: 12px;
	padding-left:5px;
}
div.item .ac.jmed{
	/*margin-top: 15px;*/
}
div.item .ac p{
	font-size: 13px;
}
div.item .ac .inner{
	margin-top: 5px;
	font-size: 13px;
	padding: 10px;
	line-height: 1.8;
	/*border-top: 1px solid #ccc;*/
	display: none;
	background: #fff;
}
div.item .ac .inner p{
	text-align: left;
	border-top: 1px solid #eee;
	padding-top: 5px;
	margin-top: 5px;
}
div.item .ac .inner a{
	text-decoration: underline;
}
div.item table{
	width: 256px;
	margin: 0 auto;
	line-height: 1.2;
}
div.item table td {
	
}
div.item table td span{
	font-size: 12px;
	display: block;
}
div.item table td:nth-child(2){
	font-weight: 700;
}
div.item table td:nth-child(3){
	color: #ff4444;
	font-weight: 500;
	font-size: 18px;
}
div.item table td:nth-child(3) em,
div.item table td:nth-child(3) span{
	color: #454545;
	font-weight: 300;
	font-size: 12px;
}
div.item table td em{
	font-size: 11px;
}

div.top_return {
    position: fixed;
    bottom: 16px;
    right: 16px;
    z-index: 999;
}
div.top_return a {
    display: block;
    text-decoration: none;
    background: #000;
    padding: 10px 15px 10px 10px;
    padding: 10px 15px 10px 10px;
    border-radius: 5px;
    color: #FFF;
	font-weight: 100;
    z-index: 0;
    opacity: 0.6;
}



/*ーーーーアコーディングーーーー*/

.cp_actab {
	position: relative;
	overflow: hidden;
	width: 100%;
	margin: 0 auto;
	/*color: #ffffff;*/
}
.cp_actab input {
	position: absolute;
	z-index: -1;
	opacity: 0;
}
.cp_actab label {
	font-weight: bold;
	line-height: 3;
	position: relative;
	display: block;
	cursor: pointer;
	margin: 0 0 1px 0;
	background: #f6f6f6;
	padding: 0 0 0 1em;
}
.cp_actab .cp_actab-content {
	overflow: hidden;
	max-height: 0;
	-webkit-transition: max-height 0.35s;
	transition: max-height 0.35s;
	color: #454545;
}

/* :checked */
.cp_actab input:checked ~ .cp_actab-content {
	max-height: 1000em;
	
}
/* Icon */
.cp_actab label::after {
	line-height: 3;
	position: absolute;
	top: 0;
	right: 0;
	display: block;
	width: 3em;
	height: 3em;
	-webkit-transition: all 0.35s;
	transition: all 0.35s;
	text-align: center;
	font-size: 24px;
    color: #4a7cd3;
}
.cp_actab input[type=checkbox] + label::after {
	content: '+';
}
.cp_actab input[type=checkbox]:checked + label::after {
	transform: rotate(315deg);
}


/*---------------------*/




@media screen and (min-width:641px) { 
	/*　画面サイズが641px以上はここを読み込む　*/
	.sp_view{
		display: none;
	}

	body div.main_image&gt;div,
	body div.main_image_pc&gt;div{
	width:1200px;
	}
	body div.main_contents #contents table td{
	width: 1200px;
}
	body div div.wrapper_price{
	}

	body div.main_image_pc&gt;div div.main_item{
	    width: 830px;
    text-align: left;
	}
	body div.main_contents #set_item table{
	width: 100%;
}


	.btn_top{
	width: 900px;
	margin: 20px auto;
    clear: both;
}
	
	body div div.wrapper_price{
		margin:40px auto;
	}

	
	body div.main_contents&gt;div{
	margin-bottom: 60px;
}
	body div.wrapper_cpn div.main_contents&gt;div{
		background: #fff;
		border-radius: 10px;
		margin: 60px 0 !important;
	}
	


	
	
	
	/*ーーーーーセット商品部分ーーーーーー*/
		div.price.pre_price{
		width: 500px;
		margin-left: 300px;
		overflow: hidden;
	}
	div.price.pre_price .price3{
		width: 200px !important;
	}

	ul.navi{
	width: 1200px;
	margin:0px auto;
		box-sizing: border-box;
}
ul.navi li{
	background: #00bcd4;
	margin: 15px 10px 15px 0;
	display: inline-block;
	font-weight: 400;
	font-size: 22px;
	width: 297px;
	border-radius: 3px;
	text-align: center;
	box-shadow:0px 4px 0px 0px #0f8e9e;
}
	ul.navi li:last-child{
		margin: 15px 0 15px 0;
	}
ul.navi li:hover{
	opacity: 0.7;
}

ul.navi li a{
	color: #fff;
	display: block;
	width: 100%;
	height: 100%;
	padding:15px 20px 15px 35px;
	font-size: 18px;
	box-sizing: border-box;
}
ul.navi li a em{
	background: #ff4444;
    color: #fff;
    padding: 5px 4px;
    display: inline-block;
    margin-right: 6px;
    border-radius: 2px;
    font-size: 13px;
    font-weight: 200;
    position: absolute;
	left: 15px;
	top:12px;
}
	.app_category{
		display: flex;
		flex-wrap: wrap;
		justify-content: flex-start;
	}
	.pre_container .btn_top{
	width: 100%;
    font-size: 18px;

}
	 .pre_container .btn_top:after {
    top: 18px;
}
	#box-item1 .item,#box-item2 .item{
		width: 60%;
	}	
	#box-item1 .pre_item_description,#box-item2 .pre_item_description{
		width: 40%;
	}
div.item{
	width: 290px;
	margin-bottom: 25px;
    float: left;
    padding: 10px;
    box-sizing: border-box;
    margin-bottom: 25px;
    border-bottom: 1px solid #ddd;
	}
	
div.item .book_image{
	text-align: center;
	height: 170px;	
}
	div.item.pre .book_image img{
		width: 280px;
	}
	
	.fig_upgrade{
	display: block;
	margin:20px  auto;
	padding-right: 50px;
}
	.wrapper_cpn{
		background: /*#c8e2e8*/#fff;
	}
	
	body  ul.menu_pc{
	float: right;
	display: block;
	width: 720px;
	border-right: 1px solid #eee;
}
body  ul.menu_pc li{
	width: 140px;
	float: left;
	display: table;
	height: 52px;
	border-left:1px solid #eee;
	text-align: center;
	
}

/*body  ul.menu_pc li:first-child{
	width: 150px;
}*/
body  ul.menu_pc li a{
	display: block;
	width: 100%;
    height: 100%;
    display: table-cell;
    vertical-align: middle;
    color: #666;
    font-size: 14px;
    line-height: 1.2;
}
	.main_image_last{
		padding: 60px 20px 70px !important;
	}
	
	
	
}
@media screen and (max-width:640px) { 
    /*　画面サイズが640px以下はここを読み込む　*/
	.heightLineParent{
		width: 100%;
	}
	#feature .box_f{
		width: 100%;
		display: block;
		margin: 0 auto 10px;
	}
	.bnr_set img{
		width: 100%;
	}
	body{
		font-size: 16px;
	}
	body header div{
		width: 100% !important;
		box-sizing: border-box;
	}
	body div.main_image{
		box-sizing: border-box;
	}
	
	body div.main_image&gt;div,
	body div.main_image_pc&gt;div{
		width: 100%;
		box-sizing: border-box;
		padding: 10px;	
		margin: auto;
		box-shadow: none;
	}
	
	body div.main_image{
		padding:  10px;
	}
	.wrapper_cpn{
		margin:20px 0 0;
	}
	body div.main_image&gt;div img, body div.main_image_pc&gt;div img{
		margin-bottom: 10px;
	}
	body div.top_text p.desc span{
		font-size:14px;
		font-weight: 200;
	}

	body div.main_image_pc&gt;div div.main_item p.title span{
		    font-size: 15px;
    display: inline-block;
    margin-bottom: 5px;
    padding: 3px 6px;
	}
	
	body div.top_text{
		width: 100%;
		box-sizing: border-box;
		padding: 10px;
		font-size: 16px;
		
	}
	
	body div.top_text .desc_top_text{
		display: block !important;
		margin-top: 10px;
	}
	body .desc_top_text #book_text{
	padding: 10px;
}
	body .desc_top_text #book_text .kaitei_block{
	width: 100%;
	padding: 20px 0;
}
body .desc_top_text #book_text .kaitei_text{
	width: 100%;
	}
body .desc_top_text #book_text .kaitei_img{
	width: 50%;
	margin: 20px auto 10px;
	text-align: center
	}
body .desc_top_text #book_text .kaitei_img img{
	width: 100%;
	}
	
	body .desc_top_text #book_text .kaitei_text h3{
	font-size: 20px;
	}
	
	body div.top_text p.desc{
		font-size: 18px;
		padding: 10px 0;
	}
 
	
	body div.top_text p.desc em{
		padding-bottom: 5px;
		display: block;
	}

	body div.main_image_pc&gt;div img{
		    padding: 0;
    margin: 0 auto 10px;
		display: block;
		float: none;
	}

	body div.main_image_pc&gt;div div.main_item{
		width: 100%;
		margin-bottom: 5px;
	}
	body div.main_image&gt;div p.desc{
		clear: both;
	}

	body div.main_image_pc&gt;div div.main_item p.title{
		font-size: 120%;
		padding-bottom: 8px;
		letter-spacing: -1px;
		margin-bottom: 10px;
	}
	body div.main_item p.day{
		padding-bottom: 5px;
	}
	body div.main_image&gt;div div.main_item p.price,
	body div.main_image_pc&gt;div div.main_item p.price{
		font-size: 18px;
	}
	/*body div.main_image&gt;div p.price{
		margin:0px 0 10px 0 !important;
	}*/
	body div.main_image&gt;div div.main_item p.price em{
		font-size: 20px;	
	}

	.btn_top:after{
		border-width: 5px 5px 5px 7px;
		top:14px;
	}
	.btn_set:after{
		top:14px;
	}
	body div.main_image&gt;div .sp_top_text{
		clear: both;
		padding-top: 10px;
	}
	
	body #cpn {
		margin:10px auto;
		width: 95%;
		padding-top:15px;
	}
	body #cpn img{
		display: none;
	}
	body #cpn .cpn_box table td {
	padding:5px 0; 
	}
	body #cpn .cpn_box .cpn_title{
	font-size:18px; 
}	
	
	
	body div.main_image&gt;div p.desc{
		display: block;
		margin-top: 0px;
		border-top:1px dashed #ddd;
		font-size: 18px;
		padding: 10px 0;
	}
	a.btn_top{
		/*font-size:18px;	
		width: 100%;
		box-sizing: border-box;
		padding: 5px;
		box-shadow:2px 2px 0px 2px #ba9008;
		overflow: hidden;*/
		    font-size: 18px;
    width: 91%;
    box-sizing: border-box;
    padding: 5px;
    box-shadow: 2px 2px 0px 2px #9f0b26;
    overflow: hidden;
    margin: 10px;
	}
	.btn_top{/*button用*/
	font-size: 18px;
    width: 100%;
    box-sizing: border-box;
    padding: 5px;
    box-shadow: 2px 2px 0px 2px #9f0b26;
    overflow: hidden;
    margin: 10px;
}
	a.btn_set{
		box-shadow:2px 2px 0px 2px #108ba8;
	}
	a.btn_set:hover{
		box-shadow:2px 2px 0px 2px #108ba8 !important;
	}
	a.btn_top:hover{
		border:2px solid #d30b23;
		box-shadow:2px 2px 0px 2px #d30b23;
	}
	body div div.wrapper_price{
		margin:20px auto;
	}
	body div.main_contents{width: 100%;padding: 10px;box-sizing: border-box;}
	body div.main_contents h2{
	}
	
	body div.main_contents #comment table{
		margin: 0px auto 0px;
	}
	body div.main_contents #comment table tr td,
	body div.main_contents #comment table tr th{
		padding:10px 10px 10px;
		border-bottom:1px solid #ccc;
	}
	
	body div.main_contents #contents table{width: 100%;}
	body div.main_contents #set_item table td.image img{
		width: 130px;
	}
	body div.main_contents #set_item table.pre td.image img{
		width: 100%;
		
	}
	body div.main_contents #set_item table.pre tr td{
		padding: 0 10px;
	}
	body div.main_contents #set_item table.pre tr:nth-child(2) td{
		padding: 10px;
	}
	body div.main_contents #set_item table td{
		font-size: 14px;
		line-height: 1.6;
	}
	body div.main_contents #set_item .pre_item_description .price{
		padding-top: 0px;
	}
	body div.main_contents h2{
		line-height: 1.4;
		font-size: 22px;
	}
	/*body div.main_contents h4{
		font-size: 20px;
		font-weight: 400;
		line-height: 1.4;
	}*/
	body div.main_contents #set_item table td.price_set div span.now{
		display: inline-block;
		font-size: 16px;
	}
	body div.main_contents #set_item table td.price_set div span.now em{
		font-size: 20px;
	}
	body div.main_contents #set_item table td.price_set div span.off{
		font-size: 12px;
	}
	body div.main_contents #set_item&gt;div table td.image_pre img{
		width: 90%;
	}
	body .sp_under{
		background: rgba(0,0,0,0.8);
		width: 100%;
		position: fixed;
		bottom: 0;
		left: 0;
		z-index: 10000;
		padding: 20px 10px 10px;
		box-sizing: border-box;
	}
	body div.main_contents #special_price p{
	font-size: 18px;
	margin-bottom: 20px;

}
	body div.main_contents #special_price p span.p_sp_price,
	body div.main_contents #special_price span.p_sp_price{
		color: #d30b23;
		display: inline-block;
}
	
	body .sp_under a{
		margin-top:-3px;
	}
	body .main_image_pc{
		margin: 10px 2px;
	}

	.hensyu table td{
		padding: 10px;
    border: 1px solid #ccc;
    vertical-align: middle;
     width: auto;
	box-sizing: border-box;
    display: block;
    margin-top: -1px;
	}
	
	.gamen{
	overflow: hidden;
	padding:20px 0 20px;
	width: 100%;
	margin: 0 auto;
}

.gamen a{
	width: calc(50% - 20px);
	float: left;
	padding-right: 20px;
	
}
.gamen a p{
	text-align: center;
	/*width: 100%;*/
	
}
.gamen a img{
	width: 100%;
}

body div.main_contents&gt;div{
	margin-bottom: 45px;
}	
	
/*セット商品部分*/
	div.item{
		width: 100%;
	}
	div.item.pre img{
		width: 100%;
	}
	div.item table{
		margin: auto;
	}
	div.item .book_image{
		text-align: center;
	}
	
	.fig_upgrade{
		width: 80%;
		display: block;
		margin: auto;
	}

	
	.pc_view{
		display: none;
	}
}



</pre></body></html>