
/********************************************************************* BASE ***/

@media (max-width: 768px) {
	html, body {
		width: auto !important;
		overflow-x: hidden !important;
		height: 100%;
	}
}

.container {
	max-width: 2345px;
}

body, a {
	font-family: "League Spartan", sans-serif;
	font-optical-sizing: auto;
	font-style: normal;
	font-weight: 400;
	color: #19272e;
	font-size: 18px;
	line-height: 30px;
	text-decoration: none;
}

@media (min-width: 992px) {

	body, a {
		font-size: 18px;
		line-height: 30px;
	}

}

a:hover {
	color: #000000;
}

p {
	margin: 0;
	padding: 0;
	margin-bottom: clamp(1.5rem, 1.4200rem + 0.4000vw, 1.9rem);
}

p:last-child {
	margin-bottom: 0;
}

h1 {
	font-family: "League Spartan", sans-serif;
	font-optical-sizing: auto;
	font-style: normal;
	font-weight: 400;
	font-size: 26px;
	line-height: 35px;
	color: #19272e;
	margin-bottom: clamp(1.8rem, 1.6200rem + 0.9000vw, 2.7rem);
}

@media (min-width: 992px) {

	h1 {
		font-size: 28px;
		line-height: 37px;
	}

}

.btn-primary {
	font-family: "League Spartan", sans-serif;
	font-optical-sizing: auto;
	font-style: normal;
	font-weight: 400;
	font-size: 1.4rem;
	padding: 0.6rem 4rem;
	border-radius: 0;
	--bs-btn-color: #ffffff;
	--bs-btn-bg: #000000;
	--bs-btn-border-color: #000000;
	--bs-btn-hover-color: #FFFFFF;
	--bs-btn-hover-bg: #19272e;
	--bs-btn-hover-border-color: #19272e;
	--bs-btn-active-color: #FFFFFF;
	--bs-btn-active-bg: #434343;
	--bs-btn-active-border-color: #434343;
}

@media (min-width: 768px) {

	.btn-primary {
		font-size: 1.6rem;
		padding: 0.65rem 4.4rem;
	}

}

@media (min-width: 1400px) {

	.btn-primary {
		font-size: 1.8rem;
		padding: 0.75rem 4.8rem;
	}

}

/******************************************************************* HEADER ***/

.header .container {
	height: 120px;
}

.header .logo img {
	width: 160px;
}

.header .dropdown {
	line-height: 1px;
}

.header .dropdown-item {
	padding: 5px 50px 5px 20px;
	font-size: 21px;
	line-height: 40px;
}

.header .dropdown-item:active {
	background-color: #000000;
	color: #FFFFFF;
}

.navigation-button {
	position: relative;
	width: 25px;
	height: 18px;
	cursor: pointer;
	z-index: 1;
	padding: 15px 0 15px 15px;
	box-sizing: content-box;
}

.navigation-button > span,
.navigation-button > span::before,
.navigation-button > span::after {
	display: block;
	position: absolute;
	width: 25px;
	height: 2px;
	background-color: #000000;
	transition-duration: .25s;
}

.navigation-button > span::before {
	content: '';
	top: 16px;
}

.navigation-button > span::after {
	content: '';
	top: 8px;
}

#navigation-toggle {
	display: none;
}

#navigation-toggle:checked + .navigation-button > span {
	top: 23px;
	transform: rotate(45deg);
}

#navigation-toggle:checked + .navigation-button > span::before {
	top: 0;
	transform: rotate(0deg);
}

#navigation-toggle:checked + .navigation-button > span::after {
	top: 0;
	transform: rotate(90deg);
}

#navigation-toggle:checked ~ .dropdown-menu {
	display: block;
	right: 0;
	top: 48px;
	border-radius: 0;
	box-shadow: rgba(0, 0, 0, 0.56) 0px 22px 70px 4px;
}

/******************************************************************* FOOTER ***/

.footer {
	padding: 30px 0;
}

.footer .info a:hover {
	text-decoration: underline;
}

.footer .info ul {
	list-style-type: none;
	padding: 0;
	margin: 0;
}

.footer .info ul li.separator {
	display: none;
}

@media (min-width: 1500px) {

	.footer {
		padding: 40px 0;
	}

	.footer .info ul li {
		float: left;
		margin-right: 15px;
	}

	.footer .info ul li.separator {
		display: inline-block;
	}

}

.footer .social a {
	text-decoration: none;
	margin-right: 30px;
}

.footer .social a:last-child {
	margin-right: 0;
}

.footer .social img {
	height: 30px;
}

/********************************************************************* HOME ***/

#slideshow-home {
	position: relative;
}

#slideshow-home .splide__slide {
	min-height: calc(100vh - 135px);
	background-color: #e4e4e4;
	background-image: none;
	background-position: center center;
	background-repeat: no-repeat;
	background-size: cover;
}

#slideshow-home .splide__arrow {
	font-size: 2rem;
	width: auto;
	background: transparent;
	color: #FFFFFF;
}

#slideshow-home .splide__arrow svg {
	fill: #FFFFFF;
}

#slideshow-home .splide__arrow--next {
	right: 0;
}

#slideshow-home .splide__arrow--prev {
	left: 0;
}

@media (min-width: 992px) {

	#slideshow-home .splide__arrow {
		font-size: 3rem;
	}

	#slideshow-home .splide__arrow--next {
		right: 1rem;
	}

	#slideshow-home .splide__arrow--prev {
		left: 1rem;
	}

}

@media (min-width: 1700px) {

	#slideshow-home .splide__arrow {
		font-size: 4rem;
	}

	#slideshow-home .splide__arrow--next {
		right: 3rem;
	}

	#slideshow-home .splide__arrow--prev {
		left: 3rem;
	}

}

@media (min-width: 1800px) {

	#slideshow-home .splide__slide {
		min-height: calc(100vh - 244px);
	}

}

.slideshow .title {
	position: absolute;
	right: 30px;
	bottom: 30px;
	max-width: 80%;
	background-color: rgba(0, 0, 0, 0.5);
	color: #FFFFFF;
	padding: clamp(0.9rem, 0.8500rem + 0.2500vw, 1.15rem);
	font-weight: 400;
	font-size: clamp(1.5rem, 0.375vw + 1.425rem, 1.875rem);
	line-height: clamp(1.8rem, 0.825vw + 1.635rem, 2.625rem);
}

@media (min-width: 992px) {

	.slideshow .title {
		right: 63px;
		bottom: 63px;
	}

}

/***************************************************************** PROJECTS ***/

.projects .row {
	--bs-gutter-x: clamp(1rem, 0.8000rem + 1.0000vw, 2rem);
	--bs-gutter-y: 0;
}

.projects a img {
	margin-bottom: 20px;
	max-width: 100%;
}

.projects a span {
	display: block;
	height: 100px;
	line-height: 26px;
}

@media (min-width: 1900px) {

	.projects .row > div {
		width: 16.66666667%;
	}

}

.projects-single .row {
	--bs-gutter-x: clamp(1rem, 0.8000rem + 1.0000vw, 2rem);
	--bs-gutter-y: clamp(1rem, 0.8000rem + 1.0000vw, 2rem);
}

.projects-single .description {
	padding: 20px 0 25px 0;
}

@media (min-width: 768px) {
	
	.projects-single .description {
		max-width: 90%;
		margin: 0 auto;
		padding: 20px 0 30px 0;
	}
	
}

@media (min-width: 1200px) {
	
	.projects-single .description {
		max-width: 70%;
		padding: 0;
	}
	
}

/******************************************************************** ABOUT ***/

.about .hero {
	margin-bottom: clamp(2rem, 1.7600rem + 1.2000vw, 3.2rem);
}

/****************************************************************** CONTACT ***/

.contact .hero {
	margin-bottom: clamp(2rem, 1.7600rem + 1.2000vw, 3.2rem);
}

.contact form {
	max-width: 750px;
	padding-top: clamp(1rem, 0.8400rem + 0.8000vw, 1.8rem);
}

.contact .form-control:not(.is-invalid, .is-valid),
.contact .form-select {
	border-color: #766666;
}

.contact .msg-error {
	padding: 10px;
	background-color: #dc3545;
	color: #FFFFFF;
}

.contact .msg-success {
	padding: 10px;
	background-color: #198754;
	color: #FFFFFF;
}

.contact .form-item input,
.contact .form-item textarea,
.contact .form-item select {
	font-family: "League Spartan", sans-serif;
	font-optical-sizing: auto;
	font-size: 20px;
	padding: 1.2rem 1.1rem;
	border-radius: 0;
	border-color: #000000;
}

.contact .form-item textarea {
	resize: none;
	height: 180px;
}

@media (min-width: 992px) {

	.contact .form-item input,
	.contact .form-item textarea,
	.contact .form-item select {
		font-size: 21px;
	}

	.contact .form-item textarea {
		height: 250px;
	}

}
