/* ----------------------------------------------------
Backgrounds
---------------------------------------------------- */
.bg-dark-green {
  background-color: #00643c;
}
.bg-light-green {
  background-color: #699d27;
  color: #ffffff;
}
.bg-light-green h2,
.bg-light-green h3,
.bg-light-green h4,
.bg-light-green .content-label {
  color: #ffffff;
}
.bg-light-green a {
  color: #ffffff;
}
.bg-light-green a .title,
.bg-light-green a .content-type {
  color: #ffffff !important;
}
.bg-bright-green {
  background-color: #a6dd5f;
}
.bg-gray {
  background-color: #696a6c;
}
.bg-light-gray {
  background-color: #929499;
}
.bg-soft-gray {
  background-color: #f4f4f5;
}
.bg-dark-blue {
  background-color: #286077;
}
.bg-orange {
  background-color: #de641f;
}
.bg-light-blue {
  background-color: #0e94e1;
}
.bg-light-orange {
  background-color: #f9a255;
}
.bg-brown {
  background-color: #715c2a;
}
.bg-tan {
  background-color: #ccab76;
}
.bg-link-blue {
  background-color: #0074b8;
}
.bg-alert-red {
  background-color: #e53e30;
}
.bg-alert-yellow {
  background-color: #ffa800;
}
.bg-alert-green {
  background-color: #a6dd5f;
}
/* ----------------------------------------------------
Buttons
---------------------------------------------------- */
.btn {
  border-radius: 2px;
  font-weight: 700;
}
.btn-primary {
  background-color: #0074b8;
  border-color: #0074b8;
  color: #ffffff;
}
.btn-default {
  background-color: #ffffff;
  border-color: #0074b8;
  color: #0074b8;
}
.btn-white-outline {
  background-color: transparent;
  border-color: #ffffff;
  color: #ffffff;
}
.btn-lg {
  padding: 18px;
}
.btn-sm {
  padding: 9px;
}
.btn-xs {
  padding: 4px 9px;
}
/* ----------------------------------------------------
Type
---------------------------------------------------- */
html {
  font-size: 62.5%;
}
body {
  font-size: 1.6rem;
  line-height: 1.7;
  font-family: 'Montserrat', sans-serif;
  line-height: 1.6;
  font-weight: 500;
}
@media (min-width: 992px) {
  body {
    font-size: 1.8rem;
  }
}
/* ----------------------------------------------------
Typeface classes
---------------------------------------------------- */
.primary-font {
  font-family: 'Montserrat', sans-serif;
}
.secondary-font {
  font-family: Georgia, Times, "Times New Roman", serif;
}
/* ----------------------------------------------------
Headers
Header scales from http://type-scale.com/
---------------------------------------------------- */
h1,
.h1,
h2,
.h2,
h3,
.h3,
h4,
.h4 {
  color: #00643c;
  font-weight: 700;
  line-height: 1.3;
}
h1:display,
.h1:display,
h2:display,
.h2:display,
h3:display,
.h3:display,
h4:display,
.h4:display {
  text-transform: uppercase;
  font-weight: 200;
}
h1,
.h1 {
  margin-bottom: 36px;
}
h2,
.h2,
h3,
.h3,
h4,
.h4 {
  margin-bottom: 18px;
}
h1,
.h1,
.h1-size {
  font-size: 2.7rem;
}
@media (min-width: 768px) {
  h1,
  .h1,
  .h1-size {
    font-size: 4.3rem;
  }
}
@media (min-width: 992px) {
  h1,
  .h1,
  .h1-size {
    font-size: 5rem;
  }
}
h2,
.h2,
.h2-size {
  font-size: 2.3rem;
}
@media (min-width: 768px) {
  h2,
  .h2,
  .h2-size {
    font-size: 2.8rem;
  }
}
@media (min-width: 992px) {
  h2,
  .h2,
  .h2-size {
    font-size: 3.5rem;
  }
}
h3,
.h3,
.h3-size {
  font-size: 2rem;
}
@media (min-width: 768px) {
  h3,
  .h3,
  .h3-size {
    font-size: 2.2rem;
  }
}
@media (min-width: 992px) {
  h3,
  .h3,
  .h3-size {
    font-size: 2.5rem;
  }
}
h4,
.h4,
.h4-size {
  font-size: 1.8rem;
}
h4,
.h4 {
  text-transform: uppercase;
}
/* ----------------------------------------------------
Copy Sizes
---------------------------------------------------- */
.intro-copy {
  font-size: 2rem;
  font-family: Georgia, Times, "Times New Roman", serif;
  line-height: 1.7;
}
@media (min-width: 992px) {
  .intro-copy {
    font-size: 2.3rem;
  }
}
.extra-large-type {
  font-size: 2rem;
  line-height: 1.7;
}
@media (min-width: 992px) {
  .extra-large-type {
    font-size: 2.3rem;
  }
}
.large-type {
  font-size: 1.8rem;
  line-height: 1.7;
}
@media (min-width: 992px) {
  .large-type {
    font-size: 2rem;
  }
}
.default-type {
  font-size: 1.6rem;
  line-height: 1.7;
}
@media (min-width: 992px) {
  .default-type {
    font-size: 1.8rem;
  }
}
.small-type {
  font-size: 1.4rem;
  line-height: 1.7;
}
@media (min-width: 992px) {
  .small-type {
    font-size: 1.6rem;
  }
}
.extra-small-type {
  font-size: 1.4rem;
}
/* ----------------------------------------------------
Custom type classes
---------------------------------------------------- */
.meta {
  font-size: 1.4rem;
  font-family: Georgia, Times, "Times New Roman", serif;
  font-style: italic;
}
.meta a {
  display: inline-block !important;
}
.content-label {
  font-size: 1.2rem;
  color: #00643c;
  text-transform: uppercase;
  letter-spacing: 1px;
  font-weight: 700;
  margin-bottom: 9px;
}
.content-type {
  font-size: 1.4rem;
  color: #696a6c;
  font-family: Georgia, Times, "Times New Roman", serif;
  font-style: italic;
  font-weight: 500;
}
.dash-top {
  margin-top: 18px;
  padding-top: 18px;
  position: relative;
}
.dash-top:before {
  content: "";
  height: 3px;
  line-height: 3px;
  position: absolute;
  top: 0;
  left: 50%;
  margin-left: -9px;
  width: 18px;
  background-color: #a6dd5f;
}
.dash-bottom {
  margin-bottom: 18px;
  padding-bottom: 18px;
  position: relative;
}
.dash-bottom:before {
  content: " ";
  height: 3px;
  position: absolute;
  bottom: 0;
  left: 50%;
  margin-left: -9px;
  width: 18px;
  background-color: #a6dd5f;
}
/* --------------------------------------------------
Multiple columns
-------------------------------------------------- */
@media (min-width: 768px) {
  .multi-column-2 {
    -webkit-column-width: 50%;
    column-width: 50%;
    -webkit-column-count: 2;
    column-count: 2;
    -webkit-column-gap: 36px;
    column-gap: 36px;
  }
}
@media (min-width: 768px) {
  .multi-column-3 {
    -webkit-column-width: 50%;
    column-width: 50%;
    -webkit-column-count: 2;
    column-count: 2;
    -webkit-column-gap: 36px;
    column-gap: 36px;
  }
}
@media (min-width: 992px) {
  .multi-column-3 {
    -webkit-column-width: 33%;
    column-width: 33%;
    -webkit-column-count: 3;
    column-count: 3;
    -webkit-column-gap: 36px;
    column-gap: 36px;
  }
}
/* --------------------------------------------------
Link Lists
-------------------------------------------------- */
.link-list ul,
.link-list dl {
  list-style: none;
  padding: 0;
  margin: 0 0 36px;
}
.link-list li,
.link-list dd {
  margin-bottom: 9px;
  line-height: 1.4;
}
.link-list dt {
  position: relative;
}
.link-list dt:before {
  left: 0;
  margin-left: 0;
}
.link-list h2,
.link-list h3,
.link-list h4 {
  border-bottom: 1px solid #ebebeb;
  padding-bottom: 9px;
  margin-bottom: 36px;
}
.link-list h2 span,
.link-list h3 span,
.link-list h4 span {
  font-weight: 200;
}
.link-list.block {
  background-color: #f4f4f5;
  padding: 18px;
  margin-bottom: 36px;
}
.link-list.block h2,
.link-list.block h3,
.link-list.block h4 {
  border-bottom-color: #dedede;
}
@media (min-width: 768px) {
  .link-list.block {
    padding: 36px;
  }
}
.link-list.collapsable ul,
.link-list.collapsable dl {
  display: none;
}
@media (min-width: 992px) {
  .link-list.collapsable ul,
  .link-list.collapsable dl {
    display: block;
  }
}
@media (max-width: 768px) {
  .link-list.collapsable .content-label {
    border-top: 1px solid #ebebeb;
  }
}
/* --------------------------------------------------
Accordion
-------------------------------------------------- */
[data-toggle="collapse"],
[class|="collapsable-header"] {
  position: relative;
  padding-left: 36px;
  display: block;
  text-decoration: none;
}
[data-toggle="collapse"]:hover,
[class|="collapsable-header"]:hover,
[data-toggle="collapse"]:active,
[class|="collapsable-header"]:active,
[data-toggle="collapse"]:visited,
[class|="collapsable-header"]:visited {
  text-decoration: none;
}
[data-toggle="collapse"][aria-expanded="true"] svg,
[class|="collapsable-header"][aria-expanded="true"] svg {
  -webkit-transform: rotate(90deg);
  -moz-transform: rotate(90deg);
  -ms-transform: rotate(90deg);
  -o-transform: rotate(90deg);
}
[data-toggle="collapse"][aria-expanded="true"] svg .bar-horizontal,
[class|="collapsable-header"][aria-expanded="true"] svg .bar-horizontal {
  visibility: hidden;
}
[data-toggle="collapse"] svg,
[class|="collapsable-header"] svg {
  position: absolute;
  left: 0;
  top: 50%;
  margin-top: -8px;
  height: 16px;
  width: 16px;
  fill: #0074b8;
  -webkit-transition: all 0.2s ease-out;
  transition: all 0.2s ease-out;
}
[data-toggle="collapse"] svg rect.bar-horizontal,
[class|="collapsable-header"] svg rect.bar-horizontal {
  visibility: inherit;
}
[class|="collapsable-header"] {
  padding-left: 20px;
}
[class|="collapsable-header"] svg {
  margin-top: -5px;
  height: 10px;
  width: 10px;
}
.accordion {
  padding-top: 18px;
  border-top: 1px solid #ebebeb;
  float: left;
  width: 100%;
}
.accordion:last-of-type {
  border-bottom: 1px solid #ebebeb;
  margin-bottom: 36px;
}
.accordion .accordion-title {
  text-transform: none;
  margin: 0 0 18px;
}
.accordion .accordion-title a {
  position: relative;
  padding-left: 36px;
  display: block;
  text-decoration: none;
}
.accordion .accordion-title a:hover,
.accordion .accordion-title a:active,
.accordion .accordion-title a:visited {
  text-decoration: none;
}
.accordion .accordion-title a[aria-expanded="true"] svg {
  -webkit-transform: rotate(90deg);
  -moz-transform: rotate(90deg);
  -ms-transform: rotate(90deg);
  -o-transform: rotate(90deg);
}
.accordion .accordion-title a[aria-expanded="true"] svg .bar-horizontal {
  visibility: hidden;
}
.accordion .accordion-title a svg {
  position: absolute;
  left: 0;
  top: 50%;
  margin-top: -8px;
  height: 16px;
  width: 16px;
  fill: #0e94e1;
  -webkit-transition: all 0.2s ease-out;
  transition: all 0.2s ease-out;
}
.accordion .accordion-title a svg rect.bar-horizontal {
  visibility: inherit;
}
.accordion .learn-more {
  text-align: center;
}
.accordion-wrapper {
  float: left;
  width: 100%;
}
.accordion-wrapper > .row {
  background-color: #f4f4f5;
  margin: 0;
  padding-top: 18px;
}
@media (min-width: 768px) {
  .accordion-wrapper > .row {
    padding: 36px;
  }
}
/* --------------------------------------------------
Nav callouts
-------------------------------------------------- */
.nav-callout {
  display: block;
  padding: 36px 0 0;
  border-top: 1px solid #ebebeb;
}
@media (min-width: 768px) {
  .nav-callout {
    padding: 36px 0;
  }
}
.nav-callout:first-of-type {
  border-top: none;
  padding-top: 0;
}
.nav-callout .callout-title {
  color: #0074b8;
  margin: 0 0 18px;
}
.nav-callout .photo {
  margin-bottom: 36px;
}
.nav-callout .photo img {
  max-width: 100%;
}
.nav-callout p {
  color: #000000;
}
.nav-callout:hover {
  text-decoration: none;
}
.nav-callout:hover h2 {
  color: #286077;
  text-decoration: underline;
}
/* --------------------------------------------------
Media cards
-------------------------------------------------- */
.mc {
  margin-bottom: 18px;
}
@media (min-width: 768px) {
  .mc {
    margin-bottom: 36px;
  }
}
.mc img {
  width: 100%;
  max-width: 100%;
  height: auto;
}
.mc .mc-wrapper {
  -webkit-align-content: flex-start;
          align-content: flex-start;
  -webkit-box-align: start;
  -webkit-align-items: flex-start;
          align-items: flex-start;
  -webkit-flex-wrap: wrap;
          flex-wrap: wrap;
  height: 100%;
  background-color: #f4f4f5;
  padding-bottom: 36px;
}
.mc .mc-title,
.mc .meta,
.mc .content-type {
  display: block;
  margin-bottom: 18px;
}
.mc .mc-title a,
.mc .meta a,
.mc .content-type a {
  overflow-wrap: break-word;
  word-wrap: break-word;
  -ms-word-break: break-all;
  /* This is the dangerous one in WebKit, as it breaks things wherever */
  word-break: break-all;
  /* Instead use this non-standard one: */
  word-break: break-word;
  /* Adds a hyphen where the word breaks, if supported (No Blink) */
  -ms-hyphens: auto;
  -webkit-hyphens: auto;
  hyphens: auto;
}
.mc .mc-title {
  font-weight: 700;
  color: #00643c;
  margin-top: 0;
}
.mc a:not(.btn) {
  display: block;
}
.mc a .mc-title {
  color: #0074b8;
}
.mc.mc-full-bleed .mc-wrapper {
  -webkit-align-content: center;
          align-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
          align-items: center;
  display: -webkit-box;
  display: -webkit-flex;
  display: flex;
  background-color: transparent;
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center center;
  color: #ffffff;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
          justify-content: center;
  padding: 36px;
  text-align: center;
  min-height: 250px;
}
@media (min-width: 768px) {
  .mc.mc-full-bleed .mc-wrapper {
    min-height: 400px;
  }
}
.mc.mc-full-bleed .mc-title {
  color: #ffffff;
  text-align: center;
  font-weight: 200;
  margin-top: 0;
}
.mc.mc-full-bleed p {
  color: #ffffff;
}
.mc.mc-full-bleed p:last-of-type {
  margin-bottom: 0;
}
.mc.mc-full-bleed .btn-secondary {
  background-color: transparent;
  border-color: #ffffff;
  color: #ffffff;
}
.mc.mc-full-bleed .btn-secondary:hover {
  background-color: #0074b8 !important;
  color: #ffffff !important;
  border-color: #0074b8 !important;
}
.mc.mc-full-bleed a {
  color: #ffffff;
}
.mc.mc-full-bleed a:hover {
  text-decoration: none;
}
.mc.mc-full-bleed a:hover svg {
  fill: #ffffff;
}
.mc.mc-full-bleed a:hover .btn {
  background-color: #0074b8;
  border-color: #0074b8;
  color: #ffffff;
}
.mc.mc-50-50 {
  background-color: #ffffff;
  margin-left: 0;
  margin-right: 0;
  width: 100%;
}
@media (min-width: 500px) {
  .mc.mc-50-50 {
    float: none;
    display: -webkit-box;
    display: -webkit-flex;
    display: flex;
  }
}
.mc.mc-50-50 .mc-photo {
  min-height: 250px;
  background-size: cover;
  width: 100%;
}
@media (min-width: 500px) {
  .mc.mc-50-50 .mc-photo {
    float: none;
    width: 50%;
  }
}
.mc.mc-50-50 .mc-title {
  font-size: 2rem;
}
@media (min-width: 768px) {
  .mc.mc-50-50 .mc-title {
    font-size: 2.2rem;
  }
}
@media (min-width: 992px) {
  .mc.mc-50-50 .mc-title {
    font-size: 2.5rem;
  }
}
.mc.mc-50-50 .mc-copy {
  vertical-align: middle;
  width: 100%;
  padding-bottom: 36px;
}
@media (min-width: 500px) {
  .mc.mc-50-50 .mc-copy {
    float: none;
    width: 50%;
    padding: 36px;
  }
}
@media (min-width: 992px) {
  .mc.mc-50-50 .mc-copy {
    padding: 72px 36px;
  }
}
.mc-copy {
  font-size: 1.6rem;
  display: block;
  padding: 36px 36px 0;
}
@media (min-width: 768px) {
  .mc-flexbox-stretch {
    float: none;
    display: -webkit-box;
    display: -webkit-flex;
    display: flex;
  }
  .mc-flexbox-stretch .mc-full-bleed {
    float: none;
    display: -webkit-box;
    display: -webkit-flex;
    display: flex;
  }
}
/* --------------------------------------------------
Pullquote
-------------------------------------------------- */
.pullquote {
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center center;
  padding-top: 36px;
  padding-bottom: 36px;
  position: relative;
  text-align: center;
}
.pullquote img {
  display: inline-block;
  text-align: center;
  margin: 0 auto 9px;
  width: 100px;
  height: 100px;
}
@media (min-width: 768px) {
  .pullquote img {
    width: 150px;
    height: 150px;
  }
}
.pullquote .quote-wrapper {
  font-size: 1.4rem;
  line-height: 1.7;
}
@media (min-width: 992px) {
  .pullquote .quote-wrapper {
    font-size: 1.6rem;
  }
}
.pullquote .quote-wrapper .row {
  width: 100%;
  margin: 0;
  padding: 0 36px;
}
.pullquote blockquote {
  border: none;
  padding: 0;
  margin: 0;
}
.pullquote .quote {
  color: #00643c;
  font-weight: 700;
  line-height: 1.3;
  font-size: 2rem;
  font-family: Georgia, Times, "Times New Roman", serif;
  font-style: italic;
  font-weight: 500;
  margin-bottom: 18px;
  position: relative;
}
.pullquote .quote:display {
  text-transform: uppercase;
  font-weight: 200;
}
@media (min-width: 768px) {
  .pullquote .quote {
    font-size: 2.2rem;
  }
}
@media (min-width: 992px) {
  .pullquote .quote {
    font-size: 2.5rem;
  }
}
.pullquote .credit {
  font-size: 1.4rem;
  margin-top: 18px;
  padding-top: 18px;
  font-family: 'Montserrat', sans-serif;
  font-style: normal;
  font-weight: 700;
  letter-spacing: 3px;
  text-transform: uppercase;
  position: relative;
}
.pullquote .credit:before {
  content: "";
  height: 3px;
  line-height: 3px;
  position: absolute;
  top: 0;
  left: 50%;
  margin-left: -9px;
  width: 18px;
  background-color: #a6dd5f;
}
.pullquote.hero {
  background: #699d27 url(/img/weave.png) no-repeat left top;
  background-size: 400px auto;
}
@media (min-width: 768px) {
  .pullquote.hero {
    background-size: 550px auto;
  }
}
@media (min-width: 992px) {
  .pullquote.hero {
    background-size: 700px auto;
  }
}
@media (min-width: 992px) {
  .pullquote.hero .quote-wrapper {
    padding-top: 72px;
    padding-bottom: 72px;
  }
}
.pullquote.hero .quote {
  font-size: 2.3rem;
  color: #ffffff;
}
@media (min-width: 768px) {
  .pullquote.hero .quote {
    font-size: 2.8rem;
  }
}
@media (min-width: 992px) {
  .pullquote.hero .quote {
    font-size: 3.5rem;
  }
}
.pullquote.hero .credit {
  text-shadow: 0 0 7px rgba(0, 0, 0, 0.3);
  color: #ffffff;
}
/* --------------------------------------------------
Content Block 25-75
-------------------------------------------------- */
.cb-25-75 {
  border-top: 1px solid #ebebeb;
}
.cb-25-75:first-of-type {
  border-top: none;
}
.cb-25-75 .cb-photo {
  padding: 36px 9px 0;
}
@media (min-width: 768px) {
  .cb-25-75 .cb-photo {
    padding-right: 18px;
  }
}
@media (min-width: 992px) {
  .cb-25-75 .cb-photo {
    padding-right: 36px;
  }
}
.cb-25-75 .cb-photo img {
  display: block;
  margin: 0 auto;
}
.cb-25-75 .cb-copy {
  padding: 36px 9px 0;
}
@media (min-width: 768px) {
  .cb-25-75 .cb-copy {
    border-left: 1px solid #ebebeb;
    padding-left: 18px;
  }
}
@media (min-width: 992px) {
  .cb-25-75 .cb-copy {
    padding-left: 36px;
  }
}
.cb-25-75 .cb-title {
  margin-top: 0;
}
/* --------------------------------------------------
Notables
-------------------------------------------------- */
.notables {
  font-size: 1.4rem;
  line-height: 1.7;
  margin-bottom: 36px;
}
@media (min-width: 992px) {
  .notables {
    font-size: 1.6rem;
  }
}
@media (min-width: 768px) {
  .notables {
    float: none;
    display: table;
  }
}
.notables .item {
  text-align: center;
  padding: 36px 36px 0;
  border-bottom: 1px solid #ebebeb;
}
@media (min-width: 768px) {
  .notables .item {
    border-bottom: none;
    border-left: 1px solid #ebebeb;
    float: none;
    display: table-cell;
  }
  .notables .item:first-of-type {
    border: none;
  }
}
.notables .note-graphic {
  font-size: 6rem;
  color: #286077;
  font-weight: 700;
  line-height: 1;
}
@media (min-width: 768px) {
  .notables .note-graphic {
    font-size: 4rem;
  }
}
@media (min-width: 992px) {
  .notables .note-graphic {
    font-size: 5rem;
  }
}
@media (min-width: 1200px) {
  .notables .note-graphic {
    font-size: 6rem;
  }
}
.notables img {
  height: auto;
  max-width: 100px;
  width: 100%;
}
/* --------------------------------------------------
Table
-------------------------------------------------- */
.table {
  border-bottom: 1px solid #ebebeb;
  margin-bottom: 36px;
  width: 100%;
}
.table thead th {
  font-size: 1.2rem;
  color: #00643c;
  text-transform: uppercase;
  letter-spacing: 1px;
  font-weight: 700;
  margin-bottom: 9px;
  border-top: none;
  border-bottom: 2px solid #000000;
  font-weight: 500;
}
.table td {
  padding: 12px;
  vertical-align: top;
  border-top-color: #ebebeb;
}
.table.job-stats td:first-of-type {
  font-size: 1.4rem;
  color: #00643c;
  text-transform: uppercase;
}
.table .highlight-row {
  background-color: #f4f4f5;
  font-weight: 700;
}
@media (max-width: 768px) {
  .table-stack-sm table tr {
    display: block;
    border-top: 1px solid #ebebeb;
    padding: 9px 0;
  }
  .table-stack-sm table td,
  .table-stack-sm table th {
    display: block;
    border: none!important;
    padding: 9px;
  }
}
