@charset "UTF-8";
/* http://meyerweb.com/eric/tools/css/reset/
   v2.0 | 20110126
   License: none (public domain)
*/
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  font: inherit;
  vertical-align: baseline;
}

/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
  display: block;
}

body {
  line-height: 1;
}

ol, ul {
  list-style: none;
}

blockquote, q {
  quotes: none;
}

blockquote:before, blockquote:after,
q:before, q:after {
  content: "";
  content: none;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

/*
    Colorbox Core Style:
    The following CSS is consistent between example themes and should not be altered.
*/
#colorbox, #cboxOverlay, #cboxWrapper {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 9999;
  overflow: hidden;
}

#cboxWrapper {
  max-width: none;
}

#cboxOverlay {
  position: fixed;
  width: 100%;
  height: 100%;
}

#cboxMiddleLeft, #cboxBottomLeft {
  clear: left;
}

#cboxContent {
  position: relative;
}

#cboxLoadedContent {
  overflow: auto;
  -webkit-overflow-scrolling: touch;
}

#cboxTitle {
  margin: 0;
}

#cboxLoadingOverlay, #cboxLoadingGraphic {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

#cboxPrevious, #cboxNext, #cboxClose, #cboxSlideshow {
  cursor: pointer;
}

.cboxPhoto {
  float: left;
  margin: auto;
  border: 0;
  display: block;
  max-width: none;
  -ms-interpolation-mode: bicubic;
}

.cboxIframe {
  width: 100%;
  height: 100%;
  display: block;
  border: 0;
  padding: 0;
  margin: 0;
}

#colorbox, #cboxContent, #cboxLoadedContent {
  box-sizing: content-box;
  -moz-box-sizing: content-box;
  -webkit-box-sizing: content-box;
}

/*
    User Style:
    Change the following styles to modify the appearance of Colorbox.  They are
    ordered & tabbed in a way that represents the nesting of the generated HTML.
*/
#cboxOverlay {
  background: #000;
  opacity: 0.9;
  filter: alpha(opacity=90);
}

#colorbox {
  outline: 0;
}

#cboxContent {
  margin-top: 20px;
  background: #000;
}

.cboxIframe {
  background: #fff;
}

#cboxError {
  padding: 50px;
  border: 1px solid #ccc;
}

#cboxLoadedContent {
  border: 5px solid #000;
  background: #fff;
}

#cboxTitle {
  position: absolute;
  top: -20px;
  left: 0;
  color: #ccc;
}

#cboxCurrent {
  position: absolute;
  top: -20px;
  right: 0px;
  color: #ccc;
}

#cboxLoadingGraphic {
  background: url(../../img/colorbox-loading.gif) no-repeat center center;
}

/* these elements are buttons, and may need to have additional styles reset to avoid unwanted base styles */
#cboxPrevious, #cboxNext, #cboxSlideshow, #cboxClose {
  border: 0;
  padding: 0;
  margin: 0;
  overflow: visible;
  width: auto;
  background: none;
}

/* avoid outlines on :active (mouseclick), but preserve outlines on :focus (tabbed navigating) */
#cboxPrevious:active, #cboxNext:active, #cboxSlideshow:active, #cboxClose:active {
  outline: 0;
}

#cboxSlideshow {
  position: absolute;
  top: -20px;
  right: 90px;
  color: #fff;
}

#cboxPrevious {
  position: absolute;
  top: 50%;
  left: 5px;
  margin-top: -32px;
  background: url(../../img/colorbox-controls.png) no-repeat top left;
  width: 28px;
  height: 65px;
  text-indent: -9999px;
}

#cboxPrevious:hover {
  background-position: bottom left;
}

#cboxNext {
  position: absolute;
  top: 50%;
  right: 5px;
  margin-top: -32px;
  background: url(../../img/colorbox-controls.png) no-repeat top right;
  width: 28px;
  height: 65px;
  text-indent: -9999px;
}

#cboxNext:hover {
  background-position: bottom right;
}

#cboxClose {
  position: absolute;
  top: 5px;
  right: 5px;
  display: block;
  background: url(../../img/colorbox-controls.png) no-repeat top center;
  width: 38px;
  height: 19px;
  text-indent: -9999px;
}

#cboxClose:hover {
  background-position: bottom center;
}

/*
    User Style:
    Change the following styles to modify the appearance of Colorbox.  They are
    ordered & tabbed in a way that represents the nesting of the generated HTML.
*/
/*
#cboxOverlay{background:#fff; opacity: 0.8; filter: alpha(opacity = 90);}
#colorbox{outline:0;}
#cboxContent{margin-top:32px; overflow:visible; background:#000;}
.cboxIframe{background:#fff;}
#cboxError{padding:50px; border:1px solid #ccc;}
#cboxLoadedContent{background:#000; padding:1px;}
#cboxLoadingGraphic{background:url(../img/colorbox-loading.gif) no-repeat center center;}
#cboxLoadingOverlay{background:#000;}
#cboxTitle{position:absolute; top:-22px; left:0; color:#000;}
#cboxCurrent{position:absolute; top:-22px; right:205px; text-indent:-9999px;}
*/
/* these elements are buttons, and may need to have additional styles reset to avoid unwanted base styles */
/*#cboxPrevious, #cboxNext, #cboxSlideshow, #cboxClose {border:0; padding:0; margin:0; overflow:visible; text-indent:-9999px; width:20px; height:20px; position:absolute; top:-20px; background:url(../img/colorbox-controls.png) no-repeat 0 0;}
*/
/* avoid outlines on :active (mouseclick), but preserve outlines on :focus (tabbed navigating) */
/*#cboxPrevious:active, #cboxNext:active, #cboxSlideshow:active, #cboxClose:active {outline:0;}

#cboxPrevious{background-position:0px 0px; right:44px;}
#cboxPrevious:hover{background-position:0px -25px;}
#cboxNext{background-position:-25px 0px; right:22px;}
#cboxNext:hover{background-position:-25px -25px;}
#cboxClose{background-position:-50px 0px; right:0;}
#cboxClose:hover{background-position:-50px -25px;}
.cboxSlideshow_on #cboxPrevious, .cboxSlideshow_off #cboxPrevious{right:66px;}
.cboxSlideshow_on #cboxSlideshow{background-position:-75px -25px; right:44px;}
.cboxSlideshow_on #cboxSlideshow:hover{background-position:-100px -25px;}
.cboxSlideshow_off #cboxSlideshow{background-position:-100px 0px; right:44px;}
.cboxSlideshow_off #cboxSlideshow:hover{background-position:-75px -25px;}
*/
@font-face {
  font-family: "icomoon";
  src: url("../fonts/icomoon.eot?kwaa52");
  src: url("../fonts/icomoon.eot?#iefixkwaa52") format("embedded-opentype"), url("../fonts/icomoon.woff?kwaa52") format("woff"), url("../fonts/icomoon.ttf?kwaa52") format("truetype"), url("../fonts/icomoon.svg?kwaa52#icomoon") format("svg");
  font-weight: normal;
  font-style: normal;
}
.icon-classic3:before {
  content: "";
}

.icon-projector1:before {
  content: "";
}

.icon-home:before {
  content: "";
}

.icon-pencil:before {
  content: "";
}

.icon-pencil2:before {
  content: "";
}

.icon-image:before {
  content: "";
}

.icon-image2:before {
  content: "";
}

.icon-images:before {
  content: "";
}

.icon-music:before {
  content: "";
}

.icon-headphones:before {
  content: "";
}

.icon-camera:before {
  content: "";
}

.icon-bullhorn:before {
  content: "";
}

.icon-book:before {
  content: "";
}

.icon-file:before {
  content: "";
}

.icon-file2:before {
  content: "";
}

.icon-file3:before {
  content: "";
}

.icon-copy:before {
  content: "";
}

.icon-copy2:before {
  content: "";
}

.icon-paste:before {
  content: "";
}

.icon-paste2:before {
  content: "";
}

.icon-paste3:before {
  content: "";
}

.icon-stack:before {
  content: "";
}

.icon-tag:before {
  content: "";
}

.icon-tags:before {
  content: "";
}

.icon-barcode:before {
  content: "";
}

.icon-cart:before {
  content: "";
}

.icon-location:before {
  content: "";
}

.icon-map:before {
  content: "";
}

.icon-clock:before {
  content: "";
}

.icon-print:before {
  content: "";
}

.icon-screen:before {
  content: "";
}

.icon-tv:before {
  content: "";
}

.icon-box-add:before {
  content: "";
}

.icon-box-remove:before {
  content: "";
}

.icon-bubbles:before {
  content: "";
}

.icon-bubbles2:before {
  content: "";
}

.icon-bubble:before {
  content: "";
}

.icon-bubbles3:before {
  content: "";
}

.icon-user:before {
  content: "";
}

.icon-users:before {
  content: "";
}

.icon-quotes-left:before {
  content: "";
}

.icon-busy:before {
  content: "";
}

.icon-spinner:before {
  content: "";
}

.icon-search:before {
  content: "";
}

.icon-expand:before {
  content: "";
}

.icon-contract:before {
  content: "";
}

.icon-key:before {
  content: "";
}

.icon-key2:before {
  content: "";
}

.icon-lock:before {
  content: "";
}

.icon-wrench:before {
  content: "";
}

.icon-settings:before {
  content: "";
}

.icon-cog:before {
  content: "";
}

.icon-cog2:before {
  content: "";
}

.icon-stats:before {
  content: "";
}

.icon-bars:before {
  content: "";
}

.icon-fire:before {
  content: "";
}

.icon-remove:before {
  content: "";
}

.icon-remove2:before {
  content: "";
}

.icon-cloud-download:before {
  content: "";
}

.icon-cloud-upload:before {
  content: "";
}

.icon-earth:before {
  content: "";
}

.icon-link:before {
  content: "";
}

.icon-flag:before {
  content: "";
}

.icon-attachment:before {
  content: "";
}

.icon-eye:before {
  content: "";
}

.icon-eye-blocked:before {
  content: "";
}

.icon-eye2:before {
  content: "";
}

.icon-bookmark:before {
  content: "";
}

.icon-bookmarks:before {
  content: "";
}

.icon-star:before {
  content: "";
}

.icon-star2:before {
  content: "";
}

.icon-star3:before {
  content: "";
}

.icon-heart:before {
  content: "";
}

.icon-heart2:before {
  content: "";
}

.icon-thumbs-up:before {
  content: "";
}

.icon-thumbs-up2:before {
  content: "";
}

.icon-info:before {
  content: "";
}

.icon-blocked:before {
  content: "";
}

.icon-cancel-circle:before {
  content: "";
}

.icon-checkmark-circle:before {
  content: "";
}

.icon-spam:before {
  content: "";
}

.icon-close:before {
  content: "";
}

.icon-checkmark:before {
  content: "";
}

.icon-minus:before {
  content: "";
}

.icon-plus:before {
  content: "";
}

.icon-enter:before {
  content: "";
}

.icon-play:before {
  content: "";
}

.icon-pause:before {
  content: "";
}

.icon-stop:before {
  content: "";
}

.icon-backward:before {
  content: "";
}

.icon-forward:before {
  content: "";
}

.icon-first:before {
  content: "";
}

.icon-last:before {
  content: "";
}

.icon-previous:before {
  content: "";
}

.icon-next:before {
  content: "";
}

.icon-eject:before {
  content: "";
}

.icon-volume-high:before {
  content: "";
}

.icon-volume-medium:before {
  content: "";
}

.icon-volume-low:before {
  content: "";
}

.icon-volume-mute:before {
  content: "";
}

.icon-volume-mute2:before {
  content: "";
}

.icon-volume-increase:before {
  content: "";
}

.icon-volume-decrease:before {
  content: "";
}

.icon-loop:before {
  content: "";
}

.icon-radio-checked:before {
  content: "";
}

.icon-radio-unchecked:before {
  content: "";
}

.icon-pilcrow:before {
  content: "";
}

.icon-newtab:before {
  content: "";
}

.icon-google-drive:before {
  content: "";
}

.icon-facebook:before {
  content: "";
}

.icon-soundcloud:before {
  content: "";
}

.icon-soundcloud2:before {
  content: "";
}

.icon-file-pdf:before {
  content: "";
}

.icon-file-word:before {
  content: "";
}

.icon-file-excel:before {
  content: "";
}

.icon-file-powerpoint:before {
  content: "";
}

.fw-bold {
  font-weight: bold;
}

.fs-small {
  font-size: 0.875rem;
}

.fs-base {
  font-size: 1rem;
}

.fs-med {
  font-size: 1.2rem;
}

.fs-big {
  font-size: 1.5rem;
}

.mb-small {
  margin-bottom: 0.875rem;
}

.mb-base {
  margin-bottom: 1rem;
}

.mb-med {
  margin-bottom: 1.2rem;
}

.row:before, .row:after,
.p50:before,
.p50:after,
.p75:before,
.p75:after,
.p25:before,
.p25:after {
  content: "";
  display: block;
  clear: both;
  height: 0;
  visibility: hidden;
}

.p50 {
  width: 48%;
  margin-left: 1%;
  margin-right: 1%;
}

.p75 {
  width: 73%;
  margin-left: 1%;
  margin-right: 1%;
}

.p25 {
  width: 23%;
  margin-left: 1%;
  margin-right: 1%;
}

.visible-xl,
.visible-xl-inline-block,
.visible-xl-inline {
  display: none;
}

.visible-l,
.visible-l-inline-block,
.visible-l-inline {
  display: none;
}

.visible-m,
.visible-m-inline-block,
.visible-m-inline {
  display: none;
}

.visible-s,
.visible-s-inline-block,
.visible-s-inline {
  display: none;
}

.visible-xs,
.visible-xs-inline-block,
.visible-xs-inline {
  display: none;
}

.visible-xxs,
.visible-xxs-inline-block,
.visible-xxs-inline {
  display: none;
}

.resp-img {
  max-width: 100%;
}

@media screen and (max-width: 1280px) {
  .hidden-xl {
    display: none;
  }

  .visible-xl {
    display: block;
  }

  .visible-xl-inline-block {
    display: inline-block;
  }

  .visible-xl-inline {
    display: inline;
  }
}
@media screen and (max-width: 1024px) {
  .hidden-l {
    display: none;
  }

  .visible-l {
    display: block;
  }

  .visible-l-inline-block {
    display: inline-block;
  }

  .visible-l-inline {
    display: inline;
  }
}
@media screen and (max-width: 800px) {
  .hidden-m {
    display: none;
  }

  .visible-m {
    display: block;
  }

  .visible-m-inline-block {
    display: inline-block;
  }

  .visible-m-inline {
    display: inline;
  }
}
@media screen and (max-width: 600px) {
  .hidden-s {
    display: none;
  }

  .visible-s {
    display: block;
  }

  .visible-s-inline-block {
    display: inline-block;
  }

  .visible-s-inline {
    display: inline;
  }
}
@media screen and (max-width: 480px) {
  .hidden-xs {
    display: none;
  }

  .visible-xs {
    display: block;
  }

  .visible-xs-inline-block {
    display: inline-block;
  }

  .visible-xs-inline {
    display: inline;
  }
}
@media screen and (max-width: 400px) {
  .hidden-xxs {
    display: none;
  }

  .visible-xxs {
    display: block;
  }

  .visible-xxs-inline-block {
    display: inline-block;
  }

  .visible-xxs-inline {
    display: inline;
  }
}
h1 {
  font-size: 3rem;
  font-weight: 300;
  color: #333;
  letter-spacing: -1px;
  margin-bottom: 1.25rem;
  line-height: 1.2;
}

h2 {
  font-size: 2rem;
  font-weight: 300;
  color: #333;
  letter-spacing: -1px;
  margin-bottom: 1rem;
  line-height: 1.2;
}

h3 {
  font-size: 1.6rem;
  color: #333;
  letter-spacing: -1px;
  margin-bottom: 12px;
  line-height: 1.2;
}

small {
  font-size: 11px;
  color: #7e7e7e;
}

em {
  font-weight: 600;
}

a {
  color: #018683;
  text-decoration: none;
}
a:hover {
  text-decoration: underline;
}

label {
  font-weight: 600;
  font-color: #333;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  display: block;
  margin-bottom: 10px;
}
label i {
  font-weight: 400;
  padding-left: 6px;
  color: #8c8c8c;
  letter-spacing: 0;
  text-transform: none;
}

input[type=text],
input[type=email],
input[type=tel],
input[type=password],
input[type=number],
textarea,
select {
  background-color: #fff;
  border: none;
  width: 100%;
  box-sizing: border-box;
  -moz-box-sizing: border-box;
  font-family: "Open Sans", "Tahoma", sans-serif;
  font-size: 14px;
  color: #333;
  padding: 8px;
}
input[type=text]:focus,
input[type=email]:focus,
input[type=tel]:focus,
input[type=password]:focus,
input[type=number]:focus,
textarea:focus,
select:focus {
  outline-color: #018683;
}

.button-container {
  margin: 12px 0;
}

button,
.cta {
  font-family: "Open Sans", "Tahoma", sans-serif;
  padding: 8px 12px;
  font-size: 14px;
  border: none;
  background-color: #018683;
  color: #fff;
}
button:focus,
.cta:focus {
  outline: none;
}
button:hover,
.cta:hover {
  cursor: pointer;
  background-color: #016462;
}
button:disabled, button:disabled:hover,
.cta:disabled,
.cta:disabled:hover {
  background-color: #757575;
}
button.textual,
.cta.textual {
  color: #018683;
  background: transparent;
  padding: 0;
  font-size: inherit;
}

.state-error input,
.state-error textarea {
  background-color: #FFC8C2;
}
.state-error input:focus,
.state-error textarea:focus {
  outline-color: #FF908A;
}

.error-message {
  display: block;
  color: #d60e00;
  margin-top: 6px;
}

.field-container {
  margin-top: 16px;
  float: left;
}
.field-container .error-message {
  display: block;
  margin-top: 6px;
  color: #D60E00;
}
.field-container.state-error .error-message {
  visibility: visible;
}

@media screen, print {
  .print-view {
    font-family: "Open Sans";
    font-size: 14pt;
    line-height: 1.45;
    background-color: #fff;
    color: #333;
    padding: 1cm;
  }
  .print-view h1 {
    font-size: 36px;
    font-weight: 300;
    color: #333;
    letter-spacing: -1px;
    margin-bottom: 40px;
  }
  .print-view .refrain {
    margin-left: 50pt;
  }
  .print-view .refrain:before {
    content: "Refr.:";
    font-size: 16pt;
    font-weight: 700;
    font-style: italic;
    display: inline-block;
    float: left;
    margin-left: -50pt;
    vertical-align: bottom;
  }
  .print-view .tip {
    display: inline-block;
    position: relative;
    width: 0;
    height: 1em;
    margin-top: 1.8em;
  }
  .print-view .tip .content {
    color: black;
    position: absolute;
    bottom: 120%;
    font-size: 1.15em;
    font-weight: 700;
    font-style: italic;
    display: inline-block;
    width: 500pt;
  }
}
@media screen {
  .print-view {
    font-family: "Open Sans";
    font-size: 1.4rem;
    line-height: 1.45;
    background-color: transparent;
    color: #333;
    padding: 2rem;
  }
  .print-view h1 {
    font-size: 2em;
    font-weight: 300;
    color: #333;
    letter-spacing: -1px;
    margin-bottom: 1.5em;
  }
  .print-view .refrain {
    margin-left: 2em;
    min-height: 1em;
  }
  .print-view .refrain:before {
    display: block;
    content: "Refr.:";
    font-size: 1em;
    font-weight: 700;
    font-style: italic;
    float: none;
    margin-left: -2em;
    vertical-align: bottom;
  }
  .print-view .tip {
    display: inline-block;
    position: relative;
    width: 0;
    height: 1em;
    margin-top: 1.8em;
  }
  .print-view .tip .content {
    color: black;
    position: absolute;
    bottom: 120%;
    font-size: 1.15em;
    font-weight: 700;
    font-style: italic;
    display: inline-block;
    width: 20em;
  }
}
@media screen and (max-width: 600px) {
  .print-view {
    font-size: 1.25rem;
  }
}
@media screen and (max-width: 480px) {
  .print-view {
    font-size: 1.1rem;
  }
}
@media print {
  html, body {
    background: white !important;
    margin: 0 !important;
  }

  .print-view {
    padding: 2.5cm;
    font-size: 20pt;
  }
  .print-view h1 {
    font-size: 38pt;
  }
}
html, body {
  background-color: #f2f0ee;
  font-family: "Open Sans", "Tahoma", sans-serif;
  font-size: 12px;
  color: #656565;
  line-height: 135%;
}

[ng\:cloak], [ng-cloak], [data-ng-cloak], [x-ng-cloak], .ng-cloak, .x-ng-cloak {
  display: none !important;
}

.scrollable {
  overflow-x: hidden;
  overflow-y: auto;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
}

body {
  margin: 0 0 5em 0;
}

body > header {
  background-color: #333333;
  padding: 20px 0 8px 0;
  margin-bottom: 2rem;
}
body > header #logo-full,
body > header #logo-minimal {
  vertical-align: middle;
  margin-top: -10px;
}
body > header #logo-minimal {
  display: none;
}

nav {
  display: inline-block;
  margin-left: 50px;
  vertical-align: middle;
}
nav a {
  vertical-align: middle;
  letter-spacing: 1px;
  display: inline-block;
  margin-right: 30px;
  color: rgba(255, 255, 255, 0.6);
  text-transform: uppercase;
  font-weight: 600;
  font-size: 11px;
  text-decoration: none;
  padding-bottom: 4px;
}
nav a:hover {
  color: #fff;
  border-bottom: 1px solid #fff;
  text-decoration: none;
}

.content-wrapper {
  max-width: 720px;
  margin: auto;
  padding: 0 20px;
}
.content-wrapper.without-header {
  margin-top: 200px;
}

.login-wrapper {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 85vh;
  width: 100%;
}
.login-wrapper.column {
  flex-direction: column;
}
.login-wrapper form {
  width: 90%;
  max-width: 360px;
}
.login-wrapper .field-container {
  float: none;
}
.login-wrapper button {
  width: 100%;
}
.login-wrapper #boa-avatar {
  max-width: 60%;
  margin: 0 auto 1rem;
  border-radius: 50%;
  border: 8px solid #fff;
  display: block;
}

/****************************************
			S O N G    L I S T
 ***************************************/
body {
  position: relative;
  left: 0;
  transition: left 0.3s ease 0s;
}

body.detailed-view {
  overflow: hidden;
  left: 100%;
}
body.detailed-view #song-overlay {
  left: 0;
}

#control-panel {
  background-color: #018683;
  color: #fff;
  margin: -2rem 0 2rem 0;
  padding: 2rem 0;
}
#control-panel h1,
#control-panel h3 {
  color: #fff;
}
#control-panel .option-list {
  padding: 1rem 0 1rem;
}
#control-panel .option-list:after {
  content: "";
  display: block;
  clear: both;
}
#control-panel .option-list li {
  cursor: pointer;
  float: left;
  width: 33.3333%;
  text-align: center;
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-bottom: 1.5rem;
}
#control-panel .option-list li i {
  background-color: #016462;
  border-radius: 50%;
  width: 75px;
  height: 75px;
  line-height: 71px;
  display: block;
  margin: 0 auto 1rem auto;
  box-sizing: border-box;
  transition: all 0.3s ease;
  position: relative;
  overflow: hidden;
}
#control-panel .option-list li i:after {
  opacity: 0;
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  width: 6px;
  height: 6px;
  margin: -3px 0 0 -3px;
  border-radius: 50%;
  background: #fff;
  transition: all 0.2s ease;
  z-index: -1;
}
#control-panel .option-list li.selected i {
  color: #018683;
}
.no-csstransitions #control-panel .option-list li.selected i, .no-csstransforms3d #control-panel .option-list li.selected i {
  background-color: #fff;
}
#control-panel .option-list li.selected i:after {
  transform: scale3d(17, 17, 1);
  opacity: 1;
}
#control-panel .option-list li.disabled {
  opacity: 0.4;
  cursor: not-allowed;
}
#control-panel .option-list li:hover i {
  background-color: #015553;
}

#control-button-container {
  float: right;
  margin-top: 0.25rem;
}
#control-button-container button {
  padding: 9px 12px 9px 8px;
  border-radius: 4px;
  border: 1px solid #fff;
  text-transform: uppercase;
  font-size: 1rem;
  font-weight: bold;
  margin-left: 1rem;
  line-height: 1;
}
#control-button-container button i {
  font-size: 1.25rem;
}
#control-button-container button:first-child {
  margin-left: 0;
}
#control-button-container button.selected {
  background-color: #fff;
  color: #018683;
}
#control-button-container #thumb-view-button {
  padding-right: 8px;
  border-top-right-radius: 0;
  border-bottom-right-radius: 0;
}
#control-button-container #list-view-button {
  padding-right: 8px;
  margin-left: -4px;
  border-top-left-radius: 0;
  border-bottom-left-radius: 0;
}

#sorting-option-container {
  opacity: 0;
  max-height: 0;
  overflow: hidden;
  transition: all 0.5s ease;
}
.show-sorting-selector #sorting-option-container {
  max-height: 250px;
  opacity: 1;
}

#filter-option-selector {
  opacity: 0;
  max-height: 0;
  overflow: hidden;
  transition: all 0.5s ease;
}
.show-filter-selector #filter-option-selector {
  max-height: 250px;
  opacity: 1;
}

#book-filter,
#tag-filter {
  display: none;
}

.for-book #text-filter,
.for-tags #text-filter {
  display: none;
}

.for-book #book-filter {
  display: block;
}

.for-tags #tag-filter {
  display: block;
}

.book-selector {
  font-size: 1.3rem;
  padding: 1rem 1rem 1rem 4.25rem;
  border-bottom: 1px solid #fff;
  position: relative;
  z-index: 1;
  cursor: pointer;
  transition: color 0.4s ease;
}
.book-selector i {
  font-size: 1.5rem;
  width: 3rem;
  text-align: center;
  position: absolute;
  left: 0.5rem;
  color: #fff;
}
.book-selector:before, .book-selector:after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  z-index: -1;
  display: block;
  transition: all 0.4s ease;
  box-sizing: border-box;
}
.book-selector:before {
  top: 100%;
  width: 100%;
  background-color: #fff;
}
.book-selector:after {
  top: 0;
  width: 0.5rem;
}
.book-selector.all-book:after, .book-selector.others-book:after {
  background-color: #016462;
}
.book-selector.blue-book:after {
  background-color: #025d8c;
}
.book-selector.yellow-book:after {
  background-color: #FBB829;
}
.book-selector.green-book:after {
  background-color: #7FAF1B;
}
.book-selector.selected {
  color: #018683;
}
.book-selector.selected i {
  color: #fff;
}
.book-selector.selected:before {
  top: 0;
}
.book-selector.selected:after {
  width: 3.75rem;
}

#song-overlay {
  position: fixed;
  top: 0;
  bottom: 0;
  left: -100%;
  width: 100%;
  background-color: rgba(255, 255, 255, 0.96);
  transition: left 0.3s ease 0s;
}
#song-overlay header {
  background-color: #018683;
}
#song-overlay header h1 {
  color: #fff;
  font-size: 2rem;
  padding: 1rem 0.5rem;
}
#song-overlay .print-view {
  padding: 1rem;
}

.song-container {
  position: relative;
  box-sizing: border-box;
}
.song-container header {
  box-sizing: border-box;
  margin-top: 1rem;
  padding: 0.8rem 2.5rem 0.8rem 1rem;
  background-color: #fcfbfa;
  border-radius: 4px;
  position: relative;
  cursor: pointer;
  outline: none;
  transition: all 0.2s ease;
}
.song-container header:hover {
  outline: 1px solid #ddd;
}
.song-container header:hover .more-indicator {
  color: #fff;
  background-color: #ddd;
}
.song-container header:hover .more-indicator:before {
  top: 0%;
}
.song-container header h3 {
  margin-bottom: 0;
}
.song-container header .more-indicator {
  width: 2rem;
  position: absolute;
  right: 0;
  top: 0;
  bottom: 0;
  color: #333;
  transition: all 0.3s ease 0s;
  /*    &:before {
          border-top-right-radius: $border-radius-small;
          border-bottom-right-radius: $border-radius-small;
          content: "";
          transition: all 0.3s ease 0s;
          background-color: $primary-color;
          position: absolute;
          top: 100%;
          bottom: 0;
          left: 0;
          right: 0;
      } */
}
.song-container header .more-indicator i {
  position: absolute;
  top: 50%;
  right: 0;
  left: 0;
  text-align: center;
  font-size: 1.3rem;
  margin-top: -0.7rem;
}
.song-container header .secondary-title {
  font-size: 0.8em;
  letter-spacing: 0;
  font-weight: 300;
}

.detailed header {
  border-bottom-left-radius: 0;
  border-bottom-right-radius: 0;
  background-color: #fff;
  padding-right: 4.5rem;
  border-bottom: 1px solid #ddd;
}
.detailed header:hover {
  outline: none;
}
.detailed header .more-indicator {
  display: none;
  color: #fff;
  background-color: #ddd;
}

.song-details {
  display: none;
  background-color: #fcfbfa;
  min-height: 300px;
  border-bottom-left-radius: 4px;
  border-bottom-right-radius: 4px;
  padding-right: 4.5rem;
}
.song-details .action-buttons {
  font-size: 0.9rem;
  background-color: #d57762;
  color: #fff;
  position: absolute;
  right: 0;
  bottom: 0;
  top: 0;
  width: 4.2rem;
  border-top-right-radius: 4px;
  border-bottom-right-radius: 4px;
}
.song-details .action-buttons li {
  text-align: center;
  padding: 1rem 0;
  cursor: pointer;
  background-color: transparent;
  transition: all 0.4s ease;
}
.song-details .action-buttons li i {
  display: block;
  margin: 0 auto 0.3rem;
}
.song-details .action-buttons li:active {
  background-color: #b95b46;
  outline: none;
}
.song-details .action-buttons .close-action-button {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
}
.detailed .song-details {
  display: block;
}

.book-numbers {
  float: right;
  position: relative;
  top: -2px;
}
.book-numbers .book-number {
  font-size: 1.6rem;
  font-weight: 400;
  color: #fff;
  text-shadow: 1px 1px rgba(0, 0, 0, 0.25);
  letter-spacing: -1px;
  display: inline-block;
  margin-left: 8px;
  border-radius: 4px;
  border: none;
  padding: 6px;
}
.book-numbers .blue-number {
  background-color: #025D8C;
}
.book-numbers .yellow-number {
  background-color: #FBB829;
}
.book-numbers .green-number {
  background-color: #7FAF1B;
}

.stats {
  text-align: right;
}

#empty-song-list,
#loading-list {
  padding: 4rem;
  color: #ccc;
  font-size: 1.2rem;
  font-weight: bold;
  text-align: center;
}
#empty-song-list i,
#loading-list i {
  font-size: 10rem;
  text-align: center;
}
#empty-song-list p,
#loading-list p {
  margin-top: 2rem;
}

@media screen and (max-width: 600px) {
  #control-button-container {
    float: none;
    margin-bottom: 1.25rem;
  }
}
@media screen and (max-width: 480px) {
  h3 {
    font-size: 1.5rem;
  }

  #control-panel .option-list li i {
    width: 60px;
    height: 60px;
    line-height: 56px;
    font-size: 2.5em;
  }
}
@media screen and (max-width: 400px) {
  h3 {
    font-size: 1.4rem;
  }
}
.with-icon:before {
  font-family: "icomoon";
  speak: none;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  /* Better Font Rendering =========== */
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  padding-right: 0.5em;
}

.del-icon:before {
  content: "";
}

.ppt-icon:before {
  content: "";
}

#lyrics {
  min-height: 385px;
  max-width: 100%;
}

.info-panel {
  padding: 16px;
  background-color: #e8e8e8;
  border: 1px solid #dfdfdf;
  border-radius: 5px;
  margin-bottom: 12px;
}
.info-panel pre {
  display: block;
  font-weight: bold;
  font-family: monospace;
}
.info-panel li {
  line-height: 150%;
  margin: 6px 0;
  margin-left: 18px;
  list-style-type: disc;
  list-style-position: outside;
}

.tag-group-separator {
  display: block;
  height: 0;
  margin: 16px 0 8px;
  border-top: 1px solid #f7f7f7;
  border-bottom: 1px solid #dedede;
}
.inverted .tag-group-separator {
  border: none;
}

.tag-group-name {
  position: relative;
  top: -8px;
  text-transform: uppercase;
  color: #aaa;
  font-weight: bold;
  margin-left: 8px;
  text-shadow: 1px 2px #fff;
  font-size: 11px;
  letter-spacing: 2px;
  background-color: #f0f0f0;
  padding: 0 4px;
}
.inverted .tag-group-name {
  margin-left: 0;
  background-color: transparent;
  text-shadow: none;
  color: #fff;
}

.tag {
  display: inline-block;
  padding: 6px 10px;
  margin: 6px 4px 0 0;
  background-color: #ddd;
  border-radius: 3px;
  box-shadow: 0 1px #ccc;
  cursor: pointer;
  transition: all 0.25s ease;
}
.tag:hover {
  background-color: #ccc;
}
.tag.active, .tag.compact {
  background-color: #018683;
  color: #fff;
}
.tag.compact, .touch .tag.compact {
  font-size: 11px;
  padding: 2px 8px;
  cursor: default;
}
.touch .tag {
  font-size: 14px;
  padding: 10px 14px;
}
.inverted .tag {
  background-color: transparent;
  color: #fff;
  border: 1px solid #fff;
  box-shadow: none;
}
.inverted .tag:hover {
  background-color: #016462;
}
.inverted .tag.active, .inverted .tag.compact {
  background-color: #fff;
  color: #018683;
}

#chords-help-btn:before {
  font-family: "icomoon";
  speak: none;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  /* Better Font Rendering =========== */
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  content: "";
  padding-right: 6px;
}

#preview-print-view-btn {
  display: block;
  float: right;
}
#preview-print-view-btn:before {
  font-family: "icomoon";
  speak: none;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  /* Better Font Rendering =========== */
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  content: "";
  padding-right: 6px;
}

#preview-plain-text-btn:before {
  font-family: "icomoon";
  speak: none;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  /* Better Font Rendering =========== */
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  content: "";
  padding-right: 6px;
}

#overlay {
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
}
#overlay #overlay-content {
  position: absolute;
}

/****************  Google Drive file uploader *************/
@keyframes spinner {
  100% {
    -ms-transform: rotate(0deg);
    /* IE 9 */
    -webkit-transform: rotate(0deg);
    /* Chrome, Safari, Opera */
    transform: rotate(0deg);
  }
}
@-webkit-keyframes spinner {
  100% {
    -ms-transform: rotate(360deg);
    /* IE 9 */
    -webkit-transform: rotate(360deg);
    /* Chrome, Safari, Opera */
    transform: rotate(360deg);
  }
}
.drive-upload-container .uploaded-file-wrapper {
  background-color: #edfffe;
  border: 1px solid #cbfffd;
  padding: 6px;
  margin: 0.5em 0;
  border-radius: 4px;
}
.drive-upload-container .uploaded-file-wrapper:before {
  font-size: 16px;
}
.drive-upload-container .uploaded-file-wrapper a {
  font-size: 14px;
}
.drive-upload-container .uploaded-file-wrapper button {
  float: right;
}
.drive-upload-container .new-file-container {
  float: none;
  position: relative;
}
.drive-upload-container .uploaded-file-container {
  position: relative;
}
.drive-upload-container .init-info-container {
  position: relative;
  min-height: 50px;
}
.drive-upload-container .progress-indicator {
  display: none;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  background-color: rgba(240, 240, 240, 0.8);
  text-align: center;
  font-size: 14px;
  color: #018683;
}
.drive-upload-container .progress-indicator .progress-icon {
  font-family: icomoon;
  font-size: 20px;
  display: block;
  margin-bottom: 6px;
  animation: spinner 2s ease 0 infinite normal;
  -webkit-animation: spinner 1s linear 0 infinite normal;
}
.drive-upload-container.in-progress .progress-indicator {
  display: block;
}
.drive-upload-container.has-uploaded-file .uploaded-file-container {
  display: block;
}
.drive-upload-container.has-uploaded-file .new-file-container,
.drive-upload-container.has-uploaded-file .init-info-container {
  display: none;
}
.drive-upload-container.no-uploaded-file .uploaded-file-container,
.drive-upload-container.no-uploaded-file .init-info-container {
  display: none;
}
.drive-upload-container.no-uploaded-file .new-file-container {
  display: block;
}
.drive-upload-container.connecting .uploaded-file-container,
.drive-upload-container.connecting .new-file-container {
  display: none;
}
.drive-upload-container.connecting .init-info-container {
  display: block;
}
.drive-upload-container.connecting .init-info-container .error-message {
  display: none;
}

@media (max-width: 800px) {
  label i {
    display: block;
    padding-left: 0;
  }

  .book-numbers .book-number {
    font-size: 16px;
    font-weight: 400;
    padding: 4px 6px;
    border-bottom-width: 4px;
  }
}
@media (max-width: 600px) {
  .p50,
.p75,
.p25 {
    width: 100%;
  }

  button[type=submit] {
    width: 100%;
    display: block;
    margin: 12px 0;
    height: 44px;
  }

  nav {
    margin-left: 2rem;
  }
  nav a:last-child {
    margin-right: 0;
  }

  .book-numbers .book-number {
    font-size: 14px;
    padding: 2px 4px;
  }
}
@media (max-width: 400px) {
  body > header #logo-full {
    display: none;
  }
  body > header #logo-minimal {
    display: inline-block;
  }
}

/*# sourceMappingURL=boa.css.map */
