/* base / home page styles */
:root {
    --show1-color: #ee4037;
    --show2-color: #ee4037;
}
body {
    font-family: 'Montserrat', sans-serif;
    font-size: 1em;
    line-height: 1.2;
}
a, a:link, a:visited, a:hover, a:active {
    color: var(--show1-color, #073d93);
    font-weight: 600;
    text-decoration: none;
}
p {
    margin-bottom: 1em;
}
strong {
    font-weight: 600;
}
.defined-icon {
    display: none;
}
header {
    margin-bottom: 3vh;
}
header svg {
    width: 90vw;
    display: block;
    margin: 1vh auto;
}
header svg .sundays {
    fill: var(--show1-color, white);
}
header p,
#contact h2 {
    font-family: 'Rubik', sans-serif;
    font-weight: 500;
    text-align: center;
}
header p {
    margin-bottom: 0.3em;
}
header p span,
nav a {
    font-weight: 700;
}
header #season {
    font-size:1.3em;
    color: var(--show1-color, #666);
}
nav {
    font-size: 0.8em;
    text-align: center;
}
nav ul,
nav ul li {
    display: inline;
}
nav li a::after {
    content: '\00A0\00B7';
}
nav li:last-of-type a::after {
    content: none;
}
article, section {
    margin: 3vh 0;
    padding: 0 3vw;
}
article > div {
    background-color: #666;
    color: #fff;
    display: flex;
    justify-content: center;
    align-items: center;
    font-family: 'Rubik', sans-serif;
    font-size: 1.1em;
    font-weight: 700;
    padding: 3vh 0;
}
article#show1 > div {
    background-color: var(--show1-color, #666)
}
article#show2 > div {
    background-color: var(--show2-color, #666)
}
article#show3 > div {
    background-color: var(--show3-color, #666)
}
article > div > h1 {
    text-shadow: 2px 2px 2px black;
}
article > div > h1 + a {
    display: block;
    line-height: 0;
    margin-left: 3vw;
}
article > div svg {
    width: 12vw;
}
article > div + div#showtheme {
    background: none;
    color: #000;
    display: block;
    font-size: 0.9em;
    font-weight: 400;
    text-align: center;
    padding-top: 2vh;
    padding-bottom: 0;
}
#showtheme h2 {
    font-size: 1.1em;
    font-weight: 700;
    margin-bottom: 1vh;
}
#showtheme p {
    margin: 0;
}
article > div + p span {
    white-space: nowrap;
}
dl {
    margin: 5vh 0;
}
dt div,
#fourfor .performer div {
    width: 8rem;
    height: 8rem;
    background-color: #000;
    border-radius: 50%;
    margin: 0 auto;
    display: flex;
    justify-content: center;
    align-items: center;
}
dt img,
#fourfor .performer div img {
    border-radius: 50%;
}
dt img {
    width: 90%;
    filter: grayscale(1);    
}
#fourfor .performer div img {
    width: 100%;
}
dd h2 {
    font-family: 'Rubik', sans-serif;
    font-size: 1.2em;
    font-weight: 700;
    text-transform: uppercase;
    text-align: center;
}
dd h2 + p {
    font-family: 'Rubik', sans-serif;
    font-size: 1.1em;
    font-weight: 500;
    font-style: italic;
    text-align: center;
    margin-top: 0;
}
dd p {
    font-size: 0.9em;
    margin: 2vh 0;
}
dd .vidlink {
    display: flex;
    justify-content: center;
    align-items: center;
}
dd .vidicon {
    width: 8vw;
    margin-right: 2vw;
}
article#show1 dd .vidicon path {
    fill: var(--show1-color, black);
}
footer {
    display: flex;
    justify-content: flex-start;
    align-content: flex-start;
    padding: 2vh 2vw;
    border-top: 2px dashed #000;
}
footer a {
    display: inline-block;
    margin-right: 2vw;
}
footer svg {
    width: 10vw;
}
footer div {
    flex-grow: 1;
}
footer p {
    text-align: right;
    font-size: 0.7em;
    margin: 0.3vh 0;
}
footer div span {
    white-space: nowrap;
}
.video {
    display: none;
}
.video:target {
    position: fixed;
    left: 20vw;
    top: 10vh;
    display: block;
}
.video:target::before {
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    position: fixed;
    background-color: rgba(0,0,0,.85);
    content: "";
    cursor: default;
}
.video div {
    position: relative;
    width: 60vw;
    height: 33.75vw;
}
.video iframe {
    z-index: 1;
    width: 100%;
    height: 100%;
}
.video .close {
    position: relative;
    display: block;
}
.video .close::after {
    right: -1vmax;
    top: -1vmax;
    width: 2vmax;
    height: 2vmax;
    position: absolute;
    display: flex;
    z-index: 2;
    align-items: center;
    justify-content: center;
    background-color: white;
    border-radius: 50%;
    color: black;
    content: "x";
    cursor: pointer;
    font-size: 0.5em;
}

/* map / contact page styles */
#venuemap {
    height: 0;
    padding-bottom: 75%;
    margin: 3vh auto;
    position: relative;
}
#venuemap iframe {
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
}
#map p {
    font-size: 0.9em;
    line-height: 1.4;
    text-indent: 7%;
}
#map p a {
    font-weight: 600;
}
#contact h2 {
    font-size: 1.2em;
    margin-bottom: 2vh;
    text-align: left;
}
#mailsent {
    display: none;
    background-color: #ccc;
    font-size: 1em;
    font-style: italic;
    padding: 2vmin;
    border: 1px solid #000;
    border-radius: 5px;
    margin-top: 3vh;
}
#contact div {
    display: flex;
    align-content: flex-start;
    justify-content: flex-start;
    margin-bottom: 2vh;
}
#contact form input,
#contact form textarea {
    font-family: 'Montserrat', sans-serif;
    font-size: 0.8em;
}
#contact form input[type="text"],
#contact form input[type="email"] {
    width: 30vw;
}
#contact form textarea {
    width: 60vw;
    height: 20vh;
}
#contact label {
    margin: 0.5vh 1.8vw 0 0;
}
#contact input[type="text"]:focus,
#contact input[type="email"]:focus,
#contact textarea:focus {
    background-color: rgba(66, 217, 244, 0.5);
}
#contact input[type="submit"] {
    padding: 1.5vmin;
    background-color: #073d93;
    border: none;
    color: #fff;
}

/* 4 for page styles */
#fourfor #logo {
    width: 65vw;
    margin: 5vh auto 3vh;
    position: relative;
}
#fourfor #logo img {
    position:absolute;
    top: 6%;
    left: 42.5%;
    width: 30%;
    border-radius: 50%;
}
#fourfor #links {
    display: flex;
    justify-content: space-between;
}
#fourfor .performer {
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    align-content: flex-start;
    align-items: center;
    width: 25vw;
}
#fourfor .performer div {
    width: 5rem;
    height: 5rem;
    margin: 0 0 1vh 0;
}
#fourfor .performer a {
    display: block;
    width: 70%;
    font-family: 'Rubik', sans-serif;
    font-size: 0.8em;
    font-weight: 500;
    text-align: center;
}
#fourfor article h1 {
    font-family: 'Rubik', sans-serif;
    font-size: 1.5em;
    font-weight: 500;
    text-align: center;
    color: var(--show1-color, black);
    margin-bottom: 2vh;
}
#fourfor aside:first-of-type {
    border-bottom: 1px solid var(--show1-color, black);
    margin-bottom: 1em;
}
#fourfor p {
    font-size: 0.9em;
    line-height: 1.3;
}
#fourfor blockquote {
    font-size: 1.1em;
    font-weight: 700;
    margin-left: 7%;
    margin-bottom: 3vh;
}
#fourfor article p,
#fourfor aside p {
    text-indent: 7%;
}
#fourfor article p {
    position: relative;
}
#fourfor .q {
    color: var(--show1-color, black);
}
#fourfor .num {
    display: block;
    position: absolute;
    top: 0;
    left: -6%;
    font-size: 1em;
}
#fourfor .name {
    font-weight: 600;
}
#fourfor em {
    font-style: italic;
}
#fourfor .author {
    text-align: right;
}
#fourfor .about-lh {
    border-top: 1px solid var(--show1-color, black);
    padding-top: 1em;
}
#fourfor .about-lh div {
    float: left;
    width: 30vmin;
    height: 30vmin;
    border-radius: 50%;
    overflow: hidden;
    margin: 0 2vmin 1vmin 0;
}
#fourfor .about-lh div img {
    width: 100%;
}
#fourfor .about-lh p {
    font-size: 0.8em;
    text-indent: 0;
}
#fourfor .about-lh p:first-of-type {
    font-family: 'Rubik', sans-serif;
    font-size: 1em;
    font-weight: 500;
    color: var(--show1-color, black);
    margin-bottom: 0.3em;
}
#fourfor + footer {
    clear: both;
}

@media only screen and (min-width : 640px) {                
    header {
        display: flex;
        align-items: center;
        justify-content: space-between;
        margin-top: 2vh;
        padding-bottom: 0;
    }
    header svg {
        width: 50vw;
        margin: 0 3vw;
    }
    header div * {
        text-align: right;
    }
    header div {
        margin-right: 3vw;
    }
    header p {
        font-size: 1.1em;
    }
    article > div {
        font-size: 1.3em;
        padding: 1.5vh 0;
    }
    article > div > h1 + a {
        margin-left: 1vw;
    }
    article > div svg {
        width: 8vw;
    }
    article > div + p {
        font-size: 1em;
        font-weight: 700;
    }
    article > div + div#showtheme {
        font-size: 1.3em;
        font-weight: 400;
        margin-top: 2vh;
    }
    #showtheme h2 {
        font-size: 1.1em;
        font-weight: 700;
        margin-bottom: 1vh;
    }
    dl {
        display: flex;
        align-items: center;
        justify-content: center;
        margin: 8vh 0;
    }
    dt div {
        width: 10rem;
        height: 10rem;
        margin-right: 3vw;
    }
    dd {
        flex-grow: 1;
    }
    dd h2, dd h2 + p {
        text-align: left;
    }
    dd .vidlink {
        justify-content: flex-start;
    }
    dd .vidicon {
        width: 5vw;
        margin-right: 1vw;
    }
    footer svg {
        width: 7vw;
    }
    .video .close::after {
        font-size: 0.8em;
    }
    #map {
        margin-top: 5vh;
    }
    #map p {
        text-indent: 5%;
    }
    #venuemap {
        width: 50%;
        padding-bottom: 37.5%;
        margin: 0 2vmin 1vmin 0;
        float: left;
    }
    #contact {
        clear: both;
    }
    #fourfor #logo {
        width: 55vw;
    }
    #fourfor #links {
        margin-bottom: 5vh;
    }
    #fourfor .performer {
        width: 30vw;
    }
    #fourfor .performer div {
        width: 10rem;
        height: 10rem;
    }
    #fourfor .performer a {
        font-size: 1.2em;
        width: 80%;
    }
    #fourfor article h1 {
        font-size: 2em;
    }
    #fourfor p {
        font-size: 1.1em;
    }
    #fourfor .about-lh p {
        font-size: 1em;
    }
    #fourfor .about-lh p:first-of-type {
        font-size: 1.2em;
    }
}

@media only screen and (min-width : 768px) {
    header {
        margin-bottom: 0;
    }
    header div p {
        font-size: 1.3em;
    }
    nav a {
        font-size: 1.2em;
    }
    nav li a::after {
        content: '\00A0\00A0\00B7\00A0';
    }
    article {
        margin: 2vh 0;
    }
    article > div {
        font-size: 1.5em;
        padding: 1vh 0;
    }
    article > div > h1 + a {
        margin-left: 2vw;
    }
    article > div svg {
        width: 8vw;
    }
    article > div + p {
        font-size: 1.2em;
        margin-top: 1vh;
    }
    dl {
        margin: 3vh 0;
    }
    dt div {
        padding: 0;
    }
    dd h2 {
        font-size: 1.3em;
    }
    dd h2 + p {
        font-size: 1.2em;
        margin-bottom: 0;
    }
    dd p {
        font-size: 1.1em;
        margin: 1vh 0;
    }
    footer {
        padding: 2vh 2vw 4vh;
    }
    footer svg {
        width: 7vw;
    }
    footer p {
        font-size: 0.8em;
    }
    .video .close::after {
        font-size: 1em;
    }
    #venuemap + div {
        font-size: 1em;
    }
    #contact form {
        width: 59vw;
        display: flex;
        justify-content: flex-start;
        align-content: flex-start;
        flex-wrap: wrap;
    }
    #contact label {
        margin: 0.3vh 1vw 0 0;
    }
    #contact form input[type="text"],
    #contact form input[type="email"] {
        width: 20vw;
    }
    #contact form input[type="text"] {
        margin-right: 2.5vw;        
    }
    #contact form textarea {
        width: 30vw;
    }
    #contact input[type="submit"] {
        font-size: 1em;
        padding: 1vmin;
        align-self: flex-end;
    }
    #fourfor #links {
        margin-bottom: 3vh;
    }
    #fourfor article h1 {
        font-size: 2.3em;
    }
    #fourfor .num {
        left: -5%;
        font-size: 1.2em;
    }
    #fourfor .about-lh div {
        width: 25vmin;
        height: 25vmin;
    }
}

@media only screen and (min-width : 992px) {
    header p {
        font-size: 1.8em;
    }
    nav a {
        font-size: 1.3em;
    }
    article > div svg {
        width: 5vw;
    }
    dl {
        width: 75vw;
        margin-left: auto;
        margin-right: auto;
    }
    dt div {
        width: 12rem;
        height: 12rem;
    }
    dd .vidicon {
        width: 4vw;
    }
    footer svg {
        width: 4vw;
    }
    footer p {
        font-size: 0.9em;
    }
    #map {
        margin-bottom: 5vh;
    }
    #venuemap {
        width: 30%;
        padding-bottom: 22.5%;
    }
    #contact form {
        width: 57vw;
    }
    #contact form textarea {
        width: 40vw;
    }
    #fourfor .num {
        left: -4%;
    }
    #fourfor .about-lh div {
        width: 20vmin;
        height: 20vmin;
    }
}