/*
==  THEME DETAILS  ============================================================
   	Theme Name: ZakenNet Katapult
	Theme URI: https://www.zakennetkatapult.nl/
    Description: Stylesheet voor ZakenNet Katapult
    Version: 1.0
  	Author: Kracht Internet Marketing
	Author URI: https://www.krachtinternetmarketing.nl

===============================================================================
*/

/*---------------------------------------------- 
	1.1 Basics
------------------------------------------------*/
	:root {
		--white: #FFF;
		--grey: #707070;
		--light-grey: #BBBBBB;
		--lighter-grey: #EFEFEF;
		--purple: #6F177D;
		--light-purple: #F1E8F2;
		--yellow: #FFCB66;
	}

	html {
  		font-size: 20px;
	}

	body {
		font-family: "helvetica-neue-lt-pro", sans-serif;
		font-size: 0.8rem;
	  	line-height: 2.5rem;
		font-weight: 400;
		color: var(--grey);
		background: var(--white);
		-webkit-font-smoothing: antialiased;
  		-moz-osx-font-smoothing: grayscale;
	}

	a, a:hover, .btn, .btn:hover , .transition {
		transition: all 0.3s ease-in-out;
		text-decoration:none;	
	}
	
	p , figure , blockquote , ul {
		margin: 0 !important;
	}

	a {
		color: var(--purple);
	}

	a:hover {
		color: var(--grey);
	}

	button:focus ,
	:focus {
		outline: 0 !important;
	}
	
	h1, h2, h3, h4, h5, .h1, .h2, .h3, .h4, .h5{
		color: var(--purple);
		font-weight: 300;
		font-style: italic;
		line-height: 1.4;
		margin: 0;
		padding: 0;
	}

	h1, .h1 {
		font-size: 2.5rem;
	}

	h2, .h2 {
		font-size: 2rem;
	}

	h3, .h3 {
		font-size: 1.5rem;
	}
	
	h4, .h4 {
		font-size: 1.25rem;
	}

	.fs-xxl {
		font-size: 1.5rem;
	}

	.fs-xl {
		font-size: 1.1rem;
	}

	.fs-lg {
		font-size: 0.9rem;
	}

	.fs-xs {
		font-size: 0.75rem;
	}

	.fw-bold {
		font-weight: 700;
	}

	.fw-semibold , strong {
		font-weight: 600;
	}

	.fw-medium {
		font-weight: 500;
	}

	.bg-cover {
		background-position: center;
		background-size: cover;
		background-repeat: no-repeat;
	}

	.box-shadow {
		box-shadow: 0px 0px 6px 0px rgba(0,0,0,0.2);
	}

	.border-radius {
		border-radius: 20px;
	}

	.z-index-1 {
		position: relative;
		z-index: 8;
	}

	.list-inline-item:not(:last-child) {
		margin-right: 0.25rem;
	}

	hr {
		margin: 4rem 0;
	}
	
	@media (min-width: 1200px) {
		.container {
			max-width: 1150px;
		}
	}

	@media (min-width: 1360px) {
		.container {
			max-width: 1260px;
		}	
	}

	@media (min-width: 1550px) {
		.container {
			max-width: 1430px;
		}	
	}

	@media all and (max-width: 1500px) {
    	html {
			font-size: 18px;
		}
	}

	@media all and (max-width: 1200px) {
    	html {
			font-size: 16px;
		}
	}
	
	@media all and (max-width: 576px) {
    	html {
			font-size: 15px;
		}
		body {
			font-size: 1rem;
	  		line-height: 2rem;	
		}
		h1, .h1 {
			font-size: 2rem;
		}

		h2, .h2 {
			font-size: 1.5rem;
		}

		h3, .h3 {
			font-size: 1.25rem;
		}

		h4, .h4 {
			font-size: 1rem;
		}
			}

/* Buttons -------------------------------------- */
	.btn {
		font-size: 0.9rem;
		font-weight: 700;
		line-height: 1;
		padding: 1.3rem 1.5rem;
		border: none;
		border-radius: 50px;
	}

	.btn-primary {
		color: var(--white);
		background: var(--purple);
	}

	.btn-primary:hover {
		background: var(--grey);
	}

	button:focus ,
	.btn:focus {
		outline: 0 !important;
		box-shadow: none !important;
	}

/*---------------------------------------------- 
	1.2 Content Block 
------------------------------------------------*/
	.content-block p + p ,
	.content-block p + h2 ,
	.content-block p + h3 ,
	.content-block p + h4 ,
	.content-block p + h5 ,
	.content-block p + ul ,
	.content-block h3 + ul ,
	.content-block h4 + ul ,
	.content-block ul + p ,
	.content-block ul + h3 {
		margin-top: 1.5rem !important;
	}

	.content-block h1 {
		margin-bottom: 1.5rem;
	}

	.content-block h2 {
		margin-bottom: 0.75rem;
	}

	.content-block img.aligncenter {
		margin: 0 auto;
		display: block;
	}

	.content-block .embed-responsive {
		margin: 2.5rem 0;
	}

/*---------------------------------------------- 
	1.3 Colors 
------------------------------------------------*/
	.bg-white {
		background: var(--white) !important;
	}

	.bg-grey {
		background: var(--grey) !important;
	}

	.bg-purple {
		background: var(--purple) !important;
	}

	.bg-light-purple {
		background: var(--light-purple) !important;
	}

	.bg-yellow {
		background: var(--yellow) !important;
	}

	.bg-light-grey {
		background: var(--light-grey) !important;
	}

	.bg-lighter-grey {
		background: var(--lighter-grey) !important;
	}

	.bg-gradient-purple {
		background: #FFCC66;
	    background: linear-gradient(45deg,rgba(255, 204, 102, 1) 0%, rgba(159, 12, 54, 1) 30%, rgba(153, 0, 51, 1) 50%, rgba(144, 0, 55, 1) 80%, rgba(51, 0, 102, 1) 100%);
	}

	.text-white {
		color: var(--white) !important;
	}

	.text-grey {
		color: var(--blue) !important;
	}

	.text-light-grey {
		color: var(--light-grey) !important;
	}

	.text-lighter-grey {
		color: var(--lighter-grey) !important;
	}

	.text-purple {
		color: var(--purple) !important;
	}

	.text-yellow {
		color: var(--yellow) !important;
	}

/*---------------------------------------------- 
	1.4 Spacing
------------------------------------------------*/
	.py-100 {
		padding: 5rem 0;
	}

	.mt-50 {
		margin-top: 2.5rem;
	}

	.mb-50 {
		margin-bottom: 2.5rem;
	}

/*---------------------------------------------- 
	1.5 Veilingitem
------------------------------------------------*/
	.veilingitem {
		padding: 1.75rem 1.5rem;
	}

	.veilingitem img {
		border: 1px solid rgba(112, 112, 112, 0.5);
	}

	.veilingitem__price-value {
		font-size: 1rem;
	}

	.veilingitem__price-amount {
		font-size: 1.5rem;
	}

/*---------------------------------------------- 
	1.6 Swiper 
------------------------------------------------*/
	.swiper-button-next, 
	.swiper-button-prev {
		font-size: 1.3rem;
		color: var(--white);
		background: var(--purple);
		display: inline-block;
		line-height: 3rem;
		height: 3rem;
		width: 3rem;
		border-radius: 100%;
		text-align: center;
		position: relative;
		top: 0;
		right: inherit;
		left: inherit;
		margin: 0;
	}

	.swiper-button-next::after, 
	.swiper-button-prev::after {
		display: none;
	}

	.swiper-button-prev {
		left: 0;
	}

	.swiper-button-next.veilingitems {
		right: -5px;
	}
	
	.swiper-veilingitems {
		overflow: visible;
	}

	.swiper-bedrijven .swiper-wrapper {
		transition-timing-function: linear;
	}

/*---------------------------------------------- 
	1.7 Gravity Form
------------------------------------------------*/
	.gform_wrapper ,
	body .gform_wrapper .top_label div.ginput_container, 
	.gform_wrapper ul.gform_fields li.gfield ,
	.gform_wrapper li.hidden_label input {
		padding: 0 !important;
		margin: 0 !important;
		width: 100% !important;
	}

	.gform_wrapper.gravity-theme .gfield_label {
		font-size: 0.8rem !important;
		font-weight: 700 !important;
		margin: 0 !important;
	}

	.gform_wrapper input:not([type=radio]):not([type=checkbox]):not([type=submit]):not([type=button]):not([type=image]):not([type=file]) ,
	.gform_wrapper textarea ,
    .gform_wrapper select {
		font-size: 0.8rem !important;
		font-weight: 400;
		padding: 10px 15px !important;
		background: var(--white) !important;
		height: 2.75rem;
        color: var(--grey) !important;
		border: none;
		width: 100% !important;
		border-radius: 0;
	}

	#input_1_3 {
		width: 50% !important;
	}

	.gform_wrapper.gravity-theme .gfield textarea.small {
		height: 8.75rem !important;
	}

	.gform_wrapper.gravity-theme .gform_footer {
		margin: 0.75rem 0 0 0 !important;
		padding: 0 !important;
		justify-content: flex-start;
	}

	.gform_wrapper.gravity-theme .gform_footer .btn {
		margin: 0 !important;
	}

	.gform_confirmation_message {
		margin-top: 1rem !important;
	}

	.gform_wrapper .field_description_below .gfield_description {
		font-size: 0.7rem !important;
		color: var(--black);
		padding: 0 !important;
		border: none !important;
	}

	.gform_wrapper .gform_fileupload_multifile .gform_drop_area {
		padding: 0 !important;
		border: 0 !important;
		margin: 0 !important;
		background: none !important;
	}

	.gform_wrapper.gravity-theme .gfield_radio .gchoice + .gchoice {
		margin-left: 0.75rem;
	}

	.gform_wrapper.gravity-theme .gfield_checkbox label, 
	.gform_wrapper.gravity-theme .gfield_radio label {
		font-size: 0.8rem !important;
	}

	.gform_wrapper.gravity-theme .gform_fields {
		grid-row-gap: 0.75rem !important;
	}

	.gform_required_legend {
		display: none !important;
	}

	.gform_wrapper .gform_validation_errors>h2 {
		font-size: 14px !important;
		margin: 0 !important;
	}

/*---------------------------------------------- 
	2. Header 
------------------------------------------------*/
	.header {
		padding: 1.75rem 0 0 0;
	}

	.header__badge i {
		font-size: 1.75rem; 
		color: var(--white);
		position: absolute;
		top: 50%;
		left: 50%;
		transform: translate(-50%, -50%);
	}

	.header__badge img {
	  	animation: spin 8s linear infinite;
	}
	
	@keyframes spin {
		from { transform: rotate(0deg); }
	  	to { transform: rotate(-360deg); }
	}

	@media all and (max-width: 767px) {
		.header__badge i {
			font-size: 1.25rem;	
		}
	}

/*---------------------------------------------- 
	3. Hero
------------------------------------------------*/
	.hero {
		position: relative;
		overflow: hidden;
		padding-bottom: 20vh;
	}

	.hero {
		height: 23.5rem;
		padding-bottom: 3.5rem;
	}

	.hero--frontpage {
		height: calc(100dvh);
		min-height: 100dvh;
		padding-bottom: 20vh;
	}

	.hero__bg {
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
		z-index: -1;
	}

	.hero__title {
		font-size: 3.5rem;
		line-height: 1.45;
	}

	.hero__details li {
		font-size: 1.1rem;
	}

	.hero__details li strong {
		color: rgba(255, 255, 255, 0.7);
	}

	@media all and (max-width: 1200px) {
		.hero--frontpage {
			height: 55rem !important;
			min-height: inherit;
			padding-bottom: 8rem;
		}
		.hero__title {
			font-size: 3rem;
		}
	}

	@media all and (max-width: 992px) {
		.hero--frontpage {
			padding-bottom: 6rem;
		}
		.hero__title {
			font-size: 2.5rem;
		}
		.hero__details li.mt-50 {
			margin-top: 0;
		}
	}

	@media all and (max-width: 767px) {
		.hero--frontpage {
			height: 47.5rem !important;
			padding-bottom: 3rem;
		}
		.hero__title {
			font-size: 2rem;
		}	
		.hero__details li {
			font-size: 1rem;
		}
		.hero {
			height: 15rem;
			padding-bottom: 2.5rem;
		}	
	}

/*---------------------------------------------- 
	4.1 Frontpage Intro
------------------------------------------------*/
	.frontpage-intro__image-first img {
		max-width: 26.5rem;
	}

	.frontpage-intro__image-second {
		border: 0.5rem solid var(--white);	
		position: absolute;
		right: 0;	
		top: 12.5rem;
	}

	.frontpage-intro__image-second img {
		max-width: 21.5rem;
	}

	.frontpage-intro__images {
		margin-top: 9rem;
		margin-bottom: 14.5rem;
	}

	.frontpage-intro__content {
		margin-left: 2.5rem;
	}

	@media all and (min-width: 992px) and (max-width: 1199.98px) {
		.frontpage-intro__image-first img {
			max-width: 22.5rem;
		}
		.frontpage-intro__image-second img {
			max-width: 17.5rem;
		}	
	}

	@media all and (max-width: 992px) {
		.frontpage-intro {
			padding-bottom: 5rem;
		}
	}

	@media all and (max-width: 767px) {
		.frontpage-intro__images {
			margin-top: 5rem;
			margin-bottom: 3rem;
		}
		.frontpage-intro__image-first img ,
		.frontpage-intro__image-second img {
			max-width: inherit;
			width: 100%;
		}
		.frontpage-intro__image-second {
			position: inherit;
			top: inherit;
			margin-top: 1.5rem !important;
			border: none;
		}	
		.frontpage-intro__content {
			margin-left: 0;
		}
	}

/*---------------------------------------------- 
	4.2 Frontpage Inschrijving
------------------------------------------------*/
	.frontpage-inschrijving__details li span {
		width: 5.25rem;
	}

	.frontpage-inschrijving__wrapper-formulier {
		padding: 1.75rem 1.5rem;
	}

/*---------------------------------------------- 
	5. Footer 
------------------------------------------------*/
	.footer {
		padding: 2.5rem 0 2rem 0;
		background-image: url("../images/bg-primary.jpg");
		background-size: cover;
		background-repeat: no-repeat;
		background-position: center bottom;
		position: relative;
		z-index: 0;
		min-height: 235px;
	}

	.footer__author {
		color: rgba(255, 255, 255, 0.85);
	}

	.footer__author strong {
		color: var(--white) !important;
		font-weight: 700 !important;
	}

	.footer__menu li a {
		font-weight: 500;
		color: rgba(255, 255, 255, 0.85);
		padding: 0;
		position: relative;
	}

	.footer__menu li:not(:last-child) a::after {
		content: "-";
		display: inline-block;
		padding: 0 1rem;
	}	

	@media all and (max-width: 767px) {
		.footer__brand {
			width: 25%;
		}
		.footer__menu li:not(:last-child) a::after {
			padding: 0 0.5rem;	
		}
	}