@charset "UTF-8";

/* メインコンテンツ 
======================================== */
.page-template-blog .main_content,
.page-template-all .main_content,
.single .main_content, 
.archive .main_content,
.search .main_content,
.page-template-blog .side_content,
.page-template-all .side_content,
.single .side_content, 
.archive .side_content,
.search .side_content {
	margin-bottom: 20px;
}
.introduction {
	font-size: 14px;
	margin: 15px 0;
}
.sub_title {
	font-size: 14px;
	font-weight: normal;
	line-height: 20px;
	background: linear-gradient(to bottom, #f0f0f0 0%, #fff 100%);
	border: 1px solid #bfbfbf;
	position: relative;
	margin-bottom: 12px;
	padding: 7px 10px;
}
.sub_title:before {
	content: "";
	border: 7px solid transparent;
	border-top: 7px solid #fff;
	position: absolute;
	bottom: -13px;
	left: 50%;
	transform: translate(-50%, 0);
	z-index: 2;
}
.sub_title:after {
	content: "";
	border: 7px solid transparent;
	border-top: 7px solid #bfbfbf;
	position: absolute;
	bottom: -14px;
	left: 50%;
	transform: translate(-50%, 0);
}
.entry-title {
	font-size: 14px;
	font-weight: normal;
	line-height: 20px;
	background: #525252;
	border-radius: 2px 2px 0 0;	
	margin: -15px -15px 15px;
	padding: 7px 10px;
}
.single .entry-title {
	color: #fff;
	margin: 0;
}
.entry-title a {
	color: #fff;
	font-weight: normal !important;
}
.entry-title a:hover {
	color: #fb6964;
}
.post,
.single section {
	font-size: 14px;
	line-height: 1.7em;
	text-align: justify;
	background: #f0f0f0;
	background: linear-gradient(to bottom, #f0f0f0 0%, #ffffff 10%, #ffffff 90%, #f0f0f0 100%);
	border-bottom: 2px dotted #ccc;
	padding: 15px;
}
.post img,
.single section img {
	margin: 5px 0;
}
.post a,
.single section a {
	font-weight: 600;
}
@media screen and (max-width: 719px) {
	.page-template-blog .main_content,
	.page-template-all .main_content,
	.single .main_content, 
	.archive .main_content,
	.search .main_content {
		margin-bottom: 0;
	}
	.page-template-blog .side_content,
	.page-template-all .side_content,
	.single .side_content, 
	.archive .side_content,
	.search .side_content {
		margin: 15px 0 0;
	}
	.entry-title {
		margin: -10px -10px 10px;
	}
	.entry-title a:hover {
		color: #fff;
	}
	.post,
	.single section {
		padding: 10px;
	}
}

/* サイドコンテンツ 
======================================== */
.side_area,
.side_area a {
	color: #666;
	font-size: 12px;
}
.side_area a:hover {
	color: #fb6964;
}
.side_area + .side_area {
	margin-top: 11px;
}
.side_area .title_block {
	color: #fff;
	background: #525252;
	border-radius: 2px 2px 0 0;
	padding: 6px 10px;
}
.side_area .block li a {
	background: #f0f0f0;
	border-bottom: 1px dotted #999;
	display: block;
	padding: 7px 10px;
}
.side_area .block li:last-child a {
	border-bottom: none;
}
.side_area .column_search {
	background: #f0f0f0;
	padding: 8px 10px;
}
@media screen and (max-width: 719px) {
	.side_area a:hover {
		color: #666;
	}
}

/* 検索エリア
======================================== */
.column_search {
	font-size: 0;
}
.column_search input {
	margin: 5px 0;
}
.column_search input[type="text"] {
	width: 86%;
	height: 25px;
	background: #fff;
	border: #525252 solid 1px;
	border-right: none;
	display: inline-block;
	margin: 0;
	padding: 0 3px;
}
.column_search input[type="submit"] {
	width: 14%;
	height: 25px;
	font-family: FontAwesome;
	color: #fff;
	background: #525252;
	border: #525252 solid 1px;
	-webkit-border-radius: 0 4px 4px 0;
	border-radius: 0 4px 4px 0;
	display: inline-block;
	vertical-align: top;
	margin: 0;
	padding: 0;
	cursor: pointer;
}

/* エントリーエリア
======================================== */
.entry {
	background: #f0f0f0;
	padding: 15px;
}
.entry .entry-utility {
	font-size: 13px;
	margin-bottom: 15px;
}
.entry .entry-parts {
	font-size: 11px;
	text-align: right;
}
.entry .home a:before,
.entry .comments-link a:before,
.entry .edit-link a:before {
	font-family: FontAwesome;
	content: '\f015';
	padding-right: 4px;
}
.entry .comments-link a:before {
	content: '\f27a';
}
.entry .edit-link a:before {
	content: '\f044';
}
@media screen and (max-width: 719px) {
	.entry {
		padding: 10px;
	}
}

/* ページネーション
======================================== */
.linear {
	padding: 20px 10px 0;
}
.linear_navi {
	color: #333;
	font-size: 0;
	text-align: center;
	margin: -4px;
}
.linear_navi a,
.linear_navi span {
	min-width: 27px;
	min-height: 27px;
	color: #fff;
	font-family: FontAwesome;
	font-size: 12px;
	text-decoration: none;
	line-height: 100%;
	background: #525252;
	border-radius: 2px;
	display: inline-block;
	margin: 4px;
	padding: 8px;
}
.linear_navi a:hover {
	background: #fa6863;
}
.linear_navi .current {
	background: #fa6863;
}
@media screen and (max-width: 719px) {
	.linear_navi a:hover {
		background: #525252;
	}
}

/* リニアナビ
======================================== */
.navigation {
	font-size: 0;
	margin: 20px 0;
}
.nav a {
	width: 50%;
	font-size: 12px;
	background: linear-gradient(to bottom, #f0f0f0 0%, #fff 100%);
	border: 1px solid #bfbfbf;
	display: block;
	float: left;
	padding: 7px 10px;
	white-space: nowrap;
	text-overflow: ellipsis;
	overflow: hidden;
}
.next a {
	float: right;
}
.next a:after {
	font-family: FontAwesome;
	content: '\f101';
}
.previous a:before {
	font-family: FontAwesome;
	content: '\f100';
}
.next {
	text-align: right;
	padding-left: 15px;
}
@media screen and (max-width: 719px) {
	.navigation {
		margin: 15px 0;
	}
}

/* コメントエリア
======================================== */
#comments-title {
	display: none;
}
.comment-respond {
	background: #f0f0f0;
}
.comment-form {
	padding: 15px;
}
.comment-reply-title {
	color: #fff;
	font-size: 14px;
	font-weight: normal;
	line-height: 20px;
	background: #525252;
	border-radius: 2px 2px 0 0;
	padding: 7px 10px;
}
.comment-reply-title:before {
	font-family: FontAwesome;
	content: '\f27a';
	padding-right: 5px;
}
.comment-form p {
	width: 100%;
	background: #fff;
	display: table;
}
.comment-form p + p {
	border-top: 1px solid #fff;
}
.comment-form p.comment-notes,
.comment-form p.logged-in-as {
	background: transparent;
	margin-bottom: 10px;
}
.comment-form p.comment-form-author {
	border-top: none;
}
.comment-form p.comment-form-cookies-consent,
.comment-form p.form-submit {
	border-top: none;
	background: transparent;    
}
.comment-form p.comment-form-cookies-consent input {
	display: none;
}
.comment-form p label {
	width: 30%;
	color: #fff;
	font-weight: normal;
	vertical-align: middle;
	background: #525252;
	display: table-cell;
	padding: 10px;
}
.comment-form p label[for="wp-comment-cookies-consent"] {
	width: auto;
	color: #333;
	background: transparent;
	padding: 10px 0 0;
}
.comment-form p .input_area {
	display: block;
	margin-right: 20px;
}
.comment-form p input,
.comment-form p textarea {
	width: 100%;
	display: table-cell;
	margin: 10px;
	padding: 5px;    
	border: 1px solid #525252;
}
.comment-form p textarea {
	height: 100px;
}
.required {
	color: #f08080;   
	font-weight: 600;
	display: inline-block;
	vertical-align: middle;
	padding-left: 3px;    
}
.comment-notes .required {
	padding-left: 0;
	padding-right: 3px;
}
.required-field-message .required {
	padding-left: 0;
}
#wp-comment-cookies-consent {
	width: auto;
}
.comment-form-cookies-consent label:before {
	font-family: FontAwesome;
	content: '\f0c8';
	color: #6998b9;
	font-size: 16px;
	vertical-align: middle;
	padding-right: 5px;
	cursor: pointer;
}
.comment-form-cookies-consent input:checked + label:before {
	font-family: FontAwesome;
	content: '\f14a';
}
.comment-form p.form-submit input.submit {
	width: 32%;
	font-family: FontAwesome;
	color: #fff;
	background: #6998b9;
	border: none;
	border-radius: 2px;
	margin: 10px auto 0;
	padding: 5px 0;
	cursor: pointer;
}
.comment-form p.form-submit input.submit:hover {
	opacity: .8;
}
@media screen and (max-width: 719px) {
	.comment-form {
		padding: 10px;
	}
	.comment-form p label {
		width: 100%;
		color: #fff;
		display: block;
	}
	.comment-form p input,
	.comment-form p textarea {
		display: block;
	}
	.comment-form p.form-submit input.submit:hover {
		opacity: 1;
	}
}

/* 全ての記事
======================================== */
.page-template-all .post {
	background: #fff;
	border-bottom: none;
	padding: 0;
}
.page-template-all .post:last-of-type {
	border-bottom: 1px solid #bfbfbf;
}
.page-template-all .post a {
	font-weight: normal;
}
.page-template-all .entry-title {
	margin: 0;
}
.page-template-all .thumbnail {
	width: 80px;
	height: 80px;
	position: relative;
	float: left;
	margin: 7px 10px 10px;
	overflow: hidden;
}
.page-template-all .thumbnail img {
	display: block;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	margin: 0;
}
.page-template-all .text {
	padding: 7px 10px 10px;
}
.page-template-all .entry {
	background: #fff;
	padding: 0 10px 7px;
}
.page-template-all .entry i {
	color: #5dd8cf;
}
.page-template-all .entry .entry-utility {
	font-size: 12px;
	float: right;
	margin: 0;
}
.page-template-all .entry .entry-parts {
	font-size: 12px;
	text-align: left;
	float: left;
}
@media screen and (max-width: 719px) {
	.page-template-all .thumbnail {
		display: none;
	}
	.page-template-all .text {
		padding: 7px 5px 10px;
	}
	.page-template-all .entry {
		padding: 0 5px 7px;
	}
}

/* YouTubeプレーヤー
======================================== */
.player {
	width: 100%;
	max-width: 605px;
	background: #ddd url(/wp-content/themes/harubaru/images/media/loader.gif) center center no-repeat;
	position: relative;
	margin: 5px 0;
	padding-top: 56.25%;
}
.player iframe {
	width: 100% !important;
	height: 100% !important;
	max-width: 605px;
	display: block;
	position: absolute;
	top: 0;
	right: 0;
}

/* 画像モーダルウィンドウ
======================================== */
.slbActive {
	overflow: hidden;
}
.slbOverlay, .slbWrapOuter, .slbWrap {
	position: fixed;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
}
.slbOverlay {
	background-color: rgba(0, 0, 0, 0.9);
	overflow: hidden;
	z-index: 2000;
	opacity: 1;
	-webkit-animation: slbOverlay 0.5s;
	animation: slbOverlay 0.5s;
}
.slbWrapOuter {
	overflow-x: hidden;
	overflow-y: auto;
	z-index: 2010;
}
.slbWrap {
	text-align: center;
	position: absolute;
}
.slbWrap:before {
	content: "";
	height: 100%;
	display: inline-block;
	vertical-align: middle;
}
.slbContentOuter {
	max-width: 100%;
	text-align: left;
	display: inline-block;
	vertical-align: middle;
	position: relative;
	margin: 0px auto;
	padding: 0 1em;
	z-index: 2020;
}
.slbContentEl .slbContentOuter {
	padding: 5em 1em;
}
.slbContent {
	position: relative;
}
.slbContentEl .slbContent {
	background-color: #fff;
	box-shadow: 0 0.2em 1em rgba(0, 0, 0, 0.4);
	-webkit-animation: slbEnter 0.3s;
	animation: slbEnter 0.3s;
}
.slbImageWrap {
	-webkit-animation: slbEnter 0.3s;
	animation: slbEnter 0.3s;
	position: relative;
}
.slbImageWrap:after {
	content: "";
	position: absolute;
	top: 5em;
	right: 0;
	bottom: 5em;
	left: 0;
	display: block;
	z-index: -1;
}
.slbImage {
	width: auto;
	max-width: 100%;
	height: auto;
	line-height: 0;
	display: block;
	margin: 0 auto;
	padding: 5em 0;
}
.slbCloseBtn {
	border: 0;
	background: none;
	margin: 0;
	padding: 0;
	cursor: pointer;
}
.slbCloseBtn::-moz-focus-inner,
.slbArrow::-moz-focus-inner {
	border: 0;
	padding: 0;
}
.slbCloseBtn:hover,
.slbArrow:hover {
	opacity: 0.8;
}
.slbCloseBtn:active,
.slbArrow:active {
	color: #fff;
}
.slbCloseBtn {
	width: 1.66667em;
	height: 1.66667em;
	color: #fefefe;
	font-size: 3em;
	text-align: center;
	line-height: 1.66667em;
	position: absolute;
	right: -0.33333em;
	top: 0;
	-webkit-animation: slbEnter 0.3s;
	animation: slbEnter 0.3s;
}
.slbLoading .slbCloseBtn {
	display: none;
}
.slbLoading .slbArrows {
	display: none;
}
.slbArrows, .slbArrow {
	display: none
}
@-webkit-keyframes slbOverlay {
	from {
	  opacity: 0;
	}
	to {
	  opacity: 1;
	}
}
@-moz-keyframes slbOverlay {
	from {
	  opacity: 0;
	}
	to {
	  opacity: 1;
	}
}
@keyframes slbOverlay {
	from {
	  opacity: 0;
	}
	to {
	  opacity: 1;
	}
}
@-webkit-keyframes slbEnter {
	from {
	  opacity: 0;
	  -webkit-transform: translate3d(0, -1em, 0);
	}
	to {
	  opacity: 1;
	  -webkit-transform: translate3d(0, 0, 0);
	}
}
@keyframes slbEnter {
	from {
	  opacity: 0;
	  -webkit-transform: translate3d(0, -1em, 0);
	  transform: translate3d(0, -1em, 0);
	}
	to {
	  opacity: 1;
	  -webkit-transform: translate3d(0, 0, 0);
	  transform: translate3d(0, 0, 0);
	}
}
@media screen and (max-width: 719px) {
	.slbCloseBtn:hover,
	.slbArrow:hover {
		opacity: 1;
	}
}