@charset "utf-8";
/* CSS Document */

/* constructs ==============================================================
	1. p-content
	2. p-constructLink
	3. p-constructTitle
	4. p-constructArea
	5. p-constructSingleArea
	6. p-sidebar
	7. p-nothing
======================================================================== */

/* =====================================================================
	1. p-content
======================================================================== */
.p-content {
	margin: 0 0 100px;
}
@media screen and (max-width: 799px) {
	.p-content {
		overflow: hidden;
	}
}

/* =====================================================================
	2. p-constructLink
======================================================================== */
.p-constructLink {
	display: table;
	width: 100%;
	margin: auto;
	text-align: center;
}
.p-constructLink .menu-item {
	float: left;
	display: inline-block;
	width: 300px;
	height: 50px;
	margin: 20px 14px;
}
.p-constructLink .menu-item a {
	display: block;
	width: 300px;
	height: 50px;
}
.p-constructLink .p-building.menu-item {
	background: url(../img/constructs/link_building.png) no-repeat center center;
}
.p-constructLink .p-building.current-menu-item {
	background: url(../img/constructs/link_building_current.png) no-repeat center center;
}
.p-constructLink .p-civileng.menu-item {
	background: url(../img/constructs/link_civileng.png) no-repeat center center;
}
.p-constructLink .p-civileng.current-menu-item {
	background: url(../img/constructs/link_civileng_current.png) no-repeat center center;
}
.p-constructLink .p-housing.menu-item {
	background: url(../img/constructs/link_housing.png) no-repeat center center;
}
.p-constructLink .p-housing.current-menu-item {
	background: url(../img/constructs/link_housing_current.png) no-repeat center center;
}
.p-constructLink .menu-item a:hover {
	background-color: rgba(255,255,255,0.5);
	transition: .4s linear;
  -webkit-transition: .4s linear;
  -moz-transition: .4s linear;
  -o-transition: .4s linear;
  -ms-transition: .4s linear;
}
.tinynav {
	display: none;
}
@media screen and (max-width: 799px) {
	.p-constructLink {
		display: none;
	}
	.tinynav { 
		display: block;
		width: auto;
		text-align: center;
		margin: 20px auto;
		overflow: hidden;
	}
}

/* =====================================================================
	3. p-constructTitle
======================================================================== */
.p-constructTitle {
	width: auto;
	height: 130px;
	margin: 0 15px 20px;
	text-align: center;
}
.p-constructTitle.p-building {
	background: url(../img/constructs/tit_building.png) no-repeat center;
	background-size: auto 130px;
}
.p-constructTitle.p-civileng {
	background: url(../img/constructs/tit_civileng.png) no-repeat center;
	background-size: auto 130px;
}
.p-constructTitle.p-housing {
	background: url(../img/constructs/tit_housing.png) no-repeat center;
	background-size: auto 130px;
}

.p-constructLocation {
	width: 960px;
	height: 590px;
	margin: 0 auto 40px;
	border: #CCCCCC solid 5px;
	box-sizing: border-box;
}
@media screen and (max-width: 799px) {
	.p-constructLocation {
		display: table;
		width: 90%;
		height: 40vh;
		margin: 0 auto 20px;
		text-align: center;
	}
}

/* =====================================================================
	4. p-constructArea
======================================================================== */
.p-constructArea {
	float: left;
	display: inline-block;
	width: 646px;
	margin: 0 7px 30px;
	text-align: center;
}
.p-constructArea .p-constructList {
	display:-webkit-box;
	display:-moz-box;
	display:-ms-box;
	display:-webkit-flexbox;
	display:-moz-flexbox;
	display:-ms-flexbox;
	display:-webkit-flex;
	display:-moz-flex;
	display:-ms-flex;
	display:flex;
	-webkit-box-lines:multiple;
	-moz-box-lines:multiple;
	-webkit-flex-wrap:wrap;
	-moz-flex-wrap:wrap;
	-ms-flex-wrap:wrap;
	flex-wrap:wrap;
}
.p-constructArea .p-constructList .c-list {
	float: left;
	display: inline-block;
	vertical-align: top;
	list-style: none;
	width: 145px;
	margin: 0 8px 45px;
}
.p-constructArea .p-constructList .c-eyecatch a:hover img {
	opacity: 0.7;
	transition: .4s linear;
  -webkit-transition: .4s linear;
  -moz-transition: .4s linear;
  -o-transition: .4s linear;
  -ms-transition: .4s linear;
}
.p-constructArea .p-constructList .c-category a {
	text-decoration: none;
}
.p-constructArea .p-constructList .c-name {
	font-weight: normal;
}
.p-constructArea .p-constructList .c-name a {
	text-decoration: none;
}
.p-constructArea .wp-pagenavi {
	margin: 0 0 30px;
}
@media screen and (max-width: 799px) {
	.p-constructArea {
		float: none;
		display: block;
		width: auto;
		margin: 0;
		overflow: hidden;
	}
	.p-constructArea .p-constructList {
		width: auto;
		display: block;
		text-align: center;
		overflow: hidden;
	}
	.p-constructArea .p-constructList .c-list {
		float: none;
	}
}

/* =====================================================================
	5. p-constructSingleArea
======================================================================== */
.p-constructSingleArea {
	text-align: center;
	margin: 0 35px;
}
.p-constructSingleArea .p-eyecatch {
	margin: 0 0 20px;
}
.p-constructSingleArea .p-eyecatch img {
	max-width: 920px;
	height: auto;
}
.p-constructSingleArea .p-constructTitle {
	position: relative;
	width: 920px;
	height: auto;
	min-height: 50px;
	margin: 0 auto 20px;
	padding: 0 0 0 36px;
	box-sizing: border-box;
	border: #E4E4E4 solid 1px;
	font-weight: normal;
	font-size: 3.0rem;
	line-height: 5.0rem;
	text-align: left;
}
.p-constructSingleArea .p-constructTitle:before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	min-height: 100%;
	border-left: #666666 solid 10px;
}
.p-constructSingleArea .p-constructTable {
	width: 920px;
	height: auto;
	min-height: 50px;
	margin: 0 auto 45px;
	border-collapse: collapse;
	border: #CCCCCC solid 1px;
}
.p-constructSingleArea .p-constructTable .c-tableHead {
	width: 170px;
	padding: 1.0rem 2.0rem;
	border: #CCCCCC solid 1px;
	text-align: left;
	vertical-align: top;
	background-color: #EFEFEF;
}
.p-constructSingleArea .p-constructTable .c-tableData {
	width: auto;
	padding: 1.0rem 2.0rem;
	border: #CCCCCC solid 1px;
	text-align: left;
	vertical-align: top;
}
.p-constructSingleArea .p-constructTable .c-location {
	width: 100%;
	height: 400px;
	border: #CCCCCC solid 5px;
	box-sizing: border-box;
}
.p-constructSingleArea .p-navigation {
	display: block;
	height: 50px;
	margin: 0 0 100px;
}
.p-constructSingleArea .p-navigation .p-alignleft {
	display: inline-block;
	width: 300px;
	height: 50px;
	margin: 0 10px 0 auto;
}
.p-constructSingleArea .p-navigation .p-alignleft a {
	display: block;
	width: 300px;
	height: 50px;
	box-sizing: border-box;
	border: #E4E4E4 solid 1px;
	background: url(../img/constructs/link_before.png) no-repeat center;
	background-size: 140px 48px;
}
.p-constructSingleArea .p-navigation .p-alignleft a:hover {
	background: url(../img/constructs/link_before.png) no-repeat center, #EEEEEE;
	background-size: 140px 48px;
	transition: .4s linear;
  -webkit-transition: .4s linear;
  -moz-transition: .4s linear;
  -o-transition: .4s linear;
  -ms-transition: .4s linear;
}
.p-constructSingleArea .p-navigation .p-alignright {
	display: inline-block;
	width: 300px;
	height: 50px;
	margin: 0 auto 0 10px;
}
.p-constructSingleArea .p-navigation .p-alignright a {
	display: block;
	width: 300px;
	height: 50px;
	box-sizing: border-box;
	border: #E4E4E4 solid 1px;
	background: url(../img/constructs/link_next.png) no-repeat center;
	background-size: 140px 48px;
}
.p-constructSingleArea .p-navigation .p-alignright a:hover {
	background: url(../img/constructs/link_next.png) no-repeat center, #EEEEEE;
	background-size: 140px 48px;
	transition: .4s linear;
  -webkit-transition: .4s linear;
  -moz-transition: .4s linear;
  -o-transition: .4s linear;
  -ms-transition: .4s linear;
}
@media screen and (max-width: 799px) {
	.p-constructSingleArea .p-eyecatch img {
		max-width: 100%;
		height: auto;
	}
	.p-constructSingleArea .p-constructTitle {
		width: auto;
	}
	.p-constructSingleArea .p-constructTable {
		width: 100%;
	}
	.p-constructSingleArea .p-constructTable .c-tableHead {
		display: block;
		width: auto;
	}
	.p-constructSingleArea .p-constructTable .c-tableData {
		display: block;
	}
	.p-constructSingleArea .p-constructTable .c-location {
		height: 250px;
	}
	.p-constructSingleArea .p-navigation {
		margin: 0 0 50px;
	}
	.p-constructSingleArea .p-navigation .p-alignleft {
		width: 140px;
		margin-right: 5px;
	}
	.p-constructSingleArea .p-navigation .p-alignleft a {
		width: 140px;
	}
	.p-constructSingleArea .p-navigation .p-alignright {
		width: 140px;
		margin-left: 5px;
	}
	.p-constructSingleArea .p-navigation .p-alignright a {
		width: 140px;
	}
}

/* =====================================================================
	6. p-sidebar
======================================================================== */
.p-sidebar {
	float: right;
	display: inline-block;
	width: 300px;
	margin: 0 15px;
}
.p-sidebar .c-sideWidget {
	width: 300px;
	margin: 0 0 50px;
}
.p-sidebar .c-sideWidget .c-widgetTitle {
	width: 300px;
	height: 50px;
	margin: 0 0 15px;
}
.p-sidebar .c-sideWidget.widget_recent_entries .c-widgetTitle {
	background: url(../img/constructs/tit_case.png) no-repeat;
	background-size: 300px 50px;
}
.p-sidebar .c-sideWidget.widget_recent_entries li {
	position: relative;
	margin: 0 0 15px 15px;
	list-style: none;
	font-size: 1.4rem;
	line-height: 2.2rem;
	text-align: left;
}
.p-sidebar .c-sideWidget.widget_recent_entries li a {
	position: relative;
	top: 20px;
	display: block;
	padding: 0 0 20px;
	text-decoration: none;
}
.p-sidebar .c-sideWidget.widget_recent_entries .post-date {
	position: absolute;
	top: 0;
	left: 0;
	float: left;
	display: block;
	font-weight: bold;	
}
.p-sidebar .c-sideWidget.widget_categories .c-widgetTitle {
	background: url(../img/constructs/tit_category.png) no-repeat;
	background-size: 300px 50px;
}
.p-sidebar .c-sideWidget.widget_categories .cat-item {
	margin: 0 0 15px 35px;
	font-weight: bold;
	font-size: 1.4rem;
	line-height: 2.2rem;
	text-align: left;
}
.p-sidebar .c-sideWidget.widget_categories .cat-item a {
	text-decoration: none;
}
.p-sidebar .c-sideWidget.widget_search .c-widgetTitle {
	background: url(../img/constructs/tit_search.png) no-repeat;
	background-size: 300px 50px;
}
.p-sidebar .c-sideWidget.widget_search .screen-reader-text {
	color: #FFFFFF;
	width: 15px;
	height: 34px;
	font-size: 5px;
}
.p-sidebar .c-sideWidget.widget_search input[type="text"] {
	width: 218px;
	height: 30px;
	margin: 0;
	padding: 0;
	border: #CCCCCC solid 1px;
}
.p-sidebar .c-sideWidget.widget_search input[type="submit"] {
	float: right;
	width: 54px;
	height: 34px;
	background-color: #666666;
	border: none;
	border-radius: 0;
	font-weight: bold;
	color: #FFFFFF;
}
.p-sidebar .c-sideWidget.widget_search input[type="submit"]:hover {
	cursor: pointer;
	opacity: 0.7;
	transition: .4s linear;
  -webkit-transition: .4s linear;
  -moz-transition: .4s linear;
  -o-transition: .4s linear;
  -ms-transition: .4s linear;
}
@media screen and (max-width: 799px) {
	.p-sidebar {
		float: none;
		display: block;
		margin: 0 auto;
		text-align: center;
		overflow: hidden;
	}
	.p-sidebar .c-sideWidget.widget_search .screen-reader-text {
		width: 0;
		display: none;
	}
}

/* =====================================================================
	7. p-nothing
======================================================================== */
.p-nothing {
	margin: 0 15px 10px;
	font-weight: bold;
	font-size: 2.0rem;
	line-height: 3.0rem;
	text-align: center;
}