:root{
  --bg:#0b0b0b; --txt:#f6f6f6; --muted:#c8c8c8;
  --panel: rgba(255,255,255,.06); --stroke: rgba(255,255,255,.18);
  --orange:#ff7a18; --orange-strong:#ff8c32; --good:#40d39b;
  --bad:#ff5d5d;
  --shadow: 0 18px 48px rgba(0,0,0,.46);
}
*{ box-sizing:border-box } html,body{ height:100% }
body{
  margin:0; font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  background:var(--bg); color:var(--txt); overflow-x:hidden;
}

/* background */
.bg-mesh{
  position:fixed; inset:-10vmax; z-index:-3;
  background:
    radial-gradient(42vmax 42vmax at 12% 18%, rgba(255,122,24,.18), transparent 60%),
    radial-gradient(50vmax 50vmax at 88% 22%, rgba(255,122,24,.08), transparent 60%),
    radial-gradient(55vmax 55vmax at 50% 88%, rgba(255,255,255,.06), transparent 60%),
    linear-gradient(180deg, #0b0b0b 0%, #0a0a0a 100%);
  animation: float 24s ease-in-out infinite alternate; filter:saturate(1.05);
}
@keyframes float{ 0%{transform:translateY(0)} 100%{transform:translateY(-1.2vh)} }
.grid-overlay{
  position:fixed; inset:0; z-index:-2; pointer-events:none;
  background:
    linear-gradient(rgba(255,255,255,.05) 1px, transparent 1px) 0 0/44px 44px,
    linear-gradient(90deg, rgba(255,255,255,.05) 1px, transparent 1px) 0 0/44px 44px;
  mask-image: radial-gradient(80% 60% at 50% 40%, rgba(0,0,0,.9), transparent 80%);
}

/* layout */
.container{ width:min(1100px,92vw); margin-inline:auto }
.glass{
  background:var(--panel); border:1px solid var(--stroke);
  border-radius:22px; backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px);
  box-shadow:var(--shadow)
}
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.55rem;
  padding:.6rem .9rem; border-radius:12px; border:1px solid rgba(255,255,255,.24);
  color:var(--txt); background:rgba(255,255,255,.06); font-weight:800; transition:.22s;
}
.btn.small{ padding:.45rem .7rem; font-weight:700 }
.btn:hover{ transform:translateY(-2px); box-shadow:0 14px 28px rgba(255,122,24,.22) }
.btn.primary{ background:linear-gradient(135deg,#ff7a18,#ff9538); border-color:#ff9a3f; color:#0a0a0a }
.btn.outline{ background:transparent }
.upgrade{ background:linear-gradient(135deg,#ff7a18,#ff9538); border-color:#ff9a3f; color:#0a0a0a }

/* header */
.topbar{ display:flex; align-items:center; justify-content:space-between; padding:20px 0 }
.brand{ display:flex; align-items:center; gap:.6rem; text-decoration:none; color:var(--txt) }
.brand-logo{ height:80px; width:auto; object-fit:contain; filter: drop-shadow(0 4px 10px rgba(255,122,24,.4)) }
.nav{ display:flex; gap:.6rem; flex-wrap:wrap }
.nav a{ color:var(--txt); text-decoration:none; opacity:.9; padding:.55rem .8rem; border-radius:10px }
.nav a:hover{ background:rgba(255,255,255,.08); opacity:1 }

/* hero */
.hero{ padding:1.2rem; margin:.6rem 0 1rem; display:grid; gap:1rem }
.hero-copy{ text-align:center }
.eyebrow{ display:inline-block; padding:.35rem .6rem; border-radius:999px; background:rgba(255,255,255,.08); border:1px solid var(--stroke); font-weight:800; margin-bottom:.5rem }
h1{ margin:.2rem 0 .35rem; font-size: clamp(26px, 3.2vw, 38px) }
.lede{ margin:.2rem 0 .7rem; color:var(--muted) }

/* filters */
.filters{ display:grid; gap:.8rem }
.search{
  position:relative; display:flex; align-items:center; gap:.4rem;
  background:rgba(255,255,255,.06); border:1px solid var(--stroke); border-radius:14px; padding:.55rem .7rem;
}
.search .i{ width:18px;height:18px; opacity:.7 }
.search input{
  border:none; outline:none; width:100%; background:transparent; color:var(--txt); font:inherit;
}
.row{ display:flex; gap:.6rem; flex-wrap:wrap; align-items:center }

.chip-group{ display:flex; gap:.4rem; flex-wrap:wrap }
.chip{
  padding:.45rem .7rem; border-radius:999px; background:rgba(255,255,255,.06); border:1px solid var(--stroke);
  color:var(--txt); font-weight:800; cursor:pointer; transition:.18s
}
.chip:hover{ transform:translateY(-1px) }
.chip.active{ background:linear-gradient(135deg, rgba(255,122,24,.30), rgba(255,122,24,.12)); border-color:rgba(255,122,24,.55) }

.select{ display:flex; align-items:center; gap:.45rem; background:rgba(255,255,255,.06); border:1px solid var(--stroke); border-radius:12px; padding:.35rem .5rem }
.select span{ color:var(--muted); font-weight:700 }
.select select{ appearance:none; background:transparent; color:var(--txt); border:none; outline:none; font-weight:700 }

/* summary */
.summary{ padding:.7rem 1rem; margin-bottom:.6rem; font-weight:800 }

/* list items */
.list{ list-style:none; padding:0; margin:0; display:grid; gap:.55rem }
.item{
  display:grid; grid-template-columns: auto 1fr auto auto; align-items:center; gap:.8rem;
  padding:.6rem .7rem; border:1px solid var(--stroke); background:rgba(255,255,255,.06); border-radius:18px;
  transition:.18s;
}
.item:hover{ transform:translateY(-2px); box-shadow:0 18px 36px rgba(0,0,0,.35) }
.badge{
  font-weight:900; letter-spacing:.02em; color:#0a0a0a;
  padding:.25rem .55rem; border-radius:999px; border:1px solid rgba(255,255,255,.18);
  display:inline-grid; place-items:center; min-width:38px; text-align:center;
}
.badge.win{ background:linear-gradient(135deg, #34d399, #10b981) }
.badge.loss{ background:linear-gradient(135deg, #ef4444, #f97373) }

.title{ font-weight:800 }
.meta{
  display:flex; align-items:center; gap:.6rem; color:var(--muted);
  font-weight:600; justify-self:flex-start;
}

.opponent{ opacity:.95; font-weight:700 }
.elo{
  font-weight:900;
  color:var(--orange-strong);
  justify-self:flex-end;
}
.btn.view{
  justify-self:flex-end;
  border-color:rgba(255,122,24,.45);
}

/* empty */
.empty{ display:grid; place-items:center; text-align:center; gap:.4rem; padding:1.2rem }
.empty .emoji{ font-size:32px }
.empty .title{ font-weight:800; font-size:18px }

/* footer */
.footer{ display:flex; align-items:center; justify-content:space-between; gap:1rem; padding:.8rem 1rem; margin:1rem 0 }
.logo-mini{ width:22px;height:22px;border-radius:6px; background:linear-gradient(135deg,#ff7a18,#ff9538); box-shadow:0 0 14px rgba(255,122,24,.35) }
.small{ color:var(--muted) }
.foot-links{ display:flex; gap:.8rem; flex-wrap:wrap }
.foot-links a{ color:var(--txt); text-decoration:none; opacity:.9; padding:.4rem .6rem; border-radius:10px }
.foot-links a:hover{ background:rgba(255,255,255,.08); opacity:1 }

/* responsive */
@media (max-width: 720px){
  .item{ grid-template-columns: auto 1fr auto; }
  .opponent{ display:none } /* hide opponent label on small screens (still visible in title) */
}

.hero{
  /* keep it as a self-contained centered card */
  display:block;                     /* override grid/flex earlier, keep simple */
  width: min(1100px, 92vw);
  margin-inline: auto !important;    /* force card to center */
  text-align: center;
  padding: 2rem 1rem;
}

/* Center the inner blocks and control line length for balance */
.hero-copy,
.filters{
  width: 100%;
  max-width: 900px;                  /* adjust to taste */
  margin-inline: auto;               /* center inside hero */
}

/* Search bar should be centered and not run too wide */
.filters .search{
  max-width: 900px;
  margin-inline: auto;
}

/* Center the chips + selects row */
.filters .row{
  justify-content: center;
}

/* Make sure any eyebrow/meta pills don't stick left */
.hero .eyebrow,
.hero .meta{
  margin-left: auto;
  margin-right: auto;
}

@media (max-width: 640px){
  .hero{ padding: 1.25rem 1rem; }
  .hero-copy, .filters, .filters .search{ max-width: none; }
  .filters .row{ justify-content: center; }
}

/* Make search bar longer + more prominent */
.filters .search{
  flex: 1 1 100%;
  max-width: 600px;              /* bump width */
  margin-inline: auto;
  font-size: 1rem;
  border: 1px solid rgba(255,255,255,.25);
  background: rgba(255,255,255,.08);
  transition: box-shadow .25s;
}
.filters .search:focus-within{
  box-shadow: 0 0 0 2px var(--orange);
}
.filters .search input{
  font-size: 1rem;
}

/* Style selects as clear dropdowns */
.select{
  position: relative;
  display: flex;
  align-items: center;
  gap:.45rem;
  background: rgba(255,255,255,.08);
  border: 1px solid var(--stroke);
  border-radius: 12px;
  padding:.45rem .9rem;
  cursor: pointer;
  transition: border-color .25s;
}
.select:hover{
  border-color: var(--orange-strong);
}
.select select{
  appearance: none;       /* remove native arrow */
  background: transparent;
  color: var(--txt);
  border: none;
  outline: none;
  font-weight: 700;
  padding-right: 1.4rem;  /* leave room for chevron */
  cursor: pointer;
}

/* Add chevron icon */
.select::after{
  content: "▾";
  position: absolute;
  right: .7rem;
  top: 50%;
  transform: translateY(-50%);
  color: var(--muted);
  pointer-events: none;
  font-size: .9rem;
}

/* Make search bar span the full width on top */
.filters{
  display: grid;
  gap: 1rem;
}

.filters .search{
  grid-column: 1 / -1;       /* force full width of filters grid */
  width: 100%;               /* stretch */
  max-width: 900px;          /* cap so it doesn’t get ridiculous */
  margin-inline: auto;
}

/* Let Sort dropdown size to its content */
.select{
  display: inline-flex;
  align-items: center;
  gap:.45rem;
  background: rgba(255,255,255,.08);
  border: 1px solid var(--stroke);
  border-radius: 12px;
  padding:.45rem .9rem;
  cursor: pointer;
  width: auto;               /* not fixed */
  max-width: none;
}

.select select{
  width: auto;               /* shrink to fit text */
  min-width: fit-content;    /* modern browsers */
  background: transparent;
  color: var(--txt);
  border: none;
  outline: none;
  font-weight: 700;
  cursor: pointer;
  padding-right: 1.4rem;     /* space for chevron */
}

/* ---- Make the search bar larger and centered on its own row ---- */
.hero .filters{
  display: grid;                      /* grid lets us span columns cleanly */
  gap: 1rem;
}

.hero .filters .search{
  grid-column: 1 / -1;                /* full row */
  width: 100%;
  max-width: 980px;                   /* wider cap */
  margin-inline: auto;
  font-size: 1rem;
  border: 1px solid rgba(255,255,255,.28);
  background: rgba(255,255,255,.10);
}
.hero .filters .search:focus-within{
  box-shadow: 0 0 0 2px var(--orange);
}

/* Keep the chips + selects centered beneath the search */
.hero .filters .row{
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: .6rem;
}

/* ---- Auto-size selects to content ---- */
.select{
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  background: rgba(255,255,255,.08);
  border: 1px solid var(--stroke);
  border-radius: 12px;
  padding: .45rem .9rem;
  cursor: pointer;
  flex: 0 0 auto;                     /* never stretch */
  inline-size: max-content;           /* shrink-wrap the pill */
}

.select select{
  appearance: none;
  background: transparent;
  color: var(--txt);
  border: none;
  outline: none;
  font-weight: 700;
  white-space: nowrap;                /* keep the label on one line */
  width: auto !important;             /* override any prior 100% */
  min-width: 0;                       /* allow shrink */
  padding-right: 1.4rem;              /* room for chevron */
}

/* Chevron */
.select::after{
  content: "▾";
  position: absolute;
  right: .7rem;
  top: 50%;
  transform: translateY(-50%);
  color: var(--muted);
  pointer-events: none;
  font-size: .9rem;
}

/* Center the footer glass bar perfectly */
.footer.container.glass{
  width: min(1100px, 92vw);
  margin-left: auto !important;
  margin-right: auto !important;
}

.empty{ display: grid; }
.empty.is-hidden{ display: none !important; }