@font-face
{
	font-family: 'FreeLoader';
	src: url('/fonts/freebooterupdated-webfont.woff2') format('woff2');
}

@font-face
{
	font-family: 'Lucida Grande';
	src: url('/fonts/lucidagrande-webfont.woff2') format('woff2');
}


@font-face
{
	font-family: 'Lucida Grande';
	src: url('/fonts/lucidagrandebold-webfont.woff2') format('woff2');
	font-weight: bold;
}

@font-face
{
	font-family: 'Optima';
	src: url('/fonts/optima-webfont.woff2') format('woff2');
}

@font-face
{
	font-family: 'Oswaldo';
	src: url('/fonts/raleway-regular-webfont.woff2') format('woff2');
}

@font-face
{
	font-family: 'Oswaldo';
	src: url('/fonts/raleway-bold-webfont.woff2') format('woff2');
	font-weight: 700;
}

@font-face
{
	font-family: 'Oswaldo';
	src: url('/fonts/raleway-extrabold-webfont.woff2') format('woff2');
	font-weight: 800;
}

@font-face
{
	font-family: 'Oswaldo';
	src: url('/fonts/raleway-black-webfont.woff2') format('woff2');
	font-weight: 900;
}

	footer > form > span:first-of-type
	{
		display: none;
	}
@media (prefers-color-scheme: light),
(prefers-color-scheme: dark),
(prefers-color-scheme: no-preference)
{
	footer > form > span:first-of-type
	{
		display: inline;
	}
}

html {-webkit-text-size-adjust:none}

body
{
	background: #000;
	color: #ddd;
/*     max-width: 1024px; */
    max-width: 1280px;
	margin: 0 auto;
	font-family: Lucida Grande, Helvetica, Arial, sans-serif;
}

a,
button
{
	color: #6684C9;
	text-decoration: none;
	display: inline-block;

	background: none;
	font: inherit;
	padding: 0;
	border: 0;
}

a:hover,
button:hover
{
	color: #C4D7FF;
/* 	color: white; */
/*     text-shadow: 0 0 2em #fff; */
/*     color: #223b75; */
}

address
{
	font-style: normal;
}

.nowrap
{
	white-space: nowrap;
}

	body > label
	{
		padding: 1rem 2rem;
		z-index: 2;
		background: rgba(0, 0, 0, 0.5);
		display: block;
		position: sticky;
		top: 0;
		font-weight: bold;
	}

	body > input
	{
		position: fixed;
		left: 0;
		opacity: 0;
	}

	body > header
	{
		display: none;
	}

	body > input:checked + header
	{
		display: block;
	}

/*
    nav ul
    {
    	box-sizing: border-box;
    	height: 100%;
    	overflow: hidden;
    }
 */

	body > input:checked ~ main,
	body > input:checked ~ footer
	{
		display: none;
	}







body > header
{
	grid-area: nav;
}

main
{
	padding-top: 2rem;
/* 	padding-right: 1rem; */
	grid-area: main;
/* 	margin: 0 auto; */
/* 	max-width: 1024px; */
}

main > section
{
	padding: 0 1rem;
}

nav
{
	/*background: linear-gradient(to right, #000, #0C2355, #5E7DC2, #fff, #838698); */
    /* padding: 1rem; */
    font-family: Optima;
    font-size: 1.5rem;
		text-align: center;
/*     height: 100%; */
    background: #334265;
/*     box-sizing: border-box; */
    /* background: linear-gradient(to right, #000, #334265); */
    /* background: linear-gradient(to right, #000, #223b75, #334265); */
    /* background: linear-gradient(to right, #000, #223b75); */
    /* background: radial-gradient(ellipse at left top, transparent, #000); */
    background: radial-gradient(ellipse at right top, #000, #334265);
    position: sticky;
    top: 0;
}

nav ul
{
	list-style: none;
	margin: 0;
/* 	height: 100%; */
	padding: 2rem 1rem 10rem;
/* 	padding-top: 2rem; */
/*     box-sizing: border-box; */
/* 	background: radial-gradient(ellipse at left top, transparent 59%, #000); */
/* 	background: radial-gradient(ellipse at right top, transparent 59%, #000 69%); */
		background: url(/images/logo.png) no-repeat;
		background-position: center top;
    padding-top: 10rem;
}

nav li + li
{
	margin-top: 1rem;
}

nav a
{
/* 	color: #fff; */
}

main > section header h2,
main > section header h3,
main > section header h4,
main > section header h5
{
	margin: 0;
}

h3
{
	font-size: 1.3em;
}

h4
{
	font-size: 1.2em;
}

main > header
{
	text-align: center;
}

main > header h1,
main > header h2
{
	font-family: FreeLoader;
	margin: 0;
}

main > header h1
{
    font-size: 14vw;
    line-height: 0.7;
    text-shadow: 0 0 0.1em #fff;
    color: #223b75;
}

main > header h2
{
    font-size: 6vw;
    color: #aaa;
	font-weight: normal;
}

main > header h2::before
{
	content: "... ";
}

section.secondary_header
{
	text-align: center;
	margin-bottom: 2rem;
}

main > section header h1
{
	font-size: 2rem;
	border-bottom: 1px solid;
	grid-area: h1;
}

.tickets
{
	text-align: center;
	margin: 3rem 0;
}

.tickets a
{
	font-size: 1.5rem;
}

button
{
	border: 2px solid;
	padding: 0.5rem 1rem;
	border-radius: 0.5rem;
	cursor: pointer;
}

.show_details
{
	text-align: center;
    background: #222;
    padding: 0.5rem 1rem;
    border-radius: 1rem;
    border: 4px outset;
}

li:nth-child(2n) .show_details
{
	background: #161616;
}

.show_details p.title
{
	font-size: 1.5rem;
    margin: 0;
}

.show_details p.byline
{
	margin: 0.5rem 0 0 0;
}

.show_details p.category
{
	font-style: italic;
}

.show_details p.synopsis
{
	text-align: start;
}

footer
{
	grid-area: footer;
	padding: 1rem;
	border-top: 1px solid;
	margin-top: 2rem;
	display: flex;
}

footer > form,
footer > div
{
	flex: 1;
}

footer > form
{
	margin: 0;
	color: #666;
	display: none;
	font-weight: bold;
}

footer > form label
{
	cursor: pointer;
	margin: 0 0.3em;
	padding: 0.1em 0;
}

footer > form input
{
	display: none;
}

footer > form input + label
{
	border-bottom: 3px solid transparent;
}

footer > form input:checked + label
{
	border-bottom: 3px solid;
}

footer > div
{
	text-align: right; /* for old Edge */
	text-align: end;
}

footer > div > :first-child
{
	margin-top: 0;
}

footer address
{
	margin-bottom: 1rem;
}

@media(min-width: 900px)
{
	body
	{
		display: grid;
		grid-template-areas:
							"nav main"
							". footer";
		grid-column-gap: 1rem;
		grid-auto-columns: 1fr 5fr;
	}

	body > label
	{
		display: none;
	}

	body > header
	{
		display: block;
	}

	nav
	{
		text-align: right; /* for Edge ??? */
		text-align: end;
	}

	nav ul
	{
		background: radial-gradient(ellipse at right top, transparent 59%, #000 69%), url(/images/logo.png) no-repeat;
		background-position: 0 0, right 30px;
	}

	main
	{
		padding-right: 1rem;
	}

	main > header h1
	{
		font-size: 12vw;
	}

	main > header h2
	{
		font-size: 5vw;
	}
}

@media(min-width: 1024px)
{
	main > header h1
	{
		font-size: 7.9rem; /* 8rem was too big for Edge ??? */
	}

	main > header h2
	{
		font-size: 3.5rem;
	}
}
