/* ===== WTC Unified Dark Theme with Red & Gold Accents ===== */

body {
  margin: 0;
  font-family: 'Oswald', Arial, sans-serif;
  background: #1a1a1a url('A_digital_painting_in_a_combination_of_realism_and.png') center center/cover no-repeat fixed;
  color: #fff;
  padding: 0;
}

a {
  color: #ffd700;
  text-decoration: none;
  transition: color 0.2s;
}
a:hover {
  color: #b00000;
  text-shadow: 0 0 5px #ffd700;
}

h1, h2, h3 {
  color: #ffd700;
  text-shadow: 0 0 8px #b0000055, 0 2px 12px #000;
  font-weight: 700;
  font-family: 'Oswald', Arial, sans-serif;
  letter-spacing: 1px;
}

p, li, label, input, select, textarea, th, td {
  font-family: 'Oswald', Arial, sans-serif;
}

/* ===================
    NAVIGATION (Hamburger)
   =================== */
.site-nav, .navbar {
  width: 100vw;
  background: #333;
  border-bottom: 2px solid #b00000;
  z-index: 100;
  display: flex;
  align-items: center;
  position: relative;
}

.site-nav-links, .nav-content {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  width: 100%;
  gap: 1em;
  padding: 1em 0;
}

.site-nav-link, .nav-link {
  color: #fff;
  background: #b00000;
  text-decoration: none;
  font-family: 'Oswald', Arial, sans-serif;
  font-weight: bold;
  padding: 0.4em 1.1em;
  border-radius: 10px;
  transition: background .2s, color .2s;
  border: 2px solid transparent;
  font-size: 1.1em;
  margin: 0 0.18em;
  box-shadow: 0 2px 10px #0007;
  display: inline-block;
}
.site-nav-link.active, .nav-link.active,
.site-nav-link:hover, .nav-link:hover {
  background: #ffd700;
  color: #b00000;
  border: 2px solid #b00000;
}

.hamburger {
  display: none;
  flex-direction: column;
  width: 44px;
  height: 44px;
  justify-content: center;
  background: none;
  border: none;
  cursor: pointer;
  z-index: 101;
  position: absolute;
  right: 10px;
  top: 10px;
}
.hamburger span {
  display: block;
  width: 32px;
  height: 5px;
  margin: 5px 0;
  background: #ffd700;
  border-radius: 3px;
  transition: 0.3s;
}

@media (max-width: 1200px) {
  .site-nav-links, .nav-content { gap: 0.5em; }
  .site-nav-link, .nav-link {
    font-size: 1em;
    padding: 0.32em 0.75em;
  }
}
@media (max-width: 900px) {
  .site-nav-links, .nav-content {
    gap: 0.2em;
    padding: 1em 0 0.7em 0;
  }
  .site-nav-link, .nav-link {
    font-size: 0.95em;
    padding: 0.32em 0.5em;
  }
}
@media (max-width: 800px) {
  .site-nav-links, .nav-content {
    display: none;
    flex-direction: column;
    background: #333;
    margin: 0;
    padding: 0.7em 0;
    box-shadow: 0 10px 32px #0006;
    position: absolute;
    width: 100%;
    left: 0;
    top: 100%;
  }
  .site-nav-links.open, .nav-content.open {
    display: flex;
  }
  .hamburger {
    display: flex;
  }
  .site-nav, .navbar {
    position: relative;
    min-height: 60px;
  }
}

/* ===================
   HERO & BUTTONS
   =================== */
.hero {
  text-align: center;
  padding: 50px 0;
}
.hero-title {
  font-size: 2.5rem;
  text-shadow: 0 0 10px #b00000;
}
.cta-button, button, input[type="submit"], .main-link {
  background: #ffd700;
  color: #8B0000;
  border: 3px solid #8B0000;
  padding: 1.2em 3.5em;
  font-weight: bold;
  border-radius: 17px;
  font-size: 1.3em;
  cursor: pointer;
  text-decoration: none;
  box-shadow: 0 0 18px #ffd700;
  transition: .18s;
  font-family: 'Oswald', Arial, sans-serif;
}
.cta-button:hover, button:hover, input[type="submit"]:hover, .main-link:hover {
  background: #8B0000;
  color: #ffd700;
  border-color: #ffd700;
}

/* ===================
   CARDS, SECTIONS, BLOCKS
   =================== */
.cards, .player-cards, .members-grid, .video-grid {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 2em;
  padding: 2em 0;
}
.card, .player-card, .section, .block, .video-card, .member-card {
  background: #222;
  border: 2px solid #ffd700;
  border-radius: 10px;
  box-shadow: 0 0 18px #ffd70044, 0 2px 12px #000a;
  padding: 1.2em;
  color: #fffbe2;
  font-family: 'Oswald', Arial, sans-serif;
  margin: 1em;
  text-align: center;
  transition: transform 0.2s, box-shadow 0.2s;
}
.card:hover, .player-card:hover, .video-card:hover, .member-card:hover {
  transform: translateY(-6px) scale(1.03);
  box-shadow: 0 4px 30px #ffd70066, 0 2px 12px #000c;
}
.cabinet-img, .member-flag, .video-iframe {
  border-radius: 7px;
  border: 2px solid #ffd700;
  background: #fff;
  margin-bottom: 0.7em;
}

.placeholder-img {
  width: 180px; height: 120px; border: 2px dashed #ffd700; border-radius: 10px;
  background: #292929; display: flex; align-items: center; justify-content: center;
  color: #ffd700; font-size: 1.25em; font-style: italic; opacity: 0.7; margin-bottom:1em;
  text-align:center;
}

/* ===================
   VIDEO GRID (Highlights)
   =================== */
.video-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: 2em;
  margin-top: 1.5em;
  margin-bottom: 2em;
}
.video-card {
  background: rgba(30,30,30,0.98);
  border-radius: 15px;
  box-shadow: 0 2px 18px #0008;
  padding: 1.2em;
  display: flex;
  flex-direction: column;
  align-items: center;
  border: 2px solid #ffd70022;
  transition: box-shadow 0.3s, border 0.3s;
}
.video-card:hover {
  box-shadow: 0 4px 24px #b00000bb;
  border: 2px solid #ffd700;
}
.video-title {
  color: #ffd700;
  font-size: 1.15em;
  margin: 0.9em 0 0.4em 0;
  text-align: center;
  font-weight: 600;
}
.video-iframe {
  width: 100%;
  aspect-ratio: 16/9;
  border: 2px solid #b00000;
  border-radius: 9px;
  background: #000;
  margin-bottom: 0.6em;
  max-width: 600px;
}

/* ===================
   MEMBERS
   =================== */
.member-card {
  background: linear-gradient(135deg,#2d2100 0,#332800 100%);
  border: 2px solid #ffd700;
  border-radius: 15px;
  box-shadow: 0 0 18px #ffd70044, 0 2px 12px #000a;
  padding: 1.5em 1em;
  text-align: center;
  color: #fffbe2;
  display: flex;
  flex-direction: column;
  align-items: center;
  min-height: 210px;
  position: relative;
  transition: transform 0.2s, box-shadow 0.2s;
}
.member-card:hover {
  transform: translateY(-6px) scale(1.03);
  box-shadow: 0 4px 30px #ffd70066, 0 2px 12px #000c;
}
.member-flag {
  width: 48px;
  height: 32px;
  border-radius: 4px;
  object-fit: contain;
  border: 2px solid #ffd700;
  background: #fff3;
  margin-bottom: 0.7em;
  box-shadow: 0 0 8px #ffd70077;
  display: block;
}
.member-name {
  font-size: 1.20em;
  color: #ffd700;
  font-weight: bold;
  margin-bottom: 0.4em;
  margin-top: 0.2em;
  letter-spacing: 1.2px;
  text-shadow: 0 0 8px #ffd70033;
}
.member-honours {
  color: #ffe080;
  font-size: 1em;
  margin-bottom: 0.2em;
  font-style: italic;
}
.member-stats {
  margin-top: 0.5em;
  display: flex;
  justify-content: center;
  gap: 1.7em;
}
.member-stat {
  color: #fffbe2cc;
  font-size: 1em;
  text-align: center;
  min-width: 70px;
}
.member-stat-label {
  color: #ffd700;
  font-size: 0.95em;
  font-weight: bold;
  display: block;
  margin-bottom: 2px;
}

/* ===================
   FOOTER
   =================== */
footer {
  background-color: #b00000;
  color: white;
  text-align: center;
  padding: 1rem;
  margin-top: 2rem;
  font-size: 1.1em;
  letter-spacing: 1px;
  border-top: 2px solid #ffd700;
}

/* ===================
   RESPONSIVE
   =================== */
@media (max-width: 700px) {
  .cards, .player-cards, .members-grid, .video-grid { gap: 1.1em; padding: 1em 0; }
  .main-link, .cta-button, button, input[type="submit"] { font-size: 1em; padding: 0.8em 1.3em; }
  .member-stats { gap: 0.8em; }
}
@media (max-width: 650px) {
  .container { padding: 0 0.3em; }
  .video-card { padding: 0.5em; }
  .video-title { font-size: 1em; }
}