/* CSS Document */


#fv {
	position: relative;
}
#fv > img {
	width: 100%;
	aspect-ratio: 5/2;
	object-fit: cover;
}
#fv h2 {
	position: absolute;
    bottom: 30%;
    right: 10%;
    width: 23%;
	filter: drop-shadow(2px 2px 4px rgba(0, 0, 0, .5));
}

#fv h3 {
	color: #1b745b;
	background: #e2e1de;
	text-align: center;
	font-size: 140%;
	line-height: 1.4;
	letter-spacing: 3.4px;
	font-weight: 500;
	padding: 30px 0;
}

#workDetail {
	margin: 0 auto;
	padding: 40px 20px;
	font-family: 'Zen Kaku Gothic New', sans-serif;
	color: #333;
}
#workDetail .inner{
	max-width: 820px;
}

#workDetail .meta {
	color: #1b745b;
	margin-bottom: 10px;
}
#workDetail .date {
    color: #1b745b;
    font-size: 110%;
	margin-right: 10px;
}
#workDetail .categoryLabel {
	display: inline-block;
	padding: 2px 15px;
    border: 1px solid #54838d;
    color: #54838d;
    border-radius: 8px;
    line-height: 1.5em;
    font-weight: 500;
}

#workDetail .award {
	display: flex;
  	align-items: center;
	color: #b57e10;
	font-size: 120%;
}
#workDetail .award .awardIcon {
	background: url(img/awardIcon.webp) no-repeat left center;
    background-size: 48px auto;
    padding-left: 55px;
    min-height: 33px;
    display: flex;
    align-items: center;
    margin: 0 3px;	
}
#workDetail .mainPhoto{
		margin: 30px 0 0;
	}
#workDetail .mainPhoto img {
	width: 100%;
	aspect-ratio: 4/3;
  object-fit: cover;
	margin-bottom: 20px;
}

#workDetail .thumbnailList {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin-bottom: 40px;
}

#workDetail .thumbnailList img {
	width: calc(25% - 7.5px);
	aspect-ratio: 4/3;
  object-fit: cover;
}
#workDetail .thumbnailList img:hover {
	cursor: pointer;
	opacity: .8;
}
#workDetail .thumbnailList img.current {
	opacity: .8;
}

#workDetail h2 {
	text-align: center;
	font-weight: 500;
	margin: 40px 0 20px;
	padding-bottom: 5px;
	font-size: 110%;
	position: relative;
	letter-spacing: 2.0px;
}
#workDetail h2:before {
    content: '';
    position: absolute;
    left: 50%;
    bottom: -6px;
    display: inline-block;
    width: 200px;
    height: 1px;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    background-color: #1b745b;
}

#workDetail .areaLabelWrap {
	text-align: center;
	margin-bottom: 50px;
}

#workDetail .areaLabel {
	background: #1b745b;
	color: #fff;
	padding: 4px 10px;
	margin-right: 8px;
}

#workDetail .description {
	line-height: 2em;
	letter-spacing: .4px;
	margin: 30px 20px;
}

#workDetail .detailTable {
	width: 100%;
	margin: 60px auto;
}

#workDetail .detailTable th,
#workDetail .detailTable td {
	padding: 30px 20px;
	border-top: 1px solid #bcc3c5;
	border-bottom: 1px solid #bcc3c5;
	vertical-align: top;
	text-align: left;
}
#workDetail .detailTable th {
	width: 25%;
	background: #e2e1de;
	text-align: center;
	font-weight: 400;
}

#contact {
	background: #fff;
}
#contact .titleSet::before {
    border-bottom-color: #E2E1DE;
}
#contact .tel{
	border: 1px solid #1B745B;
}


#searchCategory{
	background: #e2e1de;
	padding: 50px 0 100px;
}
#searchCategory .inner{
	background: #ffff;
    border-radius: 40px;
	position: relative;
}
#searchCategory .labelTag {
	background: #e2e1de;
    padding: 20px 30px;
    border-radius: 0 0 10px 10px;
    box-shadow: -2px 4px 10px #000;
    font-size: 120%;
    line-height: 1.4;
    letter-spacing: 2.0px;
    font-weight: 500;
    position: absolute;
    left: 100px;
    top: -5px;
}
#searchCategory h2{
	padding: 80px 0 20px;
    text-align: center;
    font-size: 110%;
    font-weight: 500;
    line-height: 2em;
    letter-spacing: .4px;
}
#searchCategory h2 strong{
    font-size: 140%;
    padding-bottom: 10px;
	position: relative;
    display: inline-block;
    margin-bottom: 1.5em;
}
#searchCategory h2 strong:before {
    content: '';
    position: absolute;
    left: 50%;
    bottom: -15px;
    display: inline-block;
    width: 100px;
    height: 1px;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    background-color: #231d1c;
}

#searchCategory .categoryNav {
	display: flex;
	flex-wrap: wrap;
	gap: 15px;
	justify-content: center;
	margin: 20px auto 30px;
	max-width: 900px;
}

#searchCategory .categoryNav .btn {
	border: 2px solid #ccc;
    border-radius: 10px;
    font-size: 1.1em;
    cursor: pointer;
    transition: background-color 0.2s ease;
	color: #fff;
	letter-spacing: .4px;
    font-family: 'Zen Kaku Gothic New', sans-serif;
	text-align: center;
	white-space: nowrap;
	display: flex;
	align-items: center;   
	justify-content: center;
	gap: 8px;
	width: 160px;
	height: 60px;
	padding: 0 20px;
	box-sizing: border-box;
	line-height: 3;
	background: #ccc;
}

#searchCategory .categoryNav .btn .arrowDownIcon {
	width: 12px;
	height: auto;
	display: inline-block;
	vertical-align: middle;
}
#searchCategory .categoryNav .btn .arrowRightIcon {
	width: 8px;
	height: auto;
	display: inline-block;
	vertical-align: middle;
}

#searchCategory .categoryNav .road {
	background-color: #54838d;
	border: 2px solid #54838d;
}
#searchCategory .categoryNav .bank {
	background-color: #70afbc;
	border: 2px solid #70afbc;
}
#searchCategory .categoryNav .bridge {
	background-color: #54838d;
	border: 2px solid #54838d;
}
#searchCategory .categoryNav .construction {
	background-color: #70afbc; 
	border: 2px solid #70afbc;
}

#searchCategory .categoryNav .current {
	background-color: #fff;
	border-color: #54838d;
	color: #54838d;
}


#searchCategory .categoryNav .btn.all {
	background: #1b745b;
	color: #fff;
	border: 2px solid #1b745b;
}

#searchCategory .searchMap{
	padding: 50px 0;
	text-align: center;
	font-size: 110%;
    font-weight: 500;
    line-height: 2em;
    letter-spacing: .4px;
}
#searchCategory .searchMap .btn.map{
	background: #e2e1de;
	color: #333;
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 10px 20px;
	text-decoration: none;
	font-size: 140%;
    width: 170px;
}
#searchCategory .searchMap .btn.map::after{
	border-left: 4px solid #e2e1de;
}
#searchCategory .searchMap .btn.map .mapIcon {
	width: 20px;
	height: auto;
	display: inline-block;
}
#searchCategory .searchMap span{
	line-height: 3.4;
}

@media screen and (max-width: 480px) {
  
	
	#fv h2 {
    	width: 30%;
        right: 5%;
		bottom: 40%;
	}
	#fv > img {
		aspect-ratio: 5/3;
	}
	#workDetail {
		padding: 20px 0;
	}
	#workDetail .thumbnailList img {
		width: 48%;
	}
	#workDetail .award {
		font-size:110%;
	}
	
	#workDetail .description {
		margin: 30px 0;
	}
	#workDetail .detailTable {
		margin: 30px auto;
	}
	#workDetail .detailTable th,
	#workDetail .detailTable td {
		display: block;
		width: 100%;
        padding: 15px 0;
        border-top: none;
        border-bottom: none;
	}
	#workDetail .detailTable tr {
		margin-bottom: 15px;
		display: block;
		border-bottom: none;
	}
	
	#searchCategory {
		padding: 30px 0 50px;
	}
	#searchCategory .labelTag {
		font-size: 110%;
	}
	#searchCategory h2 strong {
		font-size: 130%;
	}
	#searchCategory .categoryNav {
		flex-direction: column;
		align-items: stretch;
		gap: 12px;
    	margin: 20px auto 10px;
	}
	#searchCategory .categoryNav .btn {
		width: 100%;
		justify-content: center;
		font-size: 1.1em;
        height: 40px;
		line-height: 6;
	}
	#searchCategory .categoryNav .btn .arrowRightIcon {
		width: 8px;
	}
	#searchCategory .searchMap .btn.map{
		width: 150px;
		font-size: 130%;
	}
	#searchCategory .searchMap .btn.map .mapIcon {
		width: 16px;
	}
}
