@charset "utf-8";

.enf{
	font-family: 'Open Sans Condensed', 'HelveticaNeue-Condensed', Calibri, Helvetica, Arial, sans-serif;
}
.msgo{
	font-family: 'MS PGothic', sans-serif;
}

/* ==========================================================================
   parts style
   ========================================================================== */

.sp-only{display: none;}
@media only screen and (max-width: 480px) {
	.pc-only{display: none;}
	.sp-only{display: block;}
}

iframe{
	max-width: 100%;
}

img{
	max-width: 100%;
	height: auto;
}

img.left{
float: left;
clear: both;
margin-left: 5px;
margin-right: 15px;
margin-bottom: 15px;
}

img.right{
float: right;
clear: both;
margin-right: 5px;
margin-left: 15px;
margin-bottom: 15px;
}

figure{
	margin: 1.5em auto;
	text-align: center;
	position: relative;
}
figure img{
	margin-left: auto;
	margin-right: auto;
}
figure > p,
figcaption{
	font-size: 80%;
	margin-top: 5px;
	text-align: center;
}
figure.left{
	float:left;
	width: 45%;
	margin: 0 5% 1.5em 0;
}
figure.right {
	float:right;
	width: 45%;
	margin: 0 0 1.5em 5%;
}
figure.left figcaption,
figure.right figcaption {
	font-size: 90%;
	text-align: left;
}


.left{

}
.right{

}
.clear{
	clear:both;
}
img.center,
.aligncenter {
    display: block;
    margin-left: auto;
    margin-right: auto;
}
.alignright { float: right; }
.alignleft { float: left; }

.small{
	font-size: 90%;
}
.xsmall{
	font-size: 80%;
}
.xxsmall{
	font-size: 70%;
}

.sup{
	font-weight: normal;
	font-size: 90%;
}
.nowrap{
	white-space: nowrap;
}
.half{
	width: 50%;
}

.notice{
	color: #d00;
}

blockquote {
	color: #3F1000;
	quotes:"\201C" "\201D";
	position: relative;
	margin: 1.5em 0;
	padding: 1.5em 50px;
	background: #fff;
}
blockquote:before {
	content: open-quote;
	font-family: serif;
	font-size: 100px;
	color: #DBDBB9;
	line-height: 1;
	position: absolute;
	top: 5px;
	left: 5px;
}
blockquote:after {
	content: close-quote;
	font-family: serif;
	font-size: 100px;
	color: #DBDBB9;
	line-height: 0;
	position: absolute;
	right: 5px;
	bottom: 5px;
}
blockquote cite{
	display: block;
	font-size: 90%;
	font-style: normal;
	text-align: right;
}

hr{
	border: 0;
	border-top:1px dotted #ccc;
	height: 1px;
	margin: 1.5em 0;
}

.iframe-content {
	position: relative;
	width: 100%;
	padding-top: 56.25%;
}
.iframe-content iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}

.page-top{
	text-align: right;
}
.page-top a{
	padding-right: 20px;
	background: url(../images/ico_page_top_mark.png) 100% 0 no-repeat;
}

header p, footer p,
header ul, footer ul,
header ol, footer ol,
header dl, footer dl{
	margin: 0;
}

td > ul,
td > ol,
#main ul ul,
#main ul ol,
#main ol ol,
#main ol ul{
	margin-top: 0.5em;
	margin-bottom: 1em;
	margin-left: 0;
/*	padding-left: 20px;*/
}

#main > .layout{
	width: 620px;
}
#main.one-column > .layout{
	width: 100%;
}


p,
ul,
ol,
dl{
	margin-top: 1em;
	margin-bottom: 1em;
}

p:first-child,
ul:first-child,
ol:first-child,
dl:first-child:not(.column){
	margin-top: 0;
}
p:last-child,
ul:last-child,
ol:last-child,
dl:last-child:not(.column){
	margin-bottom: 0;
}

h1:first-child,
h2:first-child,
h3:first-child,
h4:first-child{
	margin-top: 0;
}

ul{
	padding-left: 25px;
}
dd{
	margin-left: 0;
}

dt,
th{
	font-weight: bold;
}


/*
a[target="_blank"]:after{
	content: url("../images/ico_external.png") ;
	margin-left: 5px;
	vertical-align: middle;
}

a[href$=".pdf"]:after{
	content: url("../images/ico_pdf.png") ;
	margin-left: 5px;
	vertical-align: middle;
}
*/

a:hover img{
	opacity: 0.5;
}

a.no-icon{
	background-image: none;
	padding-right: 0;
}
a.no-icon:after{
	content: none;
	margin: 0;
}

em{
	color: #0AA0DB;
}


a.more {
	color: #fff;
	font-size: 90%;
	display: table;
	margin: 1.5em auto;
	padding: 0.85em 1.5em;
	background: #0AA0DB url(../images/ico_arrow.png) 95% 50% no-repeat;
	border-radius: 4px;
	line-height: 1;
	min-width: 10em;
	text-align: center;
}
a.more:hover {
	color: #fff !important;
}
a.more-link {
	color: #27519d;
	display: table;
	font-size: 86%;
	margin: 0 0 0 auto;
	padding: 0 0 0 18px;
	background: url(../images/ico_arrow_square.png) 0 50% no-repeat;
	line-height: inherit;
}

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

	a.more-link-pc {
		color: #27519d;
		font-size: 86%;
		margin: 0 0 0 auto;
		padding: 0 0 0 18px;
		display: table;
		background: url(../images/ico_arrow_square.png) 0 50% no-repeat;
		line-height: inherit;
		min-width: 1px;
	}
	a.more-link-pc:hover {
		color: #27519d !important;
	}
}

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

	a.more {
		background-size: 5px auto;
		min-width: 8em;
		max-width: 90%;
	}
}

/* ※リスト */
ul.annot{
	color: #444;
	font-size: 90%;
	list-style: none;
	padding-left: 0;
}
ul.annot > li{
	padding-left: 1.5em;
	position: relative;
}
ul.annot > li:before{
	content:'※';
	position: absolute;
	left: 0;
}

ol.annot{
	color: #444;
	font-size: 90%;
	list-style: none;
	padding-left: 0;
	counter-reset:number;
}
ol.annot > li{
	padding-left: 2.5em;
	position: relative;
}
ol.annot > li:before{
	counter-increment: number;
	content: '※'counter(number);
	position: absolute;
	left: 0;
}

p.annot{
	color: #444;
	font-size: 90%;
	padding-left: 1.5em;
	position: relative;
}
p.annot:before{
	content:'※';
	position: absolute;
	left: 0;
}



dl.feature-box dt{
	font-weight: bold;
	font-size: 130%;
	margin-bottom: 10px;
}
dl.feature-box dd{
	font-size: 90%;
}
dl.feature-box dt img{
	float: left;
	margin: 5px 15px 0 0;
	vertical-align: middle;
}

.page-navigation .utility-nav{
	float: none;
	display: table;
	margin: 5em auto 0;
}
.page-navigation .utility-nav li.active{
	font-weight: bold;
}

ul.vertical{
	list-style: none;
	padding: 0;
}
ul.vertical li{
	margin-bottom: 10px;
}

ul.list{
	overflow: hidden;
	border-top: 1px solid #E7E3C1;
}
ul.list li{
	border-bottom: 1px solid #E7E3C1;
}

@media only screen and (min-width: 768px) {
	ul.col2{
		overflow: hidden;
	}
	ul.col2 li:nth-child(odd){
		float: left;
		width: 46%;
		margin-right: 8%;
		box-sizing: border-box;
	}
	ul.col2 li:nth-child(even) {
		float: left;
		width: 46%;
		margin-right: 0;
		box-sizing: border-box;
	}
}


.local-nav{
	font-size: 110%;
	list-style: none;
	margin: 0 0 2em;
	padding: 1px;
	background: #fff;
	border: 1px solid #E7E3C1;
}
.local-nav ul{
	margin: 0;
	padding: 0;
	list-style: none;
}
.local-nav li{
	border-top: 1px solid #E7E3C1;
}
.local-nav > ul > li:first-child{
	border-top: none;
}
.local-nav li a{
	display: block;
	padding: 10px 10px 10px 28px;
	background: url(../images/ico_arrow.png) 10px 50% no-repeat;
}
.local-nav li.active > a{
	color: #333;
	font-weight: bold;
	background-image: url(../images/ico_arrow_mono.png);
}
.local-nav li.story > a:before{
	content: url(../images/ico_story_s.png);
	margin-right: 5px;
	vertical-align: middle;
}
.local-nav ul ul{
	font-size: 90%;
	list-style: none;
	margin: 0 10px 0 25px;
	padding: 0;
}
.local-nav ul ul li{
	border-top: 1px dotted #e0e0e0;
	border-bottom: none;
}
.local-nav ul ul li a{
	display: block;
	padding: 6px 25px 6px 5px;
	background: url(../images/ico_arrow_tri_s.png) 98% 50% no-repeat;
}

.local-nav-title{
	color: #fff;
	font-size: 120%;
	margin-top: 0;
	margin-bottom: 0;
	background: #926C4E;
	text-align: center;
}
.local-nav-title a{
	color: #fff;
	display: block;
	padding: 10px;
}


.content-header{
	max-width: 1340px;
	margin: 0 auto;
	padding: 20px 0 30px;
	box-sizing: border-box;
	background: #fff;
	position: relative;
}
.content-header-inner{
	max-width: 1220px;
	margin-left: auto;
	margin-right: auto;
	padding-left: 20px;
	padding-right: 20px;
}
@media only screen and (min-width: 1360px) {
	.category-header + .content-header:before{
		position: absolute;
		content:'';
		bottom: 0;
		left: -10px;
		width:10px;
		height: 60%;
		background: url(../images/content_header_bg_l.png) 0 100% no-repeat;
		background-size: 100% 100%;
	}
	.category-header + .content-header:after{
		position: absolute;
		content:'';
		bottom: 0;
		right: -10px;
		width:10px;
		height: 60%;
		background: url(../images/content_header_bg_r.png) 0 100% no-repeat;
		background-size: 100% 100%;
	}
}
.content-header.bg{
	background: -webkit-gradient(linear, left top, left bottom, color-stop(1.00, #f5f5f5), color-stop(0.00, #fff));
	background: -webkit-linear-gradient(#fff, #f5f5f5);
	background: -moz-linear-gradient(#fff, #f5f5f5);
	background: -o-linear-gradient(#fff, #f5f5f5);
	background: -ms-linear-gradient(#fff, #f5f5f5);
	background: linear-gradient(#fff, #f5f5f5);
}

.page-header{
	display : -webkit-box;
	display : -ms-flexbox;
	display : -webkit-flex;
	display: flex;
	width: 100%;
	padding: 0 0 30px;
	background: url(../images/pageheader_bg.jpg) 50% 100% no-repeat;
}
.page-header .page-title{
  -webkit-box-flex: 1;
  -webkit-flex: 1;
      -ms-flex: 1;
          flex: 1 1  auto;
    width: 100%;
}
.page-header .page-title{
	font-size: 200%;
	font-weight: bold;
	margin: 0;
	line-height: 1.3;
}
.page-header .page-cattitle{
	color: #1b5288;
	font-weight: normal;
	font-size: 20px;
	font-size: 1.2rem;
	margin: 0 0 5px;
	display: block;
}
.page-header .page-subtitle{
	font-weight: bold;
	font-size: 22px;
	font-size: 1.5rem;
	margin: 5px 0 0;
	display: block;
}
.pns-header .page-title{
	font-size: 280%;
	font-weight: bold;
	margin: 0;
	line-height: 1.3;
}
.pns-header .page-cattitle{
	font-size: 22px;
	font-size: 1.5rem;
	margin: 0 0 5px;
}
.page-attribute{
  -webkit-box-flex: 1;
  -webkit-flex: 1;
      -ms-flex: 1;
          flex: 1 0 auto;
	font-size: 90%;
	padding: 0 20px;
}
.page-attribute + .page-attribute{
	border-left: 1px solid #ddd;
}

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

	.page-header .page-attribute{
		display: none;
	}
	.pns-attribute-bottom-area{
		margin-bottom: 2em;
	}
	.pns-attribute-bottom-area .page-attribute{
		margin: 0;
		padding: 1em;
	}
	.pns-attribute-bottom-area .page-attribute + .page-attribute{
		border-top: 1px solid #ddd;
		border-left: none;
	}
}

.pns-category-description{
	max-width: 960px;
	margin: 1.5em auto;
	text-align: center;
}

h2{
	clear: both;
	font-size: 180%;
	font-weight: bold;
	margin-top: 1.5em;
	padding: 20px 0;
	line-height: 1.3;
	background: url(../images/h2_bg.png) 0 100% no-repeat;
}
h3{
	clear: both;
	font-size: 138%;
	font-weight: bold;
	margin-top: 1.5em;
	padding: 0.8em 30px;
	line-height: 1.3;
	border-bottom: 1px solid #698CAA;
	background: #F6F7F9 url(../images/h3_bg.png) 0 50% no-repeat;
}
h4{
	clear: both;
	font-size: 110%;
	font-weight: bold;
	margin-top: 1.5em;
	padding: 0.8em 0 0.8em 30px;
	line-height: 1.3;
	border-bottom: 1px dotted #ccc;
	background: url(../images/h4_bg.png) 0 50% no-repeat;
}

body.news.detail .main-content h2,
body.event.detail .main-content h2{
	clear: both;
	font-size: 110%;
	font-weight: bold;
	margin-top: 1.5em;
	padding: 0.8em 0 0.8em 30px;
	line-height: 1.3;
	border-bottom: 1px dotted #ccc;
	background: url(../images/h4_bg.png) 0 50% no-repeat;
}

#main h2 > a:after,
#main h3 > a:after,
#main h4 > a:after{
	content:'';
	display: inline-block;
	width: 12px;
	height: 16px;
	margin-left: 10px;
	background: url(../images/ico_arrow.png) 0 50% no-repeat;
	vertical-align: middle;
}


#main > .col-w,
#main > .cols,
#main > .frame,
#main > ul,
#main > ol,
#main > dl,
#main > table{
	margin-top: 1.5em;
	margin-bottom: 1.5em;
}

#main p + ul{
	margin-top: 1em;
}

#main table + h2{
	margin-top: 2em;
}
#main table + h3,
#main table + h4{
	margin-top: 3em;
}


.main-content li{
	margin-bottom: 0.5em;
}

#main article{
	margin-bottom: 60px;
}

.article-header{
	margin-bottom: 30px;
	overflow: hidden;
}
.article-header time{
	font-size: 90%;
}
.article-header h1{
	margin: 5px 0;
}
.article-header .entry-data{
	text-align: right;
	font-size: 80%;
	float: right;
}


.summary{
	color: #642F04;
	font-size: 90%;
	text-align: center;
}

.link-button{
	color: #FF4D4D;
	font-size: 110%;
	font-weight: bold;
	margin: 1em auto;
	padding: 12px 30px 12px 70px;
	display: table;
	line-height: 1.3;
	background: #fff url(../images/arrow_p.png) 15px 50% no-repeat;
	background-size: auto 60%;
	border: 3px solid #FF4D4D;
}
.link-button span{
	font-size: 86%;
	font-weight: normal;
}

.entries-thumbs{
	margin: 1em 0;
	padding: 0;
	list-style: none;
}
.entries-thumbs li{
	width: 280px;
	margin-bottom: 20px;
	padding-bottom: 20px;
	display: inline-block;
	border-bottom: solid 2px #e0e0e0;
	position: relative;
	vertical-align: top;
}
.entries-thumbs li:nth-child(odd){
	margin-right: 20px;
}
.entries-thumbs li a{
	font-weight: bold;
	display: block;
}
.entries-thumbs li .pt{
	border: 10px solid  #F5F5F5;
	display: block;
	text-align: center;
	width: 100%;
	height: 210px;
	vertical-align: middle;
	overflow: hidden;
	box-sizing: border-box;
}
.entries-thumbs li .pt > span{
	display: table;
	table-layout: fixed;
	text-align: center;
	width: 100%;
	height: 100%;
	vertical-align: middle;
}
.entries-thumbs li .pt > span > span{
	display: table-cell;
	table-layout: fixed;
	width: 100%;
	height: 100%;
	vertical-align: middle;
}

.entries-thumbs li .tag{
	float: left;
	margin-left: -10px;
	position: absolute;
}
.entries-thumbs li dt{
	font-size: 130%;
	font-weight: bold;
}
.entries-thumbs li dd{
	color: #333;
	font-weight: normal;
}
.entries-thumbs li time{
	color: #999;
	font-size: 90%;
	font-weight: normal;
}


@media only screen and (max-width: 960px) {
	.entries-thumbs li{
		max-width: 42%;
	}
	.entries-thumbs li:nth-child(odd){
		margin-right: 6%;
	}
	.entries-thumbs li .pt{
		box-sizing: border-box;
	}
}
@media only screen and (max-width: 480px) {

	.entries-thumbs li .tag{
		margin-left: -7px;
	}
	.entries-thumbs li .tag img{
		height: 30px;
	}
	.entries-thumbs li .pt{
		height: auto;
	}

}
@media only screen and (max-width: 320px) {

	.entries-thumbs{
		margin-left: 10px;
	}
	.entries-thumbs li{
		width: auto;
		max-width: inherit;
	}
	.entries-thumbs li:nth-child(odd){
		margin-right: 0;
	}
}


.entries-list{
	margin: 1em 0;
	padding: 0;
	list-style: none;
	border-top: 1px solid #E7E3C1;
}
.entries-list > li{
	padding: 10px 0;
	border-bottom: 1px solid #E7E3C1;
	overflow: hidden;
}
	h2 + .entries-list li:first-child{
		padding-top: 0;
	}

.entries-list > li > a{
	font-weight: bold;
	display: block;
	padding: 0 10px;
}
.entries-list > li .tag{
	margin-left: -15px;
	display: block;
}

.entries-list .tmb{
	margin-top: 25px;
	max-width: 150px;
	max-height: 150px;
	height: auto;
}

.entries-list.salam-list .tmb{
	margin-top: 25px;
	max-width: 100%;
	max-height: 100%;
	height: auto;
}

dl.entry-summary{
	margin: 0;
	overflow: hidden;
}
dl.entry-summary dt{
	font-size: 115%;
	margin-bottom: 10px;
}
dl.entry-summary a{
	padding: 0;
	display: inline;
}
dl.entry-summary dt time{
	float: none;
	display: block;
	font-size: 68%;
	font-weight: normal;
}
.search-list dl.entry-summary dt .entry-title{
	display: block;
}
dl.entry-summary dt .entry-title + time{
	display: inline-block;
}
dl.entry-summary dt .category{
	color: #999;
	font-weight: normal;
	float: none;
	display: inline-block;
	font-size: 68%;
	margin-left: 15px;
}
dl.entry-summary dd{
	color: #555;
	font-weight: normal;
	overflow: hidden;
}

.entry-title .tag{
	margin: 0 0 10px -10px;
}

.page-navigation ul{
	font-size: 90%;
	margin: 50px 0;
	padding: 0;
	list-style: none;
	overflow: hidden;
}
.page-navigation .prev{
	float:left;
	width: 45%;
	text-align: left;
}
.page-navigation .next{
	float:right;
	width: 45%;
	text-align: right;
}
.page-navigation .prev a:before{
	content:'<';
	font-size: 12px;
	margin-right: 5px;
	margin-bottom: 5px;
	display: inline-block;
	vertical-align: middle;
}
.page-navigation .next a:after{
	content:'>';
	font-size: 12px;
	margin-left: 5px;
	margin-bottom: 5px;
	display: inline-block;
	vertical-align: middle;
}

.block{
	margin-top: 1.5em;
	margin-bottom: 1.5em;
}

.frame{
	position: relative;
	display: block;
	background: #FCFCF4;
	padding: 30px;
	overflow: hidden;
}
div.frame{
	margin: 1em 0;
}
.frame{
	position: relative;
	display: block;
	background: #FCFCF4;
	padding: 30px;
}
a.frame,
a .frame{
	display: block;
	background: url(../images/arrow_r.png) 98% 50% no-repeat;
}
a.frame:hover,
a:hover .frame{
	border-color: #B2DEF9;
	background-color:#FEFEF4;
}

.frame dt{
	color: #1b5288;
	font-weight: bold;
	font-size: 20px;
	margin: 0 0 15px;
}
.frame dd{
	font-size: 86%;
}

.attention-title{
	color: #1b5288;
	font-weight: bold;
	font-size: 20px;
	margin: 0 0 15px;
	padding-left: 40px;
	background: url(../images/ico_notice.png) 0 50% no-repeat;
}

.thick-frame{
	display: block;
	border: 30px solid #F5F5F5;
	margin: 1.5em 0;
	padding: 30px 50px;
}

.page-nav{
	margin: 5em 0 1em;
	padding: 0;
	list-style:none;
}
.page-nav li.index{
	display: block;
	text-align: center;
}
.page-nav li.prev{
	float: left;
	margin-top: -1.6em;
}
.page-nav li.prev a{
	padding-left: 15px;
	background: url(../images/ico_arrow.png) 0 50% no-repeat;
}
.page-nav li.next{
	float: right;
	margin-top: -1.6em;
}
.page-nav li.next a{
	padding-right: 15px;
	background: url(../images/ico_arrow.png) 100% 50% no-repeat;
}

.attention{
	font-size: 117%;
	font-weight: 800;
}

.attention strong{
	color: #CC0000;
}
.alert{
	color: #c00;
}
#content .error{
	color: #c00;
}

.num{
	text-align: right;
}

.price{
	text-align: right;
	font-weight: bold;
}
.price .tax{
	font-size: 84%;
	font-weight: 100;
}


.lead{
	font-size: 190%;
	font-weight: normal;
	margin: 0.5em 0;
	line-height: 1.5;
}
.point{
	color: #4EBDD8;
}

.description{
	margin-bottom: 35px;
}




.social-buttons{
	margin: 0;
	padding: 0;
	list-style: none;
}
.social-buttons li{
	float: left;
	margin-right: 15px;
	vertical-align: top;
}
.social-buttons .fb_iframe_widget > span{
	vertical-align: baseline !important;
}


/* ------------------------------
   flexslider
------------------------------ */



.flexslider{
	position: relative;
}
.slides{
	margin: 0;
	padding: 0;
	list-style:none;
}
.slides li{
	position: relative;
	display: inline-block;
}
.slides li > a >img{
	width: 100%;
}
.slides .caption{
	position: absolute;
	margin: 0 auto;
	bottom: 0;
	color: #fff;
	font-size: 14px;
	padding: 5px 10px;
	background: rgba(0,0,0,0.5);
	left: 50%;
	width: 768px;
	margin-left: -384px;
	text-align: left;
}
.flex-control-paging{
	display: table;
	margin: 0 auto;
	padding: 0;
	list-style:none;
}
.flex-control-nav li {
	margin: 0 6px;
	display: inline-block;
	zoom: 1;
}
.flex-control-paging li a {
	width: 11px;
	height: 11px;
	display: block;
	background: #666;
	background: rgba(0, 0, 0, 0.5);
	cursor: pointer;
	overflow: hidden;
	text-indent: 100%;
	-webkit-box-shadow: inset 0 0 3px rgba(0, 0, 0, 0.3);
	-moz-box-shadow: inset 0 0 3px rgba(0, 0, 0, 0.3);
	-o-box-shadow: inset 0 0 3px rgba(0, 0, 0, 0.3);
	box-shadow: inset 0 0 3px rgba(0, 0, 0, 0.3);
	-webkit-border-radius: 50%;
	-moz-border-radius: 50%;
	border-radius: 50%;
}
.flex-control-paging li a.flex-active{
	background-color: #FF4D4D;
}
.flex-direction-nav{
	margin: 0;
	padding: 0;
	list-style:none;
}
.flex-prev{
	position: absolute;
	top: 50%;
	left: 10px;
	display: inline-block;
	text-indent: 100%;
	margin-top: -49px;
	width: 51px;
	height: 78px;
	overflow: hidden;
	background: url(../images/arrow_w_l.png) no-repeat;
	background-position: 0 0;
	background-size: auto 100%;
	max-height: 25%;
	opacity: 0.5;
}
.flex-next{
	position: absolute;
	top: 50%;
	right: 10px;
	display: inline-block;
	text-indent: 100%;
	margin-top: -49px;
	width: 51px;
	height: 78px;
	overflow: hidden;
	background: url(../images/arrow_w_r.png) no-repeat;
	background-position: 100% 0;
	background-size: auto 100%;
	max-height: 25%;
	opacity: 0.5;
}

.flex-pauseplay{
	position: absolute;
	right: 10px;
	bottom: 0;
	font-size: 12px;
}

.flex-play {
  color: #2c3e50;
  display: block;
  z-index: 1;
  transition: all 0.3s;
  -webkit-transition: all 0.3s;
  -moz-transition: all 0.3s;
}
.flex-play:after {
  content: '';
  display: inline-block;
  margin-left: 5px;
  width: 0;
  height: 0;
  border-top: 8px solid transparent;
  border-bottom: 8px solid transparent;
  border-left: 12px solid #2c3e50;
  vertical-align: top;
}

.flex-pause{
  	color: #2c3e50;
  border-color: transparent;
}
.flex-pause:after {
  content: '';
  display: inline-block;
  margin-left: 5px;
  opacity: 1;
  width: 8px;
  height: 16px;
  background: #2c3e50;
/*  position: absolute;
  right: 5px;
  top: 0;*/
  border-left: 4px solid #2c3e50;
  box-shadow: inset 4px 0 0 0 #f9f9f9;
  vertical-align: top;
}



/* ------------------------------
   heading
------------------------------ */



/* ------------------------------
   with link-icon
------------------------------ */

ul.link{
	padding: 0;
	list-style: none;
}
ul.link li{
	margin-bottom: 0.5em;
}
ul.link.list li{
	margin: 0;
}
ul.link.list a{
	padding-top: 10px;
	padding-bottom: 10px;
	background-position: 0 50%;
}
.link a{
	font-weight: bold;
	display: block;
	text-decoration: none;
	padding: 0 0 0 20px;
	background: url(../images/ico_arrow_circle.png) 0 0.4em no-repeat;
	background-size: 14px 14px;
}
.links a{
	font-weight: normal;
}
a.link{
	font-weight: bold;
	display: inline-block;
	text-decoration: none;
	padding: 0 0 0 20px;
	background: url(../images/ico_arrow_circle.png) 0 0.4em no-repeat;
	background-size: 14px 14px;
}
.link-s a{
	font-weight: bold;
	display: block;
	text-decoration: none;
	padding: 0 0 0 15px;
	background: url(../images/ico_arrow_tri_s.png) 0 0.5em no-repeat;
}
a.link-s{
	display: inline-block;
	text-decoration: none;
	padding: 0 0 0 15px;
	background: url(../images/ico_arrow_tri_s.png) 0 0.5em no-repeat;
}
p.link-f{
	margin-left: 1em;
}
.more{
	text-align: right;
}
.entry-prev:before {
	content: '';
	width: 15px;
	height: 12px;
	display: inline-block;
	background: url(../images/ico_arrow_g_prev.png) 0 50% no-repeat;
}
.entry-next:after {
	content: '';
	width: 15px;
	height: 12px;
	display: inline-block;
	background: url(../images/ico_arrow_g_next.png) 100% 50% no-repeat;
}

/* ------------------------------
   button
------------------------------ */

.button{
	display: inline-block;
	margin-left: auto;
	margin-right: auto;
	padding: 1.3em 20px;
	color: #fff;
	font-size: 16px;
	font-weight: bold;
	background: #08B7D6 url(../images/ico_arrow.png) 95% 50% no-repeat;
	background-size: auto auto;
	border-radius: 5px;
	border: none;
	text-align: center;
	text-decoration: none;
	-webkit-appearance: none;
	background-position: 95% 50%;
	background-repeat: no-repeat;
	line-height: 1.3;
}
.button-primary{
	background-color: #FF821E;
}
.button-sub{
	background-color: #42A577;
}
.button-darken{
	background-color: #474747;
}
.button-minor{
	color: #333;
	font-size: 80%;
	padding: 0.8em 50px;
	background: #fff;
	border: 1px solid #dadada;
	border-radius: 3px;
}
.button-minor:hover{
	color: #333 !important;
	background-color: #f5f5f5;
}
.button-minor:before{
	content: '';
	width: 15px;
	height: 12px;
	display: inline-block;
	background: url(../images/ico_arrow_g.png) 0 50% no-repeat;
}
.button-small{
	font-size: 12px;
	color: #fff !important;
	padding: 8px 13px;
	background: #08B7D6 url(../images/ico_arrow_s.png) 94% 50% no-repeat;
}

.button-go{
	font-size: 90%;
	padding: 1em;
	background-image: none;
	display: block;
	max-width: 150px;
}
.button-go:before{
	content: '';
	width: 15px;
	height: 12px;
	display: inline-block;
	background: url(../images/ico_arrow_s.png) 0 50% no-repeat;
}
.button-download{
	padding-left: 35px;
	background:#555555 url(../images/ico_download.png) 10px 50% no-repeat;
}
.button-more{
	padding: 8px 20px 8px 16px;
	background-color: #08B7D6;
}
.button-faq{
	background: #3C906C;
}
.button-multiline{
	padding-top: 1em;
	padding-bottom: 0.6em;
}
.button-lt{
	font-size: 90%;
	padding: 1.2em 50px 1em;
}
.button-xl{
	font-size: 140%;
	padding: 1.1em 1.5em;
}
.button:hover,
.button-primary:hover{
	color: #fff;
}
.button .small{
	display: block;
	font-size: 12px;
	font-weight: normal;
	margin-top: 10px;
}

.buttonArea{
	text-align: center;
	padding: 2em;
	clear: both;
	overflow: hidden;
}

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

	.buttonArea {
		padding: 15px 20px;
		clear: both;
	}
	.submitArea{
		margin: 30px -15px -15px ;
		padding: 20px 25px;
		background-color: #E7F4FA;
	}

	.buttonArea .forward,
	.buttonArea .back{
		float: none;
		margin: 0 0 10px;
	}
	.buttonArea .forward:last-child,
	.buttonArea .back:last-child{
		margin-bottom: 0;
	}

	.buttonArea .button,
	.buttonArea .button-primary{
		width: 100%;
		display: block;
		box-sizing: border-box;
	}

}

/* ------------------------------
label
------------------------------ */

.label{
	color: #fff;
	font-size: 12px;
	display: inline-block;
	padding: 5px 15px 5px;
	line-height: 1;
	text-align: center;
	position: relative;
	overflow: hidden;
}
.label_product{
	background: #1E6FC0;
}
.label_webservice{
	background: #40929D;
}
.label_education{
	background: #00B050;
}
.label:before{
	content: '';
	display: block;
	background: rgba(255,255,255,0.2);
	width: 100%;
	height: 200%;
	position: absolute;
	margin-left: 50%;
	left: 0;
	top: -200%;
	transform: rotate(135deg);
	transform-origin: left center;
}

/* ------------------------------
   column
------------------------------ */

.cols {
  margin-left: -1.5em;
  margin-right: -1.5em;
  margin-top: -1.5em;
	display : -webkit-box;
	display : -ms-flexbox;
	display : -webkit-flex;
	display: flex;
}
.cols.is-grid {
	-webkit-flex-wrap: wrap;
		-ms-flex-wrap: wrap;
			flex-wrap: wrap;
}
.cols[class*="has"]{
	-webkit-flex-wrap: wrap;
		-ms-flex-wrap: wrap;
			flex-wrap: wrap;
}
.cols:last-child {
  margin-bottom: -1.5em;
}

.cols:not(:last-child) {
  margin-bottom: 1.5em;
}

.col {
  -webkit-box-flex: 1;
  -webkit-flex: 1;
      -ms-flex: 1;
          flex: 1;
  min-width:1px; /* for firefox */
  padding: 1.5em;
}
.cols.is-grid .col,
.cols[class*="has"] .col{
	-webkit-box-flex: 0;
	-webkit-flex: none;
	  -ms-flex: none;
		  flex: none;
}

.cols.has2cols .col{
	width: 50%;
	box-sizing: border-box;
}
.cols.has3cols .col{
	width: 33%;
	box-sizing: border-box;
}
.cols.has4cols .col{
	width: 25%;
	box-sizing: border-box;
}

.col.card{
	margin: 1.5em;
	padding: 0 0 3em;
	background: #fff;
	position: relative;
}
.card .btn-row{
	position: absolute;
	bottom: 0.5em;
	left: 0;
	right: 0;
}

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

}
@media only screen and (max-width: 767px) {

	.cols {
		margin-left: -0.5em;
		margin-right: -0.5em;
		margin-top: -0.5em;
	}
	.col{
		padding: 0.5em;
	}
	.cols-sp-v{
		margin: 0;
		-webkit-box-direction:column;
		-ms-flex-direction: column;
		flex-direction:column;
	}
	.cols-sp-v .col{
		padding: 10px 0;
		flex: 1 1 auto;
	}
	.col.card{
		margin: 0.5em;
	}
	.card .btn-row{
		bottom: 0;
	}
}

.col > figure{
	margin: 0 auto;
}




/* ------------------------------
   2column
------------------------------ */

img.col-r,
img.col-l{
	margin-bottom: 1em;
}

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

	.col-w{
		overflow: hidden;
	}
	.col-r{
		float: right;
		width: 47%;
		margin-left: 3%;
	}
	.col-l{
		float: left;
		width: 47%;
		margin-right: 3%;
		overflow: hidden;
	}
	.col-r + p,
	.col-r + div{
		margin-top: 0;
		margin-right: 0;
		padding-right: 3%;
		overflow: hidden;
	}
	.col-l + p,
	.col-l + div{
		margin-top: 0;
		margin-left: 0;
		padding-left: 3%;
		overflow: hidden;
	}

	.col-figure{
		max-width: 37%;
	}
	.col-figure-w{
		max-width: 50%;
		min-width: 320;
	}
}

/* ------------------------------
   table
------------------------------ */

table{
	font-size: 100%;
	margin: 1em 0;
	border-collapse: collapse;
}
table caption{
	font-size: 110%;
	padding-bottom: 5px;
}

table th{
	padding: 10px 15px;
}

table td{
	padding: 10px 15px;
}
table thead th{
	background:#f3f3f3;
}

table.thn th{
	font-weight: normal;
}

table.line{
	border-top: 1px solid #E7E3C1;
	background: none;
}
table.line th{
	border-color: #E7E3C1;
	border-style: solid;
	background: none;
	border-width: 0 0 1px;
}
table.line td{
	border-color: #E7E3C1;
	border-style: solid;
	background: none;
	border-width: 0 0 1px;
}

table.timeline th{
	font-weight: normal;
	white-space: nowrap;
	text-align: left;
}


table.vertical{
	table-layout: fixed;
	width: 100%;
	border-top:1px solid #e2e2e2;
}
table.vertical th,
table.vertical td{
	clear: both;
	padding: 1em 1.5em;
	border-bottom:1px solid #e2e2e2;
}
table.vertical th{
	color: #1b5288;
	width: 25%;
	text-align: left;
	min-width: 30%;
	background: #F5F5F5;
}
table.vertical thead th:not(:first-child){
	width: auto;
}
table.vertical th span.required{
	float:right;
	margin-left:10px;
}
table.vertical td p{
	margin: 0 0 5px;
	font-size: 100%;
}


table.horizontal{
	width: 100%;
	border-top:1px solid #e2e2e2;
}
table.horizontal th,
table.horizontal td{
	text-align: center;
	clear: both;
	padding: 1em 0.5em;
	border-bottom:1px solid #e2e2e2;
}
table.horizontal tr > *:first-child{
	padding-left: 1em;
}
table.horizontal tr > *:last-child{
	padding-right: 1em;
}
table.horizontal thead th{
	font-size: 90%;
	white-space: nowrap;
	background: #F5F5F5;
}
table.horizontal tbody th{
	background: #F5F5F5;
}
table.horizontal tfoot th,
table.horizontal tfoot td{
	font-weight: bold;
	background: #F5F5F5;
}

table.vertical table{
	border-top: 1px dotted #e2e2e2;
}
table.vertical table th,
table.vertical table td{
	border-bottom: 1px dotted #e2e2e2;
}

table.define tbody th,
table.define tbody td:first-child{
	text-align: left;
	max-width: 40%;
/*	width: 40%;*/
}
table.data th,
table.data td{
	text-align: left;
}
table.numeric td{
	text-align: right;
}
table.data-numeric thead th:first-child,
table.data-numeric tfoot th:first-child,
table.data-numeric td{
	text-align: left;
}
table.data-numeric td:last-child{
	text-align: right;
}
table.data-numeric thead tr th:last-child,
table.data-numeric tfoot tr *:last-child{
	width: 1%;
	white-space: nowrap;
}


table.charge{
	width: 100%;
	border-top: 1px solid #bbb;
}
table.charge th,
table.charge td{
	font-weight: bold;
	padding: 2em 1em;
	border-bottom: 1px solid #bbb;
}
table.charge thead th{
	font-size: 90%;
	padding: 0.5em;
	background: #fff;
	text-align: center;
	line-height: 1.2;
}
table.charge tbody th{
	text-align: left;
}
table.charge tbody td{
	text-align: right;
}
table.charge thead .use{
	color: #fff;
	background: #6ABCA6;
}
table.charge thead .add{
	background: #CECFD1;
}
table.charge thead .support{
	color: #fff;
	background: #71C0E1;
}
table.charge .use{
	background: #C3F3E5;
}
table.charge .add{
	background: #F5F5F5;
}
table.charge .support{
	background: #CDEEFD;
}

table.download{
	width: 100%;
	margin: 0 0 2.5em;
}
table.download th,
table.download td{
	font-size: 86%;
	padding: 15px 10px;
	background: none;
	border-bottom: 1px dotted #6A8CA8;
	text-align: center;
}
table.download th:first-child,
table.download td:first-child{
	padding-left: 0;
}
table.download th:last-child,
table.download td:last-child{
	padding-right: 0;
}
table.download tbody th{
	font-size: 100%;
	text-align: left;
}
table.download tbody th a{
	color: #08B7D6;
}
table.download tbody th a:before{
	content:'';
	display: inline-block;
	background: #555555 url(../images/ico_download.png) 50% 50% no-repeat;
	margin-right: 10px;
	vertical-align: middle;
	border-radius: 100%;
	width: 32px;
	height: 32px;
	margin-top: -2px;
	padding: 0;
	float: left;
}

table.layout th,
table.layout td{
	font-weight: normal;
	padding: 0;
	border: none;
	text-align: left;
}

table.equal{
	table-layout: fixed;
}

th.left,
td.left{
	text-align: left !important;
}
th.right,
td.right{
	text-align: right !important;
}
th.center,
td.center{
	text-align: center !important;
}

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

	table.vertical table{
		margin-left: 10%;
		width: 90%;
	}

	table.horizontal th,
	table.horizontal td{
		padding: 10px 5px;
	}
	table.horizontal td{
		padding: 10px 5px;
	}

	table.vertical.sp-row{
		margin-bottom: 1em;
	}
	table.vertical.sp-row > tbody > tr{
		display: block;
	}
	table.vertical.sp-row > tbody > tr > th,
	table.vertical.sp-row > tbody > tr > td{
		width: auto;
		display: block;
		padding: 5px 0;
		border: none;
	}
	table.vertical.sp-row > tbody > tr > td:last-child{
		padding-bottom: 1em;
		border-bottom:1px solid #e2e2e2;
	}

}

span.required{
	display: inline-block;
	padding: 0 7px;
	color: #fff;
	font-size: 80%;
	font-weight: normal;
	background: #F15084;
	border-radius: 4px;
}


.utility-nav{
	font-size: 90%;
	line-height: 1;
	margin: 0 auto;
	padding: 0;
	display: table;
	border-left:1px solid #DDDDDD;
}
.utility-nav li{
	padding: 0 15px;
	display: table-cell;
	border-right:1px solid #DDDDDD;
}
.utility-nav a{
	color: #333;
}


/* ------------------------------
   pager
------------------------------ */

#pager{
	margin: 50px 0 20px;
	text-align: center;
}
#pager ul{
	display: table;
	border-collapse: separate;
	border-spacing: 5px 5px;
	margin: 0 auto;
	padding: 0;
}
#pager ul li{
	display: inline-table;
}
#pager a{
	display: block;
	margin: 0;
	padding: 1px 7px;
	text-decoration: none;
	background: #fff;
	border: 1px solid #642F04;
}
#pager .fs-current a{
	display: block;
	padding: 1px 7px;
	color: #fff;
	background: #642F04;
}


/* ------------------------------
   a-form
------------------------------ */

.total-price{
	text-align: right;
}
.total-price dt{
	font-weight: normal;
}
.total-price .total{
	font-size: 120%;
	font-weight: bold;
}

span.required{
	background: #D92B00;
	padding: 2px;
}

.aform-content dl select{
	-webkit-appearance: menulist-button;
	height: 2em;
	min-height: 100%;
}

#main .aform-content ul.aform-payment .aform-payment-description{
	margin: 0;
}
.aform-payment-description table{
	width: 99%;
}
.aform-payment-description th{
	white-space: nowrap;
}
.aform-payment-description .aform-select{
	width: auto;
}
.aform-payment-description .cc_zeus-cvv{
	width: 5em;
}
.aform-content .aform-payment-description input,
.aform-content .aform-payment-description textarea,
.aform-content .aform-payment-description select{
	font-size: 100%;
	padding: 3px;
}
#main .aform-content ul.aform-payment .aform-payment-description table th,
#main .aform-content ul.aform-payment .aform-payment-description table td{
	padding: 10px 5px;
}
.ssl_seal{
	float: right;
	margin-left: 15px;
}




.entry-links {
	margin: 0;
	padding: 0;
	list-style: none;
}
.entry-links li{
	margin: 0 0 10px;
}
.entry-links li a{
	color: #fff;
	display: block;
	text-align: center;
	background-image: url(../images/ico_arrow.png);
	background-position: 95% 50%;
	background-repeat: no-repeat;
}
.entry-links li a:hover{
	color: #fff !important;
}
.entry-links li.contact a{
	font-size: 90%;
	padding: 0.5em;
	background-color: #27519D;
}
.entry-links li.contact a:before{
	content: url(../images/ico_mail.png);
	vertical-align: middle;
	margin-right: 5px;
}
.entry-links li.entry a{
	font-size: 120%;
	padding: 1.5em;
	line-height: 1.3;
	background-color: #0AA0DB;
}
.entry-links li.entry.career a{
	background-color: #0BA5AF;
}
.entry-links li.entry.handicapped a{
	background-color: #71BB30;
}
.entry-links li.entry.grad a{
	padding: 1em;
}
.entry-links li.entry.grad a span{
	font-size: 70%;
	display: block;
}



.page-anchors{
	margin: 1em 0;
	padding: 0.8em 30px 0.3em;
	list-style: none;
	border-top: 1px solid #698CAA;
	border-bottom: 1px solid #698CAA;
	background: #F5F5F5;
}
.page-anchors li{
	display: inline-block;
	margin-right: 2em;
	margin-bottom: 0.5em;
}
.page-anchors li:last-child{
	margin-right: 0;
}
.page-anchors li a{
	color: #333;
	font-size: 96%;
	font-weight: bold;
	display: block;
	padding-left: 25px;
	background-image: url(../images/ico_arrow_circle_down.png);
	background-position: 0 50%;
	background-repeat: no-repeat;
	background-size: 16px 16px;
}

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

	.page-anchors{
		padding: 0.8em 1em;
	}
	.page-anchors li{
		margin-right: 1em;
	}
}

.card-content{
	padding: 1em 2em;
	background: #fff;
}

.profile dt{
	font-size: 140%;
	font-weight: bold;
	margin-bottom: 0.5em;
	line-height: 1.5;
}
.profile dd{
	font-size: 90%;
}

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

	.card-content{
		padding: 1em;
	}
	.profile dt{
		font-size: 120%;
	}
}


/* ------------------------------
   nav-tab
------------------------------ */

ul.tab{
	display: flex;
	margin: 1.5em 0;
	padding: 0;
	list-style: none;
	width: 100%;
	background: #08B6D8;
	border-top-left-radius: 6px;
	border-top-right-radius: 6px;
}
ul.tab li{
	max-width: 25%;
	flex: 1;
	font-weight: bold;
	margin: 0;
	/*	display: table-cell;
	vertical-align: top;*/
	text-align: center;
	background: url(../images/gnav_devider.png) 100% 50% no-repeat;
}
ul.tab li.active{
	border-top-left-radius: 6px;
	border-top-right-radius: 6px;
	background: #1B5288;
	position: relative;
}
ul.tab li:last-child:nth-child(n+4){
	background-image: none;
}
ul.tab li.active:after{
	top: 100%;
	left: 50%;
	border: solid transparent;
	content: " ";
	height: 0;
	width: 0;
	position: absolute;
	pointer-events: none;
	border-color: rgba(27, 82, 136, 0);
	border-top-color: #1B5288;
	border-width: 10px;
	margin-left: -10px;
}
ul.tab li a,
ul.tab li strong{
	color: #fff;
	font-size: 18px;
	font-weight: bold;
	display: block;
	padding: 1.2em 1em;
}


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

	ul.tab{
		flex-wrap: wrap;
	}
	ul.tab li{
		max-width: 50%;
		width: 50%;
		flex: inherit;
	}

	ul.tab li a,
	ul.tab li strong{
		font-size: 110%;
		padding: 1em 0.5em;
	}

}
@media only screen and (max-width: 400px) {

	ul.tab li a,
	ul.tab li strong{
		padding: 1em 5px;
	}

	ul.tab li a:before{
		margin-right: 3px;
		content:none;
	}

}




/* info
----------------------------------------- */

.info-list{
	overflow: hidden;
}
.info-list a{
	color: #333;
}
.info-list time{
	color: #999;
}
.info-list time + img{
	margin-left: 15px;
}
.info-list dt{
	font-size: 90%;
	font-weight: normal;
	float: left;
	clear: left;
	padding: 0;
}
.info-list dd{
	padding: 0 0 0 200px;
	margin-bottom: 1em;
	font-size: 90%;
}
.event-list dd{
	padding-left: 100px;
}
@media only screen and (max-width: 767px) {

	.info-list dt{
		float: none;
	}
	.info-list dt img{
		height: 1rem;
	}
	.info-list dd{
		padding: 0;
		font-size: 1em;
	}
}


.price-system{
	margin: 0;
	padding: 0;
	list-style: none;
	overflow: hidden;
}
/*ここだけタブレットはスマホレイアウト*/
@media only screen and (min-width: 768px) {
	.price-system-base{
		width: 61%;
		float: left;
	}
	.price-system-option{
		width: 30%;
		padding-left: 8%;
		float: left;
		background: url(../images/ico_plus.png) 2% 60% no-repeat;
	}
}
@media only screen and (max-width: 767px) {
	.price-system-base{
		overflow: hidden;
	}
	.price-system-option{
		padding-top: 50px;
		background: url(../images/ico_plus.png) 50% 5px no-repeat;
	}
}
.price-system .price-system-base dl{
	width: 49%;
	margin-right: 2%;
	float: left;
}
.price-system .price-system-base dl:last-child{
	margin-right: 0;
}
#main .price-system h4{
	margin-bottom: 10px;
	border: none;
}
.price-system dl{
	margin: 0;
}
.price-system dt{
	font-size: 110%;
	padding: 1.7em 0.5em;
	text-align: center;
	line-height: 1.4;
}
.price-system dd{
	font-size: 130%;
	font-weight: bold;
	padding: 1.5em 1em;
	text-align: center;
	min-height: 2.8em;
}
.price-system dt .sup{
	font-weight: normal;
}
.price-system dd .sup{
	display: block;
	font-size: 14px;
	font-size: 0.9rem;
}
.price-system .use dt{
	color: #fff;
	background: #6ABCA6;
	padding: 1em;
}
.price-system .use dd{
	background: #C3F3E5;
}
.price-system .support dt{
	color: #fff;
	background: #71C0E1;
	padding: 1em;
}
.price-system .support dd{
	background: #CDEEFD;
}
.price-system .add dt{
	background: #CECFD1;
}
.price-system .add dd{
	background: #E4E4E4;
}


/* product-columns
----------------------------------------- */

.boxes{
	overflow:hidden;
}
.boxes > .box{
	float: left;
	margin-bottom: 2.5em;
}
.boxes-4 > .box{
	width: 23.5%;
	margin-right: 2%;
}
.boxes-4 .box:nth-child(4n){
	margin-right:0;
}

.product-columns.columns{
	display: flex;
	flex-wrap: wrap;
	margin-top: 30px;
	margin-left: -1%;
	margin-right: -1%;
	padding-bottom: 50px;
}
.product-columns .column{
	width: 23%;
	flex: none;
	margin: 1%;
	box-sizing: border-box;
}

.item-image{
	position: relative;
	overflow: hidden;
}
.item-image-ov:after{
	content:'';
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: rgba(0,0,0,0.3);
	z-index: 2;
}
.item-image-ov:hover:after,
a:hover .item-image-ov:after{
	display: none;
}
.item-image-ov:hover img,
a:hover .item-image-ov img{
	opacity: 1;
}
.item-image-title{
	position: absolute;
	left: 0;
	top: 50%;
	-webkit-transform: translateY(-50%);
	-ms-transform: translateY(-50%);
	transform: translateY(-50%);
	width: 100%;
	margin: 0;
	padding: 0;
	box-sizing: border-box;
	color: #fff;
	font-size: 230%;
	font-weight: bold;
	text-align: center;
	background: none;
	z-index: 3;
}
.item-image-title-en{
	font-size: 12px;
	font-weight: normal;
	display: block;
	margin-top: 1em;
}
.item-image .caption{
	position: absolute;
	left: 0;
	bottom: 0;
	width: 100%;
	box-sizing: border-box;
	color: #fff;
	font-weight: bold;
	padding: 0.5em 1.2em;
	background: rgba(0,0,0,0.3);
	z-index: 3;
}
.item-description{
	margin: 0;
	padding: 1.5em 10%;
	color: #fff;
	font-size: 86%;
	background: #1B5288;
	position: relative;
}
.item-description:after{
	top: 100%;
	left: 50%;
	border: solid transparent;
	content: " ";
	height: 0;
	width: 0;
	position: absolute;
	pointer-events: none;
	border-color: rgba(27, 82, 136, 0);
	border-top-color: #1B5288;
	border-width: 10px;
	margin-left: -10px;
}
	.analysis .item-description{
		background-color: #2a8092;
	}
	.analysis .item-description:after{
		border-color: rgba(42, 128, 146, 0);
		border-top-color: #2a8092;
	}
	.maintenance .item-description{
		background-color: #3d9875;
	}
	.maintenance .item-description:after{
		border-color: rgba(61, 152, 117, 0);
		border-top-color: #3d9875;
	}
	.house .item-description{
		background-color: #829541;
	}
	.house .item-description:after{
		border-color: rgba(130, 149, 65, 0);
		border-top-color: #829541;
	}
.item-image + .item-label{
	margin: 0;
}
.item-label dt{
	font-size: 114%;
	text-align: center;
	margin-bottom: 10px;
	padding-bottom: 10px;
	border-bottom: 1px solid #1b5288;
}
.item-label dd{
	font-size: 86%;
}
a:not(:hover) .item-label dt,
a:not(:hover) .item-label dd{
	color: #333;
}
.item-label-l dt{
	color: #1b5288;
	padding-bottom: 0;
	border: none;
}
ul.item-subcategories{
	font-size: 90%;
	margin: 0;
	padding: 2em 10%;
	display: flex;
	flex-wrap: wrap;
}
.item-subcategories li{
	width: 30%;
	margin-right: 3%;
}
.item-subcategories li a{
	color: #333;
}
.pns_type{
	margin: 10px 0;
	padding-bottom: 1em;
}
.pns_type img + img{
	margin-left: 5px;
}

.case + .case{
	margin-top: 1.8em;
	padding-top: 1.8em;
	border-top: 1px solid #bbb;
}
.case .title{
	margin: 1em 0;
}
.case .title a{
	color: #333;
	font-size: 110%;
	line-height: 1.3;
}
.case dd{
	font-size: 86%;
}

.more-text{
	color: #3AB9EE;
	font-weight: bold;
}

.segment-title{
	font-size: 220%;
	margin-bottom: 1em;
	background: none;
	text-align: center;
}
.segment-title.sub{
	font-size: 170%;
}
.segment-title:after{
	content: "";
	display: block;
	max-width: 300px;
	margin: 15px auto 0;
	border-bottom: 1px solid #698CAA;
}
.segment-title-en-l{
	color: #1b5288;
	font-weight: normal;
	text-transform: uppercase;
}
.segment-title-en{
	margin: 1em 0 2em;
	display: block;
	font-size: 12px;
	font-weight: normal;
	color: #1b5288;
	text-transform: uppercase;
}
.segment-title-sub-jp{
	margin: 1em 0 1.5em;
	display: block;
	font-size: 13px;
	font-weight: normal;
}
.segment-title.sub .segment-title-en{
	text-transform: inherit;
}

.aside-w{
	padding: 50px 0;
	background: #fff;
}
.aside-g{
	padding: 50px 0;
	background: #F5F5F5;
}


.item-row{
	display: flex;
	align-items: center;
}
.item-row + .item-row{
	margin-top: 30px;
}
.item-row .item-image{
	width: 32.5%;
	max-width: 200px;
}
.item-row .item-image-tmb{
/*
	flex: none;
	width: 24.2%;
	max-width: 150px;
	*/
}
.item-row .item-content{
	flex: 1;
	margin: 0 0 0 20px;
}
.item-row .card-content{
	align-items: stretch;
}
.item-content dt{
	font-size: 140%;
	margin-bottom: 1rem;
	line-height: 1.3;
}
.item-content dd{
	font-size: 86%;
}
a:not(:hover) .item-content dt,
a:not(:hover) .item-content dd{
	color: #333;
}
.item-card{
	background: #fff;
}
.item-card .item-content{
	margin: 0;
}
.item-card-b{
	background: #fff;
	-webkit-box-shadow: 0 7px 6px -6px #aaa;
	box-shadow: 0 7px 6px -6px #aaa;
}
.item-card-link{
	padding-bottom: 20px;
	background-image: url(../images/ico_arrow_card.png);
	background-position: 100% 100%;
	background-repeat: no-repeat;
}
.item-keyword{
	color: #1b5288;
	font-weight: bold;
	margin-top: 1em;
}
.item-keyword img{
	margin-right: 10px;
}
.item-date{
	font-weight: normal;
	overflow: hidden;
}
.item-date time{
	color: #9f9f9f;
	font-size: 12px;
	float: right;
}
.item-date + dt{
	font-size: 120%;
	margin: 0.5rem 0;
}
.aside-ws{
	padding: 50px 0;
	background: #E6F0F1;
	overflow: hidden;
}
@media only screen and (min-width: 768px) {

	.highlights-columns.columns {
		flex-wrap: wrap;
		margin: 0;
	}
	.highlights-columns .column {
		width: 50%;
		flex: none;
		box-sizing: border-box;
		margin: 0;
		padding-top: 2.5em;
		padding-bottom: 2.5em;
		border-bottom: 1px solid #bbb;
	}
	.highlights-columns .column:nth-last-child(1),
	.highlights-columns .column:nth-last-child(2):nth-child(odd){
		border-bottom: none;
	}

	.other-highlights-columns.columns {
		padding-bottom: 50px;
	}
	.other-highlights-columns .column:nth-child(odd){
		padding-right: 2.5em;
		border-right: 1px solid #bbb;
	}
	.other-highlights-columns .column:nth-child(even){
		padding-left: 2.5em;
	}
	.other-highlights-columns .column:nth-child(1),
	.other-highlights-columns .column:nth-child(2){
		padding-top: 0;
	}
	.other-highlights-columns .column:nth-last-child(1),
	.other-highlights-columns .column:nth-last-child(2):nth-child(odd){
		padding-bottom: 0;
		border-bottom: none;
	}

	.top-highlights-columns{
		padding: 0 1.2em;
		background: #fff;
	}
	.top-highlights-columns .column{
		padding: 1.2em 0;
	}
	.top-highlights-columns .column:nth-child(odd){
		padding-right: 1.5em;
	}
	.top-highlights-columns .column:nth-child(even){
		padding-left: 1.5em;
	}
}
.other-highlights-columns{

}
.main-pickups-columns{
	margin: -5%;
	padding-bottom: 50px;
}
.main-pickups-columns .column {
	width: 40%;
	flex: none;
	margin: 5%;
	box-sizing: border-box;
}
.main-pickups-columns .column .item-image {
/*	max-height: 280px;*/
	overflow: hidden;
	text-align: center;
}

@media only screen and (min-width: 768px) {
	.main-pickups-columns .column .item-image {
/*		height: 280px;*/
		overflow: hidden;
	}
	.main-pickups-columns .column .item-image img{
		max-height: 100%;
	}
}

@media only screen and (max-width: 767px) {
	.product-columns .column{
		width: 48%;
	}

	.main-pickups-columns{
		margin: 0;
	}
	.main-pickups-columns .column {
		width: auto;
		margin: 1.5em 0;
	}
	.main-pickups-columns .item-subcategories{
		padding: 2em 5%;
	}

}

@media only screen and (min-width: 1281px) {
	.news-pickups-columns {
		margin-right: -3.907%;
		margin-left: -3.907%;
	}
}
.news-pickups-columns .column {
	width: 26.086%;
	flex: none;
	margin: 1.8% 3.624%;
	box-sizing: border-box;
}

.related-pns-columns.columns {
	display: flex;
	flex-wrap: wrap;
	margin-top: 30px;
	margin-left: -1%;
	margin-right: -1%;
	padding-bottom: 50px;
}
.related-pns-columns .column {
	width: 31%;
	flex: none;
	margin: 1%;
	box-sizing: border-box;
}
.other-category-column{
	display: flex;
	padding: 2em 5%;
	background: #fff;
}
.other-category-column h2{
	font-size: 130%;
	margin: 0;
	padding: 0 2em 0 0;
	background: none;
}
.other-category-column h2:after{
	content: ' : ';
}
.other-category-column ul{
	margin: 0;
}
.other-category-column ul li{
	margin: 0 2em 0 0;
	display: inline-block;
}
.other-category-column ul a{
	color: #333;
}

.button-search-by-name{
	width: 250px;
}
@media only screen and (min-width: 980px) {
	.button-search-by-name-row{
		position: absolute;
		top: 15px;
		right: 0;
		width: 100%;
		text-align:right;
	}
}
@media only screen and (max-width: 980px) {
	.button-search-by-name-row{
		margin: 3em 0 0;
		text-align: center;
	}
}


/* 07 support */

.support-menu-columns.columns{

}
.support-menu-columns .column{
	display: flex;
	-webkit-align-items: center;
	align-items: center;
	margin: 20px;
	padding: 0;
}
.support-menu-columns .column a{
	text-align: center;
	width: 100%;
	padding: 1em 0.5em;
	color: #333;
	font-weight: bold;
	font-size: 120%;
	line-height: 1.3;
}
.support-menu-columns .column a .sup{
	font-size: 14px;
}
.support-menu-columns + .buttonArea{
	padding-top: 0;
}
@media only screen and (max-width: 767px) {
	.support-menu-columns.columns{
		margin: 0;
	}
	.support-menu-columns .column{
		margin: 20px 0;
	}
	.support-menu-columns + .buttonArea{
		padding: 0;
	}
}

/*support-info-columns*/
.support-info-columns.columns{
	margin: 0;
	padding: 0;
}
.support-info-columns .column {
	margin: 0;
	padding: 0.5em 0 0.5em 70px;
}
.support-info-columns .column a{
	color: #333;
}
.support-info-columns .column img{
	margin: 0 1em 0 -70px;
	vertical-align: middle;
}

@media only screen and (min-width: 768px) {
	.support-info-columns.columns {
		list-style: none;
		margin: 0 auto;
		padding: 1em 0;
		max-width: 1160px;
	}
	.support-info-columns.columns:first-of-type {
		padding-top: 0;
	}
	.support-info-columns .column {
		width: 48%;
		flex: none;
		margin: 0;
		padding: 0.5em 0 0.5em 70px;
		box-sizing: border-box;
		font-size: 86%;
	}
	.support-info-columns .column:nth-child(odd) {
		margin-right: 2%;
	}
	.support-info-columns .column:nth-child(even) {
		margin-left: 2%;
	}
	.support-info-columns + .support-info-columns{
		border-top: 1px solid #ccc;
	}
}

/*support-list*/
.support .update{
	color: #c00;
	margin-right: 5px;
	display: block;
}
.support-list-box{
	padding: 4%;
	background: #fff;
}
.support-list-box + .support-list-box{
	margin-top: 25px;
}
.support-list-box h3,
.support-list-box h4{
	margin-bottom: 0;
}
table.support{
	width: 100%;
	margin: 0 0 2em;
}
table.support + table.support{
	margin-top: 3em;
	border-top: 1px dotted #6A8CA8;
}
table.support th{
	font-size: 110%;
	margin-right: 0.5em;
	padding: 1em 1em 1em 30px;
	text-align: left;
	border-bottom: 1px dotted #6A8CA8;
}
table.support th:before{
	content:'●';
	color: #1B5288;
	margin-right: 5px;
}
table.support td{
	font-size: 86%;
	padding: 1em;
	border-bottom: 1px dotted #6A8CA8;
}
table.support td img{
/*	max-width: 100%;*/
}
@media only screen and (min-width: 768px) {
	table.support .name{
		width: 25%;
	}
	table.support .sub{
		width: 30%;
	}
	table.support .version{
		width: 18%;
	}
	/*
	table.support .type{
		width: 140px;
	}
	*/
	table.support .buttons{
		width: 24%;
	}
	table.index_by_name .name{
		width: 30%;
	}
	table.index_by_name .sub{
		width: 40%;
	}
	table.index_by_name .buttons{
		width: 30%;
	}
}
table.support .buttons{
	width: auto;
	text-align: left;
	white-space: nowrap;
}


@media only screen and (max-width: 767px) {
	table.support,
	table.support tbody{
		display: block;
	}
	table.support tr{
		width: 100%;
		display: flex;
		flex-wrap: wrap;
		border-bottom: 1px dotted #6A8CA8;
	}
	table.support th,
	table.support td{
		display: block;
		flex: none;
		border: none;
		width: auto;
		padding: 0.5em 1em;
/*		max-width: 50%;*/
		box-sizing: border-box;
	}
	table.support th{
		margin: 0;
		padding-left: 1em;
	}
	table.support td:last-child{
		width: 100%;
		max-width: 100%;
	}
}
@media only screen and (max-width: 480px) {

}






/* 08 support-detail */


.release-note dt{
	color: #1b5288;
	font-size: 110%;
	padding: 5px 0 10px 30px;
	background: url(../images/ico_note.png) no-repeat;
	cursor: pointer;
}
.release-note dd{
	font-size: 86%;
	font-family: 'MS PGothic', sans-serif;
}

/* 更新履歴 */
#histories .history{
	margin: 2em 0;
	padding-bottom: 1em;
	border-bottom: 1px solid #eee;
}
#histories .history dt{
	font-size: 110%;
	padding-bottom: 0.5em;
	cursor: pointer;
}
#histories .history dt:before{
	content:'';
	display: inline-block;
	margin: 0 15px 0 5px;
	width: 7px;
	height: 11px;
	background: url(../images/ico_arrow_g.png) no-repeat;
	-webkit-transition: -webkit-transform 0.2s;
	transition: transform 0.2s;
	-webkit-transform: rotate(90deg);
	transform: rotate(90deg);
}
#histories .history dt.close:before{
	-webkit-transform: rotate(0deg);
	transform: rotate(0deg);
}
#histories .history dd{
	padding-left: 27px;
}


/* faq */

.faq.detail main h2{
	font-size: 125%;
}

/* googlemap */
.gmap iframe {
	pointer-events:none;
}

/* sitemap */

.sitemap-columns.columns {
	flex-wrap: wrap;
	margin-top: 30px;
	margin-left: -1%;
	margin-right: -1%;
	padding-bottom: 50px;
}
.sitemap-columns .column{
	width: 29%;
	margin: 1% 2%;
	flex: none;
}




/* added styles #37204 */

.has-abs-elm {
  position: relative;
}
.term-def-under {
  position: absolute;
  left: 0;
}
.term-desc {
  display: block;
  margin-left: 5em;
}
.term-desc-long {
    margin-left: 6.3em;
}

#container .narrow {
  margin-top: .5em;
  margin-bottom: 0;
}

.indent {
  margin-left: 2em;
}

.term-def-under-two {
  display: block;
  float: left;
}

.term-desc-two {
  display: block;
  margin-left: 3.1em;
}

.stepdown {
  text-indent: 1em;
}

.shiftdown {
  margin-top: 60px;
}

.price-system .price-system-base dl.spread {
  width: 100%;
}

table.vertical.widen th {
  width: 38%;
}

table.charge thead .left-justify,
table.charge tbody .left-justify {
  text-align: left;
}

table.charge.line-shorten th,
table.charge.line-shorten td {
  padding: 0.8em 1em;
}

table.vertical.line-shorten th,
table.vertical.line-shorten td {
    padding: 0.5em 1em;
}
table.charge.case {
    width: 80%;
    border-collapse: separate;
}
table.charge.compact {
    width: 60%;
}
table.charge.case tbody th,
table.charge.case tbody td {
    padding: 0.5em 1em;
    text-align: center;
}

.on-top {
  vertical-align: top;
}

.block-level {
  display: block;
}

.serial-number > li a:before {
    content: "0" counter(count, decimal);
    counter-increment: count;
    margin-right: 3px
}

.serial-number {
    counter-reset: count;
}

/* /support/jt_kohka/faq/001439.html */
.first-level {
    color: #b90000;
}
.second-level {
    color: #b900b9;
}
.third-level {
    color: #0000ff;
}
.four-level {
    color: #006a00;
}

/* ordered list-style */
ol.circle-number {
    list-style: none;
    padding-left: 0;
    counter-reset: counter;
}
ol.circle-number > li{
    padding-left: 1.5em;
    position: relative;
}
ol.circle-number > li:before{
    content: counter(counter);
    counter-increment: counter;
    display: block;
    float: left;
    margin-top: 0.3em;
    margin-left: -1.5em;
    width: 1em;
    height: 1em;
    line-height: 1;
    border: 1px solid #000000;
    border-radius: 50%;
    text-align: center;
	font-size: 86%;
}

ol.bracket-number {
    list-style: none;
    padding-left: 0;
    counter-reset: undercounter;
}
ol.bracket-number > li{
    padding-left: 1.5em;
    position: relative;
}
ol.bracket-number > li:before{
    content: "(" counter(undercounter) ")";
    counter-increment: undercounter;
    margin-left: -25px;
    margin-right: 5px;
}

ol.oneside-number {
    list-style: none;
    padding-left: 0;
    counter-reset: undercounter;
}
ol.oneside-number > li{
    padding-left: 1.5em;
    position: relative;
}
ol.oneside-number > li:before{
    content: counter(undercounter) ")";
    counter-increment: undercounter;
    margin-left: -20px;
    margin-right: 5px;
}

/* YouTube style */
.youtube {
	position: relative;
	height: 0;
	padding-bottom: 56.25%;
	overflow:hidden;
	border: 1px #cccccc solid;
}
.youtube iframe {
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
}
