/* Custom Styles for Pinball Kansas City */
:root {
  --bg-grad: radial-gradient(1200px 500px at 10% -20%, rgba(13,110,253,.15), transparent),
             radial-gradient(1200px 500px at 110% 20%, rgba(32,201,151,.18), transparent),
             linear-gradient(180deg, #0b1020 0%, #0a0e19 100%);
}
body {
  background: var(--bg-grad) fixed;
  color: #dbe3ff;
}
.navbar {
  backdrop-filter: saturate(1.2) blur(8px);
  background: rgba(10, 14, 25, 0.7) !important;
  border-bottom: 1px solid rgba(255,255,255,.08);
}
/* Mobile nav look: dark panel with pill links */
@media (max-width: 991.98px) {
  #mainNav .navbar-collapse {
    background: rgba(9,12,20,.96);
    border: 1px solid rgba(255,255,255,.08);
    border-radius: .9rem;
    padding: .75rem;
    margin-top: .5rem;
    box-shadow: 0 16px 38px rgba(0,0,0,.55);
  }
  #mainNav .navbar-nav { gap: .35rem; }
  #mainNav .nav-link {
    display: flex;
    align-items: center;
    gap: .5rem;
    color: #e8eeff;
    padding: .7rem .9rem;
    border-radius: .75rem;
    font-weight: 600;
    transition: background-color .15s ease, color .15s ease;
  }
  #mainNav .nav-link .bi { color: #cfe1ff; }
  #mainNav .nav-link:hover { background: rgba(255,255,255,.08); color: #ffffff; }
  #mainNav .nav-link.active,
  #mainNav .nav-link:focus,
  #mainNav .nav-link:active {
    background: #ffffff;
    color: #0b1020;
  }
  #mainNav .nav-link.active .bi,
  #mainNav .nav-link:focus .bi,
  #mainNav .nav-link:active .bi { color: #0b1020; }
}
.hero {
  position: relative;
  padding: 16rem 0 5rem;
  background: radial-gradient(80% 120% at 50% -10%, rgba(111,66,193,.25), transparent);
}
.hero::before {
  content: "";
  position: absolute; inset: 0;
  /* Path is relative to this CSS file */
  /* background: url('../images/oldkcpc.jpg') center center / cover no-repeat; */
  /* background: url('../images/hero-01.jpg') center center / cover no-repeat; */
  /* background: url('../images/hero-02.jpg') center center / cover no-repeat; */
  background: url('../images/hero-04.jpg') center center / cover no-repeat;
  opacity: .7;
  z-index: 0;
}
.hero > * { position: relative; z-index: 1; }
.hero h1 { letter-spacing: .5px; }
.hero .lead { color: #cfe1ff; }
.glass {
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.12);
  box-shadow: 0 10px 30px rgba(0,0,0,.35);
  color: #e9efff;
}
.glass h5 { color: #ffffff; }
.card.glass:hover { transform: translateY(-2px); transition: transform .2s ease; }
.section-title {
  color: #fff;
  font-weight: 700;
  letter-spacing: .3px;
}
.text-muted-soft { color: #a6b4d0 !important; }
.btn-lightglass {
  color: #0b1020;
  background: #ffffff;
  border: none;
}
.btn-lightglass:hover { background: #e9eefc; }
.link-arrow { text-decoration: none; }
.link-arrow i { transition: transform .15s ease; }
.link-arrow:hover i { transform: translateX(2px); }
footer { border-top: 1px solid rgba(255,255,255,.08); }
.brand-badge {
  display: inline-flex; align-items: center; gap: .5rem;
  padding: .375rem .75rem; border-radius: 999px;
  background: rgba(13,110,253,.12); color: #9ec5fe;
  border: 1px solid rgba(13,110,253,.25);
}
.shadow-soft { box-shadow: 0 10px 30px rgba(0,0,0,.25); }
.ratio-21x9 { --bs-aspect-ratio: 42.857%; }
img.object-fit-cover { object-fit: cover; }
.league-logo, .logo-placeholder {
  width: 72px; height: 72px;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.16);
  border-radius: .6rem;
  display: inline-flex; align-items: center; justify-content: center;
}
.league-logo { object-fit: contain; background: rgba(255,255,255,.06); }
.logo-placeholder i { font-size: 28px; color: #ffffff; }

/* Events tables */
.events-table td, .events-table th { vertical-align: middle; padding: .5rem .25rem; }
.events-table .col-day { width: 180px; white-space: nowrap; }
.events-table .col-time { width: 92px; text-align: center; font-variant-numeric: tabular-nums; font-feature-settings: "tnum" 1; }
.events-table .col-venue { width: auto; }
.events-table .col-details { width: 180px; text-align: right; }
.table-transparent tr, .table-transparent th, .table-transparent td { background-color: transparent !important; }
.events-table .col-venue .venue-sub { display: block; color: #a6b4d0; margin-top: .125rem; }
/* Improve contrast for badges and table text on dark glass cards */
.events-table { color: #e9efff; }
.events-table .badge {
  background: rgba(255,255,255,.10) !important;
  color: #ffffff !important;
  border: 1px solid rgba(255,255,255,.22) !important;
  font-weight: 600;
}
.events-table .col-day .badge {
  width: 75px;
}
.events-table .col-day .badge:first-of-type {
  /* width: 75px;
  display: inline-block; */
}
.events-table .col-details .pill {
    width: 73px;
    text-align: center;
}
.events-table .col-details .pill:first-of-type {
  width: 85px;
  display: inline-block;
  text-align: center;
}
.events-table .venue-sub { color: #c8d4f0; }

/* Weekly card compact list */
.weekly-list .item {
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: .5rem;
  padding: .6rem .75rem;
}
.weekly-list .item + .item { margin-top: .5rem; }
.weekly-list .top {
  display: flex; align-items: baseline; gap: .5rem; flex-wrap: wrap;
}
.weekly-list .day { color: #ffffff; font-weight: 700; }
.weekly-list .time { color: #cfe1ff; font-variant-numeric: tabular-nums; }
.weekly-list .venue { color: #a6b4d0; margin-top: .15rem; }

/* Compact pills for metadata */
.pill { display: inline-block; font-size: .75rem; line-height: 1; padding: .3rem .55rem; border-radius: 999px; border: 1px solid; }
.pill-success { background: rgba(25,135,84,.18); border-color: rgba(25,135,84,.4); color: #9ad0a6; }
.pill-pass { background: rgba(13,110,253,.20); border-color: rgba(13,110,253,.45); color: #b6d3ff; }
.pill-drop { background: rgba(25,135,84,.18); border-color: rgba(25,135,84,.4); color: #9ad0a6; }
.pill-warning { background: rgba(255,193,7,.22); border-color: rgba(255,193,7,.45); color: #ffe29a; }
.pill-danger { background: #f8d7da; border-color: #f1aeb5; color: #dc3545; }
.venue-meta { margin-top: .25rem; display: flex; gap: .4rem; flex-wrap: wrap; }
/* Inline venue + tags layout for monthlies */
.venue-inline { display: flex; align-items: center; justify-content: space-between; gap: .5rem; }
.venue-inline .name { color: #ffffff; font-weight: 600; }
.venue-inline .tags { display: flex; flex-wrap: wrap; gap: .35rem; justify-content: flex-end; }
.events-table .col-details .tags { display: flex; flex-wrap: wrap; gap: .35rem; justify-content: flex-end; }

/* <= SM: 25% day, 50% venue, 25% details (xs, sm) */
@media (max-width: 767.98px) {
  .events-table { table-layout: fixed; }
  .events-table .col-day { width: 25%; white-space: normal; }
  .events-table .col-venue { width: 50%; }
  .events-table .col-details { width: 25%; }
}

.ks {
 color: #8babf1 !important;
}

.mo {
 color: #f8b8d0 !important;
}