@charset "utf-8";

body {
	min-width: 940px;
	color: #333333;
	font-family: "メイリオ", "Meiryo", verdana, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "ＭＳ Ｐゴシック", "MS PGothic", Sans-Serif;
	font-size: 16px;
	letter-spacing: 0.01em;
	line-height: 1.5;
}

@media (min-width: 768px) {
	body {
		overflow: visible;
	}
	body.pushable {
		overflow-x: visible;
	}
}

.container {
	position: relative;
	max-width: 1320px;
	margin: 0 auto;
}

a {
	display: inline-block;
	padding-bottom: 2px;
	color: #b22a56;
	text-decoration: underline dashed;
}

a:hover {
	text-decoration: none;
	-webkit-transition: all .3s;
	-moz-transition: all .3s;
	-ms-transition: all .3s;
	-o-transition: all .3s;
	transition: all .3s;
}

img {
	max-width: 100%;
	max-height: 100%;
	vertical-align: bottom;
}

a img {
	cursor: pointer;
}

@media (max-width: 767px) {
	body {
		min-width: 0;
		font-size: 14px;
	}

	.container {
		width: 100%;
	}
}
/*----------------------------------------------------
	#header
----------------------------------------------------*/
.headerDesc {
	width: 100%;
	background-color: #000;
	color: #ffffff;
	font-size: 11px;
	line-height: 1;
	text-align: right;
}

.headerDesc span {
	display: block;
	max-width: 1300px;
	margin: 0 auto;
	padding: 4px 0;
}

#header {
	position: relative;
	/*background-color: #fff;*/
	line-height: 1;
}

.headerWrap {
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-align-items: center;
	align-items: center;
	-webkit-justify-content: space-between;
	justify-content: space-between;
	-ms-flex-pack: justify;
	-ms-flex-align: center;
}

.headerInfo .tel {
	text-align: right;
}

.headerInfo .nav {
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
}

.headerInfo .nav a {
	position: relative;
	display: inline-block;
	padding: 0 1em;
	margin: 0 0em;
	height: 40px;
	overflow: hidden;
	text-align: center;
	text-decoration: none;
	color: #b22a56;
}

.headerInfo .nav span {
	display: block;
	line-height: 40px;
	font-size: 20px;
	-webkit-transition: all .3s;
	-moz-transition: all .3s;
	-ms-transition: all .3s;
	-o-transition: all .3s;
	transition: all .3s;
}
.headerInfo .nav a:hover span {
	-webkit-transform: translate(0, -40px);
	-moz-transform: translate(0, -40px);
	-ms-transform: translate(0, -40px);
	-o-transform: translate(0, -40px);
	transform: translate(0, -40px);
}


#header img {
	vertical-align: top;
}

#header .main {
	display: none;
	padding: 15px 20px;
}

#header .main .navi {
	width: 170px;
	float: left;
}

#header .main .navi li {
	margin-bottom: 5px;
	float: left;
}

#header .main .slide {
	position: relative;
	max-width: 800px;
	margin-right: auto;
	margin-left: auto;
	text-align: center;
}

#header .main .slide ul li {
	text-align: center;
}

#header .main .slide ul li img {
	display: inline-block;
}

#header .main .thumb {
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-align-items: center;
	align-items: center;
	-webkit-justify-content: center;
	justify-content: center;
	max-width: 740px;
	padding: 10px 0 0;
	-ms-flex-pack: center;
	-ms-flex-align: center;
}

#header .main .thumb img {
	margin: 0 4px;
	border: 1px solid #ccc;
}

#header .main .thumb .active img {
	border: 1px solid #f30;
}

#header .bx-wrapper .bx-controls-direction a {
	width: 40px;
	height: 40px;
}

#header .bx-wrapper .bx-prev {
	left: -50px;
	background-position: 0 -40px;
	background-size: 120px 79px;
}

#header .bx-wrapper .bx-next {
	right: -50px;
	background-position: -54px -40px;
	background-size: 120px 79px;
}

#header .foot {
	margin-top: -50px;
}

#header .foot .navi ul {
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-align-items: center;
	align-items: center;
	-webkit-justify-content: center;
	justify-content: center;
	-ms-flex-align: center;
	-ms-flex-pack: center;
}

#header .sp_header {
	display: none;
}

@media (max-width: 767px) {
	.headerDesc {
		position: absolute;
		top: 0;
		left: 0;
	}

	#header {
		padding-top: 50px;
	}

	#header h1 {
		top: -1em;
	}

	.headerWrap {
		display: none;
	}

	#header .foot {
		display: none;
	}

	#header .main {
		padding: 0;
	}

	#header .sp_header {
		display: -webkit-flex;
		display: -ms-flexbox;
		display: flex;
		position: fixed;
		top: 0;
		left: 0;
		-webkit-justify-content: space-between;
		justify-content: space-between;
		width: 100%;
		height: 50px;
		background-color: #2b2b2b;
		z-index: 9999;
		-ms-flex-pack: justify;
	}

	#header .sp_logo img {
		height: 50px;
	}

	#header .sp_nav {
		display: -webkit-flex;
		display: -ms-flexbox;
		display: flex;
		-webkit-align-items: center;
		align-items: center;
		-webkit-justify-content: flex-end;
		justify-content: flex-end;
		-ms-flex-pack: end;
		-ms-flex-align: center;
	}

	#header .sp_nav span img {
		height: 40px;
	}
}

body .ui.sidebar.menu {
	border: none;
}

body .ui.sidebar.menu .logo {
	height: 50px;
	padding-top: 15px;
	background-color: #2b2b2b;
	text-align: center;
}

body .ui.sidebar.menu .logo a {
	color: #ffffff;
}

body .ui.sidebar.menu a {
	color: rgba(0, 0, 0, 0.87);
	font-weight: normal;
}

body .ui.sidebar.menu .item {
	font-size: 14px;
}

body .ui.sidebar.menu .contact .wrap {
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-justify-content: space-between;
	justify-content: space-between;
	-ms-flex-pack: justify;
}

body .ui.sidebar.menu .contact .wrap a {
	width: 100%;
	margin-right: 1px;
}

body .ui.sidebar.menu .contact .wrap a:last-child {
	margin-right: 0;
}

body .ui.sidebar.menu .contact .tel {
	padding: 4px;
}

body .ui.sidebar.menu .contact .tel img {
	width: 100%;
}

/*----------------------------------------------------
	#main
----------------------------------------------------*/
#main {
	position: relative;
	min-height: 300px;
}

#content {
	max-width: 1300px;
	margin: 0 auto;
	padding-bottom: 15px;
}

@media (max-width: 767px) {
	#main {
		padding: 0 10px;
	}
	#content {
		width: 100%;
	}
}

.main_contact {
	padding: 20px 0;
}

.main_contact ul {
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-justify-content: space-around;
	justify-content: space-around;
	-ms-flex-pack: distribute;
}

.main_contact li {
	margin: 0 10px;
}

@media (max-width: 767px) {
	.main_contact ul {
		-webkit-flex-direction: column;
		-ms-flex-direction: column;
		flex-direction: column;
	}

	.main_contact li {
		margin: 0 0 12px 0;
		padding: 0 10%;
		text-align: center;
	}

	.main_contact li:last-child {
		margin-right: 0;
	}
}
/*----------------------------------------------------
	#footer
----------------------------------------------------*/
#footer .footer_nav {
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-justify-content: space-between;
	justify-content: space-between;
	margin: 10px 0;
	padding: 20px 0;
	border-top: 1px solid #ccc;
	border-bottom: 1px solid #ccc;
	-ms-flex-pack: justify;
}

#footer .footer_nav h3 {
	font-size: 14px;
	letter-spacing: 0.05em;
}

#footer .footer_nav a {
	color: #666666;
}

#footer .footer_nav a:before {
	display: inline-block;
	content: "・";
}

#footer .footer_nav ul {
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-flex-wrap: wrap;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	-webkit-justify-content: space-between;
	justify-content: space-between;
	-ms-flex-pack: justify;
}

#footer .footer_nav ul li {
	width: 48%;
	font-size: 12px;
	white-space: nowrap;
}

#footer .footer_nav ul li a {
	padding-left: 0.5em;
	text-indent: -0.5em;
}

#footer .copy {
	font-size: 10px;
	text-align: center;
}

@media (max-width: 767px) {
	#footer .footer_nav {
		-webkit-flex-direction: column;
		-ms-flex-direction: column;
		flex-direction: column;
		padding: 20px 10px;
	}

	#footer .footer_nav h3 {
		font-size: 14px;
	}

	#footer .footer_nav > div {
		width: 100%;
		margin-bottom: 12px;
	}

	#footer .footer_nav > div:last-child {
		margin-bottom: 0;
	}

	#footer .footer_nav > div ul li {
		font-size: 10px;
		white-space: pre-wrap;
	}

	#footer .copy {
		padding: 0 10px;
		font-size: 10px;
		text-align: center;
	}
}
/*----------------------------------------------------
	#index
----------------------------------------------------*/
body#index #header .main {
	display: block;
}

/*body#index #header .foot {*/
	/*margin-top: 0;*/
/*}*/

body#index #content .usp ul {
	padding-top: 15px;
	padding-bottom: 15px;
	text-align: center;
}

body#index #content .usp li {
	display: inline-block;
	padding: 0 10px 10px 10px;
	*: inline;
	*: 1;
}

body#index #content .info {
	margin-bottom: 24px;
	background: #fff;
}

body#index #content .info > div {
	padding: 12px;
	border: 1px solid #000;
}

body#index #content .info .head {
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-justify-content: space-between;
	justify-content: space-between;
	margin-bottom: 8px;
	border-bottom: 1px solid #000;
	-ms-flex-pack: justify;
}

body#index #content .info .head h3 {
	font-size: 18px;
	letter-spacing: 0.1em;
}

body#index #content .info .head h3 i {
	margin: 0 0.3em;
}

body#index #content .info .head h3 .en {
	font-size: 12px;
}

body#index #content .contents li {
	margin-right: 15px;
	margin-bottom: 15px;
	float: left;
}

body#index #content .link li {
	margin-right: 20px;
	margin-bottom: 20px;
	float: left;
}

/*----------------------------------------------------
	#
----------------------------------------------------*/
/* clearfix */
.clearfix,
#header,
#header .main,
#header .foot,
#main,
#footer {
	*zoom: 1;
}

.clearfix:after,
#header:after,
#header .main:after,
#header .foot:after,
#main:after,
#footer:after {
	display: block;
	height: 0;
	clear: both;
	content: ".";
	visibility: hidden;
}

#content h2 {
	margin-bottom: 10px;
	padding-top: 15px;
	clear: both;
}

#content .contact li {
	margin-right: 20px;
	margin-bottom: 20px;
	float: left;
}

#content .error-message {
	color: #f00;
}

#content .caution {
	color: #f00;
}

#content .section {
	margin-bottom: 24px;
}

.center {
	text-align: center;
}

/*----------------------------------------------------
	#
----------------------------------------------------*/
/* numeric controls */
ol#controls {
	height: 28px;
	margin: 1em 0;
	padding: 0;
}

ol#controls li {
	height: 28px;
	margin: 0 10px 0 0;
	padding: 0;
	float: left;
	line-height: 28px;
	list-style: none;
}

ol#controls li a {
	height: 28px;
	padding: 0 10px;
	float: left;
	border: 1px solid #ccc;
	background: #daf3f8;
	color: #555;
	line-height: 28px;
	text-decoration: none;
}

ol#controls li.current a {
	background: #5dc9e1;
	color: #fff;
}

ol#controls li a:focus,
#prevBtn a:focus,
#nextBtn a:focus {
	outline: none;
}

.ttl1 {
	margin-bottom: 8px;
	text-align: center;
}

.ttl1 .ja {
	font-size: 18px;
	letter-spacing: 0.1em;
}

.ttl1 .en {
	display: block;
	letter-spacing: 0.14em;
}

.sample {
	border: 1px solid #ccc;
	border-radius: 3px;
	text-shadow: 0px 1px 3px rgba(255, 0, 0, 0.6);
	box-shadow: 1px 1px 2px #666666;
}

.hide {
	display: none;
}

.pc {
	display: inline;
}

.pc.block {
	display: block;
}

.pc.inline-block {
	display: inline-block;
}

.pc_hide {
	display: none;
}

.pc_hide.block {
	display: none;
}

.pc_hide.inline-block {
	display: none;
}

.sp {
	display: none;
}

.sp.block {
	display: none;
}

.sp.inline-block {
	display: none;
}

@media (max-width: 767px) {
	.sp {
		display: inline;
	}

	.sp.block {
		display: block;
	}

	.sp.inline-block {
		display: inline-block;
	}

	.sp_hide {
		display: none;
	}

	.sp_hide.block {
		display: none;
	}

	.sp_hide.inline-block {
		display: none;
	}

	.pc {
		display: none;
	}

	.pc.block {
		display: none;
	}

	.pc.inline-block {
		display: none;
	}

	.pc_hide {
		display: inline;
	}

	.pc_hide.block {
		display: block;
	}

	.pc_hide.inline-block {
		display: inline-block;
	}
}

table {
	max-width: 100%;
	margin-bottom: 20px;
	background-color: transparent;
	border-collapse: collapse;
	border-spacing: 0;
}

.table th,
.table td {
	padding: 8px;
	border-top: 1px solid #dddddd;
	line-height: 20px;
	text-align: left;
	vertical-align: top;
}

.table th {
	font-weight: bold;
}

.flex {
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-justify-content: space-around;
	justify-content: space-around;
	-ms-flex-pack: distribute;
}

@media (max-width: 767px) {
	table.flex {
		display: block;
	}

	table.flex > tbody {
		display: block;
	}

	table.flex > tbody > tr {
		display: -webkit-flex;
		display: -ms-flexbox;
		display: flex;
		-webkit-flex-direction: column;
		-ms-flex-direction: column;
		flex-direction: column;
	}

	table.flex > tbody > tr > td,
	table.flex > tbody > tr > th {
		width: 100%;
	}

	table.flex-reverse {
		display: block;
	}

	table.flex-reverse > tbody {
		display: block;
	}

	table.flex-reverse > tbody > tr {
		display: -webkit-flex;
		display: -ms-flexbox;
		display: flex;
		-webkit-flex-direction: column-reverse;
		-ms-flex-direction: column-reverse;
		flex-direction: column-reverse;
	}

	table.flex-reverse > tbody > tr > td,
	table.flex-reverse > tbody > tr > th {
		width: 100%;
	}

	.flex {
		-webkit-flex-direction: column;
		-ms-flex-direction: column;
		flex-direction: column;
	}
}

.pagination {
	padding: 24px 0;
}

.pagination ul {
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-justify-content: center;
	justify-content: center;
	-ms-flex-pack: center;
}

.pagination ul li {
	margin-left: -1px;
}

.pagination ul a {
	display: inline-block;
	min-width: 2.5em;
	height: 2.5em;
	padding: 0.75em 0;
	border: 1px solid #ccc;
	line-height: 1;
	text-align: center;
	text-decoration: none;
}

.pagination ul li:first-child a {
	border-radius: 4px 0 0 4px;
}

.pagination ul li:last-child a {
	border-radius: 0 4px 4px 0;
}

.pagination ul .active {
	background-color: #efefef;
}

@media (max-width: 767px) {
	.pc_bg {
		background: none !important;
	}
}
/*----------------------------------------------------
	フォーム系
----------------------------------------------------*/
textarea {
	width: 100%;
	max-width: 100%;
}

input[type='text'],
input[type='email'],
select,
textarea {
	min-height: 32px;
	margin-bottom: 4px;
	padding: 0 0.5em;
	border: 1px solid #ccc;
	border-radius: 4px;
}

input[type='radio'] {
	margin-right: 0.3em;
}

@media (max-width: 767px) {
	input,
	textarea {
		max-width: 100%;
	}
}

.btn {
	display: inline-block;
	padding: 8px 1.5em;
	border: none;
	background-color: #2b2b2b;
	color: #ffffff;
	box-shadow: 1px 1px 2px rgba(0, 0, 0, 0.5);
	cursor: pointer;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
}

.btn:disabled {
	background-color: #999;
}

#contacts form th {
	padding-top: 12px;
}

#contacts form td {
	font-size: 12px;
}

@media (max-width: 767px) {
	#contacts form table,
	#contacts form tbody,
	#contacts form tr,
	#contacts form th,
	#contacts form td {
		display: block;
	}

	#contacts form th {
		padding-bottom: 0;
	}

	#contacts form td {
		border-top: none;
	}
}
/*----------------------------------------------------
	汎用クラス
----------------------------------------------------*/
.ttl01 {
	margin-bottom: 1.5em;
	padding: 1.5em 0;
	border-top: 1px solid #635e5e;
	border-bottom: 1px solid #635e5e;
	text-align: center;
}

.ttl01 h2 {
	font-size: 1.25em;
	font-weight: bold;
	letter-spacing: 0.075em;
	line-height: 1;
}

.ttl01 .desc {
	display: block;
	font-size: 0.75em;
}

.center {
	text-align: center;
}

.mb1 {
	margin-bottom: 1em;
}

.mb2 {
	margin-bottom: 2em;
}

.ms1 {
	margin-right: 1em;
	margin-left: 1em;
}

.ms2 {
	margin-right: 2em;
	margin-left: 2em;
}

.pd1 {
	padding: 1em 0;
}

.pd2 {
	padding: 2em 0;
}


.mt-1 {
	margin-top: 1rem;
}

.mt-2 {
	margin-top: 2rem;
}

.mb-1 {
	margin-bottom: 1rem;
}

.mb-2 {
	margin-bottom: 2rem;
}

.ml-1 {
	margin-left: 1rem;
}

.ml-2 {
	margin-left: 2rem;
}

.mr-1 {
	margin-right: 1rem;
}

.mr-2 {
	margin-right: 2rem;
}

.mx-1 {
	margin-right: 1rem;
	margin-left: 1rem;
}

.mx-2 {
	margin-right: 2rem;
	margin-left: 2rem;
}

.pt-1 {
	padding-top: 1rem;
}

.pt-2 {
	padding-top: 2rem;
}

.pb-1 {
	padding-bottom: 1rem;
}

.pb-2 {
	padding-bottom: 2rem;
}

.pl-1 {
	padding-left: 1rem;
}

.pl-2 {
	padding-left: 2rem;
}

.pr-1 {
	padding-right: 1rem;
}

.pr-2 {
	padding-right: 2rem;
}

.px-1 {
	padding-right: 1rem;
	padding-left: 1rem;
}

.px-2 {
	padding-right: 2rem;
	padding-left: 2rem;
}

.fz-12 {
	font-size: 0.75em;
}

.fz-14 {
	font-size: 0.875em;
}

.fz-16 {
	font-size: 1em;
}

.fz-18 {
	font-size: 1.125em;
}

.fz-20 {
	font-size: 1.25em;
}

.fz-22 {
	font-size: 1.375em;
}

.fz-24 {
	font-size: 1.5em;
}
