.site-header {
  margin-top: 50px;
  margin-bottom: 50px;
}

.site-header h1 {
  font-size: 26px;
  margin: 0;
  text-align: center;
  flex: 1 1;
}

.site-header h1 a {
    display: block;
    text-decoration: none;
  }

.site-header h1 a img {
      display: block;
      width: auto;
      max-height: 144px;
      max-width: 155px;
      margin: 0 auto;
      border: 0;
    }

.site-header nav {
  display: flex;
  align-items: center;
  margin: 0 -14px;
}

.site-header nav > .group {
    flex: none;
    width: 300px;
  }

.site-header nav > .group a {
      text-decoration: none;
      text-transform: uppercase;
      letter-spacing: 0em;
      font-size: 16px;
      padding: 0 0 3px 0;
      margin: 0 14px;
      font-weight: bold;
    }

.site-header nav > .group a:hover {
        border-bottom: 2px solid #222;
        padding-bottom: 1px;
      }

.site-header nav > .group:last-child {
    text-align: right;
  }

.site-header.floating-nav h1 {
  flex: none;
  margin-right: 8px;
}

.site-header.floating-nav nav {
  margin-left: 0;
}

.site-header.floating-nav nav .group {
  flex: 1 1;
}

.site-header.floating-nav nav .group:last-child {
  text-align: left;
  margin-left: 14px;
}

.site-social {
  text-align: center;
  padding-top: 25px;
  margin: 50px 0;
}

.site-social a {
  display: inline-block;
  height: 24px;
  width: 24px;
  margin: 0px 10px;
  text-decoration: none;
  color: #222;
}

.site-social a svg {
  fill: currentColor;
  width: 24px;
  height: auto;
}

.site-subscribe {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  margin: 0 auto;
  max-width: 800px;
}

.site-subscribe a {
  display: flex;
  align-items: center;
  line-height: 14px;
  border: 1px solid #222;
  border-radius: 4px;
  padding: 8px 12px;
  text-decoration: none;
  font-size: 10px;
  margin: 0 6px 15px 6px;
  transition: transform 0.1s ease-in-out;
}

.site-subscribe a:hover {
    transform: translateY(-3px);
  }

.site-subscribe a svg {
  flex-shrink: 0;
  fill: currentColor;
  height: 26px;
  width: auto;
  margin-right: 8px;
}

.site-subscribe a label {
  cursor: pointer;
}

.site-subscribe a span {
  display: block;
  letter-spacing: 1px;
  line-height: 11px;
  margin-bottom: 1px;
  text-transform: uppercase;
  color: #111;
  opacity: 0.65;
}

.site-subscribe a b {
  display: block;
  letter-spacing: 0;
  text-transform: capitalize;
  font-size: 16px;
  color: #111;
  font-weight: 600;
}

.site-subscribe a.apple_podcasts svg {
  margin-right: 10px;
}

.site-subscribe a.tuneIn svg {
  width: 26px;
  height: auto;
}

.site-subscribe a.soundcloud svg {
  width: 26px;
  height: auto;
}

.site-subscribe a.iHeartRadio svg {
  width: 26px;
  height: auto;
}

.site-subscribe a.deezer svg {
  width: 26px;
  height: auto;
}

.site-subscribe a.youtube svg {
  width: 26px;
  height: auto;
}

.site-subscribe a.goodpods svg {
  width: 26px;
  height: auto;
}

.site-episode {
  margin-bottom: 50px;
}

.site-episode-intro-container {
  word-break: break-word;
  overflow-wrap: break-word;
  word-wrap: break-word;
  display: flex;
}

.site-episode-intro-container .site-episode-artwork {
  order: 9999;
  width: 140px;
  height: 140px;
  flex-shrink: 0;
  margin-left: 1em;
  margin-top: 0.25em;
}

.site-episode-intro {
  flex-grow: 1;
}

.episodes .site-episode-intro-container .site-episode-artwork {
  width: 100px;
  height: 100px;
}

.site-episode time {
  font-size: 14px;
  border-top: 2px solid #222;
  display: block;
  margin-bottom: 16px;
}

.site-episode time span {
  background: #222;
  color: #fff;
  font-size: 16px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  padding: 4px 8px;
  display: inline-block;
}

.site-episode h2 a {
    text-decoration: none;
  }

.site-episode h2 a:hover {
      text-decoration: underline;
    }

.site-episode h2 {

  margin: 0.20em 0;
  line-height: 1.25em;
  font-size: 32px;
}

.site-episode .site-episode-nav {
  margin: 1.75em 0 .75em 0;

}

.site-episode .site-episode-nav a {
    text-decoration: none;
  }

.site-episode .site-episode-nav a:hover {
      text-decoration: underline;
    }

.site-episode .site-episode-nav a.active {
      font-weight: bold;
    }

body.transcript .site-episode .site-episode-nav .site-episode-transcript-link,
body.episode .site-episode .site-episode-nav .site-episode-notes-link {
  font-weight: bold;
}

.site-episode .site-episode-summary {
  margin: .75em 0 1em 0;
}

.site-episode .site-button {
  margin-right: 8px;
}

.site-featured-episodes {
  background: #222;
  color: #fff;
  padding: 50px 0;
}

.site-featured-episodes .site-container {
  padding: 0;
  display: flex;
}

.site-featured-episodes .site-episode {
  margin-bottom: 0;
  padding: 0 15px;
  flex: 1;
}

.site-featured-episodes .site-episode .site-episode-artwork {
  display: none;
}

.site-featured-episodes .site-episode .site-episode-summary {
  font-size: 18px;
}

.site-featured-episodes .site-episode header {
  border-top: 2px solid #fff;
  margin-bottom: 20px;
}

.site-featured-episodes .site-episode header span {
  background: #fff;
  color: #222;
  font-size: 14px;
  font-weight: bold;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  padding: 3px 6px;
  display: inline-block;
}

.site-featured-episodes .site-episode time {
  display: block;
  border: 0;
  margin: 0;
}

.site-featured-episodes .site-episode time span {
  color: #fff;
  font-size: 14px;
  font-weight: bold;
  background: transparent;
  padding: 0;
  display: inline;
}

.site-featured-episodes .site-episode h2 {
  font-size: 26px;
}

.site-featured-episodes .site-episode h2 a {
    color: #fff;
  }

.site-featured-episodes .site-episode .site-button {
  border-color: #fff;
  color: #fff;
  font-size: 14px;
  padding: 4px 8px;
}

.site-featured-episodes .site-episode .site-button:hover {
    background: #fff;
    color: #222;
  }

.site-episode-show-notes {
  word-break: break-word;
  overflow-wrap: break-word;
  word-wrap: break-word;
  margin-top: 40px;
}

.site-episode-show-notes h1 {
    font-size: inherit;
    line-height: inherit;
  }

.site-episode-show-notes div > br:only-child {
    display: none;
  }

.site-episode-show-notes ul + br, .site-episode-show-notes ol + br {
    display: none;
  }

.site-episode-show-notes blockquote {
    border-left: 4px solid #666;
    font-style: italic;
    margin-left: 0;
    padding-left: 1em;
  }

.site-video-embed {
  margin: 2em 0 0 0;
  width: 80%;
  aspect-ratio: 16 / 9;
}

.pagination-info {
  margin-bottom: 2em;
  text-align: center;
  text-transform: uppercase;
  font-weight: 500;
  font-size: 15px;
  letter-spacing: 0.02em;
}

.pagination {
  border-top: 2px solid #222222;
  padding-top: 50px;
  margin: 50px 0 30px 0;
  display: flex;
  justify-content: center;
}

.pagination .page-item.site-button {
    font-weight: 500;
    font-size: 13px;
    padding: 2px 8px;
  }

.pagination .page-item.site-button.prev-page {
      margin-right: 6px;
    }

.pagination .page-item.site-button.next-page {
      margin-left: 6px;
    }

/* Search */

.site-episode-search {
  margin-top: -1rem;
  margin-bottom: 2rem;
  text-align: center;
  margin-left: auto;
  margin-right: auto;
  width: 50%;
}

.site-episode-search-input {
  position: relative;
}

.site-episode-search .site-episode-search-icon {
  align-items: center;
  bottom: 0;
  display: flex;
  left: 0;
  padding-left: 0.5rem;
  pointer-events: none;
  position: absolute;
  top: 0;
}

.site-episode-search .site-episode-search-icon svg {
  fill: currentColor;
  color: #222;
  flex-shrink: 0;
  height: 1.25rem;
  width: 1.25rem;
}

.site-episode-search-input input {
  width: 100%;
  padding: 0.5rem;
  padding-left: 2rem;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Oxygen", "Ubuntu", "Cantarell", "Fira Sans", "Droid Sans", "Helvetica Neue", sans-serif;
  background-color: transparent;
  -webkit-appearance: none;
  border: 2px solid #222;
  color: #222;
  font-size: 16px;
  outline: 0;
}

@media (max-width: 600px) {
  .site-episode-search {
    width: 100%;
    margin-bottom: 1rem;
  }

  .site-video-embed {
    width: 100%;
  }
}

.site-people {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.5em;
}

.site-people .site-person {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  display: flex;
  font-size:  14px;
  align-items: flex-start;
  line-height: 1.4em;
  -moz-column-gap: 0.75rem;
       column-gap: 0.75rem;
}

.site-person .site-person-avatar {
  position: relative;
  width: 96px;
  height: 112px;
  flex-shrink: 0;
}

.site-person .site-person-avatar img {
  border-radius: 100%;
  width: 96px;
  height: 96px;
}

.site-person .site-person-icon svg {
  color: #aaa;
  width: 96px;
  height: 96px;
  fill: currentColor;
}

.site-person-role {
  font-weight: bold;
  line-height: 1;
  color: white;
  background-color: #000;
  border-radius: 9999px;
  padding: 4px 8px;
}

.site-person .site-person-avatar .site-person-role {
  position: absolute;
  bottom:  0.5rem;
  font-size: 10px;
  left: 50%;
  transform: translateX(-50%);
}

.site-person .site-person-details {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  padding-top: 0.5rem;
}

.site-person .site-person-name {
  font-size: 16px;
  font-weight: 600;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.site-person .site-person-name:hover {
  text-decoration: underline;
}

.site-person .site-person-bio {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.site-person-links {
  display: flex;
  align-items: center;
  -moz-column-gap: 0.5rem;
       column-gap: 0.5rem;
  padding-top: 0.25rem;
}

.site-person-links a {
  line-height: 0;
  flex-shrink: 0;
}

.site-person-links a svg {
  fill: currentColor;
  height: 20px;
  width: 20px;
}

.site-episode-people {
  margin-top: 5rem;
  margin-bottom: 5rem;
}

.site-episode-people h3 {
  font-size: 20px;
}

.people .site-people {
  margin: 4rem 0 5rem 0;
}

/* Individual Person Page  */

.site-person-header {
  display: flex;
  align-items: center;
  -moz-column-gap: 1.5rem;
       column-gap: 1.5rem;
  margin-bottom: 3rem;
}

.site-person-header h1 {
  margin-top: 0;
  margin-bottom: 0.4em;
}

.site-person-header .site-person-role {
  font-weight: 600;
  font-size: 18px;
  padding: 6px 14px;
}

.site-person-header .site-person-image {
  border-radius: 100%;
  height: 8rem;
  width: 8rem;
}

.site-person-header .site-person-icon svg {
  height: 8rem;
  width: 8rem;
  fill: currentColor;
  color: #aaa;
}

.site-person-metadata {
  display: flex;
  align-items: center;
  -moz-column-gap: 0.75rem;
       column-gap: 0.75rem;
}

.site-person-metadata .site-person-links {
  padding-top: 0;
}

.site-person-metadata .site-person-links a svg {
  height: 22px;
  width: 22px;
}

.site-person-subheader {
  font-weight: 500;
  font-size: 16px;
  text-transform: uppercase;
  letter-spacing: 0.02em;
}

p.site-person-bio {
  margin-bottom: 3rem;
}

.person .site-episodes {
  margin-bottom: 5rem;
}

@media all and (max-width: 750px) {
  .site-people {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .people .site-people {
    margin: 3rem 0 4rem 0;
  }
  .site-episode-people {
    margin-top: 3rem;
    margin-bottom: 3rem;
  }
  .site-person .site-person-details {
    padding-top: 0;
  }
  .site-person .site-person-avatar {
    width: 78px;
    height: 94px;
  }
  .site-person .site-person-avatar img {
    width: 78px;
    height: 78px;
  }
  .site-person .site-person-icon svg {
    width: 78px;
    height: 78px;
  }
  .site-person-header {
    -moz-column-gap: 1rem;
         column-gap: 1rem;
    margin-bottom: 2rem;
  }
  .site-person-header h1 {
    font-size: 24px;
  }
  .site-person-header .site-person-role {
    font-size: 16px;
    padding: 6px 12px;
  }
  .site-person-header .site-person-image {
    height: 5rem;
    width: 5rem;
  }
  .site-person-header .site-person-icon svg {
    height: 5rem;
    width: 5rem;
  }
  p.site-person-bio {
    margin-bottom: 2rem;
  }
}

@media all and (max-width: 480px) {
  .site-people {
    grid-template-columns: repeat(1, minmax(0, 1fr));
  }

  .people .site-people {
    margin: 2rem 0 3rem 0;
  }
}

.site-supporters-container {
  margin: 4rem 0 5rem 0;
  display: flex;
  gap: 0 1em;
}

.site-supporters {
  order: 1;
  flex-grow: 1;
}

.site-supporters-count {
  font-weight: bold;
  margin-bottom: 0.75rem;
}

.site-supporter {
  line-height: 1em;
  display: flex;
  align-items: center;
  gap: 0 1em;
  margin-bottom: 1em;
}

.site-supporter-image {
  border-radius: 100%;
}

.site-supporter-icon {
}

.site-supporter-icon svg {
  color: #aaa;
  fill: currentColor;
}

.site-supporter-image, .site-supporter-icon, .site-supporter-icon svg {
  width: 70px;
  height: 70px;
}

.site-supporters-campaign {
  order: 2;
  width: 40%;
}

.site-supporters-campaign-name {
  font-weight: bold;
}

.site-supporters-campaign-intro {
  margin: 0.5rem 0 1rem 0;
}

.site-supporters-goal {
  margin-top: 1rem;
}

.site-supporters-goal-progress-text {
  font-size: 16px;
}

.site-supporters-goal-progress {
  margin: 0rem 0 0.5rem 0;
  border: 2px solid #888;
  border-radius: 9999px;
  overflow: hidden;
}

.site-supporters-goal-progress-bar {
  height: 18px;
  background: #888;
  opacity: 0.6;
}

.site-supporters-goal-description {
  margin: 0;
  font-size: 14px;
  line-height: 1.5em;
}

.site-supporters-widget {
  margin: 3em auto 0 auto;
  text-align: center;
}

.site-supporters-widget > a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  -moz-column-gap: 16px;
       column-gap: 16px;
  text-decoration: none;
}

.site-supporters-widget-images {
  display: inline-flex;
  align-items: center;
}

.site-supporters-widget-images img {
  height: 60px;
  width: 60px;
  border-radius: 9999px;
  margin-left: -12px;
  border: 3px solid #fff;
}

.site-supporters-widget span {
  font-weight: 500;
  font-size: 16px;
}

.site-supporters-widget span:hover {
  text-decoration: underline;
}

@media all and (max-width: 750px) {
  .site-supporters-container {
    margin: 2rem 0 4rem 0;
  }
  .site-supporters-count {
    font-size: 16px;
  }
  .site-supporter {
    font-size: 16px;
    gap: 0 0.6em;
  }
  .site-supporter-image, .site-supporter-icon, .site-supporter-icon svg {
    width: 50px;
    height: 50px;
  }
  .site-supporters-campaign-name {
    font-size: 16px;
  }
  .site-supporters-campaign-intro {
    font-size: 14px;
    line-height: 1.5em;
    margin: 0rem 0 0.75rem 0;
  }
  .site-supporters-goal-progress-text {
    font-size: 14px;
  }
  .site-button.site-supporters-campaign-button {
    font-size: 14px;
    padding: 8px 10px;
    line-height: 1.2em;
  }
}

@media all and (max-width: 480px) {
  .site-supporters-container {
    display: block;
    margin: 1rem 0 3rem 0;
  }
  .site-supporter-image, .site-supporter-icon, .site-supporter-icon svg {
    width: 36px;
    height: 36px;
  }
  .site-supporters-campaign {
    border-bottom: 1px solid #888;
    margin-bottom: 1.25rem;
    padding-bottom: 1.25rem;
    width: 100%;
  }
  .site-supporters-goal {
    margin-top: 0.5rem;
  }
  .site-supporters-goal-progress-bar {
    height: 14px;
  }
  .site-supporters-widget {
    margin-top: 2em;
  }
  .site-supporters-widget > a {
    -moz-column-gap: 10px;
         column-gap: 10px;
  }
  .site-supporters-widget-images img {
    height: 46px;
    width: 46px;
  }
}

.site-container.player {
  padding: 15px;
  display: flex;
}

.player button {
  padding: 0;
  appearance: none;
  border: none;
  text-decoration: none;
  background: transparent;
  cursor: pointer;
  -webkit-appearance: none;
  -moz-appearance: none;
}

.playback-controls {
  flex: 0 0 80px;
  display: flex;
  align-items: center;
  margin-top: 5px;
}

.playback-progress {
  padding: 0 14px;
  flex: 1 1 auto;
  font-size: 14px;
  min-width: 0;
}

.currently-playing {
  height: 18px;
}

#title {
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.playback-duration {
  font-size: 80%;
  opacity: 0.7;
}

#timer {
  float: left;
}

#duration {
  float: right;
}

.volume-speed-controls {
  flex: 0 0 60px;
  margin-top: 15px;
}

#volumeBtn {
  cursor: pointer;
  display: inline-block;
  vertical-align: middle;
  height: 16px;
  width: 16px;
  margin: 0 0 0 5px;
}

#volumeBtn svg {
    height: 16px;
    width: 16px;
    fill: currentColor;
  }

#volumeBtn.player-muted .unmuted {
  display: none;
}

#volumeBtn.player-unmuted .muted {
  display: none;
}

#playbackSpeed {
  border: 1px solid #fff;
  border-radius: 3px;
  display: inline-block;
  cursor: pointer;
  font-size: 60%;
  line-height: 1.5em;
  width: 32px;
  text-align: center;
  vertical-align: middle;
  opacity: 0.6;
  transition: opacity 0.15s;
}

#playbackSpeed:hover {
    opacity: 1.0;
  }

#progressBar {
  background: rgba(255,255,255,0.1);
  position: relative;
  display: block;
  width: 100%;
  height: 8px;
  border-radius: 4px;
  cursor: pointer;
  margin: 4px 0;
  overflow: hidden;
}

#progress {
  background: #fff;
  height: 8px;
  display:block;
  position: absolute;
  top: 0;
  left: 0;
  width: 0%;
  border-radius: 4px;
}

.playPause {
  flex: 1;
  position: relative;
  width: 36px;
  height: 36px;
}

#playBtn, #pauseBtn {
  position: absolute;
  top:0;
  left: 0;
  cursor: pointer;
  display: block;
  width: 36px;
  height: 36px;
}

#playBtn svg, #pauseBtn svg {
    width: 36px;
    height: 36px;
    fill: currentColor;
  }

#rewindBtn , #fastForwardBtn {
  flex: 0 0 18px;
  opacity: 0.6;
  cursor: pointer;
  height: 18px;
  width: 18px;
  display: inline-block;
  transition: opacity 0.15s;
}

#rewindBtn svg, #fastForwardBtn svg {
    height: 18px;
    width: 18px;
    fill: currentColor;
  }

#rewindBtn:hover, #fastForwardBtn:hover {
    opacity: 1.0;
  }

#rewindBtn {
  margin-right: 5px;
}

#fastForwardBtn {
  margin-left: 5px;
}

.loader-ring {
  flex: 1;
  position: relative;
  display: inline-block;
  width: 36px;
  height: 36px;
}

.loader-ring:after {
  content: " ";
  display: block;
  width: 35px;
  height: 35px;
  margin: 1px;
  border-radius: 50%;
  border: 3px solid #ffffff;
  border-color: #ffffff transparent #ffffff transparent;
  animation: loader-ring 1.2s linear infinite;
}

@keyframes loader-ring {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}

@media all and (max-width: 480px) {
  #rewindBtn, #fastForwardBtn, #playbackSpeed { display: none; }

  .site-container.player {
    padding: 5px 25px 0 22px;
  }

  .playPause {
    width: 24px;
    height: 24px;
  }

  #playBtn, #pauseBtn {
    cursor: pointer;
    display: block;
    width: 24px;
    height: 24px;
  }

    #playBtn svg, #pauseBtn svg {
      width: 24px;
      height: 24px;
    }

  .playback-controls {
    flex: 0 0 24px;
    display: flex;
    align-items: center;
    margin-top: 0px;
  }

  .loader-ring {
    width: 24px;
    height: 24px;
  }

  .loader-ring:after {
    width: 23px;
    height: 23px;
  }

  .playback-progress {
    padding: 0 4px;
    flex: 1 1 auto;
    font-size: 14px;
    min-width: 0;
  }

  .currently-playing {
    height: 14px;
    font-size: 12px;
  }

  #title {
    display: block;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .volume-speed-controls {
    flex: 0 0 20px;
    margin-top: 12px;
  }
}

/* Alpine JS cloaking */

[x-cloak] { display: none; }

*, *:before, *:after {
  box-sizing: border-box;
}

body {
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Oxygen", "Ubuntu", "Cantarell", "Fira Sans", "Droid Sans", "Helvetica Neue", sans-serif;
  padding: 0;
  margin: 0;
  padding-bottom: 150px;
  background-color: #fff;
}

a {
  color: #222;
}

.preview-notice {
  background: #FCC853;
  color: #0C1824;
  padding: 8px 10px;
  text-align: center;
  width: 100%;
  font-size: 80%;
}

.preview-notice a {
  color: inherit;
  font-weight: bold;
}

.text-centered {
  text-align: center;
}

.site-container {
  max-width: 980px;
  margin: 0 auto;
  padding: 0 15px;
}

.mobile-nav-menu, .mobile-nav {
  display: none;
}

.site-main {
  padding: 0;
  line-height: 1.45em;
  font-size: 20px;
}

.site-content {
  min-height: 400px;
}

.site-intro {
  font-size: 32px;
  line-height: 1.33333em;
  margin-bottom: 50px;
}

.site-no-episodes {
  margin: 3em 0 1em;
}

.site-first-episode {
  text-align: center;
  margin-bottom: 50px;
}

.site-credits {
  font-size: 16px;
  margin: 50px 0;
  text-align: center;
}

.site-button {
  -webkit-appearance: none;
  background-color: transparent;
  border: 2px solid #222;
  font-size: 18px;
  display: inline-block;
  padding: 8px 12px;
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-weight: bold;
  cursor: pointer;
  outline: 0;
}

.site-button:hover {
  background-color: #222;
  color: #fff;
}

.site-mailinglist {
  padding: 50px 0px 0px 0px;
  text-align: center;
}

.site-mailinglist h3 {
  margin: 0 0 10px 0;
}

.site-mailinglist p {
  margin-top: 0;
  max-width: 600px;
  margin-left: auto;
  margin-right: auto;
}

.site-mailinglist .email-input {
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Oxygen", "Ubuntu", "Cantarell", "Fira Sans", "Droid Sans", "Helvetica Neue", sans-serif;
  background-color: transparent;
  -webkit-appearance: none;
  border: 2px solid #222;
  color: #222;
  font-size: 18px;
  display: block;
  margin: 0 auto 10px auto;
  text-align: center;
  width: 360px;
  padding: 8px 12px;
  outline: 0;
}

.site-newsletter-success { display: none; }

.site-newsletter-success svg {
  fill: currentColor;
  flex-shrink: 0;
  height: 24px;
  width: 24px;
  color: #222;
  margin-right: 8px;
}

#site-newsletter-form { height: 100px; }

#site-newsletter-form.subscribed {
  display: none;
}

#site-newsletter-form.subscribed + .site-newsletter-success {
  text-align: center;
  display: inline-flex;
  align-items: center;
  height: 100px;
  line-height: 100px;
}

#site-footer {
  background: #222;
  color: #fff;
  position: fixed;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 105px;
}

.site-powered-by {
  display: block;
  position: absolute;
  bottom: 0;
  right: 0;
  padding: 5px 15px;
  font-size: 7px;
  line-height: 20px;
  text-transform: uppercase;
  opacity: 0.55;
  transition: opacity 0.2s;
}

.site-powered-by span {
  font-weight: normal;
  vertical-align: middle;
  display: inline-block;
  position: relative;
  top: 1px;
}

.site-powered-by a {
  color: white;
  display: inline-block;
  text-decoration: none;
}

.site-powered-by svg {
  display: inline-block;
  vertical-align: middle;
  height: 18px;
  margin-left: 5px;
}

.site-powered-by:hover {
  opacity: 1.0;
}

/* Responsive elements */

@keyframes fadeIn {
  0% { opacity: 0; }
  20% { opacity: 0; }
  40% { opacity: 0.3; }
  60% { opacity: 0.5; }
  80% { opacity: 0.9; }
  100% { opacity: 1; }
}

@media all and (max-width: 750px) {
  .site-header {
    margin-top: 30px;
    margin-bottom: 30px;
  }

  .site-header h1 {
    order: 1;
    text-align: left;
    flex-grow: 1;
    flex-shrink: 0;
    flex: 1 1 auto;
    width: 100%;
    margin-bottom: 20px;
  }
      .site-header h1 a img {
        margin: 0;
      }

  .site-header nav {
    flex-wrap: wrap;
    margin: 0;
  }

    .site-header nav > .group {
      width: auto;
      order: 2;
    }

      .site-header nav > .group a {
        margin-left: 0;
      }

  .site-header.floating-nav nav .group:last-child {
    text-align: left;
    margin: 0;
  }
}

@media all and (max-width: 480px) {
  body {
    padding-bottom: 100px;
    position: relative;
  }

    body.noscroll {
      overflow: hidden;
    }

  .mobile-nav-menu {
    display: block;
    position: absolute;
    top: 0;
    right: 15px;
    cursor: pointer;
    height: 25px;
    width: 30px;
    text-align: center;
  }

    .mobile-nav-menu svg {
      fill: currentColor;
      height: 25px;
      width: 25px;
    }

  .mobile-nav {
    z-index: 2;
    position: fixed;
    display: none;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    overflow-x: hidden;
    background: #222;
    color: #fff;
  }

    .mobile-nav.open {
      display: block;
    }

    .mobile-nav .mobile-nav-close {
      cursor: pointer;
      position: absolute;
      right: 15px;
      top: 28px;
      height: 25px;
      width: 30px;
      text-align: center;
    }

      .mobile-nav .mobile-nav-close svg {
        fill: currentColor;
        height: 25px;
        width: 25px;
      }

    .mobile-nav .mobile-nav-content {
      padding: 50px 0;
      text-align: center;
    }

      .mobile-nav .mobile-nav-content a {
        padding: 20px 0;
        display: block;
        color: #fff;
        text-decoration: none;
        letter-spacing: 0.05em;
        font-weight: bold;
        text-transform: uppercase;
        margin: 30px 0;
        font-size: 32px;
      }
      .mobile-nav .mobile-nav-content.mobile-nav-compact a {
        padding: 16px 0;
        margin: 14px 0;
        font-size: 26px;
      }

  .site-container {
    padding: 0 25px;
  }

  .site-header {
    margin-top: 30px;
    margin-bottom: 10px;
  }

  .site-header h1 {
    font-size: 22px;
    margin: 0 0 10px 0;
    order: 0;
    flex: none;
    width: 90%;
    text-align: left;
  }

    .site-header h1 a {
      display: block;
      text-decoration: none;
    }

      .site-header h1 a img {
        display: block;
        width: auto;
        max-height: 100px;
        max-width: 110px;
        margin: 0px;
        border: 0;
      }

  .site-header nav {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    margin: 0px;
  }

    .site-header nav > .group {
      display: none;
    }

  .site-intro {
    font-size: 20px;
    line-height: 1.33333em;
    margin-bottom: 20px;
  }

  .site-first-episode {
    margin-bottom: 28px;
  }

  .site-button {
    font-size: 11px;
    padding: 3px 6px;
  }

  .site-content {
    min-height: auto;
  }

  .site-episode time {
    font-size: 12px;
    margin-bottom: 12px;
  }

  .site-episode time span {
    font-size: 13px;
  }

  .site-episode h2 {
    margin: 0.15em 0;
    line-height: 1.1em;
    font-size: 20px;
  }

  .site-episode .site-episode-summary {
    margin: .5em 0 .6666em 0;
    font-size: 18px;
  }

  .site-episode-intro-container .site-episode-artwork {
    width: 70px;
    height: 70px;
    flex-shrink: 0;
    margin-left: 1em;
  }

  .episode .site-episode-intro-container, .transcript .site-episode-intro-container, .episodes .site-episode-intro-container  {
    display: block;
  }

  .episode .site-episode-intro-container .site-episode-artwork {
    margin-left: 0;
    width: 90px;
    height: 90px;
  }

  .episodes .site-episode-intro-container .site-episode-artwork {
    width: 70px;
    height: 70px;
    float: right;
  }

  .site-episode-show-notes {
    font-size: 16px;
    line-height: 1.5em;
    margin-top: 20px;
  }

    .site-episode-show-notes ul, .site-episode-show-notes ol {
      padding-left: 20px;
    }

  .site-episode .site-button {
    margin-right: 5px;
  }

  .site-episode {
    margin-bottom: 30px;
  }

  .site-featured-episodes {
    padding: 0 0 20px 0;
  }

  .site-featured-episodes .site-container {
    display: block;
  }

  .site-featured-episodes .site-episode {
    margin-top: 0;
    margin-bottom: 0;
    flex: none;
    padding: 30px 25px 15px 25px;
  }

    .site-featured-episodes .site-episode h2 {
      font-size: 20px
    }

  .site-credits {
    margin: 20px 0;
  }
  .site-social {
    padding-top: 25px;
    margin: 20px 0;
  }

  .site-social a {
    height: 20px;
    width: 20px;
    margin: 0px 4px;
  }

  .site-social a svg {
    width: 20px;
  }

  .site-mailinglist .email-input {
    width: 85%;
  }

  .site-subscribe {
    flex-wrap: wrap;
  }

  .site-subscribe a {
    margin-left: auto;
    margin-right: auto;
    width: 70%;
  }

  #site-footer {
    padding-top: 5px;
    height: 75px;
  }

  .site-powered-by {
    text-align: center;
    display: block;
    position: relative;
    padding: 0;
    margin: 0 auto;
    top: -5px;
    transform: scale(0.9);
  }

  .pagination-info {
    margin-bottom: 1em;
    text-align: left;
    font-size: 12px;
    letter-spacing: 0;
  }

  .pagination {
    padding-top: 30px;
    margin: 30px 0 30px 0;
  }

    .pagination .page-item.site-button {
      font-size: 11px;
      padding: 1px 8px;
    }

}
