/* Filters */
#filters button.active {
    border-color: var(--bs-primary);
    background-color: var(--bs-primary);
}

/* Vignette */
.vignette {
	position: relative;
	perspective: 80rem;
	aspect-ratio: 1;
}

.vig-faceA, .vig-faceB {
	transition: transform .5s;
	border: solid .2rem var(--bs-dark);

	backface-visibility: hidden;
	width: 100%;
	height: 100%;
}

	.vig-faceA {
		display: flex;
		justify-content: center;
		align-items: center;

		background-color: var(--bs-dark);
		color: var(--bs-light);
	}

		.vignette:hover .vig-faceA {
			transform: rotateY(180deg);
		}
		
		.vig-faceA > div {
    		text-align: center;
    	}

	.vig-faceB {
		position: absolute;
		top: 0;
		left: 0;

		cursor: pointer;
		transform: rotateY(180deg);
	}

		.vig-faceB > button {
			background-color: var(--bs-dark);
			border: none;
			padding: 0;
		}

			.vig-faceB > button > img {
				opacity: .25;
				object-fit: cover;

				width: inherit;
				height: inherit;
			}

			.vig-faceB > button > span {
				position: absolute;
				transform: translate(-50% , -50%);
				color: var(--bs-light);

				left: 50%;
				top: 50%;
				width: 100%;
			}

		.vignette:hover .vig-faceB {
			transform: rotateY(0deg);
		}

#projectView {
	position: fixed;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;

	border: solid .1rem var(--bs-dark);
	background-color: var(--bs-gray);
	color: var(--light);

	top: 50%;
	left: 50%;

	transform: translate(-50%, -50%);
	width: 60vw;
	height: 80vh;
}

	#projectView > div {
		height: 40vh;
		margin: 1rem 0;
	}

	#projectView #imgSet img {
		background-color: var(--bs-dark);
		object-fit: contain;

		width: 100%;
		height: 40vh;
	}

	#projectView #titre {
		font-weight: bold;
		color: var(--bs-dark);
	}

	#projectView #description {
		margin: 0;
		padding: 0 1rem;

		overflow-y: auto;
		height: 20vh;
	}

.popup-header {
	display: flex;
	justify-content: space-between;
	align-items: center;

	border-radius: 1rem 1rem 0 0;
	background-color: var(--bs-dark);
	color: var(--bs-light);

	padding: .5rem 1rem;
}

	.popup-header > h3 > span {
		font-size: .75rem;
		font-style: italic;
	}

	.popup-header > a {
		font-family: cursive;
		font-size: 1.25rem;
		font-weight: bold;

		cursor: pointer;
		color: var(--bs-danger) !important;
		padding-right: .25rem;
	}

		.popup-header > a:hover {
			color: var(--bs-light) !important;;
		}

.popup-body {
	display: flex;
	flex-direction: column;
	height: 100%;
}

.popup-carousel {
	position: relative;
	display: flex;

	background-color: var(--bs-gray-dark);
	height: 50%;
}

	.popup-carousel > button {
		border: solid var(--bs-dark);
		border-width: .2rem 0;
		background-color: #FFFA;
		font-size: 1.25rem;
		font-weight: bold;

		padding: .5rem;
		z-index: 3;
	}

	.popup-carousel > button:hover {
		background-color: #FFFD;
	}

	.popup-carousel > div {
		border: solid var(--bs-dark);
		border-width: .2rem 0;

		width: 100%;
		height: 100%;
	}

.popup-images > img {
	position: absolute;
	
	transition: opacity .5s;
	transform: translate(-50%, -50%);
	object-fit: contain;
	opacity: 0;

	left: 50%;
	top: 50%;
	padding: .2rem 0;
	width: 100%;
	max-height: 100%;
}

	.popup-images > img.active {
		opacity: 1;
	}

.popup-count {
	position: absolute;
	transform: translate(-50%, 0);

	border-radius: 1rem;
	background-color: #FFFA;

	left: 50%;
	bottom: .5rem;
	padding: 0 .5rem;
}

.popup-section {
	overflow: auto;
	height: 50vh;
	margin: 1rem;
}

    .popup-section a {
        color: var(--bs-primary) !important;
    }

        .popup-section a:hover {
            color: var(--bs-secondary) !important;
        }