/* Begin Site Styles */
body {
  background-color: #000;
  color: #fff;
  padding-bottom: 20px;
}

.header {
  height: 40px;
  background: url("../img/header-mobile.jpg") no-repeat;
  background-size: 100% 100% !important;
}

.header2 {
  height: 40px;
  background: url("../img/header-mobile.jpg") no-repeat;
  background-size: 100% 100% !important;
}

.header3 {
  height: 40px;
  background: url("../img/header-mobile.jpg") no-repeat;
  background-size: 100% 100% !important;
}

.navbar-header {
  height: 60px;
  background: url("../img/header_bg.jpg") no-repeat;
  background-size: 82% 100% !important;
}

.navbar-header2 {
  height: 60px;
  background: url("../img/header_bg2.jpg") no-repeat;
  background-size: 82% 100% !important;
}

.navbar-header3 {
  height: 60px;
  background: url("../img/header_bg3.jpg") no-repeat;
  background-size: 82% 100% !important;
}

.container-fluid>.navbar-collapse,
.container-fluid>.navbar-header,
.container>.navbar-collapse,
.container>.navbar-header {
  margin-left: 0;
}



/* Optional: Ensure videos scale correctly */
.embed-responsive {
  max-width: 100%;
}

#main-content {
  color: #fff;
}

.main-content {
  color: #fff;
  font-size: 18px;
}

a {
  color: #5e35b1;
  text-decoration: none;
}

a:hover,
a:focus {
  color: #ccc;
  text-decoration: underline;
}

h1 {
  font-family: 'Uncial Antiqua', cursive;
  font-weight: bold;
}

h2,
h3,
h4,
h5,
h6,
.h1,
.h2,
.h3,
.h4,
.h5,
.h6 {
  font-family: 'Stardos Stencil', cursive;
  font-weight: bold;
}

.nopadding {
  padding: 20px 0 20px 0 !important;
  margin: 0 !important;
}

.home-info {
  color: #000;
  padding: 0 0 15px 0 !important;
  margin: 0 !important;
}

.event {
  border-bottom: dotted 1px #000;
  padding-bottom: 10px;
  margin-bottom: 5px;
}

.event h4 {
  padding: 0;
  margin: 0;
  color: #5e35b1;
}

.event-calendar {
  width: 55px;
  height: 65px;
  padding: 5px;
  background-color: #b64ff8;
  border: solid 4px #000;
  text-align: center;
  margin-left: 10px;
}

.event-calendar-home {
  width: 55px;
  height: 65px;
  padding: 5px;
  background-color: #b64ff8;
  border: solid 4px #000;
  text-align: center;
  margin-left: 15px;
}

.event-calendar-home h2 {
  padding: 0;
  margin: 0;
}

.event-calendar-home h4 {
  padding: 0;
  margin: 0;
  color: #000;
}

.event-calendar h2 {
  padding: 0;
  margin: 0;
}

.event-calendar h4 {
  padding: 0;
  margin: 0;
  color: #000;
}

.img-photo-cover {
  border-color: #fff !important;
  border: 0.625em solid rgba(255, 255, 255, .5);
  /* 10 */
  -webkit-box-shadow: 0 0 0.938em rgba(0, 0, 0, .25);
  /* 15 */
  box-shadow: 0 0 0.938em rgba(0, 0, 0, .25);
  /* 15 */
  -webkit-transition: -webkit-box-shadow .3s ease, border-color .3s ease;
  transition: box-shadow .3s ease, border-color .3s ease;
}

.navbar-right {
  padding-right: 15px;
}

/* End Site Styles */

/* Begin Slippry Overrides */
.sy-box.sy-loading {
  background: url("../lib/slippry/img/sy-loader.gif");
}

.sy-controls li a:after {
  background-image: url("../lib/slippry/img/arrows.svg");
}

.thumb-box {
  padding: 1.4em 0 1em;
  margin-left: -1%;
  width: 102%;
}

.thumb-box .thumbs {
  overflow: hidden;
  *zoom: 1;
  list-style: none;
}

.thumb-box .thumbs li {
  float: left;
  width: 25%;
  text-align: center;
  padding: 0 1%;
}

.thumb-box .thumbs li img {
  width: 100%;
  opacity: .8;
  -moz-transition: opacity 0.32s;
  -o-transition: opacity 0.32s;
  -webkit-transition: opacity 0.32s;
  transition: opacity 0.32s;
  border-bottom: 4px solid transparent;
}

.thumb-box .thumbs li img.active {
  border-color: #b64ff8;
  opacity: 1;
}

.thumb-box .thumbs li:hover img {
  opacity: 1;
  -moz-transition: opacity 0.2s;
  -o-transition: opacity 0.2s;
  -webkit-transition: opacity 0.2s;
  transition: opacity 0.2s;
}

/* End Slippry Overrides */

/* Begin Bootstrap Overrides */
.navbar {
  border-radius: 0;
  margin: 0;
}

.navbar-left-margin {
  border-radius: 0;
}

.navbar-inverse {
  background-color: #000;
  border-color: #080808;
  border-top: solid 2px #b64ff8;
  border-bottom: solid 2px #b64ff8;
}

.navbar-inverse .navbar-nav>li>a {
  color: #ffffff;
  font-weight: bold;
}

.navbar-inverse .navbar-nav>li>a:hover {
  color: #9d9d9d;
}

.navbar-inverse .navbar-nav>.active>a,
.navbar-inverse .navbar-nav>.active>a:hover,
.navbar-inverse .navbar-nav>.active>a:focus {
  color: #ffffff;
  background-color: #b64ff8;
}

.panel {
  color: #000;
  border: none;
}

.panel-default {
  border-color: #ddd;
}

.panel-default>.panel-heading {
  color: #fff;
  background-color: #b64ff8;
}

/* End Bootstrap Overrides */

/* Begin Helpers */
.top-buffer {
  margin-top: 15px;
}

.last {
  border: none;
}

/* End Helpers */


.navbar-inverse .navbar-toggle {
  margin: 10px 0 0 0;
  background-color: #b64ff8;
}

.navbar-inverse .navbar-toggle:hover,
.navbar-inverse .navbar-toggle:focus {
  background-color: #7300e6;
}

.home-sub-banner {
  background-color: black;
  margin-left: 0;
  margin-right: 0;
  border-top: solid 2px #b64ff8;
  border-bottom: solid 3px #b64ff8;
}

.home-sub-banner img {
  height: 50px;
}


/* CUSTOMIZE THE CAROUSEL
-------------------------------------------------- */

/* Carousel base class */
.carousel {
  height: 225px;
}

/* Since positioning the image, we need to help out the caption */
.carousel-caption {
  z-index: 10;
}

/* Declare heights because of positioning of img element */
.carousel .item {
  height: 225px;
  background-color: #777;
}

.carousel-inner>.item>img {
  position: absolute;
  top: 0;
  left: 0;
  min-width: 100%;
  height: 225px;
}

/* CAROUSEL FADE EFFECT
-------------------------------------------------- */
.carousel-fade .carousel-inner .item {
  opacity: 0;
  transition-property: opacity;
}

.carousel-fade .carousel-inner .active {
  opacity: 1;
}

.carousel-fade .carousel-inner .active.left,
.carousel-fade .carousel-inner .active.right {
  left: 0;
  opacity: 0;
  z-index: 1;
}

.carousel-fade .carousel-inner .next.left,
.carousel-fade .carousel-inner .prev.right {
  opacity: 1;
}

.carousel-fade .carousel-control {
  z-index: 2;
}

/*
WHAT IS NEW IN 3.3: "Added transforms to improve carousel performance in modern browsers."
now override the 3.3 new styles for modern browsers & apply opacity
*/
@media all and (transform-3d),
(-webkit-transform-3d) {

  .carousel-fade .carousel-inner>.item.next,
  .carousel-fade .carousel-inner>.item.active.right {
    opacity: 0;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }

  .carousel-fade .carousel-inner>.item.prev,
  .carousel-fade .carousel-inner>.item.active.left {
    opacity: 0;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }

  .carousel-fade .carousel-inner>.item.next.left,
  .carousel-fade .carousel-inner>.item.prev.right,
  .carousel-fade .carousel-inner>.item.active {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
}

  /* Carousel base class */
  .carousel {
    height: 250px;
  }

  /* Since positioning the image, we need to help out the caption */
  .carousel-caption {
    z-index: 10;
  }

  /* Declare heights because of positioning of img element */
  .carousel .item {
    height: 250px;
    background-color: #777;
  }

  .carousel-inner>.item>img {
    position: absolute;
    top: 0;
    left: 0;
    min-width: 100%;
    height: 250px;
  }


@media (min-width: 768px) {
  .header {
    height: 110px;
    background: url("../img/header_bg.jpg") no-repeat;
    background-size: 100% 110px;
    width: 100%;
    display: block;
  }

    .header2 {
    height: 110px;
    background: url("../img/header_bg2.jpg") no-repeat;
    background-size: 100% 110px;
    width: 100%;
    display: block;
  }

    .header3 {
    height: 110px;
    background: url("../img/header_bg3.jpg") no-repeat;
    background-size: 100% 110px;
    width: 100%;
    display: block;
  }

  .home-info {
    display: flex;
    gap: 20px;
    /* Adds spacing between columns */
    height: 900px;
    /* Set the finite height for the entire section */
    overflow: hidden;
    /* Prevents section from growing beyond this height */
  }

  .home-info>div {
    flex: 1;
    /* Makes all columns take equal width */
    overflow-y: auto;
    /* Enables vertical scrolling when content overflows */
    max-height: 100%;
    /* Ensures that each column respects the fixed height */
  }

  .home-sub-banner img {
    height: 180px;
  }

  /* Carousel base class */
  .carousel {
    height: 500px;
  }

  /* Since positioning the image, we need to help out the caption */
  .carousel-caption {
    z-index: 10;
  }

  /* Declare heights because of positioning of img element */
  .carousel .item {
    height: 500px;
    background-color: #777;
  }

  .carousel-inner>.item>img {
    position: absolute;
    top: 0;
    left: 0;
    min-width: 100%;
    height: 500px;
  }
}

  #navbar {
    padding-left: 0;
  }

  .navbar-header {
    height: 40px;
  }

/* About Page Specific Styles */

/* Full-width images */

.full-width {
  width: 100%;
  display: block;
}

#about .full-width {
  width: 100%;
  height: 350px;
  display: block;
}

/* Text container */
#about .content {
  max-width: 900px;
  margin: 40px auto;
  padding: 20px;
  text-align: center;
}

/* Side images (small) */
#about .side-img {
  max-width: 100%;
  height: auto;
  display: block;
  margin: 0 auto;
}

/* Bullet point styling */
#band ul {
  text-align: left;
  margin-left: 20px;
}

#band .full-width {
  width: 100%;
  height: 350px;
  display: block;
}

/* Text container */
#band .content {
  max-width: 900px;
  margin: 40px auto;
  padding: 20px;
  text-align: center;
}

/* Side images (small) */
#band .side-img {
  max-width: 100%;
  height: auto;
  display: block;
  margin: 0 auto;
}

/* Bullet point styling */
#band ul {
  text-align: left;
  margin-left: 20px;
}

.img-thumbnail {
  margin-bottom: 0; /* eliminate extra bottom spacing */
}

.fixed-thumb {
  width: 100%;
  height: 200px;
  object-fit: cover;
  object-position: center;
}

.gallery-item {
  padding: 10px; /* controls even spacing all around */
}

.img-thumbnail {
  margin-bottom: 0;
}

.fixed-thumb {
  width: 100%;
  height: 200px;
  object-fit: cover;
  object-position: center;
}

.featured-thumb {
  height: 420px;
}

.gallery-item {
  padding: 10px;
}

h1.gallery-section-title {
  color: #5e35b1;
  text-decoration: underline;
  margin-bottom: 20px;
}

.lb-container {
  max-width: 70vw;
}

.lite-frosted-bg {
  background: rgba(255, 255, 255, 0.45); /* more opaque white */
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid rgba(255, 255, 255, 0.3);
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1);
  border-radius: 8px;
}

.frosted-bg {
  background: rgba(255, 255, 255, 0.3); /* translucent white */
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px); /* Safari support */
  border: 1px solid rgba(255, 255, 255, 0.2); /* optional soft border */
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1);  /* subtle depth */
  border-radius: 8px; /* optional rounded corners */
}

.gold-frosted-bg {
  background: rgba(255, 223, 100, 0.35); /* soft golden-yellow tint */
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px); /* Safari support */
  border: 1px solid rgba(255, 223, 100, 0.5); /* soft golden border */
  box-shadow: 0 4px 20px rgba(255, 223, 100, 0.3);  /* warm golden glow */
  border-radius: 8px;
}

.blue-frosted-bg {
  background: rgba(100, 180, 255, 0.35); /* soft frosty blue */
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px); /* Safari support */
  border: 1px solid rgba(100, 180, 255, 0.5); /* soft blue border */
  box-shadow: 0 4px 20px rgba(100, 180, 255, 0.3);  /* subtle icy glow */
  border-radius: 8px;
}

.red-frosted-bg {
  background: rgba(255, 80, 80, 0.35); /* soft translucent red */
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px); /* Safari support */
  border: 1px solid rgba(255, 80, 80, 0.5); /* soft red border */
  box-shadow: 0 4px 20px rgba(255, 80, 80, 0.3);  /* subtle red glow */
  border-radius: 8px;
}

.lectures-gallery-img {
  width: 100%;
  height: 250px; /* Adjust this height as needed */
  object-fit: cover;
  margin-top: 30px;
  border-radius: 4px; /* optional: gives a nice soft edge */
}

.navbar-nav > li > a {
  color: #fff; /* or whatever your navbar text color is */
  text-shadow: 1px 1px 2px rgba(0,0,0,0.5);
  transition: all 0.2s ease-in-out;
  font-weight: bold;
  font-size: 12px;
}

.navbar-nav > li > a:hover,
.navbar-nav > li > a:focus {
  text-decoration: underline;
  text-shadow: 1px 1px 4px rgba(255,255,255,0.4);
  color: #ffdd57; /* Optional highlight color on hover */
  cursor: pointer;
}






