/* ==========================================================
   Swamplands Festival Styles (With Variables)
   ========================================================== */

:root {
  /* --- Color Palette --- */
  --color-bg: #0F2D40;             /* Midnight swamp blue */
  --color-primary: #1A3F4E;        /* Deep teal */
  --color-secondary: #1E4D5E;      /* Accent blue */
  --color-gold: #F8E4B5;           /* Torchlight gold */
  --color-orange: #D2691E;         /* Rustic orange */
  --color-orange-dark: #A0522D;
  --color-highlight: #fd7e14;      /* Bootstrap orange variant */
  --color-border-light: #dee2e6;

  /* --- Typography --- */
  --font-heading: 'Cinzel', serif;
  --font-body: 'Spectral', serif;
  --font-decor: 'Special Elite', cursive;
}

/* -------------------------
   General Styles
   ------------------------- */

html {
  overflow-x: hidden;
}

body {
  font-family: var(--font-body);
  background-color: var(--color-bg) !important;
  color: var(--color-gold);
  text-align: center;
  padding-top: 70px;
  overflow-x: hidden;
}

strong {
  font-weight: bold !important;
}

/* -------------------------
   Button Styles
   ------------------------- */

.btn-primary {
  background-color: var(--color-orange);
  border: none;
  font-size: 1.2rem;
  color: var(--color-gold);
  border-radius: 8px;
}

.btn-primary:hover {
  background-color: var(--color-orange-dark);
}


/* -------------------------
   Card Styles
   ------------------------- */

.card {
  background-color: var(--color-primary);
  color: var(--color-gold);
  border: 2px solid var(--color-orange);
  margin-bottom: 15px;
  padding: 10px;
}

.custom-card-dark {
  background-color: #1a2c34;
  color: var(--color-gold);
  border: 1px solid rgba(255, 255, 255, 0.1);
  padding: 1.5rem;
  border-radius: 12px;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.custom-card-dark:hover {
  transform: translateY(-4px);
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.3);
}

/* Headings inside dark card */
.custom-card-dark h5 {
  font-family: 'Playfair Display', serif;
  font-weight: 600;
  margin-bottom: 1rem;
  color: var(--color-gold);
  border-bottom: 1px solid rgba(255, 255, 255, 0.15);
  padding-bottom: 0.5rem;
}

/* Paragraphs inside dark card */
.custom-card-dark p {
  font-size: 1rem;
  margin-bottom: 1rem;
  color: var(--color-gold);
  line-height: 1.5;
}

/* Links */
.custom-card-dark a {
  color: var(--color-orange);
  font-weight: 500;
  text-decoration: none;

  transition: color 0.3s ease, border-color 0.3s ease;
}

.custom-card-dark a:hover {
  color: var(--color-orange);
  border-color: var(--color-orange);
}

/* List items */
.custom-card-dark ul {
  padding-left: 1.2rem;
  margin-top: 1rem;
}

.custom-card-dark ul li {
  color: var(--color-gold);
  font-size: 0.95rem;
  margin-bottom: 0.5rem;
  padding-left: 1.2rem;
  position: relative;
}


/* -------------------------
   Icon/Link Styles
   ------------------------- */

i {
  font-size: 2rem;
  color: var(--color-orange);
}

a {
  color: var(--color-orange);
}

/* -------------------------
   Navbar Styles
   ------------------------- */

.navbar {
  background-color: var(--color-bg) !important;
  position: fixed;
  width: 100%;
  top: 0;
  left: 0;
  z-index: 1000;
}

.navbar-brand,
.nav-link {
  font-family: var(--font-decor);
  color: var(--color-gold) !important;
}

/* -------------------------
   Hero Section Styles
   ------------------------- */
.hero {
  position: relative;
  z-index: 0;
  width: 100%;
  min-height: 75vh;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  background: url('../imgs/hero.PNG') no-repeat center center;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center top;
  aspect-ratio: 16 / 9;           /* ✅ Prevents tall cropping on mobile */
  max-height: 80vh;               /* ✅ Keeps it viewable */
  padding-top: 100px;
  padding-bottom: 100px;

}


/* -------------------------
   Footer Styles
   ------------------------- */

.footer p {
  color: var(--color-gold);
}

.footer a {
  color: var(--color-orange-dark);
}

/* -------------------------
   Event Container Section
   ------------------------- */

.event-container {
  padding: 40px 20px;
}

/* -------------------------
   Event Pill Styles
   ------------------------- */

.event-pill {
  background-color: var(--color-primary);
  color: var(--color-gold);
  padding: 2rem;
  margin-top: 2rem;
  border-radius: 50px;
  box-shadow: 0 3px 6px rgba(0, 0, 0, 0.3);
  transition: transform 0.2s ease-in-out;
}

.orange-border {
  border: 2px solid var(--color-highlight);
}

.border-accent {
  border-left: 4px solid var(--color-orange);
}

.event-pill .border {
  border: 1px solid var(--color-border-light) !important;
  background-color: var(--color-primary) !important;
  color: var(--color-secondary) !important;
  transition: all 0.3s ease;
  border-radius: 20px;
}

.event-pill:hover {
  transform: scale(1.02);
}

.event-pill .border:hover {
  transform: translateY(-5px);
  box-shadow: 0 6px 16px rgba(0, 0, 0, 0.10);
  background-color: var(--color-primary);
}

/* Event Titles & Descriptions */
.event-title {
  font-size: 1.8rem;
  font-weight: bold;
  font-family: var(--font-heading);
  color: var(--color-gold);
  text-align: center;
}

.event-desc {
  font-size: 1.2rem;
  text-align: center;
  margin-bottom: 10px;
}

.event-details p {
  font-size: 1.1rem;
  margin: 5px 0;
  text-align: center;
}

.event-pill h5,
.event-pill p {
  color: var(--color-gold);
}

.event-pill h5 {
  font-weight: 600;
  font-size: 1.25rem;
  margin-bottom: 0.75rem;
}

.event-pill p {
  font-size: 1rem;
  margin-bottom: 0;
}

/* Utility Class */
.text-orange {
  color: var(--color-highlight);
}

/* -------------------------
   Accordion Styling
   ------------------------- */

.accordion {
  background-color: transparent;
  border: none;
}

.accordion-item {
  background-color: var(--color-secondary);
  border: 2px solid var(--color-orange);
  border-radius: 10px;
  margin-bottom: 10px;
}

.accordion-button {
  background-color: var(--color-bg);
  color: var(--color-gold);
  font-weight: bold;
  font-family: var(--font-body);
  font-size: 1.3rem;
  text-align: left;
  padding: 15px;
  border-radius: 10px;
  transition: background 0.3s ease-in-out;
}

.accordion-button:not(.collapsed) {
  background-color: var(--color-bg);
  color: var(--color-gold);
  box-shadow: none;
}

.accordion-button:hover {
  background-color: var(--color-orange-dark);
}

.accordion-body {
  background-color: var(--color-secondary);
  color: var(--color-gold);
  padding: 15px;
  text-align: left;
}

/* -------------------------
   Responsive Adjustments
   ------------------------- */
/* Mobile Adjustments */
@media (max-width: 768px) {
  .hero {

  background-size: contain !important;
  background-repeat: no-repeat;
  background-position: center top;

    min-height: 50vh;
    height: auto;
    aspect-ratio: auto;
    padding-top: 80px;

  }

  .hero h1 {
    font-size: 2.25rem;
  }

  .card {
    margin-bottom: 15px;
    padding: 10px;
  }
}

@media (max-width: 576px) {
  .event-pill {
    padding: 1rem !important;
    border-radius: 20px !important;
  }
}