/*
Shims for Flexbox - should work on Safari and IE10+
*/
.display-flex {
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
}
* {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  box-sizing: border-box;
  -webkit-tap-highlight-color: transparent;
}
body {
  color: #231f20;
  font-family: "ff-meta-serif-web-pro", Georgia, serif;
  font-size: 19px;
  line-height: 1.42105263;
  padding: 0;
  margin: 0;
  touch-action: manipulation;
  position: relative;
}
@media (prefers-color-scheme: dark) {
  body {
    color: white;
  }
}
.interactive {
  padding: 10px;
  margin: 20px auto;
  border-top: 1px solid #e0e0e0;
  border-bottom: 1px solid #e0e0e0;
  font-family: "ff-dagny-web-pro", Helvetica Neue, Helvetica, sans-serif;
  max-width: 760px;
}
a {
  color: #0777b3;
  text-decoration: none;
}
a:visited {
  color: #7e838b;
}
a:hover,
a:focus {
  color: #2b4d70;
}
a img {
  border: none;
}
img,
video,
embed,
object,
iframe {
  max-width: 100%;
}
h1,
h2,
h3,
h4,
h5,
h6 {
  color: #231f20;
  margin: 1.42105263 0 0.71052632 0;
}
h1 {
  font-size: 60px;
  line-height: 1.07142857;
  letter-spacing: 2px;
  text-align: center;
  font-family: 'PT Sans';
  text-transform: uppercase;
}
@media (max-width: 768px) {
  h1 {
    font-size: 42px;
    line-height: 1.0952381;
    letter-spacing: 1px;
  }
}
h2 {
  font-family: 'PT Sans';
  text-align: center;
  letter-spacing: 1px;
  font-size: 28px;
  line-height: 1.42105263;
  font-style: italic;
}
@media (max-width: 480px) {
  h2 {
    font-size: 24px;
    line-height: 1.0952381;
  }
}
h3 {
  font-family: 'PT Sans';
  font-size: 28px;
  line-height: 1.04545455;
  text-align: center;
  letter-spacing: 1px;
}
h4 {
  font-size: 16px;
  font-weight: 600;
  line-height: 1.5;
  margin: 0.71052632 0 0 0;
}
.byline {
  font-size: 19px;
  margin-bottom: 0;
}
.staff-position {
  font-style: italic;
  font-size: 15px;
  margin-top: 0;
}
.publish-date {
  font-size: 16px;
  font-family: "ff-dagny-web-pro", Helvetica Neue, Helvetica, sans-serif;
  color: #7e838b;
}
.graphic-hed {
  font-family: "ff-dagny-web-pro", Helvetica Neue, Helvetica, sans-serif;
  font-size: 22px;
  font-weight: bold;
  text-align: center;
}
.graphic-chatter {
  font-family: "ff-dagny-web-pro", Helvetica Neue, Helvetica, sans-serif;
  font-size: 18px;
  font-weight: normal;
  text-align: left;
  padding-bottom: 5px;
}
.source-container {
  margin-top: 5px;
}
.source-container::after {
  clear: both;
  content: "";
  display: block;
}
.data-source,
.art-credit,
.caption {
  color: #7e838b;
  font-family: "ff-dagny-web-pro", Helvetica Neue, Helvetica, sans-serif;
  font-size: 14px;
}
.data-source {
  font-style: italic;
}
@media (min-width: 480px) {
  .data-source {
    float: left;
  }
}
@media (min-width: 480px) {
  .art-credit {
    float: right;
  }
}
.main-nav {
  background: white;
  border-bottom: 1px solid #e0e0e0;
  box-shadow: 0 2px 7px rgba(0, 0, 0, 0.1);
  position: relative;
  line-height: 1;
  z-index: 999;
}
.main-nav .wrapper {
  max-width: 1020px;
  margin: auto;
  position: relative;
  padding: 10px;
}
.main-nav .logo {
  display: inline-block;
  vertical-align: middle;
  width: 160px;
}
.main-nav .logo img {
  height: 24px;
  max-height: 100%;
}
.share-bar {
  display: inline-block;
  position: absolute;
  right: 0;
  vertical-align: middle;
}
.share-icon {
  margin-left: 3px;
  margin-right: 3px;
  width: 30px;
}
.share-icon:hover .changes-color {
  fill: #231f20;
}
.marketing {
  font-family: "ff-dagny-web-pro", Helvetica Neue, Helvetica, sans-serif;
  margin: 20px 5px;
  padding: 10px;
  text-align: center;
  width: calc(100% - 10px);
}
.marketing--footer {
  border: 1px solid #e0e0e0;
  max-width: 630px;
}
@media (min-width: 640px) {
  .marketing--footer {
    margin: 20px auto;
  }
  .marketing--footer span {
    white-space: pre;
  }
}
.marketing--sidebar {
  border-top: 1px solid #e0e0e0;
  border-bottom: 1px solid #e0e0e0;
  max-width: 350px;
}
@media (max-width: 500px) {
  .marketing--sidebar {
    margin: auto;
  }
}
.marketing__text {
  margin: 5px auto;
}
.marketing__body {
  font-size: 18px;
  line-height: 21px;
}
.marketing__button {
  background: #0777b3;
  border-radius: 3px;
  color: white;
  display: inline-block;
  font-size: 19px;
  font-weight: bold;
  margin-top: 3px;
  padding: 5px 20px;
}
.marketing__button:hover {
  color: #fff;
  background: #2b4d70;
}
.marketing__button:visited {
  color: #fff;
}
.show-comments {
  border: 1px solid #0777b3;
  padding: 20px;
  text-align: center;
  text-transform: uppercase;
  font-family: "ff-dagny-web-pro", Helvetica Neue, Helvetica, sans-serif;
  font-weight: bold;
  font-size: 15px;
  color: #0777b3;
  cursor: pointer;
  margin: 20px 0;
}
.thin-div {
  border-bottom: 1px solid #e0e0e0;
  margin-bottom: 15px;
  font-family: "ff-dagny-web-pro", Helvetica Neue, Helvetica, sans-serif;
  margin: auto;
  max-width: 900px;
}
.thin-div .center {
  position: relative;
  top: 15px;
  margin: auto;
  width: 105px;
  text-align: center;
  font-size: 20px;
  background: white;
}
.dont-miss {
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin: auto;
  margin-top: 15px;
  max-width: 900px;
  font-size: 17px;
  font-family: "ff-dagny-web-pro", Helvetica Neue, Helvetica, sans-serif;
}
.dont-miss .story {
  -webkit-flex: 0 0 25%;
  -ms-flex: 0 0 25%;
  flex: 0 0 25%;
}
@media (max-width: 480px) {
  .dont-miss .story {
    -webkit-flex: 1 1 50%;
    -ms-flex: 1 1 50%;
    flex: 1 1 50%;
  }
}
.dont-miss .padded {
  padding: 10px;
}
.dont-miss img {
  width: 100%;
}
.dont-miss a {
  color: #424648;
  transition: color .1s linear;
}
.dont-miss a:hover {
  color: #0777b3;
}
.dont-miss .small {
  font-weight: bold;
  font-size: 15px;
}
.project-credits {
  padding-top: 10px;
  max-width: 900px;
  margin: 10px auto;
}
@media (min-width: 768px) {
  .project-credits {
    display: flex;
    flex-wrap: wrap;
    margin-bottom: 35px;
  }
}
.project-credit {
  flex-basis: 50%;
  font-family: "ff-dagny-web-pro", Helvetica Neue, Helvetica, sans-serif;
  font-size: 17px;
  line-height: 1.2;
  margin: 3px 0;
  padding: 0 10px;
}
footer.nav-bottom {
  background: black;
  opacity: 0.95;
  padding: 8px 8px 4px 8px;
  position: relative;
  z-index: 99;
}
footer.nav-bottom .logo {
  float: left;
  margin-right: 10px;
}
footer.nav-bottom .logo img {
  margin-top: 5px;
  height: 20px;
}
footer.nav-bottom::after {
  clear: both;
  content: " ";
  display: block;
}
.chart {
  max-width: 800px;
  margin: auto;
}
@media (max-width: 480px) {
  .chart {
    width: 100%;
  }
}
.visible-mobile {
  display: none !important;
}
@media (max-width: 480px) {
  .visible-mobile {
    display: inline !important;
  }
  .hidden-mobile {
    display: none !important;
  }
}
.flip {
  max-width: 1020px;
  margin: auto;
  border-bottom: 0;
}
.grid {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-evenly;
}
@media (max-width: 768px) {
  .grid {
    display: inline-block;
    padding-top: 10px;
  }
}
/* The flip card container - set the width and height to whatever you want. We have added the border property to demonstrate that the flip itself goes out of the box on hover (remove perspective if you don't want the 3D effect */
.flip-card {
  background-color: transparent;
  width: 250px;
  height: 200px;
  perspective: 1000px;
  /* Remove this if you don't want the 3D effect */
  width: 25%;
  padding-left: 5px;
  padding-right: 5px;
  padding-top: 30px;
  padding-bottom: 32%;
  margin-bottom: 2%;
}
@media only screen and (max-width: 999px) {
  .flip-card {
    height: 400px;
    width: 33%;
  }
}
@media (max-width: 768px) {
  .flip-card {
    width: 50%;
    margin: auto;
    height: 380px;
  }
}
@media (max-width: 480px) {
  .flip-card {
    display: block;
    width: 75%;
    padding: 0 2%;
  }
}
.flip-card .city {
  font-size: 16px;
  margin: 0;
  text-transform: uppercase;
  font-weight: 700;
  text-align: center;
  padding: 0 0 5px;
}
.flip-card .text-flip {
  display: flex;
  flex-wrap: wrap;
  padding-bottom: 4px;
}
.flip-card .details {
  flex: 50%;
  font-size: 14px;
  margin: 0;
  text-align: left;
  padding: 0 0 4px;
}
@media (max-width: 480px) {
  .flip-card .details {
    padding: 0 5px 4px;
  }
}
/* This container is needed to position the front and back side */
.flip-card-inner {
  position: relative;
  width: 100%;
  height: 100%;
  text-align: center;
  transition: transform 0.8s;
  transform-style: preserve-3d;
}
@media (max-width: 480px) {
  .flip-card-inner {
    height: 58%;
  }
}
/* Do an horizontal flip when you move the mouse over the flip box container */
.flip-card:hover .flip-card-inner {
  transform: rotateY(180deg);
}
/* Position the front and back side */
.flip-card-front,
.flip-card-back {
  position: absolute;
  width: 100%;
  height: 240px;
  -webkit-backface-visibility: hidden;
  /* Safari */
  backface-visibility: hidden;
}
/* Style the front side (fallback if image is missing) */
.flip-card-front {
  background-color: white;
  color: black;
}
/* Style the back side */
.flip-card-back {
  padding: 20px 10px 10px;
  background-color: #97cbf0;
  color: black;
  transform: rotateY(180deg);
}
