/*!
Theme Name: Vedder
Theme URI: https://luuk-arends.notion.site/Vedder-B2B-db5082ce819348fe8c4e570d116585c4?pvs=4
Author: Luuk Arends
Author URI: https://vedderb2b.com/
Description: Vedder is a theme with limitless possibilities, offered with the convenience of WordPress.
Version: 1.3
Tested up to: 8.3
Requires PHP: 5.6
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: vedder
*/

/* Body */

body {
	font-family: "Inter Regular";
}

/* Texts */

.text-green {
	color: #42AC6F;
}

.text-red {
	color: #d02e26;
}

.text-orange {
	color: orange;
}

/* Anchors */

a {
	color: #d02e26;
	text-decoration: none;
	transition: all ease .3s;
}

/* Icons */

.bi-check2,
.bi-check-circle-fill {
	color: #42AC6F;
}

/* Headings */

h1, h2, h3 {
	font-family: "Inter Bold";
}

.title-group {
	display: flex;
	justify-content: space-between;
}

/* Spacing */

@media (min-width: 1200px) {
	.py-xl-6 {
		padding-top: 6rem !important;
		padding-bottom: 6rem !important;
	}
}

/* Slicks */

.slick-prev::before, .slick-next::before {
	color: #000;
}

.slick-item {
	margin-left: .5rem;
	margin-right: .5rem;
}

/* Typography */

b, strong, .fw-bold {
	font-family: "Inter Bold";
}

/* Backgrounds */

/* Buttons */

.btn, .button, .wp-element-button {
	border-radius: 3rem;
	padding: .75rem 1.5rem;
	font-size: 1rem;
	font-family: "Inter SemiBold";
}

.btn-primary, .btn-primary:visited, .button, .button:visited, .wp-element-button, .wp-element-button:visited {
	color: #fff;
	background-color: #d02e26;
	border: 1px solid #d02e26;
}

.btn-primary:hover, .wp-element-button:hover {
	color: #fff;
	background-color: #000;
	border: 1px solid #d02e26;
	text-decoration: none !important;
}

.btn-secondary {
	background-color: #000;
	border-color: #000;
}

@media (max-width: 768px) {
	.button-group {
		display: flex;
		flex-direction: column;
		gap: 1rem;
	}
}

/* Header */

.navbar-top {
	font-size: .875rem;
    padding: .75rem 0;
    border-bottom: 1px solid #333;
}

.navbar-top a {
	color: #fff;
	transition: all ease .3s;
}

.navbar-top a:hover {
	color: #d02e26;
}

.navbar-top .container {
	display: flex;
	justify-content: space-between;
}

.top-usps, .top-nav {
	display: flex;
	gap: 1rem;
    padding: 0;
    margin: 0;
    list-style: none;
    color: #fff;
}

.top-nav .bi {
	margin-right: .25rem;
}

.top-usps .bi-circle-fill {
	font-size: .75rem;
}

.navbar-nav {
	flex-direction: row;
	gap: 2.5rem;
}

.nav-link {
	color: #fff;
}

.navbar-actions {
	display: flex;
	align-items: center;
	gap: 1.25rem;
}

.actions-search .bi {
	font-size: 1.25rem;
}

.search-form .search-field {
	padding: .5rem;
    border-radius: .375rem;
    border: var(--bs-border-width) solid var(--bs-border-color);
}

.search-form .search-submit {
	display: none;
}

.nav-toggler {
	color: #fff;
    font-size: 1.125rem;
}

#offcanvasNavMob {
	background-color: #000;
	color: #fff;
}

#offcanvasNavMob .navbar-nav {
	flex-direction: column;
    gap: .5rem;
    margin-bottom: 3rem;
}

.navbar-nav .dropdown-menu {
	position: absolute;
	padding: 1rem;
	min-width: 320px;
}

.menu-item-has-children:hover ul.dropdown-menu {
    display: block;
}

.navbar-nav .dropdown-menu .dropdown-item {
	background-image: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='currentColor' class='bi bi-chevron-right' viewBox='0 0 16 16'><path fill-rule='evenodd' d='M4.646 1.646a.5.5 0 0 1 .708 0l6 6a.5.5 0 0 1 0 .708l-6 6a.5.5 0 0 1-.708-.708L10.293 8 4.646 2.354a.5.5 0 0 1 0-.708'/></svg>");
	background-repeat: no-repeat;
    background-size: 18px;
    background-position: 97.5% 50%;
}

.navbar-nav .dropdown-menu .dropdown-item:active {
	background-color: #000;
}

/* Hero */

.hero {
	position: relative;
	min-height: 60vh;
	color: #fff;
	display: flex;
	align-items: end;
}

.hero::after {
	content: "";
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	z-index: 10;
	background: linear-gradient(180deg, rgba(255,255,255,0) 0%, rgba(0,0,0,1) 100%);
}

.hero-content {
	position: relative;
	z-index: 20;
	padding-bottom: 6rem;
}

.hero-title {
	font-size: 3rem;
}

.hero-subtitle {
	font-size: 1rem;
	font-family: "Inter Regular";
	text-transform: uppercase;
	letter-spacing: .125rem;
}

.hero-descr {
	margin: 1.5rem 0;
	font-size: .925rem;
}

.hero-img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

/* USPs */

.usps-item {
	display: flex;
	gap: 1.5rem;
	color: #fff;
}

.usps-item .bi {
	font-size: 1.5rem;
	opacity: .75;
}

.usps-title {
	font-size: 1.125rem;
	font-family: "Inter SemiBold";
}

.usps-descr {
	font-size: .925rem;
	opacity: .5;
}

/* WooCommerce */

ul.page-numbers {
	padding: 0;
	margin: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 1rem;
	list-style: none;
}

ul.page-numbers .page-numbers {
	width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
	color: #000;
    background-color: #fff;
    border-radius: 50%;
}

ul.page-numbers .page-numbers.current {
	color: #fff;
	background-color: #d02e26;
}

.woocommerce-info {
	padding: 1rem 1.5rem;
    border-radius: 3rem;
    color: #fff;
    background-color: #d02e26 !important;
}

/* Products */

.product-item {
	display: flex;
	flex-direction: column;
	color: inherit;
	background-color: #fff;
	position: relative;
	border-radius: .5rem;
	overflow: hidden;
	top: 0;
	transition: all ease .3s;
}

.product-item:hover {
	top: -.5rem;
	box-shadow: 0 .125rem .25rem rgba(var(--bs-body-color-rgb),.075);
}

.product-img {
	width: 100%;
	height: 306px;
	object-fit: cover;
}

.product-content {
	padding: 1rem;
}

.product-status {
	font-size: .825rem;
    font-family: "Inter SemiBold";
    padding: .25rem .75rem;
    background-color: #fff;
    border-radius: 3rem;
    color: #42AC6F;
    position: absolute;
    top: 1rem;
    left: 1rem;
}

.product-title {
	font-family: "Inter SemiBold";
	font-size: 1.125rem;
}

.product-content .list-group {
	font-size: .825rem;
	margin-bottom: .5rem;
}

.product-content .list-group .list-group-item {
	padding-left: 0;
    padding-right: 0;
    display: flex;
    justify-content: space-between;
}

.price-m2 {
	font-family: "Inter SemiBold";
    color: #42AC6F;
}

.m2 {
	color: #000;
	font-size: .825rem;
    position: relative;
    top: -.5rem;
}

.product-content .btn {
	font-size: .925rem;
    padding: .25rem 1rem;
    margin-top: .5rem;
}

/* Reviews */

.review {
	background-color: #fff;
	height: 100%;
}

.review-header {
	display: flex;
	align-items: center;
	gap: 1.5rem;
	padding: 1.5rem;
}

.review-avatar {
	width: 75px;
	height: 75px;
	border-radius: 50%;
}

.review-content {
	padding: 1.5rem;
	border-top: 2px solid #f8f9fa;
}

.review-content p:last-child {
	margin-bottom: 0;
}

.slickReviews .slick-track {
    display: flex !important;
}

.slickReviews .slick-slide {
    height: inherit !important;
}

/* Content */

.content-block {
	padding: 3rem;
	background-color: #fff;
}

.content-form {
	padding: 3rem;
}

	@media (max-width: 768px) {
		.content-block {
			padding: 1.5rem;
		}

		.content-form {
			padding: 1.5rem;
		}
	}

.content-block h1,
.content-block h2 {
	font-size: 2rem;
	margin-top: 1.5rem;
	margin-bottom: 1.5rem;
}

	@media (max-width: 768px) {
		.content-block h1,
		.content-block h2 {
			font-size: 1.5rem;
			margin-top: 1.5rem;
			margin-bottom: 1.5rem;
		}
	}

.content-block h3 {
	font-size: 1.5rem;
	margin-top: 1.5rem;
	margin-bottom: 1.5rem;
}

.content-block h1:first-child,
.content-block h2:first-child {
	margin-top: 0;
}

.content-block p:last-of-type {
	margin-bottom: 0;
}

.content-block .wp-element-button {
	margin-top: 1.5rem;
}

.content-block ul {
	padding: 0;
	margin: 1rem 0;
	list-style: none;
}

.content-block ul li {
	padding: .5rem 0;
	border-bottom: 1px solid #dee2e6;
}

.content-media {
	position: relative;
	width: 100%;
	height: 100%;
	min-height: 210px;
}

	@media (min-width: 1200px) {
		.content-media {
			min-height: 420px;
		}
	}

.content-img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

	@media (min-width: 1200px) {
		.content-block {
			height: 100%;
			padding: 6rem 12rem;
		}

		.content-form {
			padding: 6rem 12rem;
		}
	}

.content-block a:hover {
	text-decoration: underline;
}

/* Brands */

.brand-item .brand-img {
	width: 200px;
	height: 200px;
	object-fit: contain;
	border: 1px solid #000;
	background-color: #fff;
	border-radius: .5rem;
	padding: 1rem;
}

	@media (max-width: 768px) {
		.brand-item .brand-img {
			width: 150px;
			height: 150px;
			margin: 0 auto;
		}
	}

/* Quotation */

.q-form {
	display: flex;
	flex-direction: column;
	gap: 1rem;
}

.q-toggle {
	padding: 1rem;
    background-color: #fff;
    font-size: 1.125rem;
    display: flex;
    gap: 1rem;
    align-items: center;
    font-family: "Inter SemiBold";
}

.q-collapse {
	padding: 1rem;
    background-color: #fff;
    border-top: 1px solid #f8f9fa;
}

.q-item_title {
	font-family: "Inter SemiBold";
    margin-bottom: 1rem;
}

.q-options {
	display: flex;
	flex-direction: column;
	gap: .5rem;
}

.q-option_label {
	display: flex;
    align-items: center;
    gap: 1rem;
    padding: .5rem;
    border: 1px solid var(--bs-border-color);
	cursor: pointer;
}

.q-option_list {
    margin-bottom: 0;
    padding: 0;
    font-size: .925rem;
    display: flex;
    list-style: none;
    gap: 1rem;
}

.q-option_title {
	font-family: "Inter SemiBold";
}

.chosen {
	background-color: #d4efdf;
    border: 1px solid #27ae60;
    color: #1e8449;
}

.quote-form label {
	font-family: "Inter SemiBold";
}

/* Single Product */

.rank-math-breadcrumb p {
	font-size: .925rem;
	margin-bottom: 0;
}

.single-product div.product .woocommerce-product-gallery {
	float: none !important;
}

.woocommerce-product-gallery__wrapper .wp-post-image {
	width: 100%;
    height: 320px;
    object-fit: cover;
}

@media (min-width: 1200px) {
	.woocommerce-product-gallery__wrapper .wp-post-image {
		height: 620px;
	}
}

.single-product div.product .woocommerce-product-gallery .flex-control-thumbs img {
	width: 100%;
	height: 77.73px;
	object-fit: cover;
}

@media (min-width: 1200px) {
	.single-product div.product .woocommerce-product-gallery .flex-control-thumbs img {
		height: 150px;
	}
}

.onsale {
	position: absolute;
    z-index: 10;
    padding: .5rem 1rem;
    background-color: #d02e26;
    color: #fff;
    border-radius: 3rem;
    margin: 1rem;
}

.summary {
	padding: 1.5rem;
	background-color: #fff;
}

@media (min-width: 1200px) {
	.summary {
		padding: 3rem;
	}
}

.summary .product_title {
	font-size: 1.5rem;
}

.summary .list-group {
	font-size: .925rem;
    margin-bottom: 1rem;
}

.summary .price-m2 {
	font-size: 1.25rem;
}

.m2-calculator {
	display: flex;
    gap: 1rem;
    padding: 1rem;
    background-color: #f8f9fa;
    border-radius: .5rem;
}

@media (max-width: 768px) {
	.m2-calculator {
		flex-direction: column;
	}
}

.list-spec {
	margin-bottom: 0;
}

.list-spec .list-group-item {
	display: flex;
	align-items: center;
	justify-content: space-between;
}

.list-spec .spec-label {
	font-family: "Inter Bold";
}

.advice {
	display: flex;
	align-items: center;
    gap: 1.5rem;
    background-color: #fff;
    margin: 1.5rem 0;
    padding: 1.5rem;
}

.advice-img {
	width: 100px;
    height: 100px;
    border-radius: 50%;
}

.advice-content {
	display: grid;
    gap: .5rem;
    font-size: .925rem;
}

.advice-title {
	font-size: 1.125rem;
    font-family: "Inter Bold";
}

.advice-options {
	display: flex;
    list-style: none;
    gap: 1rem;
    padding: 0;
    margin: 0;
}

.advice-options a {
	color: #000;
}

.advice-options a:hover,
.advice-options a .bi {
	color: #d02e26;
}

.type-product .usp-items {
	display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    font-size: .875rem;
    align-items: center;
    gap: .5rem;
}

.type-product .usp-items .usp-item {
	display: grid;
	text-align: center;
}

/* Forms */

.gform_wrapper.gform-theme--foundation .gform_fields {
	gap: 1rem;
}

.gform_heading {
	display: none !important;
}

.gform_wrapper.gform-theme--foundation .gform_footer input[type="submit"] {
	border-radius: 3rem !important;
    padding: .75rem 1.5rem !important;
    font-size: 1rem !important;
    font-family: "Inter SemiBold" !important;
    background-color: #d02e26 !important;
    border-color: #d02e26 !important;
}

.gform_wrapper.gform-theme--foundation .gform_fields .gfield_label {
	font-family: "Inter SemiBold";
}

/* Footer */

.footer,
.footer a {
	color: #fff;
	transition: all ease .3s;
}

.footer a:hover {
	color: #d02e26;
}

.footer-top {
	color: #000;
}

.footer-top .usp-item .bi {
	color: #42AC6F;
}

	@media (max-width: 768px) {
		.footer-top {
			font-size: .875rem;
		}
	}

.footer-content .btn {
	width: 100%;
	margin-top: 1.5rem;
}

.footer-content .btn:hover {
	color: #fff !important;
}

.footer-title {
	color: #fff;
	font-size: 1.125rem;
	font-family: "Inter SemiBold";
	margin-bottom: 1.5rem;
}

.footer-content {
	padding: 6rem 4rem;
	height: 100%;
}

	@media (max-width: 768px) {
		.footer-content {
			padding: 1.5rem;
		}
	}

.footer-middle .btn-primary {
	width: 100%;
	margin: 3rem 0;
}

	@media (max-width: 768px) {
		.footer-content_left {
			border-right: 0;
		}
	}

.footer-contact_list, .footer-list {
	margin: 0;
	padding: 0;
	list-style: none;
}

.footer-contact_list li, .footer-list li {
	line-height: 1.75;
	letter-spacing: .025rem;
	margin-bottom: .5rem;
}

.footer-content_right .footer-title {
	margin-bottom: 1rem;
	border-bottom: 1px solid #d02e26;
	padding-bottom: 1rem;
}

.copyright-content {
	font-size: .825rem;
	color: #fff;
	text-align: center;
}