@charset "UTF-8";
a, h1 a, h2 a, h3 a, h4 a, h5 a, h6 a {
  text-decoration: none;
  color: #D73032;
}

body {
  border-top: 4px solid #D73032;
  margin: 0 6%;
  font-family: "Catamaran", sans-serif;
}

@media (min-width: 1136px) {
  body {
    width: 1000px;
    margin: 0 auto;
  }
}
h1, h2, h3, h4, h5, h6 {
  font-family: "Catamaran", sans-serif;
}

.is-muted a:hover {
  text-decoration: underline;
}

.red {
  color: #D73032;
}

.red-bg {
  background: #D73032;
}

.absolute {
  position: absolute;
}

.flex-spacer {
  flex-grow: 1;
}

.white {
  color: white;
}

.text-black {
  color: #313439;
}

.lightred-bg {
  background: #fff5f5;
}

.uppercase {
  text-transform: uppercase;
}

.font-narrow {
  font-family: "Barlow Semi Condensed", sans-serif;
}

.subnav {
  font-family: "Barlow Semi Condensed", sans-serif;
}

.section {
  padding: 20px 20px 0 20px;
}

.section.title-link {
  padding-bottom: 0;
}

#nav-toggle-box {
  display: flex;
  align-items: center;
  padding: 8px 4px;
}

#hero-image {
  background-image: url(/images/www-hero.jpg);
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center center;
  height: 200px;
}

@media (max-width: 768px) {
  .skinny-padding {
    padding-left: 16px;
    padding-right: 16px;
  }
}
.title {
  padding: 12px;
  font-size: 18px;
  line-height: 24px;
  font-weight: lighter;
  margin-bottom: 0;
}

#top {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  padding-top: 16px;
  padding-bottom: 16px;
}

#nav {
  margin-left: 14px;
}
#nav li {
  display: inline-block;
  margin-left: 20px;
  margin-start: 20px;
}
#nav a {
  display: inline-block;
}
#nav ul {
  margin: 0;
}

table.calendar {
  margin-left: 4px;
}

table.calendar * th.time-cell {
  height: 40px;
  padding: 0;
  text-align: right;
}

table.calendar * td.show-cell {
  vertical-align: top;
}

table.calendar * td.on-air {
  border: 2px solid red;
}

div.show-info {
  line-height: 14px;
  font-size: 12px;
}

table.calendar * th.time-header {
  width: 40px;
}

table.calendar * td, table.calendar * th {
  text-align: center;
  border: solid 1px rgb(142, 142, 142);
  position: relative;
  vertical-align: middle;
}

table.calendar * th {
  padding: 0;
  padding-top: 0.4rem;
  padding-bottom: 0.4rem;
}

td.open-shift {
  background-color: lightgray;
}

.calendar-padded {
  padding-top: 0.8rem;
  padding-bottom: 0.4rem;
  padding-left: 0.2rem;
  padding-right: 0.2rem;
  font-size: 14px;
  font-weight: 700;
  line-height: 16px;
  overflow-x: hidden;
}

.calendar-summary {
  overflow-y: hidden;
  height: 70px;
}

table.calendar * td {
  padding: 0;
}

table.playlist * td, table.playlist * th {
  padding: 0.8rem;
}

table.playlist td:first-child {
  padding-left: 0.8rem;
}

.program-show {
  width: 100%;
  height: 100%;
}

@media (max-width: 768px) {
  body {
    margin: 0;
  }
  ul.subnav li {
    text-align: center;
    border: none;
    display: inline-block;
    padding: 0 6px 0 6px;
  }
  .subnav {
    padding: 0 16px 0 16px;
  }
  ul.subnav {
    text-align: center;
  }
}
@media (min-width: 768px) {
  .archive-date {
    text-align: right;
  }
  table.calendar {
    table-layout: fixed;
  }
}
#listen-live-but {
  background: #D73032;
  border: none;
  box-shadow: 1px 1px 2px rgba(0, 0, 0, 0.25);
  color: white;
  cursor: pointer;
  font-size: 16px;
  font-family: "Catamaran", sans-serif;
  margin-top: 20px;
  padding: 10px;
  width: 100%;
  transition: box-shadow 0.25s ease-in-out;
}

#listen-live-but:hover {
  box-shadow: 1px 1px 2px rgba(0, 0, 0, 0.25), 0 0 8px rgba(0, 0, 0, 0.75) inset;
}

#listen {
  line-height: 1.25;
  background: #fff5f5;
}

.listen-content {
  padding: 20px;
}

.player-link {
  color: black;
  display: inline-block;
  width: 100%;
}

.firebunker-callout {
  background: black;
  color: white;
  margin-top: 20px;
  padding-bottom: 20px;
  text-align: center;
}
.firebunker-callout div {
  opacity: 0.55;
}

#homepage-specials .event-hero {
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center center;
  text-align: center;
  min-height: 260px;
}
#homepage-specials .event h2 {
  font-family: "Barlow Semi Condensed", sans-serif;
  font-weight: 300;
  font-size: 28px;
  margin-bottom: 8px;
}
#homepage-specials .event:hover h2,
#homepage-specials .event:hover .event-date {
  color: #f03c69;
}
#homepage-specials .event {
  border-bottom: solid 2px #0d0d0e;
  margin-bottom: 28px;
}
#homepage-specials .event-date {
  margin-top: 8px;
}

#homepage-leftcol {
  padding-top: 20px;
}

#onair-title {
  font-size: 14px;
  margin-bottom: 10px;
  text-transform: uppercase;
  width: 100%;
}

.onair-primary {
  font-size: 20px;
}

.onair-secondary {
  font-size: 16px;
}

.wp-post {
  margin-bottom: 48px;
}

.livecam-container {
  position: relative;
  width: 100%;
  height: 400px;
}

.livecam {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.bf-event-info {
  margin-bottom: 2px;
}

.fr-pitch {
  margin-bottom: 24px;
}

.button {
  color: #fff;
  background-color: #d73032;
}
.button:hover {
  color: #fff;
  background-color: #df5b5c;
}
.button:disabled, .button.is-disabled {
  color: #fff;
  background-color: rgba(17, 17, 19, 0.5);
}
.button.is-secondary {
  background: none;
  border: 2px solid #d73032;
  color: #d73032;
}
.button.is-secondary:hover {
  color: rgba(255, 255, 255, 0.95);
  background-color: #d73032;
  border-color: #d73032;
}
.button.is-secondary:disabled, .button.is-secondary.is-disabled {
  color: rgba(17, 17, 19, 0.5);
  border-color: rgba(17, 17, 19, 0.3);
}
.button.is-secondary:disabled:hover, .button.is-secondary.is-disabled:hover {
  background-color: transparent;
}
.button.is-secondary.is-loading:hover:before {
  border-color: rgba(255, 255, 255, 0.25);
  border-bottom-color: #fff;
}
.button.is-tertiary {
  background: none;
  color: #d73032;
}
.button.is-tertiary:hover {
  color: #d73032;
}
.button.is-tertiary:disabled, .button.is-tertiary.is-disabled {
  text-decoration: none;
  color: rgba(17, 17, 19, 0.5);
}
.button.is-secondary.is-loading:before, .button.is-tertiary.is-loading:before {
  border-color: rgba(215, 48, 50, 0.25);
  border-bottom-color: #d73032;
}

.album-thumb {
  position: absolute;
  height: 100%;
  width: 100%;
  object-fit: cover;
}

.sq {
  width: 100%;
  position: relative;
}

.sq:after {
  content: "";
  display: block;
  padding-bottom: 100%;
}

.stripes-lightgrey-24 {
  background-color: lightgrey;
  background-image: repeating-linear-gradient(45deg, transparent, transparent 12px, rgba(255, 255, 255, 0.5) 12px, rgba(255, 255, 255, 0.5) 24px);
}

table.skinny-table tbody td, table.skinny-table tbody th {
  padding: 8px;
}

table.no-border td, table.no-border th {
  border-bottom: 0px;
}

th.minWidth, td.minWidth {
  width: 1%;
  white-space: nowrap;
}

td span.editableCell {
  display: block;
}

td.hasEditableChild {
  cursor: text;
}

.align-top {
  vertical-align: top;
}

div.event-summary {
  padding-bottom: 0.19rem;
}
div.event-summary p:empty {
  display: none;
}
div.event-summary p:last-of-type {
  margin-bottom: 0;
}
div.event-summary .livecam-link {
  display: block;
  width: max-content;
  margin-top: 0.2rem;
}

h1 a.event-link {
  display: inline-block;
  vertical-align: middle;
  font-size: 65%;
  transition: filter 0.25s ease-in-out;
}

h1 a.event-link:hover {
  filter: saturate(230%);
}

a.permalink {
  color: inherit;
}

a.permalink:hover:after {
  content: "🔗";
  font-size: 60%;
  filter: contrast(0%) saturate(230%);
  display: inline-block;
  overflow: visible;
  width: 0;
  margin-left: 0.25em;
  margin-right: -0.25em;
}

#dj-banner {
  display: flex;
  justify-content: space-between;
  padding: 0 0.5rem 0 0.2rem;
}
#dj-banner span {
  flex-basis: fit-content;
}
#dj-banner span a {
  color: #fff;
}
#dj-banner span a:hover {
  text-decoration: underline;
}

/* Two column list on dj & program info pages. */
.playlist-archive {
  display: flex;
  flex-direction: column;
  margin-top: 1em;
}
.playlist-archive .row {
  display: flex;
  align-items: center;
  margin-bottom: 0.8rem;
  min-height: 2.2rem;
}
.playlist-archive .row .col-left {
  width: 14.5rem;
  flex-shrink: 0;
}
.playlist-archive .row .col-left p {
  margin: 0;
}
.playlist-archive .row .col-right {
  flex: 1;
}
.playlist-archive .row .col-right p {
  margin: 0;
}