@import url('https://fonts.googleapis.com/css2?family=Chakra+Petch:wght@300;400;500;600;700&family=Orbitron:wght@400..900&family=Share+Tech+Mono&display=swap');

:root {
  --bg-dark: #0a0a0a;
  --bg-darker: #050505;
  --neon: #39ff14; /* light-neon green */
  --neonlighter: #98e18a;
  --text-light: #e6ffe6;
}

html, body {
  background: var(--bg-dark);
  color: var(--text-light);
  font-family: 'Chakra Petch', 'Share Tech Mono', system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
}

/* Smooth scroll to in-page anchors */
html { scroll-behavior: smooth; }

/* Offset for fixed navbar when using anchor links */
:target { scroll-margin-top: 80px; }

a { color: var(--neon); }
a:hover { color: #b4ffb0; }

/* Hero background switching */
.hero {
  position: relative;
  min-height: 100vh;
  background-position: center center;
  background-size: cover;
  background-repeat: no-repeat;
}

.hero::after {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(to bottom, rgba(0,0,0,0.45), rgba(0,0,0,0.85));
}

.hero-content {
  position: relative; /* above overlay */
  z-index: 2;
  margin-bottom: 14vh; /* pushes content near the bottom on large screens */
}

/* Adjust bottom offset for different viewports */
@media (max-width: 1199.98px) {
  .hero-content { margin-bottom: 12vh; }
}
@media (max-width: 991.98px) {
  .hero-content { margin-bottom: 10vh; }
}
@media (max-width: 767.98px) {
  .hero-content { margin-bottom: 10vh; }
}

/* Larger desktops: bring hero content closer to the bottom */
@media (min-width: 1200px) {
  .hero-content { margin-bottom: 9vh; }
}
@media (min-width: 1400px) {
  .hero-content { margin-bottom: 8vh; }
}

/* Navbar styles */
.neon-brand {
  color: var(--neon) !important;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-family: 'Orbitron', 'Chakra Petch', system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
}

.navbar-dark {
  background: rgba(5,5,5,0.75);
  backdrop-filter: blur(6px);
  border-bottom: 1px solid rgba(57,255,20,0.25);
}

#mainNav { top: 0; left: 0; right: 0; z-index: 1050; }

/* Desktop fade-in behavior */
.desktop-nav-hidden { opacity: 0; transition: opacity 600ms ease; }
.desktop-nav-shown { opacity: 1; }

/* Mobile fixed behavior revealed on scroll */
@media (max-width: 767.98px) {
  .mobile-fixed-top { position: fixed !important; top: 0; left: 0; right: 0; z-index: 1030; transform: translateY(-100%); transition: transform 300ms ease; }
  .mobile-fixed-top.visible { transform: translateY(0); }
  /*body { padding-top: 56px; }*/
}

/* Sections */
section { padding: 80px 0; }
.section-title { color: var(--neon); text-transform: uppercase; letter-spacing: 0.1em; margin-bottom: 1rem; }
h1, h2, h3, h4, h5, h6, .section-title {
  font-family: 'Orbitron', 'Chakra Petch', system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
}
#events .event-name, .neon-lighter{
  color: var(--neonlighter);
}
#events .event-tracklist, li.track-item{
  color: var(--neonlighter);
}
.card-dark {
  background: #0e0e0e;
  border: 1px solid rgba(57,255,20,0.15);
}
.section-genre-format{
  color: var(--neon);
}

.cart-summary {
  color: var(--neonlighter);
}

.btn-neon {
  --bs-btn-color: #000;
  --bs-btn-bg: var(--neon);
  --bs-btn-border-color: var(--neon);
  --bs-btn-hover-bg: #14320f;
  --bs-btn-hover-border-color: #b4ffb0;
  --bs-btn-hover-color: white;
}

.text-muted-past { color: #9bb99a !important; }

/* Events styling */
.event-status {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 4px;
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.event-upcoming {
  border-left: 4px solid var(--neon);
  box-shadow: 0 4px 12px rgba(57, 255, 20, 0.1);
}

.event-upcoming .event-status {
  background-color: rgba(57, 255, 20, 0.15);
  color: var(--neon);
}

.event-past {
  opacity: 0.75;
  border-left: 4px solid #9bb99a;
  background: linear-gradient(to right, rgba(155, 185, 154, 0.05), transparent);
}

.event-past .event-status {
  background-color: rgba(155, 185, 154, 0.1);
  color: #9bb99a;
}

/* Footer */
footer {
  background: var(--bg-darker);
  border-top: 1px solid rgba(57,255,20,0.2);
  color: #b5ffb3;
}

/* Product grid helpers */
.product-card img { object-fit: cover; }

/* Filter styles to match dark/neon theme */
.card-dark .card-header {
  background: #0f0f0f;
  color: var(--text-light);
  border-bottom: 1px solid rgba(57,255,20,0.2);
}
.card-dark .list-group-item {
  background: #0e0e0e;
  color: var(--text-light);
  border-color: rgba(57,255,20,0.15);
}
.card-dark .list-group-item-action:hover,
.card-dark .list-group-item-action:focus {
  background: #121212;
  color: var(--text-light);
}
.card-dark .list-group-item.active {
  background: var(--neon);
  border-color: var(--neon);
  color: #000;
}

/* Merch hero */
.merch-hero {
  background: linear-gradient(180deg, rgba(57,255,20,0.08), rgba(57,255,20,0.02));
  border-bottom: 1px solid rgba(57,255,20,0.2);
}

.filter-total-count{
  background-color: #0e0e0e !important;
    color: #39ff14 !important;
}

/* Category chips (mobile) */
.category-chip {
  display: inline-block;
  padding: 6px 10px;
  border: 1px solid rgba(57,255,20,0.4);
  border-radius: 999px;
  color: var(--text-light);
  text-decoration: none;
  font-size: 0.9rem;
}
.category-chip.active {
  background: var(--neon);
  color: #000;
  border-color: var(--neon);
}

/* Product cards enhanced */
.product-list-section, .mix-list-section{
  padding-top: 0;
}

.product-card {
  transition: transform 200ms ease, box-shadow 200ms ease, border-color 200ms ease;
  border-color: rgba(57,255,20,0.25);
}
.product-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 24px rgba(57,255,20,0.12);
  border-color: var(--neon);
}
.product-media-wrap { position: relative; overflow: hidden; }
.product-media { transition: transform 300ms ease; }
.product-card:hover .product-media { transform: scale(1.04); }
.product-name{
  color: var(--neon);
}

/* Product detail gallery */
.product-gallery .thumb-img {
  width: 76px;
  height: 76px;
  object-fit: cover;
  border: 1px solid rgba(57,255,20,0.25);
  border-radius: 6px;
  transition: transform 150ms ease, box-shadow 150ms ease, border-color 150ms ease;
}
.product-gallery .thumb-btn:focus .thumb-img,
.product-gallery .thumb-btn:hover .thumb-img {
  transform: translateY(-2px);
  box-shadow: 0 6px 18px rgba(57,255,20,0.18);
  border-color: var(--neon);
}

.price-badge {
  position: absolute;
  top: 10px; right: 10px;
  background: rgba(0,0,0,0.7);
  border: 1px solid rgba(57,255,20,0.5);
  color: var(--text-light);
  padding: 4px 8px;
  font-size: 0.85rem;
  border-radius: 6px;
  z-index: 2;
}

.category-badge {
  position: absolute;
  top: 10px; left: 10px;
  /*background: rgba(57,255,20,0.15);*/
  background: #212a28;
  color: var(--neon);
  padding: 3px 6px;
  font-size: 0.7rem;
  border: 1px solid rgba(57,255,20,0.4);
  border-radius: 4px;
  letter-spacing: 0.08em;
  z-index: 2;
}

/* Sticky side card (desktop) */
@media (min-width: 768px) {
  .sticky-side { position: sticky; top: 90px; }
}

/* Modals */
.modal-content { background: #0c0c0c; color: var(--text-light); border: 1px solid rgba(57,255,20,0.2); }
.modal-header { border-bottom-color: rgba(57,255,20,0.15); }
.modal-footer { border-top-color: rgba(57,255,20,0.15); }
.modal .btn-close { 
  filter: invert(1) grayscale(100%) brightness(200%);
  opacity: 0.8;
}
.modal .btn-close:hover { 
  opacity: 1;
}

.form-switch .form-check-input { background-color: #1a1a1a; border-color: rgba(57,255,20,0.5); }
.form-switch .form-check-input:checked { background-color: var(--neon); border-color: var(--neon); }

/* reCAPTCHA customization */
.recaptcha-custom {
  display: inline-block;
  padding: 10px;
  background: #0f0f0f;
  border: 1px solid rgba(57,255,20,0.25);
  border-radius: 6px;
}
.recaptcha-custom:hover {
  border-color: var(--neon);
  box-shadow: 0 0 0 .2rem rgba(57,255,20,0.15);
}

/* Custom alerts */
.alert {
  background: #0e0e0e;
  border: 1px solid rgba(57,255,20,0.25);
  color: var(--text-light);
  padding: 1rem 1.25rem;
  border-radius: 6px;
  position: relative;
  overflow: hidden;
}

.alert::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 4px;
  height: 100%;
  background: var(--neon);
  opacity: 0.8;
}

.alert.alert-success {
  background: linear-gradient(90deg, rgba(57,255,20,0.1), transparent);
}

.alert.alert-success::before {
  background: var(--neon);
}

.alert.alert-danger {
  background: linear-gradient(90deg, rgba(255,57,20,0.1), transparent);
}

.alert.alert-danger::before {
  background: #ff3914;
}

/* Forms: make inputs match theme */
.form-control,
.form-select {
  background-color: #0f0f0f;
  color: var(--text-light);
  border-color: rgba(57,255,20,0.25);
}
.form-control::placeholder { color: #98b698; opacity: 0.8; }
.form-control:focus,
.form-select:focus {
  outline: none;
  box-shadow: 0 0 0 .2rem rgba(57,255,20,0.15);
  border-color: var(--neon);
}

/* Parallax bubbles background */
.parallax-container {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 0;
  overflow: hidden;
}

.parallax-bubbles {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 200%;
  will-change: transform;
}

.bubble {
  position: absolute;
  border-radius: 50%;
  opacity: 0;
  filter: blur(40px);
  animation: bubbleFadeIn 2s ease-out forwards, bubbleFloat 20s ease-in-out infinite;
}

.bubble.small {
  width: 80px;
  height: 80px;
  filter: blur(25px);
}

.bubble.medium {
  width: 150px;
  height: 150px;
  filter: blur(35px);
}

.bubble.large {
  width: 250px;
  height: 250px;
  filter: blur(50px);
}

.bubble.variant-1 {
  background: radial-gradient(circle at 30% 30%, rgba(57,255,20,0.15), rgba(57,255,20,0.03));
}

.bubble.variant-2 {
  background: radial-gradient(circle at 40% 40%, rgba(152,225,138,0.12), rgba(152,225,138,0.02));
}

.bubble.variant-3 {
  background: radial-gradient(circle at 35% 35%, rgba(57,255,20,0.18), rgba(57,255,20,0.04));
}

@keyframes bubbleFadeIn {
  from {
    opacity: 0;
    transform: scale(0.5);
  }
  to {
    opacity: 1;
    transform: scale(1);
  }
}

@keyframes bubbleFloat {
  0%, 100% {
    transform: translate(0, 0) scale(1);
  }
  25% {
    transform: translate(10px, -15px) scale(1.05);
  }
  50% {
    transform: translate(-15px, -10px) scale(0.95);
  }
  75% {
    transform: translate(8px, 12px) scale(1.02);
  }
}

/* Ensure sections have relative positioning and higher z-index */
main {
  position: relative;
  z-index: 1;
}

section {
  position: relative;
  z-index: 1;
}


/* Lazy embed placeholder */
.lazy-embed {
  position: relative;
  overflow: hidden;
}
.lazy-embed-placeholder {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  background: #0a0a0a;
  border: 0;
  cursor: pointer;
  z-index: 1;
}
.lazy-embed-placeholder img {
  max-width: 50%;
  height: auto;
  /*filter: drop-shadow(0 0 12px rgba(57,255,20,0.35));*/
}
.lazy-embed-placeholder:focus-visible {
  outline: 2px solid var(--neon);
  outline-offset: 2px;
}


