/*
==  THEME DETAILS  ============================================================
    Theme Name: Personeelsvereniging Saxenburgh
	Theme URI: https://www.pvsxb.nl/
    Description: Stylesheet voor Personeelsvereniging Saxenburgh
    Version: 1.0
   	Author: Kracht Internet Marketing
	Author URI: https://www.krachinternetmarketing.nl

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

/*---------------------------------------------- 
	1.1 Basics
------------------------------------------------*/
	html {
  		font-size: 20px;
	}

	body {
   		font-family: 'Montserrat', sans-serif;
		font-size: 0.8rem;
	  	line-height: 1.5rem;
		font-weight: 400;
		color: #3B3B3B;
		background: #FFF; 
		-webkit-font-smoothing: antialiased;
  		-moz-osx-font-smoothing: grayscale;
	}
	
	a, a:hover, .btn, .btn:hover , .transition {
		-webkit-transition: all 0.3s ease-in-out;
		-moz-transition: all 0.3s ease-in-out;
		-ms-transition: all 0.3s ease-in-out;
		-o-transition: all 0.3s ease-in-out;
		text-decoration:none;	
	}
	
	p , figure , blockquote , ul {
		margin: 0 !important;
	}

	a {
		color: #F57238; 
	}

	a:hover {
		color: #3B3B3B;
	}

	button:focus ,
	:focus {
		outline: 0 !important;
	}
	
	h1, h2, h3, h4, h5, .h1, .h2, .h3, .h4, .h5 {
		font-family: 'Pluto Medium';
		font-weight: 400;
		line-height: 1.4;
		margin: 0;
		padding: 0;
	}

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

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

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

	.font-bold {
		font-weight: 700 !important;
	}

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

	.border-round {
		-webkit-border-radius: 10px;
		-webkit-border-top-left-radius: 0;
		-moz-border-radius: 10px;
		-moz-border-radius-topleft: 0;
		border-radius: 10px;
		border-top-left-radius: 0;
	}
	
	.bg-cover {
		background-position: center;
		background-size: cover;
		background-repeat: no-repeat;
	}

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

	i.large {
		font-size: 2.5rem;
	}

 	hr {
		margin: 0.5rem 0;
		border-top: 3px solid #F57238;
		opacity: 1;
	}

	hr.small {
		max-width: 6rem;
	}

	hr.large {
		max-width: 22.75rem;
	}

	hr.thin {
		border-top: 1px solid #F57238;
	}

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

	@media all and (max-width: 1280px) {
    	html {
			font-size: 16px;
		}
		h1, .h1 {
			font-size: 1.75rem;
		}
		h2, .h2 {
			font-size: 1.5rem;
		}
	}

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

	@media (min-width: 1280px) {
		.container {
			max-width: 1240px;
		}	
	}

	@media (min-width: 1440px) {
		.container {
			max-width: 1400px;
		}	
	}

/* Font -------------------------------------- */
	@font-face {
		font-family: 'Pluto Medium';
		src: url('fonts/PlutoMedium.eot');
		src: url('fonts/PlutoMedium.eot') format('embedded-opentype'),
			 url('fonts/PlutoMedium.woff2') format('woff2'),
			 url('fonts/PlutoMedium.woff') format('woff'),
			 url('fonts/PlutoMedium.ttf') format('truetype'),
			 url('fonts/PlutoMedium.svg#PlutoMedium') format('svg');
	}

/* Buttons -------------------------------------- */
	.btn-primary, 
	.btn-primary:active {
		background: #3B3B3B;
    	color: #FFF;
    	border: none;
	}
	
	.btn-primary:hover {
		background: #F57238;
	}

	.btn-primary:hover::after {
		color: #3B3B3B;
	}

	.btn-secondary {
		background: #F57238;
    	color: #FFF;
    	border: none;
	}
	
	.btn-secondary:hover {
		background: #3B3B3B;
	}

	.btn-third {
		background: #1D64AF;
    	color: #FFF;
    	border: none;
	}
	
	.btn-third:hover {
		background: #3B3B3B;
		color: #FFF;
	}

	.btn {
		font-size: 0.8rem;
		font-weight: 700;
		line-height: 1;
		padding: 0.7rem 1rem;
		-webkit-border-radius: 5px;
		-moz-border-radius: 5px;
		border-radius: 5px;
	}

	.btn-plus::after {
		content: "+";
		color: #F57238;
		padding-left: 0.7rem;
	}

	.button:hover i.text-orange , 
	.button:hover i.text-blue {
		color: #3B3B3B !important;
	}

	.button:hover span {
		background: #3B3B3B !important;
	}

    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 h3 + ul ,
	.content-block h4 + ul ,
	.content-block ul + p ,
	.content-block ul + h3 {
		margin-top: 1.5rem !important;
	}

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

	.content-block ul {
		list-style: none;
	  	padding: 0;
	}
	
	.content-block li {
  		position: relative;
		padding-left: 20px;
	}

	.content-block ul li:before {
		font-family: "Font Awesome 6 Pro";
		content: "\f0c8";
		font-size: 0.5rem;
		font-weight: 900;
		position: absolute;
    	left: 0;
		color: #F57238;
	}

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

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

/*---------------------------------------------- 
	1.3 Colors 
------------------------------------------------*/
	.bg-blue {
		background: #1D64AF !important;
	}

	.bg-light-blue {
		background: #D7E4F1 !important;
	}

	.bg-orange {
		background: #F57238 !important;
	}

	.bg-light-grey {
		background: #F4F3F0 !important;
	}

	.bg-light-blue {
		background: #D7E4F1 !important;
	}

	.bg-red {
		background: #FF0000 !important;
	}

    .text-black {
        color: #3B3B3B !important;
    }

	.text-blue {
		color: #1D64AF !important;
	}
	
	.text-orange {
		color: #F57238 !important;
	}

	.text-grey {
		color: #3B3B3B !important;
	}

	.text-red {
		color: #FF0000 !important;
	}

	.text-green {
		color: #00CC00 !important;
	}
	
/*---------------------------------------------- 
	1.4 Spacing 
------------------------------------------------*/
	.py-40 {
		padding: 2rem 0;
	}

	.mb-40 {
		margin-bottom: 2rem;
	}

	.mt-40 {
		margin-top: 2rem;
	}

/*---------------------------------------------- 
	1.5 Item Overzicht 
------------------------------------------------*/
	.item-overzicht figure span.date {
		font-size: 1.3rem;
		font-weight: 900;
		color: #FFF;
		display: flex;
		text-align: center;
		height: 3.2rem;
		width: 3.2rem;
		position: absolute;
		right: 0.75rem;
		bottom: 0.75rem;
	}

	.item-overzicht .wrapper {
		padding: 1.25rem 1.5rem;
	}

	.item-overzicht .wrapper .title {
		line-height: 1.5rem;
		min-height: 3rem;
	}

	.item-overzicht:hover .button i.text-orange {
		color: #3B3B3B !important;
	}

	.item-overzicht:hover .button span {
		background: #3B3B3B !important;
	}

/*---------------------------------------------- 
	1.6 Item Nieuws 
------------------------------------------------*/
	.item-nieuws .title {
		color: #3B3B3B;
	}

	.item-nieuws .title:hover {
		color: #F57238;
	}

/*---------------------------------------------- 
	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;
	}

	.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 {
		padding: 10px 15px !important;
		border: none;
		background: #F4F3F0;
		height: 60px;
		border-radius: 0;
        color: #3B3B3B !important;
		width: 100% !important;
	}

	.gform_wrapper .gform_footer input.button, .gform_wrapper .gform_footer input[type=submit], 
	.gform_wrapper .gform_page_footer input.button, .gform_wrapper .gform_page_footer input[type=submit] ,
	button.gpnf-add-entry {
		font-size: 0.8rem;
		font-weight: 700;
		line-height: 1;
		padding: 0.7rem 1rem;
		background: #F57238;
    	color: #FFF;
		-webkit-border-radius: 5px;
		-moz-border-radius: 5px;
		border-radius: 5px;
    	border: none;
	}

	.gform_wrapper.gravity-theme .gform_footer input {
		margin: 0.5rem 0 0 0 !important;
	}

	.gform_wrapper.gravity-theme .gfield input.large, 
	.gform_wrapper.gravity-theme .gfield select.large {
		height: 60px;
	}

	.gform_wrapper.gravity-theme .gfield textarea.small {
		height: 120px !important;
	}

	.gform_wrapper.gravity-theme #field_submit, 
	.gform_wrapper.gravity-theme .gform_footer {
		justify-content: flex-end;
	}

	.gform_wrapper .hidden ,
	.ginput_product_price_label {
		display: none !important;
	}

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

	.gform_wrapper .field_description_below .gfield_description {
		font-size: 0.7rem !important;
		color: #2B3A40;
		padding: 0 !important;
		border: none !important;
	}

	.gform_wrapper.gravity-theme .gform_fields {
		grid-row-gap: 15px !important;
	}

	.gform_required_legend {
		display: none !important;
	}

	.gform_wrapper .gform_validation_errors>h2 {
		font-size: 14px !important;
		margin: 0 !important;
	}
	
	.gform_wrapper.gravity-theme .gf_page_steps {
		text-align: right;
		border-bottom: 1px solid #F57238 !important;
		padding-bottom: 1.25rem !important;
		margin-bottom: 2rem !important;
	}

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

	.gform_wrapper.gravity-theme .gf_step + .gf_step {
		margin-left: 1rem;
	}

	.gform_wrapper.gravity-theme .gf_step_label {
		padding: 0;
	}

	.gform_wrapper.gravity-theme .gf_step_number {
		font-weight: 700 !important;
		border: none !important;
		background: #3B3B3B !important;
		color: #FFF !important;
	}

	.gform_wrapper.gravity-theme .gf_step_active .gf_step_number {
		background: #F57238 !important;
	}

	.gform_wrapper.gravity-theme .gf_step_completed .gf_step_number::before {
		border: none !important;
		background: #3B3B3B !important;
		top: 0 !important;
		left: 0 !important;
	}

	.gform_wrapper.gravity-theme .gform_previous_button.button, 
	.gform_wrapper.gravity-theme .gform_save_link.button {
		background: #838080;
		color: #FFF;
	}

	.gform_wrapper .field_description_below .gfield_description {
		color: #F57238;	
	}

	.gform_wrapper.gravity-theme .gfield_list_group {
		border: none !important;
	}

	.gform_wrapper.gravity-theme #field_1_78 span {
		font-size: 1.25rem !important;
		font-weight: 700 !important;
		color: #3B3B3B !important;
		background: none !important;
		padding-left: 0 !important;
		padding-right: 0 !important;
	}

/*---------------------------------------------- 
	2.1 Header 
------------------------------------------------*/
	#header .brand {
		text-align: center;
		position: absolute;
		top: 0.5rem;
		left: 3rem;
		max-width: 12rem;
		padding: 0.5rem 0.65rem;
		z-index: 9;
	}

	@media all and (max-width: 992px) {
		#header .brand {
			max-width: 9rem;	
		}
	}

	@media all and (max-width: 767px) {
		#header .brand {
			left: 1rem;	
			max-width: 8rem;
		}
	}
	
/*---------------------------------------------- 
	2.2 Navigation 
------------------------------------------------*/
	#navigation #hoofdmenu {
		padding: 1.6rem 0 1.25rem 0;
	}

	#navigation #hoofdmenu li a {
		font-size: 0.75rem;
		color: #1D64AF;
		line-height: 1;
		font-weight: 700;
		padding: 0.8rem;
		background: #F4F3F0;
		-webkit-border-radius: 5px;
		-moz-border-radius: 5px;
		border-radius: 5px;
	}

	#navigation #hoofdmenu li a::after {
		content: "+";
		color: #F57238;
		padding-left: 0.5rem;
	}

	#navigation #hoofdmenu li.member a {
		color: #FFF;
		background: #F57238;
	}

	#navigation #hoofdmenu li.member a::after {
		color: #FFF;
	}

	#navigation #hoofdmenu li a:hover ,
	#navigation #hoofdmenu li.active a {
		color: #FFF;
		background: #1D64AF;
	}

	#navigation #hoofdmenu li + li {
		margin-left: 0.8rem;
	}

	@media all and (max-width: 1200px) {
		#navigation #hoofdmenu li + li {
			margin-left: 0.5rem;
		}
		#navigation #hoofdmenu li a {
			font-size: 0.65rem;
            padding: 0.8rem 0.5rem;
		}
		#navigation #hoofdmenu li a::after {
			padding-left: 0.5rem;
		}
	}

/*---------------------------------------------- 
	2.3 Navigation Mobile
------------------------------------------------*/
	#navigation-mobile .cd-dropdown-trigger {
		display: inline-block;
    	position: relative;
    	padding: 0;
		font-size: 1rem;
		width: 2.25rem;
		height: 2.25rem;
		line-height: 2.5rem;
		background: #1D64AF;
		color: #FFF;	
		text-align: center;
		margin: 0.75rem 0;
		z-index: 99;
		-webkit-border-radius: 5px;
		-moz-border-radius: 5px;
		border-radius: 5px;
	}

	#navigation-mobile .cd-dropdown-trigger i {
		margin: 0;	
	}
	
	#navigation-mobile .cd-dropdown-content a {
		font-size: 1rem;
		font-weight: 700;
		color: #3B3B3B;
		text-align: left !important;
	}

	#navigation-mobile .current_page_item a {
		color: #F57238;
	}

	#navigation-mobile .cd-dropdown {
		background: #F4F3F0;
		z-index: 999;
	}
	
	#navigation-mobile .cd-dropdown-wrapper {
		height: auto;
		margin: 0 !important;
	}
	
	#navigation-mobile ul {
		padding-left: 0;
	}
	
	#navigation-mobile .cd-dropdown-content a, 
	#navigation-mobile .cd-dropdown-content ul a {
		border-top-width: 0.25px;
    	border-bottom-width: 0;
    	border-left-width: 0;
    	border-right-width: 0;
    	border-color: #D6D5D3;
    	border-style: solid;	
	}
	
	#navigation-mobile .cd-dropdown-content .go-back a {
		background: #FFF;
		color: #454545;
	}

	.go-back a::before, .go-back a::after {
		background: #FFF !important;	
	}
	
	#navigation-mobile .cd-secondary-dropdown > a,
	#navigation-mobile .cd-secondary-dropdown > .go-back a {
  		display: none !important;
		background: #FFF;
	}

	#navigation-mobile .has-children > a::before, 
	#navigation-mobile .has-children > a::after, 
	#navigation-mobile .go-back a::before, .go-back a::after ,
	.cd-dropdown .cd-close::after, 
	.cd-dropdown .cd-close::before {
		background: #F57238 !important;
	}

	#navigation-mobile .cd-secondary-dropdown > .go-back a + a {
		display: block !important;
	}

/*---------------------------------------------- 
	3.1 Hero 
------------------------------------------------*/
	#hero .item img {
		-webkit-border-radius: 40px;
		-webkit-border-top-left-radius: 0;
		-moz-border-radius: 40px;
		-moz-border-radius-topleft: 0;
		border-radius: 40px;
		border-top-left-radius: 0;
	}
	
	#hero .item .wrapper {
		padding: 1rem 1.25rem;
		position: absolute;
		bottom: 3rem;
		left: 3rem;
		max-width: 40rem;
	}

	#hero .item .button ,
	#hero .item .closed {
		position: absolute;
		bottom: 3rem;
		right: 3rem;
	}	

	#hero::after {
		content: "";
		display: block;
		width: 100%;
		height: 3rem;
		background: #F4F3F0;
		position: absolute;
		bottom: 0;
	}

	@media all and (max-width: 767px) {
		#hero::after {
			height: 6rem;	
		}
		#hero .item .wrapper {
			position: relative;
			left: inherit;
			top: -2rem;
			margin: 0 0.5rem;
			z-index: 8;
		}
	}

/*---------------------------------------------- 
	3.2 Frontpage Nieuws
------------------------------------------------*/
	#frontpage-nieuws {
		background-image: url(../images/nieuws-bg.jpg);
	}

/*---------------------------------------------- 
	4. Page Intro
------------------------------------------------*/
	#page-intro {
		padding-top: 6rem;
	}

	#page-intro .wrapper {
		padding: 1rem 1.25rem;
	}

	#page-intro::after {
		content: "";
		display: block;
		width: 100%;
		height: 4.25rem;
		background: #FFF;
		position: absolute;
		bottom: 0;
	}

	@media all and (max-width: 992px) {
		#page-intro {
			padding-top: 7.5rem;
		}
	}

/*---------------------------------------------- 
	5.1 Module Bestuur
------------------------------------------------*/
	#page-modules .bestuur .item hr {
		border-top: 1px solid #F57238;
		margin: 0.25rem 0;
	}

	@media (min-width: 1200px) {
		#page-modules .bestuur .item {
			width: 20%;
			flex: 0 0 auto;
		}
	}

/*---------------------------------------------- 
	6.1 Footer Top
------------------------------------------------*/
	#footer-top #footer-menu li a {
		font-size: 0.8rem;
		color: #FFF;
		line-height: 1;
		font-weight: 700;
		padding: 0;
		background: none;
		
	}

	#footer-top #footer-menu li a::after {
		content: "+";
		color: #F57238;
		padding-left: 0.7rem;
	}

	#footer-top #footer-menu li.member a {
		color: #FFF;
		background: #F57238;
		padding: 0.8rem 0.9rem;
		-webkit-border-radius: 5px;
		-moz-border-radius: 5px;
		border-radius: 5px;
	}

	#footer-top #footer-menu li.member a::after {
		color: #FFF;
	}

	#footer-top #footer-menu li.member a:hover {
		color: #1D64AF;
		background: #FFF;
	}

	#footer-top #footer-menu li.member a:hover::after {
		color: #F57238;
	}

	#footer-top #footer-menu li + li {
		margin-left: 2.75rem;
	}

	#footer-top #footer-menu li a:hover {
		color: #F57238;
	}

	@media all and (max-width: 992px) {
		#footer-top #footer-menu li + li {
			margin-left: 0.75rem;
		}
		#footer-top #footer-menu li a {
			font-size: 0.7rem;
		}
		#footer-top #footer-menu li a::after {
			padding-left: 0.25rem;
		}
	}

	@media all and (max-width: 767px) {
		#footer-top #footer-menu li {
			display: none;
		}
		#footer-top #footer-menu li.member {
			display: block;
			margin-left: 0;
		}
	}

/*---------------------------------------------- 
	6.2 Footer Bottom
------------------------------------------------*/
	#footer-bottom {
		padding: 1.25rem 0;
	}

	#footer-bottom .social-media li a {
		font-size: 2.5rem;
		color: #1D64AF;
	}

	#footer-bottom .social-media li a:hover {
		color: #3B3B3B;
	}
	
	#footer-bottom .social-media li.list-inline-item:not(:last-child) {
		margin-right: 0.75rem;
	}