* {
  box-sizing: border-box;
  -moz-box-sizing: border-box;
}
html {
  height: 100%;
  overflow-y: scroll;
}
html,
body {
  padding: 0;
  margin: 0;
}
body {
  background: #0d1117;
  color: #c9d1d9;
  font-family: system-ui, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  font-size: 16px;
  line-height: 1.5em;
  margin-bottom: 1em;
}
a {
  text-decoration: none;
  color: #58a6ff;
}
a:hover {
  text-decoration: underline;
}
.clearfix:after {
  content: " ";
  display: block;
  clear: both;
}
.noselect {
  cursor: default;
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  -khtml-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}
#container {
  padding: 2em;
}
div#container > * + * {
  margin-block-start: 3rem;
}
header {
  background: #0d1117;
  color: #c9d1d9;
}
h1 {
  display: inline-block;
  font-size: 2em;
  font-weight: bold;
}
h1 a {
  color: #c9d1d9;
}
.tagline {
  margin-top: 0.5em;
  color: #8b949e;
}
footer {
  color: #8b949e;
  font-size: 0.875em;
  font-style: italic;
  margin-top: 3em;
}
nav.breadcrumbs {
  border-bottom: 1px solid #30363d;
  font-size: 1.25em;
  padding: 0 0 1em 0;
}
nav.breadcrumbs ul {
  list-style: none;
}
nav.breadcrumbs li {
  display: inline;
}
nav.breadcrumbs li + li:before {
  content: ">";
  padding: 0.25em;
}
nav.breadcrumbs a,
nav span {
  display: inline;
}
nav.breadcrumbs a {
  color: #c9d1d9;
}
#albums,
#media {
  margin: 0;
}
#albums a {
  background-size: cover;
}
#albums h3 {
  font-size: 1.25em;
  margin-bottom: 0.25em;
}
#media .albumList,
#media .albumList img {
  cursor: zoom-in;
}
nav.pagination {
  color: #8b949e;
  display: inline-block;
  font-size: 1em;
  margin-top: 2em;
  padding: 0em 0em 0.5em 0em;
}
nav.pagination .page {
  margin-right: 0.25em;
}
nav.pagination .page.current {
  font-weight: bold;
}
nav.pagination a {
  color: #8b949e;
}
.justified-gallery {
  width: 100%;
  position: relative;
  overflow: hidden;
}
.justified-gallery > a,
.justified-gallery > div,
.justified-gallery > figure {
  position: absolute;
  display: inline-block;
  overflow: hidden;
  opacity: 0.1;
  margin: 0;
  padding: 0;
}
.justified-gallery > a > img,
.justified-gallery > div > img,
.justified-gallery > figure > img,
.justified-gallery > a > a > img,
.justified-gallery > div > a > img,
.justified-gallery > figure > a > img,
.justified-gallery > a > svg,
.justified-gallery > div > svg,
.justified-gallery > figure > svg,
.justified-gallery > a > a > svg,
.justified-gallery > div > a > svg,
.justified-gallery > figure > a > svg {
  position: absolute;
  top: 50%;
  left: 50%;
  margin: 0;
  padding: 0;
  border: none;
  opacity: 0;
}
.justified-gallery > a > .jg-caption,
.justified-gallery > div > .jg-caption,
.justified-gallery > figure > .jg-caption {
  opacity: 0;
  position: absolute;
  bottom: 0;
  padding: 0.25em;
  background-color: #0d1117;
  left: 0;
  right: 0;
  margin: 0;
  color: #c9d1d9;
  font-size: 1em;
}
.justified-gallery > a > .jg-caption.jg-caption-visible,
.justified-gallery > div > .jg-caption.jg-caption-visible,
.justified-gallery > figure > .jg-caption.jg-caption-visible {
  display: initial;
  opacity: 0.75;
  transition: opacity 250ms ease-in;
}
.justified-gallery > a > .jg-caption.jg-caption-permanent,
.justified-gallery > div > .jg-caption.jg-caption-permanent,
.justified-gallery > figure > .jg-caption.jg-caption-permanent {
  display: initial;
  opacity: 1;
  background-color: rgba(13, 17, 23, 0.75);
}
.justified-gallery > a:hover .jg-caption-permanent h3,
.justified-gallery > div:hover .jg-caption-permanent h3,
.justified-gallery > figure:hover .jg-caption-permanent h3 {
  text-decoration: underline;
}
.justified-gallery > .jg-entry-visible {
  opacity: 1;
  background: none;
}
.justified-gallery > .jg-entry-visible > img,
.justified-gallery > .jg-entry-visible > a > img,
.justified-gallery > .jg-entry-visible > svg,
.justified-gallery > .jg-entry-visible > a > svg {
  opacity: 1;
  transition: opacity 250ms ease-in;
}
.justified-gallery > .jg-filtered {
  display: none;
}
.justified-gallery > .jg-spinner {
  position: absolute;
  bottom: 0;
  margin-left: -48px / 2;
  padding: 10px 0 10px 0;
  left: 50%;
  opacity: 1;
  overflow: initial;
}
.justified-gallery > .jg-spinner > span {
  display: inline-block;
  opacity: 0;
  width: 8px;
  height: 8px;
  margin: 0 4px 0 4px;
  background-color: #000;
  border-radius: 6px;
}
