@charset"UTF-8";

/*###########################################################################################*/
/* reset */
/*###########################################################################################*/
/*
html5doctor.com Reset Stylesheet
v1.6.1
Last Updated: 2010-09-17
Author: Richard Clark - http://richclarkdesign.com
Twitter: @rich_clark

html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
abbr, address, cite, code,
del, dfn, em, img, ins, kbd, q, samp,
small, strong, sub, sup, var,
b, i,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, figcaption, figure,
footer, header, hgroup, menu, nav, section, summary,
time, mark, audio, video {
	background: transparent;
	border: 0;
	font-size: 100%;
	margin: 0;
	padding: 0;
	outline: 0;
	vertical-align: baseline;
}

body {
	line-height: 1;
}*/

article,aside,details,figcaption,figure,
footer,header,hgroup,menu,nav,section {
	display: block;
}

#mirai nav ul {
	list-style: none;
}

blockquote, q {
	quotes: none;
}

blockquote:before, blockquote:after,
q:before, q:after {
	content: '';
	content: none;
}

h2#page_title{
	background-image: url(../images/mirai/ttl_futurecalendar.png);
}
@media only screen and (-webkit-min-device-pixel-ratio: 2) {
	h2#page_title{
		#background-image: url(../images/company/ttl_company@2x.png);
	}
}

#mirai {
	color: #505050;
	font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
	letter-spacing: 0.05rem;
}
	

#mirai a {
	background: transparent;
	font-size: 100%;
	margin: 0;
	padding: 0;
	vertical-align: baseline;
}

/* change colours to suit your needs */
ins {
	background-color: #ff9;
	color: #000;
	text-decoration: none;
}

/* change colours to suit your needs */
mark {
	background-color: #ff9;
	color: #000;
	font-style: italic;
	font-weight: bold;
}

del {
	text-decoration: line-through;
}

abbr[title], dfn[title] {
	border-bottom: 1px dotted;
	cursor: help;
}

table {
	border-collapse: collapse;
	border-spacing:0;
}

/* change border colour to suit your needs */
hr {
	border: 0;
	border-top: 1px solid #cccccc;
	display: block;
	height: 1px;
	margin: 1em 0;
	padding: 0;
}

input, select {
	vertical-align: middle;
}

/* custom reset */

#mirai *,
#mirai *::before,
#mirai *::after {
	box-sizing: border-box;
}

#mirai ul,
#mirai ol {
	list-style: none;
}


/* iOS�ǤΥǥե���ȥ��������ꥻ�å� */
input[type="button"],input[type="text"],input[type="submit"],input[type="image"],textarea{
   -webkit-appearance: none;
   border-radius: 0;
}

input[type="submit"],
input[type="button"] {
  border-radius: 0;
  -webkit-box-sizing: content-box;
  -webkit-appearance: button;
  appearance: button;
  border: none;
  box-sizing: border-box;
  cursor: pointer;
}
input[type="submit"]::-webkit-search-decoration,
input[type="button"]::-webkit-search-decoration {
  display: none;
}
input[type="submit"]::focus,
input[type="button"]::focus {
  outline-offset: -2px;
}

/*###########################################################################################*/
/* MEDIA QUERY FORMAT */
/*###########################################################################################*/
#mirai .sp { display: block; }

#mirai .pc { display: none; }

@media screen and (min-width:768px){
	/* ��768px�ʾ��Ŭ�Ѥ����CSS�ʥ��֥�åȥ������ʾ��*/

	/* ���֥�åȤϳ��ͥ��ޥۤ�Ʊ���ǥ�����ʤΤǡ�����Ϥ��ޤ���Ѥ��ޤ��� */
}

@media screen and (min-width:992px){
	/* ��992px�ʾ��Ŭ�Ѥ����CSS��PC�������ʾ�� */
#mirai .sp { display: none;  }
#mirai .pc { display: block; }
    
}


/*###########################################################################################*/
/* �쥤�����ȥ١��� */
/*###########################################################################################*/
#mirai html {
	font-size: 62.5%;
	/* sets the root font to 10px */
}

#mirai body {
	color: #505050;
	font-size: 1.3rem;
	/* default font to 13px */
	font-family: "�⥴���å���", YuGothic, "�⥴���å� Medium", "Yu Gothic Medium", "�⥴���å�", "Yu Gothic", sans-serif;
	letter-spacing: 0.05rem;
//	line-height: 1.4;
	margin: 0px;
	padding: 0px;
}

#mirai .wrapper {
	min-height: 100%;
	overflow-y: hidden;
	position: relative;
}

#mirai main {
	position: relative;
}

#mirai main.container {
	display: block;
	margin-top: 70px;
}

@media screen and (max-width: 320px) {
    main.container {
        margin-top: 60px;
    }
}

.f-mincho {
	font-family: "����ī", YuMincho, "�ҥ饮����ī ProN W3", "Hiragino Mincho ProN", "HG��īE", "�ͣ� ����ī", "�ͣ� ��ī", serif;
}

.f-english {
	font-family: imperial-urw, sans-serif;
}

.f-bold{
	font-weight: bold;
}

.f-line {
    text-decoration: underline;
}

html body .f-no-line {
    text-decoration: none;
}

.inner{
	margin: 0 auto;
	padding: 0 4%;
}

.title-inner{
	align-items: center;
	display: flex;
	justify-content: center;
    height: 12rem;
    flex-direction: column;
    text-align: center;
}

.col-list{
}

.col-list .list-item-wrap{
	display: flex;
	flex-wrap: wrap;
	width: 100%;
}

.col-list .list-item {
    width: 100%;
}

@media (max-width: 991px) {
	/* ��991px�ʲ���Ŭ�Ѥ����CSS��SP��TB�� */

	.col1-sm .list-item-wrap {
		flex-direction: column;
	}

	.col1-sm .list-item-wrap .list-item {
		width: 100%;
	}

	/* �����å��ܥå�������x��ɽ���������� */

	.col-sm-2 .list-item-wrap .list-item {
		width: 50%;
	}

	/* ξü�� */
	.col-sm-2.both-end-sm .list-item-wrap .list-item:first-child{
		display: flex;
		justify-content: flex-start;
	}

	.col-sm-2.both-end-sm .list-item-wrap .list-item:last-child{
		display: flex;
		justify-content: flex-end;
	}

	.col-sm-3 .list-item-wrap .list-item {
		width: 33.33%;
	}

	.col-sm-5 .list-item-wrap .list-item {
		width: 20%;
	}

	.col-sm-10 .list-item-wrap .list-item {
		width: 10%;
	}

}

@media screen and (min-width:768px){
	/* ��768px�ʾ��Ŭ�Ѥ����CSS�ʥ��֥�åȥ������ʾ��*/
  .s_wrap {
      width: 100%;
  }
	.inner {
		padding: 0 4%;
	}

	.title-inner{
		height: 210px;
		padding: 0;
	}
}

@media screen and (min-width:992px){
	/* ��992px�ʾ��Ŭ�Ѥ����CSS��PC�������ʾ�� */

	.inner {
		max-width: 1000px;
		padding: 0;
	}
    
    .inner-small {
        width: 540px;
        margin-left: auto;
        margin-right: auto;
    }
    
    .table1 .list-item-wrap {
        max-width: 748px;
    }

	.col1-lg .list-item-wrap {
		display: flex;
		flex-direction: column;
	}

	.col-lg-1 .list-item-wrap .list-item {
		width: 100%;
	}

	.col-lg-2 .list-item-wrap .list-item{
		width: 50%;
	}

	/* ξü�� */
	.col-lg-2.both-end-lg .list-item-wrap .list-item:first-child{
		display: flex;
		justify-content: flex-start;
	}

	.col-lg-2.both-end-lg .list-item-wrap .list-item:last-child{
		display: flex;
		justify-content: flex-end;
	}

	.col-lg-3 .list-item-wrap .list-item {
		width: 33.33%;
	}
    
    .col-lg-4 .list-item-wrap .list-item {
		width: 25%;
	}

	.col-lg-5 .list-item-wrap .list-item {
		width: 20%;
	}

	.col-lg-10 .list-item-wrap .list-item {
		width: 10%;
	}

}

.cf:before,
.cf:after {
	content: "";
	display: table;
}

.cf:after {
	clear: both;
}

.cf {
	zoom: 1;
}

.object-fit-img {
	object-fit: cover;
	font-family: 'object-fit: cover;'
}

.a-center{
	text-align: center;
}

.a-right{
	text-align: right;
}

@media screen and (max-width:768px){
	/* ��768px�ʾ��Ŭ�Ѥ����CSS�ʥ��֥�åȥ������ʾ��*/

	.ta-sm-center{
        text-align: center;
    }
    
    .ta-sm-left{
        text-align: left;
    }
    
    .ta-sm-right{
        text-align: right;
    }
}

@media screen and (min-width:992px){
	/* ��992px�ʾ��Ŭ�Ѥ����CSS��PC�������ʾ�� */
    
    .ta-lg-center{
        text-align: center;
    }
    
    .ta-lg-left{
        text-align: left;
    }
    
    .ta-lg-right{
        text-align: right;
    }
}

#contact {
    padding-top: 70px;
    margin-top: -70px;
}

@media screen and (max-width:320px){
    #contact {
        padding-top: 60px;
        margin-top: -60px;
    }
}

/*###########################################################################################*/
/* ���� */
/*###########################################################################################*/
#mirai img {
	max-width: 100%;
	height: auto;
}

#mirai a:link,
#mirai a:visited,
#mirai a:hover,
#mirai a:active{
	color: #505050;
	outline: none;
	text-decoration: none;
}

a.blue-line{
	color: #00306d;
	border-bottom: 1px solid #00306d;
	text-decoration: none;
}

#mirai a[href*="tel:"] {
    color: inherit;
    text-decoration: underline;
}

/* TEL��󥯤�̵�� */
@media screen and (min-width:992px){
#mirai a[href*="tel:"] {
        pointer-events: none !important;
        cursor: default !important;
        text-decoration: none !important;
    }
}

/* ���Ф� */

.title1{
	font-size: 2rem;
	font-weight: normal;
	letter-spacing: 0.1rem;
}

.sub-title1{
	font-size: 1.2rem;
	letter-spacing: 0.11rem;
}

.title2{
	font-size: 2.1rem;
	font-weight: normal;
	letter-spacing: 0.08rem;
}

@media screen and (min-width:992px) {
	/* ��992px�ʾ��Ŭ�Ѥ����CSS��PC�������ʾ�� */

	.title1{
		font-size: 2.4rem;
	}

	.sub-title1{
		font-size: 1.4rem;
	}

	.title2{
		font-size: 2.1rem;
	}
}

@media screen and (min-width:992px) {
	/* ��992px�ʾ��Ŭ�Ѥ����CSS��PC�������ʾ�� */

	/* �ۥС����˥᡼����� */

	.line,
	.line-white {
		position: relative;
		display: inline-block;
		text-decoration: none;
	}

	.line:before,
	.line-white:before {
		background: #505050;
		bottom: -1px;
		content: "";
		height: 1px;
		opacity: 0.8;
		position: absolute;
		transform: scale(0, 1);
		transform-origin: right;
		transition: transform 0.4s ease;
		width: 100%;
	}

	.line:hover:before,
	.line-white:hover:before {
		transform-origin: left;
		transform: scale(1, 1);
	}

	.line-white:before {
		background: #fff;
	}
}

/* ����������� */

.blue-underline{
	color: #00306d;
	border-bottom: 1px solid #00306d;
}

.bg-grad-gray{
	background: linear-gradient(to bottom, #eee, #FFF) no-repeat top center;
}

.bg-gray{
	background: #f8f8f8;
}

/* list */

.decimal-list{
	list-style: decimal;
}

.decimal-list .list-item{
	margin-bottom: 1rem;
}

/* letter-spacing */

.ls-1{
	letter-spacing: 0.1rem;
}

@media (max-width: 991px) {
	/* ��991px�ʲ���Ŭ�Ѥ����CSS��SP��TB�� */
	.ls-sm-1 {
		letter-spacing: 0.1rem;
	}
}

@media (min-width: 992px) {
	/* ��992px�ʾ��Ŭ�Ѥ����CSS��PC�������ʾ�� */
	.ls-lg-1 {
		letter-spacing: 0.1rem;
	}
}


/* line-height */

.lh-10{
	line-height: 1;
}

.lh-16{
	line-height: 1.6;
}

.lh-18{
	line-height: 1.8;
}

.lh-20{
	line-height: 2;
}

.lh-22{
	line-height: 2.2;
}

@media (max-width: 991px) {
	/* ��991px�ʲ���Ŭ�Ѥ����CSS��SP��TB�� */
	.lh-sm-10 {
		line-height: 1;
	}
    
    .lh-sm-12 {
		line-height: 1.2;
	}
    
    .lh-sm-14 {
		line-height: 1.4;
	}

	.lh-sm-16 {
		line-height: 1.6;
	}

	.lh-sm-18 {
		line-height: 1.8;
	}

	.lh-sm-20 {
		line-height: 2;
	}

	.lh-sm-22 {
		line-height: 2.2;
	}
}

@media (min-width: 992px) {
	/* ��992px�ʾ��Ŭ�Ѥ����CSS��PC�������ʾ�� */

	.lh-lg-10 {
		line-height: 1;
	}
    
    .lh-lg-12 {
		line-height: 1.2;
	}
    
    .lh-lg-14 {
		line-height: 1.4;
	}

	.lh-lg-16 {
		line-height: 1.6;
	}

	.lh-lg-18 {
		line-height: 1.8;
	}

	.lh-lg-20 {
		line-height: 2;
	}

	.lh-lg-22 {
		line-height: 2.2;
	}
}

/* font */

@media (max-width: 991px) {
	/* ��991px�ʲ���Ŭ�Ѥ����CSS��SP��TB�� */

	.text-sm-10{
		font-size: 1rem;
	}

	.text-sm-11{
		font-size: 1.1rem;
	}

	.text-sm-12{
		font-size: 1.2rem;
	}

	.text-sm-13{
		font-size: 1.3rem;
	}

	.text-sm-14{
		font-size: 1.4rem;
	}

	.text-sm-15{
		font-size: 1.5rem;
	}

	.text-sm-16{
		font-size: 1.6rem;
	}

	.text-sm-18{
		font-size: 1.8rem;
	}

	.text-sm-19{
		font-size: 1.9rem;
	}

	.text-sm-20{
		font-size: 2rem;
	}

	.text-sm-21{
		font-size: 2.1rem;
	}

	.text-sm-225{
		font-size: 2.25rem;
	}

	.text-sm-24{
		font-size: 2.4rem;
	}
}

@media screen and (min-width:768px) and (max-width:991px){
	/* ��768px�ʾ� - 991�ʲ���Ŭ�Ѥ����CSS�ʥ��֥�åȡ�*/

	.text-tb-10{
		font-size: 1.0rem;
	}

}


@media (min-width: 992px) {
	/* ��992px�ʾ��Ŭ�Ѥ����CSS��PC�������ʾ�� */

	.text-lg-10{
		font-size: 1.0rem;
	}
    
    .text-lg-11{
		font-size: 1.1rem;
	}
    
    .text-lg-12{
		font-size: 1.2rem;
	}
    
    .text-lg-13{
		font-size: 1.3rem;
	}
    
    .text-lg-14{
		font-size: 1.4rem;
	}

	.text-lg-15{
		font-size: 1.5rem;
	}


	.text-lg-16{
		font-size: 1.6rem;
	}

	.text-lg-20{
		font-size: 2rem;

	}

	.text-lg-22{
		font-size: 2.2rem;
	}

	.text-lg-24{
		font-size: 2.4rem;
	}

	.text-lg-26{
		font-size: 2.6rem;
	}

	.text-lg-28{
		font-size: 2.8rem;
	}

	.text-lg-30{
		font-size: 3rem;
	}

	.text-lg-32{
		font-size: 3.2rem;
	}

	.text-lg-36{
		font-size: 3.6rem;
	}

	.text-lg-38{
		font-size: 3.8rem;
	}

	.text-lg-40{
		font-size: 4rem;
	}

	.text-lg-42{
		font-size: 4.2rem;
	}

	.text-lg-45{
		font-size: 4.5rem;
	}

	.text-lg-48{
		font-size: 4.8rem;
	}
}


/*###########################################################################################*/
/* ����;�� */
/*###########################################################################################*/
@media (max-width: 991px) {
	/* ��991px�ʲ���Ŭ�Ѥ����CSS��SP��TB�� */

	/*
    base 378px �Ѵ��ḫɽ

    x-x-10 = 10px = 2.646vw
    x-x-15 = 15px = 3.968vw
    x-x-20 = 20px = 5.291vw
    x-x-40 = 40px = 10.582vw
    x-x-60 = 60px = 15.873vw
    x-x-80 = 80px = 21.164vw
    x-x-120 = 120px = 31.746vw
    x-x-160 = 160px = 42.328vw
    x-x-210 = 210px = 55.556vw
    */

	.m-sm-0 {
		margin: 0 !important;
	}
	.mt-sm-0 {
		margin-top: 0 !important;
	}
	.mr-sm-0 {
		margin-right: 0 !important;
	}
	.mb-sm-0 {
		margin-bottom: 0 !important;
	}
	.ml-sm-0 {
		margin-left: 0 !important;
	}

	/* 5px = 1.323vw */
	.mt-sm-5 {
		margin-top: 1.323vw !important;
	}

	/* 10px = 2.646vw */
	.m-sm-10 {
		margin: 2.646vw !important;
	}
	.mt-sm-10 {
		margin-top: 2.646vw !important;
	}
	.mr-sm-10 {
		margin-right: 2.646vw !important;
	}
	.mb-sm-10 {
		margin-bottom: 2.646vw !important;
	}
	.ml-sm-10 {
		margin-left: 2.646vw !important;
	}

	/* 15px = 3.968vw */
	.m-sm-15 {
		margin: 3.968vw !important;
	}
	.mt-sm-15 {
		margin-top: 3.968vw !important;
	}
	.mr-sm-15 {
		margin-right: 3.968vw !important;
	}
	.mb-sm-15 {
		margin-bottom: 3.968vw !important;
	}
	.ml-sm-15 {
		margin-left: 3.968vw !important;
	}

	/* 20px = 5.291vw */
	.m-sm-20 {
		margin: 5.291vw !important;
	}
	.mt-sm-20 {
		margin-top: 5.291vw !important;
	}
	.mr-sm-20 {
		margin-right: 5.291vw !important;
	}
	.mb-sm-20 {
		margin-bottom: 5.291vw !important;
	}
	.ml-sm-20 {
		margin-left: 5.291vw !important;
	}
    
    /* 30px = 7.936vw */
	.m-sm-30 {
		margin: 7.936vw !important;
	}
	.mt-sm-30 {
		margin-top: 7.936vw !important;
	}
	.mr-sm-30 {
		margin-right: 7.936vw !important;
	}
	.mb-sm-30 {
		margin-bottom: 7.936vw !important;
	}
	.ml-sm-30 {
		margin-left: 7.936vw !important;
	}

	/* 40px = 10.582vw */
	.m-sm-40 {
		margin: 10.582vw !important;
	}
	.mt-sm-40 {
		margin-top: 10.582vw !important;
	}
	.mr-sm-40 {
		margin-right: 10.582vw !important;
	}
	.mb-sm-40 {
		margin-bottom: 10.582vw !important;
	}
	.ml-sm-40 {
		margin-left: 10.582vw !important;
	}

	/* 60px = 15.873vw */
	.m-sm-60 {
		margin: 15.873vw !important;
	}
	.mt-sm-60 {
		margin-top: 15.873vw !important;
	}
	.mr-sm-60 {
		margin-right: 15.873vw !important;
	}
	.mb-sm-60 {
		margin-bottom: 15.873vw !important;
	}
	.ml-sm-60 {
		margin-left: 15.873vw !important;
	}

	/* 80px = 21.164vw */
	.m-sm-80 {
		margin: 21.164vw !important;
	}
	.mt-sm-80 {
		margin-top: 21.164vw !important;
	}
	.mr-sm-80 {
		margin-right: 21.164vw !important;
	}
	.mb-sm-80 {
		margin-bottom: 21.164vw !important;
	}
	.ml-sm-80 {
		margin-left: 21.164vw !important;
	}

	/* 120px = 31.746vw */
	.m-sm-120 {
		margin: 31.746vw !important;
	}
	.mt-sm-120 {
		margin-top: 31.746vw !important;
	}
	.mr-sm-120 {
		margin-right: 31.746vw !important;
	}
	.mb-sm-120 {
		margin-bottom: 31.746vw !important;
	}
	.ml-sm-120 {
		margin-left: 31.746vw !important;
	}

	/* 160px = 42.328vw */
	.m-sm-160 {
		margin: 42.328vw !important;
	}
	.mt-sm-160 {
		margin-top: 42.328vw !important;
	}
	.mr-sm-160 {
		margin-right: 42.328vw !important;
	}
	.mb-sm-160 {
		margin-bottom: 42.328vw !important;
	}
	.ml-sm-160 {
		margin-left: 42.328vw !important;
	}

	/* 210px = 55.556vw */
	.m-sm-210 {
		margin: 55.556vw !important;
	}
	.mt-sm-210 {
		margin-top: 55.556vw !important;
	}
	.mr-sm-210 {
		margin-right: 55.556vw !important;
	}
	.mb-sm-210 {
		margin-bottom: 55.556vw !important;
	}
	.ml-sm-210 {
		margin-left: 55.556vw !important;
	}


	.p-sm-0 {
		padding: 0 !important;
	}
	.pt-sm-0 {
		padding-top: 0 !important;
	}
	.pr-sm-0 {
		padding-right: 0 !important;
	}
	.pb-sm-0 {
		padding-bottom: 0 !important;
	}
	.pl-sm-0 {
		padding-left: 0 !important;
	}

	/* 10px = 2.646vw */
	.p-sm-10 {
		padding: 2.646vw !important;
	}
	.pt-sm-10 {
		padding-top: 2.646vw !important;
	}
	.pr-sm-10 {
		padding-right: 2.646vw !important;
	}
	.pb-sm-10 {
		padding-bottom: 2.646vw !important;
	}
	.pl-sm-10 {
		padding-left: 2.646vw !important;
	}

	/* 15px = 3.968vw */
	.p-sm-15 {
		padding: 3.968vw !important;
	}
	.pt-sm-15 {
		padding-top: 3.968vw !important;
	}
	.pr-sm-15 {
		padding-right: 3.968vw !important;
	}
	.pb-sm-15 {
		padding-bottom: 3.968vw !important;
	}
	.pl-sm-15 {
		padding-left: 3.968vw !important;
	}

	/* 20px = 5.291vw */
	.p-sm-20 {
		padding: 5.291vw !important;
	}
	.pt-sm-20 {
		padding-top: 5.291vw !important;
	}
	.pr-sm-20 {
		padding-right: 5.291vw !important;
	}
	.pb-sm-20 {
		padding-bottom: 5.291vw !important;
	}
	.pl-sm-20 {
		padding-left: 5.291vw !important;
	}

	/* 40px = 10.582vw */
	.p-sm-40 {
		padding: 10.582vw !important;
	}
	.pt-sm-40 {
		padding-top: 10.582vw !important;
	}
	.pr-sm-40 {
		padding-right: 10.582vw !important;
	}
	.pb-sm-40 {
		padding-bottom: 10.582vw !important;
	}
	.pl-sm-40 {
		padding-left: 10.582vw !important;
	}

	/* 60px = 15.873vw */
	.p-sm-60 {
		padding: 15.873vw !important;
	}
	.pt-sm-60 {
		padding-top: 15.873vw !important;
	}
	.pr-sm-60 {
		padding-right: 15.873vw !important;
	}
	.pb-sm-60 {
		padding-bottom: 15.873vw !important;
	}
	.pl-sm-60 {
		padding-left: 15.873vw !important;
	}

	/* 80px = 21.164vw */
	.p-sm-80 {
		padding: 21.164vw !important;
	}
	.pt-sm-80 {
		padding-top: 21.164vw !important;
	}
	.pr-sm-80 {
		padding-right: 21.164vw !important;
	}
	.pb-sm-80 {
		padding-bottom: 21.164vw !important;
	}
	.pl-sm-80 {
		padding-left: 21.164vw !important;
	}

	/* 120px = 31.746vw */
	.p-sm-120 {
		padding: 31.746vw !important;
	}
	.pt-sm-120 {
		padding-top: 31.746vw !important;
	}
	.pr-sm-120 {
		padding-right: 31.746vw !important;
	}
	.pb-sm-120 {
		padding-bottom: 31.746vw !important;
	}
	.pl-sm-120 {
		padding-left: 31.746vw !important;
	}

	/* 160px = 31.746vw */
	.p-sm-160 {
		padding: 31.746vw !important;
	}
	.pt-sm-160 {
		padding-top: 31.746vw !important;
	}
	.pr-sm-160 {
		padding-right: 31.746vw !important;
	}
	.pb-sm-160 {
		padding-bottom: 31.746vw !important;
	}
	.pl-sm-160 {
		padding-left: 31.746vw !important;
	}

	/* 210px = 55.556vw */
	.p-sm-210 {
		padding: 55.556vw !important;
	}
	.pt-sm-210 {
		padding-top: 55.556vw !important;
	}
	.pr-sm-210 {
		padding-right: 55.556vw !important;
	}
	.pb-sm-210 {
		padding-bottom: 55.556vw !important;
	}
	.pl-sm-210 {
		padding-left: 55.556vw !important;
	}
}

@media (min-width: 992px) {
	/* ��992px�ʾ��Ŭ�Ѥ����CSS��PC�������ʾ�� */

	/*
    x-x-10 = 10px
    x-x-15 = 15px
    x-x-20 = 20px
    x-x-40 = 40px
    x-x-60 = 60px
    x-x-80 = 80px
    x-x-120 = 120px
    x-x-160 = 160px
    x-x-210 = 210px
    */

	.m-lg-0 {
		margin: 0 !important;
	}
	.mt-lg-0 {
		margin-top: 0 !important;
	}
	.mr-lg-0 {
		margin-right: 0 !important;
	}
	.mb-lg-0 {
		margin-bottom: 0 !important;
	}
	.ml-lg-0 {
		margin-left: 0 !important;
	}

	/* 10px */
	.m-lg-10 {
		margin: 1rem !important;
	}
	.mt-lg-10 {
		margin-top: 1rem !important;
	}
	.mr-lg-10 {
		margin-right: 1rem !important;
	}
	.mb-lg-10 {
		margin-bottom: 1rem !important;
	}
	.ml-lg-10 {
		margin-left: 1rem !important;
	}

	/* 15px */
	.m-lg-15 {
		margin: 1.5rem !important;
	}
	.mt-lg-15 {
		margin-top: 1.5rem !important;
	}
	.mr-lg-15 {
		margin-right: 1.5rem !important;
	}
	.mb-lg-15 {
		margin-bottom: 1.5rem !important;
	}
	.ml-lg-15 {
		margin-left: 1.5rem !important;
	}

	/* 20px */
	.m-lg-20 {
		margin: 2rem !important;
	}
	.mt-lg-20 {
		margin-top: 2rem !important;
	}
	.mr-lg-20 {
		margin-right: 2rem !important;
	}
	.mb-lg-20 {
		margin-bottom: 2rem !important;
	}
	.ml-lg-20 {
		margin-left: 2rem !important;
	}
    
    /* 30px */
	.m-lg-30 {
		margin: 3rem !important;
	}
	.mt-lg-30 {
		margin-top: 3rem !important;
	}
	.mr-lg-30 {
		margin-right: 3rem !important;
	}
	.mb-lg-30 {
		margin-bottom: 3rem !important;
	}
	.ml-lg-30 {
		margin-left: 3rem !important;
	}

	/* 40px */
	.m-lg-40 {
		margin: 4rem !important;
	}
	.mt-lg-40 {
		margin-top: 4rem !important;
	}
	.mr-lg-40 {
		margin-right: 4rem !important;
	}
	.mb-lg-40 {
		margin-bottom: 4rem !important;
	}
	.ml-lg-40 {
		margin-left: 4rem !important;
	}

	/* 60px */
	.m-lg-60 {
		margin: 6rem !important;
	}
	.mt-lg-60 {
		margin-top: 6rem !important;
	}
	.mr-lg-60 {
		margin-right: 6rem !important;
	}
	.mb-lg-60 {
		margin-bottom: 6rem !important;
	}
	.ml-lg-60 {
		margin-left: 6rem !important;
	}

	/* 80px */
	.m-lg-80 {
		margin: 8rem !important;
	}
	.mt-lg-80 {
		margin-top: 8rem !important;
	}
	.mr-lg-80 {
		margin-right: 8rem !important;
	}
	.mb-lg-80 {
		margin-bottom: 8rem !important;
	}
	.ml-lg-80 {
		margin-left: 8rem !important;
	}

	/* 120px */
	.m-lg-120 {
		margin: 12rem !important;
	}
	.mt-lg-120 {
		margin-top: 12rem !important;
	}
	.mr-lg-120 {
		margin-right: 12rem !important;
	}
	.mb-lg-120 {
		margin-bottom: 12rem !important;
	}
	.ml-lg-120 {
		margin-left: 12rem !important;
	}

	/* 160px */
	.m-lg-160 {
		margin: 16rem !important;
	}
	.mt-lg-160 {
		margin-top: 16rem !important;
	}
	.mr-lg-160 {
		margin-right: 16rem !important;
	}
	.mb-lg-160 {
		margin-bottom: 16rem !important;
	}
	.ml-lg-160 {
		margin-left: 16rem !important;
	}

	/* 210px */
	.m-lg-210 {
		margin: 21rem !important;
	}
	.mt-lg-210 {
		margin-top: 21rem !important;
	}
	.mr-lg-210 {
		margin-right: 21rem !important;
	}
	.mb-lg-210 {
		margin-bottom: 21rem !important;
	}
	.ml-lg-210 {
		margin-left: 21rem !important;
	}

	.p-lg-0 {
		padding: 0 !important;
	}
	.pt-lg-0 {
		padding-top: 0 !important;
	}
	.pr-lg-0 {
		padding-right: 0 !important;
	}
	.pb-lg-0 {
		padding-bottom: 0 !important;
	}
	.pl-lg-0 {
		padding-left: 0 !important;
	}

	/* 10px */
	.p-lg-10 {
		padding: 1rem !important;
	}
	.pt-lg-10 {
		padding-top: 1rem !important;
	}
	.pr-lg-10 {
		padding-right: 1rem !important;
	}
	.pb-lg-10 {
		padding-bottom: 1rem !important;
	}
	.pl-lg-10 {
		padding-left: 1rem !important;
	}

	/* 15px */
	.p-lg-15 {
		padding: 1.5rem !important;
	}
	.pt-lg-15 {
		padding-top: 1.5rem !important;
	}
	.pr-lg-15 {
		padding-right: 1.5rem !important;
	}
	.pb-lg-15 {
		padding-bottom: 1.5rem !important;
	}
	.pb-lg-15 {
		padding-left: 1.5rem !important;
	}

	/* 20px */
	.p-lg-20 {
		padding: 2rem !important;
	}
	.pt-lg-20 {
		padding-top: 2rem !important;
	}
	.pr-lg-20 {
		padding-right: 2rem !important;
	}
	.pb-lg-20 {
		padding-bottom: 2rem !important;
	}
	.pl-lg-20 {
		padding-left: 2rem !important;
	}

	/* 40px */
	.p-lg-40 {
		padding: 4rem !important;
	}
	.pt-lg-40 {
		padding-top: 4rem !important;
	}
	.pr-lg-40 {
		padding-right: 4rem !important;
	}
	.pb-lg-40 {
		padding-bottom: 4rem !important;
	}
	.pl-lg-40 {
		padding-left: 4rem !important;
	}

	/* 60px */
	.p-lg-60 {
		padding: 6rem !important;
	}
	.pt-lg-60 {
		padding-top: 6rem !important;
	}
	.pr-lg-60 {
		padding-right: 6rem !important;
	}
	.pb-lg-60 {
		padding-bottom: 6rem !important;
	}
	.pl-lg-60 {
		padding-left: 6rem !important;
	}

	/* 80px */
	.p-lg-80 {
		padding: 8rem !important;
	}
	.pt-lg-80 {
		padding-top: 8rem !important;
	}
	.pr-lg-80 {
		padding-right: 8rem !important;
	}
	.pb-lg-80 {
		padding-bottom: 8rem !important;
	}
	.pl-lg-80 {
		padding-left: 8rem !important;
	}

	/* 120px */
	.p-lg-120 {
		padding: 12rem !important;
	}
	.pt-lg-120 {
		padding-top: 12rem !important;
	}
	.pr-lg-120 {
		padding-right: 12rem !important;
	}
	.pb-lg-120 {
		padding-bottom: 12rem !important;
	}
	.pl-lg-120 {
		padding-left: 12rem !important;
	}

	/* 160px */
	.p-lg-160 {
		padding: 16rem !important;
	}
	.pt-lg-160 {
		padding-top: 16rem !important;
	}
	.pr-lg-160 {
		padding-right: 16rem !important;
	}
	.pb-lg-160 {
		padding-bottom: 16rem !important;
	}
	.pl-lg-160 {
		padding-left: 16rem !important;
	}

	/* 210px */
	.p-lg-210 {
		padding: 21rem !important;
	}
	.pt-lg-210 {
		padding-top: 21rem !important;
	}
	.pr-lg-210 {
		padding-right: 21rem !important;
	}
	.pb-lg-210 {
		padding-bottom: 21rem !important;
	}
	.pl-lg-210 {
		padding-left: 21rem !important;
	}
}

/*###########################################################################################*/
/* Animation */
/*###########################################################################################*/
.fade-animation {
	position: relative;
	transform: translate3d(0, 60px, 0);
	transition: transform 1.5s cubic-bezier(0.165, 0.84, 0.44, 1), opacity 1.5s cubic-bezier(0.165, 0.84, 0.44, 1);
	opacity: 0;
}

.fade-animation.is-anime {
	 transform: translate3d(0, 0, 0);
	 opacity: 1;
 }

.slidefade-animation {
	position: relative;
	transform: translate3d(-60px, 0, 0);
	transition: transform 1.5s cubic-bezier(0.165, 0.84, 0.44, 1), opacity 1.5s cubic-bezier(0.165, 0.84, 0.44, 1);
	opacity: 0;
}

.slidefade-animation.is-anime {
	transform: translate3d(0, 0, 0);
	opacity: 1;
}

.fade-animation.active {
	transform: translate3d(0, 0, 0);
	opacity: 1;
}

.opacity-animation {
	opacity: 0;
	transition: opacity 0.8s ease-in-out;
}

.opacity-animation.active,
.opacity-animation.is-anime {
	opacity: 1;
}

.slide-animation {
	transform: translate3d(-100.5%, 0, 0);
	transition: transform 1s cubic-bezier(0.215, 0.61, 0.355, 1);
}

.slide-animation:before {
	content: '';
	display: block;
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	z-index: 2;
	background-color: #000;
	transform-origin: right;
	transition: transform 0.85s cubic-bezier(0.215, 0.61, 0.355, 1) 0.5s;
}

.slide-animation.active,
.slide-animation.is-anime {
	transform: translate3d(0, 0, 0);
}

.slide-animation.active:before,
.slide-animation.is-anime:before {
	transform: translate3d(0, 0, 0) scale(0, 1);
}


/*###########################################################################################*/
/* button */
/*###########################################################################################*/

#mirai .btn-wrap{
	align-items: center;
	display: flex;
	justify-content: center;
}

#mirai .btn{
	display: flex;
	align-items: center;
	justify-content: center;
	border: none;
	background: #969696;
	color: #FFF;
    cursor: pointer;
	height: 6rem;
}

#mirai button.btn{
	display: block;
}

#mirai a.btn{
	color: #FFF;
}

#mirai .btn:hover{
	color: #FFF;
	background: #505050;
}

#mirai .btn.c1 {
	background: #00306d;
	color: #FFF;
}

#mirai .btn.c2 {
	background: #FFF;
	color: #505050;
}

#mirai .btn.c3 {
	background: #FFF;
	color: #505050;
    border: 1px solid #969696;
}

#mirai .btn.btn-center{
	margin-right: auto;
	margin-left: auto;
}

.btn.w-sm-95p{
	width: 95%;
}

.btn.w-sm-97p{
	width: 97%;
}

.btn.w-sm-100p{
    width: 100%;
}

@media screen and (min-width:768px) {
	/* ��768px�ʾ��Ŭ�Ѥ����CSS�ʥ��֥�åȥ������ʾ��*/
	.btn.h-tb-60 {
		height: 60px;
	}
}

@media screen and (min-width:992px) {
	/* ��992px�ʾ��Ŭ�Ѥ����CSS��PC�������ʾ�� */

	.btn.w-lg-50p{
		width: 50%;
	}

	.btn.w-lg-98p{
		width: 98%;
	}

	.btn.w-lg-100p{
		width: 100%;
	}

	.btn.w-lg-100 {
		width: 100px;
	}

	.btn.w-lg-150 {
		width: 150px;
	}

	.btn.w-lg-200 {
		width: 200px;
	}

	.btn.w-lg-250 {
		width: 250px;
	}

	.btn.w-lg-300 {
		width: 300px;
	}

	.btn.w-lg-400 {
		width: 400px;
	}

	.btn.w-lg-500 {
		width: 500px;
	}

	.btn.w-lg-600 {
		width: 600px;
	}

	.btn.w-lg-667 {
		width: 667px;
	}

	.btn.h-lg-30 {
		height: 30px;
	}

	.btn.h-lg-40 {
		height: 40px;
	}

	.btn.h-lg-50 {
		height: 50px;
	}

	.btn.h-lg-100 {
		height: 100px;
	}
}

/*###########################################################################################*/
/* +-�������� */
/*###########################################################################################*/
.toggle-icon {
    position: relative;
    cursor: pointer;
}

.toggle-icon:before,
.toggle-icon:after {
	background: #505050;
	bottom: 0;
	content: "";
	position: absolute;
	right: 4%;
	top: 0;
	height: 2px;
	margin: auto;
	width: 1.5rem;
}

.toggle-icon:before {
	transition: opacity 0.3s ease;
}

.toggle-icon:after {
	transform: rotate(90deg);
	transition: transform 0.3s ease;
}

.toggle-icon.active:before {
	opacity: 0;
}

.toggle-icon.active:after {
	transform: rotate(180deg);
}

@media screen and (min-width:992px) {
	.toggle-icon:before,
	.toggle-icon:after {
		width: 12px;
	}
}

.toggle-icon-white {
	position: relative;
}
.toggle-icon-white:before, .toggle-icon-white:after {
	background: #fff;
	bottom: 0;
	content: "";
	position: absolute;
	right: 20px;
	top: 0;
	height: 2px;
	margin: auto;
	width: 13px;
}
.toggle-icon-white:after {
	transform: rotate(90deg);
}


/*###########################################################################################*/
/* SPɽ������ɽ���ڤ��ؤ� */
/*###########################################################################################*/

@media screen and (max-width:991px) {
    .read-more-content{
        display: none;
    }
    
    .hide-text {
        overflow: hidden;
        display: -webkit-box;
        -webkit-box-orient: vertical;
        -webkit-line-clamp: 3;
    }
}



/*###########################################################################################*/
/* �ơ��֥� */
/*###########################################################################################*/
/* form���� */
.table1,
.table2{
	border: none;
	border-collapse: collapse;
	width: 100%;
}
.table1 tr td,
.table1 tr th,
.table2 tr td,
.table2 tr th{
	display: block;
}

.table1 tr th,
.table2 tr th{
	background: #f8f8f8;
	border: 1px solid #b4b4b4;
	border-bottom: 0;
	border-top: 0;
	font-size: 1.4rem;
	font-weight: normal;
	padding: 10px 10px 10px 15px;
	text-align: left;
	vertical-align: middle;
	width: 100%;
}

.table1 tr th.bg-error{
	background: #fff2f2;
}

.table1 tr:first-child th{
	border-top: 1px solid #b4b4b4;
}

.table1 tr td,
.table2 tr td{
	border:1px solid #b4b4b4;
	font-weight:normal;
	line-height:1.5;
	position: relative;
	text-align:left;
	vertical-align:middle;
}

.table1 input[type=text],
.table1 input[type=tel],
.table1 input[type=email],
.table1 input[type=password],
.table1 input[type=number]
{
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	padding: 10px;
    font-size: 1.4rem;
}

.table1 .input-wrap{
	min-height: 50px;
	padding: 10px;
	display: flex;
	align-items: center;
}

.table1 .point{
	font-size: 1.1rem;
	margin-top: 10px;
}

/* detail_bukken�ǻ��ѡ�tablet���������ɻߡ� */

table2.col1,table2.col2{
	width: 50%;
}

@media screen and (max-width:991px) {
    .input-wrap.input-wrap-m-sm .list-item-wrap {
        margin: -1.343vw 0 !important;
    }
    .input-wrap.input-wrap-m-sm .list-item {
        margin: 1.343vw 0 !important;
    }    
}

@media screen and (min-width:992px) {
    .input-wrap.input-wrap-m-lg .list-item-wrap {
        margin: -5px 0 !important;
    }
    .input-wrap.input-wrap-m-lg .list-item {
        margin: 5px 0 !important;
    }    
}

/* IE11�Τ� */
@media all and (-ms-high-contrast: none) {
    *::-ms-backdrop, .table1 tr td, .table1 tr th {
        padding-bottom: 1px;
    }
    
    *::-ms-backdrop, .table1 .input-wrap {
        position: relative;
    }
    *::-ms-backdrop, .table1 input[type=text], .table1 input[type=tel], .table1 input[type=password], .table1 input[type=password] {
        width: 99.9% !important;
    }
}

/* noline table */

.table2 tr th,
.table2 tr td{
	border: 0;
	background: none;
	letter-spacing: 0.05rem;
}

.table2 tr th{
	font-weight: bold;
	padding: 0 0 2rem 0;
	vertical-align: top;
	width: 30%;
}

@media screen and (max-width:991px) {
    .table2 tr th{
        width: 35%;
    }   
}

.table2 tr td{
	padding: 0 0 2rem 0;
}

/* 2col ver */

.table2.col2 tr th,
.table2.col2 tr td{
	display: table-cell;
}

@media screen and (min-width:992px) {
	/* ��992px�ʾ��Ŭ�Ѥ����CSS��PC�������ʾ�� */

	.table-flex-wrap{
		display: flex;
	}

	.table-flex-wrap .table1{
		width: 100%;
	}

	.table-flex-wrap .table1 tr th{
		width: 25%;
	}
    
    .table-flex-wrap.col-lg-2 {
        justify-content: space-between;
    }
    
    .table-flex-wrap.col-lg-2 table {
        width: 49%;
    }

	.table1 tr td,
	.table1 tr th,
	.table2 tr td,
	.table2 tr th{
		display: table-cell;
	}

	.table1 tr th {
		border: 1px solid #b4b4b4;
		padding: 20px 10px;
		width: 250px;
	}

	.table2 tr th,
	.table2 tr td{
		letter-spacing: 0.06rem;
	}

}

/*###########################################################################################*/
/* �ե�����ѡ��� */
/*###########################################################################################*/

.req,
.any{
	background-color: #63afce;
	text-align: center;
	vertical-align: middle;
	padding: 4px;
	margin-left: 5px;
	color: #fff;
	font-size: 1rem;
	font-weight: normal;
}

.any {
	background-color: #969696;
}


.error-alert {
    padding: 15px;
    margin-bottom: 4rem;
    background: #fff2f2;
}

.alert{
	margin: 10px 0;
    color: #ec1818;
}

.error-col{
	font-size: 1.1rem;
	margin-top: 10px;
    color: #ec1818;
}

.error-list{
	margin: 10px 0;
}

.error-list .error-item{
	color: #ec1818;
	font-size: 1.4rem;
	line-height: 1.4;
}

@media screen and (min-width:992px) {
	/* ��992px�ʾ��Ŭ�Ѥ����CSS��PC�������ʾ�� */

	.req,
	.any{
		float: right;
		margin: 0;
	}
}

input, label {
	margin-top: 0;
    cursor: pointer;
}

.table1 input[type=text],
.table1 input[type=tel],
.table1 input[type=password],
.table1 input[type=email],
.table1 input[type=number],
button,
textarea{
	border: 0;
	width: 100%;
    padding: 10px;
}

textarea{
	font-size: 1.4rem;
	font-family: "�⥴���å���", YuGothic, "�⥴���å� Medium", "Yu Gothic Medium", "�⥴���å�", "Yu Gothic", sans-serif;
	resize: vertical;
    line-height: 1.6;
}

input[type="checkbox"] {
	background-color: initial;
	margin: 3px 3px 3px 4px;
	padding: initial;
	border: initial;
}

input[type="button"],
button{
	font-size: 1.4rem;
	border: 0;
}

input[type="submit"],
input[type="button"] {
    display: block;
    font-size: 1.4rem;
}

select {
    min-width: 130px;
    padding: 0.3rem 0.4rem;
    font-size: 1.4rem;
}

.range-select-item-wrap .range-select-item {
    width: 45%
}

/* �ϰϻ����ѥ��쥯�ȥܥå��� */
.range-select-item-wrap .to-mark {
    width: 10%;
    margin: 0;
    text-align: center;
}

.range-select-item-wrap select {
    width: 100%;
}

.range-select-item-wrap {
    display: flex;
    align-items: center;
}

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

    .range-select-item-wrap .range-select-item {
        width: auto;
    }

    .range-select-item-wrap .to-mark {
        width: auto;
        margin: 0 1rem;
    }

    .range-select-item-wrap select {
        width: 100%;
    }

}

/* �̾IE��Edge���ꡣ�ޤȤ�񤭤���ȸ����ʤ��Τǡ������Τޤ� */

::placeholder {
	color: #b4b4b4;
}

/* IE */
:-ms-input-placeholder {
	color: #b4b4b4;
}

/* Edge */
::-ms-input-placeholder {
	color: #b4b4b4;
}

/*###########################################################################################*/
/* header */
/*###########################################################################################*/

#mirai .header {
	position: fixed;
	width: 100%;
	z-index: 9999;
}

#mirai .header a {
	color: #fff;
	font-family: imperial-urw, sans-serif;
	letter-spacing: 1px;
}

#mirai .header-nav-sp {
	opacity: 0;
}

#mirai .header-nav-sp.fixed {
	opacity: 1;
}

#mirai .header-nav-sp .wrap {
	background: #fff;
	display: flex;
	padding-right: 70px;
	position: fixed;
	top: 0;
	transition: opacity 0.8s ease, transform 0.5s;
	width: 100%;
	z-index: 11;
}

#mirai .header-nav-sp #mirai .header-logo {
	align-items: center;
	display: flex;
	padding: 0 10px;
	margin-right: auto;
	width: 77%;
}

#mirai .header-nav-sp.fixed #mirai .header-logo #mirai .header-logo-img {
	vertical-align: top;
}

#mirai .header-nav-sp .header-tel {
	align-items: center;
	background: #969696;
	display: none;
	flex-direction: column;
	height: 70px;
	justify-content: center;
	padding-bottom: 7px;
	position: relative;
	width: 70px;
}

#mirai .header-nav-sp .header-tel.is-shown {
	display: flex;
}

#mirai .header-nav-sp .header-tel .icon-tel-img{
	max-width: 34px;
}

#mirai .header-nav-sp .header-tel .header-tel-txt {
	left: 50%;
	letter-spacing: 1px;
	bottom: 9px;
	color: #fff;
	font-size: 0.8rem;
	display: inline-table;
	position: absolute;
	transform: translateX(-50%);
}

@media screen and (min-width:768px) {
	/* ��768px�ʾ��Ŭ�Ѥ����CSS�ʥ��֥�åȥ������ʾ��*/

	#mirai .header-nav-sp .header-tel .header-tel-txt {
		font-size: 0.5rem;
	}
}

#mirai .header-nav-sp .header-btn {
	align-items: center;
	background: #505050;
	cursor: pointer;
	display: none;
	flex-direction: column;
	height: 70px;
	justify-content: center;
	position: fixed;
	right: 0;
	top: 0;
	transition: opacity 0.8s, transform 0.5s;
	padding-bottom: 7px;
	width: 70px;
	z-index: 14;
}

#mirai .header-nav-sp .header-btn.is-shown {
	display: flex;
}

#mirai .header-nav-sp .header-btn .header-btn-bar-hum {
	background-color: #fff;
	display: block;
	height: 2px;
	margin-bottom: 6px;
	position: relative;
	top: 0;
	transition: all 0.3s ease;
	width: 23px;
}

#mirai .header-nav-sp .header-btn.active .header-btn-bar-hum {
	background-color: #fff;
}

#mirai .header-nav-sp .header-btn .header-btn-bar-hum:last-child {
	margin-bottom: 0;
}

#mirai .header-nav-sp .header-btn.active .header-btn-bar-hum:nth-child(1) {
	top: 8px;
	transform: rotate(45deg);
}

#mirai .header-nav-sp .header-btn.active .header-btn-bar-hum:nth-child(2) {
	opacity: 0;
}

#mirai .header-nav-sp .header-btn.active .header-btn-bar-hum:nth-child(3) {
	top: -8px;
	transform: rotate(-45deg);
}

#mirai .header-nav-sp .header-btn .header-btn-bar-txt {
	bottom: 9px;
	color: #fff;
	font-size: 0.8rem;
	left: 50%;
	letter-spacing: 1px;
	position: absolute;
	transform: translateX(-50%);
}

@media screen and (min-width:768px) {
	/* ��768px�ʾ��Ŭ�Ѥ����CSS�ʥ��֥�åȥ������ʾ��*/

	#mirai .header-nav-sp .header-btn .header-btn-bar-txt {
		font-size: 0.5rem;
	}
}

#mirai .header-nav-sp .header-btn .header-btn-bar-txt.menu {
	opacity: 1;
}

#mirai .header-nav-sp .header-btn.active .header-btn-bar-txt.menu {
	opacity: 0;
}

#mirai .header-nav-sp .header-btn .header-btn-bar-txt.close {
	opacity: 0;
}

#mirai .header-nav-sp .header-btn.active .header-btn-bar-txt.close {
	opacity: 1;
}

/* �ϥ�С�������˥塼�Υꥹ�� */

#mirai .header-nav {
	box-sizing: border-box;
	background-color: rgba(80, 80, 80, 0.95);
	height: 100%;
	transform: translate3d(-100%, 0, 0);
	transform-origin: left;
	transition: opacity 0.7s ease 0s, transform 0.7s cubic-bezier(0.45, 0.05, 0.14, 0.99) 0s;
	opacity: 0;
	overflow-y: scroll;
	pointer-events: none;
	position: fixed;
	width: 100%;
	z-index: 13;
}

#mirai .header-nav.is-active {
	min-height: 100vh;
	opacity: 1;
	transform: translate3d(0, 0, 0);
	pointer-events: auto;
}

#mirai .header-nav #mirai .header-nav-list {
	padding-bottom: 40px;
	padding-top: 80px;
	position: absolute;
	margin: auto 0;
	width: 100%;
}

#mirai .header-nav #mirai .header-nav-list #mirai .header-nav-item {
	color: #fff;
	border-bottom: 1px solid #333;
	margin: auto;
	/* padding: 16px 7%; */
	position: relative;
	text-align: left;
}

#mirai .header-nav #mirai .header-nav-list #mirai .header-nav-item:last-child{
	border-bottom: 0;
}

#mirai .header-nav #mirai .header-nav-list #mirai .header-nav-item.about-company {
    padding: 0 7%;
}

#mirai .header-nav-btn {
    display: block;
    padding: 16px 7%;
}

#mirai .header-nav #mirai .header-nav-list #mirai .header-nav-item #mirai .header-nav-btn-ac {
	cursor: pointer;
	position: relative;
}

#mirai .header-nav #mirai .header-nav-list #mirai .header-nav-item #mirai .header-nav-btn-ac::before,
#mirai .header-nav #mirai .header-nav-list #mirai .header-nav-item #mirai .header-nav-btn-ac::after {
	background-color: #fff;
	bottom: 0;
	content: '';
	height: 2px;
	margin: auto;
	position: absolute;
	right: 4%;
	top: 0;
	transition: transform 0.3s ease;
	width: 18px;
}

#mirai .header-nav #mirai .header-nav-list #mirai .header-nav-item #mirai .header-nav-btn-ac::after {
	transform: rotate(90deg);
}

#mirai .header-nav #mirai .header-nav-list #mirai .header-nav-item #mirai .header-nav-btn-ac.active::before {
	opacity: 0;
}

#mirai .header-nav #mirai .header-nav-list #mirai .header-nav-item #mirai .header-nav-btn-ac.active::after {
	transform: rotate(180deg);
}

#mirai .header-nav #mirai .header-nav-list #mirai .header-nav-item #mirai .header-nav-btn-ac #mirai .header-nav-btn {
	display: inline-block;
	position: relative;
}

#mirai .header-nav #mirai .header-nav-list #mirai .header-nav-item #mirai .header-nav-btn-ac #mirai .header-nav-btn span {
	display: inline-block;
	position: relative;
}

#mirai .header-nav #mirai .header-nav-list #mirai .header-nav-item #mirai .header-nav-btn-ac #mirai .header-nav-btn span:before {
	background: #c8c8c8;
	bottom: -6px;
	content: '';
	height: 2px;
	opacity: 0.8;
	position: absolute;
	transform: translate3d(0, 0, 0) scale(0, 1);
	transform-origin: right;
	transition: transform 0.4s ease;
	width: 100%;
}

#mirai .header-nav #mirai .header-nav-list #mirai .header-nav-item #mirai .header-nav-btn-logo{
	margin: 30px 0;
}

#mirai .header-nav #mirai .header-nav-list #mirai .header-nav-item #mirai .header-nav-btn-tel{
	margin-bottom: 30px;
}

#mirai .header-nav #mirai .header-nav-list #mirai .header-nav-item #mirai .header-nav-item-company-txt{
	line-height: 1.6;
}


/* �ϥ�С�������˥塼�Υ��֥ꥹ�� */

#mirai .header-nav-sub-list {
	display: none;
	margin-bottom: 30px;
	margin-top: 10px;
	position: relative;
	z-index: 10;
}

#mirai .header-nav-sub-list.active {
	display: block;
}

#mirai .header-nav-sub-item {
	opacity: 0;
	transform: translate3d(18px, 0, 0);
	transition: opacity 0.5s ease 0.1s, transform 0.5s ease 0.1s;
}

#mirai .header-nav-btn-ac.active + #mirai .header-nav-sub-list #mirai .header-nav-sub-item {
	opacity: 1;
	transform: translate3d(0, 0, 0);
}

#mirai .header-nav-sub-item #mirai .header-nav-sub-btn {
	display: block;
	font-size: 1.3rem;
	padding: 10px 7% 10px 7%;
	position: relative;
}

#mirai .header-nav-sub-item:last-child {
	margin-bottom: 0;
	margin-right: 0;
}

@media screen and (max-width:320px){
	/* ��320px�ʲ���Ŭ�Ѥ����CSS��iphone5/SE��*/

	#mirai .header-nav-sp.fixed #mirai .header-logo #mirai .header-logo-img{
		background-size: 170px;
		width: 170px;
	}
	#mirai .header-nav-sp .wrap{
		padding-right: 60px;
	}
	#mirai .header-nav-sp .header-tel,
	#mirai .header-nav-sp .header-btn{
		height: 60px;
		width: 60px;
	}
}

@media screen and (min-width:992px) {
	/* ��992px�ʾ��Ŭ�Ѥ����CSS��PC�������ʾ�� */

	#mirai .header a{
		font-size: 1.1rem;
	}

	#mirai .header-nav-pc {
		position: fixed;
		display: flex;
		height: 70px;
		width: 100%;
	}

	/* TOP�ڡ������� */

	#mirai .header-nav-pc.animate {
		position: relative;
	}

	#mirai .header-nav-pc.fixed {
		background: #fff;
		color: #505050;
		display: block;
		position: fixed;
		top: 0;
		opacity: 1;
	}

	#mirai .header-nav-pc.fixed a,
	#mirai .header-nav-pc.fixed .header-name {
		color: #505050;
	}

	#mirai .header-nav-pc #mirai .header-nav-pc-list {
		display: flex;
		justify-content: space-between;
		padding-left: 2%;
		width: 34%;
		max-width: 480px;
	}

	#mirai .header-nav-pc #mirai .header-nav-pc-list #mirai .header-nav-pc-item {
		display: inline-block;
		vertical-align: top;
		padding: 26px 0 28px;
	}

	/* ���֥�˥塼 */

	#mirai .header-nav-pc #mirai .header-nav-pc-list #mirai .header-nav-pc-item #mirai .header-nav-pc-sub-list {
		background: #e4e4e4;
		display: none;
		left: 0;
		min-height: 70px;
		padding: 20px 0 20px 118px;
		position: fixed;
		text-align: left;
		top: 69px;
		width: 100%;
	}

	#mirai .header-nav-pc #mirai .header-nav-pc-list #mirai .header-nav-pc-item #mirai .header-nav-pc-sub-list #mirai .header-nav-pc-sub-item {
		display: inline-block;
		margin-right: 40px;
		margin-top: 8px;
		position: relative;
        vertical-align: middle;
	}

	#mirai .header-nav-pc-sub-item a {
		color: #505050;
		font-size: 1.2rem;
		line-height: 1.5;
	}

	#mirai .header-nav-pc-sub-item a::after {
		background: rgb(80, 80, 80);
	}

	/* �ۥС����˥᡼����� */

	#mirai .header-nav-pc #mirai .header-nav-pc-list #mirai .header-nav-pc-item a{
		display: inline-block;
		position: relative;
		text-decoration: none;
	}

	#mirai .header-nav-pc #mirai .header-nav-pc-list #mirai .header-nav-pc-item a:before {
		background: #fff;
		bottom: -4px;
		content: "";
		height: 1px;
		opacity: 0.8;
		position: absolute;
		transform: scale(0, 1);
		transform-origin: right;
		transition: transform 0.4s ease;
		width: 100%;
	}

	#mirai .header-nav-pc.fixed #mirai .header-nav-pc-list #mirai .header-nav-pc-item a::before,
	#mirai .header-nav-pc #mirai .header-nav-pc-list #mirai .header-nav-pc-item #mirai .header-nav-pc-sub-item a::before{
		background: rgb(80, 80, 80);
	}

	#mirai .header-nav-pc #mirai .header-nav-pc-list #mirai .header-nav-pc-item a:hover:before {
		transform-origin: left;
		transform: scale(1, 1);
	}

	/* ��� */

	#mirai .header-logo{
		left: 38%;
		position: absolute;
		top: 50%;
		transform: translateY(-50%);
		z-index: 12;
	}

	#mirai .header-nav-pc #mirai .header-logo-img{
		height: 32px;
		width: 240px;
		vertical-align: top;
	}

	.header-name{
		color: #fff;
		position: absolute;
		font-size: 1.1rem;
		right: 370px;
		top: 28px;
		letter-spacing: 0.5px;
	}

	.header-tel {
		background: none;
		height: auto;
		padding: 0;
		position: absolute;
		right: 160px;
		top: 16px;
		width: auto;
	}

	#mirai .header-nav-pc .header-tel-img{
		background: url(/common/img/tel.png) no-repeat;
		background-size: 184px;
		height: 34px;
		width: 184px;
	}

	#mirai .header-nav-pc.fixed .header-tel-img{
		background-image: url(/common/img/tel_gray.png);
	}

	.header-btn-login,
	.header-btn-regist{
		position: absolute;
		top: 0;
	}

	.header-btn-login .hover-img,
	.header-btn-regist .hover-img{
		align-items: center;
		display: flex;
		height: 70px;
		justify-content: center;
		width: 70px;
	}


	.header-btn-login {
		right: 70px;
	}

	#mirai .header-nav-pc.fixed .header-btn-login{
		background: #828282;
	}

	.header-btn-regist {
		right: 0;
	}

	#mirai .header-nav-pc.fixed .header-btn-regist{
		background: #505050;
	}
}

@media screen and (min-width:1200px) {
	/* ��1200px�ʾ��Ŭ�Ѥ����CSS��PC�������ʾ�� */

	#mirai .header-logo{
		left: 42%;
	}

}

/* �ɥ���˥塼�κݡ�������������� */
.scroll-lock {
    overflow: hidden;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
}


/*###########################################################################################*/
/* �ե�å��Ǥ���ѥ󤯤��ꥹ�� */
/*###########################################################################################*/
/* TOP�Τ��طʤ��� */
.breadcrumb-wrap{
	width: 100%;
	background: #f8f8f8;
}

.breadcrumb-list {
	background: #f8f8f8;
	font-size: 1.2rem;
	max-width: 1000px;
	margin: auto;
	overflow-x: auto;
	padding: 10px;
	position: relative;
}

.breadcrumb-list ol {
	display: table;
	list-style: none;
}

.breadcrumb-list ol li {
	display: table-cell;
	padding: 5px 1em;
	white-space: nowrap;
}

.breadcrumb-list ol li:first-child {
	padding-left: 0;
}

@media screen and (min-width:992px) {
	/* ��992px�ʾ��Ŭ�Ѥ����CSS��PC�������ʾ�� */

	.breadcrumb-list {
		background: #fff;
		padding-left: 0;
	}

	/* ���������С������� */
	.breadcrumb-list.scroll-bar::-webkit-scrollbar {
		height: 10px;
	}

	.breadcrumb-list.scroll-bar::-webkit-scrollbar-track {
		background-color: #fff;
	}

	.breadcrumb-list.scroll-bar::-webkit-scrollbar-thumb {
		background-color: rgba(238, 238, 238, 0.8);
	}
}

/*###########################################################################################*/
/* footer */
/*###########################################################################################

#mirai .footer, #footer {
	position: relative;
	text-align: left;
}

#mirai .footer-nav {
	letter-spacing: 0.06em;
}

#mirai .footer-nav #mirai .footer-nav-wrap {
	display: block;
}

#mirai .footer-nav #mirai .footer-nav-wrap #mirai .footer-nav-title {
	border-top: 1px solid #e6e6e6;
	cursor: default;
	font-size: 1.4rem;
	height: 61px;
	position: relative;
	padding: 20px 4% 0;
}

#mirai .footer-nav #mirai .footer-nav-wrap #mirai .footer-nav-title-link:before,
#mirai .footer-nav #mirai .footer-nav-wrap #mirai .footer-nav-title-link:after {
	display: none;
}

#mirai .footer-nav #mirai .footer-nav-wrap #mirai .footer-nav-list-search.slideToggle,
#mirai .footer-nav #mirai .footer-nav-wrap #mirai .footer-nav-list.slideToggle {
	background: #f8f8f8;
	display: none;
	padding: 10px 0;
}

#mirai .footer-nav #mirai .footer-nav-wrap #mirai .footer-nav-list #mirai .footer-nav-item a {
	font-size: 1.3rem;
	display: block;
	padding: 10px 4%;
}

#mirai .footer-nav #mirai .footer-nav-wrap #mirai .footer-nav-title-link a {
	display: block;
}

#mirai .footer-info-company {
	background: #f8f8f8;
}

#mirai .footer-info-company #mirai .footer-info-tel #mirai .footer-info-tel-number {
	font-family: "imperial-urw", sans-serif;
	font-size: 3.2rem;
	line-height: 1.4;
	margin-left: 5px;
}

#mirai .footer-info-company #mirai .footer-info-company-logo{
	width: 260px;
}

#mirai .footer-info-company #mirai .footer-info-tel img {
	width: 36px;
}

#mirai .footer-info-company .address {
	font-size: 1.4rem;
	line-height: 1.4;
}

#mirai .footer-copy {
    position: relative;
	text-align: center;
	padding: 10px;
	background: #00306d;
	color: #fff;
	font-size: 1rem;
}

@media screen and (min-width:992px) {*/
	/* ��992px�ʾ��Ŭ�Ѥ����CSS��PC�������ʾ�� 

	#mirai .footer,
    #mirai .footer-info-company{
		background: #fff;
	}

	#mirai .footer-nav {
		max-width: 1000px;
		margin: auto;
		display: flex;
		justify-content: space-between;
	}

	#mirai .footer-nav #mirai .footer-nav-wrap {
		display: inline-block;
		font-size: 0;
		margin-right: 0;
		vertical-align: top;
	}

	#mirai .footer-nav #mirai .footer-nav-wrap.left{
		width: 46%;
	}

	#mirai .footer-nav #mirai .footer-nav-wrap.sp{
		display: none;
	}

	#mirai .footer-nav #mirai .footer-nav-wrap #mirai .footer-nav-title {
		border: 0;
		color: #505050;
		height: auto;
		letter-spacing: 1px;
		padding: 0;
	}

	#mirai .footer-nav #mirai .footer-nav-title:before,
	#mirai .footer-nav #mirai .footer-nav-title:after {
		display: none;
	}

	#mirai .footer-nav-wrap #mirai .footer-nav-list {
		padding: 20px 0 0 0;
	}

	#mirai .footer-nav #mirai .footer-nav-wrap.pc #mirai .footer-nav-list {
		margin-top: 0;
	}

    #mirai .footer-nav #mirai .footer-nav-wrap.pc.right{
        top: -3px;
        position: relative;
    }

	#mirai .footer-nav #mirai .footer-nav-wrap #mirai .footer-nav-list-search{
		display: flex !important;
		justify-content: space-between;
	}

	#mirai .footer-nav #mirai .footer-nav-wrap #mirai .footer-nav-list-search.slideToggle,
	#mirai .footer-nav #mirai .footer-nav-wrap #mirai .footer-nav-list.slideToggle {
		background: #fff;
	}

	#mirai .footer-nav #mirai .footer-nav-wrap #mirai .footer-nav-list {
		display: inline-block;
		vertical-align: top;
	}

	#mirai .footer-nav #mirai .footer-nav-wrap #mirai .footer-nav-list.slideToggle {
		display: block !important;
		padding-top: 20px;
	}

	#mirai .footer-nav #mirai .footer-nav-wrap.right #mirai .footer-nav-list.slideToggle {
		padding-top: 0;
	}

	#mirai .footer-nav #mirai .footer-nav-wrap #mirai .footer-nav-list #mirai .footer-nav-item a {
		font-size: 1.2rem;
		display: inline-block;
		line-height: 1.6;
		margin-bottom: 13px;
		padding: 0;
		position: relative;
	}

	#mirai .footer-nav-wrap.pc #mirai .footer-nav-list #mirai .footer-nav-item a {
		font-size: 1.4rem;
	}

	#mirai .footer-nav-wrap #mirai .footer-nav-list #mirai .footer-nav-item a:before {
		content: "";
		background: #505050;
		bottom: -4px;
		height: 1px;
		opacity: 0.8;
		position: absolute;
		transform: scale(0, 1);
		transform-origin: right;
		transition: transform 0.4s ease;
		width: 100%;
	}

	#mirai .footer-nav-wrap #mirai .footer-nav-list #mirai .footer-nav-item a:hover:before {
		transform-origin: left;
		transform: scale(1, 1);
	}

	#mirai .footer-info-company #mirai .footer-info-company-logo{
		width: 320px;
	}

	#mirai .footer-info-company #mirai .footer-info-tel #mirai .footer-info-tel-number {
		font-size: 3rem;
		margin-right: 5px;
		margin-left: 0px;
	}

	#mirai .footer-info-company #mirai .footer-info-tel #mirai .footer-info-tel-text{
		display: inline-block;
		font-size: 1.4rem;
		position: relative;
		top: -4px;
	}

	#mirai .footer-info-company #mirai .footer-info-tel #mirai .footer-info-tel-text:before{
		content: '[';
		margin-right: 5px;
	}

	#mirai .footer-info-company #mirai .footer-info-tel #mirai .footer-info-tel-text:after{
		content: ']';
		margin-left: 5px;
	}
}*/

/* page top */

.pagetop {
	position: absolute;
    top: -44px;
    height: 44px;
	right: 0;
	z-index: 1;
}

@media screen and (min-width:992px) {
	/* ��992px�ʾ��Ŭ�Ѥ����CSS��PC�������ʾ�� */
    .pagetop {
        top: auto;
        bottom: 50px;
    }
}

.pagetop img {
	width: 20px;
}

.pagetop a {
	background: #00306d;
	display: block;
	padding: 15px;
}

@media screen and (min-width:992px) {
	/* ��992px�ʾ��Ŭ�Ѥ����CSS��PC�������ʾ�� */

	.pagetop img {
		width: 30px;
	}

	.pagetop a {
		padding: 20px;
	}
}


/*###########################################################################################*/
/*###########################################################################################*/

/* TOP */

/*###########################################################################################*/
/*###########################################################################################*/

/*###########################################################################################*/
/* mainvisual */
/*###########################################################################################*/
.top-wrap{
	text-align: center;
}
.section-top-mainvisual {
	display: flex;
	flex-direction: column;
	justify-content: center;
	height: 100vh;
	overflow: hidden;
	position: relative;
}

.section-top-mainvisual h1 {
	color: #fff;
	font-size: 4.4rem;
	font-weight: 300;
	line-height: 1.2;
	z-index: 1;
}

.section-top-mainvisual h1 span {
	color: #fff;
	display: block;
	font-size: 1rem;
	letter-spacing: 0.7px;
	margin-top: 15px;
}

.section-top-mainvisual .logo {
	z-index: 1;
}

.section-top-mainvisual .logo img {
	max-width: 180px;
}

.scroll {
	bottom: 2%;
	position: absolute;
	text-align: center;
	width: 100%;
}

.scroll img {
	width: 80px;
}

/* ���̤򤫤��뤿��Υ����������� */
.slick-main .slick-slide {
	/* slick�ˤ�ä�element.style���դ�����opacity��̵���� */
	opacity: 1 !important;
}

.slick-main .slideobject {
	/* �ե��������Ǥν������ */
	opacity: 0;
	transition: 0s;
}

.slick-main .slick-active .slideobject {
	/* slick-active(���̳���)�κݤΥե��������� */
	/* [����]slick¦�������Ʊ��duration���� */
	opacity: 1;
	transition: ease 5.0s;
}

.slick-main .slick-continue .slideobject {
	/* ���ե����Ȥη�³�Ѥ���Ϳ����slick-continue�Υե��������� */
	/* [����]slick¦�������Ʊ��duration���� */
	opacity: 0;
	transition: ease 5.0s;
}

.slick-main .image {
	/* ���� ���������Ǥν������ */
	transform: scale(1.4, 1.4);
	transition: 0s;
}

.slick-main .slick-active .image {
	/* ������slick-active(���̳���) */
	/* ������򤫤������Ǥˤ�ɬ���ե����ɤ��Ф����礭���transition-duration���� */
	transform: scale(1.2, 1.2);
	transition: ease 10.0s;
}
.slick-main .slick-continue .image {
	/* ������slick-continue */
	/* ������򤫤������Ǥˤ�ɬ���ե����ɤ��Ф����礭���transition-duration���� */
	transform: scale(1.0, 1.0);
	transition: ease 10.0s;
}

/* ���饤�ɼ���δ��ܥ������� */
.slick-main {
	height:100vh;
	left: 0;
	position: absolute !important;
	top: 0;
	width: 100%;
}

.slick-main .slideobject {
	/*padding-top: 50%;*/
	height: 100vh;
	overflow: hidden;
	position: relative;
	vertical-align: bottom;
	z-index: 10;
}

.slick-main .slideobject .image {
	bottom: 0;
	object-fit: cover;
	height: 100%;
	left: 0;
	position: absolute;
	right: 0;
	top: 0;
	width: 100%;
	z-index: 10;
}

@media screen and (min-width:992px) {
	/* ��992px�ʾ��Ŭ�Ѥ����CSS��PC�������ʾ�� */

	/* ���饤�����ܥ���TOP�ڡ������� */

	.top-wrap .slick-dots {
		bottom: 70px;
		height: 20px;
		left: auto;
		margin-left: auto;
		position: relative;
		right: 30px;
		text-align: right;
		width: 100%;
	}

	.top-wrap .slick-dots li {
		position: relative;
		z-index: 1;
	}

	.top-wrap .slick-dots li {
		border-bottom: 3px solid #fff;
		display: inline-block;
		height: 10px;
		margin: 0px 8px 0px 0px;
		width: 40px;
	}

	.top-wrap .slick-dots li.slick-active{
		border-color: #00306d;
	}

	.top-wrap .slick-dots li button {
		font-size: 0;
		line-height: 0;
		display: block;
		width: 10px;
		height: 10px;
		padding: 0px;
		cursor: pointer;
		color: transparent;
		border: 0;
		outline: none;
		background: transparent;
		text-indent: -9999999px;
	}

	.top-wrap .slick-dots li button:before {
		font-family: 'slick';
		font-size: 6px;
		line-height: 20px;
		position: absolute;
		top: 0;
		left: 0;
		width: 20px;
		height: 20px;
		content: '?';
		text-align: center;
		opacity: .25;
		color: black;
		-webkit-font-smoothing: antialiased;
		-moz-osx-font-smoothing: grayscale;
	}
}

/*###########################################################################################*/
/* SPECIAL(slider)  */
/*###########################################################################################*/
.section-special h2 .title-sub{
	font-size: 1.4rem;
	display: block;
	letter-spacing: 1px;
}

/* recommend menu : staff recommend�Ǥ⻲�Ȥ��Ƥޤ� */

.category-wrap{
	width: 100%;
	text-align: center;
}

.category-wrap .category {
	display: flex;
	flex: 0 0 70%;
	overflow-x: scroll;
}

.category-wrap .category li{
	color: #969696;
    font-family: imperial-urw, sans-serif;
	padding: 0 20px;
	white-space: nowrap;
}

.category-wrap .category li:hover{
	cursor: pointer;
}

.category-wrap .category li.active{
	color: #505050;
}

@media screen and (min-width:768px){
	/* ��768px�ʾ��Ŭ�Ѥ����CSS�ʥ��֥�åȥ������ʾ��*/
	.category-wrap .category {
		overflow-x: inherit;
		justify-content: center;
	}

	.category-wrap .category li{
		margin: 0 20px;
		padding: 0;
	}
}

/* recommend slider */

.section-special .recommend-overview-list{
	display: none;
}

.recommend-overview-list .message{
	text-align: center;
	margin: 40px 0;
}

.recommend-overview-list .recommend-overview-item {
	padding: 1%;
}

@media screen and (max-width:992px) {
	/* ��992px�ʾ��Ŭ�Ѥ����CSS�ʥ��֥�åȰʲ���*/

	.recommend-overview-list .recommend-overview-item {
		width: 92vw !important;
	}
    
    .section-staff-recommend .recommend-overview-list .recommend-overview-item {
		width: 100% !important;
	}
}

.recommend-overview-list .recommend-overview-item .recommend-overview-thumbnail {
	height: 250px;
	overflow: hidden;
	position: relative;
}

.recommend-overview-list .recommend-overview-item .recommend-overview-thumbnail img {
	height: 250px;
	object-fit: cover;
	transition: transform 0.3s ease-out;
	width: 100%;
}

.recommend-overview-list .recommend-overview-item .recommend-overview-info {
	text-align: left;
}

.recommend-overview-list .recommend-overview-item .recommend-overview-info .recommend-overview-info-catch-copy{
	color: #505050;
	font-size: 1.6rem;
	line-height: 1.6;
	margin: 10px 0;
}

.recommend-overview-list .recommend-overview-item .recommend-overview-info .recommend-overview-info-access,
.recommend-overview-list .recommend-overview-item .recommend-overview-info .recommend-overview-info-price{
	color: #969696;
}

.recommend-overview-list .recommend-overview-item .recommend-overview-info .recommend-overview-info-price span{
	border: 1px solid #b4b4b4;
    font: normal 300 1rem imperial-urw, sans-serif;
	padding: 2px 5px;
	margin: 0 0 0 5px;
}

@media screen and (min-width:768px){
	/* ��768px�ʾ��Ŭ�Ѥ����CSS�ʥ��֥�åȥ������ʾ��*/

	.section-special .recommend-overview-list .recommend-overview-item .recommend-overview-thumbnail,
	.section-special .recommend-overview-list .recommend-overview-item .recommend-overview-thumbnail img{
		height: 400px;
	}
}

@media screen and (min-width:992px){
	/* ��992px�ʾ��Ŭ�Ѥ����CSS��PC�������ʾ�� */

	.recommend-overview-list .recommend-overview-item {
		max-width: 667px;
		margin-right: 20px;
	}

	.recommend-overview-list .recommend-overview-item .recommend-overview-thumbnail,
	.recommend-overview-list .recommend-overview-item .recommend-overview-info{
		width: 100%;
	}

	.recommend-overview-list .recommend-overview-item .recommend-overview-thumbnail,
	.recommend-overview-list .recommend-overview-item .recommend-overview-thumbnail img{
		height: 500px;
		width: 667px;
	}

	.recommend-overview-list .recommend-overview-item .recommend-overview-thumbnail img:hover {
		object-fit: cover;
		transform: translate3d(0, 0, 0) scale(1.1, 1.1);
	}
}


/*###########################################################################################*/
/* SEARCH */
/*###########################################################################################*/

/* ʪ�︡�� */

.section-search {
	background: #969696;
	color: #fff;
}

/* ʪ������ڤ��ؤ���˥塼 */

.search-type-list {
	display: table;
	margin-bottom: 15px;
	table-layout: fixed;
	width: 100%;
}

.search-type-item {
	border: 1px solid #5a5a5a;
	display: table-cell;
	text-align: center;
	transition: 1s cubic-bezier(0.075, 0.82, 0.165, 1);
}

.search-type-item:nth-child(1),
.search-type-item:nth-child(2) {
	border-right: none;
}

.search-type-item-btn-top {
	cursor: pointer;
	font-size: 1.4rem;
	font-weight: bold;
	display: block;
	letter-spacing: 0.06em;
	overflow: inherit;
	padding: 17px 0 14px;
	position: relative;
}

.search-type-item.active {
	background: #fff;
}

.search-type-item.active .search-type-item-btn-top:before,
.search-type-item.active .search-type-item-btn-top:after {
	border: 8px solid transparent;
	border-top: 8px solid #fff;
	content: '';
	height: 0;
	left: 0;
	margin-left: auto;
	margin-right: auto;
	position: absolute;
	right: 0;
	top: 100%;
	width: 0;
}

.search-type-item.active .search-type-item-btn-top:after {
	border: 1px solid #5a5a5a;
	border-bottom: none;
	border-left: none;
	content: "";
	display: inline-block;
	height: 12px;
	top: 45px;
	transform: rotate(135deg);
	vertical-align: middle;
	width: 12px;
}

.search-type-item:hover {
	background: #fff;
}

.search-type-item.active {
	background: #fff;
}

.search-type-item .search-type-item-btn-top:hover,
.search-type-item.active .search-type-item-btn-top{
	color: #505050;
}


/* �����ܥå��� �����ȥ� */

.search-content {
	text-align: left;
}

.search-content a{
	color: #fff;
}

.search-title-item {
	float: left;
	font-size: 1.5rem;
	padding: 21px 0 6px 23px;
	position: relative;
	width: 50%;
}

.search-title-item .search-title-btn-main{
	font-size: 2rem;
	font-weight: bold;
}

.search-title-item .search-title-btn-sub{
	font-size: 1.4rem;
}

.search-title-item .search-title-btn-all {
	display: none;
}

@media screen and (min-width:992px) {
	/* ��992px�ʾ��Ŭ�Ѥ����CSS��PC�������ʾ�� */

	.search-content {
		border: 1px solid #505050;
	}

	.search-title-item:nth-child(2) {
		border-left: 1px solid #505050;
	}

	.search-title-item {
		border-bottom: 1px solid #505050;
	}

	.search-title-item .search-title-btn-all {
		bottom: 9px;
		display: inline-block;
		font-size: 1.3rem;
		font-weight: normal;
		letter-spacing: 0.06em;
		position: absolute;
		right: 24px;
	}
}

/* �������ꥢ */

.search-area-item {
	float: left;
	padding-top: 16px;
}

.search-area-item:nth-child(1) {
	margin: auto;
	min-height: 270px;
	padding-top: 22px;
	width: 100%;
}

.search-area-item .search-area-map-list {
	margin: 0 auto;
	transform-origin: left;
	transform: translate3d(0, 0, 0) scale(0.8);
	max-width: 402px;
}

.search-area-item .search-area-map-list .search-area-map-item {
	position: absolute;
	text-align: center;
}

/* ��ʿ�� */
.search-area-item .search-area-map-list .search-area-map-item.map1 {
	height: 60px;
	left: 0;
	line-height: 60px;
	top: 40px;
	width: 18%;
}

/* ������� */
.search-area-item .search-area-map-list .search-area-map-item.map2 {
	height: 70px;
	left: 20%;
	line-height: 70px;
	top: 30px;
	width: 22%;
}

/* ���϶� */
.search-area-item .search-area-map-list .search-area-map-item.map3 {
	height: 100px;
	left: 44%;
	line-height: 100px;
	top: 0;
	width: 34%;
}

/* �Ķ��� */
.search-area-item .search-area-map-list .search-area-map-item.map4 {
	height: 56px;
	left: 80%;
	line-height: 56px;
	top: 0;
	width: 34%;
}

/* ������ */
.search-area-item .search-area-map-list .search-area-map-item.map5 {
	height: 80px;
	left: 2%;
	line-height: 80px;
	top: 106px;
	width: 22%;
}

/* ��¢��� */
.search-area-item .search-area-map-list .search-area-map-item.map6 {
	height: 46px;
	left: 27%;
	line-height: 46px;
	top: 106px;
	width: 25%;
}

/* ����� */
.search-area-item .search-area-map-list .search-area-map-item.map7 {
	height: 54px;
	left: 27%;
	line-height: 54px;
	top: 158px;
	width: 25%;
}

/* ���¶� */
.search-area-item .search-area-map-list .search-area-map-item.map8 {
	height: 106px;
	left: 54%;
	line-height: 106px;
	top: 106px;
	width: 24%;
}

/* ����� */
.search-area-item .search-area-map-list .search-area-map-item.map9 {
	height: 150px;
	left: 80%;
	line-height: 150px;
	top: 62px;
	width: 20%;
}

/* ˭��� */
.search-area-item .search-area-map-list .search-area-map-item.map10 {
	height: 55px;
	left: 102%;
	line-height: 55px;
	top: 62px;
	width: 22%;
}

/* ���ɶ� */
.search-area-item .search-area-map-list .search-area-map-item.map11 {
	height: 88px;
	left: 102%;
	line-height: 88px;
	top: 124px;
	width: 22%;
}

/* ����� */
.search-area-item .search-area-map-list .search-area-map-item.map12 {
	height: 58px;
	left: 0;
	line-height: 58px;
	top: 193px;
	width: 25%;
}

/* Ĵ�ۻ� */
.search-area-item .search-area-map-list .search-area-map-item.map13 {
	height: 54px;
	left: 27%;
	line-height: 54px;
	top: 218px;
	width: 25%;
}

/* ����ë�� */
.search-area-item .search-area-map-list .search-area-map-item.map14 {
	height: 54px;
	left: 54%;
	line-height: 54px;
	top: 218px;
	width: 34%;
}

/* ��ë�� */
.search-area-item .search-area-map-list .search-area-map-item.map15 {
	height: 54px;
	left: 90%;
	line-height: 54px;
	top: 218px;
	width: 34%;
}

.search-area-item .search-area-map-list .search-area-map-item .search-area-map-box {
	border: 1px solid #505050;
	display: block;
	font-weight: bold;
	font-size: 1.4rem;
	height: 100%;
	letter-spacing: 0.06em;
	transition: background-color 0.3s ease;
	transform: translate3d(0, 0, 0) rotate(0.01deg);
	width: 100%;
}

@media screen and (min-width:768px) {
	/* ��768px�ʾ��Ŭ�Ѥ����CSS�ʥ��֥�åȥ������ʾ��*/

	.search-area-item .search-area-map-list .search-area-map-item .search-area-map-box {
		font-size: 1rem;
	}
}

.search-area-item .search-area-map-list .search-area-map-item .search-area-map-box:hover {
	background-color: #c0c0c0;
	color:#5a5a5a;
}

@media screen and (max-width:320px) {
	/* iphone 5/SE */
	.search-area-item .search-area-map-list {
		max-width: 320px;
	}
}


@media screen and (min-width:992px) {
	/* ��992px�ʾ��Ŭ�Ѥ����CSS��PC�������ʾ�� */

	.search-area-item,
	.search-area-item:nth-child(1){
		display: block !important;
		width: 50%;
	}

	.search-area-item:nth-child(1) {
		padding: 50px 55px 0 20px;
	}

	.search-area-item .search-area-map-list {
		position: relative;
		margin: 0 auto;
		max-width: 340px;
	}

	.search-area-item .search-area-map-list .search-area-map-item .search-area-map-box {
		font-size: 1.4rem;
	}

}

/* ������ */

.search-area-line-item {
	margin-bottom: 27px;
}

.search-area-item:nth-child(2) {
	display: none;
	padding: 30px 0 0 24px;
}

@media screen and (min-width:992px) {
	/* ��992px�ʾ��Ŭ�Ѥ����CSS��PC�������ʾ�� */

	.search-area-line-list {
		display: inline-block;
		vertical-align: top;
	}

	.search-area-line-list:nth-child(2) {
		padding-left: 88px;
	}

	.search-area-item:nth-child(2) {
		border-left: 1px solid #505050;
		display: block !important;
	}
}

/* �������ض衦������꤫��õ���ܥ��� */

.search-type-list-other{
	display: flex;
	text-align: center;
}

.search-type-list-other .search-type-item{
	border: 1px solid #505050;
	padding: 16px 0;
	transition: background-color 0.3s ease;
	transform: translate3d(0, 0, 0) rotate(0.01deg);
	width: 100%;
}

.search-type-list-other .search-type-item:hover{
	background: #fff;
}

.search-type-list-other .search-type-item:hover a{
	color: #505050;
}

.search-type-list-other .search-type-item a{
	color: #fff;
	display: block;
	position: relative;
}

.search-type-list-other .search-type-item a:before {
	background: url(/common/img/btn_arrow.png) no-repeat;
	background-size: 100% 100%;
	content: "";
	height: 11px;
	margin-top: -5px;
	position: absolute;
	right: 8px;
	top: 50%;
	width: 7px;
}

@media screen and (max-width:320px) {
	/* ��320px�ʲ���Ŭ�Ѥ����CSS��iphne5/SE��*/

	.search-type-list-other .search-type-item{
		font-size: 1.2rem;
	}
}

@media screen and (min-width:992px) {
	/* ��992px�ʾ��Ŭ�Ѥ����CSS��PC�������ʾ�� */

	.search-type-list-other .search-type-item {
        display: block;
		border-top: 0;
		/*width: 501px;*/
	}
}


/*###########################################################################################*/
/* SERVICE */
/*###########################################################################################*/
.section-service .scroll-wrap{
	display: flex;
	margin: 0 auto;
	overflow-x: scroll;
	overflow-scrolling: touch;
}

.section-service .service-menu{
	flex: 0 0 95%;
	height: auto;
	margin-right: 2%;
}

.service-menu .service-menu-item.service-menu-title{
	background: #f8f8f8;
	min-height: 220px;
	padding: 5%;
}

.service-menu-title{
	text-align: left;
}

.service-menu-title-en,
.service-menu-title-more{
	font: normal 300 1.3rem imperial-urw, sans-serif;
}

.service-menu-title-jp{
	font-size: 1.8rem;
	line-height: 1.6;
}

@media screen and (max-width:991px) {
    .service-menu-thumbnail img {
        width: 100%;
        min-height: 56vw;
    }
}

@media screen and (min-width:992px) {
	/* ��992px�ʾ��Ŭ�Ѥ����CSS��PC�������ʾ�� */

	.section-service .inner{
		max-width: 1340px;
	}

	.section-service .scroll-wrap{
		display: block;
		overflow-x: hidden;
	}

	.section-service .service-menu{
		height: auto;
		margin: 0;
	}

	.service-menu .service-menu-item{
		height: 430px;
		padding: 0;
		position: relative;
		width: 50%;
	}

	.section-service .service-menu:nth-of-type(1) .service-menu-title,
	.section-service .service-menu:nth-of-type(2) .service-menu-image,
	.section-service .service-menu:nth-of-type(3) .service-menu-title,
	.section-service .service-menu:nth-of-type(4) .service-menu-image{
		float: right;
	}

	.section-service .service-menu:nth-of-type(1) .service-menu-image,
	.section-service .service-menu:nth-of-type(2) .service-menu-title,
	.section-service .service-menu:nth-of-type(3) .service-menu-image,
	.section-service .service-menu:nth-of-type(4) .service-menu-title{
		float: left;
	}

	.service-menu-title-jp{
		font-size: 2.7rem;
	}

	.service-menu .service-menu-item.service-menu-title .service-menu-title-inner{
		left: 50%;
		position: absolute;
		top: 50%;
		transform: translateY(-50%) translateX(-50%);
		width: 80%;
	}

	.service-menu .service-menu-item:nth-child(1).service-menu-image{
		text-align: right;
	}

	.service-menu .service-menu-item:nth-child(2).service-menu-image{
		text-align: left;
	}

	.service-menu .service-menu-image .service-menu-thumbnail {
		height: 430px;
		overflow: hidden;
		position: relative;
	}

	.service-menu .service-menu-image .service-menu-thumbnail .mask{
		align-items: center;
		background-color: rgba(0,0,0,0.4);
		display: flex;
		justify-content: center;
		height: 100%;
		left: 0;
		opacity: 0;
		position: absolute;
		top: 0;
		transition: all 0.2s ease;
		width: 100%;
	}

	.service-menu .service-menu-image .service-menu-thumbnail:hover .mask {
		opacity: 1;
	}

	.service-menu .service-menu-image .service-menu-thumbnail .caption {
		color: #fff;
		font-family: imperial-urw, sans-serif;
		font-size: 1.4rem;
		text-align: center;
	}

	.service-menu .service-menu-image .service-menu-thumbnail img {
		height: 430px;
		transition: transform 0.3s ease-out;
		transform: translate3d(0, 0, 0) scale(1, 1);
		/*width: 670px;*/
	}

	.service-menu .service-menu-image:hover .service-menu-thumbnail img {
		opacity: 0.8;
		transform: translate3d(0, 0, 0) scale(1.1, 1.1);
	}

}

/*###########################################################################################*/
/* MOVIE */
/*###########################################################################################*/
.section-movie {
	background: #f8f8f8;
}

.movie-wrap {
     position: relative;
     padding-bottom: 56.25%; /*�����ڥ����� 16:9�ξ��ν���*/
     height: 0;
     overflow: hidden;
}
 
.movie-wrap iframe {
     position: absolute;
     top: 0;
     left: 0;
     width: 100%;
     height: 100%;
}


/*###########################################################################################*/
/* GUIDE */
/*###########################################################################################*/
@media screen and (min-width:992px) {
	/* ��992px�ʾ��Ŭ�Ѥ����CSS��PC�������ʾ�� */

	.section-guide {
		margin-bottom: 80px;
	}
}

/*###########################################################################################*/
/* STAFF RECOMMEND */
/*###########################################################################################*/
.section-staff-recommend .recommend-overview-slider{
	display: flex;
	flex-wrap: wrap;
	margin: 0 2%;
}

.section-staff-recommend .recommend-overview-list{
	display: none;
	max-width: 1000px;
	margin: 0 auto;
}

.section-staff-recommend .recommend-overview-list .recommend-overview-item:last-child{
	margin-bottom: 0;
}

.section-staff-recommend .recommend-overview-list .recommend-overview-item {
	max-width: 100%;
	margin-bottom: 40px;
}

@media screen and (min-width:768px){
	/* ��768px�ʾ��Ŭ�Ѥ����CSS�ʥ��֥�åȥ������ʾ��*/

	.section-staff-recommend .recommend-overview-list .recommend-overview-item {
		width: 49.5%;
		margin-right: 1%;
		margin-bottom: 40px;
	}

	.section-staff-recommend .recommend-overview-list .recommend-overview-item:nth-child(2n){
		margin-right: 0;
	}

	.section-staff-recommend .recommend-overview-list .recommend-overview-item:nth-child(3n){
		margin-bottom: 0;
	}
}

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

	.section-staff-recommend .recommend-overview-slider{
		margin: 0;
	}

	.section-staff-recommend .recommend-overview-item{
		width: 480px;
		margin-bottom: 60px;
	}

	.section-staff-recommend .recommend-overview-list .recommend-overview-item .recommend-overview-thumbnail,
	.section-staff-recommend .recommend-overview-list .recommend-overview-item .recommend-overview-thumbnail img{
		width: 480px;
		height: 360px;
	}

}

/*###########################################################################################*/
/* MOVIE */
/*###########################################################################################*/
.section-guide .inner{
	padding-bottom: 0;
}

.section-guide p{
	text-align: left;
}

@media screen and (min-width:992px) {
	/* ��992px�ʾ��Ŭ�Ѥ����CSS��PC�������ʾ�� */

	.section-guide p{
		text-align: center;
	}

	.section-guide .sp{
		display: none;
	}

}

/*###########################################################################################*/
/*###########################################################################################*/

/* list_bukken */

/*###########################################################################################*/
/*###########################################################################################*/
.list-bukken .inner{
	padding-top: 0;
	text-align: center;
}

/* fatty/parts/bukken_list.php���� */

.overview-list-inner{
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}

.overview-list .overview-item {
	max-width: 100%;
    text-align: center;
}

.overview-list .overview-item:last-child{
	margin-bottom: 0;
}

.overview-list .overview-item .overview-thumbnail {
	height: 250px;
	overflow: hidden;
	position: relative;
}

@media screen and (max-width:320px) {
    .overview-list .overview-item .overview-thumbnail {
        height: 220px;
    }
}

.overview-list .overview-item .overview-thumbnail img {
	object-fit: cover;
	transition: transform 0.3s ease-out;
	width: 100%;
}

.overview-list .overview-item .overview-info .overview-info-txt{
	margin-bottom: 1rem;
}

/* �������ʪ�� */

.overview-list .overview-item.member .overview-info{
	display: flex;
	flex-wrap: wrap;
	position: absolute;
	top: 38%;
}

.overview-list .overview-item.member .overview-info [class*="overview-info-txt"]{
	width: 100%;
	font-size: 1.4rem;
}

.overview-list .overview-item.member .overview-info [class*="overview-info-txt"] {
	font-size: 1.6rem;
}

.overview-list .overview-item.member .overview-info .overview-info-txt-num{
	color: #00306d;
	font-size: 2rem;
}

.overview-list .overview-item.member .overview-item-catch{
	color: #fff;
	background: #00306d;
	padding: 20px;
	height: 60px;
}

/* ����ʪ�� */

.overview-list .overview-item.public .overview-info{
	text-align: left;
}

.overview-list .overview-item.public .overview-info .overview-info-access,
.overview-list .overview-item.public .overview-info .overview-info-price {
	color: #969696;
}

.overview-list .overview-item.public .overview-info .overview-info-price span {
	border: 1px solid #b4b4b4;
	font-size: 1rem;
	margin: 0 0 0 5px;
	padding: 2px 5px;
}

/* �ܥ��� */

@media screen and (min-width:768px) and (max-width: 991px) {
	/* ���֥�åȥ������Τ�*/

	.overview-list .overview-item {
		width: 48%;
		position: relative;
		padding: 0 0 5rem;
	}

	.overview-list .overview-item .overview-info-price{
		padding-bottom: 15px;
	}
    
    .overview-list .overview-item.member .overview-info {
        display: flex;
        flex-wrap: wrap;
        position: absolute;
        top: 50%;
        transform: translate(0, -50%);
    }

	.overview-list .overview-item .col-list .list-item-wrap {
		position: absolute;
		bottom: 10px;
		width: 100%;
	}

    .overview-list .overview-item .overview-info .overview-info-txt:last-child {
        margin-bottom: 0;
    }
}

@media screen and (min-width:768px){
    .overview-list .overview-item.member .overview-info [class*="overview-info-txt"] {
        font-size: 1.1rem;
    }
    .overview-list .overview-item.member .overview-item-catch {
        font-size: 1.2rem;
    }

}

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

	.overview-list-inner{
		margin: 0;
	}

	.overview-list .overview-item {
		width: 480px;
		position: relative;
		padding: 0 0 5rem;
	}

	.overview-list .overview-item .col-list .list-item-wrap {
		position: absolute;
		bottom: 10px;
		width: 100%;
	}

	.overview-list .overview-item .overview-thumbnail,
	.overview-list .overview-item .overview-info{
		width: 100%;
	}

	.overview-list .overview-item.member .overview-info [class*="overview-info-txt"] {
		font-size: 1.6rem;
	}

	/* �������ʪ�� */

	.overview-list .overview-item.member .overview-item-catch{
		width: 480px;
	}

	.overview-list .overview-item .overview-thumbnail,
	.overview-list .overview-item .overview-thumbnail img{
		height: 360px;
		width: 480px;
	}

	.overview-list .overview-item.public .overview-thumbnail .is-hover:hover {
		object-fit: cover;
		transform: translate3d(0, 0, 0) scale(1.1, 1.1);
	}
}

/*###########################################################################################*/
/* detail_bukken */
/*###########################################################################################*/
.detail-bukken-wrap{
	text-align: left;
}

.section-bukken-thanks p{
	line-height: 1.6;
}

/* mainvisual */

.section-bukken-mainvisual{
	display: flex;
	flex-wrap: wrap;
}

.section-bukken-mainvisual .inner{
	padding: 0 2%;
}

.section-bukken-mainvisual .headline-wrap{
	order: 2;
}

.section-bukken-mainvisual .mainvisual-img{
	height: 50vh;
	order: 1;
	width: 100vw;
    vertical-align: top;
}

.section-bukken-mainvisual .caption{
	font-family: "�⥴���å���", YuGothic, "�⥴���å� Medium", "Yu Gothic Medium", "�⥴���å�", "Yu Gothic", sans-serif;
	font-size: 1.8rem;
	line-height: 1.6;
	margin-bottom: 10px;
	padding-top: 50px;
}

.bukken-overview,
.merit-icon{
	display: flex;
	flex-wrap: wrap;
	position: relative;
}

.bukken-overview{
	margin-bottom: 20px;
}

.bukken-overview .bukken-overview-item::after{
	content: '��';
}

.bukken-overview .bukken-overview-item:last-child::after{
	display: none;
}

.merit-icon .merit-icon-item{
	border: 1px solid #b4b4b4;
	font-size: 1.1rem;
	line-height: 2;
	margin: 0 5px 5px 0;
	padding: 0 5px;
}

.merit-icon .merit-icon-item.type{
	font: 1.1rem imperial-urw, sans-serif;
	line-height: 2;
}

/* CV���ꥢ */

.section-bukken-first-cv-area .inner{
	padding-top: 0;
}

.bukken-cv-area .catch-copy{
	font-size: 2.1rem;
	margin-bottom: 10px;
}

@media screen and (min-width:992px) {
	/* ��992px�ʾ��Ŭ�Ѥ����CSS��PC�������ʾ�� */

	/* mainvisual */

	.section-bukken-mainvisual{
		display: block;
	}

	.section-bukken-mainvisual .mainvisual-img {
		height: 500px
	}

	.section-bukken-mainvisual .inner{
		height: 210px;
		padding: 0;
	}

	.section-bukken-mainvisual .merit-icon{
		margin-bottom: 50px;
	}

	/* CV���ꥢ */

	.bukken-cv-area{
		display: flex;
		justify-content: space-between;
	}

	.bukken-cv-area .bukken-cv-area-item{
		width: 48%;
	}

	.bukken-cv-area .bukken-cv-area-item .btn {
		position: relative;
		width: 100%;
	}

	.bukken-cv-area .bukken-cv-area-item .btn:before {
		background: url(/common/img/btn_arrow.png) no-repeat;
		background-size: 100% 100%;
		content: "";
		height: 11px;
		margin-top: -5px;
		position: absolute;
		right: 11px;
		top: 50%;
		width: 7px;
	}
}

/* slick��SP�ξ��Τ�ȯ��(jsʻ��) */

.section-pickup .slick-list{
	height: 250px;
}


.section-pickup .slick-dots{
	display: block;
	margin-top: 1.5rem;
	position: absolute;
	width: 100%;
}

@media screen and (max-width:991px) {
    .slick-slider {
        text-align: center;
    }
    
    .section-pickup .slick-dots{
        display: inline-block;
        position: relative;
    	width: auto;
        text-align: left;
    }
}

.section-pickup .slick-dots li {
position: relative;
display: inline-block;
width: 20px;
height: 20px;
margin: 0 5px;
padding: 0;
cursor: pointer;
}

.section-pickup .slick-dots li button,
.section-pickup .slick-dots li button:before{
width: 20px;
height: 20px;
outline: none;
}

.section-pickup .slick-dots li button
{
line-height: 0;
display: block;
padding: 5px;
color: transparent;
background: transparent;
}

.section-pickup .slick-dots li button:before
{
font-family: 'slick';
line-height: 20px;
position: absolute;
top: 0;
left: 0;
content: '��';
opacity: .25;
color: black;
}

.section-pickup .slick-dots li.slick-active button:before
{
opacity: 1;
color: #00306d;
}

.section-pickup .slick-list .overview-thumbnail img{
height: 250px;
object-fit: contain;
}

@media screen and (min-width:992px) {
/* ��992px�ʾ��Ŭ�Ѥ����CSS��PC�������ʾ�� */

	.section-pickup .overview-list .overview-item .overview-thumbnail img {
		max-width: inherit;
		height: inherit;
	}
}


/* section-staff-report */

.section-staff-report .staff-report-item:first-child{
	text-align: center;
}

@media screen and (min-width:992px) {
	/* ��992px�ʾ��Ŭ�Ѥ����CSS��PC�������ʾ�� */

	.section-staff-report .staff-report-inner{
		display: flex;
		justify-content: space-between;
	}

	.section-staff-report .staff-report-item{
		width: 78%;
	}

	.section-staff-report .staff-report-item:first-child{
		text-align: left;
		width: 22%;
	}

	.section-staff-report .staff-report-item .thumbnail{
		max-width: 180px;
	}
}

/* section-bukken-spec */

.section-bukken-spec .caption-wrap{
	display: flex;
}

.section-bukken-spec .caption-wrap .caption{
	width: 20%;
}

.section-bukken-spec .caption-wrap .upddate{
	width: 80%;
	text-align: right;
	font-size: 1.2rem;
	line-height: 1.4;
}

.section-bukken-spec .table1{
	border: 0;
	width: 100%;
}
.section-bukken-spec .table1 tr{
	padding: 20px 0;
}
.section-bukken-spec .table1 th{
	font-weight: bold;
	padding: 10px 0;
	width: 32%;
}

.table1 noline td{
	padding: 10px 0;
}

@media screen and (min-width:992px) {
	/* ��992px�ʾ��Ŭ�Ѥ����CSS��PC�������ʾ�� */

	.section-bukken-spec .table1{
		width: 48%;
	}
}

/* simulation-wrap */

.simulation-wrap .simulation-item:nth-child(2n){
	height: 65px;
	margin: 10px 0;
}

.simulation-wrap .simulation-item .input-wrap{
	border: 1px #b4b4b4 solid;
}

.simulation-wrap .simulation-item .title{
	background: #e8e8e8;
	font-weight: bold;
	padding: 20px 0;
	text-align: center;
	border-bottom: 1px #b4b4b4 solid;
}

.simulation-wrap .simulation-item .input-inner{
	padding: 2rem;
}

.simulation-wrap .simulation-item .input-item{
	display: flex;
	align-items: center;
	margin: 10px 0;
    line-height: 1;
}

.simulation-wrap .simulation-item .input-item-text{
	width: 38%;
}

.simulation-wrap .simulation-item .input-box-gray{
	border: 0;
	padding: 8px 10px;
	background: #e8e8e8;
	width: 30%;
	font-weight: bold;
	text-align: center;
	margin-right: 10px;
}

.simulation-wrap .simulation-item .btn{
	width: 100%;
	height: 100%;
}

.simulation-wrap .simulation-item .calc-result{
	border: 0;
	font-size: 3rem;
	background: none;
	text-align: center;
	margin: 32px 0;
}

.simulation-wrap .simulation-item .calc-yen{
    margin-left: 0.4em;
    margin-top: 0.5em;
}

.simulation-wrap .simulation-item .comment{
	margin-top: 10px;
	text-align: left;
	font-size: 1.1rem;
}

/* ��� */

.simulation-wrap .simulation-item.result .input-item{
	justify-content: center;
}


@media screen and (min-width:992px) {
	/* ��992px�ʾ��Ŭ�Ѥ����CSS��PC�������ʾ�� */

	.simulation-wrap{
		display: flex;
		justify-content: space-between;
	}

	.simulation-wrap .simulation-item{
		width: 40%;
		display: inline-grid;
	}

	.simulation-wrap .simulation-item:nth-child(2n){
		width: 16%;
		height: auto;
		margin: 0;
	}
}

/* section-other-recomend */

.section-other-recomend .overview-list{
	text-align: center;
}

/* contact */

/*
.detail-bukken-wrap .table1 tr td.address-td2{
	border-top: none;
}
*/

.detail-bukken-wrap .section-contact .btn-wrap{
	margin-bottom: 0;
}

.detail-bukken-wrap .section-contact .text-wrap{
	background: #f8f8f8;
	margin: 5% 0 0;
	padding: 4%;
}

.detail-bukken-wrap .section-contact h2{
	text-align: center;
}

/* section-bukken-thanks */

.section-bukken-thanks{
	text-align: center;
}


/*###########################################################################################*/
/* fatty/parts/merit.php */
/*###########################################################################################*/
.section-merit .sub-caption{
	background: #e8e8e8;
	border: 1px solid #b4b4b4;
	text-align: center;
}

.section-merit .merit-list{
	display: flex;
	justify-content: space-between;
}

.section-merit .merit-list .merit-list-item{
	width: 48%;
}

.section-merit .example{
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: center;
}

.section-merit .example .no-wrap,
.section-merit .example .text{
	margin-bottom: 10px;
}

.section-merit .example .no-wrap{
	background: #505050;
	color: #Fff;
	font-size: 1.1rem;
	padding: 0px 10px 1px;
	width: 12%;
}

.section-merit .example .number{
	font-size: 1.4rem;
}

.section-merit .example .text{
	width: 86%;
	font-weight: bold;
}

.regist-button{
	background-color: #00306d;
}

/*###########################################################################################*/
/* company.php */
/*###########################################################################################*/

/* section-company-mainvisual */

.section-company-mainvisual .inner{
	padding: 90px 0;
}

.section-company-mainvisual h1{
	margin: 0;
	text-align: center;
}

.section-company-mainvisual .mainvisual-img {
	height: 140px;
	width: 100%;
}

/* section-sprit */

.section-company-sprit{
	text-align: center;
}

.section-company-sprit .lead{
	line-height: 2.5;
}

.section-company-profile h2{
	text-align: left;
}

@media screen and (min-width:992px) {
	/* ��992px�ʾ��Ŭ�Ѥ����CSS��PC�������ʾ�� */

	.section-company-mainvisual .mainvisual-img {
		height: 500px;
		width: 100%;
	}

	.section-company-sprit .lead{
		line-height: 2.5;
	}

}

/* section-access-map */

.section-access-map .text{
	line-height: 2;
	font-size: 1.4rem;
	letter-spacing: 0.08rem;
	margin: 2.2rem 0;
}

/* group */

.section-group-company .groupbg .inner{
	padding-bottocm: 0;
}

.section-group-company .groupbg .group-catch {
	font-size: 2rem;
	font-weight: bold;
	letter-spacing: 0.48rem;
}

.section-group-company .groupbg .group-message {
	font-size: 1.4rem;
	letter-spacing: 0.08rem;
}

.section-group-company .company-list-wrap.inner{
	padding-top: 10%;
}

.section-group-company .table1{
	margin-bottom: 20px;
}

.section-group-company .table1.noline tr th{
	padding: 0;
	vertical-align: top;
}

.section-group-company .table1 tr th,
.section-group-company .table1 tr td{
	display: table-cell;
	font-size: 1.1rem;
	line-height: 1.5;
}

.section-group-company .table1 tr th{
	width: 28%;
}

.section-group-company .table1 tr td{
	width: 68%;
}

.section-group-company .company-item{
	margin-bottom: 20px;
}

.section-group-company tr:last-child .company-item{
	margin-bottom: 0;
}

@media screen and (min-width:992px) {
	/* ��992px�ʾ��Ŭ�Ѥ����CSS��PC�������ʾ�� */

	.section-group-company .groupbg {
		background: url(/common/img/company/map.png) top right no-repeat;
		background-size: 50%;
		padding-bottom: 30px;
		position: relative;
		width: 100%;
		min-height: 720px;
	}
	.section-group-company .groupbg .group-catch {
		font-size: 2rem;
		font-weight: bold;
		letter-spacing: 4.8px;
		margin-left: -10px;
	}

	.section-group-company .groupbg .group-message {
		width: 560px;
	}

	.section-group-company .table1 tr th,
	.section-group-company .table1 tr td{
		font-size: 1.4rem;
	}

	.section-group-company .table1 tr th{
		width: 30%;
	}

	.section-group-company .table1 tr td{
		width: 70%;
	}
}

/* section-not-found-bukken */

.section-not-found-bukken .text{
	line-height: 1.4;
}

/*###########################################################################################*/
/* _list_staff.php */
/*###########################################################################################*/
.staff-list-wrap .inner{
	padding-top: 0;
}

.staff-list-wrap .staff-list{
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}

.staff-list-wrap .staff-list .staff-list-item{
	width: 48%;
}

.staff-list-wrap .staff-list-item .staff-thumbnail {
	overflow:hidden;
	position: relative;
}

.staff-list-wrap .staff-list-item .staff-thumbnail img {
	min-height: 120px;
	max-height: 210px;
	width: 100%;
}

.staff-list-wrap .name-wrap .name-jp{
	display: block;
	font-size: 2rem;
	margin: 0 0 5px 0;
}

.staff-list-wrap .name-wrap .name-eng{
	font-family: imperial-urw, sans-serif;
	letter-spacing: 0.5px;
}

.staff-list-wrap .staff-list-item .title{
	line-height: 1.6;
}

@media screen and (min-width:992px) {
	/* ��992px�ʾ��Ŭ�Ѥ����CSS��PC�������ʾ�� */

	.staff-list-wrap .staff-list .staff-list-item{
		width: 32%;
	}

	.staff-list-wrap .staff-list-item .staff-thumbnail img {
		height: 210px;
		transition: transform 0.3s ease-out, -webkit-transform 0.3s ease-out;
		transform: translate3d(0, 0, 0) scale(1, 1);
	}

	.staff-list-wrap .staff-list-item .staff-thumbnail:hover img {
		transform: translate3d(0, 0, 0) scale(1.1, 1.1);
	}

	.staff-list-wrap .staff-list-item .name-jp{
		display: inline-block;
		font-size: 2.4rem;
		margin-right: 10px;
	}
}

/*###########################################################################################*/
/* _detail_staff.php */
/*###########################################################################################*/

.staff-detail-wrap .page-navi{
	display: flex;
	justify-content: space-between;
}

.staff-detail-wrap .staff-thumbnail{
	text-align: center;
}

.staff-detail-wrap .staff-thumbnail img{
	width: 540px;
}

.staff-detail-wrap .name-wrap{
	text-align: center;
}

.staff-detail-wrap .name-wrap .name-jp{
	display: block;
	font-size: 2.8rem;
}

.staff-detail-wrap .name-wrap .name-eng{
	font-family: imperial-urw, sans-serif;
	letter-spacing: 0.5px;
}

.staff-detail-wrap .table1 tr th {
	width: 20%;
	vertical-align: top;
}

.staff-detail-wrap .multi-btn{
	width: 100%;
}

.staff-detail-wrap .message-title {
	margin: 4rem 0 2rem;
}

.staff-detail-wrap .tt-comment a {
    color: #00306d !important;
}


/*###########################################################################################*/
/* REGISTER */
/*###########################################################################################*/
#form-anc {
    padding-top: 70px;
    margin-top: -70px;
}

.section-register-mainvisual {
    position: relative;
}

@media screen and (max-width:991px) {
    .section-register-mainvisual {
        margin: 0-4.5%;
    }
}

.section-register-mainvisual .before-num, 
.section-register-mainvisual .after-num, 
.section-register-mainvisual .raiten-num {
    position: absolute;

    color: #fff;
    font-size: 3.2vw;
    text-align: center;
}

.section-register-mainvisual .large-text {
    font-size: 1.5em;
    font-weight: bold;
    line-height: 1;
}

.section-register-mainvisual .after-num, 
.section-register-mainvisual .raiten-num {
    top: 33.8vw;
    font-size: 3.6vw;
    width: 24vw;
}

.section-register-mainvisual .before-num {
    top: 33.5vw;
    left: 7.2vw;
    width: 20vw;
}

.section-register-mainvisual .after-num {
    left: 36vw;
}

.section-register-mainvisual .raiten-num {
    left: 69vw;
}

@media screen and (min-width:992px) {
    .section-register-mainvisual {
        position: relative;
    }

    @media screen and (max-width:991px) {
        .section-register-mainvisual {
            margin: 0-4.5%;
        }
    }

    .section-register-mainvisual .before-num, 
    .section-register-mainvisual .after-num, 
    .section-register-mainvisual .raiten-num {
        position: absolute;

        color: #fff;
        font-size: 1.8rem;
        text-align: center;
    }

    .large-text {
        font-size: 1.5em;
        font-weight: bold;
        line-height: 1;
    }

    .section-register-mainvisual .after-num, 
    .section-register-mainvisual .raiten-num {
        top: 28.5rem;
        font-size: 2.2rem;
        width: 16.5rem;
    }

    .section-register-mainvisual .before-num {
        top: 28.3rem;
        left: 21rem;
        width: 13.6rem;
    }

    .section-register-mainvisual .after-num {
        left: 40.5rem;
    }

    .section-register-mainvisual .raiten-num {
        left: 63rem;
    }
}

.reg-area-list .list-item {
    position: relative;
    border-right: 1px solid #ddd;
    border-bottom: 1px solid #ddd;
}

@media screen and (max-width:768px){
    .src-area-wrap select {
        width: 100%;
    }

    .reg-area-list .list-item:nth-child(3n) {
        border-right: none;
    }
}

@media screen and (min-width:992px){
    .reg-area-list .list-item:nth-child(5n) {
        border-right: none;
    }
}

.reg-area-list .list-item label {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 50px;
}

.reg-area-list .list-item input[type="checkbox"] {
    display: none;
}

.reg-area-list .list-item input[type="checkbox"]:checked + label {
    background: #969696;
    color: #FFF;
} 

.reg-area-list .list-item.chk:before {
    content: '';
    display: block;
    position: absolute;
    top: 0px;
    right: 7px;
    width: 9px;
    height: 14px;
    border-right: 3.5px solid #fff;
    border-bottom: 3.5px solid #fff;
    -webkit-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
    transform: rotate(45deg);
}

.chk-wrap .src-area-wrap {
    border-bottom: 1px solid #b4b4b4;
}

.check_all, [id^="src_ad_sub_box"] label, [id^="src_st_sub_box"] label {
    display: block;
    padding: 10px;
    border-top: 1px solid #b4b4b4;
    border-bottom: 1px solid #b4b4b4;
}

.src_box_area {
    margin-bottom: -1px;
}

@media screen and (min-width:992px){
    #src_st_box3 {
        margin-bottom: -2px;
    }
}

.src-list {
    position: relative;
}

.src-area-wrap {
    padding: 10px;
    border-top: 1px solid #b4b4b4;
}

#src_way_box {
    padding: 10px;
}

.src-middle-area {
    padding: 10px;
}

.reg-area-list .list-item-wrap {
    position: relative;
}

@media screen and (max-width:991px) {
    #ADDR2, #ADDR3 {
        top: -1px;
    }   
}

.thk-msg1 {
    font-size: 1.4rem;
}

.thk-msg2 {
    padding: 2rem;
    margin-top: 2rem;
    background: #eee;
}

.msg-over {
    background: #f8f8f8;
    padding: 2rem 1.5rem;
}

/* Ʊ��ʪ���䤤��碌 */
.reg-contact-price span {
    border: 1px solid #b4b4b4;
    font-size: 1rem;
    margin: 0 0 0 5px;
    padding: 2px 5px;
}

.reg-contact-info-wrap {
    display: flex;
}

.reg-contact-check {
    width: 8%;
}

.reg-contact-info {
    width: 92%;
}

.all-no-check {
    width: auto;
    height: auto;
    padding: 1.5rem 3rem;
    font-size: 0.9em;
}

.hideShowPassword-toggle {
    background: #666;
    color: #FFF;
    border: none;
    cursor: pointer;
    font-size: 12px;
    right: 2% !important;
    border-radius: 2px;
    padding: 3px 4px;
    width: 3em;
}

.hideShowPassword-wrapper {
    position: static !important;
    width: 100% !important;
}

@media screen and (min-width:768px) and (max-width: 991px) {
	/* ���֥�åȥ������Τ�*/
    
    .reg-contact-list-inner {
        display: flex;
        flex-wrap: wrap;
        justify-content: space-between;
    }
    
    .reg-contact-list .reg-contact-item {
        width: 48%;
    }
    
    .reg-contact-check input[type="checkbox"] {
        vertical-align: top;
    }
    
}

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

    .reg-contact-list-inner {
        display: flex;
        flex-wrap: wrap;
        margin-left: -15px;
    }
    
    .reg-contact-list .reg-contact-item {
        width: 25%;
        padding-left: 15px;
        margin-left: 0%;
    }

    .reg-contact-thumbnail img {
        height: 160px;
        width: 100%;
    }

    .reg-contact-check {
        width: 10%;
    }

    .reg-contact-info {
        width: 90%;
    }

}

/*###########################################################################################*/
/* recruit */
/*###########################################################################################*/
.section-recruit-mainvisual .mainvisual-img{
	height: 140px;
	width: 100%;
}

.section-recruit-mission .message{
	text-align: left;
}

.section-recruit-about{
	background: #969696;
	color: #fff;
}

@media screen and (max-width:991px) {
	/* ��991px�ʲ���Ŭ�Ѥ����CSS��SP��TB�� */

	.section-recruit-about .table2 th,
	.section-recruit-form .table2 th{
		padding-bottom: 0.5rem;
		width: 100%;
	}
}

@media screen and (min-width:992px){
	/* ��992px�ʾ��Ŭ�Ѥ����CSS��PC�������ʾ�� */

	.section-recruit-mission .message{
		text-align: center;
	}

	.section-recruit-mainvisual .mainvisual-img{
		height: 500px;
	}

	.section-recruit-mission .list-item .image{
		width: 480px;
		height: 80px;
	}

	.section-recruit-about .table2{
		width: 700px;
		margin: 0 auto;
	}
}

/*###########################################################################################*/
/* service */
/*###########################################################################################*/

.title-service .title-large-sub {
    font-size: 1.1rem;
}

.title-service .title-large {
    font-size: 1.6rem;
    font-weight: normal;
    line-height: 1.4;
}

.title-blue {
    font-size: 1.3rem;
    font-weight: bold;
    color: #00306d;
}

/*  service1.html  */

.service1-lead {
    font-size: 1.6rem;
}

.service1-title-blue {
    font-size: 1.3rem;
    font-weight: bold;
    color: #00306d;
}

.service1-lead-large {
    font-size: 2rem;
}

.service1-title-bg-blue {
    padding: 1.2rem 0;
    background: #e5eaf0;
    text-align: center;
    font-size: 1.3rem;
    font-weight: bold;
}

.service1-asterisk {
    font-size: 1.1rem;
}

.service1-reason3-explanation {
    font-size: 1.2rem;
    font-weight: bold;
}

.service-either-example {
    font-size: 1.2rem;
}

.scroll-wrap {
    overflow: auto;
    width: 100%;
    overflow-scrolling: touch;
}

.service-table {
    width: 600px;
    text-align:  center;
}

@media screen and (min-width:600px) and (max-width:991px) {
    .service-table {
        width: 100%;
    }
}

.service-table th, .service-table td {
    padding: 1rem;
    vertical-align: middle;
    border: 1px solid #c8c8c8;
}

.service-table thead th {
    background: #e5eaf0;
}

.service-table th {
    background: #c8c8c8;
    font-weight: normal;
}

@media screen and (min-width:992px){
    .title-service .title-large {
        font-size: 2.1rem;
    }

    .title-large-sub {
        margin-bottom: 0.5rem;
    }
    .service1-lead {
        font-size: 2rem;
        text-align: center;
    }

    .service1-title-blue {
        text-align:  center;
    }

    .service1-asterisk {
        font-size: 1.2rem;
    }

    .service1-lead-large {
        text-align: center;
    }

    .section-service1-reason1 .col-list .list-item:first-child {
        padding-right: 20px;
    }

    .section-service1-reason1 .col-list .list-item:last-child {
        padding-left: 20px;
    }

    .section-service1-reason2 .list-item-wrap {
        justify-content: space-between;
    }

    .section-service1-reason2 .list-item-wrap .list-item {
        width: 30%;
    }

    .service-either-example {
        font-size: 1.3rem;
    }

    .section-service1-reason4 .col-list .list-item:first-child {
        padding-right: 20px;
    }

    .section-service1-reason4 .col-list .list-item:last-child {
        padding-left: 20px;
    }

    .section-service1-reason4-either {
        width: 540px;
        margin: 0 auto;
    }

    .section-service1-reason4-either .service-table {
        width: 540px;
    }

    .section-service1-reason4-either .service-table th, .service-table td {
        padding: 0.6rem;
    }
}

/*  service2.html  */

.service2-lead-text {
    font-size: 1.6rem;
}

#mirai .future-calender img {
    max-width: none;
}

.interview {
    display: flex;
    flex-wrap: wrap;
}

.interview .person {
    width: 20%;
    font-weight: bold;
}

.interview .speech {
    width: 80%;
}

.interview .person, .interview .speech {
    margin-top: 3rem;
    line-height: 2;
}

.interview .person:first-of-type, .interview .speech:first-of-type {
    margin-top: 0;
}

@media screen and (min-width:992px) {
    .service2-lead-text {
        font-size: 2rem;
    }

    .align-right-lg {
        padding-left: 50%;
    }

    .interview .person {
        width: 12%;
    }

    .interview .speech {
        width: 88%;
    }
}


/*  service4.html  */

.title-bg-blue {
    padding: 3% 4%; 
    background: #00306d;
    color: #FFF;
    font-size: 1.3rem;
    font-weight: bold;
}

.each-company-figure {
    width: 33%;
    height: auto;
}


.service-description dt {
    padding: 2% 3%; 
    background: #f8f8f8;
    color: #505050;
    font-size: 1.3rem;
    font-weight: bold;
}

.service-description dd {
    margin-top: 4%;
    margin-bottom: 6%;
    line-height: 1.6;
}

.service3-about-service {
    display: block;
}


@media screen and (min-width:992px) {
    .section-service4-case-study .col-lg-2 .list-item {
        width: 48.5%;
    }

    .section-service4-case-study .col-lg-2 .list-item:nth-child(2) {
        width: 1.5%;
        display: flex;
        align-items: center;
        transform: rotate(-90deg);
    }

    .section-service4-case-study .arrow {
        width: 100%;
    }
}


/* ---------------------------------------------------------------------------------- */
/*                                   search, register                                 */  
/* ---------------------------------------------------------------------------------- */

.search-inner.inner {
    padding-left: 0;
    padding-right: 0;
}
.headding-search {
    font-size: 1.8rem;
    font-weight: normal;
    text-align: center;
}

.bu_num_label1{
    position:absolute;
    right:15%;
}

.bu_num_label2{
    position:absolute;
    right: 4%;
}

.search-lv0-group-list{
    width:100%;
}

.search-lv0-group-list .search-lv1-checkbox {
    margin: 0;
}

.search-lv0-group-name {
    padding: 5% 0 5% 4%;
    font-weight: bold;
    color: #505050;
    background: #EEE;
}

.search-lv1-name {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    position: relative;
    width: 100%;
    min-height:50px;
    padding: 5% 0 5% 4%;
    border-bottom:1px solid #b4b4b4;
}

.search-lv1-name:first-child {
    border-top:1px solid #b4b4b4;
}

.search-lv1-name.no-data:before, .search-lv1-name.no-data:after {
    content: "";
    display: none;
}

.search-lists-block  {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    position: relative;
    width: 100%;
    min-height:50px;
    padding-top: 5%;
    padding-bottom: 5%;
    padding-left: 10%;
    border-bottom:1px solid #b4b4b4; 
    background: #f8f8f8;
}

.no-data {
    pointer-events: none;
    color: #bbb;
}

.search-check-wrap {
    width: 8%;
}

.option-name {
    text-align:left;
    width:92%;
    padding-right: 25%;
    line-height: 1.3;
    margin-left: auto;
}

.search-lists-block .option-name {
    padding-right: 15%;
}

.bukken-num {
    width: 5em;
    text-align: right;
    white-space: nowrap;
}

.row-bukken-num{
    margin-right:3px;
    font-size:1.8rem;
    font-weight:bold;
}

.search-box {
    display: flex;
    width: 100%;
    padding: 4% 0;
    margin: 10% 0;
    background: #f8f8f8;
    text-align: center;
    align-items: center;
    justify-content: center;
}

.fixed-search-box {
    display: none;
    position: fixed;
    left: 0;
    bottom: 0;
    margin: 0;
    background: #969696;
    z-index: 999;
    color: #FFF;
}

.search-box-btn {
    width: 33%;
    height: 4rem;
    margin-left: 3%;
}

@media screen and (min-width:992px) {
    .search-lv0-group-name {
        padding: 25px 20px;
        font-size: 1.6rem;
    }
    
    .search-lv1-name {
        padding: 20px 0 20px 20px;
    }
    
    .bu_num_label1 {
        position: static;
    }
    
    .bu_num_label1:before, .bu_num_label2:before {
        content: " (";
    }
    
    .bu_num_label1:after, .bu_num_label2:after {
        content: ")";
    }
    
    .search-lv2-list {
        display: flex;
        flex-wrap: wrap;
        margin-top: -25px;
    }
    
    .search-lv2-list-item {
        width: 25%;
        margin-top: 25px;
    }
    
    .search-lv1-list {
        padding: 40px 0 40px 60px;
        border-bottom: 1px solid #b4b4b4;
    }
    
    .search-lists-block {
        display: inline;
        position: relative;
        width: auto;
        min-height: auto;
        padding: 0;     
        border-bottom: none;
        background: none;
    }
    
    .bu_num_label2 {
        position: static;
    }
    
    .search-check-wrap {
        display: inline-block;
    }
    
    .search-lists-block .option-name {
        display: inline-block;
        width: auto;
        padding-right: 0;
    }
    
    .option-name{
        width:950px;
        padding-right: 80px;
    }

    
    .search-box {
        margin: 60px 0;
    }
        
    .fixed-search-box {
        padding: 18px 0;
        margin: 0;
    }
    
    .row-bukken-num {
        font-size: 2.2rem;
        font-weight: normal;
    }
    
    .search-box-btn {
        width: 240px;
        height: 6rem;
        margin-left: 40px;
    }
    
    .condition-form .col-lg-10 .list-item-wrap {
        max-width: 100%;
    }
}



/* ---------------------------------------------------------------------------------- */
/*                                     mypage                                         */  
/* ---------------------------------------------------------------------------------- */

.mypage_content_area{
	width:90%;
	margin:1em auto;
	padding:10px;
	background:#FFFFCC;
	-webkit-border-radius:15px;
	margin-top:10px;
	font-size:12px;
}

.mypage_tab_head{
	background:#eaf1ff;
	padding:3px 10px;
	font-size:18px;
}
 
.bl_list .mypage_chk{
	width:26px;
	height:26px;
}
      
/* ��˥塼 */
#mypage ul#mymenu {
    display: table;
    table-layout: fixed;
    text-align: center;
    width: 100%;
}

#mypage ul#mymenu li {
    line-height: 1em;
    display: table-cell;
    vertical-align: middle;
    border-left: 1px solid #999;
}

#mypage ul#mymenu li:first-child {
    border-left: none;
}

#mypage ul#mymenu li.bold {
    font-weight: bold;
}

/* �եå����ε��夵���륫���� */
#mypage #footer_num{
line-height: 0.8;
}
    #mypage #footer_num [id^="num"]{
        font-size: 20px;
    line-height: 0.8;
    font-weight: bold;
    }
    #mypage #footer_num a{
        color: #333;
    }

/* ʪ��ꥹ�� */
#mypage	#src_mypage_form{
}

/* TOP */
#mypage #recommend{
    padding-top: 20px;
  padding-bottom: 20px;
  margin-bottom: 20px;
}

    #mypage #recommend .mypage-bu-check {
        display: block;
        background: #eee;
        padding: 0.5rem 1rem;
        text-align: left;
    }

    #mypage #recommend input[type="checkbox"]{
        margin: 0;
        position: relative;
        top: 5px;
        width: 2.5rem;
        height: 2.5rem;
        margin-bottom: 1rem;
    }

    .unread-bukken {
        display: flex;
    }
    .unread-bukken li {
        display: block;
        width: 50%;
        text-align: center;
    }

    .unread-bukken a {
        display: block;
        background: #f8f8f8;
        padding: 25px 0 15px;
    }

    .unread-bukken li:first-child a {
        background: #efefef;
    }


    .unread-bukken a span {
        font-size: 1.8em;
    }

    .mypage-textarea {
        width: 100%;
        height: 30vw;
        border: 1px solid #ccc;
    }

    @media screen and (min-width:992px){
        .mypage-textarea {
            height: 200px;
        }
    }

    .mypage-tanto a {
        display: flex;
        padding: 4%;
        align-items: center;
        justify-content: space-between;
    }

    .mypage-tanto-name {
        width: 65%;
        text-align: center;
    }

    .mypage-tanto-image {
        width: 30%;
        max-height: 20vw;
        height: 15vw;
        object-fit: cover;
    }


    </style>

