body,
button,
input,
select,
optgroup,
textarea {
	color: #404040;
	/* font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif; */
        font-family: proxima-nova, sans-serif;
        font-weight: 400;
        font-style: normal;
        font-size: 1rem;
        line-height: 1.5;
}

.no-padding {
    padding: 0;
}

/* HEADER */

.header {
    background: rgba(255,255,255,1);
    padding: 0 6%;
    -webkit-box-shadow: 0px 0px 20px 0px rgba(0,0,0,0.2);
    -moz-box-shadow: 0px 0px 20px 0px rgba(0,0,0,0.2);
    box-shadow: 0px 0px 20px 0px rgba(0,0,0,0.2);
    position: fixed;
    z-index: 9999;
    width: 100%;
}

/* HEADER LOGO */

.pwwc-logo {
    padding: 0 20px 0 0;
    margin: 40px 20px 40px 0;
    border-right: 2px solid #c9c9c9;
    float: left;
}
.pwwc-logo a {
    float: left;
}
.pwwc-logo img {
    height: 30px;
}
.pwwc-sub-logo {
    margin: 40px 0;
    font-size: 17px;
    line-height: 15px;
    color: #7d7d7d;
    text-transform: uppercase;
}

/* HEADER NAV */

.header nav ul.topmenu {
    list-style-type: none;
    display: flex;
    flex: auto;
    margin: 0px 0 0px 0;
    padding: 0;
}
.header nav ul.topmenu li {
    margin: 0 20px;
}
.header nav ul.topmenu li:last-of-type {
    margin-right: 0;
}

.header nav ul.topmenu li a {
    color: #9d9d9d;
    font-size: 20px;
    line-height: 30px;
    padding: 40px 0;
    display: block;
    font-weight: 400;
    position: relative;
}
.header nav ul.topmenu li a:hover {
    text-decoration: none;
    color: #111;
    padding-bottom: 36px;
    border-bottom: solid 4px #ffa200;
}
.header nav ul.topmenu li.current_page_item a {
    opacity: 0.5;
}
.header nav ul.topmenu li.current_page_item a:hover {
    opacity: 1;
}
.header nav .contact-button {
    width: 154px;
    font-weight: 500;
    font-size: 20px;
    line-height: 20px;
    align-items: center;
    padding: 13px 0;
    margin-left: 15px;
    color: #fff;
    background: #578fae;
    border: none;
    text-align: center;
    /*-webkit-box-shadow: 5px 5px 15px 0px rgba(0,0,0,0.15);
    -moz-box-shadow: 5px 5px 15px 0px rgba(0,0,0,0.15);
    box-shadow: 5px 5px 15px 0px rgba(0,0,0,0.15);*/
}
.header nav .contact-button:hover {
    text-decoration: none;
    background: #679fbe;
    /*-webkit-box-shadow: 5px 5px 15px 0px rgba(0,0,0,0.0);
    -moz-box-shadow: 5px 5px 15px 0px rgba(0,0,0,0.0);
    box-shadow: 5px 5px 15px 0px rgba(0,0,0,0.0);*/
}

/* FOOTER */

.footer {
    width: 100%;
    float: left;
    background: #151515;
    padding: 30px 6%;
}
.footer p {
    font-size: 16px;
    color: rgba(255,255,255,0.5);
    line-height: 1;
    margin: 0;
    padding: 0;
}


/* HOME PAGE */

/* HOME HERO */

.home-hero {
    background-image: url('../img/home-hero-bg-2.jpg');
    background-size: cover;
    background-position: center center;
    width: 100%;
    margin-top: 110px;
    float: left;
    padding: 500px 6% 100px 6%;
}
.home-hero h1 {
    color: #fff;
    font-weight: 700;
    font-size: 60px;
    line-height: 60px;
    margin: 0 0 7px -4px;
    padding: 0;
}
.home-hero h2 {
    color: #fff;
    font-weight: 300;
    font-size: 48px;
    line-height: 48px;
    margin: 0 0 20px -4px;
    padding: 0;
}
.home-hero a {
    color: #fff;
    position: relative;
    font-weight: 700;
    font-size: 24px;
    line-height: 24px;
    margin: 0;
    padding: 0;
    text-decoration: none;
}
.home-hero a:hover {
    text-decoration: underline;
}
.home-hero a:after {
    position: absolute;
    font-weight: 700;
    top: 2px;
    right: -40px;
    content: '\2192';
    font-size: 30px;
    line-height: 24px;
    color: #ffa200;
}
.home-hero a:hover:after {
    right: -45px;
}
/* HOME SECTION */

.home-section {
    width: 100%;
    float: left;
}
.no-padding .row {
    margin-left: 0 !important;
    margin-right: 0 !important;
}
.home-section .sect-img {
    background-size: cover;
    background-position: center center;
    min-height: 360px;
}
.home-section .home-section-copy {
    padding: 130px 115px;
}
.home-section .home-section-copy h1 {
    font-size: 40px;
    line-height: 42px;
    font-weight: 300;
    color: #232323;
    padding: 0;
    margin: 0 0 20px 0;
}
.home-section .home-section-copy p {
    font-size: 20px;
    line-height: 2;
    color: #646464;
    padding: 0;
    margin: 0 0 30px 0;
}
.home-section .home-section-copy a {
    color: #fff;
    font-size: 20px;
    line-height: 20px;
    padding: 15px 30px;
    text-decoration: none;
    display: inline-block;
    background: #578fae;
    font-weight: 700;
}
.home-section .home-section-copy a:hover {
    background: #679fbe;
}

/* SUB PAGES */

/* SUB PAGE HERO */

.subpage-hero {
    background-image: url('../img/home-hero-bg-2.jpg');
    background-size: cover;
    background-position: center center;
    width: 100%;
    margin: 110px 0 0 0;
    float: left;
    padding: 300px 6% 60px 6%;
}
.subpage-hero h1 {
    color: #fff;
    font-weight: 700;
    font-size: 60px;
    line-height: 60px;
    margin: 0 0 7px -4px;
    padding: 0;
}
.subpage-hero h2 {
    color: #fff;
    font-weight: 300;
    font-size: 48px;
    line-height: 48px;
    margin: 0 0 20px -4px;
    padding: 0;
}

.subpage-section {
    width: 100%;
    float: left;
    padding: 9% 12%;
}
.subpage-section:nth-of-type(even) {
    background: #fff;
}
.subpage-section .sect-img {
    background-size: cover;
    background-position: center center;
    width: 100%;
}
.subpage-section .sect-img:after {
    content: "";
    display: block;
    padding-bottom: 100%;
}
.subpage-section-copy {
    padding: 0 100px;
}
.subpage-section-copy.lt {
    padding: 0 10% 0 0;
}
.subpage-section-copy.rt {
    padding: 0 0 0 10%;
}
.subpage-section .subpage-section-copy h1 {
    font-size: 36px;
    line-height: 42px;
    font-weight: 300;
    color: #232323;
    padding: 0;
    margin: 0 0 20px 0;
}
.subpage-section .subpage-section-copy h2 {
    font-size: 32px;
    line-height: 42px;
    font-weight: 300;
    color: #232323;
    padding: 0;
    margin: 0 0 20px 0;
}
.subpage-section .subpage-section-copy p {
    font-size: 18px;
    line-height: 2;
    color: #646464;
    padding: 0;
    margin: 0 0 30px 0;
}

.subpage-section .subpage-section-copy ul {
    /*background: rgba(0,0,0,0.02); */
    padding: 0px;
    margin: 0 0 30px 0;
}
.subpage-section .subpage-section-copy ul.dbul {
    column-count: 2;
}
.subpage-section .subpage-section-copy ul.dbul li:first-of-type {
    column-span: all;
}
.subpage-section .subpage-section-copy ul li:first-of-type {
    font-size: 18px;
    font-weight: 700;
    list-style-type: none;
    margin: 0 0 20px 0;
    line-height: 1.75;
    padding-left: 0;
}
.subpage-section .subpage-section-copy ul li:first-of-type:before {
    content: none;
}
.subpage-section .subpage-section-copy ul li {
    font-size: 18px;
    line-height: 2;
    margin: 0 0 10px 0px;
    padding-left: 30px;
    list-style: none;
    position: relative;
}
.subpage-section .subpage-section-copy ul li:before {
    background: #ffa700;
    height: 9px;
    width: 9px;
    display: inline-block;
    left: 0;
    position: absolute;
    top: 0.65em;
    content: '';
}
.subpage-section .subpage-section-copy ul li:last-of-type {
    margin-bottom: 0;
}
.subpage-section .subpage-section-copy a.blubtn {
    color: #fff;
    font-size: 18px;
    line-height: 18px;
    padding: 15px 30px;
    text-decoration: none;
    display: inline-block;
    background: #578fae;
    font-weight: 700;
}
.subpage-section .subpage-section-copy a.blubtn:hover {
    background: #679fbe;
}

/* ABOUT PAGE */

.subpage-hero.about {
    background-image: url('../img/about-hero-bg.jpg');
    background-position: top right;
}

/* CAREERS PAGE */

.subpage-hero.careers {
    background-image: url('../img/about-hero-bg.jpg');
    background-position: top right;
}

/* CONTACT PAGE */

.subpage-hero.contact {
    background-image: url('../img/about-hero-bg.jpg');
    background-position: top right;
}
.subpage-section.contact .subpage-section-copy {
    padding-left: 30px;
}

/* SERVICES PAGE */

.subpage-hero.services {
    background-image: url('../img/about-hero-bg.jpg');
    background-position: top right;
}

/* CONTACT PAGE */

.contact-form {
    width: 100%;
    min-height: 700px;
    background: rgba(0,0,0,0.05);
}
.map-responsive{
    overflow:hidden;
    padding-bottom:56.25%;
    position:relative;
    height:0;
}
.map-responsive iframe{
    left:0;
    top:0;
    height:100%;
    width:100%;
    position:absolute;
}
.contact-form {
    background: #fff;
    -webkit-box-shadow: 0 0 3px 0 rgba(0,0,0,.1);
    box-shadow: 0 0 3px 0 rgba(0,0,0,.1);
    padding: 35px;
    margin-bottom: 30px;
}
span.wpcf7-not-valid-tip {
    color: #fff;
    background: #f00;
    margin-top: -8px;
    font-size: 13px;
    line-height: 13px;
    text-align: center;
    padding: 4px;
    border-bottom-left-radius: 3px;
    border-bottom-right-radius: 3px;
}
.contact-form p {
    margin-bottom: 0px !important;
}
.contact-form label {
    width: 100%;
    max-width: 100%;
    margin-bottom: 15px;
    font-size: 20px;
}
.contact-form input {
    max-width: 100% !important;
    width: 100%;
    height: 45px;
}
.contact-form textarea {
    height: 140px;
}
.wpcf7-submit {
    margin-top: 10px !important;
    border-radius: 0 !important;
    padding: 10px 30px !important;
    font-size: 22px !important;
    color: #fff !important;
    font-weight: 700 !important;
    background: #578fae !important;
    border: none !important;
    width: auto !important;
}
input[type="submit"].wpcf7-submit:hover {
    background: #679fbe !important;                                
}
div.wpcf7-validation-errors {
    background: #f00;
    color: #fff;
    border: none;
    line-height: 1.2em;
    padding: 20px;
    font-weight: 900;
    font-size: 18px;
    margin: 20px 0 0 0;
    text-align: center;
}
div.wpcf7-mail-sent-ok {
    background: #0a4;
    color: #fff;
    border: none;
    line-height: 1.2em;
    padding: 20px;
    margin: 20px 0 0 0;
    font-weight: 900;
    font-size: 18px;
    text-align: center;
}