@charset "UTF-8";

/* 共通 */
#postList:before {
	content: "";
	display: block;
	background: #009333;
}
#postList > .title {
	color: #fff;
	position: relative;
	text-align: center;
	background: #005033;
}
#postList > .title:before {
	top: 0;
	left: 0;
	z-index: 0;
	content: "";
	width: 100%;
	height: 50%;
	display: block;
	background: #00330a;
	position: absolute;
}
#postList > .title span {
	z-index: 1;
	position: relative;
	display: inline-block;
	vertical-align: middle;
}
#postList .paging {
	text-align: center;
}
#postList .paging > * {
	vertical-align: middle;
}
#postList .paging .pager:after,
#postList .paging .pager:first-of-type:before {
	content: "｜";
	display: inline-block;
}
@media screen and (min-width:769px){
	#postList:before {
		height: 100px;
		width: calc(50% + 270px);
	}
	#postList > .title {
		width: 200px;
		height: 200px;
		font-size: 20px;
		line-height: 200px;
		margin: -100px 0 -100px calc(50vw - 430px);
		position: relative;
	}
	#postList > .title span {
		line-height: 1.5;
	}
	#postList .paging {
		font-size: 20px;
		margin-top: 100px;
	}
	#postList .paging .arrow {
		font-size: 16px;
	}
	#postList .paging .arrow:last-child {
		margin-left: 20px;
	}
	#postList .paging .arrow:first-child {
		margin-right: 20px;
	}
}
@media screen and (max-width:768px){
	#postList {
		padding-bottom: 375px;
	}
	#postList:before {
		height: 50px;
	}
	#postList > .title {
		width: 100px;
		height: 100px;
		margin: -50px 5px;
		line-height: 100px;
	}
	#postList > .title span {
		line-height: 15px;
		line-height: 22.5px;
	}
	#postList .list {
		overflow: hidden;
		position: relative;
	}
	#postList .list:after {
		left: 0;
		bottom: 0;
		width: 100%;
		content: "";
		display: block;
		position: absolute;
		box-shadow: 0 0 100px 100px #fff;
	}
	#postList .paging {
		font-size: 15px;
		background: #fff;
	}
	#postList .paging .arrow {
		font-size: 12px;
	}
}

/* 記事一覧 */
#postList.post .list li {
	position: relative;
}
#postList.post .list li + li {
	margin-top: 50px;
}
#postList.post .list li .box {
	background: #fff;
	position: absolute;
	writing-mode: vertical-rl;
	-ms-writing-mode: tb-rl;
	-webkit-writing-mode: vertical-rl;
	text-orientation: upright;
	z-index: 3;
}
#postList.post .list li .box a {
	box-sizing: border-box;
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
}
#postList.post .list li figure {
	position: relative;
}
#postList.post .list dd {
	overflow: hidden;
}
#postList.post .list li a > p {
	left: 0;
	bottom: 0;
	color: #fff;
	position: absolute;
	background: #009333;
	font-family: "游ゴシック体", YuGothic, "游ゴシック","Yu Gothic","メイリオ",Meiryo,"ＭＳ Ｐゴシック","Verdana",sans-serif;
}
#postList.post .list li img {
	max-width: 100%;
}
@media screen and (min-width:769px){
	#postList.post .list {
		padding-top: 300px;
		padding-bottom: 100px;
	}
	#postList.post .list li {
		margin: 0 auto;
		max-width: 980px;
	}
	#postList.post .list li:after {
		content: "";
		display: block;
		clear: both;
	}
	#postList.post .list li:nth-child(odd) figure { float: right; }
	#postList.post .list li:nth-child(even) figure { float: left; }
	#postList.post .list li figure:after {
		top: 100px;
		content: "";
		width: 100%;
		height: 100%;
		display: block;
		background: #f5f5eb;
		position: absolute;
		z-index: 0;
	}
	#postList.post .list li:nth-child(odd) figure:after {
		left: 220px;
	}
	#postList.post .list li:nth-child(even) figure:after {
		right: 220px;
	}
	#postList.post .list li figure {
		width: 790px;
	}
	#postList.post .list li figure a {
		z-index: 1;
		position: relative;
	}
	#postList.post .list li .box a {
		height: 380px;
		display: block;
		padding: 40px 30px 40px 50px;
	}
	#postList.post .list li:nth-child(odd) .box { bottom: 0; left: 0; }
	#postList.post .list li:nth-child(even) .box { right: 0; top: 0; }
	#postList.post .list li dt {
		font-size: 28px;
		line-height: 48px;
	}
	#postList.post .list li dd {
		font-size: 15px;
		line-height: 30px;
		max-width: 90px;
	}
	#postList.post .list li a > p {
		padding: 12px 7px;
	}
}
@media screen and (max-width:768px){
	#postList.post .list {
		margin-top: 100px;
		padding-bottom: 1px;
		background: #f5f5eb;
	}
	#postList.post .list li {
		margin-bottom: 320px;
	}
	#postList.post .list li figure {
		text-align: center;
	}
	#postList.post .list li figure img {
		/*max-width: 168%;*/
		/*margin: 0 -1000px;*/
	}
	#postList.post .list li .box {
		top: 76.6%;
	}
	#postList.post .list li:nth-child(odd) .box { left: 20px; }
	#postList.post .list li:nth-child(even) .box { right: 20px; }
	#postList.post .list li .box a {
		height: 285px;
		display: block;
	}
	#postList.post .list li .box dl {
		padding: 30px 20px 30px 43px;
	}
	#postList.post .list li .box dt {
		font-size: 21px;
		line-height: 36px;
		margin-left: 2px;
	}
	#postList.post .list li .box dd {
		font-size: 11px;
		line-height: 22.5px;
	}
	#postList.post .list li a > p {
		font-size: 10px;
		padding: 12px 6px;
	}
}

/* お知らせ一覧 */

#postList.topics figure {
	overflow: hidden;
	text-align: center;
}
#postList.topics figure img {
	max-width: 100%;
	margin: 0 -500px;
}
@media screen and (min-width:751px) {
	#postList.topics ul {
		max-width: 840px;
		margin: 300px auto 0;
	}
	#postList.topics li + li {
		margin-top: 100px;
	}
	#postList.topics li a {
		display: block;
		overflow: hidden;
	}
	#postList.topics figure {
		float: left;
		width: 286px;
		margin-right: 40px;
	}
	#postList.topics dt {
		font-size: 18px;
		line-height: 30px;
		padding-top: 32px;
	}
	#postList.topics dd {
		font-size: 15px;
		line-height: 30px;
		margin-top: 7px;
	}
}
@media screen and (max-width:750px) {
	#postList.topics ul {
		padding: 0 80px;
		margin-top: 155px;
		margin-bottom: 85px;
	}
	#postList.topics li + li {
		margin-top: 46px;
	}
	#postList.topics dt {
		font-size: 13.5px;
		line-height: 22.5px;
		margin: 17px 0 6px;
	}
	#postList.topics dd {
		font-size: 11px;
		line-height: 22.5px;
	}
	#postList .list:after {
		content: none;
	}
}