/* start with mobile styles and override as needed */
body {
  margin: 0px;
  padding: 0px;
  background-color: #000000;
  color: #FFFFFF;
  font-family: courier, fixed-width;
  font-size: 16px;
}

a {
  font-family: courier, fixed-width;
  font-size: 0.8rem;
  color: #CC99FF;
  text-decoration: none;
}

a.menu {
  color: #AAFFDD;
}

a.landingheaderlink {
  color: #FFFFFF;
  letter-spacing: 6px;
}

a.lowkey {
  font-size: 0.5rem;
}

a.delete {
  color: #FFAAAA;
  margin-left: 24px;
}

input, textarea {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  font-family: courier, fixed-width;
  font-size: 0.8rem;
  background-color: #000000;
  color: #AADDFF;
  border: 1px solid #9933FF;
  border-radius: 6px;
}

input[type=submit]:hover {
  background-color: #9933FF;
}

select {
  font-family: courier, fixed-width;
  font-size: 0.8rem;
  background-color: #000000;
  color: #AADDFF;
  border: 1px solid #9933FF;
  border-radius: 6px;
}

input[type="radio"]{
  appearance: none;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background-clip: content-box;
  border: 1px solid #9933FF;
  background-color: #000000;
}

input[type="radio"]:checked{
  background-color: #9933FF;
  padding: 4px;
  border: 1px solid #9933FF;
}

span.radiolabel {
  color: #AAFFDD;
}

input[type="checkbox"]{
  appearance: none;
  width: 18px;
  height: 18px;
  border: 1px solid #9933FF;
  background-color: #000000;
}

input[type="checkbox"]:checked{
  background-color: #9933FF;
  padding: 4px;
  border: 1px solid #9933FF;
}

input:-webkit-autofill {
  -webkit-box-shadow: 0 0 0px 1000px #000000 inset;
  -webkit-text-fill-color: #AADDFF !important;
}

input:-webkit-autofill::first-line {
  font-family: courier, fixed-width !important;
}

input.login {
  height: 24px;
  width: 240px;
  font-size: 1rem;
  background-color: #000000;
}

input.delete {
  color: #FFAAAA;
  margin-left: 120px;
}

div.messages {
  width: 480px;
  border: 2px solid #AAFFDD;
  border-radius: 12px;
  padding: 12px;
  margin: 20px;
  color: #AAFFDD;
}
div.errors {
  width: 480px;
  border: 2px solid #FFAAAA;
  border-radius: 12px;
  padding: 12px;
  margin: 20px;
  color: #FFAAAA;
}
div.debug {
  width: 480px;
  border: 2px solid #AADDFF;
  border-radius: 12px;
  padding: 12px;
  margin: 20px;
  color: #AADDFF;
}

div.content {
  width: 98%;
}

div.leftside {
  float: left;
}

div.rightside {
  float: right;
}

div.landingheader {
  width: 480px;
  border: 2px solid #FFFFFF;
  border-radius: 12px;
  padding: 12px;
  margin: 20px;
}

div.table {
  display: inline-flex;
  width: min-content;
  color: #AAFFDD;
  border: 2px solid #663399;
  border-radius: 12px;
  padding: 12px;
  margin: 20px;
}

th.listcell {
  color: #AADDFF;
  white-space: nowrap;
}

td.active {
  color: #AAFFDD;
  padding: 0px 12px 0px 12px;
  white-space: nowrap;
}

td.inactive {
  color: #FFAAAA;
  padding: 0px 12px 0px 12px;
  white-space: nowrap;
}

td.deleted {
  color: #FFAAAA;
  padding: 0px 12px 0px 12px;
  white-space: nowrap;
}

h1.logo {
  font-family: courier, fixed-width;
  font-size: 2em;
  letter-spacing: 18px;
  margin: 0px;
  text-align: center;
}

div.landing {
  width: 480px;
  color: #AAFFDD;
  border: 2px solid #663399;
  border-radius: 12px;
  padding: 12px;
  margin: 20px;
}

span.landing_title {
  color: #FFFFFF;
  letter-spacing: 6px;
}

div.menu {
  text-align: right;
  color: #AAFFDD;
  border: 2px solid #663399;
  border-radius: 12px;
  padding: 12px;
  margin: 20px;
}
 
span.counts {
  font-family: courier, fixed-width;
  font-size: 0.5rem;
  color: #AADDFF;
}

span.sle_set {
  font-size: 0.8rem;
  letter-spacing: 6px;
  color: #663399;
}

span.sle_song {
  font-size: 0.8rem;
  color: #AAFFDD;
}

span.sle_header {
  font-size: 0.5rem;
  color: #AAFFDD;
}

div.header {
  position: relative;
  display: table;
  width: 100%;
}

div.keysig {
  background-color: #000000;
  position: relative;
  display: table-cell;
  margin-top: 20px;
  float: left;
  text-align: left;
  z-index: 999;
}

.keysigimg {
  filter: invert(1);
}

span.solo_key {
  color: #AAFFDD;
  display: inline-block;
  vertical-align: middle;
  line-height: normal;
}

div.meta {
  position: relative;
  display: table-cell;
  text-align: right;
  float: right;
  z-index: 999;
}

div.songlist {
  float: left;
  width: 100%;
}

span.pagetitle {
  font-family: courier, fixed-width;
  font-size: 2em;
  font-weight: bold;
  padding: 0px;
  margin: 0px;
}

span.band {
  font-family: courier, fixed-width;
  font-size: 1.5em;
  font-weight: bold;
  color: #AADDFF;
  padding: 0px;
  margin: 0px;
}

span.artist {
  font-family: courier, fixed-width;
  font-size: 1.2em;
  font-weight: bold;
  color: #AAFFDD;
  padding: 0px;
  margin: 0px;
}

span.songtitle {
  font-weight: bold;
  color: #AADDFF;
}

div.nav {
  display: block;
  height: 60px;
  position: fixed;
  top: 0px;
  z-index: 999;
}

div.nonnav {
  position: relative;
  display: block;
  top: 60px;
  z-index: 0;
}

div.sitenav {
  float: left;
}

div.songnav {
  float: right;
}

div.scrollnav {
  float: right;
}

div.navbutton {
  float: left;
}

div.songbutton {
  float: left;
}

div.scrollbutton {
  position: fixed;
  right: 150px;
}

div.scrollslider {
  position: fixed;
  top: 10px;
  right: 10px;
}

input.scrollslide {
  -webkit-appearance: none;
  height: 42px;
  border: 1px solid #FFFFFF;
  border-radius: 30px;
  color: #FFFFFF;
  background-color: #600360;
  cursor: pointer;
  -webkit-transition: .2s;
}

.scrollslide::-webkit-slider-thumb {
  -webkit-appearance: none;
  width: 24px; 
  height: 24px;
  border-radius: 12px;
  background: #FFFFFF;
  cursor: pointer;
}

.scrollslide::-moz-range-thumb {
  width: 24px; 
  height: 24px;
  border-radius: 12px;
  background: #FFFFFF;
  cursor: pointer;
}

a.button {
  display: block;
  color: #FFFFFF;
  font-size: 0.8em;
  border: 1px solid #FFFFFF;
  background-color: #600360;
  border-radius: 24px;
  padding: 12px 12px 12px 12px;
  margin: 12px;
  letter-spacing: 3px;
  transition: background-color 0.3s ease, color 0.3s ease;
  cursor: pointer;
}

a.button:hover {
  color: #CCCCCC;
  border: 1px solid #CCCCCC;
}

a.button:active {
  color: #999999;
  background-color: #030003;
  border: 1px solid #999999;
}

.stanza {
  display: block;
  position: relative;
  padding-bottom: 12px;
  z-index: -1;
}

.verse {
  display: table-cell;
  position: relative;
  color: #FFFFFF;
  padding: 2px;
}

/* not in use?
  position: relative;
  display: table-cell;
}

.nav-title {
  font-family: Arial,Helvetica,sans-serif;
  font-size: 12px;
  text-align: right;
}
*/

pre.line {
  font-family: courier, fixed-width;
  font-size: large;
  padding: 0px;
  margin: 0px;
}

span.chord_line {
  padding: 0px;
  margin: 0px;
}
span.chords {
  font-weight: bold;
  padding: 0px;
  margin: 0px;
}

.vertical {
  font-family: courier, fixed-width;
  font-size: 0.5em;
  display: table-cell;
  color: #AADDFF;
  padding: 0px 3px 0px 3px;
}

.chorus,.repeat {
  display: table-cell;
  position: relative;
  color: #AADDFF;
  padding: 2px;
  border-style: double;
  border-width: 1px 2px;
}

.bridge {
  display: table-cell;
  position: relative;
  color: #AAFFDD;
  padding: 2px;
  border-style: dashed;
  border-width: 1px 2px;
}

.landing_item {
  font-size: 0.8rem;
}

.landing_date {
  font-size: 0.5rem;
  color: #AAFFDD;
}

.directory_song {
  font-size: 1.2em;
}

.directory_band {
  font-size: 0.8em;
  color: #AADDFF;
}

.directory_option {
  font-size: 0.5em;
  color: #AAFFDD;
}

.performer_song {
  font-size: medium;
}

div.form-label {
  color: #AADDFF;
  display: block;
  position: relative;
  left: 2px;
  margin-bottom: -1em;
}

div.form-input {
  display: block;
  position: relative;
  padding: 1px;
  left: 100px;
  top: -0.5em;
}

.instructions {
  color: #AADDFF;
  width: 800px;
}

.legend_item {
  font-weight: bold;
}

.notes {
  display: block
}

.small {
  font-size: 10px;
}

td.listcell {
  padding: 0px 12px 0px 12px;
  white-space: nowrap;
}

span.db_title {
  font-size: 0.8em;
  color: #FFFFFF;
}

span.drawbars {
  font-size: 0.8em;
  font-weight: bold;
  color: #CC99FF;
  letter-spacing: 2px;
}

span.chorusvibrato {
  font-size: 0.8em;
  font-weight: bold;
  color: #AAFFDD;
  letter-spacing: 2px;
}

span.percussion {
  font-size: 0.8em;
  color: #AADDFF;
}

span.rotary {
  font-size: 0.8em;
  font-weight: bold;
  color: #AAFFDD;
}

span.notes {
  font-size: 0.5em;
  color: #FFFFFF;
}

@media only screen and (min-width: 768px) {
  /* desktop styles */

}

@media print {
   /* print-only styles */

  body {
    background: #FFFFFF !important;
    color: #000000;
    font-size: 0.8em;
  }

  span.title {
    font-size: 2.0em;
  }

  span.band {
    color: #000000;
  }

  span.artist {
    color: #000000;
  }

  span.solo_key {
    color: #696969;
  }

  .verse {
    color: #000000;
  }

  .chorus,.repeat {
    color: #696969;
  }

  .bridge {
    color: #939393;
  }

  div.keysig {
    background-color: #FFFFFF;
  }

  .keysigimg {
    filter: invert(0);
  }

  span.solo_key {
    color: #939393;
    font-size: x-small;
  }

/* avoid breaks in entire stanzas
  div.stanza {
    page-break-inside: avoid;
  }
*/

  /* keep chords stuck to lyrics across page breaks */
  pre.line {
    page-break-inside: avoid;
    font-size: x-small;
  }

  .vertical {
    color: #999999;
  }

  .sitenav {
    display: none;
  }

  .songnav {
    display: none;
  }

  .scrollnav {
    display: none;
  }
}

