/* RUNEBID app shell — top bar, side nav, content frame */

.app {
  display: grid;
  grid-template-rows: 48px 1fr;
  grid-template-columns: 200px 1fr;
  grid-template-areas:
    "top top"
    "side main";
  height: 100vh;
  width: 100vw;
  overflow: hidden;
}

/* --- TOP BAR --------------------------------------------- */
.topbar {
  grid-area: top;
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 0 18px;
  background: var(--s1);
  border-bottom: 0.5px solid var(--b1);
  -webkit-app-region: drag;
}
.topbar > * { -webkit-app-region: no-drag; }

.brand {
  display: flex; align-items: center; gap: 10px;
  font-family: "Barlow Condensed", sans-serif;
  font-weight: 700;
  font-size: var(--fs-lg);
  text-transform: uppercase;
  letter-spacing: 0.22em;
  color: var(--cyan);
  text-shadow: 0 0 12px rgba(0,200,255,0.35);
}
.brand__mark {
  width: 22px; height: 22px;
  border: 1.5px solid var(--cyan);
  border-radius: 4px;
  position: relative;
  box-shadow: 0 0 10px rgba(0,200,255,0.45) inset, 0 0 8px rgba(0,200,255,0.25);
}
.brand__mark::after {
  content: "";
  position: absolute;
  inset: 4px;
  background: var(--cyan);
  opacity: 0.5;
  border-radius: 2px;
}

.balance-pill {
  display: flex; align-items: center; gap: 8px;
  padding: 0 12px; height: 30px;
  background: var(--s2);
  border: 0.5px solid var(--b1);
  border-radius: 999px;
}
.balance-pill__label { color: var(--t3); font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: 1.2px; }
.balance-pill__amount { font-family: "JetBrains Mono", monospace; color: var(--green); font-size: var(--fs-md); }

.mode-toggle {
  display: flex;
  background: var(--s2);
  border: 0.5px solid var(--b1);
  border-radius: 999px;
  height: 28px;
  padding: 2px;
}
.mode-toggle button {
  height: 100%;
  padding: 0 12px;
  border: none;
  background: transparent;
  color: var(--t2);
  font-family: "Barlow Condensed", sans-serif;
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: 1.4px;
  border-radius: 999px;
  transition: all var(--t-fast) var(--ease);
}
.mode-toggle button.is-active {
  background: var(--bg);
  color: var(--cyan);
  box-shadow: 0 0 10px rgba(0,200,255,0.18) inset;
}
.mode-toggle button[data-mode="seller"].is-active {
  color: var(--gold);
  box-shadow: 0 0 10px rgba(255,180,0,0.20) inset;
}

/* Mode-aware nav: items marked for the opposite mode get subdued.
   Items without data-mode are mode-agnostic and stay full strength. */
.app[data-mode="buyer"]  .nav-item[data-mode="seller"],
.app[data-mode="seller"] .nav-item[data-mode="buyer"] {
  opacity: 0.45;
}
.app[data-mode="buyer"]  .nav-item[data-mode="seller"]:hover,
.app[data-mode="seller"] .nav-item[data-mode="buyer"]:hover {
  opacity: 1;
}

/* In seller mode the balance pill shifts to gold — small visual reminder
   that bidding/earning is the active context. */
.app[data-mode="seller"] .balance-pill__amount { color: var(--gold); }

/* --- SIDE NAV -------------------------------------------- */
.sidenav {
  grid-area: side;
  display: flex; flex-direction: column;
  gap: 2px;
  padding: 12px 10px;
  background: var(--s1);
  border-right: 0.5px solid var(--b1);
}
.nav-item {
  display: flex; align-items: center; gap: 10px;
  padding: 9px 12px;
  border-radius: var(--radius-sm);
  background: transparent;
  border: none;
  color: var(--t2);
  font-family: "Barlow Condensed", sans-serif;
  font-size: var(--fs-md);
  text-transform: uppercase;
  letter-spacing: 1.6px;
  font-weight: 600;
  text-align: left;
  transition: all var(--t-fast) var(--ease);
}
.nav-item:hover { color: var(--t1); background: var(--s2); }
.nav-item.is-active {
  /* Active nav indicator picks up the currently-selected game's accent so
     the entire chrome shifts color as the user moves between D4/PoE2/etc.
     --active-game falls back to cyan when no game is selected. */
  background: color-mix(in srgb, var(--active-game) 8%, transparent);
  color: var(--active-game);
  box-shadow: inset 2px 0 0 var(--active-game);
}

/* ── Game-aware chrome accents ─────────────────────────────────
   The body picks up data-game="diablo4" etc. from game-filter.js. We
   tint subtle elements (focused inputs, top-bar underline, brand mark
   glow, post-request CTA hue) so the operator knows at a glance which
   game context they're in without staring at the pill bar. */
.input:focus,
.select:focus,
.textarea:focus { border-color: var(--active-game); box-shadow: 0 0 0 2px color-mix(in srgb, var(--active-game) 18%, transparent); }
.brand__mark    { box-shadow: 0 0 10px color-mix(in srgb, var(--active-game) 40%, transparent) inset, 0 0 8px color-mix(in srgb, var(--active-game) 25%, transparent); }
.brand__mark::after { background: var(--active-game); }
/* Game-themed shell — when the user picks a game, the whole app gets a
   stronger color identity: top game-bar underline, sidebar tint, brand
   glow, and a stronger radial wash. Not just nav. */
html[data-game] body {
  background-image:
    radial-gradient(circle at 50% -8%, color-mix(in srgb, var(--active-game) 14%, transparent), transparent 55%),
    radial-gradient(circle at 8% 105%, color-mix(in srgb, var(--active-game) 8%, transparent), transparent 60%);
}
/* Tint the sidebar subtly with the active game so the chrome shifts */
html[data-game] .sidenav {
  border-right-color: color-mix(in srgb, var(--active-game) 30%, var(--b1));
  background:
    linear-gradient(180deg,
      color-mix(in srgb, var(--active-game) 6%, var(--s1)),
      var(--s1) 70%);
}
/* Stronger game-bar bottom border in the active color */
html[data-game] #game-bar {
  border-bottom: 0.5px solid color-mix(in srgb, var(--active-game) 50%, var(--b1));
  box-shadow: 0 8px 24px -16px color-mix(in srgb, var(--active-game) 80%, transparent);
}
/* Brand mark glow gets stronger so the corner reads as "in D4" */
html[data-game] .brand__mark {
  box-shadow:
    0 0 12px color-mix(in srgb, var(--active-game) 60%, transparent) inset,
    0 0 14px color-mix(in srgb, var(--active-game) 40%, transparent);
}
/* Default ("all" / no game) — keep cyan/neutral */
html[data-game="all"] body,
html:not([data-game]) body {
  background-image: none;
}
.nav-item__icon { width: 16px; height: 16px; opacity: 0.85; }
.nav-item__badge {
  margin-left: auto;
  background: var(--red);
  color: white;
  font-family: "JetBrains Mono", monospace;
  font-size: 10px;
  min-width: 18px; height: 16px;
  padding: 0 5px;
  border-radius: 8px;
  display: inline-flex; align-items: center; justify-content: center;
}

/* Collapsible "More" group — hides secondary items by default */
.nav-more { width: 100%; }
.nav-more summary {
  list-style: none;
  cursor: pointer;
}
.nav-more summary::-webkit-details-marker { display: none; }
.nav-more summary::after {
  content: "▾";
  margin-left: auto;
  color: var(--t3);
  font-size: 10px;
  transition: transform 200ms;
}
.nav-more[open] summary::after { transform: rotate(180deg); color: var(--t2); }
.nav-item--more { color: var(--t3); }
.nav-more__items {
  display: flex;
  flex-direction: column;
  padding-left: 12px;
  border-left: 0.5px solid var(--b1);
  margin: 2px 0 4px 16px;
}
.nav-more__items .nav-item { font-size: 12px; padding: 6px 10px; }
.sidenav__footer {
  margin-top: auto;
  padding: 12px 8px;
  border-top: 0.5px solid var(--b1);
  font-size: var(--fs-xs);
  color: var(--t3);
}
.sidenav__footer .mono { color: var(--t2); }

/* --- MAIN CONTENT --------------------------------------- */
.main {
  grid-area: main;
  background: var(--bg);
  overflow: hidden;
  position: relative;
  display: flex;
  flex-direction: column;
}

/* Global game filter — sticky strip at the top of main, visible on every
   page. Promoted from inside the Feed page so buyers + sellers + both see
   the same prominent control. */
.game-bar {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 10px 22px;
  background: linear-gradient(180deg, var(--s1) 0%, rgba(11,14,22,0.85) 100%);
  border-bottom: 0.5px solid var(--b1);
  flex-shrink: 0;
  position: relative;
  z-index: 5;
}
.game-bar__label {
  font-family: "Barlow Condensed", sans-serif;
  font-size: 10px;
  letter-spacing: 0.20em;
  text-transform: uppercase;
  color: var(--t3);
  margin-right: 6px;
}
.game-bar__pill {
  height: 30px;
  padding: 0 14px;
  border-radius: 6px;
  background: var(--s2);
  border: 0.5px solid var(--b1);
  color: var(--t2);
  font-family: "Barlow Condensed", sans-serif;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  transition: all 120ms cubic-bezier(.2,.8,.2,1);
}
.game-bar__pill:hover {
  color: var(--t1);
  border-color: var(--b2);
  background: var(--s3);
}
.game-bar__pill.is-active {
  color: var(--cyan);
  border-color: rgba(0, 200, 255, 0.55);
  background: rgba(0, 200, 255, 0.10);
  box-shadow: 0 0 14px rgba(0, 200, 255, 0.15);
}
.game-bar__pill[data-game="diablo4"].is-active { color: var(--d4); border-color: rgba(200,64,64,0.55); background: rgba(200,64,64,0.10); box-shadow: 0 0 14px rgba(200,64,64,0.15); }
.game-bar__pill[data-game="poe"].is-active     { color: var(--poe); border-color: rgba(201,162,74,0.55); background: rgba(201,162,74,0.10); box-shadow: 0 0 14px rgba(201,162,74,0.15); }
.game-bar__pill[data-game="poe2"].is-active    { color: var(--poe2); border-color: rgba(224,189,102,0.55); background: rgba(224,189,102,0.12); box-shadow: 0 0 14px rgba(224,189,102,0.15); }
.game-bar__pill[data-game="wow"].is-active     { color: var(--wow); border-color: rgba(244,200,66,0.55); background: rgba(244,200,66,0.10); box-shadow: 0 0 14px rgba(244,200,66,0.15); }
.game-bar__pill[data-game="gw2"].is-active     { color: var(--gw2); border-color: rgba(199,62,58,0.55); background: rgba(199,62,58,0.10); box-shadow: 0 0 14px rgba(199,62,58,0.15); }
.game-bar__pill.is-soon {
  opacity: 0.55;
  cursor: not-allowed;
  position: relative;
}
.game-bar__pill.is-soon:hover { opacity: 0.85; }
.game-bar__pill.is-soon .game-bar__soon-tag {
  font-size: 8px;
  letter-spacing: 0.16em;
  padding: 1px 4px;
  border-radius: 3px;
  background: rgba(255,180,0,0.12);
  border: 0.5px solid rgba(255,180,0,0.45);
  color: var(--gold);
  margin-left: 4px;
}
.game-bar__sep {
  color: var(--t3);
  margin: 0 4px;
  font-family: "JetBrains Mono", monospace;
  font-size: 14px;
  user-select: none;
}
.game-bar__dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: currentColor;
  box-shadow: 0 0 6px currentColor;
}

/* Pages now live below the sticky game bar. */
.page-host {
  flex: 1;
  position: relative;
  overflow: hidden;
  min-height: 0;
}

.page {
  position: absolute;
  inset: 0;
  display: none;
  flex-direction: column;
  overflow: hidden;
}
.page.is-active { display: flex; }

.page__header {
  display: flex; align-items: center; gap: 14px;
  padding: 16px 22px 12px;
  border-bottom: 0.5px solid var(--b1);
}
.page__title {
  font-family: "Barlow Condensed", sans-serif;
  font-size: var(--fs-xxl);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  margin: 0;
  color: var(--t1);
}
.page__sub { color: var(--t3); font-size: var(--fs-sm); }
.page__body {
  flex: 1;
  overflow-y: auto;
  padding: 18px 22px;
}

/* feed filter bar */
.filters {
  display: flex; align-items: center; gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 14px;
  padding: 12px;
}
.filter-pill {
  height: 28px; padding: 0 12px;
  border-radius: 999px;
  background: var(--s2);
  border: 0.5px solid var(--b1);
  color: var(--t2);
  font-family: "Barlow Condensed", sans-serif;
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: 1.4px;
  transition: all var(--t-fast) var(--ease);
}
.filter-pill:hover { color: var(--t1); border-color: var(--b2); }
.filter-pill.is-active { color: var(--cyan); border-color: rgba(0,200,255,0.55); background: rgba(0,200,255,0.08); }

/* simple two-column profile grid */
.grid-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}
.grid-3 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}

/* stat tile */
.stat {
  padding: 14px 16px;
}
.stat__label { font-family: "Barlow Condensed", sans-serif; text-transform: uppercase; letter-spacing: 1.4px; font-size: var(--fs-xs); color: var(--t3); margin-bottom: 4px; }
.stat__value { font-family: "JetBrains Mono", monospace; font-size: var(--fs-xl); color: var(--t1); }
.stat__delta { font-size: var(--fs-xs); color: var(--green); margin-top: 4px; font-family: "JetBrains Mono", monospace; }

/* achievement chip */
.ach {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 12px;
  border-radius: var(--radius-sm);
  background: var(--s2);
  border: 0.5px solid var(--b1);
}
.ach__icon { font-size: 22px; }
.ach__name { font-family: "Barlow Condensed", sans-serif; font-size: var(--fs-sm); text-transform: uppercase; letter-spacing: 1.2px; }
.ach.is-locked { opacity: 0.35; }

/* order list row */
.order-row {
  display: grid;
  grid-template-columns: 1fr 120px 100px 110px;
  gap: 12px;
  align-items: center;
  padding: 12px 14px;
  margin-bottom: 8px;
}
.order-row__id { font-family: "JetBrains Mono", monospace; color: var(--t2); font-size: var(--fs-xs); }
.order-row__title { font-family: "Barlow Condensed", sans-serif; font-size: var(--fs-md); text-transform: uppercase; letter-spacing: 0.08em; }
.order-row__amount { font-family: "JetBrains Mono", monospace; color: var(--green); text-align: right; }
.order-row__status {
  font-family: "Barlow Condensed", sans-serif;
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: 1.2px;
  text-align: center;
}
.status--active { color: var(--cyan); }
.status--completed { color: var(--green); }
.status--disputed { color: var(--red); }
.status--pending { color: var(--gold); }
