
/* typography */
body {
	background:#000;
	color:#f2f2f2;
	font-family:'Ubuntu', Arial, Helvetica, sans-serif; 
	font-size:1em;
	line-height:1.4em; 
	font-weight:normal;
}
h1, h2, h3, h4, h5, h6{
	font-weight:normal;
	font-family:'Ubuntu', Arial, Helvetica, sans-serif; 
	line-height:1.2em;
	margin:.45em 0;
	padding:0;
} 
span {
	font-style: italic;
}
h1 {
	color: #fff;
	font-size: 1.3em;
	}
h2 {
	color: #d7b230;
	font-size: 1.2em;
	}
h3 {
	color: #fff;
	font-size: 1.2em;
	}
h4 {
	color: #999;
	font-size: 1.1em;
	}

.seated-event-venue-name {
    width: 55%;
}
.seated-event-date-cell {
    margin-bottom: 10px;
}

.seated-events-table {
text-align: left !important;
}

#page-header {
    background: none repeat scroll 0 0 #292a2c;
    color: #dcdcdc;
    font-size: 1.3em;
    margin: 0;
    padding: 6px 0;
    text-align: center;
}
.statement {
	text-align: left;
	padding-top: 20px;
}

/* links */
a,
a:visited,
a:active,
a:hover{color:#d7b230;}
a:hover{ text-decoration:none;}


*{	box-sizing:border-box;
	-moz-box-sizing:border-box;}

  
/* structure */   
.wrapper{
	width: 92%; 
	margin: 2% 4% 0;
}
header{ 
	padding:0;
}
#banner{ 
	text-align:center;
}
#hero{
	padding:0px 0 40px 0;
}
#page-header{
	padding:0;
}
#hero h1{ 
	line-height:1.2em;
	margin-top:0px;
	margin-bottom:10px;}

.flexslider{
	display:none;
}

#content {  
	margin:10px 0;
}

aside { 
	margin:40px 0;
}

p{ margin:0 0 1.2em;}

/* Tables */
table {
	width: 100%; 
	border-collapse: collapse; 
	}
tr {
	margin-bottom: 30px;
	}
tr:nth-of-type(odd) { 
		background: #333; 
	}
th { 
		background: #666; 
		color: white; 
		font-weight: bold; 
	}
td, th { 
		padding: 10px 6px; 
		text-align: center;
	}
.bit-venue {
    margin-left: 10px !important;
}
.button24 {
  background-color: #000; 
  border: 1px solid #d3a82d;
  color: #000;
  width: 100%;
  padding: 6px;
  text-align: center;
  text-decoration: none;
  display: inline-block;
  font-family: "Freeman", sans-serif;
  font-weight: 400;
  font-style: normal;
  font-size: 25px;
  line-height: normal;
  margin: 0px;
  transition-duration: 0.4s;
  cursor: pointer;
}
.button24v1 {
  background-color: #d3a82d; 
  border: 1px solid #d3a82d;
}
.button24v1:hover {
  background-color: #000; 
  border: 1px solid #d3a82d;
  color: #d3a82d;
}
.button24v2 {
background-color: #ec3538; 
  border: 1px solid #ec3538;
}
.button24v2:hover {
background-color: #000; 
  border: 1px solid #ec3538;
  color: #ec3538;
}
.contentNote {
	font-size: .8em;
	font-style: italic;
	color: #f6deb1;
	line-height: 140%;
	margin: 10px 0;
	}
.asideNote {
	margin-bottom: 20px;
	}
/* buttons */
.btn {
	display: block;
	background: #ef1823;
	background-image: -webkit-linear-gradient(top, #ef1823, #96020c);
	background-image: -moz-linear-gradient(top, #ef1823, #96020c);
	background-image: -ms-linear-gradient(top, #ef1823, #96020c);
	background-image: -o-linear-gradient(top, #ef1823, #96020c);
	background-image: linear-gradient(to bottom, #ef1823, #96020c);
	-webkit-border-radius: 8;
	-moz-border-radius: 8;
	border-radius: 8px;
	color: #ffffff;
	padding: 6px;
	margin: 5px;
	font-size: .8em;
	text-decoration: none;
}

.btn:hover {
	background: #fa4951;
	background-image: -webkit-linear-gradient(top, #fa4951, #ab0a12);
	background-image: -moz-linear-gradient(top, #fa4951, #ab0a12);
	background-image: -ms-linear-gradient(top, #fa4951, #ab0a12);
	background-image: -o-linear-gradient(top, #fa4951, #ab0a12);
	background-image: linear-gradient(to bottom, #fa4951, #ab0a12);
	text-decoration: none;
}

.button {
	display:inline-block;
	margin:5px;
	padding: 5px 10px;
	border:1px solid #00A1FF;
	background:#2D2E30;
	font-weight:bold;
	text-transform:uppercase;
	text-decoration:none;
	border-radius:2px;
	-moz-border-radius: 2px; 
	-webkit-border-radius: 2px;
}
a.button:link,a.button:visited,a.button:hover{text-decoration:none;}
a.button:hover {
	border:1px solid #d7b230;
	background:#000;
	
}
.photoCredits {
	color:#999;
	font-size:.9em;
	text-align: left;
	line-height: 1.1em; 
	margin: 5px 0 20px 0;
}
.photoCredits2 {
	color:#999;
	font-size:.8em;
	text-align: right;
	line-height: 1.1em; 
	margin: 5px 0 20px 0;
    font-style: italic;
}

/* Sidebar */
.quicklinks a {
	display: block;
	line-height: 1em;
	font-weight: bold;
	padding: 8px 0; 
	}
	
/* News */
.newsItem {
	border-bottom: 1px solid #333;
	margin: 20px 0;
	padding-bottom: 30px;
	}
.newsItem h3 {
	font-size:1.1em;
	color:#f1c150;
	font-weight:bold;
	margin-top: 2em;
	}
.newsItem h5 {
	font-size:1em;
	color:#a19d9d;
	font-weight:bold;
	}
.newsItem img {
	float: right; 
	margin: .5em 0 .5em 1em;
	}
.newsLeft {
	float: left; 
	width: 65%; 
	}
.newsRight {
	float: right; 
	width: 30%;
	margin: 0 0 0 .5em;
	}
aside p{
	font-size: .9em;
	}
aside h3 {
	margin: 1em 0 .5em 0;
	}
.onlineShows {
	
}
.onlineShows tr {
}
.onlineShows tbody {
	vertical-align: top;
}
.onlineShows td {
	vertical-align: top;
	border: 1px solid #666;
	padding-top: 0px;
}
.onlineshowspics  {
	float: left !important;
	text-align: left;
	margin-bottom: 10px;
}
.onlineshowspics img {
	width: 32%;
	margin: 0px 5px;
}
.osContent {
	padding: 0px 20px;
}
.osContent h3 {
	font-size: 1.7em;
	margin-top: .5em;
}
.osContent h4 {
	color: #fff;
}

.specialOShed {
	font-size: 1.5em;
	color: #ef8293;
	margin: 10px 0 3px 0;
}
.specialOS {
	font-size: 1.2em;
	color: #ef8293;
	line-height: 1.8em;
	margin-bottom: 10px;
}
.specialOSwht {
	font-size: 1.2em;
	color: #fff;
	line-height: 1.8em;
	margin-bottom: 10px;
}
.osNote {
	font-style: italic; 
	font-size: .9em;
    padding: 2px 0 10px 0;
	text-transform:uppercase;
}
.datesOS {
	text-align: left;
}
.datesOS ul {
	text-align: left;
	list-style: none;
	padding: 0px!important;
}
.datesOS ul li {
	text-align: left;
	list-style: none;
	padding: 5px 0;
}
/* Shows */
.date {
      text-align:center;
	width: 15%
}
.dest {
      text-align:center;
	width: 20%
}
.venue {
      text-align:center;
	  line-height: 1.2em;
	width: 20%
}
.acts {
      text-align:center;
	  line-height: 1.2em;
}

.tix {
      text-align:center;
	  line-height: 1.2em;
	width: 20%
}
.buy {
      text-align:center;
	  line-height: 1.2em;
	  color: #fff !important;
}
.buy a:link, .buy a:visited {
	color: #fff !important;
	text-decoration:none;
	}
.soldout {
	color: #ff0000;
	font-weight: bold;
}

/* Film */

.filmItem {
	margin-bottom: 20px;
	padding-bottom: 20px;
	border-bottom: 1px solid #333;
	}
.filmItem img {
	float: right; 
	margin: .5em 0 .5em 1em;
	}

/* Mailchimp Signup Code */
#mc_embed_signup {
	background:#000; 
	clear:left; 
	font-size:14px; 
}
#mc_embed_signup input.button {
    min-width: 90px;
}
#mc_embed_signup form {
    padding: 3px 0 1px 0;
    position: relative;
    text-align: left;
}
#mc_embed_signup .button {
	display: inline-block;
	background: #ef1823;
	background-image: -webkit-linear-gradient(top, #ef1823, #96020c);
	background-image: -moz-linear-gradient(top, #ef1823, #96020c);
	background-image: -ms-linear-gradient(top, #ef1823, #96020c);
	background-image: -o-linear-gradient(top, #ef1823, #96020c);
	background-image: linear-gradient(to bottom, #ef1823, #96020c);
	-webkit-border-radius: 8;
	-moz-border-radius: 8;
	border-radius: 8px;
	border:none;
	color: #ffffff;
	padding: 5px;
	margin: 10px;
	font-size: .9em;
	line-height: 12px;
	text-decoration: none;
}
#mc_embed_signup .button:hover {
	background: #fa4951;
	background-image: -webkit-linear-gradient(top, #fa4951, #ab0a12);
	background-image: -moz-linear-gradient(top, #fa4951, #ab0a12);
	background-image: -ms-linear-gradient(top, #fa4951, #ab0a12);
	background-image: -o-linear-gradient(top, #fa4951, #ab0a12);
	background-image: linear-gradient(to bottom, #fa4951, #ab0a12);
	text-decoration: none;
}
#mc_embed_signup label {
    display: block;
    font-size: 14px;
    font-weight: bold;
    padding-bottom: 10px;
}
#mc_embed_signup input {
	padding: 4px;}

.newsImg {
	float: right; 
	margin: 0 0 10px 20px;
	}
/* RESPONSIVE IMAGES */
img{ max-width:100%; height:auto;}


/*MAIN MENU*/
.menu-toggle{
	display:block;
	padding:10px;
	margin:20px 0 0;
	background:#000;
	color:#fff;
	cursor:pointer;
	text-transform:uppercase;
	font-size:20px;
	border: 1px solid #fff;
}
.menu-toggle.toggled-on{
	background:#666;
}
.srt-menu{
	display:none;
}	
.srt-menu.toggled-on{
	display:block;
	position:relative;
	z-index:10;
}

.srt-menu{
	clear:both;
	margin-bottom:60px;
	
}
.srt-menu li a {
	display:block;
	margin:1px 0; 
	padding:10px;
	color: #d7b230;
	text-decoration:none;
}
.srt-menu li a:hover{
	color:#fff;
}
.srt-menu li li a {
	padding-left:40px;
}
.srt-menu li li li a {
	padding-left:80px;
}

.menu-toggle {
  position: relative;
  z-index: 1000;
}


/*SECONDARY MENU*/
#secondary-navigation{
	margin-bottom:60px;
}
#secondary-navigation ul{
	margin:0;
	padding:0;
}
#secondary-navigation ul li a{ 
	background:#E6E6E6;
	display:block;
	margin:5px 0; 
	padding:10px;
	text-decoration:none;
}
#secondary-navigation ul li a:hover,
#secondary-navigation ul li.current a{
	background:#0099ff;
	color:#fff;
}

/*SPACE GRID ELEMENTS VERTICALLY, SINCE THEY ARE ONE UNDER ANOTHER SO FAR*/
.grid_1,
.grid_2,
.grid_3,
.grid_4,
.grid_5,
.grid_6,
.grid_7,
.grid_8,
.grid_9,
.grid_10,
.grid_11,
.grid_12 {
	margin-bottom:40px;
	/*positioning and padding*/
	position: relative;
    min-height: 1px;
    padding-left: 15px;
    padding-right: 15px;
}

.gridWrapper {
  display: grid;
	grid-auto-flow: column;
}

/*FOOTER*/
footer{  
	background:#000;
	color:#ccc;
	clear:both;
	font-size:80%;
	padding:5px 0;
	border-top: 1px solid #333;
}
footer h1, footer h2, footer h3, footer h4{ 
	color:#CCC; 
	margin-bottom:10px;
}
footer ul{
	margin:0 0 0 8%;
	padding:0;
}
.social {
	text-align: right;
	}

.social img {
	padding: 5px 3px;
	}
.social img:hover {
	 -webkit-transform: rotate(-10deg);
     -moz-transform: rotate(-10deg);
       -o-transform: rotate(-10deg);
      -ms-transform: rotate(-10deg);
          transform: rotate(-10deg);
	}


/* other colors and backgrounds*/


a.buttonlink{ 
	background:#000; 
	border-radius:7px; 
	color:#fff;
	display:block;
	float:left; 
	margin:10px 15px 10px 0; 
	padding:10px;
	text-decoration:none;
}
a.buttonlink:hover{
	background:#8dbc01;
}
.greenelement{
	background:#5ec79e;
	color:#fff;
}
.violetelement{
	background:#887dc2;
	color:#fff;
}

.recordsRow {
	margin: 10px 0;
}
.recordsRow:before, .recordsRow:after {
  content: "";
  display: table;
}
.recordsRow:after {
  clear: both;
}
.records1:before, .records1:after {
  content: "";
  display: table;
}
.records1:after {
  clear: both;
}
.records {
	margin-bottom: 80px;
	}
.records1 {
	float: left;
	width: 100%;
	padding: 5px; 
	margin: 3% 1%; 
	}
.records1 img{
	text-align: center;
	width: 100%;
	border: 1px solid #666;
	margin: 0 1% 1% 0;
	}
.records h3 {
	margin: 20px 0 5px 0;
	text-transform:uppercase;
	}
.records1 h4 {
	text-align:center;
	font-size: .9em;
	margin-bottom: 10px;
	}
.records hr {
	color: #333;
	}
.records a {
	color: #999;
	text-decoration:none;
	}
.records a:active, .records a:hover  {
	color: #fff;
	}
.recordPage {}
.recordPage img{
	float: right; 
	margin: 0 0 20px 20px;
	border: 1px solid #666;
	}
.recordPage h1{
	}
.recordPage h2{
	color: #d7b230 !important;
	font-size: 2em;
	line-height: 0.8em;
	}
.recordPage h3{
	margin-top: 30px;
	font-size: 1.5em;
	}
.recordPage h4{
	margin-top: 30px;
	font-size: 1.3em;
	}
.recordPage h5{
	font-style:italic;
	}
.recordPage hr {
	margin: 10px 0; 
	}
/* Contain floats*/ 
.clearfix:before,
.clearfix:after,
.row:before,
.row:after {
  content: " ";
  display: table;
}
.clearfix:after,
.container:after,
.row:after{
  clear: both;
}

/*
SMALLER MOBILE DEVICES
This is for mobile devices with smallerr screens.
*/
@media only screen and (min-width: 320px) {
#banner{
	
	text-align:left;
	margin-bottom:-10px;/*this depends on the height of the logo*/
}
.menu-toggle{/*make menu float right, instead of sitting under the logo*/
	margin:.5em 0px; /*this depends on the height of the logo*/
	display: block;
	
}

.records1 {
	float: left;
	width: 100%;
	height: 100%;
	padding: 5px; 
	margin: 1%; 
	}

} 

/*
LARGER MOBILE DEVICES
This is for mobile devices with a bit larger screens.
*/
@media only screen and (min-width: 481px) {
#banner{
	float:left;
	text-align:left;
	margin-bottom:0px;/*this depends on the height of the logo*/
}
.menu-toggle{/*make menu float right, instead of sitting under the logo*/
	margin-top:10px; /*this depends on the height of the logo*/
	float:right;
}
.records1 {
	float: left;
	width: 31%;
	padding: 5px; 
	margin: 1%; 
	}

} 

/*
TABLET & SMALLER LAPTOPS
The average viewing window and preferred media query for those is 768px.
But I think that some more breathing space is good:)
*/
@media only screen and (min-width: 920px) {
#logo {
	margin-top: 22px;
	}
.records1 {
	float: left;
	width: 12%;
	height: 250px;
	padding: 5px; 
	margin: 1%; 
	}
.wrapper{
	max-width: 1200px; 
	margin: 0 auto;
}
#hero .grid_6 {
		padding: 0px 10px !important;
	}
#banner{ 
	float:left; 
	text-align:left;
	margin-bottom:0px;
}
header{
	padding:0;
	margin-bottom: 2%;
}
#content {  
	float:left;
	width:65%;
}
#content.wide-content{
	float:none;
	width:100%;
}

.flexslider{
	display:block;
	/*demo 1 slider theme*/	
	margin: 0 0 60px; 
	background: #fff; 
	border: 4px solid #fff; 
	-webkit-border-radius: 4px; 
	-moz-border-radius: 4px; 
	-o-border-radius: 4px; 
	border-radius: 4px; 
	box-shadow: 0 1px 4px rgba(0,0,0,.2); 
	-webkit-box-shadow: 0 1px 4px rgba(0,0,0,.2); 
	-moz-box-shadow: 0 1px 4px rgba(0,0,0,.2); 
	-o-box-shadow: 0 1px 4px rgba(0,0,0,.2);
}

#topnav, .srt-menu {
	float:right;
	margin: 62px 0 0 0;
}
aside { 
	float:right;
	width:30%;
}

/*** MAIN MENU - ESSENTIAL STYLES ***/
.menu-toggle{display:none;}
#menu-main-navigation{display:block;}

.srt-menu, .srt-menu * {
	margin:			0;
	padding:		0;
	list-style:		none;
}
.srt-menu ul {
	position:		absolute;
	display:none;
	width:			12em; /* left offset of submenus need to match (see below) */
}
.srt-menu ul li {
	width:			100%;
}
.srt-menu li:hover {
	visibility:		inherit; /* fixes IE7 'sticky bug' */
}
.srt-menu li {
	float:			left;
	position:		relative;
	margin-left:1px;
}
.srt-menu li li {
	margin-left:0px;
}
.srt-menu a {
	display:		block;
	position:		relative;
}
.srt-menu li:hover ul,
.srt-menu li.sfHover ul {
	display:block;
	left:			0;
	top:			45px; /* match top ul list item height */
	z-index:		99;
	-webkit-box-shadow:  2px 3px 2px 0px rgba(00, 00, 00, .3);
    box-shadow:  2px 3px 2px 0px rgba(00, 00, 00, .3);
}
ul.srt-menu li:hover li ul,
ul.srt-menu li.sfHover li ul {
	top:			-999em;
}
ul.srt-menu li li:hover ul,
ul.srt-menu li li.sfHover ul {
	left:			12em; /* match ul width */
	top:			0;
}
ul.srt-menu li li:hover li ul,
ul.srt-menu li li.sfHover li ul {
	top:			-999em;
}
ul.srt-menu li li li:hover ul,
ul.srt-menu li li li.sfHover ul {
	left:			10em; /* match ul width */
	top:			0;
}

/*** DEMO1 SKIN ***/
#topnav, .srt-menu {
	float:right;
	margin: 62px 0 0 0;
}
.srt-menu a {
	text-decoration:none;
}
.srt-menu li a {
	margin:0; 
	padding:5px 10px;
	height:45px;
}
.srt-menu a, .srt-menu a:visited  { /* visited pseudo selector so IE6 applies text colour*/
	color:			#d7b230;	
}
.srt-menu li li a {
		border-top:		1px solid rgba(255,255,255,.2);
		background:		#333; /*fallback for old IE*/
		background:rgba(0,0,0,.6);
		color:	#fff;
		padding-left:20px;
		height:auto;
}
.srt-menu li li a:visited{color:#fff;}
.srt-menu li li li a,
.srt-menu li.current * li a{
	padding-left:20px;
	background:rgba(0,0,0,.6);
}

.srt-menu li:hover > a,
.srt-menu li.current a{ 
	color:#fff;
}
.srt-menu li li:hover > a{
	color:#fff;
}



/*GRID*/
/*
 & Columns : 12 

 */
 .row{
	 margin-left: -15px;
     margin-right: -15px;
}
 
.grid_1 { width: 8.33333333%; }
.grid_2 { width: 16.66666667%; }
.grid_3 { width: 25%; }
.grid_4 { width: 33.33333333%; }
.grid_5 { width: 41.66666667%; }
.grid_6 { width: 50%; }
.grid_7 { width: 58.33333333%; }
.grid_8 { width: 66.66666667%; }
.grid_9 { width: 75%; }
.grid_10 { width: 83.33333333%; }
.grid_11 { width: 91.66666667%; }
.grid_12 { width: 100%; }

.grid_1,
.grid_2,
.grid_3,
.grid_4,
.grid_5,
.grid_6,
.grid_7,
.grid_8,
.grid_9,
.grid_10,
.grid_11,
.grid_12 {
	float: left;
	display: block;
}

.rightfloat{float:right;}
/* @notation inspired by tinyGrid, .row and percentage by Twitter Bootstrap
 */
 
#hero [class*="grid_"] { margin-bottom:-20px;}

}

/*
DESKTOP
This is the average viewing window. So Desktops, Laptops, and
in general anyone not viewing on a mobile device. Here's where
you can add resource intensive styles.
*/
@media only screen and (min-width: 1030px) {

} 

/*
LARGE VIEWING SIZE
This is for the larger monitors and possibly full screen viewers.
*/
@media only screen and (min-width: 1240px) {

} 

/*
RETINA (2x RESOLUTION DEVICES)
This applies to the retina iPhone (4s) and iPad (2,3) along with
other displays with a 2x resolution.
*/
@media only screen and (-webkit-min-device-pixel-ratio: 1.5),
       only screen and (min--moz-device-pixel-ratio: 1.5),
       only screen and (min-device-pixel-ratio: 1.5) {


} 

/*
iPHONE 5 MEDIA QUERY
iPhone 5 or iPod Touch 5th generation styles (you can include your own file if you want)
*/
@media (device-height: 568px) and (-webkit-min-device-pixel-ratio: 2) { 

  
}
	/* 
	Max width before this PARTICULAR table gets nasty
	This query will take effect for any screen smaller than 760px
	and also iPads specifically.
	*/
	@media 
	only screen and (max-width: 760px),
	(min-device-width: 768px) and (max-device-width: 1024px)  {
	
		/* Force table to not be like tables anymore */
		table, thead, tbody, th, td, tr { 
			display: block; 
		}
		
		/* Hide table headers (but not display: none;, for accessibility) */
		thead tr { 
			position: absolute;
			top: -9999px;
			left: -9999px;
		}
		
		tr { border: 1px solid #ccc; }
		
		td { 
			/* Behave  like a "row" */
			border: none;
			position: relative;
			padding: 2px;
		}
			
.date {
      text-align:center;
	width: 100%
}
.dest {
      text-align:center;
	width: 100%
}
.venue {
      text-align:center;
	  line-height: 1.2em;
	width: 100%
}
.acts {
      text-align:center;
	  line-height: 1.2em;
}

.tix {
      text-align:center;
	  line-height: 1.2em;
	width: 100%
}

		
	}
	
	/* Smartphones (portrait and landscape) ----------- */
	@media only screen
	and (min-device-width : 320px)
	and (max-device-width : 480px) {
		body { 
			padding: 0; 
			margin: 0; 
			width: 100%; }
		
.date {
      text-align:center;
	width: 100%
}
.dest {
      text-align:center;
	width: 100%
}
.venue {
      text-align:center;
	  line-height: 1.2em;
	width: 100%
}
.acts {
      text-align:center;
	  line-height: 1.2em;
}

.tix {
      text-align:center;
	  line-height: 1.2em;
	width: 100%
}

		
		
		
		}

		
	
	/* iPads (portrait and landscape) ----------- */
	@media only screen and (min-device-width: 768px) and (max-device-width: 1024px) {
		body { 
			width: 100%; 
		}
#topnav, .srt-menu {
	float:right;
	margin: 10px 0 0 0 !important;
}
	}
	

/*
PRINT STYLESHEET
*/
@media print {
  * { background: transparent !important; color: black !important; text-shadow: none !important; filter:none !important; -ms-filter: none !important; } /* Black prints faster: h5bp.com/s */
  a, a:visited { text-decoration: underline; }
  a[href]:after { content: " (" attr(href) ")"; }
  abbr[title]:after { content: " (" attr(title) ")"; }
  .ir a:after, a[href^="javascript:"]:after, a[href^="#"]:after { content: ""; }  /* Don't show links for images, or javascript/internal links */
  pre, blockquote { border: 1px solid #999; page-break-inside: avoid; }
  thead { display: table-header-group; } /* h5bp.com/t */
  tr, img { page-break-inside: avoid; }
  img { max-width: 100% !important; }
  @page { margin: 0.5cm; }
  p, h2, h3 { orphans: 3; widows: 3; }
  h2, h3 { page-break-after: avoid; }
}
/* ================================
   MOBILE FIX FOR RECORDS PAGE
   ================================ */
@media (max-width: 768px) {

  .recordsRow {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 20px;
  }

  .records1 {
    width: 45%;
    margin: 0 auto 20px auto;
    text-align: center;
  }
  .recordPage img {
    width: 100%;
    height: auto;
    max-width: 100%;
    display: block;
    margin: 0 auto 20px auto;
  }

  .recordPage {
    text-align: center;
    padding: 0 10px;
  }

  .recordPage h2 {
    font-size: 1.4em;
    line-height: 1.3em;
    margin-top: 10px;
  }

  .recordPage h5 {
    font-size: 0.9em;
    line-height: 1.3em;
  }
}



  /* smaller screens (phones under 500px) — single column */
  @media (max-width: 500px) {
    .records1 {
      width: 90%;
    }
  }

  /* images scale down properly */
  .records1 img {
    width: 100%;
    height: auto;
  }

  /* tighten spacing between album titles */
  .records1 h4 {
    font-size: 0.9em;
    line-height: 1.2em;
    margin-top: 8px;
  }

/* MOBILE NAV VISIBILITY FIX */
.srt-menu {
  display: none;
  position: absolute;
  top: 100%; /* directly below header */
  left: 0;
  width: 100%;
  background: #000;
  z-index: 9998;
}

.srt-menu.toggled-on {
  display: block;
}

.menu-toggle {
  position: relative;
  z-index: 9999;
}

/* --- restore clearfix and float behavior for all headers --- */
header.wrapper.clearfix::after {
  content: "";
  display: table;
  clear: both;
}
/* --- force logo and nav alignment site-wide --- */
#banner {
  float: left;
  margin: 0;
}

#topnav {
  float: right;
  margin: 62px 0 0 0;
}

.srt-menu {
  display: block;
}
/* === NAV / HEADER RESCUE (site-wide) === */
/* Desktop & large screens */
@media (min-width: 920px) {
  header.wrapper.clearfix{
    display:flex !important;
    justify-content:space-between !important;
    align-items:flex-end !important;
    flex-wrap:nowrap !important;
  }

  #banner{               /* logo block */
    flex:0 0 auto !important;
    margin:0 !important;
    padding:0 !important;
  }

  #topnav{               /* nav container */
    flex:1 1 auto !important;
    text-align:right !important;
    margin:0 !important;
    position:relative !important;
    z-index:2 !important;
  }

  /* show horizontal menu, kill “mobile” positioning on desktop */
  .srt-menu{
    display:inline-flex !important;
    gap:8px;
    position:static !important;
    background:none !important;
    margin:0 !important;
    padding:0 !important;
    width:auto !important;
  }
  .srt-menu li{display:inline-block !important;}
  .menu-toggle{display:none !important;}
}

/* Mobile & tablets */
@media (max-width: 919px) {
  header.wrapper.clearfix{display:block !important;}
  .menu-toggle{display:block !important;}

  /* mobile dropdown sits below header, full width */
  .srt-menu{
    display:none;
    position:absolute !important;
    top:100% !important;
    left:0 !important;
    width:100% !important;
    background:#000 !important;
    z-index:9998 !important;
    margin:0 !important;
  }
  .srt-menu.toggled-on{display:block !important;}
}

/* Always keep header from collapsing into content */
header.wrapper.clearfix::after{
  content:"";
  display:table;
  clear:both;
}

/* === REFINED HEADER / NAV ALIGNMENT (CONSISTENT CHROME + FIREFOX) === */
@media (min-width: 920px) {
  header.wrapper.clearfix {
    align-items: flex-end !important;     /* anchors nav to bottom edge of header */
  }

  #topnav {
    display: flex;
    align-items: flex-end;                /* aligns the menu links with logo bottom */
    justify-content: flex-end;            /* pushes menu all the way right */
    width: 100%;
  }

  .srt-menu {
    display: flex;
    flex-wrap: nowrap;
    justify-content: flex-end;
    gap: 6px;                            /* adjust horizontal spacing between items */
    margin: 0;
    padding: 0;
    background: none;
  }

  .srt-menu li {
    display: inline-block;
    list-style: none;
  }

  .srt-menu li a {
    display: inline-block;
    color: #d7b230;
    text-transform: uppercase;
    text-decoration: none;
    font-size: 18px;
    line-height: 1;
    padding-bottom: 4px;                  /* gives a little breathing room */
  }

  .srt-menu li a:hover {
    color: #fff;
  }

  .menu-toggle {
    display: none;
  }
}
/* === FINAL HEADER/NAV CORRECTION === */
@media (min-width: 920px) {
  /* Put logo + nav on one line, align to bottom */
  header.wrapper.clearfix {
    display: flex !important;
    align-items: flex-end !important;   /* bottom of header */
  }

  /* Let the nav sit inside the same wrapper width and push right.
     Do NOT set a fixed width or justify-content here. */
  #topnav {
    margin-left: auto !important;       /* pushes nav to the right edge of wrapper */
    display: block !important;          /* let the UL handle flex */
    position: relative;
  }

  /* Horizontal menu, controlled spacing that won't overflow */
  .srt-menu {
    display: flex !important;
    gap: 12px;                           /* your preferred spacing */
    margin: 0 !important;
    padding: 0 !important;
    position: static !important;
    background: none !important;
    flex-wrap: nowrap;
  }

  .srt-menu li { list-style: none; }

  /* Restore original look/size */
  .srt-menu li a {
    display: inline-block;
    font-size: 20px;                    /* back to original size */
    font-weight: 400;                   /* not semi-bold */
    line-height: 1;                     /* prevents Firefox vertical stretch */
    text-transform: uppercase;
    text-decoration: none;
    color: #d7b230;
    padding: 0;                         /* no extra vertical padding */
  }

  .srt-menu li a:hover { color: #fff; }

  .menu-toggle { display: none !important; }
}

