/* Navbar */

.navbar {
	padding-top: 24px;
	padding-bottom: 24px;
}

.nav-link {
	color: var(--dark-grey);
}

.navbar-brand img{
	width: 100px;
}

.nav-item:not(:last-child) {
	margin-right: 24px;
}

.navbar>.container-fluid {
	padding-left: 54px;
	padding-right: 54px;
}

.navbar-nav .nav-link.active, .navbar-nav .nav-link.show {
	color: var(--red);
}

.dropdown-menu {
	font-size: 14px;
}

/* Modals */

.modal-content {
	background-color: var(--primary-color);
	color: var(--peach);
}

.modal-header {
	font-family: 'Playfair Display', serif;
	border-bottom: none;
	justify-content: center;
	padding-top: 54px;
}

.modal-body .buttons {
	padding: 54px 24px;
	justify-content: space-between;
    display: flex;
}

.modal .btn-close {
    --bs-btn-close-color: var(--peach);
}

.modal-footer {
	justify-content: center;
	border-top: none;
	padding-bottom: 54px;
}

.modal-footer a {
    text-decoration: underline;
    color: var(--peach);
}

/* Landing Page */
.landing-page {
	height: calc(100vh - 88px);
	padding-left: 54px;
	padding-right: 54px;
}

.landing-section {
	display: flex;
    align-items: center;
}

.landing-page-content h1, .section-subheading {
	font-family: 'Playfair Display', serif;
	font-weight: 900;
	font-size: 2.7rem;
}

.floating-img img {
	width: 100%;
}

.landing-page-links > :not(:last-child) {
	margin-right: 2.7rem;
}

.landing-page-links {
	margin-top: 54px;
}

section {
	padding-left: 54px;
	padding-right: 54px;
}

.section-heading {
	font-size: 24px;
	color: var(--red);
}

#services, #recruitment, .landing-page {
	margin-bottom: 108px;
}

#services .col-md-6 {
	display: flex;
    align-items: center;
	justify-content: center;
}

#services .page-content {
	width: 700px;
}

.card {
	max-width: 400px;
	border: none;
	box-shadow: rgb(0 0 0 / 16%) 0px 12px 24px;
}

.card-header {
	font-family: 'Playfair Display', serif;
	font-weight: 900;
	font-size: 54px;
	background: none;
	border-bottom: none;
	padding: 24px 24px 0px 24px;
}

.card-title {
	font-size: 32px;
	font-weight: 700;
	margin-bottom: 24px;
}

.card-text {
	margin-bottom: 24px;
}

.card-body {
	padding: 16px 24px 24px 24px;
}

#clients {
	background: var(--red);
	padding: 54px 24px;
}

#clientCarousel .img-container {
	max-width: 100px;
}

.owl-carousel .owl-item {
	display: flex;
	justify-content: center;
}

footer {
	background-color: var(--peach);
	color: var(--red);
	padding: 54px;
}

footer img {
	width: 150px;
}

.footer-heading {
	font-weight: 600;
	margin-bottom: 24px;
}

footer ul {
	padding-left: 0px;
}

footer ul li {
	list-style-type: none;
	margin-bottom: 16px;
}

/* Steps */

.steps-section {
	min-height: 100vh;
	display: flex;
    justify-content: center;
    align-items: center;
	margin-top: 54px;
}

.process-form img {
	position: absolute;
	width: 150px;
	margin-top: 38px;
}

.step {
	display: flex;
    flex-direction: column;
    align-items: center;
}

.circular-button {
	width: 50px;
	height: 50px;
	border-radius: 50%;
	display: flex;
	justify-content: center;
	align-items: center;
	font-size: 18px;
	font-weight: bold;
	text-align: center;
	cursor: pointer;
	box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
	transition: background-color 0.3s ease, transform 0.3s ease;
	margin-bottom: 8px;
	background: none;
	border: 1px solid var(--grey);
    color: var(--grey);
}

.step-description {
	color: var(--grey);
	margin-bottom: 8px;
	font-size: 12px;
}

.vertical-line {
    width: 2px;
    height: 24px;
    background-color: var(--grey);
    margin: 0 auto;
	margin-bottom: 8px;
}

.step.active .circular-button {
	background-color: var(--red);
	color: var(--peach);
	border: 1px solid var(--red);
}

.step.active .step-description {
	color: var(--red);
	font-weight: 600;
}

.step.active .vertical-line {
	background-color: var(--red);
}

.circle-button span {
    display: block;
}

.process-form .card {
	border-radius: 32px;
	box-shadow: 0 12px 24px rgba(0, 0, 0, 0.15);
	width: 100%;
	max-width: 100%;
	height: 80%;
	padding: 54px;
}

.process-form .card-body {
	padding: 0px;
}

.process-form .card-title {
	font-family: 'Playfair Display', serif;
	font-weight: 900;
}

.floating-logo {
	position: absolute;
    margin-top: 38px;
    padding: 0px;
	display: contents;
}

.process-form .logo-container {
	width: 150px;
}

.form-section hr {
	margin: 24px 0px;

}

.form-section {
	display: flex;
	justify-content: center;
	align-items: center;
	min-height: 100%;
	width: 100%;
	margin-top: 24px;
}

.form-section form {
	padding-bottom: 120px;
}

.form-control,.form-select {
	padding: 12px 24px;
    font-size: 14px;
	background-color: var(--light-grey);
	border-radius: 16px;
	border: none;
}

.form-control:focus {
	border-color: var(--peach);
	box-shadow: 0 0 0 .25rem var(--peach);
}

label {
	margin-bottom: 8px;
}

.checks {
	margin-top: 10px;
}

.form-check-input:checked {
    background-color: var(--red);
    border-color: var(--red);
}

.form-check-input:focus {
	box-shadow: 0 0 0 .25rem var(--peach);
}

.button-group {
	position: absolute;
	bottom: 54px;
}

/* Success Page */

#successPage {
	flex: 1;
	display: flex;
	justify-content: center;
	padding: 24px 0px;
}

#successPage img {
	width: 260px;
	margin-bottom: 16px;
}

.success-container {
	text-align: center;
}

.wrapper {
	display: flex;
    flex-direction: column;
    min-height: calc(100vh - 88px);
}

/* Workforce Page */

#workforce {
	padding-top: 24px;
	padding-bottom: 54px;
}

header {
	background-image: url('../img/header.png');
	text-align: center;
	color: var(--peach);
	padding: 24px;
	background-size: cover;
	background-repeat: no-repeat;
	width: 100vw;
	min-height: 180px;
	margin-bottom: 24px;
}

header h1 {
	font-family: 'Playfair Display', serif;
	font-weight: 900;
	font-size: 54px;
}

.subheading {
	display: flex;
	justify-content: center;
}

.subheading p {
	text-align: center;
}

#workforce .img-frame, #contact .img-frame {
	width: 200px;
    height: 200px;
    border: 1px solid var(--peach);
    border-radius: 50%;
    display: flex;
    align-items: center;
	justify-content: center;
	margin: 24px auto;
}

.member .card-body, .contact-info .card-body {
	text-align: center;
	padding-bottom: 54px;
}

.member h5, .contact-info h5{
	font-size: 14px;
    color: var(--red);
}

.card.member, .card.contact-info {
	border-radius: 16px;
	margin-bottom: 24px;
}

#contact {
	margin-top: 54px;
	margin-bottom: 54px;
}

#contact .img-frame img {
	max-height: 4rem;
}

.contact-form {
	width: 75%;
	margin-left: auto;
	margin-right: auto;
}

#skills {
	text-align: center;
	margin-bottom: 54px;
}

.skill {
	display: flex;
	justify-content: center;
}

.skill img {
	width: 100px;
	margin: 0px auto 24px;
}

.skill .card {
	background-color: var(--peach);
	width: 600px;
	padding: 54px;
	text-align: center;
}

.skill h5 {
	color: var(--red);
}

.error-page {
	background: url('../img/coffee-spill.png');
	background-size: cover;
	background-repeat: no-repeat;
	height: 100vh;
	width: 100vw;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
}

.error {
	text-align: center;
	color: var(--red);
}

.error h1 {
	font-size: 84px;
	font-weight: 700;
}

.error h3 {
	font-size: 40px;
	font-weight: 600;
	margin-bottom: 24px;
}

@media (min-width: 1800px){

}

@media (min-width: 769px) and (max-width: 1300px) {

}

@media (max-width: 576px){
	.navbar>.container-fluid {
		padding-left: 24px;
		padding-right: 24px;
	}
	.landing-page {
		padding-left: 24px;
		padding-right: 24px;
		text-align: center;
	}

	.landing-page > .row {
		flex-direction: column-reverse;
	}

	.landing-page-content h1 {
		font-size: 1.7rem;
		margin-top: 16px;
	}

	.landing-page-links {
		margin-top: 54px;
		display: flex;
		flex-direction: column;
	}

	.landing-page-links {
		margin-top: 24px;
		display: inline-flex;
		flex-direction: column;
	}

	.landing-page-links > :not(:last-child) {
		margin-bottom: 8px;
		margin-right: 0px;
	}

	section {
		padding-left: 24px;
		padding-right: 24px;
	}

	#services .floating-img {
		margin-bottom: 24px;
		margin-top: 24px;
	}

	#recruitment .card.h-100 {
		margin-bottom: 24px;
		height: auto !important;
	}

	footer {
		padding: 24px;
	}

	.btn-large {
		padding: 20px 54px;
	}

	.navbar-collapse {
		position: absolute;
		top: 54px;
		background: rgb(255 255 255 / 90%);
		padding: 24px;
		border-radius: 16px;
	}

	.navbar-toggler:focus {
		box-shadow: none;
	}

	header h1 {
		font-size: 24px;
	}

	.contact-form {
		width: 100%;
	}

	.auth .row.h-100 {
		height: 100% !important;
	}

	.side-overlay.h-100.w-100 {
		height: 140px !important;
        margin-bottom: 24px;
	}

	.process-form .card {
		border-radius: 24px;
		padding: 24px;
	}

	.process-form .card-title {
		font-size: 32px;
	}

	.process-form .button-group {
		position: unset;
	}

	.steps-section {
		min-height: unset;
		margin-top: 108px;
	}

	.multi-form {
		border-bottom: 1px solid lightgrey;
		padding-bottom: 1rem;
	}
}