﻿@charset "utf-8";

/* -----------------------------------------------------------
	top_post
----------------------------------------------------------- */

.container_post {
	display: flex;
	flex-flow: row wrap;
	margin: 30px -10px 0px;
}

.post_box {
	flex-basis: 33%;
	margin-bottom: 50px;
    padding: 0 10px 0;
}

.post_image {
	margin: 0px 0 10px 0px;
}

.post_image img {
	width: 100%;
    height: 250px;
    object-fit: cover;
	border: 2px solid #fff;
	transition: all 0.3s;
	-webkit-transition: all 0.3s;
}

.post_image img:hover {
	opacity: 0.8;
	border: 2px solid #125c81;
}
.post_meta {
	margin: 0 0 5px;
}
.post_ttl {
	margin: 0px 0 5px 0px;
}
.post_ttl a {
	color: #002d43;
}
.post_ttl a:hover {
	color: #125c81;
	text-decoration: underline;
}
.category_btn {
	font-size: 80%;
	padding: 3px 7px;
	background: #002d43;
	color: #fff;
	border-radius: 3px;
	margin-left: 10px;
}
.category_btn:hover {
	background: #125c81;
}
.category_btn a {
	color: #fff;
}

@media screen and (max-width: 767px) {
	.container_post {
		flex-flow: column;
		margin: 30px 0 0;
	}
	.post_box {
		flex-basis: 100%;
		margin-bottom: 30px;
		padding: 0;
	}
}


/* -----------------------------------------------------------
	blog
----------------------------------------------------------- */

.blog_wrap {
	display: flex;
	flex-flow: row nowrap;
	gap: 50px;
	width: 80%;
	max-width:1200px;
	margin: 100px auto;
}
.blog_main {
	flex: 1;
}
.blog_main_txt p {
	margin: 30px 0;
}
.blog_sidebar {
	width: 25%;
}

@media screen and (max-width: 767px) {
	.blog_wrap {
		flex-flow: column;
		width: 100%;
		margin: 70px 0;
		padding: 0 30px;
	}
	.blog_sidebar {
		width: 100%;
	}
}

.blog_main_ttl {
	font-size: 1.7rem;
	color: #002d43;
	margin: 10px 0 40px;
	padding: 0 0px 5px;
	border-bottom: 2px solid #002d43;
}

/*blog_sidebar*/
.blog_sidebar_ttl {
	position: relative;
	margin: 0 0 10px;
    padding-top: 7px;
    padding-bottom: 7px;
    padding-left: 25px;
    border: 1px solid #002d43;
    color: #002d43;
	font-weight: 700;
    background: #dfecf3;
	background: linear-gradient(#fff, #dfecf3);
}
.blog_sidebar_ttl::after {
	position: absolute;
	top: 0.5em;
	left: 0.7em;
	content: '';
	width: 5px;
	height: -webkit-calc(100% - 1em);
	height: calc(100% - 1em);
	background-color: #002d43;
}

@media screen and (max-width: 767px) {
	.blog_main_ttl {
		font-size: 1.5rem;
		margin: 10px 0 30px;
		padding: 0;
	}
}

.widget_container {
    margin: 0px 0 40px;
}

.widget_container li {
    position: relative;
    border-bottom: 1px solid #dadada;
}

.widget_container li a {
	display: block;
	color: #002d43;
	padding: 15px 10px;
}

.widget_container li a::after {
	font-family: 'Font Awesome 5 Free';
	content: "\f054";
    position: absolute;
	top: 50%;
    right: 10px;
	font-weight: 900;
	font-size: 0.7rem;
	margin-top: -10px; 
}

.widget_container li a:hover {
	color: #56add7;
	transition: all 0s ease;
}

/*blog_sidebar_new*/

.blog_sidebar_new {
	display: flex;
	flex-flow: row nowrap;
	margin: 25px 0px;
	padding: 0 0 20px;
	border-bottom: 1px dotted #666;
}
.new_img {
	flex: 1;
	margin: 0 10px 0 0;
}
.new_img img:hover {
	opacity: 0.8;
}
.new_meta {
	font-size: 0.8rem;
}
.new_txt {
	flex: 2;
}
.new_ttl {
	margin-top: 5px;
	line-height: 1.5;
}
.new_ttl a {
	color: #002d43;
}
.new_ttl a:hover {
	color: #125c81;
	text-decoration: underline;
}


/*blog_box*/

.blog_box {
	display: flex;
	flex-flow: row nowrap;
	margin: 30px 0px;
	padding: 0 0 20px;
	gap: 30px;
	border-bottom: 1px dotted #666;
}
.blog_ttl {
	margin: 0px 0 10px;
}
.blog_ttl a {
	font-size: 1.6rem;
	color: #002d43;
}
.blog_ttl a:hover {
	color: #125c81;
	text-decoration: underline;
}
.blog_image {
	width: 270px;
}
.blog_txt {
	flex: 1;
}
.blog_image img {
	width: 100%;
    height: 200px;
    object-fit: cover;
	border: 2px solid #fff;
	transition: all 0.3s;
	-webkit-transition: all 0.3s;
}
.blog_image img:hover {
	opacity: 0.8;
	border: 2px solid #125c81;
}

@media screen and (max-width: 767px) {
	.blog_box {
		flex-flow: column;
		width: 100%;
	}
	.blog_ttl a {
		font-size: 1.3rem;
	}
	.blog_image {
		width: 100%;
		margin-bottom: -20px;
	}
	.blog_image img {
		height: 250px;
	}
}

.related_container {
	margin: 30px 0 0;
}
.related_ttl {
	color: #fff;
	text-align: center;
	padding: 5px 0;
	background: #002d43;
}


/* -----------------------------------------------------------
	pagination
----------------------------------------------------------- */

.pagination {
	display: flex;
	flex-flow: row wrap;
	justify-content: center;
	margin: 50px 0 0;
}
.pagination a, .pagination span {
	margin: 0 10px 0px 0;
	border: 1px solid #e6e6e6;
	background: #ecf3f6;
}

.pagination a, .pagination span {
	display: block;
	color: #002d43;
	padding: 5px 15px 5px;
}

.pagination span {
	color: #fff;
	background-color: #002d43;
	padding: 5px 15px 5px;
}
.pagination a:hover {
	color: #fff;
	background: #002d43;
}
.pagination a.prev::before{
	font-family: 'Font Awesome 5 Free';
	content: "\f053";
	font-size: 0.9rem;
	padding-right: 7px;
	font-weight: 900;
}
.pagination a.next::after{
	font-family: 'Font Awesome 5 Free';
	content: "\f054";
	font-size: 0.9rem;
	padding-left: 7px;
	font-weight: 900;
}


@media screen and (max-width: 559px) {
	.pagination {
		margin: 10px 0;
	}
	.pagination a, .pagination span {
		margin: 10px 10px 0 0px;
	}
}

/*page_navi*/
.page_navi {
	margin: 50px 0 0;
	padding: 20px 0;
	border-top: 1px dotted #999;
}
.page_navi p {
	margin: 5px 0 0;
}
.page_navi a {
	color: #0b94d9;
}
.page_navi a:hover {
	color: #125c81;
	text-decoration: underline;
}
@media screen and (max-width: 559px) {
	.page_navi p {
		margin: 20px 0 0;
	}
}

/* -----------------------------------------------------------
	search
----------------------------------------------------------- */

.blog_sidebar_search {
	position:relative;
	margin: 20px 0;
}
.search_text {
	width: 100%;
	height: 40px;
	font-size: 1rem;
	line-height: 40px;
	letter-spacing: 1.5px;
	padding-left: 10px;
	border: 1px solid #002d43;
	border-radius: 3px 0 0 3px;
	vertical-align: top;
}

/* Form submit button */
.search_wrapper button {
	position:absolute;
	top:0;
	right:0;
	width: 100px;
	height: 40px;
	color: #fff;
	background: #002d43;
	border-radius: 0 3px 3px 0;
	cursor: pointer;
}

.search_wrapper button:hover,
.search_wrapper button:active,
.search_wrapper button:focus {
	background: #125c81;
	outline: 0;
}
.search_wrapper button:before { /* arrow */
	content: '';
	position: absolute;
	border-width: 8px 8px 8px 0;
	border-style: solid solid solid none;
	border-color: transparent #002d43 transparent;
	top: 12px;
	left: -6px;
}

.search_wrapper button:hover:before,
.search_wrapper button:focus:before,
.search_wrapper button:active:before {
	border-right-color: #125c81;
}
