/*! ---------- top header color changes ---------- */

.header-user__welcome, .media-body .btn.btn-default, .sf-logged-out-view .btn.btn-default {
    color: #246ba0;
    font-weight: 800;
    opacity: 0.8;
    float: left;
    font-family: "Raleway", "Helvetica Neue", Helvetica, Arial, sans-serif;
    font-size: 15px;
}

.header-utility {
    background: #dde9fb;
}


.accordion__label {
    font-weight: 500;
}

/* Offset HTML anchors for fixed header */
html {
  scroll-padding-top: 125px;
}

/* Change mobile header color */
@media (max-width: 1209px) {
  .page-header__toggle {
    background: #234781;
  }
}


/*! ---------- =change all fonts from Bitter to Raleway ---------- */
body {
    font: 18px/24px "Raleway", "Helvetica Neue", Helvetica, Arial, sans-serif;
    color: #556976;
    -webkit-text-size-adjust: 100%;
    -ms-text-size-adjust: 100%;
    font-weight: 400;
}

.alternate-typeface,
.note,
.pull-quote__attribution,
.item-list__date, .sf-fieldWrp p {
  font-family: "Raleway", "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-weight: 400;
  font-style: italic;
}

.header-user__welcome, .media-body  .btn.btn-default,
.sf-logged-out-view .btn.btn-default {
  color: #1b9aaa;
  font-weight: 800;
  opacity: 0.8;
  float: left;
  font-family: "Raleway", "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-size: 15px;
}

.header-search__input::-webkit-input-placeholder {
  color: #96aab8;
  font-family: "Raleway", "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-style: italic;
}

.header-search__input::-moz-placeholder {
  color: #96aab8;
  font-family: "Raleway", "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-style: italic;
}

.header-search__input::-ms-input-placeholder {
  color: #96aab8;
  font-family: "Raleway", "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-style: italic;
}


a {
    text-decoration: none;
    color: #0b5db1;
    font-weight: 700;
}

h1, h2, .footer-contact {
    color: #333333;
    font-family: "Raleway", "Helvetica Neue", Helvetica, Arial, sans-serif;
    text-rendering: optimizeLegibility;
    font-weight: 300;
    letter-spacing: -.035em;
    line-height: 1em;
}

h2 {
    margin-bottom: 8px;
}

h3, h4, h5, h6 {
    color: #333333;
    font-family: "Raleway", "Helvetica Neue", Helvetica, Arial, sans-serif;
    text-rendering: optimizeLegibility;
}

h3 {
  font-weight: 400;
}

h4 {
  font-weight: 500;
}

h5 {
  font-weight: 600;
}

h6 {
  font-weight: 700;
}

.page-title {
    color: #333333;
    font-weight: 300;
    margin-top: 8px;
    font-size: 42px;
}


.in-this-section {
    background: #dde9fb;
}

.footer-logo:before {
    background: #dde9fb;
}

/* Mobile-first stacking footer */

.footer-utility__list { 
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  list-style: none;    
  justify-content: center;
  justify-items: center;   
  margin: 0 auto;    
}

.footer-utility__item + .footer-utility__item {
  margin-left: 0;
}

@media screen and (min-width: 1024px) {
  .footer-utility__list {
    flex-direction: row;
    gap: 1rem;
  }
}


/* TABLES */
.table {
  width: 100%;
  overflow: auto;
  margin-bottom: 3rem;
}

/* alternate background color on rows */
.table__row:nth-child(even) {
  background-color: #e4e4e4;
}

.table__header {
  background-color: #234781;
  color: #fff;
}

.table__header, .table__cell {
  padding: 1rem;
  border: 1px solid #ccc;
  text-align: left;
}

@media only screen and (max-width: 760px), (min-device-width: 768px) and (max-device-width: 1024px) {
 .table, .table thead, .table tbody, .table__header, .table__cell, .table__row {
    display:block;
  }
  
  /* Hide table headers but keep them in the DOM for accessibility */
  .table thead .table__header {
    position: absolute;
    top: -9999px;
    left: -9999px;
  }
  
  .table__row {
    border: 1px solid #ccc;
  }
  
  .table__cell {
    /* Behave like a row*/
    border: none;
    border-bottom: 1px solid #eee;
    position: relative;
    padding-left: 50%;
    overflow: scroll;
  }
  
  .table__cell:before {
    /* Now like a table header */
    position: absolute;
    /* Top/left values mimic padding */
    top: 0.75rem;
    left: 0.75rem;
    width: 20%;
    padding-right: 1rem;
    white-space: normal;
    /* Label the data */
    content: attr(data-column);
    font-weight: bold;
  }
 }


/* BUTTONS */
.button,
.button:hover,
.button:focus{
    background: #224488;
}

.button--highlight:hover,
.button--highlight:focus {
  background: #797767;
}
.button--action {
  background: #1B9AAA;
  color: #fff;
}
.button--action:hover,
.button--action:focus {
  background: #098A9A;
}
.button--tertiary {
  background: #152B4F;
}
.button--hollow {
  background: rgba(0, 0, 0, 0);
  border: 1px solid #fff;
}
.button--warn {
  background: #e67e22;
  color: #fff;
}
.button--warn:hover,
.button--warn:focus {
  background: #d35400;
}
.button--cancel {
  background: #fff;
  border: 1px solid #234781;
  color: #234781;
  font-size: 16px;
  font-weight: 400;
}
.button--cancel:hover,
.button--cancel:focus {
  background: #152B4F;
  border-color: #152B4F;
}
.button--quick-links {
  font-size: .75em;
  text-transform: uppercase;
}

/* FONT AWESOME ICONS */
.fa, .fab, .fal, .far, .fas {
  padding-right: 0.5em;
}

span.fab.contact, span.fal.contact, span.far.contact, span.fas.contact {
  color: #2d7fbc;
  font-weight: 500;
  
}

/* FORMS */
/*----copy-pasting base styles from parent stylesheet for now so as not to affect live site----*/
/*----change colors of labels and input borders to PRSSA blue---*/

label, .sf-fieldWrp label {
  color: #234781;
}

label.required, .sf-fieldWrp.required label {
  color: #0B5DB1;
}

label.required::after, .sf-fieldWrp.required label::after {
  content: '*';
  font-weight: 400;
}

input:focus {
  border: 1px solid #0B5DB1;
}

/*---duplicating note class as a workaround before extending note class in parent styles---*/
.sf-fieldWrp p {
  font-size: 80%;
  opacity: 0.8;
}

/* HORIZONTAL TABS */


.tabs--standard .tabs__tab {
    border: 1px solid #224488;
    background: #224488;
}


.tabs--standard .tabs__tab.is-active {
    color: #224488;
}


 /* VERTICAL TABS */

.tabs--vertical .tabs__tab {
    border-right-color: #224488;
    box-shadow: inset 6px 0 0 #224488;
}


.tabs--vertical .tabs__tab {
    background: #224488;
}


.tabs--vertical .tabs__tab.is-active {
    border-color: #224488 #fff #224488 #224488;
    box-shadow: inset 6px 0 0 #224488;
    color: #224488;

}



/* ACCORDION */

.accordion__label {
    background: #224488;
    border: 1px solid #224488;
}


.accordion__label.is-active {
    color: #224488;
    background: #f7f7f7;
    border-color: #224488;
}

/* CONTENT BOX LAYOUT WITH BORDER */

.content-box {
    background: #fff;
    border: 1px solid #1c547d;
    padding: 24px;
}

/* RIGHT-COLUMN CONTENT BOX CLASSES */

.interior-layout__aside .content-box--action {
  background: #52608C;
}

.interior-layout__aside .content-box--action a:hover {
  color: #20b5c8;
}

.interior-layout__aside .content-box--highlight {
  background: #A09E89;
  border-color: #A09E89;
}

.interior-layout__aside .content-box--highlight:hover {
  background: #BDBBA7;
}

.interior-layout__aside .content-box--highlight h1, .interior-layout__aside .content-box--highlight h2, .interior-layout__aside .content-box--highlight h3, .interior-layout__aside .content-box--highlight h4, .interior-layout__aside .content-box--highlight h5, .interior-layout__aside .content-box--highlight h6, .interior-layout__aside .content-box--highlight p, .interior-layout__aside .content-box--highlight a {
  color: #434343;
}

.interior-layout__aside .content-box--highlight a:hover {
  color: #52608C;
}

/* IN THIS SECTION */
/* Style for mobile */

@media screen and (max-width: 959px) {
  .in-this-section__toggle {
    display: flex;
    justify-content: space-between;
    background: #234781;
  }
  .js .in-this-section > ul.is-active {
    background: #dde9fb;
  }
}

/* CHANGE HORIZONTAL RULE TO ONE PIXEL */
hr {
    background: #246BA0;
    height: 1px;
    margin-bottom: 12px;
    margin-top: 12px;
}

/* PAGE TITLE BANNER */
/* Make banner images size responsively on mobile devices */

@media screen and (max-width: 1023px) {
  .interior-layout__title img {
    min-height: 25vh;
    object-fit: cover;
  }
}

/* RESPONSIVE VIDEO CONTAINER */
.video-container { 
  position: relative; 
  width: 100%;
  padding-bottom: 56.25%; 
  height: 0; 
  overflow: hidden;
}

.video-container iframe, .video-container object, .video-container embed { 
  position: absolute; 
  top: 0; 
  left: 0; 
  width: 100%; 
  height: 100%; 
}

/* pricing labels on events/calendar detail pages */
dt.pricing__label {
  white-space: nowrap;
}