@charset "UTF-8";
/* Webfont includes */
@import url(cantarell/stylesheet.css);
@import url(alpha_echo/stylesheet.css);
/* Reset */
span, a, em, strong, i, bold, tt {
  display: inline; }

html, body, div, p, ul, ol, li,
h1, h2, h3, h4, h5, h6 {
  display: block; }

span, a, em, strong, i, bold, tt,
html, body,
div, p, ul, ol, li,
h1, h2, h3, h4, h5, h6 {
  font-family: inherit;
  font-size: inherit;
  text-decoration: inherit;
  font-style: inherit;
  font-weight: inherit;
  color: inherit;
  background-image: none;
  background-color: transparent;
  border: none;
  margin: 0;
  padding: 0;
  cursor: inherit;
  list-style: none;
  text-indent: none;
  vertical-align: top;
  text-align: inherit; }

html {
  font-family: Cantarell, Verdana, Tahoma, sans-serif;
  font-size: 22px;
  color: #CCC;
  background-color: black;
  overflow-x: hidden;
  min-height: 100%;
  background-image: url("../img/logotop.png");
  background-repeat: no-repeat;
  background-position: left bottom; }

.hidden {
  display: none; }

.main {
  max-width: 1100px;
  margin-left: auto;
  margin-right: auto;
  line-height: 1.5;
  position: relative; }

/* Generic elements */
a {
  color: white;
  cursor: pointer; }

a:hover {
  text-decoration: underline; }

h1 {
  font-family: "AlphaEchoRegular";
  font-weight: normal; }

h1, h2, h3, h4 {
  font-weight: bold; }

h1 {
  font-size: 150%; }

h2 {
  font-size: 125%; }

h3 {
  font-size: 110%; }

h4 {
  font-size: 100%; }

em, i {
  font-style: oblique; }

strong, b {
  font-weight: bold; }

/* Page layout */
.content {
  padding: 1.4rem;
  background-color: #FFFFFE;
  color: #333;
  border-radius: 8px;
  overflow: hidden;
  opacity: 0.95; }
  .content a {
    color: #666; }
  .content.unpublished {
    background-image: url("../img/draft.svg");
    background-repeat: repeat; }

/* Menu */
.menu {
  margin: 0.75em 0 0.75em 0; }
  .menu li {
    background-color: transparent; }
  .menu > ul > li {
    display: inline-block;
    margin-right: 8px;
    line-height: 2; }
  .menu li > ul {
    display: none;
    position: absolute;
    padding: 0.5em 0.5em;
    border: solid 2px #FB3;
    border-radius: 8px;
    background-color: rgba(0, 0, 0, 0.9);
    box-shadow: 2px 2px 6px rgba(0, 0, 0, 0.5);
    z-index: 1; }
  .menu li:hover > ul {
    display: block; }
  .menu li > ul a {
    display: block;
    padding: 0 0.5em;
    border-radius: 4px; }
  .menu > ul > li > a {
    background-color: #FB3;
    color: black;
    border-radius: 8px;
    padding: 2px 12px;
    -moz-transition-property: background-color;
    -moz-transition-duration: 500ms; }
  .menu > ul > li > a:hover {
    background-color: #F60;
    text-decoration: none; }

/* Specific classes & styles */
.titlebanner {
  line-height: 1;
  color: #FB3;
  margin-top: 0.5em; }
  .titlebanner h1 {
    text-transform: lowercase;
    text-shadow: 0px 0px 1px #FB3;
    font-family: inherit;
    font-weight: bold; }
  .titlebanner p {
    font-size: 75%; }
  .titlebanner a {
    display: block;
    color: inherit; }
  .titlebanner a:hover {
    text-decoration: none; }

.rfloat {
  float: right;
  margin-left: 1em; }

.lfloat {
  float: left;
  margin-right: 1em; }

.photo {
  padding: 6px;
  background-color: white;
  box-shadow: 2px 2px 4px rgba(0, 0, 0, 0.25);
  margin-right: 1rem;
  box-sizing: border-box; }

figcaption {
  font-style: italic; }
  figcaption p:first-child {
    margin-top: 0; }

.sheet-music {
  margin: 1rem 0;
  display: block;
  max-width: 100%; }
  .sheet-music.fullpage {
    border: solid 1px silver;
    box-shadow: 2px 2px 4px rgba(0, 0, 0, 0.25); }

figure.sheet-music > img {
  max-width: 100%; }

td {
  vertical-align: top;
  padding: 1rem; }

.content h2, .content h3, .content h4, .content p, .content li {
  margin-top: 0.5em; }

.content ul > li {
  margin-left: 1.5em;
  list-style-position: outside;
  list-style-type: disc;
  display: list-item; }

.content .music ul > li {
  display: inline-block;
  list-style: none;
  margin-left: 0;
  margin-right: 1rem;
  margin-bottom: 2rem;
  position: relative;
  width: 492px;
  box-sizing: border-box; }

.content .music img {
  box-shadow: 2px 2px 4px rgba(0, 0, 0, 0.25);
  border: solid 1px black;
  border-radius: 3px; }

.content blockquote, .content pre {
  border-radius: 3px; }

.content blockquote {
  border: solid 1px rgba(0, 0, 0, 0.5);
  padding-left: 1em;
  padding-top: 0.5em;
  padding-bottom: 0.5em;
  padding-right: 1em;
  background-color: rgba(255, 255, 255, 0.7); }
  .content blockquote:before {
    content: '”';
    font-family: serif;
    font-size: 300%;
    float: left;
    position: relative;
    line-height: 1;
    margin-right: 0.25em;
    color: rgba(0, 0, 0, 0.5); }

.content pre {
  border: solid 1px rgba(0, 0, 0, 0.5);
  padding-left: 1em;
  padding-top: 0.5em;
  padding-bottom: 0.5em;
  padding-right: 1em;
  background-color: rgba(0, 0, 0, 0.5);
  color: #FFFFFF; }

.allein figure {
  margin-left: 0;
  padding: 6px;
  background-color: white;
  box-shadow: 2px 2px 4px rgba(0, 0, 0, 0.25);
  border: solid 1px silver;
  float: left;
  border-radius: 3px; }
  .allein figure img {
    max-height: 25rem;
    max-width: 80vw; }

.allein ul {
  overflow: hidden; }

.adminlinks {
  color: black;
  font-size: 9pt;
  background-color: #DDD;
  padding: 0.25em 1em;
  border-bottom: solid 1px #999;
  box-shadow: 0px -2px 2px rgba(0, 0, 0, 0.5) inset; }
  .adminlinks * {
    vertical-align: baseline; }
  .adminlinks form {
    display: inline; }
  .adminlinks a {
    color: #00C;
    padding: 0.5em;
    background-color: transparent; }

.footer {
  margin-top: 1em;
  margin-bottom: 1em;
  text-align: center;
  font-size: 60%;
  color: #48C; }
  .footer p {
    display: inline; }
  .footer p + p:before {
    content: '-'; }

.breadcrumbs {
  font-size: 50%;
  border-bottom: dotted 1px #888;
  padding-bottom: 1.5em;
  margin-bottom: 1em; }

.languages,
.childpages {
  vertical-align: bottom; }
  .languages ul > li,
  .childpages ul > li {
    list-style: none;
    margin: 0;
    display: inline; }
    .languages ul > li + li:before,
    .childpages ul > li + li:before {
      content: '-';
      margin-left: 0.5em;
      margin-right: 0.5em; }

.languages {
  font-size: 60%;
  position: absolute;
  top: 0;
  right: 0; }

.blog {
  position: relative;
  display: table;
  width: 100%; }
  .blog .principal,
  .blog .sidebar {
    font-size: 85%;
    display: table-cell; }
  .blog .principal {
    width: auto;
    padding-right: 1em; }
  .blog .sidebar {
    width: 15em;
    text-indent: -4em;
    padding-left: 5em; }
    .blog .sidebar .bloglist .bloglistitem h6 {
      display: inline; }
  .blog .blog-entry {
    margin-bottom: 1em; }
    .blog .blog-entry .readmore {
      margin-top: 0.25em;
      display: block; }
    .blog .blog-entry h1 {
      color: inherit; }
      .blog .blog-entry h1 a {
        color: inherit; }
  .blog .tags strong {
    display: block; }
  .blog .tags a {
    font-size: 80%;
    background-color: #EEE;
    padding: 0.25em;
    border-radius: 0.25em;
    margin: 0.25em;
    border: solid 1px #888;
    line-height: 2; }

audio.track {
  display: block; }

body.advent svg {
  margin-left: auto;
  margin-right: auto;
  display: block;
  width: 100%;
  height: 100%;
  max-width: 100vw;
  max-height: 100vh;
  min-width: 400px;
  min-height: 600px; }

body.advent .info-button {
  position: absolute;
  right: 1rem;
  bottom: 1rem; }
  body.advent .info-button:hover {
    text-decoration: none; }

body.advent .info-popup-container {
  position: absolute;
  left: 0;
  top: 0;
  right: 0;
  bottom: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: rgba(0, 0, 0, 0.5);
  transition-duration: 1s; }
  body.advent .info-popup-container.hidden {
    visibility: hidden;
    opacity: 0; }

body.advent .info-popup {
  background-color: #EEE;
  color: #333;
  padding: 1em;
  max-width: 25em;
  border-radius: 8px;
  border: solid 2px #333; }
