/* CSS Document */


/*
	Extra small devices (portrait phones, less than 576px)
	No media query since this is the default in Bootstrap

	Small devices (landscape phones, 576px and up)
	@media (min-width: 576px) { ... }

	Medium devices (tablets, 768px and up)
	@media (min-width: 768px) { ... }

	Large devices (desktops, 992px and up)
	@media (min-width: 992px) { ... }

	Extra large devices (large desktops, 1200px and up)
	@media (min-width: 1200px) { ... }
*/


/*
	Google Font
*/

@import url('https://fonts.googleapis.com/css2?family=Raleway:wght@200;300;400;500;600;700;800;900&display=swap');

body {
    font-family: 'Raleway', sans-serif;
	background: #ffffff;
}

/*
	Background Colors
*/


span.error {
    color: red;
}


/*
	Text Styling
*/

* {
    -webkit-tap-highlight-color: rgba(255, 255, 255, 0) !important;
    -webkit-focus-ring-color: rgba(255, 255, 255, 0) !important;
    outline: none !important;
}


/*
	Header
*/

.ppn_how-it-works {
    overflow-y: scroll;
}


h1 {
	font-weight: 300;
    text-transform: uppercase;
	font-size: 24px;
	margin-top: 30px;
	margin-bottom: 0;
}

.normal-page h1 {
	margin-bottom: 20px;
}

h2 {
	font-weight: bold;
	font-size: 24px;
	margin-top: 30px;
	margin-bottom: 0;	
}


.footer p a { 
	padding: 5px;
	color: #ffffff;
	font-size: 14px;
}

.footer p a:hover {
	text-decoration: none;
}

.mb {
	margin-bottom: 20px;
}

/* Tom style */

p {
	font-size: 15px;
}

.top-header {
    background: #108bd9;
    padding-top: 3px;
    padding-bottom: 3px;
}

.top-header .telephone a {
    font-size: 27px;
    color: white;
    font-weight: 600;
    padding-top: 0;
    padding-bottom: 0;
}

.header .nav-item a {
    font-size: 15px;
    font-weight: 600;
    color: #3c3c3b;
}

.header {
    background: none;
    padding-top: 4px;
    padding-bottom: 4px;
}

.header .nav-item .nav-link {
    padding-left: 40px;
    padding-right: 0px;
}

.intro-section {
    background: #f5f5f5;
    padding-top: 65px;
    padding-bottom: 65px;
}

.intro-section h4 {
    font-size: 47px;
    font-weight: 700;
    color: #108bd9;
    padding-left: 40px;
    padding-right: 40px;
}

.carousel-indicators {
    display: none;
}

.how-it-works, .benefits{
    background: #f5f5f5;
    padding-top: 34px;
    padding-bottom: 34px;
    border-bottom: 1px solid #ad1913;
}

.how-it-works.first-section {
    border-top: 1px solid #ad1913;
}

.faq-section, .contact-form-section, .ppn_about .about-page, .ppn_privacy .privacy-page, .ppn_cookie .cookie-page, .ppn_terms .terms-page, .ppn_post-a-job .post-a-job-page {
    padding-top: 34px;
    padding-bottom: 34px;
}

.how-it-works .title h1, .benefits .title h1, .faq-section .title h1, .ppn_privacy .privacy-text h1, .ppn_cookie .cookie-text h1, .ppn_terms .terms-text h1, .ppn_post-a-job .post-a-job-page .title h1  {
    font-size: 28px;
    font-weight: 700;
    color: #ad1913;
    margin-top: 0px;
}
.ppn_privacy .privacy-text h1, .ppn_cookie .cookie-text h1, .ppn_terms .terms-text h1 {
    padding-bottom: 12px;
}

.how-it-works-blocks, .benefits-blocks {
    padding-top: 35px;
}

.how-it-works-blocks p, .benefits-blocks p {
    font-size: 15px
}

.how-it-works-blocks h4, .benefits-blocks h4 {
    font-size: 16px;
    color: #212529;
    margin-bottom: 0px;
    padding-top: 14px;
    font-weight: 700;
    padding-bottom: 14px;
}

.benefits-blocks.last {
    padding-top: 0px;
}

.benefits-blocks.last p {
    font-size: 15px;
}

.benefits-blocks.last h4 {
    font-size: 16px;
    color: #212529;
    margin-bottom: 0px;
    padding-top: 14px;
    font-weight: 700;
}

.about-section h1 {
    text-transform: none;
    margin-top: 0px;
    color: #108bd9;
    font-size: 28px;
    padding-bottom: 25px;
}

.about-section {
    padding-top: 34px;
    padding-bottom: 34px;
    border-bottom: 1px solid #ad1913;
}

.homepage-contact {
    padding-top: 34px;
    padding-bottom: 34px;
    background: #108bd9;
}

.homepage-contact h1 {
    text-transform: none;
    margin-top: 0px;
    color: white;
    font-size: 28px;
    padding-bottom: 15px;
    font-weight: 700;
}

.homepage-contact p {
    font-size: 15px;
    color: white;
}

.homepage-contact .form-control {
    border-radius: 0;
    font-size: 14px;
    border: 0;
    margin-bottom: 10px;
}

.ppn_contact .contact-form .form-control {
    border-radius: 0;
    font-size: 14px;
    border: 1px solid #cacaca;
    margin-bottom: 10px;
}

.homepage-contact .btn {
    border: none;
    border-radius: 0;
    font-size: 14px;
}

.footer {
    padding-top: 22px;
    padding-bottom: 22px;
}

.footer-nav {
    padding-top: 8px;
    padding-bottom: 8px;
}

.footer-nav a {
    padding-left: 0px;
    font-size: 15px;
    color: #3c3c3b;
    font-weight: 600;
}

.navbar-dark .navbar-toggler {
    border-color: transparent;
}

.navbar-dark .navbar-toggler-icon {
    background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' width='30' height='30' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%2860, 60, 59, 1%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e")
}

.navbar-dark .navbar-nav .nav-link {
     color: #3c3c3b;
}

.navbar-dark .navbar-nav .nav-link:focus, .navbar-dark .navbar-nav .nav-link:hover {
    color: #108bd9;
}

.navbar {
    padding: 7px 0 7px 0;
}

a:not([href]):not([tabindex]):focus, a:not([href]):not([tabindex]):hover {
    color: white;
}

.intro-banner {
    position: relative;
    overflow: hidden;
}

.intro-banner-caption {
    position: absolute;
    top: 35%;
    left: 50%;
    transform: translate( -50%, -50% );
    text-align: center;
    color: white;
    font-weight: bold;
}

.intro-banner .intro-banner-caption h3 {
    font-size: 25px;
    font-weight: 800;
    color: #ad1913; 
}

.intro-banner-button {
    position: absolute;
    top: 75%;
    left: 50%;
    transform: translate( -50%, -50% );
}

.intro-banner .intro-banner-button a {
    font-size: 15px;
    font-weight: 500;
    color: white; 
    background: rgba(173, 25, 19, 0.7);
    padding: 7px;
    width: 100%;
    display: block;
}

  .intro-section h4 {
    font-size: 23px;
    padding-left: 15px;
    padding-right: 15px;
  }
  
  .intro-section {
    padding-top: 35px;
    padding-bottom: 35px;
  }

  .about-section .title h1, .ppn_about .about-text h1 {
    text-align: left;
  }
  
  .footer-nav {
    text-align: center!important;
  }

   .top-header .telephone a {
    font-size: 22px;
    padding-right: 18px;
  } 
  
  .header .nav-item .nav-link {
    padding-left: 17px;
  }  

  .navbar-dark .navbar-nav .nav-link {
    font-size: 13px;
  }

  .header .nav-item .nav-link {
    padding: 19px 0px 19px 0px;
    border-bottom: 1px solid #f2f2f2;
    margin: 0 15px 0;
  }


  .header .nav-item .nav-link.last-item  {
    border-bottom: none;
    padding: 19px 0px 6px 0px;
  }

  .intro-banner .intro-banner-caption h3  {
    font-size: 28px;
  }

  .intro-banner .intro-banner-button a  {
    font-size: 19px;
  }

.btn:not(:disabled):not(.disabled) {
    background: white;
    color: black;
    border: 1px solid #cacaca;
    border-radius: 0px;
}

.ppn_faq .faq-background, .ppn_contact .contact-background, .ppn_about .about-background, .ppn_privacy .privacy-background, .ppn_cookie .cookie-background, .ppn_terms .terms-background, .ppn_post-a-job .post-a-job-background { 
    background: #f5f5f5;
}

.faq-section .title p {
    font-size: 15px;
    margin-bottom: 0px;
}

.accordion {
    padding-top: 20px;
}

.accordion h2 {
    margin-top: 0px;
}

.accordion .card-header {
    background: white;
}

.accordion .btn {
    color: #212529;
}

.accordion .btn:hover {
    color: #108bd9;
}

.accordion .btn-link.focus, .btn-link:focus {
    color: #108bd9;
}

.accordion .card {
    margin-bottom: 12px;
}

.accordion .card:last-child {
    margin-bottom: 0px;
}

.accordion .btn:not(:disabled):not(.disabled) {
    padding-left: 0px;
}

.contact-form-section .title h1 {
    font-size: 28px;
    font-weight: 700;
    color: #108bd9;
    margin-top: 0px;
    padding-bottom: 12px;
}

.ppn_about .about-text h1 {
    font-size: 28px;
    font-weight: 700;
    color: #108bd9;
    margin-top: 0px;
    padding-bottom: 12px;
    text-transform: none;
}

.ppn_about .about-image {
    padding-bottom: 20px;
}

.ppn_index .about-section .title h1 {
    text-align: left;
}

.ppn_post-a-job .post-a-job-page .title p {
    font-weight: 700;
}

.ppn_post-a-job .post-a-job-page h2 {
    font-weight: 700;
    color: #ad1913;
    font-size: 16px;
    margin-top: 0;
}

.ppn_index .invalid-feedback {
    color: white;
    padding-bottom: 18px;
    font-style: italic;
    font-weight: 600;
    font-size: 14px;
    margin-top: -7px;
    text-decoration: underline;
}

.ppn_index .form-control, .ppn_contact .contact-form .form-control {
    color: black;
}

.ppn_contact .invalid-feedback {
    color: red;
    padding-bottom: 18px;
    font-style: italic;
    font-weight: 600;
    font-size: 14px;
    margin-top: -7px;
}

.ppn_faq .btn:not(:disabled):not(.disabled) {
    border: 0;
    font-size: 14px;
    font-weight: 500;
}

.ppn_faq .accordion>.card:not(:last-of-type) {
    border-bottom: 1px solid rgba(0,0,0,.125);
}

.ppn_faq .btn.focus, .btn:focus {
    box-shadow: none;
}

.footer-nav a:hover {
    color: #108bd9;
    text-decoration: none;
}

.intro-banner2 .content .fas {
    padding-left: 8px;
}

.homepage-contact .btn:hover {
    color: white!important;
    text-decoration: none;
    background: black!important;
}

.contact-form-section .btn:hover {
    color: white!important;
    text-decoration: none;
    background: #108bd9!important;
}

.footer .logo {
    padding-bottom: 13px;
}

.ppn_contact .contact-form-section .btn {
    color: white;
    background: #ad1913;
}

.ppn_contact .opening-times {
    background: white;
}

.ppn_contact .opening-times h2 {
    padding-bottom: 9px;
    margin-top: 20px;
    color: #108bd9; 
}

.ppn_contact .open-days p {
    font-weight: 600;
}

button.btn.btn-link.btn-block.text-left.collapsed::after {
    position: absolute;
    right: 20px;
    font-family: "Font Awesome 5 Free";
    content: "\f078";
    font-weight: 900;
}


button.btn.btn-link.btn-block.text-left::after {
    position: absolute;
    right: 20px;
    font-family: "Font Awesome 5 Free";
    content: "\f077";
    font-weight: 900;
}

/*.ppn_faq .btn-link.focus, .btn-link:focus {
    color: #108bd9!important;
}*/

button.btn.btn-link.btn-block.text-left.collapsed {
    color: #212529;
}

button.btn.btn-link.btn-block.text-left {
    color: #108bd9;
}

.ppn-contact .contact-form-section .success-message {
    font-weight: 700!important;
    font-style: italic!important;
}

/* Post a job box */
	.intro-banner2 {
    background: url("/~wpc/assets/images/xl-intro-banner.jpg");
	min-height: 324px;
    width: 100%;
    background-repeat: no-repeat;
    background-position: top center;
    background-size: cover;
    background-color: #fff;	
	}
	.box { display: table-cell; text-align: left; }	
	.valign-middle { vertical-align: middle; }
	.caption {
    position: absolute;
    top: 0;
    right: 0;
    left: 0;
    bottom: 0;
    padding: 0;
    text-align: right;
    text-shadow: none;
	}

.caption .container {
    display: table;
    width: 100%;
    height: 100%;
    max-width: 1170px;
    margin-left: auto;
    margin-right: auto;
    text-align: center;
}	
.content h3 {
    margin-bottom: 20px;
    font-weight: 800;
    color: #ad1913;
    font-size: 28px;
}	

.caption a {
    font-weight: 500;
    color: white;
    background: rgba(173, 25, 19, 0.7);
    padding: 7px;
    width: 86%;
    display: block;
    font-size: 19px;
    font-size: 19px;
    margin: 0 auto;
    word-spacing: 2px;

}

.accordion a {
  color: #108bd9;
}

/* Post a job box END */


/* Small devices */

@media screen and (min-width: 576px) {
    .benefits-blocks.last {
    padding-top: 35px;
  }
    .footer-nav {
    padding-top: 8px!important;
    padding-bottom: 0px!important;
  }
  .ppn_index .about-section .title h1 {
    text-align: center;
  }
   .intro-banner2 {
    height: 100%;
  }
   .content h3 {
   margin-bottom: 58px!important;
   width: 90%;
   margin: 0 auto;
  }
   .caption a {
   width: fit-content;
   width: max-content;
   padding: 8px 40px;
  }
  .how-it-works-blocks p, .benefits-blocks p {
   margin-left: 20px;
   margin-right: 20px;
  }
  .footer .logo {
  padding-bottom: 0px;
  }
  .ppn_contact .needs-validation {
    margin-bottom: 0px;
  }
  .ppn_contact .form-control.message {
    height: 112px;
  }
}


/* Medium devices */

@media screen and (min-width: 768px) {
    .intro-section h4  {
    font-size: 45px; 
    padding-left: 55px;
    padding-right: 55px;
  }
    .header .nav-item .nav-link {
    border-bottom: none;
    font-size: 14px;
  }
    .footer-nav {
    text-align: left!important;
  }
    .content h3 {
    margin-bottom: 60px!important;
    width: 87%;
  }
}

/* Large device */

@media screen and (min-width: 992px) {
    .intro-banner .intro-banner-caption h3  {
    font-size: 28px;
  }
    .intro-banner .intro-banner-button a  {
    font-size: 19px;
  }
    .header .nav-item .nav-link {
    border-bottom: none;
    font-size: 15px;
  }
  .intro-section {
    padding-top: 54px;
    padding-bottom: 54px;
  }
  .footer-nav {
    padding-top: 15px!important;
    text-align: center!important;
    padding-left: 0px;
    padding-right: 0px;
  }
  .footer-nav a {
    font-size: 13px;
  }
  .content h3 {
    width: 69%;
  }
}

/* Extra large devices */

@media screen and (min-width: 1200px) {
  .footer-nav a {
    font-size: 15px;
  }
}


/* IE overides */

@media screen and (-ms-high-contrast: active), (-ms-high-contrast: none) {
  .caption a {
    display: inline;
  }
  body {
    font-weight: 300;
  }
  h1 {
	font-weight: 200;
  }
  h2 {
	font-weight: 900;
}
  .top-header .telephone a {
    font-weight: 500;
}

.header .nav-item a {
    font-weight: 500;
}
  .intro-section h4 {
    font-weight: 600;
}
  .how-it-works .title h1, .benefits .title h1, .faq-section .title h1, .ppn_privacy .privacy-text h1, .ppn_cookie .cookie-text h1, .ppn_terms .terms-text h1, .ppn_post-a-job .post-a-job-page .title h1  {
    font-weight: 600;
    font-weight: 600;
}
  .how-it-works-blocks h4, .benefits-blocks h4 {
    font-weight: 600;
}
  .benefits-blocks.last h4 {
    font-weight: 600;
}
  .homepage-contact h1 {
    font-weight: 600;
}
  .footer-nav a {
    font-weight: 500;
}
  .intro-banner-caption {
    font-weight:700;
}
  .intro-banner .intro-banner-caption h3 {
    font-weight: 700;
}
  .intro-banner .intro-banner-button a {
    font-weight: 400;
}
  .contact-form-section .title h1 {
    font-weight: 600;
}
  .ppn_about .about-text h1 {
    font-weight: 600;
}
  .ppn_post-a-job .post-a-job-page .title p {
    font-weight: 700;
}

.ppn_post-a-job .post-a-job-page h2 {
    font-weight: 600;
}

.ppn_index .invalid-feedback {
    color: white;
    font-weight: 500;
}
  .ppn_contact .invalid-feedback {
    color: red;
    font-weight: 500;
}

.ppn_faq .btn:not(:disabled):not(.disabled) {
    font-weight: 400;
}
  .ppn_contact .open-days p {
    font-weight: 600;
}

button.btn.btn-link.btn-block.text-left.collapsed::after {
    font-weight: 800;
}


button.btn.btn-link.btn-block.text-left::after {
    font-weight: 800;
}
  .content h3 {
    font-weight: 700;
}	

.caption a {
    font-weight: 400;
}
  
.ppn_contact .opening-times h2 {
    font-weight: 700;
  }
}










