@charset "utf-8";

body {
	border-left: 5px solid #0086ae;
	border-right: 5px solid #0086ae;
	font-family: 'Open Sans',verdana,"ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic Pro","メイリオ",Meiryo,"游ゴシック",YuGothic,sans-serif;
	font-size: 15px;
	line-height: 1.4;
	background: #fbfaf5;
	color: #81511c;
	word-wrap: break-word;
	letter-spacing: 0.05em;
	min-width: 1024px;
}
@media (max-width: 767px) {
	body {
		min-width: 0;
		border: 0;
		font-size: 12px;
	}
}

table a {
	word-break: break-all;
}

br {letter-spacing: 0;}

a {/*リンクされた文字*/
	color: #00b7ee;
	text-decoration: none;
}
a:hover {/*マウスをのせたとき*/
	color: #666666;
	text-decoration: underline;
}

img {
	max-width: 100%;
}

/********** フォーム **********/
button {
	font-family: 'Open Sans',verdana,"ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic Pro","メイリオ",Meiryo,"游ゴシック",YuGothic,sans-serif;
	vertical-align: middle;
	cursor: pointer;
}

input[type="text"],
input[type="password"],
textarea,
select {
	padding: 14px;
	border: 1px solid #cccccc;
	background: #ffffff;
	color: #666666;
	font-size: 15px;
	font-family: "ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic Pro",Verdana,"游ゴシック",YuGothic,"メイリオ",Meiryo,sans-serif;
	vertical-align: middle;
}
input[type="text"]:hover,
input[type="password"]:hover,
textarea:hover,
select:hover {
	border-color: #888888;
	color: #333333;
}
input[type="text"]:focus,
input[type="password"]:focus,
textarea:focus,
select:focus {
	border-color: #67CBDF;
	color: #333333;
}
input[type="radio"],
input[type="checkbox"] {
	position: relative;
	top: -0.1em;
	margin: 0 5px 0 0;
	vertical-align: middle;
}
label {
	cursor: pointer;
}

/***** iframeの高さをレスポンシブ対応 *****/
@media (max-width: 767px) {
	.iframe-content {
		position: relative;
		width: 100%;
		padding: 56.25% 0 0 0;
	}
	.iframe-content iframe {
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
	}
}

/********** Page Top **********/
.go-top {
	position: fixed;
	z-index: 100000;
	bottom: 20px;
	right: 20px;
}
.go-top a {
	display: block;
	width: 60px;
	line-height: 60px;
	border-radius: 50%;
	background: rgba(255,255,255,0.8);
	color: #0086ae;
	text-align: center;
	text-decoration: none;
	box-shadow: 0 0 5px rgba(0,0,0,0.2);
}
.go-top a:hover {
	text-decoration: none;
	background: rgba(255,255,255,1);
}





/*********************************************/
/* レイアウト */
/*********************************************/
/***** header *****/
#header {
	position: relative;
	z-index: 10;
	padding-top: 10px;
	padding-bottom: 10px;
	background: #0086ae;
	color: #ffffff;
}
#header:before {
	position: absolute;
	bottom: -10px;
	content: "";
	width: 100%;
	height: 10px;
	background: url(../images/header-bg.png) center bottom repeat-x;
}
#second #header {
	margin-bottom: 60px;
}
.hd-copy {
	margin-bottom: 15px;
	font-size: 12px;
}
.hd-main {
	position: relative;
}
.hd-logo {
	width: 270px;
}
.hd-wrap {
	/*display: flex;*/
	position: absolute;
	top: -2px;
	right: 0;
}
.hd-time {
	font-size: 15px;
}
.hd-tel {
	padding-left: 30px;
	font-size: 15px;
	background: url(../images/icon-tel-s.png) left center no-repeat;
}

@media (max-width: 767px) {
	#header {
		padding-top: 10px;
		padding-bottom: 0;
		min-height: 50px;
	}
	#header:before {
		bottom: -5px;
		height: 5px;
		background-size: 9px 5px;
	}
	.hd-copy {
		display: none;
	}
	.hd-main {
		position: relative;
		margin-left: -15px;
		margin-right: -15px;
	}
	.hd-logo {
		margin-left: auto;
		margin-right: auto;
		margin-bottom: 5px;
		width: 135px;
	}
	.hd-tel {
		display: none;
	}
	.hd-time {
		display: none;
	}
}




/***** main-navi *****/
.main-navi-btn {
	display: none;
	cursor: pointer;
}
.main-navi {
	display: block;
	position: absolute;
	bottom: 8px;
	right: 0;
}
.main-navi-list {
	display: flex;
	font-size: 18px;
	line-height: 1;
}
.main-navi-list__item {
	margin-left: 30px;
	padding-left: 30px;
	border-left: 1px solid #ffffff;
}
.main-navi-list__item:first-child {
	border-left: 0;
}
.main-navi-list__link {
	color: #ffffff;
}
.main-navi-list__link:hover {
	color: #e60012;
	text-decoration: none;
}

.main-navi-btn-close {
	display: none;
}

@media (max-width: 767px) {
	.main-navi-btn {
		display: block;
		position: absolute;
		top: -10px;
		right: 0;
	}
	.main-navi {
		display: none;
		position: static;
		padding: 0;
		margin: 0;
	}
	.main-navi-list {
		display: block;
		font-size: 15px;
	}
	.main-navi-list__item {
		margin-left: 0;
		padding-left: 0;
		border-left: 0;
		border-bottom: 1px solid #ffffff;
	}
	.main-navi-list__link {
		display: block;
		padding: 0 15px;
		line-height: 45px;
		text-decoration: none;
		background: #007ba1;
	}
	.main-navi-btn-close {
		display: block;
		padding: 15px 0;
		font-weight: bold;
		font-size: 12px;
		text-align: center;
	}
}

/***** ヘルプナビ *****/
.hd-cart__btn {
	position: relative;
	float: right;
	margin-right: 10px;
	font-size: 30px;
}
.hd-cart__batch {
	position: absolute;
	top: 5px;
	right: -10px;
	width: 15px;
	line-height: 15px;
	border-radius: 50%;
	font-size: 12px;
	background: #000000;
	color: #ffffff;
	text-align: center;
}

/***** パンくず *****/
.breadcrumbs {
	margin-bottom: 30px;
	padding: 15px;
	border: 1px solid #dddddd;
	border-radius: 5px;
	font-size: 10px;
	background: #f5f5f5;
}
.breadcrumbs li {
	position: relative;
	display: inline-block;
	margin-left: 25px;
}
.breadcrumbs li:first-child {
	float: left;
	margin-left: 0;
}
.breadcrumbs li:before {
	display: block;
	content: '';
	position: absolute;
	top: 50%;
	left: -18px;
	margin-top: -3px;
	width: 6px;
	height: 6px;
	border-right: 1px solid #666666;
	border-bottom: 1px solid #666666;
	-webkit-transform: rotate(-45deg);
	transform: rotate(-45deg);
}
.breadcrumbs li:first-child:before {
	border: 0;
}

/***** contents *****/
#contents {
	min-height: 300px;
}
#main-contents {
	margin-bottom: 120px;
}
#side-contents {
	margin-bottom: 120px;
}
.side-bnr-list__item {
	margin-bottom: 15px;
}

/***** footer *****/
#footer {
	margin-top: 120px;
	padding: 30px 0 15px 0;
	background: #0086ae;
	color: #ffffff;
}
.ft-main {
	position: relative;
}
.main-navi.is-ft {
	display: block;
	bottom: auto;
	top: 7px;
}
.hd-logo.is-ft {
	margin-bottom: 30px;
}
.hd-copy.is-ft {
	margin-bottom: 0;
}
.ft-wrap {
	display: flex;
	top: 40px;
}

.ft-time {
	padding-left: 15px;
}


.copyright {
	position: absolute;
	right: 0;
	bottom: 3px;
	font-size: 12px;
}

@media (max-width: 767px) {
	#footer {
		margin-top: 120px;
		padding: 0;
		background: #0086ae;
		color: #ffffff;
		text-align: center;
	}
	.ft-main {
		position: relative;
	}
	.main-navi.is-ft {
		display: block;
		position: static;
		margin-left: -15px;
		margin-right: -15px;
		margin-bottom: 30px;
		text-align: left;
	}
	.hd-logo.is-ft {
		margin-bottom: 30px;
	}
	.hd-copy.is-ft {
		display: block;
		margin-bottom: 30px;
		text-align: left;
	}
	.ft-wrap {
		display: block;
	}
	.hd-tel.is-ft {
		display: inline-block;
		position: static;
		margin-bottom: 30px;
	}
	.ft-time.is-ft {
		display: block;
		position: static;
		margin-bottom: 30px;
	}
	.copyright {
		position: static;
		margin-left: -15px;
		margin-right: -15px;
		font-size: 12px;
		line-height: 45px;
		background: #007599;
		color: #aeecff;
		text-align: center;
	}
}




/*********************************************/
/* Components */
/*********************************************/
/***** タイトル *****/
.c-ttl-main {
	position: relative;
	margin-bottom: 45px;
	line-height: 1.2;
	font-size: 36px;
	color: #0086ae;
	text-align: center;
}
.c-ttl-main:before,
.c-ttl-main:after {
	position: absolute;
	bottom: -23px;
	content: "";
	height: 2px;
	width: 30px;
}
.c-ttl-main:before {
	left: 50%;
	background: #e60012;
}
.c-ttl-main:after {
	right: 50%;
	background: #009844;
}
.c-ttl-main.is-top {
	margin-bottom: 60px;
	font-size: 48px;
}
.c-ttl-main.is-top:before,
.c-ttl-main.is-top:after {
	width: 105px;
}
.c-ttl-main.is-second {
	margin-bottom: 90px;
}

.c-ttl-sub {
	margin-bottom: 30px;
	padding-bottom: 5px;
	border-bottom: 1px solid #cccccc;
	font-size: 24px;
	color: #000000;
}
.c-ttl-sub-s {
	margin-bottom: 15px;
	border-left: 5px solid #cccccc;
	padding-left: 10px;
	font-size: 18px;
	color: #000000;
}

.c-lead {
	margin-bottom: 45px;
	color: #81511c;
	font-size: 18px;
	text-align: center;
	line-height: 1.8;
}
.c-lead.is-top-main {
	font-size: 22px;
}

@media (max-width: 767px) {
	.c-ttl-main {
		position: relative;
		margin-bottom: 30px;
		font-size: 21px;
	}
	.c-ttl-main:before,
	.c-ttl-main:after {
		position: absolute;
		bottom: -15px;
		content: "";
		height: 2px;
		width: 15px;
	}
	.c-ttl-main.is-top {
		margin-bottom: 45px;
		font-size: 30px;
	}
	.c-ttl-main.is-top:before,
	.c-ttl-main.is-top:after {
		width: 30px;
	}

	.c-ttl-sub {
		margin-bottom: 30px;
		padding-bottom: 5px;
		border-bottom: 1px solid #cccccc;
		font-size: 24px;
		color: #000000;
	}
	.c-ttl-sub-s {
		margin-bottom: 15px;
		border-left: 5px solid #cccccc;
		padding-left: 10px;
		font-size: 18px;
		color: #000000;
	}

	.c-lead {
		margin-bottom: 30px;
		font-size: 12px;
	}
	.c-lead.is-top-main {
		font-size: 12px;
	}
}


/***** メッセージ・アラート *****/
.c-alert {
	padding: 15px;
	border: 1px solid #cccccc;
	border-radius: 5px;
}
.c-alert.is-success {
	color: #3c763d;
	background-color: #dff0d8;
	border-color: #d6e9c6;
}
.c-alert.is-info {
	color: #31708f;
	background-color: #d9edf7;
	border-color: #bce8f1;
}
.c-alert.is-warning {
	color: #8a6d3b;
	background-color: #fcf8e3;
	border-color: #faebcc;
}
.c-alert.is-danger {
	color: #a94442;
	background-color: #f2dede;
	border-color: #ebccd1;
}

.c-error {
	margin-top: 5px;
	padding: 5px 10px;
	border-radius: 5px;
	border: 2px solid #ffcfcf;
	background: #fff0f0;
	color: #ff0000;
}

.c-em {
	font-weight: bold;
	color: #ff6600;
}

/***** ボタン *****/
.c-btn {
	display: inline-block;
	padding: 5px 15px;
	border: 1px solid #bbbbbb;
	border-radius: 0;
	line-height: 1.4;
	background: #e0e0e0;
	color: #202D37;
	font-size: 14px;
	cursor: pointer;
	box-shadow: 0 1px 0 rgba(255,255,255,0.6) inset;
	text-align: center;
	text-decoration: none;
}
.c-btn:hover {
	border: 1px solid #aaaaaa;
	background-color: #d8d8d8;
	color: #333333;
	cursor: pointer;
	text-decoration: none;
}

/* input画像ボタンサイズ */
.c-btn.is-s {
	padding: 4px 5px;
	font-size: 12px;
}
.c-btn.is-m {
	padding: 7px 30px;
	font-size: 22px;
}
.c-btn.is-l {
	padding: 15px 30px;
	font-size: 30px;
}

/* input画像ボタンカラー */
.c-btn.is-primary {
	border-color: #00a0e9;
	background: #00a0e9;
	color: #ffffff;
	box-shadow: none;
}
.c-btn.is-primary:hover {
	background: #00a7f5;
	color: #ffffff;
}
.c-btn.is-success {
	border-color: #398439;
	background: #449d44;
	color: #ffffff;
	box-shadow: none;
}
.c-btn.is-success:hover {
	background: #398439;
	color: #ffffff;
}

/***** table風 レスポンシブリスト *****/
@media (min-width: 768px) {
	.c-tbl-list {
		display: table;
	}
	.c-tbl-list__tr {
		display: table-row;
		width: 100%;
	}
	.c-tbl-list__th,
	.c-tbl-list__td {
		display: table-cell;
		overflow: hidden;
		word-wrap: break-word;
		word-break: break-all;
		float: none;
	}
}

.c-tbl-list__tr {
	border: 1px solid #cccccc;
	border-bottom: 0;
}
.c-tbl-list__tr:last-child {
	border: 1px solid #cccccc;
}
.c-tbl-list__th {
	padding: 30px 15px 15px 15px;
	vertical-align: top;
}
.c-tbl-list__td {
	padding: 15px;
	background: #ffffff;
	vertical-align: top;
}

@media (max-width: 767px) {
	.c-tbl-list__tr {
		margin-bottom: 30px;
		border: 0;
	}
	.c-tbl-list__tr:last-child {
		border: 0;
	}
	.c-tbl-list__th {
		margin-bottom: 15px;
		padding: 0;
		border-right: 0;
		font-weight: bold;
		text-align: left;
	}
	.c-tbl-list__td {
		padding: 0;
	}
}


/***** table *****/
.c-tbl {
	width: 100%;
}
.c-tbl__th {
	padding: 15px;
	border: 1px solid #cccccc;
	background: #eeeeee;
}
.c-tbl__td {
	padding: 15px;
	border: 1px solid #cccccc;
	background: #ffffff;
}

/***** タイル レスポンシブ可変リスト *****/
.c-tile-list {
	margin-bottom: 30px;
}
.c-tile-list__img {
	margin-bottom: 5px;
}
.c-tile-list__ttl {
	margin-bottom: 5px;
	color: #000000;
}
@media (max-width: 767px) {
	.c-tile-list {
		margin-bottom: 15px;
		padding-bottom: 15px;
		border-bottom: 1px solid #cccccc;
	}
	.c-tile-list__txt {
		padding-left: 0;
	}
	.c-tile-list__ttl {
		font-size: 18px;
	}
}


/********** ページャー **********/
.pager {
	position: relative;
	overflow: hidden;
}
.pager-list {
	padding: 20px 0;
	position: relative;
	left: 50%;
	float: left;
}
.pager-list__item {
	overflow: hidden;
	position: relative;
	left: -50%;
	float: left;
	margin: 0 5px 0 0;
	width: 37px;
	border: 1px solid #337ab7;
	line-height: 35px;
	background: #337ab7;
	color: #ffffff;
	border-radius: 5px;
	text-align: center;
}
.pager-list__link {
	display: block;
	background: #ffffff;
	color: #337ab7;
	text-decoration: none;
}
.pager-list__link:hover {
	background: #337ab7;
	color: #ffffff;
	text-decoration: none;
}

.btn-more {
	display: block;
	padding: 15px;
	border: 1px solid #e5e5e5;
	border-radius: 5px;
	background: #f0f0f0;
	color: #333333;
	text-align: center;
}
.btn-more:hover {
	background: #eeeeee;
	text-decoration: none;
}





/*********************************************/
/* Utility */
/*********************************************/
/* clearfix */
.u-cl:before,.u-cl:after {content: " ";display: table;}
.u-cl:after {clear: both;}
.u-cl {*zoom: 1;}

/* font関連 */
.u-bold {font-weight: bold !important;}
.u-through {text-decoration: line-through}
.u-fss {font-size: 10px !important;}
.u-fs {font-size: 12px !important;}
.u-fm {font-size: 14px !important;}
.u-fl {font-size: 18px !important;}
.u-fll {font-size: 24px !important;}
.u-fxl {font-size: 30px !important;}

/* float */
.u-fl {float:left;}
.u-fr {float:right;}

/* text-align */
.u-tl {text-align: left !important;}
.u-tc {text-align: center !important;}
.u-tr {text-align: right !important;}

/* vertical-align */
.u-vat {vertical-align: top !important;}
.u-vam {vertical-align: middle !important;}
.u-vab {vertical-align: bottom !important;}

/* bottom-margin */
.u-mb0 {margin-bottom:0px !important;}
.u-mb5 {margin-bottom:5px !important;}
.u-mb10 {margin-bottom:10px !important;}
.u-mb15 {margin-bottom:15px !important;}
.u-mb20 {margin-bottom:20px !important;}
.u-mb25 {margin-bottom:25px !important;}
.u-mb30 {margin-bottom:30px !important;}
.u-mb35 {margin-bottom:35px !important;}
.u-mb40 {margin-bottom:40px !important;}
.u-mb45 {margin-bottom:45px !important;}
.u-mb50 {margin-bottom:50px !important;}
.u-mb60 {margin-bottom:60px !important;}

.u-mbxs {margin-bottom: 5px !important;}
.u-mbss {margin-bottom: 10px !important;}
.u-mbs {margin-bottom: 15px !important;}
.u-mbm {margin-bottom: 45px !important;}
.u-mbl {margin-bottom: 60px !important;}
.u-mbll {margin-bottom: 120px !important;}
.u-mbxl {margin-bottom: 240px !important;}

/* padding */
.u-plrs {padding-left: 10px !important;padding-right: 10px !important;}
.u-plrm {padding-left: 15px !important;padding-right: 15px !important;}

/* 幅 */
.u-ws { width: 50px;}
.u-wm { width: 100px;}
.u-wl { width: 200px;}
.u-w-half { width: 50%;}
.u-w-max { width: 100%;}

/* 色 */
.u-red {color: #ff0000;}

.u-required {color: #ff0000;}/* 必須 */
.u-date {color: #888888;}/* 日付 */

.u-dpn {display: none;}

.u-pc-only {display: block;}
.u-sp-only {display: none;}
img.u-pc-only {display: inline;}
img.u-sp-only {display: none;}

@media (max-width: 767px) {
	.u-pc-only {display: none;}
	.u-sp-only {display: block;}
	img.u-pc-only {display: none;}
	img.u-sp-only {display: inline;}
}

/* opacity */
.u-opa a img,
.u-opa-img img,
.u-opa-box {
	opacity:1;
	filter: alpha(opacity=100);
	transition: opacity 0.2s ease;
	backface-visibility: hidden;
}
.u-opa a:hover img,
.u-opa-img img:hover,
.u-opa-box:hover {
	opacity:0.7;
	filter: alpha(opacity=70);
}

.u-spr {
	overflow: hidden;
	white-space: nowrap;
	text-indent: 150%;
	border: 0;
	cursor: pointer;
}
.u-spr::-moz-focus-inner {
	padding: 0;
	border: none;
}
.u-pre {
	padding: 15px;
	background: #333333;
	color: #ffffff;
}

/***** 画像 *****/
.u-img {
	margin-bottom: 15px;
}

/***** テキスト *****/
.u-txt {
	line-height: 1.8;
}
@media (max-width: 767px) {
	.u-list-txt {
		padding-left: 0;
	}
}

/* input画像ボタンにつける */
.u-input-img {
	padding: 0;
	border: none;
	box-shadow: none;
	cursor: pointer;
}
.u-input-img:hover {
	padding: 0;
	border: none;
	box-shadow: none;
}
/* inputテキストボタンにつける */
.u-input-txt {
	padding: 0;
	border: none;
	background: none;
	box-shadow: none;
}
.u-input-txt:hover {
	padding: 0;
	border: none;
	background: none;
	box-shadow: none;
	cursor: pointer;
	text-decoration: underline;
}

.u-hidden {
	overflow: hidden;
}
.u-overframe {
	margin-left: -500%;
	margin-right: -500%;
	padding-left: 500%;
	padding-right: 500%;
}