/*
Theme Name: RD2, Inc.
Theme URI: https://rd2inc.com
Description:
Version: 5.0
Author: RD2, Inc.
Author URI: https://rd2inc.com/
Tags:

*/
@font-face {
    font-family: 'Pharma_RegularCon';
    src: url( 'http://fnt.webink.com/wfs/?drawer=60E02B64-E38A-4481-B938-A0CB9EA77702&font=094C8041-ECCC-E568-CF1E-5930F4DB90CF');
    font-weight: normal;
    font-style: normal;
}
@font-face {
    font-family: 'Pharma_Bold';
    src: url( 'http://fnt.webink.com/wfs/?drawer=60E02B64-E38A-4481-B938-A0CB9EA77702&font=B8DA0491-70BB-DE97-DD44-643DFC356B39');
    font-weight: normal;
    font-style: normal;
}
@font-face {
    font-family: 'Pharma_Regular';
    src: url( 'http://fnt.webink.com/wfs/?drawer=60E02B64-E38A-4481-B938-A0CB9EA77702&font=0A021AC8-6332-0ED2-6961-D7605858ACE5');
    font-weight: normal;
    font-style: normal;
}
@font-face {
    font-family: 'Pharma_BoldCon';
    src: url( 'http://fnt.webink.com/wfs/?drawer=60E02B64-E38A-4481-B938-A0CB9EA77702&font=F71CA0B6-0246-E56B-9400-BBC39B88DF36');
    font-weight: normal;
    font-style: normal;
}

/* ================================ Resets / Base Styles ================================ */

html {
    margin: 0;
    padding: 0;
    background: url('images/dots.gif') repeat;
}
/* Default font size for browsers is 16px, we are going to base everything off of that */
body {
    margin: 0;
    padding: 0;
    text-align: center;
    color: #777777; /* grey */
}
body div#pageWrap {
    width: 100%;
    margin: 0 auto;
    background: #EEE;
    position: relative;
}
body, h1, h2, h3, h4, h5, h6, td, p, li, input, select, textarea { font-family: Arial, Helvetica, sans-serif; }
a, a:visited, a:active {
    color: #555;
    text-decoration: none;
    outline: 0;
    border-bottom: 1px dotted #555;
}
a:hover { border-bottom: 1px solid #555; }
img { border: 0; }
p, ul, ol, dl {
    margin: 0 0 1.2em 0;
    padding: 0;
    font-size: 100%;
    line-height: 1.45em;
}
div#content p,
div#content ul,
div#content ol,
div#content dl {
    font-size: 0.875em; /* 14px / 16px */
}
ul li, ol li {
    font-size: inherit; /* 13px / 16px */
    margin-bottom: 0.4em;
}
dl dt { font-weight: bold; }
dl dd { margin: 0 0 0.5em 0; }
input, textarea,select, td, th { font-size: 0.8125em; /* 13px / 16px */; }
acronym,abbr {
    border-bottom: 1px dotted black;
    cursor: help;
}
sup { font-size: 0.75em; /* 13px / 16px */; }
code { font: 1.1em 'Courier New', Courier, Fixed; }
blockquote {
    margin: 1.0em 30px 1.0em 10px;
    padding-left: 20px;
    font-style: oblique;
}
blockquote cite {
    margin: 5px 0 0;
/*    display: block;*/
    font-style: normal;
}
hr { /* For Internet Explorer */ clear: both; nowhitespace: afterproperty; height: 1px; color: #666; /* light grey */ border: none; margin-bottom:1.0em; ; }
html>body hr { /* For Gecko-based browsers */ clear: both; height: 1px; background-color: #666; border: none; margin-bottom:1.0em; ; }
html>body hr { /* For Opera and Gecko-based browsers */ clear: both; height: 1px; background-color: #666; border: 0px solid #666; margin-bottom:1.0em; ; }
.hidden { display: none; }
.error { color: #CC0000; }

img {
    max-width: 100%;
    width: auto !important;
    height: auto !important;
}

a.large-black-btn,
p.large-black-btn a {
    background: #1B1818;
    display: inline-block;
    height: 42px;
    line-height: 42px;
    padding: 0 30px;
    color: #eee;
    border: none;
    margin: 0 15px 5px 0;
}
a.large-black-btn:hover,
p.large-black-btn a:hover {
    background: #C00B13;
}


/* ================================ Headers ================================ */

/*
     h1 - page titles
    h2 - section titles
    h3 - subtitles/sidebar titles
    h4 - sidebar subtitles
*/
h1 {
    font-size: 1.5625em; /* 25px / 16px */
    color: #555555;
    padding: 0 0 5px 0;
    margin: 0;
    font-family: 'Pharma_Regular', Arial, serif;
    clear: both;
    font-weight: normal;
    position: relative;
}
h2 {
    font-size: 1.25em; /* 20px / 16px */
    color: #777777;
    margin: 0 0 20px 0;
    font-family: 'Pharma_Regular', Arial, serif;
    clear: both;
    font-weight: normal;
}
h3 {
    font-size: 1.125em; /* 18px / 16px */
    margin: 0 0 8px 0;
    clear: both;
    font-weight: normal;
}
h4 {
    font-size: 1.0em; /* 16px / 16px */
    margin: 0 0 4px 0;
}
h5 {
    font-size: 0.625em; /* 10px / 16px */
    text-transform: uppercase;
    font-weight: normal;
}

/* ================================ Layout Containers ================================ */



div#page {
    margin: 0 auto 100px auto;
    padding: 0;
    text-align: left;
    position: relative;
    zoom: 1;
}
div#page { display: inline-block; } /* for IE/Mac */
div#content {
    margin: 0 auto 0 auto;
    position: relative;
    /*overflow: hidden;*/
}
div#content div#copy {
    margin: 0 auto;
    text-align: left;
    clear: both;
    position: relative;
    z-index: 10;
}
div#footer {
    clear: both;
    position: relative;
    width: 100%;
    text-align: left;
}

/* ================================ Header ================================ */

div#header {
    position: relative;
    width: 100%;
    text-align: left;
    overflow: hidden;
}
div#header div#navigation-wrapper {
    background: #1B1818;
    height: 129px;
    padding: 5px 0 0 0;
    display: inline-block;
    float: left;
}
div#logo {
    padding: 23px 0 0 0;
    width: 150px;
    height: 73px;
    cursor: pointer;
    float: left;

}
div#logo a {
    margin: 0 0 0 0;
    padding: 0;
    position: relative;
    width: 120px;
    height: 73px;
    overflow: hidden;
    text-indent: -10000px;
    display: block;
    cursor: pointer;
    border: 0;
}
div#logo a span {
    display: block;
    position: absolute;
    left: 0;
    top: 0;
    z-index: 1;
    width: 120px;
    height: 73px;
    margin: 0;
    padding: 0;
    background: url('images/rd2.png') top left no-repeat;
    cursor: pointer;
}
div#header ul {
    list-style-type: none;
    border-left: 1px solid #454343;
    padding-left: 25px;
    padding-bottom: 15px;
    float: left;
    margin-top: 20px;
    margin-bottom: 0;
    height: 94px;
}
div#header ul li {
    display: block;
    margin-bottom: 10px;
    line-height: 12px;
    font-family: 'Pharma_Regular', Arial, serif;
    font-weight: normal;
}
div#header ul li a {
    color: #777777;
    font-size: 1.0em; /* 16px / 16px */
    padding: 3px;
    border: 0;
}
div#header ul li a:hover,
div#header ul li.current_page_item a,
div#header ul li.current_page_parent a,
body.page-template-page-team-php div#header ul li#menu-item-26 a { color: #c00b13; }
body.error404 div#header ul li.current_page_parent a,
body.search div#header ul li.current_page_parent a { color: #777777; }


div.tools a.twitter {
    background: url(images/social.png) no-repeat 0 0;
    width: 23px;
    height: 16px;
    display: block;
    text-indent: -10000px;
    border: 0;
    float: left;
    margin: 3px 0 0 9px;
}
div.tools a.facebook {
    background: url(images/social.png) no-repeat -36px 0;
    width: 15px;
    height: 16px;
    display: block;
    text-indent: -10000px;
    border: 0;
    float: left;
    margin: 3px 0 0 9px;
}
div.tools a.rss {
    background: url(images/social.png) no-repeat -59px 0;
    width: 16px;
    height: 16px;
    display: block;
    text-indent: -10000px;
    border: 0;
    float: left;
    margin: 3px 10px 0 11px;
}
div.tools a.twitter:hover { background-position: 0 -30px; }
div.tools a.facebook:hover { background-position: -36px -30px; }
div.tools a.rss:hover { background-position: -59px -30px; }

form#site_search {
    position: relative;
    /* see responsive.css */
    margin-bottom: 8px;
}
form#site_search input {
    /* see responsive.css */
    border: 0;
    background: #363434;
    font-size: 0.75em; /* 12px / 16px */
    margin: 0 10px 0 0;
    padding: 3px 3px 3px 28px;
    color: #eeeeee;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
    -webkit-border-radius: 0;
}
form#site_search button {
    background: url(images/icon/search.png) no-repeat center center;
    display: block;
    border: 0;
    height: 22px;
    width: 28px;
    margin: 0;
    position: absolute;
    /* see responsive.css */
    left: 0;
    text-indent: -10000px;
    cursor: pointer;
}

div.sharer {
    background: url(images/bg-share.png) repeat;
    clear: both;
    width: 249px;
    display: inline-block;
}
div.sharer h5 {
    display: block;
    text-align: center;
    height: 33px;
    line-height: 33px;
    color: #333;
    cursor: pointer;
    margin: 0;
    padding: 0;
}
div.sharer h5.opened,
div.sharer h5:hover { background: #fff; }
div.sharer h5 em {
    font-style: normal;
    color: #c00b13;
}
div.sharer div {
    display: none;
    padding: 0 8px 0 16px;
    padding-bottom: 10px;
    height: 24px;
    background: #fff;
}
div.sharer div span {
    margin-right: 8px;
    width: 24px;
    height: 24px;
    display: block;
    float: left;
}
div.sharer div span.st_plusone_button { width: 32px; }
div.sharer div span.st_plusone_button div {
    width: 32px !important;
    margin: 0;
    padding: 0 !important;
}

/* ================================ Subnavigation ================================ */

div#content ul.menu {
    list-style-type: none;
    zoom: 1;
    z-index: 10000;
    display: block;
    position: relative;
    height: 42px;
    overflow: visible;
    width: 100%;
}
div#content ul.menu li {
    float: left;
    position: relative;
    z-index: 10000;
    width: 32.7818%;
    margin-right: 0.8273%;
    zoom: 1;
    overflow: visible;
    display: block;
    margin-bottom: 0;
}
div#content ul.menu li.last-li {
    margin-right: 0;
    float: right;
}
div#content ul.menu li a {
    color: #777777;
    background: #fff;
    font-size: 1.07142857em; /* 15px / 14px */
    width: 100%;
    height: 42px;
    line-height: 42px;
    text-align: center;
    display: block;
    border: 0;
}
div#content ul.menu li a:hover,
div#content ul.menu li.highlight a {
    background: #1B1818;
    color: #EEEEEE;
}
div#content ul.menu li.current_page_item a,
div#content ul.menu li.current-menu-ancestor a,
body.single-work div#content ul.menu li.last-li a,
body.single-team div#content ul.menu li.last-li a,
body.date div#content ul.menu li#menu-item-5661 a,
body.author div#content ul.menu li#menu-item-5652 a,
body.category div#content ul.menu li#menu-item-5660 a {
    background: #C00B13;
    color: #EEEEEE;
}
body.blog div#content ul.menu li.current_page_item a {
    color: #777777;
    background: #fff;
}
body.blog div#content ul.menu li.current_page_item a:hover,
body.blog div#content ul.menu li.current_page_item.highlight a:hover {
    background: #1B1818;
    color: #EEEEEE;
}
div#content ul.menu li ul.sub-menu {
    zoom: 1;
    position: absolute;
    top: 42px;
    left: 0;
    width: 100%;
    padding-top: 0;
    z-index: 10000;
    background: #1B1818;
    border-top: 3px solid #eeeeee;
    padding: 5px 0 5px 0;
    display: none;
}
div#content ul.menu li:hover ul.sub-menu {


}
div#content ul.menu li ul.sub-menu li {
    width: auto;
    margin: 0;
    padding: 0;
    display: block;
    float: none;
    text-align: left;
    z-index: 10000;
    zoom: 1;
    overflow: hidden;
}
div#content ul.menu li ul.sub-menu li a,
body.single-work div#content ul.menu li.last-li ul.sub-menu li a {
    background: none !important;
    font-weight: normal;
    text-transform: none;
    color: #EEEEEE !important;
    display: block;
    text-align: left;
    padding: 0 15px 0 15px;
    height: 26px;
    line-height: 26px;
    zoom: 1;
    font-size: 15px;
}
div#content ul.menu li ul.sub-menu li a:hover,
body.single-work div#content ul.menu li.last-li ul.sub-menu li a:hover {
    border: 0;
    background: #C00B13 !important;
}
div#content ul.menu li ul.sub-menu li.first-li a,
body.single-work div#content ul.menu li.last-li ul.sub-menu li.first-li a {
    padding: 0 15px 8px 15px;
    border-bottom: 1px dotted #EEEEEE;
    margin: 0 0 10px 0;
    width: 287px;
}
div#content ul.menu li ul.sub-menu li.first-li a:hover,
body.single-work div#content ul.menu li.last-li ul.sub-menu li.first-li a:hover {
    color: #c00b13;
    background: #1B1818;
}

/* submenu dropdown for mobile */
div#content div.mobile-dropdown-wrapper {
    width: 90%;
    overflow: hidden;
    margin: auto;
}
div#content select.dropdown-menu {
    width: 100%;
    padding: 5px;
    margin: 25px 0 25px 0;
    -webkit-border-radius: 0;
    -moz-border-radius: 0;
    border-radius: 0;
    border: 0;
}
div#content select.dropdown-menu option.menu-item-depth-0 {
    font-size: 1.15em;
    color: #c00b13;
}

/* ================================ Footer ================================ */

div#footer-navigation {
    background: #1B1818;
    overflow: hidden;
    display: inline-block;
}
div#footer ul#vcard {
    list-style-type: none;
    height: 99px;
    float: left;
    margin: 0;
}
div#footer ul#vcard li {
    color: #777777;
    font-size: 0.6875em; /* 11px / 16px */
    margin-bottom: 0;
    line-height: 1.4em;
}
div#footer ul#vcard li.org { display: none; }
div#footer ul#vcard a { color: #eeeeee; }
div#footer ul#menu-footer {
    list-style-type: none;
    display: block;
    margin: 0;
    float: left;
    background: #FFF;
    padding: 15px 30px 30px 20px;
}
div#footer ul#menu-footer li {
    line-height: 18px;
    margin-bottom: 2px;
}
div#footer ul#menu-footer li a {
    color: #888888;
    font-size: 0.75em; /* 12px / 16px */
    border-bottom: 0;
}
div#footer ul#menu-footer li a:hover { color: #c00b13; }
div#footer p#copyright {
    /* see responsive.css */
}

/* ================================ Content ================================ */

.more {
    font-size: 0.6875em; /* 11px / 16px */
    clear: both;
}
.entry {
    line-height: 1.6em;
}
.entry ul,
.entry ol {
    margin-left: 2.0em;
    line-height: 1.6em;
    font-size: 0.875em; /* 14px / 16px */
}
.entry p {
    line-height: 1.em;
}
.entry p.callout {
    font-size: 1.0625em; /* 17px / 16px */
    line-height: 1.5em;
}
img.alignright {
    float: right;
    margin: 0 0 1em 1em;
}
img.alignleft {
    float: left;
    margin: 0 1em 1em 0;
}
img.aligncenter {
    display: block;
    margin-left: auto;
    margin-right: auto;
}
a img.alignright {
    float: right;
    margin: 0 0 1em 1em;
}
a img.alignleft {
    float: left;
    margin: 0 1em 1em 0;
}
a img.aligncenter {
    display: block;
    margin-left: auto;
    margin-right: auto;
}
.blognav {
    height: 42px;
    display: block;
    clear: both;
    overflow: hidden;
    padding: 20px 0 0 0;
}
.blognav a {
    height: 42px;
    line-height: 42px;
    width: 150px;
    text-align: center;
    display: block;
    font-size: 0.9375em; /* 15px / 16px */
    color: #777777;
    background: #fff;
    border: 0;
}
.blognav a:hover {
    color: #EEEEEE;
    background: #c00b13;
    border: 0;
}
.blognav .alignright {
    float: right;
    width: 150px;
}
.blognav .alignleft {
    float: left;
    width: 150px;
}
.loading-more {
    height: 42px;
    line-height: 42px;
    width: 150px;
    text-align: center;
    display: block;
    font-size: 0.9375em; /* 15px / 16px */
    color: #777777;
    background: #fff;
    border: 0;
    float: right;
    clear: both;
    cursor: pointer;
}
.loading-more:hover {
    color: #EEEEEE;
    background: #c00b13;
    border: 0;
}


/* ================================ Page ================================ */

body.page div#copy ul,
body.page div#copy ol { margin-left: 2.0em; }

/* ================================ Search ================================ */

body.search div#content div#copy {
    margin: auto;
    width: 90%;
    position: relative;
    padding-top: 25px;
}
body.search div#copy h1 { margin: 0 0 20px 0; }
body.search div#copy h2 {
    margin-bottom: 10px;
    font-size: 1.0em; /* 16px / 16px */
}
body.search div.hentry { margin-bottom: 35px; }
body.search div.hentry strong { color: #1b1818; }
div#copy ul.paging {
    font-weight: bold;
    font-size: 1.0em; /* 16px / 16px */
    height: 30px;
    margin-left: 0;
    list-style-type: none;
}
div#copy ul.paging li {
    float: left;
    margin: 0 6px 6px 0;
    padding: 0;
    background: none;
    width: 15px;
    text-align: center;
    font-weight: normal;
    font-style: normal;
    line-height: normal;
    font-family: 'Museo700', Georgia, serif;
    font-size: 0.875em; /* 14px / 16px */
}
div#copy ul.paging li a,
div#copy ul.paging li.active {
    display: block;
    width: 15px;
    text-align: center;
    color: #A3A3A3;
}
div#copy ul.paging li.active,
div#copy ul.paging li.active a {
    background-color: #fff;
    border-color: #fff;
    color: #009BBB;
}

/* ================================ Lists ================================ */

div.listed {
    overflow: hidden;
    z-index: 10;
    position: relative;
    clear: both;
    float: right;
}
div.listed.alt {
    float: left;
}
div.listed a.block {
    display: block;
    background: #1B1818;
    border: 0;
    overflow: hidden;
}

div.listed a div.featured-image img:first-child {
    position: absolute;
    left: 0;
    top: 0;
    z-index: 100;
}
div.listed a div.featured-image img:last-child {
    z-index: 10;
}
div.listed a:hover img { /*display: none*/; }

div.listed a h2 {
    color: #EEE;
    font-size: 1.0em; /* 16px / 16px */
    line-height: 1.3em;
    font-family: Arial, Helvetica, sans-serif;
}
div.listed a:hover h2 { color: #c00b13; }
div.listed a h5 {
    margin: 0 0 2px 0;
    color: #777;
    line-height: 1.3em;
}
div.listed a h3 {
    font-size: 0.8125em; /* 13px / 16px */
    color: #777;
    text-transform: lowercase;
    line-height: 1.3em;
}
div.listed a p {
    font-size: 0.8125em !important; /* 13px / 16px */
    color: #777;
}
div.alt a.block {
    background-position: top left;
}
body.page-template-page-client-php div.listed a h3,
body.page-template-page-specialty-php div.listed a h3 { text-transform: none; }

/* ================================ Home ================================ */

body.home div#header,
body.contact div#header {
    /* see responsive.css */
}
body.home div#header div.tools { right: 0; }
div#postcards {
    width: 100%;
    height: 100%;
    display: block;
    margin: 0 auto 0 auto;
    position: relative;
}
div#postcards div#cycle {
    width: 100% !important;
    height: 100% !important;
    position: relative !important;
}
div#postcards #next {
    background: url(images/next.png) no-repeat center center;
    height: 305px;
    width: 28px;
    display: block;
    position: absolute;
    right: 90px;
    z-index: 1000;
    cursor: pointer;
}
div#postcards #prev {
    background: url(images/prev.png) no-repeat center center;
    height: 305px;
    width: 28px;
    display: block;
    position: absolute;
    left: 90px;
    z-index: 1000;
    cursor: pointer;
}

div#postcards #next:hover { background: url(images/next_on.png) no-repeat center center; }
div#postcards #prev:hover { background: url(images/prev_on.png) no-repeat center center; }
div.postcard {
    height: auto !important;
    width: 100% !important;
}
div.postcard a {
    display: block;
    position: relative;
    cursor: pointer;
    border: 0;
    z-index: 1000;
}
div.postcard a:hover { border: 0; }
div.postcard h2 {
    text-indent: -10000px;
    position: absolute;
}
div.postcard div.entry {
    font-size: 0.9375em; /* 15px / 16px */
    width: 320px;
    margin: 270px 0 0 145px;
    text-align: left;
    line-height: 1.5em;
}
div.postcard .more {
    text-transform: uppercase;
    margin-top: 10px;
}
div.postcard .more strong {
    font-size: 0.875em; /* 14px / 16px */
    font-weight: normal;
}

div#postcards span#spacer {
    display: block;
    width: 100%;
}


div#intro {
    width: 100%;
    position: relative;
    background: #1b1818;
    overflow: hidden;
}
div#intro h1 {
    width: 50%;
    color: #777777;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
    font-size: 1.25em; /* 20px / 16px */
}
div#intro h1 strong {
    font-size: 1.15em;
    color: #c00b13;
    font-weight: normal;
}
ul#nav-about {
    height: 176px;
    list-style-type: none;
    overflow: hidden;
    margin: 0;
}
div#nav-about-wrapper {
    background: #C00B13;
}
ul#nav-about {

}
ul#nav-about li {
    width: 33.3339%;
    height: 176px;
    margin: 0;
    float: left;
}
ul#nav-about li a {
    display: block;
    padding-top: 120px;
    height: 56px;
    color: #fff;
    text-align: center;
    border: 0;
    font-size: 15px;
}
ul#nav-about li a:hover {
    border: 0;
    color: #c00b13;
}
ul#nav-about li#nav-process a { background: #c00b13 url(images/bg-about-nav-process.png) center -140px no-repeat; }
ul#nav-about li#nav-notes a { background: #c00b13 url(images/bg-about-nav-blog.png) no-repeat center -140px; }
ul#nav-about li#nav-blog a { background: #c00b13 url(images/bg-about-nav-lab-notes.png) no-repeat center -140px; }

ul#nav-about li#nav-process a:hover { background: #fff url(images/bg-about-nav-process.png) no-repeat center 40px; }
ul#nav-about li#nav-notes a:hover { background: #fff url(images/bg-about-nav-blog.png) no-repeat center 40px; }
ul#nav-about li#nav-blog a:hover { background: #fff url(images/bg-about-nav-lab-notes.png) no-repeat center 40px; }

body.home div.listed a h2 {
    padding-bottom: 0;
    margin-bottom: 10px;
}

/* ================================ Single Project ================================ */

body.single-work div#content div#copy {
    width: 73.34711%; /* 710px */
    float: left;
}
body.single-work div#content div#copy div.hentry {
    margin: 0 0 0 4%; /* 0 0 0 28px */
}
body.single-work div#content div#copy h5 { margin-bottom: 4px; }
body.single-work div#content div#copy h3 {
    font-size: 0.875em; /* 14px / 16px */
    margin-bottom: 35px;
}
body.single-work div#content div#copy h1 { margin-bottom: 25px; }
body.single-work div#content div#copy div.entry img {
    display: block;
    background: #777;
    padding: 1px;
    border: 5px solid #c2c2c2;
    margin-bottom: 35px;
}
body.single-work div#content div#copy div.entry img.attachment-project { margin-bottom: 25px; }

div#related-work {
    float: right;
}
div#related-work h3 {
    margin: 0 0 15px 0;
}
ol#related {
    list-style-type: none;
    overflow: hidden;
}
ol#related li {
    display: block;
    position: relative;
    margin-bottom: 20px;
}
ol#related li a.block {
    display: block;
    position: relative;
    background-color: #fff;
    background-position: top right;
    background-repeat: no-repeat;
    border: 0;
    padding-bottom: 15px;
}
ol#related li a img {
    display: block;
}
ol#related li a h2 {
    color: #777777;
    font-size: 1.0em; /* 16px / 16px */
    line-height: 1.3em;
    padding: 20px 20px 5px 20px;
    margin: 0;
    font-family: Arial, Helvetica, sans-serif;
}
ol#related li a:hover h2 { color: #c00b13; }
ol#related li a h5 {
    margin-left: 20px;
    margin-bottom: 2px;
    padding: 0;
    margin-top: 0;
    color: #777;
    line-height: 1.2em;
}
ol#related li a h3 {
    margin-left: 20px;
    margin-right: 10px;
    font-size: 0.8125em; /* 13px / 16px */
    color: #777;
    text-transform: lowercase;
}

/* ================================ About: Process ================================ */

body.page div#copy ol#process {
    list-style-type: none;
    margin: 20px 0 0 0;
}
ol#process {
    overflow: hidden;
}
ol#process li {
    display: block;
    text-align: left;
    margin-bottom: 0;
    clear: both;
}
ol#process li.alt {
    padding-left: 0;
    float: left;
}
ol#process li h2 {
    display: block;
    /* see responsive.css */
    float: left;
    height: 200px;
    background: transparent url('images/bg-process-bubbles.png') left top no-repeat;
    color: #FFF;
    font-size: 1.45em; /* 21px / 14px */
    text-align: center;
    text-align: center;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    -o-background-size: cover;
    background-size: cover;
}
ol#process li h2.design,
ol#process li h2.development,
ol#process li h2.implementation {
    background: transparent url('images/bg-process-bubbles-red.png') left top no-repeat;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    -o-background-size: cover;
    background-size: cover;
}

ol#process li p {
    width: 62.07455%; /* 383px out of 617px */
    float: right;
    margin: 40px 0 0 0;
    padding: 0 0 0 70px;
    background: transparent url('images/bg-process-bracket-right.jpg') 20px center no-repeat;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
    min-height: 105px;
}
ol#process li.alt h2 {
    /* see responsive.css */
}

ol#process li.alt p {
    /* see responsive.css */
}


/* ================================ About: Team ================================ */


body.team div#content div#copy {
    margin: 0;
    position: relative;
}
body.team div#content h1 {
    background: #1b1818;
    color: #777777;
    float: left;
    font-size: 1.25em; /* 20px / 16px */
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
}
body.team div#content h1 strong {
    font-size: 1.15em; /* 23px / 20px */
    color: #c00b13;
    font-weight: normal;
}
body.team div#content div.listed a {
    background-color: #1b1818;
}

body.team div#content div.listed div.entry {
    padding: 20px 0 20px 20px;
}
body.team div#content div.listed h2 {
    display: block;
    color: #EEEEEE;
    font-size: 1.0em; /* 16px / 16px */
    padding: 0;
    margin-bottom: 5px;
    font-family: Arial, Helvetica, sans-serif;
}
body.team div#content div.listed h5 {
    display: block;
    padding: 0;
    margin: 0;
    color: #c00b13;
}


/* ================================ About: Team Single ================================ */

body.single-team div#content div#copy {
    margin: 0;
    position: relative;
}
body.single-team div.info {
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
    padding: 20px 0 30px 20px;
    background: #1B1818;
    position: relative;
}
body.single-team div.info h1 {
    display: block;
    color: #EEEEEE;
    font-size: 1.0em; /* 16px / 16px */
    padding: 0;
    margin-bottom: 5px;
    font-family: Arial, Helvetica, sans-serif;
}
body.single-team div.info h5 {
    display: block;
    padding: 0;
    margin: 0 0 25px 0;
    color: #c00b13;
}
body.single-team div.info ul {
    list-style-type: none;
    color: #949393;
    margin: 0;
}
body.single-team div.info ul li {
    font-size: 0.75em; /* 16px / 16px */
    margin: 0 0 6px 0;
    line-height: 1em;
}
body.single-team div.info ul li a {
    color: #949393;
    border: none;
}
body.single-team div.info ul li a:hover {
    color: #c00b13;
}

body.single-team div.info h6 {
    position: absolute;
    bottom: -33px;
    right: 0;
    background: #C00B13;
    color: #EEEEEE;
    height: 33px;
    line-height: 33px;
    text-transform: uppercase;
    font-size: 10px;
    margin: 0;
}
body.single-team div.info h6 a {
    display: block;
    height: 33px;
    line-height: 33px;
    color: #EEEEEE;
    text-align: center;
    border: 0;
    width: 100%;
}
body.single-team div.info h6 a:hover { border: 0; }

body.single-team div.persisted {
    position: absolute;

    height: 188px;
    top: 0;
    right: 0;
}
body.single-team div.persisted.floating {
    /* see responsive.css */

}

body.single-team div.entry { /* see responsive.css */ }
body.single-team div.entry p { margin: 0 25px 15px 25px; }
body.single-team div.entry p.more {
    font-size: 0.8125em; /* 13px / 16px */
    margin-top: 30px;
}
img.attachment-bio {
    display: block;
    margin-bottom: 25px;
    background: none !important;
    border: 0 !important;
    padding: 0 !important;
}

/* ============= Team Gallery ============== */

div#team-gallery {
    margin: 50px 0 0 0;
    width: 100% !important;
    height: 100% !important;
    position: relative;
}
div#team-gallery h3 {
    background: #1b1818;
    display: inline-block;
    height: 42px;
    line-height: 41px;
    color: #FFF;
    padding: 0 50px 0 16px;
    font-size: 1.0em; /* 16px / 16px */
    margin: 0;
}
div#team-gallery ul {
    list-style-type: none;
    margin: 0;
    background: #1b1818;
    width: 100% !important;
    height: 100% !important;
}
div#team-gallery span#spacer {
    display: block;
    width: 100%;
}
div#team-gallery span#spacer img {
    border: 0;
    padding: 0;
}
div#team-gallery ul li {
    position: relative;
    width: 100% !important;
    height: auto !important;
    overflow: hidden;
    margin: 0;
    text-align: center;
}
div#team-gallery ul li div.excerpt {
    display: none;
    background: transparent url('images/bg-team-gallery.png') left top repeat;
    position: absolute;
    width: 100%;
    height: 100%;
    padding: 20px;
    color: #FFF;
    text-align: left;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
}
div#team-gallery ul li div.excerpt h4 {
    font-size: 24px;
    margin: 0 0 15px 0;
    font-weight: normal;
    text-transform: uppercase;
}
div#team-gallery ul li div.excerpt p {
    font-size: 0.9375em; /* 15px / 16px */
    margin: 0 0 7px 0;
}
div#team-gallery ul li img {
    background: none;
    border: none;
    padding: 0;
}
div#team-gallery span#next,
div#team-gallery span#prev {
    display: inline-block;
    background: #FFF;
    height: 42px;
    line-height: 42px;
    padding: 0 40px 0 30px;
    cursor: pointer;
    font-size: 0.9375em; /* 15px / 16px */
}
div#team-gallery span#next {
    float: right;
}
div#team-gallery span#next:hover,
div#team-gallery span#prev:hover {
    background: #1b1818;
    color: #FFF;
}
div#team-gallery span#next strong {
    margin: 0 0 0 5px;
}
div#team-gallery span#prev strong {
    margin: 0 5px 0;
}

/* ================================ Labs ================================ */

body.single-post div#content div#copy,
body.blog div#content div#copy,
body.category div#content div#copy,
body.tag div#content div#copy,
body.author div#content div#copy,
body.date div#content div#copy { margin: 0 0 0 0; }
body.single-post div.post,
body.blog div.post,
body.category div.post,
body.tag div.post,
body.author div.post,
body.date div.post {
    position: relative;
    /* see responsive.css */
    background: #fff;
}
body.single-post div.post h1,
body.blog div.post h1,
body.category div.post h1,
body.tag div.post h1,
body.author div.post h1,
body.date div.post h1 { padding-bottom: 25px; }
div.post h1 a { border: 0; }
div.post h1 a:hover { color: #c00b13; }
div.entry img {
    background: #777;
    padding: 1px;
    border: 5px solid #c2c2c2;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
}
div.wp-caption {
    background: #c2c2c2;
    padding: 0 2px 0 0;
    margin-bottom: 20px;
    height: auto !important;
    width: auto !important;
    text-align: center;
}

div.wp-caption.alignleft {
    margin: 0 10px 10px 0;
    float: left;
}
div.wp-caption.alignright {
    margin: 0 0 10px 10px;
    float: right;
}

p.wp-caption-text {
    color: #464646;
    font-size: 12px;
    padding: 2px 10px 5px 10px;
    margin-bottom: 5px;
}
div.post ul.postmetadata {
    list-style-type: none;
    overflow: hidden;
}
div.post ul.postmetadata li {
    background: none;
    padding-left: 0;
    float: left;
    width: 130px;
}
div.post ul.postmetadata li h5 {
    margin: 0;
    line-height: 12px;
    color: #777;
}
div.post ul.postmetadata li.comment { width: 130px; }
div.post ul.postmetadata li.category { width: 300px; }
div.date {
    text-transform: uppercase;
    background: #C00B13;
    position: absolute;
    top: 0;
    left: 8px;
    height: 46px;
    width: 30px;
    color: #fff;
    text-align: center;
    font-size: 11px;
    padding: 5px;
    line-height: 16px;
}
div.date strong {
    font-size: 20px;
    line-height: 15px;
    display: block;
    font-weight: normal;
}
div.tags {
    background: #bbb;
    padding: 14px 6%;
    margin: 0;
    color: #777;
    line-height: 13px;
}
div.tags h5 {
    padding: 0;
    margin: 0;
}
div.tags p {
    font-size: 0.875em; /* 14px / 16px */
    margin: 0;
}
body.blog div.tags,
body.category div.tags,
body.tag div.tags,
body.author div.tags,
body.date div.tags { margin-bottom: 40px; }
div#comments { margin-top: 45px; }
div#comments h3 {
    color: #EEEEEE;
    font-size: 1.0em; /* 16px / 16px */
    background: #1B1818;
    padding: 12px 25px;
}
ol.commentlist {
    list-style-type: none;
    margin: 20px 25px 0 25px;
}
ol.commentlist li { margin-bottom: 20px; }
ol.commentlist li div {
    padding: 20px 93px 5px 20px;
    background: #fff;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
    margin: 0;
}
ol.commentlist li div p {
    line-height: 1.4em;
    color: #777;
}
ol.commentlist li cite {
    display: block;
    font-style: normal;
    font-size: 12px;
    margin-bottom: 15px;
    color: #555;
    background: #EEE url(images/bg-cite.png) no-repeat 46px 0;
    padding-left: 85px;
    min-height: 27px;
    padding-top: 5px;
}
ol.commentlist li.byuser div.quote { background: #434141 url(images/rd2er-v2.png) no-repeat right top; }
ol.commentlist li.byuser div {
    background: #434141;
    color: #eee;
}
ol.commentlist li.byuser div p { color: #eee; }
ol.commentlist li.byuser div p a {
    color: #ccc;
    border-color: #ccc;
}
ol.commentlist li.byuser cite { background-image: url(images/bg-cite-rd2.png); }
div#respond {
    background: #fff;
    margin-top: 45px;
    margin-bottom: 45px;
    position: relative;
}
div#respond h3 {
    color: #EEEEEE;
    font-size: 1.0em; /* 16px / 16px */
    background: #1B1818;
    height: 48px;
    line-height: 48px;
    padding: 0 25px 0 25px;
}
form#commentform {
    width: 90%;
    margin: 25px auto;
    padding: 0 0 60px 0;
}
form#commentform p {
    clear: both;
    overflow: hidden;
}
form#commentform label {
    display: block;
    margin-bottom: 0.3em;
    color: #777777;
    text-align: left;
    /* see responsive.css */
    font-size: 12px;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
}
form#commentform label em {
    font-style: normal;
    font-size: 10px;
}
form#commentform label strong { color: #c00b13; }
form#commentform input.text {
    display: block;
    margin-bottom: 15px;
    background: #fff;
    border: 1px solid #888;
    padding: 3px;
    float: left;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
}
form#commentform textarea.textarea {
    background: #fff;
    border: 1px solid #888;
    margin-bottom: 15px;
    resize: vertical;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
}
form#commentform input.submit {
    display: block;
    margin: 0;
    background: #C00B13;
    color: #eeeeee;
    font-size: 1.0em; /* 16px / 16px */
    border: 0;
    padding: 0;
    width: 135px;
    height: 44px;
    line-height: 44px;
    position: absolute;
    top: 0;
    right: 0;
    cursor: pointer;
    -webkit-appearance: none;
    -webkit-border-radius: 0;
    -moz-border-radius: 0;
    border-radius: 0;
}
form#commentform input.submit:hover { background: #9d1219; }
div.actions {
    background: #777777;
    position: absolute;
    right: 0;
    bottom: 0;
    width: 100%;
    height: 44px;
}
img.attachment-labs {
    display: block;
    margin-bottom: 25px;
    background: #777;
    padding: 1px;
    border: 5px solid #c2c2c2;
}

/* ================================ Contact ================================ */

body.page-template-page-contact-php div#content div#copy {
    width: 100%;
    margin: 0;
    position: relative;
    padding: 0 !important;
}
body.page-template-page-contact-php div#postcards {
/*    background: url(images/bg-contact.jpg) no-repeat;*/
    height: auto;
}
body.page-template-page-contact-php div.entry img {
    background: none;
    border: 0;
    padding: 0;
}

body.page-template-page-contact-php div#header div.tools { right: -702px; }
body.page-template-page-contact-php span#faker-left {
    background: url(images/bg-header.gif) no-repeat;
    height: 134px;
    width: 360px;
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 100;
}
body.page-template-page-contact-php span#faker-right {
    background: url(images/bg-header.gif) no-repeat top right;
    height: 40px;
    width: 310px;
    display: block;
    position: absolute;
    top: 0;
    right: 0;
    z-index: 100;
}
body.contact div.info {
    /* see responsive.css */
}
body.contact div.info h1 {
    display: block;
    color: #777777;
    /* see responsive.css */
}
body.page-template-page-contact-php div.info h1 strong {
    font-size: 30px;
    color: #c00b13;
    font-weight: normal;
}
body.page-template-page-contact-php div.entry p { margin: 0 25px 15px 25px; }
body.page-template-page-contact-php div.entry p.more {
    font-size: 0.8125em; /* 13px / 16px */
    margin-top: 30px;
}
a.map {
    border: 0;
    margin-bottom: 25px;
    display: block;
}
a.map:hover { border: 0; }
ol.contacts {
    list-style-type: none;
    overflow: hidden;
    border-bottom: 1px solid #b8b8b8;
    padding: 0 0 20px 0;
    margin-bottom: 30px;
}
ol.contacts li {
    float: left;
    width: 220px;
}
ol.contacts li h3 {
    font-size: 1.0em; /* 16px / 16px */
    color: #555555;
    margin: 0 0 3px 0;
}
ol.contacts li p {
    font-size: 0.875em; /* 14px / 16px */
    line-height: 1.3em;
    margin-bottom: 10px;
}

/* ================================ Careers ================================ */

body.careers div#copy,
body.single-career div#copy {
    width: 90%;
}

body.careers div#header div.tools,
body.single-career div#header div.tools {
    right: -702px
}

body.careers span#faker-left,
body.single-career span#faker-left {
    background: url(images/bg-header.gif) no-repeat;
    height: 134px;
    width: 360px;
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 100;
}

body.careers span#faker-right,
body.single-career span#faker-right {
    background: url(images/bg-header.gif) no-repeat top right;
    height: 40px;
    width: 310px;
    display: block;
    position: absolute;
    top: 0;
    right: 0;
    z-index: 100;
}
body.careers div#content h1,
body.single-career div#content h1 {
    margin: 20px 0 12px;
}
body.careers div.career {
    border-top: 1px solid #CCC;
    margin-top: 20px;
    padding-top: 20px;
}
body.careers div.career h2 a {
    color: #C00B13;
}

body.single-career h6.back-to {
    position: absolute;
    top: 0;
    right: 0;
    height: 33px;
    margin: 0;
    z-index: 1000;
}

body.single-career h6.back-to a {
    display: block;
    height: 33px;
    line-height: 33px;
    background: #C00B13;
    color: #EEEEEE;
    width: 176px;
    text-align: center;
    border: 0;
    text-transform: uppercase;
    font-size: 10px;
}

body.single-career h6.back-to a:hover {
    border: 0
}

body.single-career div#content div#copy {
    padding-top: 53px;
}

body.single-career div.career hr {
    background-color: #CCC;
    border-color: #CCC;
    margin-bottom: 24px;
}

body.single-career div.gform_wrapper.contact-us_wrapper {
    margin: 0;
}


/*
body.single-career div.gform_wrapper li#field_2_7 textarea {
    height: 224px;
}
body.single-career div.gform_wrapper div.gform_body {
    width: 667px;
    float: left;
    margin-left: 2em;
}
body.single-career div.gform_wrapper div.gform_footer {
    float: left;
}

*/

/* ================================ General Gravity Forms Styling ================================ */

div.gform_wrapper {
    position: relative;
}
div.gform_wrapper div.gform_heading {
    font-size: 1.0em; /* 16px / 16px */
    color: #555;
    margin: 0 0 20px 0;
}
div#gforms_confirmation_message {
    font-size: 1.0em; /* 16px / 16px */
    color: #555;
    margin: 0 0 0 25px;
}
div.gform_wrapper div.gform_body ul {
    list-style-type: none;
    margin: 0;
}
div.gform_wrapper div.gform_body {
    position: relative;
}
div.gform_wrapper div.gform_body li {
    margin: 0 0 12px 0;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
}
div.gform_wrapper div.gform_body label {
    font-size: 0.875em; /* 14px / 16px */
    margin: 0 0 4px 0;
    display: inline-block;
}
div.gform_wrapper div.ginput_complex label {
    display: block;
    margin: 3px 0;
    font-size: 11px;
    letter-spacing: 0.5pt
}
div.gform_wrapper div.ginput_complex span.ginput_left {
    width: 275px;
    margin-right: 36px;
    float: left;
}
div.gform_wrapper div.ginput_complex span.ginput_right {
    width: 275px;
    float: left;
}
div.gform_wrapper div.gform_body input {
    border: 0;
    background: #FFF;
    padding: 5px;
    font-size: 0.875em; /* 14px / 16px */
    width: 265px;
    color: #555;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
}
div.gform_wrapper div.gform_body select {
    border: 0;
    color: #555;
    width: 274px;
    padding: 5px;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
}
div.gform_wrapper div.gform_body textarea {
    border: 0;
    padding: 5px;
    color: #555;
    resize: vertical;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
}
div.gform_wrapper div.gform_footer {
    position: relative;
}
div.gform_wrapper div.gform_footer input[type="submit"] {
    background: #c00b13;
    color: #FFF;
    width: 118px;
    height: 44px;
    border: 0;
    font-size: 1.0em; /* 16px / 16px */
    cursor: pointer;
    -webkit-appearance: none;
    -webkit-border-radius: 0;
    -moz-border-radius: 0;
    border-radius: 0;
}
div.gform_wrapper div.gform_footer input[type="submit"]:hover {
   background: #9d1219;
}

div.gform_wrapper li.gform_validation_container {
    display: none;
}

div.gform_wrapper div.validation_message {
    background: #CECECE;
    color: #555;
    padding: 2px 7px 2px 7px;
}

div.gform_wrapper div.validation_error {
    color: #c00b13;
    margin: 0 0 15px 0;
    font-size: 17px;
}

/* ================================ Contact Us > Gravity Forms Styling ================================ */

div.gform_wrapper.contact-us_wrapper {
    margin: 0 0 0 2em;
}
div.gform_wrapper.contact-us_wrapper div.gform_body {
    width: 654px;
    float: left;
}
body.page div#copy div.gform_wrapper.contact-us_wrapper div.gform_body ul {
    margin-left: 0;
}
div.gform_wrapper.contact-us_wrapper div.gform_body li {
}
div.gform_wrapper.contact-us_wrapper div.gform_body li.message {
    /* see responsive.css */
}
div.gform_wrapper.contact-us_wrapper div.gform_body textarea {
    width: 270px;
    min-height: 205px;
}
div.gform_wrapper.contact-us_wrapper div.gform_footer {
    float: left;
    width: 200px;
    padding: 15px 0 0 0;
}
div.gform_wrapper.contact-us_wrapper div.gform_footer input[type="submit"] {
    /* see responsive.css */
}

/* ================================ Error ================================ */

body.error404 div#content div#copy {
    padding: 10px 20% 300px 20%;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
    font-size: 1.0em; /* 16px / 16px */
    width: 100%;
    margin: 95px auto 0 auto;
}
body.error404 div#content div#copy p:first-child {
    text-align: center;
    margin: 0 0 30px 0;
}

/* = :after Clear Fix ======================================================= */
/* Add these to any parent container that has floating child elements         */

div.gform_wrapper:after,
div.gform_wrapper li.gfield:after,
div#page:after,
div#content div#copy:after,
body.single-team div.info:after {
    content: ".";
    display: block;
    height: 0;
    clear: both;
    visibility: hidden;
}