﻿html {
  height: 100%;
  width: 100%;
}
* {
  margin: 0;
  padding: 0;
}
h1 {
  display: inline-block;
  font-weight: normal;
  margin-block-end: unset;
  margin-block-start: unset;
  margin-inline-start: unset;
  margin-inline-end: unset;
}
body {
  font-family: "Palatino Linotype", "Book Antiqua", Palatino, serif;
  overflow: hidden;
  width: 100%;
  height: 100%;
}
#loading {
  position: fixed;
  margin: 20px;
  font-size: x-large;
}
.header {
  padding-left: env(safe-area-inset-left, 0);
  height: 75px;
  white-space: nowrap;
}
.header div,
.header h1 {
  display: inline-block;
}
.header .name {
  font-size: 48px;
  padding: 5px 10px;
}
.header .button {
  cursor: pointer;
}
.header .button:hover {
  background-color: #E0E8FF;
}
.header .headeritem {
  font-size: larger;
  padding: 2px 10px 1px 10px;
}
.header .headeritem.selected {
  border-bottom: 1px dotted black;
}
.header a {
  color: black;
  text-decoration: none;
}
.scrollindicator {
  width: 100%;
  height: 2px;
}
.scrollindicator .scrollbar {
  height: 2px;
  background-color: black;
  width: 0;
}
.content {
  position: absolute;
  left: 0;
  top: 79px;
  bottom: 0;
  right: 0;
  -webkit-overflow-scrolling: touch;
  overflow-y: auto;
  overflow-x: hidden;
}
.content.noscroll {
  overflow-y: hidden;
}
.view.shows .show {
  cursor: pointer;
  display: block;
  float: left;
  width: 33.33333333%;
  min-width: 512px;
  height: 548px;
}
.view.shows .show table {
  height: 100%;
  width: 100%;
  table-layout: fixed;
}
.view.shows .show table td.image {
  vertical-align: middle;
  text-align: center;
  height: 508px;
  width: 512px;
  background-color: black;
}
.view.shows .show table td.image img {
  max-width: 508px;
  max-height: 502px;
}
.view.shows .show table td.caption {
  background-color: black;
  color: white;
  font-size: x-large;
  position: relative;
  bottom: 3px;
  text-align: center;
  height: 36px;
  padding: 0 5px;
  white-space: nowrap;
  overflow-x: hidden;
  text-overflow: ellipsis;
}
.view.shows .show .titlebar {
  background-color: grey;
  opacity: 0.7;
}
.view.shows .show .titlebar div {
  font-size: 21pt;
  padding-left: 5px;
}
.view.shows .show.selected table td {
  background-color: grey;
}
@media screen and (max-width: 1555px) {
  .view.shows .show {
    width: 50%;
    min-width: 512px;
    height: 548px;
  }
  .view.shows .show table td.image {
    height: 508px;
    width: 512px;
  }
  .view.shows .show table td.image img {
    max-width: 508px;
    max-height: 502px;
  }
}
@media screen and (max-width: 1042px) {
  .view.shows .show {
    width: 50%;
    min-width: 400px;
    height: 432px;
  }
  .view.shows .show table td.image {
    height: 396px;
    width: 400px;
  }
  .view.shows .show table td.image img {
    max-width: 396px;
    max-height: 390px;
  }
  .view.shows .show table td.caption {
    font-size: large;
    height: 32px;
  }
}
@media screen and (max-width: 816px) {
  .view.shows .show {
    width: 100%;
    min-width: 512px;
    height: 548px;
  }
  .view.shows .show table td.image {
    height: 508px;
    width: 512px;
  }
  .view.shows .show table td.image img {
    max-width: 508px;
    max-height: 502px;
  }
  .view.shows .show table td.caption {
    font-size: x-large;
    height: 36px;
  }
}
@media screen and (max-width: 520px) {
  .view.shows .show {
    width: 100%;
    min-width: 400px;
    height: 436px;
  }
  .view.shows .show table td.image {
    height: 396px;
    width: 400px;
  }
  .view.shows .show table td.image img {
    max-width: 396px;
    max-height: 390px;
  }
  .view.shows .show table td.caption {
    font-size: large;
    height: 36px;
  }
}
@media screen and (max-width: 410px) {
  .view.shows .show {
    width: 100%;
    min-width: 350px;
    height: 386px;
  }
  .view.shows .show table td.image {
    height: 346px;
    width: 350px;
  }
  .view.shows .show table td.image img {
    max-width: 346px;
    max-height: 340px;
  }
  .view.shows .show table td.caption {
    font-size: large;
    height: 36px;
  }
}
@media screen and (max-width: 350px) {
  .view.shows .show {
    width: 100%;
    min-width: 300px;
    height: 336px;
  }
  .view.shows .show table td.image {
    height: 296px;
    width: 300px;
  }
  .view.shows .show table td.image img {
    max-width: 296px;
    max-height: 290px;
  }
  .view.shows .show table td.caption {
    font-size: large;
    height: 36px;
  }
}
h1.showtitle {
  border-bottom: none;
  display: none;
  font-size: 36px;
  padding-left: 15px;
  font-weight: normal;
}
h1.showtitle.button {
  cursor: pointer;
}
h1.showtitle.button:hover {
  background-color: #E0E8FF;
}
.view.show h1 {
  font-size: 36px;
  padding-left: 15px;
  font-weight: normal;
}
.view.show .notes h1 {
  font-size: 28px;
  padding-top: 0;
  padding-left: 15px;
}
.view.show .notes .notecontainer {
  margin: 10px 30px;
  border: 1px solid black;
  padding: 5px 10px;
  background: #EEE;
  cursor: pointer;
}
.view.show .notes .notecontainer .title {
  font-weight: bold;
}
.view.show .notes .notecontainer p {
  margin-bottom: 15px;
  /*text-indent:30px;*/
  text-align: justify;
  margin-right: 15px;
}
.view.show .notes .notecontainer p a {
  color: black;
}
.view.show .notes .notecontainer p a:hover {
  background-color: #e0e8ff;
}
.view.show .notes .notecontainer p.quote {
  text-align: center;
  font-style: italic;
}
.view.show .notes .notecontainer p.attribution {
  text-align: right;
  margin-top: -15px;
}
.view.show .notes .notecontainer .more {
  display: none;
}
.view.show .notes .notecontainer .readmore {
  margin-left: 15px;
  color: blue;
  text-decoration: underline;
  cursor: pointer;
  text-align: right;
}
.view.show .notes .notecontainer .sig {
  text-align: right;
  font-weight: bold;
}
.view.show .picture {
  cursor: pointer;
  display: block;
  float: left;
  width: 16.66666667%;
  min-width: 300px;
  height: 300px;
}
.view.show .picture table {
  height: 100%;
  width: 100%;
}
.view.show .picture table td {
  vertical-align: middle;
  text-align: center;
  height: 296px;
  width: 300px;
  background-color: black;
}
.view.show .picture table td img {
  max-width: 296px;
  max-height: 290px;
}
.view.show .picture table td p {
  color: white;
  font-size: larger;
  font-style: italic;
}
.view.show .picture.selected table td {
  background-color: grey;
}
/*@media screen and (max-width:2410px) {
    .view.show .picture {
        width:(100%/7);
    }
}*/
/*@media screen and (max-width:2125px) {
    .view.show .picture {
        width:(100%/6);
    }
}*/
@media screen and (max-width: 1820px) {
  .view.show .picture {
    width: 20%;
  }
}
@media screen and (max-width: 1520px) {
  .view.show .picture {
    width: 20%;
    min-width: 256px;
    height: 256px;
  }
  .view.show .picture table td {
    height: 252px;
    width: 256px;
  }
  .view.show .picture table td img {
    max-width: 252px;
    max-height: 246px;
  }
}
@media screen and (max-width: 1300px) {
  .view.show .picture {
    width: 25%;
  }
}
@media screen and (max-width: 1050px) {
  .view.show .picture {
    width: 33.33333333%;
  }
}
@media screen and (max-width: 790px) {
  .view.show .picture {
    width: 50%;
  }
}
@media screen and (max-width: 512px) {
  .view.show .picture {
    width: 100%;
  }
}
/*.view {
    position:absolute;
    height:100%;
    width:100%;
    left:0px;
}*/
.loading {
  display: block;
  margin: auto;
  max-width: 100%;
  max-height: 100%;
  position: absolute;
  left: 0px;
  right: 0px;
  top: 0px;
  bottom: 0px;
}
.view.picture .picture {
  position: absolute;
  top: 2px;
  left: 0;
  right: 0;
  bottom: 62px;
}
.view.picture .picture img {
  visibility: hidden;
  display: block;
  position: absolute;
  left: 0px;
  right: 0px;
  top: 0px;
  bottom: 0px;
}
.view.picture .details {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 62px;
  background-color: white;
  display: flex;
}
.view.picture .details .row {
  text-align: center;
}
.view.picture .details .row .name {
  font-size: 24px;
  overflow: hidden;
  text-overflow: ellipsis;
  width: 100%;
  white-space: nowrap;
}
.view.picture .details .row div {
  display: inline-block;
}
.view.picture .details .row2 div {
  margin: 0px 10px;
}
.view.picture .details .row1 {
  margin-top: 4px;
}
.view.picture .details a {
  color: black;
  text-decoration: none;
}
.view.picture .details a:hover {
  background-color: #e0e8ff;
}
.view.picture .details .moveprevious,
.view.picture .details .movenext {
  font-size: 5vw;
  cursor: pointer;
  width: 5vw;
  align-self: center;
}
.view.picture .details .centerblock {
  width: 90vw;
}
@media all and (min-width: 1800px) {
  .view.picture .details .moveprevious,
  .view.picture .details .movenext {
    font-size: 90px;
    width: 90px;
  }
}
.view.picture .noimage {
  color: black;
  text-align: center;
}
.view.all .searchspacer {
  height: 8px;
}
@media only screen and (max-width: 480px), only screen and (max-device-width: 480px) {
  .view.all .allsearch {
    display: none !important;
  }
}
.view.all .allsearch {
  display: flex;
  flex-direction: row;
  position: fixed;
  right: 18px;
  left: 0;
  color: blue;
  background-color: white;
}
.view.all .allsearch input[type='text']:focus,
.view.all .allsearch input[type='number']:focus,
.view.all .allsearch textarea:focus {
  font-size: 2em;
}
.view.all .allsearch input,
.view.all .allsearch label {
  font-size: 20px !important;
}
.view.all .allsearch input:focus {
  font-size: 2em;
}
.view.all .allsearch label {
  margin-left: 8px;
  margin-right: 5px;
}
.view.all .allsearch input {
  width: 100%;
}
.view.all table {
  cursor: pointer;
  border-collapse: collapse;
  margin: 2px;
  margin-top: 10px;
  width: 100%;
  /*tr:nth-child(odd) {
                background-color: #eee;
            }

            tr:nth-child(even) {
                background-color: #fff;
            }*/
  /*td {
            white-space:nowrap;
        }*/
}
.view.all table tr.hidden {
  display: none;
}
.view.all table tr {
  height: 48px;
  overflow: hidden;
}
.view.all table tr.picture {
  border-bottom: 1px solid #EEE;
}
.view.all table tr:hover {
  background-color: #E0E8FF;
}
.view.all table td.showtitle {
  background-color: white;
  font-size: 36px;
  cursor: default;
  padding-left: 5px;
  border-bottom: 1px solid black;
}
.view.all table tbody:first-child tr.showtitle {
  height: 48px;
}
.view.all table tr.showtitle {
  height: 78px;
  vertical-align: bottom;
}
.view.all table .name {
  font-size: large;
  padding-left: 15px;
}
@media screen and (max-width: 1475px) {
  .view.all table {
    font-size: smaller;
  }
}
@media screen and (max-width: 1475px) {
  .view.all table {
    /*td {
                white-space:normal;
            }*/
    /*.name {
                font-size: small;
            }*/
  }
}
@media screen and (max-width: 510px) {
  .view.all table {
    /*td {
                white-space:normal;
            }*/
    /*.name {
                font-size: small;
            }*/
  }
  .view.all table tr .showtitle {
    font-size: 30px;
  }
  .view.picture .details .row2 div,
  .details .row2 div {
    margin: 0px 0px !important;
  }
  .view.picture .details .row2 div::after,
  .details .row2 div::after {
    content: " ▪ ";
  }
  .view.picture .details .row2 div:last-child::after,
  .details .row2 div:last-child::after {
    content: "";
  }
}
.noimagetitle {
  color: white;
}
.noimage {
  color: white;
  font-style: italic;
  margin-top: 5px;
}
.footer {
  clear: both;
  text-align: center;
  font-style: italic;
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  display: none;
}
.footer a {
  color: blue;
}
.footer a:visited {
  color: blue;
}
.footer div {
  display: inline-block;
}
.mode-shows .footer,
.mode-show .footer,
.mode-cv .footer,
.mode-all .footer {
  display: block;
}
.mode-shows .content,
.mode-show .content,
.mode-cv .content,
.mode-all .content {
  bottom: 1.5em;
}
@media screen and (max-width: 900px) {
  .mode-shows .footer,
  .mode-show .footer,
  .mode-cv .footer,
  .mode-all .footer {
    position: relative;
  }
  .mode-shows .content,
  .mode-show .content,
  .mode-cv .content,
  .mode-all .content {
    bottom: 0;
  }
  .header div.headeritem.currentnav,
  .header h1.headeritem.currentnav {
    display: none;
  }
  h1.showtitle {
    display: block;
  }
  .view.show h1.showtitle,
  h1.showtitle {
    text-align: center;
  }
  .view.picture .picture {
    top: 50px;
  }
}
@media screen and (max-width: 800px) {
  .header {
    height: 105px;
    text-align: center;
  }
  .header h1.name.button,
  .header div.name.button {
    display: block;
  }
  .header div.headeritem.currentnav {
    display: none;
  }
  .header div.headeritem {
    color: darkblue;
  }
  .header div.headeritem a {
    color: darkblue;
  }
  .view.show h1.showtitle,
  h1.showtitle {
    text-align: center;
    font-size: 30px;
  }
  .view.picture .picture {
    top: 48px;
  }
  .content {
    top: 108px;
  }
  .search {
    top: 108px !important;
  }
}
@media screen and (max-width: 700px) {
  .footer .footersep {
    display: none;
  }
  .footer span {
    display: block;
  }
  .view.show h1.showtitle,
  h1.showtitle {
    text-align: center;
    font-size: 27px;
  }
}
@media screen and (max-width: 600px) {
  .view.show h1.showtitle,
  h1.showtitle {
    text-align: center;
    font-size: 26px;
  }
}
@media screen and (max-width: 500px) {
  .view.show h1.showtitle,
  h1.showtitle {
    text-align: center;
    font-size: 24px;
  }
}
.nowrap {
  white-space: nowrap;
}
@media screen and (max-width: 360px) {
  .header {
    font-size: smaller;
    height: 85px;
  }
  .header div.name.button,
  .header h1.name.button {
    display: block;
    font-size: 36px;
  }
  .content {
    top: 88px;
  }
  .search {
    top: 88px !important;
  }
}