.blog_contents{
	max-width: 1200px;
	margin: auto;
}

#left_area,#right_area{
	float: left;
}
#left_area{
	width: 72%;
	padding-right: 25px;
	box-sizing: border-box;
}
#right_area{
	width: 27%;
	padding-left: 25px;
	box-sizing: border-box;
}
.blog_area{
	width: 100%;
	border-top: 1px solid #ccc;
	padding: 20px 0px;
	color: #3c3c3c;
}
.blog_area .thumb,
.blog_area .text{
	display: inline-block;
	vertical-align: top;
}
.blog_area .thumb{
	width: 25%;
	background-position: top center;
	background-size: cover;
	background-repeat: no-repeat;
}
.blog_area .thumb:before {
  content: "";
  display: block;
  padding-top: 75%;
}

.blog_area .text{
	width: 64%;
	padding-left: 25px;
	box-sizing: border-box;
}
.blog_area .text h2.titles{
	font-weight: bold;
}
.blog_area .text p.day{
	font-size: 0.8em;
	color: #999999;
}
.blog_area .text p.detail{
	font-size: 0.8em;
	margin-top: 15px;
}
.blog_area .text p.more{
	font-size: 0.8em;
	text-align: right;
}
.blog_area .text p.more img{
	width: 40px;
	vertical-align: baseline;
}

ul.taglist{
	margin-top: 15px;
	margin-bottom: 40px;
	width: 100%;
	list-style: none;
	border-top: 1px solid #999999;
}
ul.taglist li{
	font-size: 0.8em;
	border-bottom: 1px solid #999999;
	padding: 8px 10px;
}
ul.taglist li span{
	float: right;
}
li.month,
li.archives_parent{
	position: relative;
}
li.month::after{
	content: "";
	background: url("/_common/imgs/arrow_right.svg") top left no-repeat;
    width: 15px;
    height: 25px;
    position: absolute;
    right: 0;
    top: 15px;
}
li.archives_parent{
	cursor: pointer;
}
li.archives_parent::after{
	content: "";
	background: url("/_common/imgs/arrow_down.svg") top left no-repeat;
    width: 15px;
    height: 25px;
    position: absolute;
    right: 0;
    top: 15px;
}
li.active::after {
	background: url("/_common/imgs/arrow_right.svg") top left no-repeat !important;
}

ul.archives_child{
	display: none;
	list-style: none;
}
ul.archives_child li{
	padding-left: 30px;
}
.blog_margin{
	margin: auto;
}

#blogs{
	padding: 25px;
	margin-bottom: 40px;
}
#blogs h1{
	margin-bottom: 15px;
}
#blogs p.day{
	font-size: 0.9em;
	color: #999999;
}
#blogs a{
	margin: 0 !important;
}
#blogs img{
	max-width: 100%;
}
#blogs .thumbimg{
	width: 100%;
	height: auto;
	margin-bottom: 40px;
}
#blogs h2 span,
#blogs h3 span{
    display: block;
    padding-top: 100px;
    margin-top: -100px;
}
.tag_detail{
	margin: 40px 0px;
	padding: 20px;
	border-top: 1px solid #999999;
	border-bottom: 1px solid #999999;
	font-size: 0.9em;
	box-sizing: border-box;
}

#searchform{
	margin-top: 20px;
	margin-bottom: 40px;
	position: relative;
}
#searchform input,
#searchform button{
	padding: 5px;
	font-size: 1em;
}
#searchform input{
	width: 100%;
	box-sizing: border-box;
	border: transparent;
	background: #ececec;
	border-radius: 20px;
	padding: 15px;
	box-sizing: border-box;
	font-size: 0.8em;
}
#searchform button{
  position: absolute;
  right: 5px;
  top: 5px;
  background-color: transparent;
  border: 0;
}
#searchform button:focus,
#searchform button:focus-visible{
	outline: none;
}
#searchform button img{
	width: 25px;
	height: 25px;
	cursor: pointer;
}
#searchform button img:hover{
	opacity: 0.6;
}
.newold{
	margin-bottom: 30px;
	font-size: 1.1em;
}
.newold p.prev{
	float: left;
}
.newold p.next{
	float: right;
}
.clear_tag{
	clear: both;
	margin-bottom: 40px;
}

@media only screen and (max-width: 896px){
	#left_area,#right_area{
		float: none;
		width: 100%;
		padding: 0px;
		vertical-align: unset;
	}
	#left_area,#right_area{
		padding: 0px 20px;
	}
	.blog_area .text p.day,
	.blog_area .text p.detail,
	.blog_area .text p.more,
	ul.taglist li{
		font-size: 0.9em;
	}
	.tag_detail{
		margin-bottom: 80px;
	}
	#searchform input,
	#searchform button{
		font-size: 1.1em;
	}
	#searchform button img {
    width: 30px;
    height: 30px;
	}
}


/* pager */
.pagination {
	clear:both;
	margin: auto;
	text-align: center;
	border-top: 1px solid #ccc;
	padding-top: 30px;
	margin-bottom: 60px;
}
.pagination span, .pagination a {
  display: inline-block;
  padding: 5px 15px;
  text-decoration: none;
  background: #ececec;
  color: #3c3c3c;
  margin: 0px 5px;
}
.pagination span.dotted{
	font-size: 0.8em;
}

.pagination a:hover{
	color:#fff;
	background: #046eb8;
}
 
.pagination .current{
	background: #046eb8;
	color:#fff;
}


.blogheader{
	background-color: #009FE9;
	text-align: center;
	padding: 30px 0px;
	margin: 70px auto 40px;
}
.blogheader img{
	width: 130px;
}

#blogs p.day{
	margin-bottom: 40px;
}

.blog_detail h1{
	font-size: 1.2em;
	margin-bottom: 20px;
	border-top: 5px solid #009FE9;
	border-bottom: 5px solid #009FE9;
	padding: 15px 0px;
}

.blog_detail h2{
	font-size: 1.1em;
	margin: 40px 0px 20px;
	border-top: 3px solid #b8e4fc;
	border-bottom: 3px solid #b8e4fc;
	padding: 15px 0px;
}
.blog_detail h3{
	font-size: 1.1em;
	margin: 30px 0px 10px;
	border-bottom: 2px solid #ccc;
	padding-bottom: 10px;
}
.blog_detail strong{
	font-weight: normal;
	background: linear-gradient(transparent 70%, #b8e4fc 30%);
}

/* toc */
#toc_container{
	width: 100%;
	background: #ececec;
	padding: 15px;
	box-sizing: border-box;
	margin: 30px 0px;
	display: table;
	font-size: 95%;
}
#toc_container p.toc_title{
	border-bottom: 1px solid #c7c7c7;
	font-size: 1.1em;
	margin-left: 5px;
	padding-bottom: 5px;
	margin-bottom: 5px;
}
#toc_container ul li{
	margin-left: 25px;
}

/* sidebar */

#sidebar1 #categories-2{
	margin-top: 40px;
	margin-bottom: 60px;
}
#sidebar1 #categories-2 h4{
	border-bottom: 1px solid #ccc;
	padding-bottom: 5px;
	margin-bottom: 10px;
}
#sidebar1 #categories-2 ul,
#sidebar1 #categories-2 ul li{
	list-style: none;
}
#sidebar1 #categories-2 ul li{
	padding: 10px 0px;
	box-sizing: border-box;
	border-bottom: 1px solid #ccc;
}
#sidebar1 #categories-2 ul li a{
	color: #3c3c3c;
}