/* ==========================================================================
   KMSP Tournament Styles — Dark Theme
   Target: martial_tournament CPT pages + shortcodes
   Version: 1.0.0
   Dependencies: site-wide.css (design tokens)
   ========================================================================== */

/* ===== 1. TOURNAMENT INFOBOX ===== */
.kmsp-tournament-infobox {
  background: var(--kmsp-bg-card, #16213e);
  border: 1px solid var(--kmsp-border-strong, rgba(255,255,255,0.15));
  border-left: 4px solid var(--kmsp-accent, #ff5252);
  border-radius: var(--kmsp-radius, 12px);
  padding: var(--kmsp-space-lg, 24px);
  margin-bottom: var(--kmsp-space-xl, 32px);
}

.kmsp-tournament-infobox h2 {
  margin: 0 0 var(--kmsp-space-md, 16px);
  font-size: 1.25rem;
  color: var(--kmsp-text-bright, #fff);
}

/* Override calendar.css light theme for tournament context */
.kmsp-tournament-infobox .kmsp-event-table {
  width: 100%;
  border-collapse: collapse;
}

.kmsp-tournament-infobox .kmsp-event-table th {
  text-align: left;
  padding: 10px 14px;
  width: 130px;
  color: var(--kmsp-text-muted, #8a8a9a);
  border-bottom: 1px solid var(--kmsp-border, rgba(255,255,255,0.08));
  font-weight: 600;
  font-size: 0.9rem;
  white-space: nowrap;
}

.kmsp-tournament-infobox .kmsp-event-table td {
  padding: 10px 14px;
  border-bottom: 1px solid var(--kmsp-border, rgba(255,255,255,0.08));
  color: var(--kmsp-text, #e8e8e8);
}

.kmsp-tournament-infobox .kmsp-event-table time {
  color: var(--kmsp-gold, #ffc107);
  font-weight: 600;
}

/* ===== 2. SECTION HEADINGS ===== */
.kmsp-tournament-categories h2,
.kmsp-tournament-results h2,
.kmsp-tournament-standings h2,
.kmsp-tournament-live h2,
.kmsp-tournament-bracket h2,
.kmsp-tournament-source p,
.kmsp-event-nearby h2,
.kmsp-event-links h2 {
  font-size: 1.2rem;
  color: var(--kmsp-text-bright, #fff);
  margin-bottom: var(--kmsp-space-md, 16px);
}

/* ===== 3. TOURNAMENT SECTIONS (shared layout) ===== */
.kmsp-tournament-categories,
.kmsp-tournament-results,
.kmsp-tournament-standings,
.kmsp-tournament-live,
.kmsp-tournament-bracket,
.kmsp-tournament-source,
.kmsp-event-nearby,
.kmsp-event-links {
  margin-top: var(--kmsp-space-xl, 32px);
  padding-top: var(--kmsp-space-lg, 24px);
  border-top: 1px solid var(--kmsp-border, rgba(255,255,255,0.08));
}

/* ===== 4. CATEGORIES LIST ===== */
.kmsp-tournament-categories ul {
  list-style: none;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: var(--kmsp-space-sm, 8px);
}

.kmsp-tournament-categories li {
  background: var(--kmsp-bg-light, #0f3460);
  color: var(--kmsp-text, #e8e8e8);
  padding: 6px 14px;
  border-radius: var(--kmsp-radius-full, 9999px);
  font-size: 0.85rem;
  border: 1px solid var(--kmsp-border, rgba(255,255,255,0.08));
}

/* ===== 5. RESULTS & STANDINGS TABLES ===== */
/* Override site-wide.css .kmsp-tech-full-table for dark context */
.kmsp-tournament-results .kmsp-tech-full-table,
.kmsp-tournament-standings .kmsp-tech-full-table {
  background: var(--kmsp-bg-card, #16213e);
  border-radius: var(--kmsp-radius-sm, 6px);
  overflow: hidden;
}

.kmsp-tournament-results .kmsp-tech-full-table thead tr,
.kmsp-tournament-standings .kmsp-tech-full-table thead tr {
  background: var(--kmsp-bg-light, #0f3460);
}

.kmsp-tournament-results .kmsp-tech-full-table th,
.kmsp-tournament-standings .kmsp-tech-full-table th {
  color: var(--kmsp-gold, #ffc107);
  font-weight: 700;
  font-size: 0.9rem;
}

.kmsp-tournament-results .kmsp-tech-full-table td,
.kmsp-tournament-standings .kmsp-tech-full-table td {
  color: var(--kmsp-text, #e8e8e8);
}

.kmsp-tournament-results .kmsp-tech-full-table tr:hover td,
.kmsp-tournament-standings .kmsp-tech-full-table tr:hover td {
  background: rgba(255, 255, 255, 0.03);
}

/* Rank column highlight (first td = rank) */
.kmsp-tournament-results .kmsp-tech-full-table td:first-child,
.kmsp-tournament-standings .kmsp-tech-full-table td:first-child {
  font-weight: 700;
  color: var(--kmsp-gold, #ffc107);
  text-align: center;
  width: 60px;
}

/* ===== 6. LIVE EMBED ===== */
.kmsp-tournament-live {
  position: relative;
}

.kmsp-tournament-live::before {
  content: '';
  display: inline-block;
  width: 10px;
  height: 10px;
  background: #ff0000;
  border-radius: 50%;
  animation: kmsp-pulse 1.5s ease-in-out infinite;
  margin-right: 8px;
  vertical-align: middle;
}

@keyframes kmsp-pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%      { opacity: 0.5; transform: scale(1.3); }
}

.kmsp-tournament-live iframe {
  width: 100%;
  min-height: 500px;
  border: none;
  border-radius: var(--kmsp-radius, 12px);
  box-shadow: var(--kmsp-shadow, 0 4px 20px rgba(0,0,0,0.4));
}

/* ===== 7. BRACKET / TOURNAMENT TREE ===== */
.kmsp-bracket-container {
  display: flex;
  gap: var(--kmsp-space-lg, 24px);
  overflow-x: auto;
  padding: var(--kmsp-space-md, 16px) 0;
  -webkit-overflow-scrolling: touch;
}

.kmsp-bracket-round {
  flex: 0 0 auto;
  min-width: 200px;
}

.kmsp-bracket-round h3,
.kmsp-bracket-round h4 {
  text-align: center;
  font-size: 0.9rem;
  color: var(--kmsp-text-muted, #8a8a9a);
  margin-bottom: var(--kmsp-space-md, 16px);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.kmsp-bracket-match {
  background: var(--kmsp-bg-card, #16213e);
  border: 1px solid var(--kmsp-border-strong, rgba(255,255,255,0.15));
  border-radius: var(--kmsp-radius-sm, 6px);
  margin-bottom: var(--kmsp-space-md, 16px);
  overflow: hidden;
}

.kmsp-bracket-player {
  padding: 10px 14px;
  font-size: 0.9rem;
  color: var(--kmsp-text, #e8e8e8);
  display: flex;
  justify-content: space-between;
  align-items: center;
  transition: background 0.2s;
}

.kmsp-bracket-player + .kmsp-bracket-player {
  border-top: 1px solid var(--kmsp-border, rgba(255,255,255,0.08));
}

.kmsp-bracket-player.winner {
  background: rgba(255, 82, 82, 0.15);
  color: var(--kmsp-accent, #ff5252);
  font-weight: 700;
}

.kmsp-bracket-player.winner::after {
  content: '🏆';
  font-size: 0.8rem;
}

.kmsp-bracket-player span {
  font-weight: 700;
  color: var(--kmsp-gold, #ffc107);
  font-size: 0.85rem;
}

/* ===== 8. LIVE BADGE ===== */
.kmsp-live-badge {
  display: inline-block;
  background: #ff0000;
  color: #fff;
  font-size: 0.75rem;
  font-weight: 700;
  padding: 2px 8px;
  border-radius: var(--kmsp-radius-full, 9999px);
  animation: kmsp-pulse 1.5s ease-in-out infinite;
  vertical-align: middle;
  letter-spacing: 0.05em;
}

/* ===== 9. POWERED BY ===== */
.kmsp-powered-by {
  text-align: center;
  margin: var(--kmsp-space-xl, 32px) 0;
  color: var(--kmsp-text-muted, #8a8a9a);
  font-size: 0.85rem;
}

.kmsp-powered-by a {
  color: var(--kmsp-accent, #ff5252);
  text-decoration: none;
  font-weight: 700;
  transition: color 0.2s;
}

.kmsp-powered-by a:hover {
  color: var(--kmsp-gold, #ffc107);
  text-decoration: underline;
}

/* ===== 10. MASCOT TIP ===== */
.kmsp-mascot-tip {
  background: linear-gradient(135deg, var(--kmsp-bg-light, #0f3460), var(--kmsp-bg-card, #16213e));
  border: 1px solid var(--kmsp-border-strong, rgba(255,255,255,0.15));
  border-left: 4px solid var(--kmsp-gold, #ffc107);
  border-radius: var(--kmsp-radius, 12px);
  padding: var(--kmsp-space-lg, 24px);
  margin: var(--kmsp-space-xl, 32px) 0;
  position: relative;
}

.kmsp-mascot-tip::before {
  content: '💬';
  position: absolute;
  top: -12px;
  left: 16px;
  font-size: 1.4rem;
  background: var(--kmsp-bg, #1a1a2e);
  padding: 0 4px;
}

.kmsp-mascot-tip p {
  color: var(--kmsp-text, #e8e8e8);
  font-size: 0.95rem;
  line-height: 1.7;
  margin: 0;
}

/* ===== 11. NEARBY GYMS (dark override) ===== */
.singular-martial_tournament .kmsp-event-nearby,
.singular-martial_tournament .kmsp-event-links {
  border-top-color: var(--kmsp-border, rgba(255,255,255,0.08));
}

.singular-martial_tournament .kmsp-related-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: var(--kmsp-space-md, 16px);
}

.singular-martial_tournament .kmsp-related-card {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: var(--kmsp-space-md, 16px);
  background: var(--kmsp-bg-card, #16213e);
  border: 1px solid var(--kmsp-border, rgba(255,255,255,0.08));
  border-radius: var(--kmsp-radius-sm, 6px);
  text-decoration: none;
  color: var(--kmsp-text, #e8e8e8);
  transition: border-color 0.2s, box-shadow 0.2s;
}

.singular-martial_tournament .kmsp-related-card:hover {
  border-color: var(--kmsp-accent, #ff5252);
  box-shadow: 0 2px 12px rgba(255, 82, 82, 0.15);
}

.singular-martial_tournament .kmsp-related-card strong {
  color: var(--kmsp-text-bright, #fff);
  font-size: 0.95rem;
}

.singular-martial_tournament .kmsp-related-card .kmsp-stars {
  font-size: 0.85rem;
  color: var(--kmsp-gold, #ffc107);
}

.singular-martial_tournament .kmsp-related-card .kmsp-addr {
  font-size: 0.8rem;
  color: var(--kmsp-text-muted, #8a8a9a);
}

/* ===== 12. EVENT LINKS (dark override) ===== */
.singular-martial_tournament .kmsp-event-links ul {
  list-style: none;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.singular-martial_tournament .kmsp-event-links li a {
  display: inline-block;
  padding: 8px 16px;
  border: 1px solid var(--kmsp-border-strong, rgba(255,255,255,0.15));
  border-radius: var(--kmsp-radius-full, 9999px);
  text-decoration: none;
  color: var(--kmsp-text, #e8e8e8);
  font-size: 0.85rem;
  background: var(--kmsp-bg-card, #16213e);
  transition: all 0.2s;
}

.singular-martial_tournament .kmsp-event-links li a:hover {
  border-color: var(--kmsp-accent, #ff5252);
  color: var(--kmsp-accent, #ff5252);
  background: rgba(255, 82, 82, 0.08);
}

/* ===== 13. SOURCE EVENT LINK ===== */
.kmsp-tournament-source {
  background: var(--kmsp-bg-card, #16213e);
  border-radius: var(--kmsp-radius-sm, 6px);
  padding: var(--kmsp-space-md, 16px);
}

.kmsp-tournament-source p {
  margin: 0;
  color: var(--kmsp-text, #e8e8e8);
  font-size: 0.9rem;
}

.kmsp-tournament-source a {
  color: var(--kmsp-accent, #ff5252);
  text-decoration: none;
  font-weight: 600;
}

.kmsp-tournament-source a:hover {
  text-decoration: underline;
}

/* ===== 14. SHORTCODE WIDGETS ===== */
.kmsp-tournament-results-widget,
.kmsp-tournament-bracket-widget,
.kmsp-tournament-standings-widget {
  background: var(--kmsp-bg-card, #16213e);
  border: 1px solid var(--kmsp-border, rgba(255,255,255,0.08));
  border-radius: var(--kmsp-radius, 12px);
  padding: var(--kmsp-space-lg, 24px);
  margin: var(--kmsp-space-lg, 24px) 0;
}

.kmsp-tournament-results-widget h3,
.kmsp-tournament-bracket-widget h3,
.kmsp-tournament-standings-widget h3 {
  color: var(--kmsp-text-bright, #fff);
  font-size: 1.1rem;
  margin: 0 0 var(--kmsp-space-md, 16px);
}

.kmsp-tournament-results-widget a,
.kmsp-tournament-bracket-widget a,
.kmsp-tournament-standings-widget a {
  color: var(--kmsp-accent, #ff5252);
  text-decoration: none;
}

.kmsp-tournament-results-widget a:hover,
.kmsp-tournament-bracket-widget a:hover,
.kmsp-tournament-standings-widget a:hover {
  text-decoration: underline;
}

/* ===== 15. TOURNAMENT LIST (shortcode) ===== */
.kmsp-tournament-list {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: var(--kmsp-space-md, 16px);
}

.kmsp-tournament-list .kmsp-related-card {
  background: var(--kmsp-bg-card, #16213e);
  border: 1px solid var(--kmsp-border, rgba(255,255,255,0.08));
  border-radius: var(--kmsp-radius-sm, 6px);
  padding: var(--kmsp-space-md, 16px);
  display: flex;
  flex-direction: column;
  gap: 6px;
  text-decoration: none;
  color: var(--kmsp-text, #e8e8e8);
  transition: border-color 0.2s, transform 0.2s;
}

.kmsp-tournament-list .kmsp-related-card:hover {
  border-color: var(--kmsp-accent, #ff5252);
  transform: translateY(-2px);
}

.kmsp-tournament-list .kmsp-related-card strong {
  color: var(--kmsp-text-bright, #fff);
  font-size: 0.95rem;
}

.kmsp-tournament-list .kmsp-related-card span {
  font-size: 0.8rem;
  color: var(--kmsp-text-muted, #8a8a9a);
}

.kmsp-tournament-list .kmsp-related-card .kmsp-live-badge {
  font-size: 0.75rem;
  color: #fff;
}

/* ===== 16. TOURNAMENT ARCHIVE PAGE ===== */
.post-type-archive-martial_tournament .ast-article-post {
  background: var(--kmsp-bg-card, #16213e);
  border: 1px solid var(--kmsp-border, rgba(255,255,255,0.08));
  border-radius: var(--kmsp-radius, 12px);
  padding: var(--kmsp-space-lg, 24px);
  margin-bottom: var(--kmsp-space-lg, 24px);
  transition: border-color 0.2s;
}

.post-type-archive-martial_tournament .ast-article-post:hover {
  border-color: var(--kmsp-accent, #ff5252);
}

.post-type-archive-martial_tournament .entry-title a {
  color: var(--kmsp-text-bright, #fff);
  text-decoration: none;
}

.post-type-archive-martial_tournament .entry-title a:hover {
  color: var(--kmsp-accent, #ff5252);
}

/* ===== 17. RESPONSIVE ===== */
@media (max-width: 768px) {
  .kmsp-tournament-infobox {
    padding: var(--kmsp-space-md, 16px);
  }

  .kmsp-tournament-infobox .kmsp-event-table th {
    width: 90px;
    font-size: 0.82rem;
    padding: 8px 10px;
  }

  .kmsp-tournament-infobox .kmsp-event-table td {
    padding: 8px 10px;
    font-size: 0.9rem;
  }

  .kmsp-bracket-container {
    gap: var(--kmsp-space-md, 16px);
    padding-bottom: var(--kmsp-space-md, 16px);
  }

  .kmsp-bracket-round {
    min-width: 170px;
  }

  .kmsp-tournament-list {
    grid-template-columns: 1fr;
  }

  .singular-martial_tournament .kmsp-related-grid {
    grid-template-columns: 1fr;
  }

  .kmsp-mascot-tip {
    padding: var(--kmsp-space-md, 16px);
  }

  .kmsp-tournament-results .kmsp-tech-full-table,
  .kmsp-tournament-standings .kmsp-tech-full-table {
    display: block;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
}

@media (max-width: 480px) {
  .kmsp-bracket-round {
    min-width: 150px;
  }

  .kmsp-bracket-player {
    padding: 8px 10px;
    font-size: 0.82rem;
  }

  .singular-martial_tournament .kmsp-event-links li a {
    padding: 6px 12px;
    font-size: 0.8rem;
  }
}
