
a,
a:hover {
  color: #ed1c24;
}

section {
  margin: 2em auto;
}

.header .arrow {
  float: right;
  font-size: 1.5em;
  opacity: 0.5;
}

.main {
  overflow-x: hidden;
}

.category {
  margin-bottom: 2em;
}

.subcategory {
  width: 100%;
}

.items {
  margin-top: -1px;
}

.item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  border-top: 1px solid rgba(0, 0, 0, 0.05);
  padding: 2em 2.5em;
  user-select: none;
}

.item .thumbnail {
  width: 125px;
  margin-right: 3em;
  text-align: center;
}

.item .thumbnail img {
  width: auto;
  height: auto;
  max-width: 100%;
  max-height: 175px;
}

.item .text {
  width: calc(100% - 150px);
}

.item .text.full {
  width: 100%;
}

.item .title {
  font-weight: bold;
}

.item .official,
.intro .dashicons-yes,
.settings .dashicons-yes {
  position: relative;
  display: inline-block;
  width: 16px;
  height: 16px;
  padding-right: 10px;
  margin-top: 1px;
  background-color: #ed1c24;
  border-radius: 50%;
  color: #fff;
  font-size: 15px;
  line-height: 1.2;
}

.intro.shorten .official {
  display: none;
}

.settings .dashicons-yes {
  margin-right: 3px;
  background-color: #383838;
  color: #e9e9ee;
}

.settings .button.active .dashicons-yes {
  background-color: #fff;
  color: #ed1c24;
}

.filters .button .badge {
  position: relative;
  top: 0;
  right: 0;
  background-color: rgba(0.91, 0.91, 0.93, 0.05);
  background-color: rgba(0, 0, 0, 0.1);
  padding: 0 0.5em;
  margin-left: 4px;
  color: #383838;
  text-align: center;
}

.filters .button.active .badge {
  background-color: rgba(255, 255, 255, 1);
  color: #ed1c24;
}

.tooltip::after {
  content: attr(data-tooltip);
  font-size: 12px;
  position: absolute;
  bottom: 0%;
  left: -95px;
  display: inline-block;
  width: 250px;
  padding: 7px 5px;
  border-radius: 5px;
  background: #eee;
  color: #333;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  opacity: 0;
  -webkit-transition: 0.3s;
  -o-transition: 0.3s;
  transition: 0.3s;
  overflow: hidden;
  pointer-events: none;
  z-index: 10;
}

.tooltip:hover::after {
  opacity: 1;
  bottom: 100%;
}

.item .official {
  position: absolute;
  bottom: 3px;
  margin-top: 0;
  margin-left: 4px;
}

.item.prohibited {
  padding: 1em;
}

.item.prohibited .title {
  color: #dc3e47;
}

.item.prohibited ul {
  margin: 1em;
}

.item.prohibited p {
  margin-top: 0;
}

.item .name {
  font-size: 1.2em;
  font-weight: bold;
  line-height: 1.2;
}

.item .note {
  font-size: 13px;
}

.thumbnail,
.text > div:not(.buttons) {
  -webkit-transition: opacity 0.2s;
  -o-transition: opacity 0.2s;
  transition: opacity 0.2s;
}

.completed.item .thumbnail {
  opacity: 0.4;
}

.completed.item .name {
  text-decoration: line-through;
}


.item .note.custom {
  background-color: #FCF8E5;
  margin: 1em 0 0;
  padding: 0.5em 1em;
}

.item.collapsible .note {
  overflow: hidden;
  max-height: none;
}

.item.collapsible.collapse .note:not(.custom) {
  max-height: 7em;
}

.item.collapsible .more {
  font-size: 13px;
  font-weight: bold;
  cursor: pointer;
}

.item.collapsible.collapse .more {
  display: inline-block;
}

.item.collapsible .more:hover {
  text-decoration: underline;
}

.item.collapsible.collapse .more:after {
  content: 'Read More...';
}

body.compact .item {
  cursor: pointer;
}

body.compact .item:not(.expanded) {
  padding: 1em;
}

body.compact .item:not(.expanded) .thumbnail,
body.compact .category:not(.prohibited) .item:not(.expanded) .note,
body.compact .item.collapsible.collapse:not(.expanded) .more {
  display: none;
}

body.compact .item:not(.expanded) .header {
  padding: 0.5rem 1rem;
}

body.compact .item:not(.expanded) .header,
body.compact .item:not(.expanded) .title,
body.compact .item:not(.expanded) .name {
  font-size: 13px;
}

body.compact .item:not(.expanded) .name {
  font-weight: normal;
}

body.compact .item:not(.expanded) .text {
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  width: 100%;
}

body.compact .item:not(.expanded) .text > div:first-child {
  margin-right: 2em;
}

body.compact .item:not(.expanded) .buttons {
  margin-top: 0;
  min-width: 330px;
  text-align: right;
}

body.compact .item:not(.expanded) .button {
  margin-bottom: 0;
}

.category.prohibited .card {
  border-left: 10px solid #dc3e47;
  background-color: #fff4f5;
}

.category.prohibited .header {
  background-color: #fff4f5;
  color: #dc3e47;
}

.category.prohibited .text {
  width: 100%;
}

.prohibited .item {
  background-color: #fff4f5;
}

#sources .body {
  padding: 1rem;
  font-size: 13px;
}

#sources .footnote {
  margin: 0;
  padding: 1rem;
  border-top: 1px solid rgba(0, 0, 0, 0.05);
}

.button-group {
  display: inline-flex;
  margin: 0 0.5rem 0 0;
}

.button-group .button {
  display: flex;
  align-items: center;
  border-radius: 0;
  margin: 0;
  box-shadow: inset -1px 0 0 rgba(0, 0, 0, 0.05)
}

.button-group .button:first-child {
  border-radius: 0.5em 0 0 0.5em;
}

.button-group .button:last-child {
  border-radius: 0 0.5em 0.5em 0;
  box-shadow: none;
}

.button-group .button.active {
  box-shadow: none;
}

.button-group .button:hover {
  box-shadow: inset 3em 3em 10em rgba(0, 0, 0, 0.1);
}

.button.primary,
.button.active,
.button.buy,
input[type="button"],
input[type="button"]:hover,
input[type="button"]:active,
input[type="submit"],
input[type="submit"]:hover,
input[type="submit"]:active {
  background-color: #ed1c24;
  color: #fff
}

.button.complete {
  margin-right: 0;
}

.completed .button.complete {
  background-color: #ed1c24;
  color: #fff;
}

.button.complete .dashicons {
  margin: 0 5px 0 -6px;
  font-size: 26px;
  line-height: 0.75;
}

.sidebar-inner {
  border-top: 10px solid #ed1c24;
  border-bottom: 10px solid #4e3629;
}

.sidebar .logo {
  text-align: center;
}

.sidebar .logo-inner {
  display: inline-block;
  padding: 1.2em;
}

.sidebar .name {
  margin-bottom: 0;
}

.sidebar p.location {
  margin-top: 0;
}

.splash,
.splash-inner::after {
  background-color: #ed1c24;
}

.splash-image {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: brightness(40%) opacity(60%);
}

.toc {
  margin-bottom: 25px;
}

.toc .card {
  display: block;
}

.toc .header {
  padding: 0.5em 1.5em;
  cursor: auto;
}

.top-link {
  display: inline-block;
  width: calc(1em + 20px);
  margin-top: 1em;
  -webkit-box-shadow: 0 0 1px rgba(0, 0, 0, 0.1);
          box-shadow: 0 0 1px rgba(0, 0, 0, 0.1);
  overflow: hidden;
  -webkit-transition: all 0.2s;
  -o-transition: all 0.2s;
  transition: all 0.2s;
}

.top-link:hover {
  width: 125px;
}

.top-link a {
  display: inline-block;
  min-width: 125px;
  padding: 0.5em;
  background-color: #fff;
  color: #333;
  text-decoration: none;
}

.top-link span:last-child {
  margin-left: 1em;
}

.list-group {
  max-height: calc(100vh - 2em - 20px);
  overflow: auto;
}

.list-group-item {
  position: relative;
  display: block;
  padding: 1em 4em 1em 2em;
  -webkit-box-shadow: inset 0 -1px 0 rgba(0, 0, 0, 0.05);
          box-shadow: inset 0 -1px 0 rgba(0, 0, 0, 0.05);
  color: inherit;
  font-weight: bold;
}

.list-group-item:hover {
  background-color: rgba(0, 0, 0, 0.01);
  text-decoration: none;
  color: inherit;
}

.list-group-item:last-child,
.list-group-item:last-child:hover {
  -webkit-box-shadow: none;
          box-shadow: none;
}

.list-group-item.active,
.list-group-item.active:hover {
  -webkit-box-shadow: inset 0 -1px 0 rgba(0, 0, 0, 0.05), inset 5px 0 0 #ed1c24;
          box-shadow: inset 0 -1px 0 rgba(0, 0, 0, 0.05), inset 5px 0 0 #ed1c24;
}

.list-group-item.active:last-child,
.list-group-item.active:last-child:hover {
  -webkit-box-shadow: inset 5px 0 0 #ed1c24;
          box-shadow: inset 5px 0 0 #ed1c24;
}

.list-group .badge {
  background-color: rgba(0.91, 0.91, 0.93, 0.05);
  color: rgba(0, 0, 0, 0.6);
}

#respond {
  padding: 1rem;
}

@supports ((position: -webkit-sticky) or (position: sticky)) or (position:-webkit-sticky) {

  .category .header {
    position: -webkit-sticky;
    position: sticky;
    top: 0;
    z-index: 5;
  }

  #toc {
    position: -webkit-sticky;
    position: sticky;
    top: 15px;
  }
}

@media only screen and (max-width: 576px) {

  .splash {
    height: 30vh;
    min-height: 0;
    margin-top: 70px;
  }

  .content .main h2 {
    display: none;
  }

  .share.card.top {
    display: none;
  }

  .card.settings {
    flex-direction: column;
  }

  .button-group.view {
    margin-bottom: 0.5rem;
  }

  .item .thumbnail img {
    object-fit: contain;
  }

  body.compact .item:not(.expanded) .title {
    margin-bottom: 0.5rem;
  }
}

@media only screen and (max-width: 767px) {

  .single-school .navbar {
    background-color: #ed1c24;
  }

  .share,
  .item {
    padding: 0.5em 1em;
  }

  .button-group.view .label {
    display: none;
  }

  .filters .button .badge {
    display: none;
  }

  .item .buttons {
    margin-bottom: 1em;
  }

  body.compact .header,
  body.compact .item {
    padding: 0.5rem 0.5rem 0.5rem 1rem;
  }

  body.compact .item .buttons {
    display: flex;
    flex-direction: column;
    width: 140px;
    min-width: 140px !important;
    margin-bottom: 0;
  }

  body.compact .item .button:first-child {
    margin: 0 0 0.5rem 0;
  }

  body.compact .item .button .dashicons {
    display: none;
  }
}

@media only screen and (max-width : 979px) {

  .item {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }

  .item .text {
    width: 100%;
  }

  .item .thumbnail {
    width: 80%;
    margin: 0 auto 1em;
    text-align: center;
  }

  .item .thumbnail img {
    max-width: 100%;
  }

  .toc {
    display: none;
  }
}
