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


*{
	margin: 0px;
	padding: 0px;
}
img{
	border: none;
}
.imghover {
	margin: 0;
	padding: 0;
}
a:hover img.imghover {
	filter:alpha(opacity=70);
	opacity:0.7;
}
body {
	margin: 0px;
	padding: 0px;
	font-family: "ＭＳ Ｐゴシック", Osaka, "ヒラギノ角ゴ Pro W3";
}
p {
	font-size: 14px;
	line-height: 1.5;
	color: #5a5a5a;
	padding-top: 15px;
	padding-right: 0px;
	padding-bottom: 15px;
	padding-left: 0px;
}
a:link {
	color: #5a5a5a;
	text-decoration: underline;
	font-weight:bold;
}
a:visited {
	color: #5a5a5a;
	text-decoration: underline;
	font-weight:bold;
}
a:hover {
	color: #5a5a5a;
	text-decoration: none;
	font-weight:bold;
}
#bgbg{
	/*background:url(../images/bg.gif) repeat-y;
	background-position:center top;*/
}
/*
#bg_line{
	background:url(../images/bg_line.gif) repeat-x;
}
*/
#bg{
	background:url(../images/bgbg01.jpg) no-repeat;
	background-position:center top;
	/*lime追加*/
	display: flex;
	flex-direction: column;
	min-height: 100vh;
}
#q_btn_area{
	position:relative;
	width:944px;
	margin:0px auto;
}
#q_btn{
	position:absolute;
	top:45px;
	left:425px;
}
#q_box{
	width:700px;
	margin:0px auto;
}
#google_search{
	width: 872px;
	text-align:right;
	margin-top: 0px;
	margin-right: auto;
	margin-bottom: 0px;
	margin-left: auto;
	padding-top:15px;	
	padding-bottom:77px;	
}
.search_area{
	width:150px;
}
body:first-of-type .search_area{
	width:150px;
}
#gnabi{
	width: 872px;
	margin-top: 0px;
	margin-right: auto;
	margin-bottom: 0px;
	margin-left: auto;
	padding-bottom:12px;
}
.btn{
	float:left;
}
#flash{
	width: 868px;
	margin-top: 0px;
	margin-right: auto;
	margin-bottom: 0px;
	margin-left: auto;
	padding-bottom:12px;
}
#flash img{
	width: 100%;
}
#top_contetns{
	width: 872px;
	margin-top: 0px;
	margin-right: auto;
	margin-bottom: 0px;
	margin-left: auto;
}
#news{
	background:url(../images/news/bg.gif) repeat-y;
	width:630px;
	float:left;
}
.news_text{
	padding:0px 20px 0px 20px;
	font-size:12px;
	color:#666666;
	line-height:150%;
}
.topics_area{
	height:180px;
	overflow:auto;
	width:600px;
}
.topics_tbl {
	padding: 0px;
	width: 500px;
	margin-top: 0px;
	margin-right: 0px;
	margin-bottom: 0px;
	margin-left: 17px;
}
.topics_td01 {
	width: 10px;
	padding-top: 8px;
	padding-right: 0px;
	padding-bottom: 5px;
	padding-left: 5px;
	vertical-align: top;
}
.topics_td02 {
	width: 30px;
	padding-top: 8px;
	padding-right: 0px;
	padding-bottom: 5px;
	padding-left: 5px;
	vertical-align: top;
	color: #666666;
	font-size: 12px;
}
/* これ以降Mac IE 5のみに適用される \*//*/
.topics_td02 {
	width: 30px;
	padding-top: 8px;
	padding-right: 0px;
	padding-bottom: 5px;
	padding-left: 5px;
	vertical-align: top;
	color: #666666;
	font-size: 12px;
}
/* これ以降Mac IE 5以外にも適用される */ 
body:first-of-type .topics_td02 {
	width: 30px;
	padding-top: 6px;
	padding-right: 0px;
	padding-bottom: 5px;
	padding-left: 5px;
	vertical-align: top;
	color: #666666;
	font-size: 12px;
}
.topics_td03 {
	width: 475px;
	padding-top: 5px;
	padding-right: 0px;
	padding-bottom: 5px;
	padding-left: 5px;
	vertical-align: text-top;
	font-size: 12px;
	color: #666666;
	line-height: 150%;
}

#contents{
	width:224px;
	padding-left:17px;
	margin-bottom:30px;
	float:left;
	background:url(../images/contents/bg.gif) repeat-y;
	background-position:17px 0px;
}
.contents_text{
	padding-left:25px;
}
.contents_text2{
	padding:0px 0px 3px 30px;
}
#footer_navi{
	width: 489px;
	margin-top: 0px;
	margin-right: auto;
	margin-bottom: 17px;
	margin-left: auto;
	/*lime追加*/
	margin-top: auto;
	
}
#footer{
	background:url(../images/footer/bg.gif) repeat-x;
	height:20px;
	text-align:center;
	margin-top: 0px;
	margin-bottom: 0px;
}




#base{
	width: 836px;
	margin-top: 0px;
	margin-right: auto;
	margin-bottom: 0px;
	margin-left: auto;
	padding-bottom:12px;
}
main.contents {
	position: relative;
	margin-bottom: 58px;
	padding-top: 24px;
}
main.contents * {
	margin: 0;
	padding: 0;
	font-size: inherit;
	line-height: inherit;
	font-weight: normal;
	list-style: none;
	box-sizing: border-box;
}
main.contents .page-title {
	margin-bottom: 13px;
	color: #5A5A5A;
}
main.contents .page-title h1 {
	font-size: 18px;
	font-weight: 600;
	line-height: 27px;
}
main.contents .page-title .description {
	margin-top: 11px;
	font-size: 12px;
	line-height: 18px;
	letter-spacing: 0.1em;
}
main.contents h2 {
	position: relative;
	padding-left: 20px;
	height: 21px;
}
main.contents h2::before,
main.contents h2::after {
	content: '';
	position: absolute;
	left: 0;
	z-index: 1;
	width: 100%;
	background-color: #366BBE;
}
main.contents h2::before {
	top: 5px;
	height: 9px;
}
main.contents h2::after {
	bottom: 4px;
	height: 2px;
}
main.contents h2 span {
	position: relative;
	z-index: 2;
	padding: 0 10px;
	font-weight: 600;
	font-size: 14px;
	line-height: 21px;
	color: #366BBE;
	background: #fff;
}
main.contents.faq .page-title {
	margin-bottom: 37px;
}
main.contents.faq h2 {
	margin-top: -5px;
	margin-bottom: 28px;
}
main.contents.faq::after {
	content: '';
	display: block;
	clear: both;
}
main.contents.faq .left-menu {
	display: block;
	position: sticky;
	top: 20px;
	float: left;
	width: 144px;
}
main.contents.faq .left-menu ul li {
	display: flex;
	align-items: center;
	justify-content: center;
	height: 40px;
	border: 1px solid #A9A9A9;
	background: #FFF;
	font-size: 14px;
	font-weight: 600;
	color: #366BBE;
}
main.contents.faq .left-menu ul li:not(.active) {
	cursor: pointer;
}
main.contents.faq .left-menu ul li.active {
	background-color: #366BBE;
	border-color: #366BBE;
	color: #fff;
}
main.contents.faq .left-menu ul li+li {
	margin-top: 4px;
}
main.contents.faq .tab-body {
	width: 636px;
	float: right;
	color: #5A5A5A;
}
main.contents.faq .tab-body .tab-page:not(.active) {
	display: none;
}
main.contents.faq .tab-body .tab-page .faq-index {
	padding: 32px 32px 28px;
	border: 1px dashed #A9A9A9;
}
main.contents.faq .tab-body .tab-page .faq-index dl dt {
	margin-bottom: 10px;
	font-weight: 600;
	font-size: 13px;
	line-height: 1;
}
main.contents.faq .tab-body .tab-page .faq-index dl dd+dt {
	margin-top: 28px;
}
main.contents.faq .tab-body .tab-page .faq-index dl dd ul+ul {
	margin-top: 24px;
}
main.contents.faq .tab-body .tab-page .faq-index dl dd ul li {
	position: relative;
	padding-left: 34px;
	font-size: 12px;
	line-height: 21px;
	letter-spacing: 0.08em;
}
main.contents.faq .tab-body .tab-page .faq-index dl dd ul li+li {
	margin-top: 7px;
}
main.contents.faq .tab-body .tab-page .faq-index dl dd ul li span {
	position: absolute;
	top: 0;
	left: 0;
	width: 34px;
	font-weight: 300;
	color: #E6151F;
}
main.contents.faq .tab-body .tab-page .faq-index dl dd ul li p {
	text-decoration: underline;
}
main.contents.faq .tab-body .tab-page .faq-list {
	margin-top: 56px;
}
main.contents.faq .tab-body .tab-page .faq-list ul li {
	padding-bottom: 28px;
	border-bottom: 1px dashed #A9A9A9;
}
main.contents.faq .tab-body .tab-page .faq-list ul li+li {
	margin-top: 30px;
}
main.contents.faq .tab-body .tab-page .faq-list ul li h3 {
	margin-bottom: 20px;
	font-weight: 600;
	font-size: 14px;
	line-height: 1;
}
main.contents.faq .tab-body .tab-page .faq-list ul li dl {
	font-size: 12px;
	line-height: 21px;
	letter-spacing: 0.06em;
}
main.contents.faq .tab-body .tab-page .faq-list ul li dl dt {
	position: relative;
	margin-bottom: 3px;
	padding-left: 34px;
}
main.contents.faq .tab-body .tab-page .faq-list ul li dl dt span {
	position: absolute;
	top: 0;
	left: 0;
	width: 34px;
	font-weight: 300;
	color: #E6151F;
}
main.contents.faq .tab-body .tab-page .faq-list ul li dl dd+dt {
	margin-top: 15px;
}
main.contents.faq .tab-body .tab-page .faq-list ul li dl dd {
	position: relative;
	padding-left: 34px;
}
main.contents.faq .tab-body .tab-page .faq-list ul li dl dd span {
	position: absolute;
	top: 0;
	left: 0;
	width: 34px;
	font-weight: 300;
	color: #389D80;
}
main.contents.faq .tab-body .tab-page .faq-list ul li dl dd .table {
	margin-top: 19px;
	margin-bottom: 4px;
}
main.contents.faq .tab-body .tab-page .faq-list ul li dl dd .table table,
main.contents.faq .tab-body .tab-page .faq-list ul li dl dd .table table td,
main.contents.faq .tab-body .tab-page .faq-list ul li dl dd .table table th {
	border: 1px solid #D9D9D9;
	border-collapse: collapse;
}
main.contents.faq .tab-body .tab-page .faq-list ul li dl dd .table table td,
main.contents.faq .tab-body .tab-page .faq-list ul li dl dd .table table th {
	min-width: 106px;
	padding: 8px;
	text-align: center;
	font-size: 12px;
	line-height: 1;
	font-weight: 300;
}
main.contents.faq .tab-body .tab-page .faq-list ul li dl dd .image {
	margin-top: 19px;
}
main.contents.faq .tab-body .tab-page .faq-list ul li.image-harf {
	position: relative;
}
main.contents.faq .tab-body .tab-page .faq-list ul li.image-harf dl dd p {
	width: 298px;
}
main.contents.faq .tab-body .tab-page .faq-list ul li.image-harf dl dd .image {
	position: absolute;
	top: 5px;
	right: 40px;
	margin-top: 0;
}
main.contents.faq .tab-body .tab-page .faq-list ul li .links {
	display: inline-flex;
	align-items: center;
	position: relative;
	height: 28px;
	margin-top: 19px;
	margin-bottom: 4px;
	padding: 0 18px 0 12px;
	font-weight: 300;
	font-size: 12px;
	line-height: 1;
	letter-spacing: 0.09em;
	text-decoration: none;
	border: 1px solid #D9D9D9;
}
main.contents.faq .tab-body .tab-page .faq-list ul li .links::after {
	content: '';
	position: absolute;
	top: calc(50% - 3.5px);
	right: 13px;
	width: 7px;
	height: 7px;
	transform: rotate(45deg);
	border-top: solid 1px #5A5A5A;
  border-right: solid 1px #5A5A5A;
	box-sizing: border-box;
}

main.contents.contact section+section {
	margin-top: 36px;
}
main.contents.contact section h2 {
	margin-bottom: 16px;
}
main.contents.contact section p {
	font-size: 12px;
	line-height: 18px;
	font-weight: 300;
	letter-spacing: 0.08em;
}
main.contents.contact section .s-btn {
	display: inline-flex;
	align-items: center;
	height: 40px;
	margin-top: 17px;
	padding: 0 16px;
	font-size: 14px;
	font-weight: 600;
	line-height: 1;
	color: #366BBE;
	text-decoration: none;
	border: 1px solid #A9A9A9;
}
main.contents.contact-list h2 {
	margin-bottom: 17px;
}
main.contents.contact-list .member-list ul li {
	display: flex;
	font-weight: 300;
	font-size: 12px;
	line-height: 21px;
	letter-spacing: 0.04em;
}
main.contents.contact-list .member-list ul li+li {
	margin-top: 7px;
}
main.contents.contact-list .member-list ul li .name {
	width: 172px;
	font-weight: 600;
	color: #366BBE;
	text-decoration: underline;
}
main.contents.contact-list .member-list ul li .address {
	width: 335px;
}
main.contents.contact-list .member-list ul li .tel {
	width: calc(100% - 172px - 335px);
}

.member-template {
	position: relative;
}
.member-template .board-btn {
	display: flex;
	align-items: center;
	flex-direction: column;
	justify-content: center;
	position: absolute;
	top: 25px;
	right: 0;
	width: 208px;
	height: 52px;
	text-decoration: none;
	color: #fff;
	border-radius: 6px;
	background-image: url(../images/member/member-btn.png);
	background-size: contain;
	box-shadow: 0px 1px 1px 1px rgba(0, 0, 0, 0.25);
}
.member-template .board-btn .name {
	margin-bottom: 5px;
	text-shadow: 0px 1px 1px rgba(0, 0, 0, 0.25);
	font-weight: 600;
	font-size: 18px;
	line-height: 1;
}
.member-template .board-btn span {
	font-weight: 300;
	font-size: 11px;
	line-height: 1;
}
.member-template iframe {
	height: 2900px;
}

.technology .fixed-qa {
	display: flex;
	align-items: center;
	flex-direction: column;
	justify-content: center;
	position: fixed;
	bottom: 36px;
	right: 36px;
	width: 88px;
	height: 88px;
	text-decoration: none;
	color: #fff;
	background-image: url(../images/technology/qa-btn.png);
	background-size: contain;
}
.technology .fixed-qa .name {
	margin-bottom: 5px;
	text-shadow: 0px 1px 1px rgba(0, 0, 0, 0.25);
	font-weight: 600;
	font-size: 16px;
	line-height: 1;
}
.technology .fixed-qa span {
	text-align: center;
	font-weight: 300;
	font-size: 10px;
	line-height: 13px;
}

