:root {
  --color0: #000000;  /* BLACK */
  --color1: #FFFFFF; /* WHITE */
  --color2: #004985; /* BLUE */
}

html {
  color: var(--color1);
  font-size: 1.5em;
  font-family: 'Bebas Neue', cursive;
}

body {
  height: 100%;
  margin: 0;
  padding: 0;
  background-color: black;
}

.maxWidth1000 {
  width: 100%;
  max-width: 1000px;
}

.siteContainer {
  background-color: var(--color0);
	background-image: url(images/bg.jpg); width: 100%; height: auto;
	background-repeat: no-repeat; 
	background-attachment: fixed;
  background-position: center;
  overflow-x: hidden;
}

a {
  text-decoration: none;
  color: var(--color1);
}

.rockSalt {
  font-family: 'Rock Salt', cursive;
}

.mainMenu {
  display: none;
  position: fixed;
  background-color: rgba(0,0,0,0.8); 
  z-index : 1;
  width: 100%; 
  height: 100vh;
  font-size: 1.5em;
}

.mainMenu a {
  display: block; 
  text-align: center; 
  padding: 10px 18px; 
  text-decoration: none; 
  color: var(--color1);
}

.mainMenu ul {
    list-style-type: none;
    margin: 0;
    padding: 0;
    padding-top: 12%;
    overflow: hidden;
}

.mainMenu li a:hover, .btns:hover {
  background-color: var(--color2);
}

.btns {
  display: block; 
  border: none;
  color: var(--color0); 
  background-color: rgba(0, 0, 0, 0.6);
  text-align: center; 
  padding: 7px 20px; 
  text-decoration: none;
}

.btns:focus {
  outline: 0;
}

.navbottom {
  bottom: 0;
	position: fixed;
	width: 100%;
  z-index: 1;
}

.navbottom ul {
    list-style-type: none;
    margin: 0;
    padding: 0;
    overflow: hidden; 
}

.navbottom li {
    float: left;
    padding-left: 1px;
}

.fbLike1 img, .fbLike2 img {
  width: auto;
  height: 25px;
}

.fbLike2 {
  margin-left: -10px;
}

.main {
	padding-bottom: 2px;
	width: 100%;
	margin: 0 auto;
	font-size: 1.1em;
  color: var(--color1);
}

#start {
  margin-bottom: -10px;
}
	
h1	{
  font-size: 2em;
  text-align: center;
}

.columnR {
	width: 49%;
	float: right;
}

.columnL {
	width: 49%;
	float: left;
}

#welcome {
  width: 100%;	
  height: 100vh;
	border-radius: 5px;
	text-align: center;
  font-size: 1em;
  padding: 10px;
}  

#welcome2 {
  width: 100%;
  padding-top: 0px;
  margin-top: -120px;
}
  
#musicDesktop {
  text-align: center;
}

#musicMobile {
  margin-left: auto;
  margin-right: auto;
  text-align: center;
  width: 90%;
  display: none;
}

#video {
  background-color: rgba(0, 0, 0, 0.5);
  margin: auto;
}

#members {
  width: 80%;
  margin: auto; 
  margin-bottom: 20px;
}

.members {
  table-layout: fixed;
  width: 80%;
  margin: auto;
  text-align: center;
}

.bandMember {
  margin: auto;
}

.bandMember img {
  margin: auto;
  width: 100%;
}

.bandMember img:hover {
  border: 1px solid gray;
}

.bandMemberCaption { 
  margin-top: 10px; 
  margin: auto;
}

.bandMemberName {
  font-family: 'Rock Salt', cursive;
  font-size: 1.1vw;
  font-weight: bold; 
}

.bandMemberDesc {
  text-align: center;
  font-size: .75vw;
}

.bandBanner {
  margin: auto;
  width: 100%;
}

.bandBanner img {
  display: block;
  margin: auto;
  width: 88%;
  border: 1px solid gray;
  border-radius: 12px;
}

#photos {
  margin: auto;
	width: 90%;
  padding: 10px;
}

#photos img:hover {
  border: 1px solid var(--color1);
}

#biography {
  margin: auto;
  background-color: rgba(0, 0, 0, 0.5);
  width: 90%;
  border-radius: 5px;
  padding: 10px;
  text-align: left;
}

#biography p {
  font-family: 'Helvetica';
}

#biography a {
  color: rgb(255, 67, 67);
  text-decoration: none;
}

#biography a:hover {
  color: blue;
}

.socials {
  table-layout: fixed;
  width: 78%;
  margin: auto;
  margin-bottom: 33px;
  text-align: center;
}

.featureTbl {
  height: 300px;
  width: 66%;
  margin: auto;
  table-layout: auto;
  text-align: left;
}

.featureTbl-2 {
  height: 120px;
  width: 44%;
  margin: auto;
  table-layout: fixed;
  text-align: center;
  font-size: 2vh;
}

.featureTbl-2 td:hover {
  background-color: rgba(100, 243, 248, 0.55);
  box-shadow: -10px -10px 40px 8px rgba(100, 243, 248, 0.913);
  border-radius: 6px;
  border: 1px solid white;
}

.featureTbl-2 td a {
  display: block;
  height: 100%;
  width: 100%;
  padding: 1rem; /* ← move your padding here instead of on td */
  box-sizing: border-box;
  text-decoration: none;
  color: inherit;
}

.hiddenText {
  display: none;
}

.featureTbl-2 td:hover .hiddenText {
  display: block;
}

.featureTbl td.first-column {
  width: 33%;
}

.featureTbl td.second-column {
  width: 33%;
}

.featureTbl td.third-column {
  width: 33%;
}

.featureTbl td {
  text-align: center;
}

.featureTblHeader {
  font-size: 3.3vh;
  height: 150px;
}

td button {
  padding: 20px 16px;           
  border: none;                
  border-radius: 4px;          
  background-color: #cd0000;   
  color: white;              
  cursor: pointer;            
  font-size: 20px;            
  display: inline-block;      
  width: 88%;               
  box-sizing: border-box; 
  font-weight: bold;   
}

td button:hover {
  background-color: #750000;  
  transition: background-color 0.3s ease; 
}

td button:active {
  background-color: #490000;  
}

.featureTbl img {
  border: 1px solid lightgray;
  height: 472px; 
  width: auto;
  display: block; /* removes extra space below image */
  float: right;
  margin-right: 1%;
}

.backlight {
  box-shadow: -10px -10px 40px 8px rgba(100, 243, 248, 0.455);
}

.glowText {
  font-family: 'Teko', sans-serif;
  font-size: 5.5vh;
  text-transform: uppercase;
  animation: glow 3.3s ease-in-out infinite
}

.iframe-wrapper {
  text-align: center;
  margin: 0;
}

.iframe-wrapper iframe {
  max-width: 100%;
}

@keyframes glow {
  0% {
    text-shadow: 0 0 20px rgba(100, 243, 248, 0.8);
  }
  50% {
    text-shadow: 0 0 30px rgba(100, 243, 248, 0.8), 0 0 10px rgba(100, 243, 248, 0.8); /* Peak glow */
  }
  100% {
    text-shadow: 0 0 20px rgba(100, 243, 248, 0.8); /* Return to start */
  }
}

.socials td {
  max-width: 25%;
}

.socials img {
  max-height: 76px;
  max-width: 100%;
  transition: 0.5s;
}

.socials img:hover {
  max-height: 80px;
}

#shows {
  margin: auto;
  margin-bottom: 50px;
  width: 100%;
}

.showsLcol {
  width: 0%;
}

.pressRelease p {
  margin: 0 auto;
  width: 99%;
}

.pressRelease table {
  margin-top: 10px;
  table-layout: auto;
  width: 99%;
}

#contact {
  margin: auto;
	width: 90%;
  height: 600px;
	padding: 10px;
  border-radius: 5px;
  margin-bottom: 0px;
}

#contact p {
  width: 96%;
  margin: auto;
  text-align: center;
  font-size: 1.1em;
}

#contact table {
  margin-left: 36%;
}

#sponsors {
  margin: auto;
	width: 90%;
  height: 600px;
	padding: 10px;
  border-radius: 5px;
  margin-top: -100px;
  margin-bottom: 0px;
  text-align: center;
}

#sponsors table {
  margin: auto;
	width: 50%;
  table-layout: fixed;
  font-size: 2.2vh;
}

#sponsors td {
  width: 150px;
}

#copyright {
  margin: auto;
  width: 50%;
  font-size: .6em;
  text-align: center;
  padding: 10px;
  margin-bottom: 20px;
}

a:link, a:visited {
  text-decoration: none;
}

* {
  box-sizing: border-box
}

img {
  vertical-align: middle;
}

/* Contact form */

#contactForm {
    display: block;
}

#recaptcha {
  float: left;
  margin-top: -10px;
}

/* Style inputs with type="text", select elements and textareas */
input[type=text], select, textarea {
	width: 100%; /* Full width */
	padding: 12px; /* Some padding */  
	border: 1px solid #ccc; /* Gray border */
	border-radius: 4px; /* Rounded borders */
	box-sizing: border-box; /* Make sure that padding and width stays in place */
	margin-top: 6px; /* Add a top margin */
	margin-bottom: 16px; /* Bottom margin */
	resize: vertical /* Allow the user to vertically resize the textarea (not horizontally) */
  }
  
  /* Style the submit button with a specific background color etc */
  input[type=submit] {
    background-color: lightslategray;
    color: var(--color0s);
    padding: 12px 20px;
    border: none;
    border-radius: 4px;
    cursor: pointer;
    float: right; 
    margin-right: 20px; 
    width: 120px; 
    font-weight: bold;
  }
  
  /* When moving the mouse over the submit button, add a color */
  input[type=submit]:hover {
	  background-color: rgb(84, 102, 119);
  }

  #recaptcha {
    float: left;
  }

.row {
  display: flex;
  flex-wrap: wrap;
  padding: 0 4px;
}

/* Create four equal columns that sits next to each other */
.column {
  flex: 25%;
  max-width: 25%;
  padding: 0 4px;
}

.column img {
  margin-top: 8px;
  vertical-align: middle;
}

#menuTable {
	position: fixed;
  float: right;
	right: 4%;
  margin-top: 26px;
  z-index: 1000;
  -webkit-user-select: none;
	user-select: none;
	font-family: 'Roboto Condensed', sans-serif;
	color: white;
	background: rgba(0, 0, 0, 0.1);
	border-radius: 4px;
	padding: 3px;
}

#menuToggle input {
  display: block;
  width: 40px;
  height: 32px;
  position: absolute;  
  cursor: pointer;
  opacity: 0; /* hide this */
  z-index: 2; /* and place it over the hamburger */
  -webkit-touch-callout: none;
}

/* Just a quick hamburger  */
#menuToggle span {
  display: block;
  width: 33px;
  height: 4px;
  margin-bottom: 5px;
  position: relative;
  background: #ffffff;
  border-radius: 3px;
  z-index: 1;
  transform-origin: 4px 0px;
  transition: transform 0.5s cubic-bezier(0.77,0.2,0.05,1.0),
              background 0.5s cubic-bezier(0.77,0.2,0.05,1.0),
              opacity 0.55s ease;
}

#menuToggle span:first-child {
  transform-origin: 0% 0%;
}

#menuToggle span:nth-last-child(2) {
  transform-origin: 0% 100%;
}

/* Transform all the slices of hamburger into a crossmark. */
#menuToggle input:checked ~ span {
  opacity: 1;
  transform: rotate(-45deg) translate(-1px, -1px);
  background: #c5c5c5;
}

/*  * But let's hide the middle one. */
#menuToggle input:checked ~ span:nth-last-child(3) {
  opacity: 1;
  transform: rotate(45deg) translate(1px, 0px);
}

/* The last one should go the other direction  */
#menuToggle input:checked ~ span:nth-last-child(2) {
	opacity: 0;
	transform: rotate(0deg) scale(0.2, 0.2);
}

.btnScrollTop {
  display: none;
  position: fixed;
  bottom: 100px;
  right: 100px;
	font-family: 'Bebas Neue', cursive;
	font-size: 16px;
  font-weight: bold;
	padding: 8px 20px;
	border-radius: 2px;
	border: none;
	background-color: var(--color1);
	color: black;
	text-align: center;
}

.btnBack:hover, .btnScrollTop:hover, .btnScrollTopBooking:hover {
	background-color: var(--color2);
	color: white;
}

#logoD {
  max-width: 33%;
  margin-top: 11%;
  margin-bottom: 33px;
}

#logoM {
  display: none;
}

#toggleBoxMore, #toggleBoxAll {
    display: none;
}

#videoBG {
  position: fixed;
  z-index: -1;
  left: -5.1%;
  width: 50%;
  min-width: 112%;
  margin-top: -180px;
}

.arrow-down {
  width: 0;
  height: 0;
  border-left: 20px solid transparent;
  border-right: 20px solid transparent;
  border-top: 20px solid #ffffff;
  position: fixed;  /* Changed to fixed to stay in place relative to viewport */
  top: 88%;  /* Position it near the bottom of the viewport */
  left: 50%;
  transform: translate(-50%, -50%);
  animation-name: bounce;
  animation-duration: 1.5s;
  animation-timing-function: ease-in-out;
  animation-iteration-count: infinite;
}

@keyframes bounce {
  0%, 100% {
      transform: translate(-50%, -50%) translateY(0);
  }
  50% {
      transform: translate(-50%, -50%) translateY(8px);
  }
}

/* Class to hide the arrow */
.arrow-down.hidden {
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.5s, visibility 0.5s;
}

.featureFull .featureMobile {
  margin: auto;
  background: rgba(0, 0, 0, 0.5);
  color: #f1f1f1;
  width: 100%;
  padding-top: 50px;
  text-align: center;
  border-radius: 4px;
  font-size: .9em;
}

.featureMobile {
  display: none;
}

.featureFull {
  margin-top: 44px;
  margin-bottom: 44px;
}

.bcPlayer {
  margin: auto;
  margin-top: 10px;
  width: 60%;
}

#emailSignup {
  width: 66%;
  margin: auto;
}

#btnSubscribe {
  margin-left: 10px; 
  margin-top: 10px; 
  height: 50px; 
  font-size: 16px; 
  font-weight: 700; 
  font-family: Helvetica;  
  color:#FFFFFF; 
  background-color:#ff0000; 
  border-radius:3px; 
  border-width:0px;
}

#songPreviewArt {
  text-align: right; 
  padding-right: 10px; 
  padding-left: 4px;
  height: 150px;
}

.mobileLineBreak {
  display: none;
}

.previousReleases {
  margin: auto;
  table-layout: auto;
  position: relative;
}

.previousReleases img {
  max-width: 100%;
}

.previousReleases td {
  padding: 12px;
}

#playButton1 {
  position: absolute;
  width: 15%;
  top: 32%;
  left: 10%;
  z-index: 2;
  opacity: .33;
}

#playButton2 {
  position: absolute;
  width: 15%;
  top: 32%;
  left: 43%;
  z-index: 2;
  opacity: .33;
}

#playButton3 {
  position: absolute;
  width: 15%;
  top: 32%;
  left: 76%;
  z-index: 2;
  opacity: .33;
}

#playButton1:hover, #playButton2:hover, #playButton3:hover {
  opacity: 1;
}

.loader {
  display: inline-flex;
  gap: 10px;
}
.loader:before,
.loader:after {
  content: "";
  height: 20px;
  aspect-ratio: 1;
  border-radius: 50%;
  background:
    radial-gradient(farthest-side,#000 95%,#0000) 35% 35%/6px 6px no-repeat
    #fff;
  transform: scaleX(var(--s,1)) rotate(0deg);
  animation: l6 1s infinite linear;
}
.loader:after {
  --s: -1;
  animation-delay:-0.1s;
}
@keyframes l6 {
  100% {transform:scaleX(var(--s,1)) rotate(360deg);}
}

.pressKit {
  margin: auto;
  text-align: center;
  display: block;
  font-size: .8em;
  margin-top: 18px;
  background-color: red;
  color: white;
  padding-top: 6px;
  padding-bottom: 6px;
  padding-left: 20px;
  padding-right: 20px;
  border-radius: 4px;
  box-shadow: 0 8px 12px 0 rgba(0,0,0,0.1), 0 6px 16px 0 rgba(0,0,0,0.1);
  transition-duration: 0.4s;
  cursor: pointer;
}

.pressKit:hover {
  background-color: white;
  border: 1px solid gray;
  color: red;
}

.water-container {
  position: relative;
  width: 100%;
}

.water-content {
  position: absolute;
  margin-top: -8px;
  width: 100%;
  transition: transform 0.22s ease-out;
}

/* Ripple distortion layer */
.water-ripple {
  position: absolute;
  width: 100%;
  height: 100%;
  pointer-events: none;
  animation: ripple 3s infinite ease-in-out;
}

@keyframes ripple {
  0% { transform: translateY(0) skewX(0deg); }
  25% { transform: translateY(5px) skewX(2deg); }
  50% { transform: translateY(0) skewX(0deg); }
  75% { transform: translateY(-5px) skewX(-2deg); }
  100% { transform: translateY(0) skewX(0deg); }
}

.bit-vertical-date {
  color: red;
}

.bit-details {
  color: red;
}

.bit-vertical-date-subsection {
  color: white;
}


