@charset "UTF-8";

/* 共通項目
======================================== */
/* Base */
* {
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}
body {
	margin: 0;
	padding: 0;
	color: #333;
	font-size: 13px;
	font-family: "メイリオ", "Meiryo", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "ＭＳ Ｐゴシック", "MS PGothic", Sans-Serif, FontAwesome;
	line-height: 1.5;
	-webkit-text-size-adjust: 100%;
	text-size-adjust: 100%;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	word-break: break-all;
	word-wrap: break-word;
	background: rgba(82, 82, 82, .95);
	overflow-x: hidden;
}
.wrapper {
	width: 100%;
	min-width: 320px;
	background: #fff;
	overflow: hidden;
	/* footer最下部固定用 */
	display: flex;
	flex-direction: column;
	min-height: 100vh;
}
/* Content */
.container {
	margin-top:44px;
}
.home .container {
	margin: 0;
}
.content {
	max-width: 1020px;
	margin: auto;
	padding: 20px 10px;
}
.home .content {
	max-width: 100%;
	margin: 0;
	padding: 0;
}
.main_content {
	width: 75%;
	float: left;
	padding-right: 10px;
}
.home .main_content,
.media-template .main_content,
.page-template-contact .main_content,
.page-template-complete .main_content,
.page-template-default .main_content,
.tax-media-cat .main_content,
.error404 .main_content {
	width: 100%;
	float: none;
	padding-right: 0;
}
.side_content {
	width: 25%;
	float: right;
}
section {
	max-width: 1000px;
	font-size: 16px;
	margin: auto;
}
.main_title {
	font-size: 18px;
	font-weight: 600;
	border-bottom: 2px dotted #999;
	margin-bottom: 15px;
	padding-bottom: 5px;
}
.main_title a {
	color: #333;
}
.main_title a:hover {
	color: #fb6964;
}
@media screen and (max-width: 719px) {
	.content {
		padding: 15px 10px;
	}
	.main_content {
		width: 100%;
		float: none;
		padding-right: 0;
	}
	.side_content {
		width: 100%;
		float: none;
	}
	section {
		font-size: 14px;
	}
	section h1 {
		font-size: 16px;
		margin-bottom: 10px;
	}
	section h1 a:hover,
	section .title a:hover {
		color: #333;
	}
}
/* Image */
img {
	width: 100%;
	max-width: 100%;
	width /***/:auto;
	height: auto;
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
}
/* Form */
input,
textarea,
button {
	border: none;
	outline: none;
	-webkit-border-radius: 0;
	border-radius: 0;
	-webkit-appearance: none;
	appearance: none;
}
/* Link */
a {
	color: #4682b4;
	text-decoration:none;
}
a:hover {
	color: #fb6964;
	opacity: .8;
}
@media screen and (max-width: 719px) {
	a:hover {
		color: #4682b4;
		opacity: 1;
	}
}
/* Clearfix */
.clr {
	clear: both;
	zoom: 1;
}
.clr:before,
.clr:after {
	content: "";
	display: block;
	clear: both;
}
/* Font Awesome */
.fa {
	padding-right: 5px;
}
.fa.left {
	padding-left: 5px;
}

/* ヘッダー
======================================== */
header {
	width: 100%;
	height: 44px;
	background: rgba(82, 82, 82, .95);
	position: fixed;
	top: 0;
	-webkit-transition: top 0.6s;
	transition: top 0.6s;
	z-index: 1;
}
header.off_canvas {
	top: -89px;
}
header.fixed,
.ofh header {
	top: 0;
}
header .header_in {
	padding: 0 10px;
}
header nav {
	max-width: 1000px;
	margin: auto;
}
/* Title */
header nav h1,
header nav p {
	float: left;
	margin: 10px 30px 10px 0;
}
header nav h1 a,
header nav p a {
	display: block;
}
header nav h1 a img,
header nav p a img {
	height: 24px;
	display: block;
}
/* Global Navigation */
.g_nav {
	font-size: 0;
	float: left;
}
.g_nav li {
	font-size: 12px;
	display: inline-block;
}
.g_nav li a {
	height: 44px;
	color: #fff;
	text-decoration: none;
	line-height: 44px;
	display: block;
	position: relative;
	padding: 0 10px;
}
.g_nav li a:hover {
	color: #fff;
	opacity: 1;
}
.g_nav .hvr-bounce-to-right:before {
	background: #fb6964;
}
.navbar {
	display: none;
}
@media screen and (max-width: 719px) {
	/* Hamburger Menu */
	.navbar {
		display: block;
	}
	.navbar .navbar_toggle {
		width: 22px;
		height: 44px;
		background: transparent;
		position: absolute;
		top: 0;
		right: 10px;
		padding: 0;
		z-index: 3;
		cursor: pointer;
	}
	.navbar .navbar_toggle .sr_only {
		width: 1px;
		height: 1px;
		border: 0;
		position: absolute;
		overflow: hidden;
		clip: rect(0,0,0,0);
		margin: -1px;
		padding: 0;
	}
	.navbar .navbar_toggle .icon-bar {
		width: 22px;
		height: 2px;
		background-color: #fff;
		display: block;
		-webkit-transition: all 500ms ease-in-out;
		transition: all 500ms ease-in-out;
	}
	.navbar .navbar_toggle .icon-bar+.icon-bar {
		margin-top: 4px;
	}
	.navbar .navbar_toggle.active .icon-bar.center {
		background-color: transparent;
	}
	.navbar .navbar_toggle.active .icon-bar.top {
		-webkit-transform: rotate(45deg);
		transform: rotate(45deg);
		-webkit-transition: all 500ms ease-in-out;
		transition: all 500ms ease-in-out;
	}
	.navbar .navbar_toggle.active .icon-bar.bottom {
		-webkit-transform: rotate(-45deg);
		transform: rotate(-45deg);
		-webkit-transition: all 500ms ease-in-out;
		transition: all 500ms ease-in-out;
		margin-top: -8px;
	}
	.navbar .collapse {
		position: absolute;
		top:0;
		right: 0;
		left: 0;
		bottom: 0;
		z-index: 2;
		display: none;
	}
	.navbar .collapse .navbar_nav {
		width: calc(100vw - -100px); /* スクロールバーの横ずれ対策 */
		height: 100%;
		background-color: rgba(255, 255, 255, 0.95);
		position: fixed;
		overflow-y: auto;
		margin-top: 44px;
	}
	.navbar .collapse .navbar_nav ul li a {
		color: #333;
		font-size: 14px;
		text-decoration: none;
		border-bottom: 1px dotted #999;
		display: block;
		padding: 10px 20px;
	}
	.navbar .collapse .navbar_nav ul li:first-child a {
		/*border-top: 1px dotted #999;*/
	}
	.ofh {
		overflow: hidden;
	}
	.g_nav {
		display: none;
	}
}

/* パンくずリスト
======================================== */
.pankuzu {
	background: #f0f0f0;
}
.pankuzu_out {
	padding: 0 10px;
}
.pankuzu ul {
	max-width: 1000px;
	color: #333;
	font-size: 12px;
	line-height: 18px;
	margin: auto;
	padding: 5px 0;
	white-space: nowrap;
	text-overflow: ellipsis;
	overflow: hidden;
}
.pankuzu li {
	display: inline;
}
.pankuzu li:after {
	font-family: FontAwesome;
	content: "\f101";
	margin: 0 5px 0;
}
.pankuzu li:last-child:after {
	content: "";
}
.pankuzu li:last-child a {
	color: #333;
	pointer-events:none;
}
.pankuzu .home:before {
	font-family: FontAwesome;
	content: "\f015";
	margin-right: 5px;
}

/* フッター
======================================== */
#footer {
	width: 100%;
	height: 44px;
	font-size: 12px;
	color: #fff;
	text-align: center;
	line-height: 44px;
	background: rgba(82, 82, 82, .95);
	/* footer最下部固定用 */
	margin-top: auto;
}
#footer address {
	font-family: georgia, arial, sans-serif;
}
@media screen and (max-width: 719px) {
	#footer {
		font-size: 10px;
	}
}

/* トップへ戻るボタン
======================================== */
.page_top {
	width: 34px;
	height: 34px;
	position: fixed;
	right: 10px;
	bottom: 4px;
	cursor: pointer;
	display: none;
}
.page_top:after {
	content: "";
	background: rgba(255, 255, 255, .05);
	display: none;
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
}
.page_top:hover:after {
	display: block;
}
@media screen and (max-width: 719px) {
	.page_top:hover:after {
		display: none;
	}
}

/* お問い合わせ完了 / 検索結果無し / エラー404
======================================== */
.comp_message {
	background: #f0f0f0;
	padding: 20px;
}
.comp_message .top_text {
	color: #333;
	font-size: 18px;
	margin-bottom: 10px;
}
.comp_message .bottom_text {
	color: #333;
	font-size: 16px;
	margin-bottom: 10px;
}
.comp_message .button {
	float: right;
}
.comp_message .button li {
	-webkit-border-radius: 2px;
	border-radius: 2px;
	float: left;
}
.comp_message .button li a {
	width: 97px;
	height: 34px;
	color: #fff;
	font-size: 12px;
	text-align: center;
	line-height: 34px;
	display: block;
}
.comp_message .button li.home {
	background: #0076c0;
}
.comp_message .button li.mail {
	background: #2fb4c7;
	margin-right: 10px;
}
@media screen and (max-width: 719px) {
	.comp_message {
		padding: 15px;
	}
	.comp_message .top_text {
		font-size: 16px;
	}
	.comp_message .bottom_text {
		font-size: 14px;
	}
}