/** Fonts **/
@import url('https://fonts.googleapis.com/css?family=Lato:100,100i,300,300i,400,400i,700,700i,900,900i');
@import url('https://fonts.googleapis.com/css?family=Playfair+Display:400,400i,700,700i,900,900i');
@import url('https://fonts.googleapis.com/css?family=IBM+Plex+Mono:100,100i,200,200i,300,300i,400,400i,500,500i,600,600i,700,700i|IBM+Plex+Sans+Condensed:100,100i,200,200i,300,300i,400,400i,500,500i,600,600i,700,700i|IBM+Plex+Sans:100,100i,200,200i,300,300i,400,400i,500,500i,600,600i,700,700i|IBM+Plex+Serif:100,100i,200,200i,300,300i,400,400i,500,500i,600,600i,700,700i');
@import url('https://fonts.googleapis.com/css?family=Space+Mono:400,400i,700,700i');
@font-face {
  font-family: 'Ink';
  src: url('../resources/ink.ttf') format('truetype');
}

.hidden {
  display: none;
}

* {
  -webkit-tap-highlight-color: rgba(0,0,0,0);
}

html, body {
  margin:0;
  padding:0;

  /** Safari is currently the only browser which renders
      IBM Plex as intended. This adjusts Chrome/Firefox
      to match. */
  -webkit-text-stroke-width: 0.3px;
  -moz-text-stroke-width: 0.3px;
}

body:not(:root:root) {
  /** Safari-specific override. */
  -webkit-text-stroke-width: 0.0px !important;
}

body {
    margin-right: 0px !important;
    margin-left: 0px !important;
    margin-top: 0px !important;
    margin-bottom: 0px !important;
    padding: 0px !important;
}

.footer-body {
    height: 200px;
    width: 100%;
    position: relative;
    display: inline-block;
}

.footnote-paragraph {
    font-family: "IBM Plex Sans";
    font-size: 24px;
    padding: 20px;
    font-weight: 300;
}

.footnote-paragraph-body {
    margin-top: 30px;
}

.header-body {
    max-width: 700px;
    margin: 0 auto;
    padding-bottom: 25px;
}

.header-container {
  width: 100%;
  margin-left: 0%;
  background: clear;
}

.article-header {
    position: relative;
    text-align: center;
    padding-left: 10px;
}

.article-header-title {
    font-family: 'IBM Plex Sans', sans-serif;
    font-weight: bold;
    width: 100%;
    margin-top: 20px;
    //z-index: 2;
}


.article-icon-container {
  width: 255px;
  height: 255px;
  border-radius: 50px;
  animation-timing-function: ease-in-out;
  margin-top: 60px;
  position: relative;
  overflow: hidden;
  z-index: 10;
  left: -5px;
  cursor: pointer;
}

.article-icon {
  margin: 0 auto;
  width: 250px;
  height: 250px;
  border-radius: 50px;
  top: 2px;
  position: relative;
  overflow: hidden;
}

.article-title-name {
    font-weight: bold;
    text-align: left;
}

.article-title-description {
  font-weight: lighter;
  text-align: left;
  position: relative;
}

/** Responsive Article Titles */
@media screen and (min-width: 701px) {
  .article-title-name {
    font-size: 120px;
  }

  .article-title-description {
    font-size: 40px;
    top: -30px;
    padding-left: 7px;
  }
}

@media screen and (max-width: 700px) {
  .publication-header {

  }
  .article-title-name {
    font-size: 60px;
    padding-left: 7px;
  }

  .article-title-description {
    font-size: 25px;
    top: -12px;
    padding-left: 10px;
  }

  .article-meta-date {
    font-size: 18px !important;
  }

  .article-meta-object {
    margin-right: 10px !important;
  }

  .article-icon-container {
    margin-left: 5px;
    margin-top: 135px !important;
  }

  .publication-name {
    font-size: 120px !important;
    left: 0%;
    top: 75% !important;
  }

  .publication-entry {
    font-size: 15px !important;
  }

  body[header-fixed=true] .publication-name {
    font-size: 80px !important;
    top: 50% !important;
  }

  body[header-fixed=false] .publication-name {
    font-size: 120px !important;
    top: 75% !important;
  }

  /** @experiment: centering
  .article-title-name {
    padding-left: 0px !important;
    text-align: center;
  }

  .article-title-description {
    padding-left: 0px !important;
    text-align: center;
  }

  .article-icon-container {
    margin: 0 auto;
    margin-top: 25px;
  }
  .article-header {
    padding-left: 0px !important;
    margin-left: -20px !important;
  }

  .article-metadata {
    padding-left: 0px !important;
    text-align: center !important;
  }

  .article-meta-object {
    text-align: left;
  }
   end @experiment */

  .infograph-block-numeric {
    width: 32% !important;
  }

  .infograph-numeric-value {
    font-size: 50px !important;
  }

  .infograph-numeric-label {
    font-size: 11px !important;
  }
}

.article-body {
  width: 100%;
  padding-top: 25px;
}

.article-body-object {
  width: 100%;
  max-width: 700px;
  margin: 0 auto;
  position: relative;
  font-family: "IBM Plex Sans", serif;
}

.article-content {
    width: 100%;
    max-width: 700px;
    margin: 0 auto;
    position: relative;
    font-family: "IBM Plex Sans", serif;
}

.paragraph {
    font-family: "IBM Plex Sans";
    font-size: 24px;
    padding: 20px;
    font-weight: 300;
}

.article-metadata {
  text-align: left;
  position: relative;
  top: 20px;
  min-height: 120px;
  padding-left: 10px;
  display: block;
}

.article-meta-object {
  display: inline-block;
  vertical-align: top;
  height: 100px;
  margin-right: 50px;
}

.article-meta-object:last-child {
  margin-right: 0px;
}

.paragraph-body {
  margin-bottom: 20px;
}

.paragraph-note {
  font-size: 18px;
}

.paragraph-note-header {
  font-size: 14px;
  font-weight: 600;
}

.article-meta-object:last-child {
   margin-right: 0px;
}

.article-metadata div {
}

.article-meta-header {
  margin-bottom: 5px;
}

.article-meta-author {
  font-weight: 600;
  font-weight: light;
}

.article-meta-author:hover {
  cursor: pointer;
}

.article-meta-date {
  font-weight: lighter;
  font-size: 20px;
}

.article-meta-authors {
}

.paragraph-header {
  font-weight: bold;
  font-size: 16px;
  margin-bottom: 10px;
}

.abstract {
  font-size: 32px;
  font-weight: light;
}

.link {
  cursor: pointer;
}

.link sup {
  font-size: 12px;
  font-style: normal;
}

citation {
  cursor: pointer;
}

citation sup {
  font-size: 12px;
  font-style: normal;
}

.paragraph-opener {
    font-size: 20px;
}

.paragraph-opener the {
    font-size: 22px;
}

.emphasis {
    font-weight: 500;
}

/** Infograph  */

.infograph {
  margin-top: 20px;
  text-align: center;
}

.infograph-hidden {
  display: none;
}

.infograph-block {
}

.infograph-block-numeric {
  width: 215px;
  margin-left: auto;
  margin-right: auto;
  text-align: left;
  display: inline-block;
}

.infograph-numeric-value {
  font-size: 70px;
  font-weight: 300;
}

.infograph-numeric-label {
  font-weight: 600;
  position: relative;
  top: -7px;
  left: 5px;
  font-size: 14px;
}

.infograph-toggle {
  text-align: center;
  margin-top: 40px;

  -moz-user-select: none;
  -webkit-user-select: none;
  -ms-user-select: none;
  user-select: none;
}

.infograph-toggle-active {
}

.infograph-toggle-option:hover {
}

.infograph-toggle-option {
  cursor: pointer;
  text-align: left;
  padding-bottom: 5px;
  width: 30%;
  margin-right: 3%;
  display: inline-block;
  font-weight: 600;
  border-bottom: 2px solid gray;
  font-size: 20px;
}

.infograph-toggle-option:last-child {
  margin-right: 0px;
}

.infograph-chart {
    border-width: 2px;
    border-style: solid;
    margin-top: 20px;
    border-radius: 10px;
    width: 100%;
    position: relative;
    left: 0px;
}

.infograph-performance-name {
    text-align: left;
    float: left;
    font-weight: 500;
    position: relative;
    top: 5px;
}

.infograph-block-performance {
    display: block;
    height: 50px;
    margin-top: 30px;
    min-width: 40%;
    width: 0%;
}

.infograph-performance-value {
    float: right;
    position: relative;
    top: 3px;
    font-size: 24px;
    font-weight: 200;
}

.infograph-performance-value span {
}

.infograph-performance-visual {
  height: 6px;
  width: auto;
  border-radius: 2px;
  position: relative;
}

.infograph-visual-highlighted {
}

.infograph-toggle-performance {
  font-size: 0px;
}

.infograph-toggle-performance .infograph-toggle-option {
  width: 20%;
  font-weight: 200;
  font-size: 25px;
  border-bottom-width: 1px;
  margin-left: 0px;
  margin-right: 0px;
  padding-left: 0px;
  padding-right: 0px;
  left: 0px;
  right: 0px;
}

.infograph-toggle-performance .infograph-toggle-active {
  border-bottom-width: 1px;
  font-weight: 400;
}

.infograph-toggle-option label {
  padding-left: 12px;
  cursor: pointer;
}

.infograph-toggle-option:first-child label {
  padding-left: 0px;
}

.infograph-toggle-active label {
}


.infograph-toggle-label {
  width: auto;
  font-size: 14px;
  font-weight: 600;
  text-align: left;
  margin-top: 5px;
  margin-bottom: 10px;
}

.guided-tour {
  width: 102%;
  position: relative;
  left: -10px;
  font-size: 0px;
}

.guided-tour-visual {
  width: inherit;
  height: inherit;
}

.guided-tour-annotation {
  font-weight: 400;
}

.guided-tour-glossary-item {
  font-weight: 500;
  font-size: 22px;
  cursor: pointer;
  color: gray;
  margin-top: 1px;

  -moz-user-select: none;
  -webkit-user-select: none;
  -ms-user-select: none;
  user-select: none;
}

.guided-tour-glossary-item:hover {
  color: rgb(90,90,90);
}

/** Publication */
.publication-header {
  --publication-secondary-color: rgb(60,60,60);
  --publication-primary-color: white;
  --publication-border-color: rgb(230,230,230);
  --publication-header-color: black;
  --publication-header-background: rgb(250,250,250);
  box-sizing: border-box;
  font-family: "IBM Plex Sans", sans-serif;
  padding-top: 0px;
  height: 100px;
  padding-left: 0px;
  position: relative;
  display: block;
  margin-bottom: -30px;
  border-top: 7.5px solid var(--publication-border-color);
  border-bottom-width: 0px;
  border-bottom-style: solid;
  border-bottom-color: var(--publication-border-color);
  background: transparent; //var(--publication-header-background);
  z-index: 100;
  position: absolute;
  top: 0px;
  width: 100%;
  perspective: 0px;
  transform: translateY(0px);
  transform-style: flat;
  transition: 0.4s transform ease;
}

.article-icon-container {
  margin-top: 137.5px;
}

.publication-header-body {
  margin: 0 auto;
  box-sizing: border-box;
  max-width: 700px;
  font-size: 0px;
  position: relative;
  left: 0px;
  top: 0px;
  height: 100%;
}

.publication-header-title {
  position: absolute;
  left: 17.5px;
  height: 100%;
}

.publication-header-items {
  position: absolute;
  right: 10px;
  height: 100%;
  margin-top: 4px;
}

.publication-name {
  font-size: 140px;
  font-family: "Ink", "Baskerville";
  width: auto;
  height: auto;
  position: absolute;
  top: 70%;
  transform: translate(0%, -50%);
  margin-top: -0.11em;
  display: inline-block;
  padding-right: 10px;
  padding-left: 0px;
  color: transparent;
  vertical-align: top;
  color: var(--publication-header-color);
  cursor: pointer;
  // background-clip: text;
  // -webkit-background-clip: text;
  //display: none;
  opacity: 0.8;
}

.publication-name:hover {
  opacity: 1.0 !important;
}


body[header-fixed=true] .publication-name {
  font-size: 100px;
  top: 50%;
  opacity: 0.8;
}

body[header-fixed=true] .publication-header-items {
  margin-top: 0px;
}

body[header-fixed=false] .publication-name {
  font-size: 140px;
  top: 70%;
  opacity: 0.8;
}

body[header-fixed=false] .publication-header-items {
  margin-top: 4px;
}

body[header-fixed=true] .publication-header {
  position: fixed;
  border-top-width: 0px;
  border-bottom-width: 1px;
  // box-shadow: 0px 0px 40px rgba(0,0,0,0.1);
  background: var(--publication-header-background);
}

body[header-fixed=false] .publication-header {
  position: absolute;
  border-bottom-width: 0px;
  background: transparent;
  transition: none;
}

body[header-active=true] .publication-header {
  transform: translateY(0px);
}

body[header-active=false] .publication-header {
  transform: translateY(-121px);
}

.publication-entries {
  position: relative;
  display: inline-block;
  vertical-align: top;
  height: 100%;
}

.publication-entry {
  display: inline-block;
  width: auto;
  font-size: 16px;
  vertical-align: top;
  position: relative;
  top: 50%;
  transform: translate(0%, -50%);
  font-weight: 600;
  height: 101%;
  padding: 0px 0.5em;
  text-align: center;
  border-top-width: 0px;
  border-top-style: solid;
  border-top-color: transparent;
  color: var(--publication-secondary-color);
  cursor: pointer;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  opacity: 0.5;
}

.publication-entry-active {
  border-top-color: var(--publication-secondary-color);
  opacity: 1.0;

}

.publication-entry:hover {
  opacity: 1.0;
}
