.project {}

/*----------------------------------------------------------------------------------------------------*/

.project > .container {
	position: relative;
	display: block; overflow: hidden;
	
	border-radius: 30px;
	
	isolation: isolate;
}
.project > .container:before {
	content: '';
	display: block;
	padding-top: 130%;
}

/*----------------------------------------------------------------------------------------------------*/

.project > .container > .background {
    position: absolute; top: 0; left: 0;
	height: 100%; width: 100%;
    
    isolation: isolate;
}
.project > .container > .background > img,
.project > .container > .background > video {
    display: block; height: 100%; width: 100%;
    object-fit: cover;
    object-position: center;
    
    pointer-events: none;
}
.project > .container > .background:after {
	content: '';
	position: absolute; top: 0; left: 0;
	height: 100%; width: 100%;
	
	background-image: linear-gradient(to bottom, rgba(0,0,0,.5), transparent 40%, transparent 70%, rgba(0,0,0,.5) 100%);
}

/*----------------------------------------------------------------------------------------------------*/

.project > .container > .info {
    position: absolute; top: 0; left: 0;
	display: flex; width: 100%;
	flex-direction: row;
	align-items: center;
	column-gap: 20px;
	padding: 15px;
	
	border-bottom: solid 1px rgba(255,255,255,.5);
	
	color: #FFF;
	
	isolation: isolate;
}
.project > .container > .info > .icon {
	flex: 0 0 65px;
	
	background-color: #FFF;
	background-image: url("../../images/logo.png");
	background-position: center;
	background-size: 55%;
	background-repeat: no-repeat;
	border-radius: 50%;
}
.project > .container > .info > .icon:before {
	content: '';
	display: block;
	padding-top: 100%;
}
.project > .container > .info > .meta { flex: 1; }
.project > .container > .info > .meta > .title {
	display: -webkit-box; overflow: hidden;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
	margin-bottom: 5px;
	
	line-height: 18px;
	font-size: 14px;
	font-weight: 500;
}
.project > .container > .info > .meta > .date {
	font-size: 12px;
}

/*----------------------------------------------------------------------------------------------------*/

.project > .container > .sectors {
	position: absolute; bottom: 15px; left: 15px;
	display: flex; height: 40px; width: calc(100% - 30px);
	flex-direction: row;
	justify-content: flex-start;
	align-items: stretch;
	column-gap: 10px;
}
.project > .container > .sectors > .sector {
	position: relative;
	width: 40px; overflow: hidden;
	
	background-color: #FFF;
	border-radius: 50%;
	
	isolation: isolate;
}
.project > .container > .sectors > .sector > img {
	height: 100%; width: 100%;
	padding: 7.5px;
	
	object-fit: contain;
	object-position: center;
}