:root {
  --day-size: 45px;
  --star-icon-size: 20px;
  --cloud-icon-size: 23px;
  --entry-width: 1111px; /* 1120px; */
  --left-padding: 20px;
  --raie-check-size: 11px;
}

.hlslash {
  color: #000000;
  background-color: #C9CC3F;
}

.hlsong {
  color: #000000;
  background-color: #6cd950;
}

@font-face {
  font-family: Consolas;
  src: url(consolas.ttf);
}

html, body {
  margin: 0;
  height: 100%;
}

body {
  background-color: #343c44;
  color: #d8dee9;
  font-family: Consolas;
  font-size: 14px;
}

.entry-container {
    width: 1000px;
    height: 98.5vh;
    overflow-y: scroll;
    overflow-x: hidden;
    display: block;
  margin: auto;
  line-height: 20px;
}
.calendar-container {
    width: 425px; /* 540px; */
    height: 98.5vh;
    float: left;
    overflow-y: scroll;
    background: black;
    padding-top: 2px;
}

h1.month-name {
  margin-top: 0px;
  margin-bottom: 10px;
  text-align: center;
}

.entry {
  padding-bottom: 50px;
}
.entry p {
  white-space: pre-wrap;
  padding-left: var(--left-padding);
}



table.calendar {
  padding-left: 17px;
}
table.calendar td {
  width: var(--day-size);
  height: var(--day-size);
  padding: 3px;
  background-color: #323256;
  position: relative;
  border-radius: 3px;
  border: 1px solid #7878ff;
  user-select: none;
}

table.calendar td.empty {
  background-color: #19192a;
  border: 1px solid #404086;
}

table.calendar td:hover {
  background-color: #6f6fa9;
}

.day-number {
  z-index: 3;
  position: absolute;
  top: 0px;
  color: #fefafa;
}

table.calendar td.empty .day-number {
  color: #404086;
}

.star-icon {
  width: var(--star-icon-size);
  height: var(--star-icon-size);

  position: absolute;
  bottom: 3px;
  right: 2px;
}

.note-icon {
  width: var(--star-icon-size);
  height: var(--star-icon-size);

  position: absolute;
  bottom: 3px;
  left: 2px;
}

tr.empty-row {
  height: var(--day-size);
}

.invisible {
  opacity: 0;
}

.cloud-icon {
  width: var(--cloud-icon-size);
  height: var(--star-icon-size);

  position: absolute;
  top: 3px;
  right: 2px;
}

h3.entry-date {
  font-size: 27px;
  padding-left: var(--left-padding);
  text-decoration: underline;
}



.entry-separator {
  width: 100%;
  height: 55px;
  background-color: black;
  padding-left: 0px;
}



/* ----- STYLES ----- */

.parenthesis {
  color: gray;
}
.song {
  color: #000000;
  background-color: #6cd950;
  font-size: 16px;
}
.lyrics {
  color: white;
  background-color: black;
  font-size: 16px;
  white-space: pre-wrap;
  width: 800px;
  border: 3px solid #d96050;
  padding: 10px;
  margin-left: var(--left-padding);
}
.highlight {
  color: #FFFFFF;
  background-color: #505b66;
  font-size: 15px;
  text-decoration: underline;
}
.inquotes {
  color: #FFFFFF;
  background-color: #404851;
  font-size: 15px;
  font-style: italic;
}

.check {
  color: #000000;
  background-color: #d8dee9;
  font-style: italic;
}
.check-done {
  color: #000000;
  background-color: #545b65;
  font-style: italic;
}
.check-half {
  color: #000000;
  background-color: #989ca2;
  font-style: italic;
}

.part {
  color: black;
  background-color: #7878ff;
  font-size: 17px;
}
.link {
  color: #89caff;
  background-color: #2659ce;
  font-style: italic;
}
.hl-blue {
  color: #000000;
  background-color: #96DED1;
  font-weight: bold;
  font-size: 18px;
}
.hl-red {
  color: #000000;
  background-color: #C9CC3F;
  font-weight: bold;
}


/* ----- NAVIGATOR ----- */

.navigator {
  width: 425px;
  height: 30px;
  padding-bottom: 15px;
}

.navigator table td {
  width: 131px;
  height: 20px;
  padding: 3px;
  text-align: center;
  background-color: #323256;
  position: relative;
  border-radius: 3px;
  border: 1px solid #7878ff;
  user-select: none;
}

.navigator table td:hover {
  background-color: #6f6fa9;
}

/* ----- PARTS ----- */

.parts-container {
    width: 425px; /* 540px; */
    height: 98.5vh;
    float: left;
    overflow-y: scroll;
    background: black;
    padding-top: 2px;
    display: none;
}

.parts-entry {
  background-color: #3838ff;
  font-size: 15px;
  text-align: right;
  padding-right: 20px;
  font-style: italic;
  padding-top: 3px;
  padding-bottom: 3px;
  user-select: none;
}
.parts-part {
  padding-left: 20px;
  /*background-color: #6161ff;*/
  font-size: 16px;
  padding-top: 1px;
  padding-bottom: 1px;
  user-select: none;
}
.parts-part:hover {
  background-color: #3131cf;
  cursor: pointer;
}
.parts-part-separator {
  width: 370px;
  margin-left: 20px;
  margin-top: 4px;
  margin-bottom: 4px;
  height: 1px;
  background-color: gray;
}


/* ----- RAIE ----- */

.raie-viewer {
    width: var(--entry-width);
    height: 98.5vh;
    float: right;
    overflow-y: scroll;
    overflow-x: hidden;
    display: none;
}

.check-container {
  margin-left: var(--left-padding);
  background-color: black;
  padding: 10px;
  border-radius: 5px;
  /* transform: scale(1, -1) rotate(90deg); */
}

.raie-check {
  width: var(--raie-check-size);
  height: var(--raie-check-size);
  display: inline-block;
  background-color: gray;
  margin-right: 3px;
  
  padding: 3px;
  position: relative;
  border-radius: 2px;
  user-select: none;
}
.raie-check-special {
  border: 3px solid #A4C9FF;
  width: 6px;
  height: 6px;
}
.raie-check-invisible {
  width: var(--raie-check-size);
  height: var(--raie-check-size);
  display: inline-block;
  background-color: black;
  margin-right: 3px;
  
  padding: 3px;
  position: relative;
  border-radius: 2px;
  user-select: none;
}

/* ----- MSC ----- */

.msc-viewer {
    width: var(--entry-width);
    height: 98.5vh;
    float: right;
    overflow-y: scroll;
    overflow-x: hidden;
    display: none;
}

.daytitle {
  float: right;
  padding-right: 20px;
}

.msc-viewer p {
  white-space: pre-wrap;
  padding-left: 20px;
  width: 1050px;
}

.msc-viewer h3 {
  padding-left: 20px;
  padding-top: 10px;
  border-top: 1px solid gray;
}

button.random-day {
  margin-left: 20px;
  margin-top: 10px;
  width: 131px;
  padding: 3px;
  font-family: Consolas;
  color: white;
  font-size: 14px;
  text-align: center;
  background-color: #323256;
  position: relative;
  border-radius: 3px;
  border: 1px solid #7878ff;
  user-select: none;
}

/* LTRS */

.ltrs-container {
    width: 425px; /* 540px; */
    height: 98.5vh;
    float: left;
    overflow-y: scroll;
    background: black;
    padding-top: 2px;
    display: none;
}

button.desc-button {
  margin-left: 17px;
  margin-top: 10px;
  width: 181px;
  padding: 3px;
  font-family: Consolas;
  color: white;
  font-size: 14px;
  text-align: center;
  background-color: #323256;
  position: relative;
  border-radius: 3px;
  border: 1px solid #7878ff;
  user-select: none;
}

button.random-day:hover, button.desc-button:hover {
  background-color: #6f6fa9;
}

.msc-viewer .song {
  margin-left: 20px;
  color: #7ce960;
  background-color: #343c44;
  font-weight: bold;
  font-style: italic;
  font-size: 14px;
}

/* ----- RMBR ----- */

.rmbr-viewer {
    width: var(--entry-width);
    height: 98.5vh;
    float: right;
    overflow-y: scroll;
    overflow-x: hidden;
    display: none;
}

/* ----- SONGS ----- */

.songs-viewer {
    width: var(--entry-width);
    height: 98.5vh;
    float: right;
    overflow-y: scroll;
    overflow-x: hidden;
    display: none;
}