/* SCSS Framework boilerplate from Ristretto: https://github.com/kylelarkin/ristretto */
* {
  box-sizing: border-box; }

body, select, input, textarea {
  color: #333; }

::-moz-selection {
  background: #ccc;
  color: #000;
  text-shadow: none; }

::selection {
  background: #ccc;
  color: #000;
  text-shadow: none; }

a:link {
  -webkit-tap-highlight-color: transparent; }

ins {
  background-color: #ccc;
  color: #000;
  text-decoration: none; }

mark {
  background-color: #ccc;
  color: #000;
  font-style: italic;
  font-weight: bold; }

.ristretto-body {
  color: #333;
  font-family: "Surveyor Text A", "Surveyor Text B", "Times New Roman", serif;
  font-size: 100%;
  font-weight: 300;
  line-height: 1.5; }

.body--wrapper a, .editor-styles-wrapper .block-editor-block-list__block a {
  color: #111; }
  .body--wrapper a:hover, .body--wrapper a:focus, .editor-styles-wrapper .block-editor-block-list__block a:hover, .editor-styles-wrapper .block-editor-block-list__block a:focus {
    color: #111; }

.body--wrapper h1, .editor-styles-wrapper .block-editor-block-list__block h1 {
  color: #333;
  font-family: "Surveyor Display A", "Surveyor Display B", "Times New Roman", serif;
  font-size: 38px;
  font-weight: 500;
  line-height: 1;
  margin-bottom: 1.5rem; }
  @media (min-width: 320px) {
    .body--wrapper h1, .editor-styles-wrapper .block-editor-block-list__block h1 {
      font-size: calc(38px + 26 * (100vw - 320px) / 960); } }
  @media (min-width: 1280px) {
    .body--wrapper h1, .editor-styles-wrapper .block-editor-block-list__block h1 {
      font-size: 64px; } }
.body--wrapper h2, .editor-styles-wrapper .block-editor-block-list__block h2 {
  color: #333;
  font-family: "Surveyor Display A", "Surveyor Display B", "Times New Roman", serif;
  font-size: 32px;
  font-weight: 500;
  line-height: 1.2;
  margin-bottom: 1rem; }
  @media (min-width: 320px) {
    .body--wrapper h2, .editor-styles-wrapper .block-editor-block-list__block h2 {
      font-size: calc(32px + 16 * (100vw - 320px) / 960); } }
  @media (min-width: 1280px) {
    .body--wrapper h2, .editor-styles-wrapper .block-editor-block-list__block h2 {
      font-size: 48px; } }
.body--wrapper h3, .editor-styles-wrapper .block-editor-block-list__block h3 {
  color: #333;
  font-family: "Surveyor Display A", "Surveyor Display B", "Times New Roman", serif;
  font-size: 28px;
  font-weight: 500;
  line-height: 1.2;
  margin-bottom: 1rem; }
  @media (min-width: 320px) {
    .body--wrapper h3, .editor-styles-wrapper .block-editor-block-list__block h3 {
      font-size: calc(28px + 14 * (100vw - 320px) / 960); } }
  @media (min-width: 1280px) {
    .body--wrapper h3, .editor-styles-wrapper .block-editor-block-list__block h3 {
      font-size: 42px; } }
.body--wrapper h4, .editor-styles-wrapper .block-editor-block-list__block h4 {
  color: #333;
  font-family: "Gotham SSm A", "Gotham SSm B", Helvetica, Arial, sans-serif;
  font-size: 24px;
  font-weight: 300;
  line-height: 1.3;
  margin-bottom: 1rem; }
  @media (min-width: 320px) {
    .body--wrapper h4, .editor-styles-wrapper .block-editor-block-list__block h4 {
      font-size: calc(24px + 8 * (100vw - 320px) / 960); } }
  @media (min-width: 1280px) {
    .body--wrapper h4, .editor-styles-wrapper .block-editor-block-list__block h4 {
      font-size: 32px; } }
.body--wrapper h5, .editor-styles-wrapper .block-editor-block-list__block h5 {
  color: #333;
  font-family: "Gotham SSm A", "Gotham SSm B", Helvetica, Arial, sans-serif;
  font-size: 21px;
  font-weight: 300;
  line-height: 1.3;
  margin-bottom: 1rem; }
  @media (min-width: 320px) {
    .body--wrapper h5, .editor-styles-wrapper .block-editor-block-list__block h5 {
      font-size: calc(21px + 6 * (100vw - 320px) / 960); } }
  @media (min-width: 1280px) {
    .body--wrapper h5, .editor-styles-wrapper .block-editor-block-list__block h5 {
      font-size: 27px; } }
.body--wrapper h6, .editor-styles-wrapper .block-editor-block-list__block h6 {
  color: #333;
  font-family: "Gotham SSm A", "Gotham SSm B", Helvetica, Arial, sans-serif;
  font-size: 20px;
  font-weight: 500;
  line-height: 1.3;
  margin-bottom: 1rem; }
  @media (min-width: 320px) {
    .body--wrapper h6, .editor-styles-wrapper .block-editor-block-list__block h6 {
      font-size: calc(20px + 2 * (100vw - 320px) / 960); } }
  @media (min-width: 1280px) {
    .body--wrapper h6, .editor-styles-wrapper .block-editor-block-list__block h6 {
      font-size: 22px; } }
.body--wrapper p, .editor-styles-wrapper .block-editor-block-list__block p {
  font-size: 19px;
  font-weight: 300;
  line-height: 1.5;
  margin: 0 0 1em 0; }
  @media (min-width: 320px) {
    .body--wrapper p, .editor-styles-wrapper .block-editor-block-list__block p {
      font-size: calc(19px + 3 * (100vw - 320px) / 960); } }
  @media (min-width: 1280px) {
    .body--wrapper p, .editor-styles-wrapper .block-editor-block-list__block p {
      font-size: 22px; } }
  .body--wrapper p.has-small-font-size, .editor-styles-wrapper .block-editor-block-list__block p.has-small-font-size {
    font-size: 1rem; }

.body--wrapper em, .body--wrapper i, .editor-styles-wrapper .block-editor-block-list__block em, .editor-styles-wrapper .block-editor-block-list__block i {
  font-style: italic;
  font-weight: 300; }
  .body--wrapper em strong, .body--wrapper em b, .body--wrapper i strong, .body--wrapper i b, .editor-styles-wrapper .block-editor-block-list__block em strong, .editor-styles-wrapper .block-editor-block-list__block em b, .editor-styles-wrapper .block-editor-block-list__block i strong, .editor-styles-wrapper .block-editor-block-list__block i b {
    font-style: italic;
    font-weight: 500; }

.body--wrapper strong, .body--wrapper b, .editor-styles-wrapper .block-editor-block-list__block strong, .editor-styles-wrapper .block-editor-block-list__block b {
  font-weight: 500; }
  .body--wrapper strong em, .body--wrapper strong i, .body--wrapper b em, .body--wrapper b i, .editor-styles-wrapper .block-editor-block-list__block strong em, .editor-styles-wrapper .block-editor-block-list__block strong i, .editor-styles-wrapper .block-editor-block-list__block b em, .editor-styles-wrapper .block-editor-block-list__block b i {
    font-weight: 500; }

.body--wrapper ol, .editor-styles-wrapper .block-editor-block-list__block ol {
  margin: 1.5em 0 1.5em 1.5em; }

.body--wrapper ul, .editor-styles-wrapper .block-editor-block-list__block ul {
  list-style: disc;
  margin: 1.5em 0 1.5em 1.5em; }

.body--wrapper li, .editor-styles-wrapper .block-editor-block-list__block li {
  font-size: 19px;
  font-weight: 300;
  line-height: 1.5;
  margin: 0 0 .25em 0; }
  @media (min-width: 320px) {
    .body--wrapper li, .editor-styles-wrapper .block-editor-block-list__block li {
      font-size: calc(19px + 3 * (100vw - 320px) / 960); } }
  @media (min-width: 1280px) {
    .body--wrapper li, .editor-styles-wrapper .block-editor-block-list__block li {
      font-size: 22px; } }
.body--wrapper .r-button, .editor-styles-wrapper .block-editor-block-list__block .r-button {
  background-color: var(--section-color);
  border: 2px solid var(--section-color);
  color: #fff;
  display: inline-block;
  font-family: "Gotham SSm A", "Gotham SSm B", Helvetica, Arial, sans-serif;
  font-size: 0.875rem;
  font-weight: 500;
  letter-spacing: 1px;
  overflow: hidden;
  padding: .65rem .75rem;
  position: relative;
  text-decoration: none;
  text-transform: uppercase;
  transition: .25s all ease-out;
  z-index: 0; }
  .body--wrapper .r-button:hover, .editor-styles-wrapper .block-editor-block-list__block .r-button:hover {
    background: #fff;
    color: var(--section-color); }
  .body--wrapper .r-button.r-button-outline, .editor-styles-wrapper .block-editor-block-list__block .r-button.r-button-outline {
    background: transparent;
    border: 2px solid var(--section-color);
    color: var(--section-color); }
    .body--wrapper .r-button.r-button-outline:before, .editor-styles-wrapper .block-editor-block-list__block .r-button.r-button-outline:before {
      content: '';
      background-color: var(--section-color);
      position: absolute;
      width: 0%;
      top: 0;
      left: -12px;
      height: 100%;
      transition: 0.3s linear;
      transform: skew(-0.06turn);
      z-index: -1; }
    .body--wrapper .r-button.r-button-outline:hover:before, .editor-styles-wrapper .block-editor-block-list__block .r-button.r-button-outline:hover:before {
      width: 150%; }
    .body--wrapper .r-button.r-button-outline:hover, .editor-styles-wrapper .block-editor-block-list__block .r-button.r-button-outline:hover {
      color: #fff !important; }
    .body--wrapper .r-button.r-button-outline.r-button-dark, .editor-styles-wrapper .block-editor-block-list__block .r-button.r-button-outline.r-button-dark {
      border: 2px solid #333;
      color: #333; }
      .body--wrapper .r-button.r-button-outline.r-button-dark:before, .editor-styles-wrapper .block-editor-block-list__block .r-button.r-button-outline.r-button-dark:before {
        content: '';
        background-color: #333; }
      .body--wrapper .r-button.r-button-outline.r-button-dark:hover:before, .editor-styles-wrapper .block-editor-block-list__block .r-button.r-button-outline.r-button-dark:hover:before {
        width: 150%; }

.body--wrapper .r-button-text, .editor-styles-wrapper .block-editor-block-list__block .r-button-text {
  color: #E9545A;
  font-family: "Gotham SSm A", "Gotham SSm B", Helvetica, Arial, sans-serif;
  font-size: 0.875rem;
  font-weight: 500;
  letter-spacing: 1px;
  text-decoration: none;
  text-transform: uppercase;
  transition: all .25s ease-out; }
  .body--wrapper .r-button-text:hover, .editor-styles-wrapper .block-editor-block-list__block .r-button-text:hover {
    color: #e5343b; }

.body--wrapper label, .editor-styles-wrapper .block-editor-block-list__block label {
  font-family: "Gotham SSm A", "Gotham SSm B", Helvetica, Arial, sans-serif;
  font-size: 0.875rem;
  font-weight: 300;
  letter-spacing: 1px;
  text-transform: uppercase; }

.body--wrapper .page-subtitle, .editor-styles-wrapper .block-editor-block-list__block .page-subtitle {
  font-family: "Surveyor Text A", "Surveyor Text B", "Times New Roman", serif;
  font-size: 24px;
  font-style: italic;
  font-weight: 300;
  line-height: 1;
  margin-bottom: 1rem; }
  @media (min-width: 320px) {
    .body--wrapper .page-subtitle, .editor-styles-wrapper .block-editor-block-list__block .page-subtitle {
      font-size: calc(24px + 8 * (100vw - 320px) / 960); } }
  @media (min-width: 1280px) {
    .body--wrapper .page-subtitle, .editor-styles-wrapper .block-editor-block-list__block .page-subtitle {
      font-size: 32px; } }
.body--wrapper .widget-supertitle, .editor-styles-wrapper .block-editor-block-list__block .widget-supertitle {
  font-family: "Gotham SSm A", "Gotham SSm B", Helvetica, Arial, sans-serif;
  font-size: 0.75rem;
  letter-spacing: 1px;
  font-weight: 300;
  color: #888888;
  text-transform: uppercase;
  margin-bottom: .25rem; }

.body--wrapper .widget-title, .editor-styles-wrapper .block-editor-block-list__block .widget-title {
  font-family: "Gotham SSm A", "Gotham SSm B", Helvetica, Arial, sans-serif;
  font-size: 18px;
  font-weight: 300;
  letter-spacing: 1px;
  text-transform: uppercase; }
  @media (min-width: 320px) {
    .body--wrapper .widget-title, .editor-styles-wrapper .block-editor-block-list__block .widget-title {
      font-size: calc(18px + 2 * (100vw - 320px) / 960); } }
  @media (min-width: 1280px) {
    .body--wrapper .widget-title, .editor-styles-wrapper .block-editor-block-list__block .widget-title {
      font-size: 20px; } }
.body--wrapper .widget-subtitle, .editor-styles-wrapper .block-editor-block-list__block .widget-subtitle {
  color: #333;
  font-family: "Surveyor Text A", "Surveyor Text B", "Times New Roman", serif;
  font-size: 1.0625rem;
  font-style: italic;
  font-weight: 300;
  line-height: 21px; }

.body--wrapper .heading-vertical, .editor-styles-wrapper .block-editor-block-list__block .heading-vertical {
  font-family: "Gotham SSm A", "Gotham SSm B", Helvetica, Arial, sans-serif;
  font-size: 0.875rem;
  font-weight: 500;
  letter-spacing: 1px; }

.body--wrapper .section-title, .editor-styles-wrapper .block-editor-block-list__block .section-title {
  border-bottom: 3px solid #f2f2f2;
  color: var(--section-color);
  font-family: "Gotham SSm A", "Gotham SSm B", Helvetica, Arial, sans-serif;
  font-weight: 300;
  font-size: 1.25rem;
  letter-spacing: 1px;
  margin-bottom: 3rem;
  padding-bottom: 1rem;
  text-transform: uppercase; }

.body--wrapper .section-title-l, .editor-styles-wrapper .block-editor-block-list__block .section-title-l {
  border-bottom: 3px solid #f2f2f2;
  color: var(--section-color);
  font-family: "Gotham SSm A", "Gotham SSm B", Helvetica, Arial, sans-serif;
  font-weight: 300;
  font-size: 28px;
  letter-spacing: 1px;
  margin-bottom: 3rem;
  padding-bottom: 1rem;
  text-transform: uppercase; }
  @media (min-width: 320px) {
    .body--wrapper .section-title-l, .editor-styles-wrapper .block-editor-block-list__block .section-title-l {
      font-size: calc(28px + 4 * (100vw - 320px) / 960); } }
  @media (min-width: 1280px) {
    .body--wrapper .section-title-l, .editor-styles-wrapper .block-editor-block-list__block .section-title-l {
      font-size: 32px; } }
.body--wrapper .article-preview-byline, .body--wrapper .ap-byline, .body--wrapper .supertitle, .editor-styles-wrapper .block-editor-block-list__block .article-preview-byline, .editor-styles-wrapper .block-editor-block-list__block .ap-byline, .editor-styles-wrapper .block-editor-block-list__block .supertitle {
  color: #777;
  font-family: "Gotham SSm A", "Gotham SSm B", Helvetica, Arial, sans-serif;
  font-size: 0.75rem;
  font-weight: 500;
  letter-spacing: 1px;
  margin: 0;
  text-transform: uppercase; }

.body--wrapper .ap-excerpt, .editor-styles-wrapper .block-editor-block-list__block .ap-excerpt {
  font-family: "Surveyor Text A", "Surveyor Text B", "Times New Roman", serif;
  font-size: 1.0625rem;
  font-weight: 300;
  margin-top: 1rem; }
  .body--wrapper .ap-excerpt img, .editor-styles-wrapper .block-editor-block-list__block .ap-excerpt img {
    display: none; }

.body--wrapper .article-preview-heading-s, .editor-styles-wrapper .block-editor-block-list__block .article-preview-heading-s {
  font-family: "Surveyor Display A", "Surveyor Display B", "Times New Roman", serif;
  font-size: 1.3125rem;
  font-weight: 500;
  line-height: 1.25;
  margin: 0;
  margin-bottom: .25rem; }

.body--wrapper .article-preview-heading-m, .editor-styles-wrapper .block-editor-block-list__block .article-preview-heading-m {
  font-family: "Surveyor Display A", "Surveyor Display B", "Times New Roman", serif;
  font-size: 1.625rem;
  font-weight: 500;
  margin: 0; }

.body--wrapper .article-preview-heading-l, .editor-styles-wrapper .block-editor-block-list__block .article-preview-heading-l {
  font-family: "Surveyor Display A", "Surveyor Display B", "Times New Roman", serif;
  font-size: 28px;
  font-weight: 500;
  line-height: 1;
  margin: 0; }
  @media (min-width: 320px) {
    .body--wrapper .article-preview-heading-l, .editor-styles-wrapper .block-editor-block-list__block .article-preview-heading-l {
      font-size: calc(28px + 4 * (100vw - 320px) / 960); } }
  @media (min-width: 1280px) {
    .body--wrapper .article-preview-heading-l, .editor-styles-wrapper .block-editor-block-list__block .article-preview-heading-l {
      font-size: 32px; } }
.body--wrapper .article-preview-heading-xl, .editor-styles-wrapper .block-editor-block-list__block .article-preview-heading-xl {
  font-family: "Surveyor Display A", "Surveyor Display B", "Times New Roman", serif;
  font-size: 32px;
  font-weight: 500;
  line-height: 1;
  margin: 0; }
  @media (min-width: 320px) {
    .body--wrapper .article-preview-heading-xl, .editor-styles-wrapper .block-editor-block-list__block .article-preview-heading-xl {
      font-size: calc(32px + 10 * (100vw - 320px) / 960); } }
  @media (min-width: 1280px) {
    .body--wrapper .article-preview-heading-xl, .editor-styles-wrapper .block-editor-block-list__block .article-preview-heading-xl {
      font-size: 42px; } }
.article-content h2, .article-content h3, .article-content h4, .article-content h5, .article-content h6 {
  margin-top: 2rem; }

.article-content a {
  background-image: linear-gradient(to right, rgba(255, 255, 255, 0) 50%, var(--section-color) 50%);
  background-position: -0% 0;
  background-size: 200% auto;
  border-bottom: 2px solid var(--section-color);
  text-decoration: none;
  transition: background-position 0.25s ease-out; }
  .article-content a:hover {
    background-position: -100% 0;
    border-bottom: 2px solid #fff; }

.about-cnf {
  margin-top: 4rem; }
  @media (min-width: 768px) {
    .about-cnf {
      display: grid;
      grid-template-columns: repeat(2, 1fr); } }
  .about-cnf .about-genre {
    margin-bottom: 3rem; }
    @media (min-width: 768px) {
      .about-cnf .about-genre {
        padding-right: 1.5rem;
        margin-bottom: 0; } }
    @media (min-width: 1024px) {
      .about-cnf .about-genre {
        padding-right: 6rem; } }
    .about-cnf .about-genre .section-title-l {
      color: #E9545A !important;
      border-bottom: 0 !important;
      margin: 0 0 1.25rem 0 !important; }
    .about-cnf .about-genre .section-title {
      border-bottom: 0 !important;
      margin: 0 !important;
      padding: 0 !important;
      color: #333; }
    .about-cnf .about-genre .section-subtitle {
      font-style: italic;
      font-size: 1.125rem;
      margin-top: 0; }
    .about-cnf .about-genre .section-excerpt {
      font-size: 1.0625rem;
      line-height: 23px; }
    .about-cnf .about-genre .r-button-outline {
      border: 2px solid #333 !important;
      padding: 0; }
      .about-cnf .about-genre .r-button-outline .wp-block-button__link {
        font-family: "Gotham SSm A", "Gotham SSm B", Helvetica, Arial, sans-serif;
        color: #333;
        font-size: 0.9375rem;
        font-weight: 400;
        line-height: 18px;
        letter-spacing: 1px;
        text-transform: uppercase;
        position: relative;
        padding: .75rem 1.5rem .75rem 1rem;
        background-color: transparent; }
        .about-cnf .about-genre .r-button-outline .wp-block-button__link:hover {
          color: #fff;
          transform: none; }
        .about-cnf .about-genre .r-button-outline .wp-block-button__link svg {
          pointer-events: none;
          position: absolute;
          right: 12px;
          top: 14px;
          z-index: 100; }
        .about-cnf .about-genre .r-button-outline .wp-block-button__link:after {
          content: '\f0da';
          display: none;
          font-family: 'Font Awesome 5 Pro';
          font-weight: 900; }
  .about-cnf .recent-news {
    margin-top: 3rem; }
    @media (min-width: 768px) {
      .about-cnf .recent-news {
        margin-top: 0;
        padding-left: 1.5rem;
        border-left: 2px solid #eee; } }
    @media (min-width: 1024px) {
      .about-cnf .recent-news {
        padding-left: 3rem; } }
    .about-cnf .recent-news .section-title-l {
      border-bottom: 0 !important;
      margin: 0 !important;
      padding-bottom: .5rem; }
      .about-cnf .recent-news .section-title-l a {
        text-decoration: none;
        color: #E9545A; }
    .about-cnf .recent-news .news-subtitle {
      font-family: "Gotham SSm A", "Gotham SSm B", Helvetica, Arial, sans-serif;
      color: #222;
      font-size: 1.0625rem;
      font-style: italic;
      font-weight: 300;
      line-height: 1;
      letter-spacing: 0px;
      margin-bottom: 3rem; }
    .about-cnf .recent-news .news-list {
      list-style: none;
      margin: 0;
      padding-left: 0; }
      .about-cnf .recent-news .news-list .news {
        margin-top: 1.5rem;
        position: relative;
        margin: 1.5rem 0 2rem 74px; }
        .about-cnf .recent-news .news-list .news:last-child {
          margin-bottom: 0; }
        .about-cnf .recent-news .news-list .news:before {
          content: '\f1ea';
          font-family: 'Font Awesome 5 Pro';
          font-weight: 900;
          display: none; }
        .about-cnf .recent-news .news-list .news svg {
          background-color: #E9545A;
          border-radius: 50%;
          color: #fff;
          font-size: 1.25rem;
          height: 50px;
          left: -74px;
          overflow: visible;
          padding: 15px 0;
          position: absolute;
          top: 3px;
          width: 50px;
          z-index: 100; }
        .about-cnf .recent-news .news-list .news a {
          text-decoration: none; }
          .about-cnf .recent-news .news-list .news a .news-date {
            color: #E9545A;
            font-family: "Gotham SSm A", "Gotham SSm B", Helvetica, Arial, sans-serif;
            font-size: 0.75rem;
            font-weight: 500;
            line-height: 14px;
            letter-spacing: 1px;
            margin: 0 !important;
            padding-bottom: .5rem !important;
            text-transform: uppercase; }
          .about-cnf .recent-news .news-list .news a .news-title {
            font-family: "Gotham SSm A", "Gotham SSm B", Helvetica, Arial, sans-serif;
            font-size: 1.25rem;
            font-weight: 300;
            line-height: 28px;
            letter-spacing: 1px;
            margin: 0 0 .5rem 0;
            text-transform: uppercase; }
          .about-cnf .recent-news .news-list .news a .news-excerpt {
            font-size: 1.0625rem;
            line-height: 23px; }
