/* ============================================================================
   Aurora — Hel's Ledger (leaderboard / unions / character pages)
   Reuses the :root tokens from styles.css (ember-stone Norse theme).
   ========================================================================== */

.lb-body {
  min-height: 100vh;
  margin: 0;
  color: var(--parchment);
  background:
    radial-gradient(1200px 700px at 50% -10%, rgba(255, 106, 31, 0.10), transparent 60%),
    var(--stone-0);
  font-family: "Spectral", Georgia, serif;
  -webkit-font-smoothing: antialiased;
}

.lb-wrap { max-width: 1100px; margin: 0 auto; padding: 22px 18px 80px; }

/* ── top bar ─────────────────────────────────────────────────────────── */
.lb-top {
  display: flex; align-items: center; gap: 14px; flex-wrap: wrap;
  padding: 10px 0 22px; border-bottom: 1px solid rgba(214,163,94,0.18); margin-bottom: 26px;
}
.lb-home {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: "Cinzel", serif; font-weight: 700; letter-spacing: .06em;
  font-size: .82rem; color: var(--bronze); text-decoration: none; text-transform: uppercase;
  padding: 8px 14px; border: 1px solid rgba(214,163,94,0.32); border-radius: 10px;
  background: linear-gradient(180deg, rgba(18,13,11,0.7), rgba(9,7,6,0.8));
  transition: border-color .2s, color .2s, transform .15s;
}
.lb-home:hover { color: var(--ember-2); border-color: rgba(255,106,31,0.5); transform: translateY(-1px); }
.lb-title {
  font-family: "Cinzel", serif; font-weight: 900; letter-spacing: .04em;
  font-size: clamp(1.3rem, 3.4vw, 2.1rem); margin: 0;
  background: linear-gradient(180deg, var(--ember-2), var(--ember-deep));
  -webkit-background-clip: text; background-clip: text; color: transparent;
}
.lb-sub { color: var(--muted); font-size: .9rem; margin: 2px 0 0; }
.lb-top__meta { margin-left: auto; text-align: right; color: var(--muted); font-size: .76rem; font-family: "Cinzel", serif; letter-spacing: .04em; }
.lb-top__meta .dot { display:inline-block; width:8px;height:8px;border-radius:50%; background:#5ad17a; box-shadow:0 0 8px #5ad17a; margin-right:6px; }

/* ── generic card ────────────────────────────────────────────────────── */
.card {
  position: relative; border-radius: 14px; padding: 18px;
  border: 1px solid rgba(214,163,94,0.28);
  background: linear-gradient(180deg, rgba(18,13,11,0.86), rgba(9,7,6,0.9));
  box-shadow: 0 10px 30px rgba(0,0,0,0.5), inset 0 1px 0 rgba(255,255,255,0.03);
  backdrop-filter: blur(6px);
}
.section-h {
  font-family: "Cinzel", serif; font-weight: 700; letter-spacing: .08em; text-transform: uppercase;
  font-size: .9rem; color: var(--bronze); margin: 34px 0 14px;
}

/* ── union grid ──────────────────────────────────────────────────────── */
.union-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 16px; }
.union-card {
  cursor: pointer; text-decoration: none; color: inherit; display: block;
  border-radius: 14px; padding: 0; overflow: hidden;
  border: 1px solid rgba(214,163,94,0.26);
  background: linear-gradient(180deg, rgba(18,13,11,0.86), rgba(9,7,6,0.92));
  transition: transform .16s, border-color .2s, box-shadow .2s;
}
.union-card:hover { transform: translateY(-3px); box-shadow: 0 16px 40px rgba(0,0,0,0.55); }
.union-card__banner { height: 7px; width: 100%; }
.union-card__in { padding: 16px 18px 18px; }
.union-card__name { font-family: "Cinzel", serif; font-weight: 800; font-size: 1.18rem; margin: 0; }
.union-card__tag { color: var(--muted); font-style: italic; font-size: .9rem; margin: 4px 0 14px; }
.union-card__stats { display: grid; grid-template-columns: 1fr 1fr; gap: 10px 14px; }
.stat { }
.stat__k { display:block; font-family:"Cinzel",serif; font-size:.64rem; letter-spacing:.1em; text-transform:uppercase; color: var(--muted); }
.stat__v { display:block; font-family:"Cinzel",serif; font-weight:700; font-size:1.15rem; color: var(--parchment); }
.stat__v.big {
  font-size: 1.5rem;
  background: linear-gradient(180deg, var(--ember-2), var(--ember-deep));
  -webkit-background-clip: text; background-clip: text; color: transparent;
}

/* ── badges ──────────────────────────────────────────────────────────── */
.tier-badge {
  display:inline-flex; align-items:center; gap:6px;
  font-family:"Cinzel",serif; font-weight:700; font-size:.74rem; letter-spacing:.06em;
  padding:3px 10px; border-radius:999px; border:1px solid rgba(255,155,61,0.4);
  background: rgba(255,106,31,0.12); color: var(--ember-2); white-space:nowrap;
}
.pill { display:inline-flex; align-items:center; gap:6px; font-family:"Cinzel",serif; font-size:.7rem; letter-spacing:.05em; padding:2px 9px; border-radius:999px; }
.pill--online { color:#8ef0a6; border:1px solid rgba(90,209,122,0.4); background:rgba(90,209,122,0.1); }
.pill--offline { color:var(--muted); border:1px solid rgba(194,171,151,0.25); background:rgba(194,171,151,0.06); }
.pill__dot { width:7px;height:7px;border-radius:50%; background:currentColor; }
.pill--online .pill__dot { box-shadow:0 0 8px #5ad17a; }

/* ── member list ─────────────────────────────────────────────────────── */
.member-list { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px,1fr)); gap: 12px; }
.member-row {
  display:flex; align-items:center; gap:14px; cursor:pointer; text-decoration:none; color:inherit;
  padding:13px 16px; border-radius:12px; border:1px solid rgba(214,163,94,0.2);
  background: linear-gradient(180deg, rgba(20,14,12,0.8), rgba(10,8,7,0.86));
  transition: transform .14s, border-color .2s;
}
.member-row:hover { transform: translateX(2px); border-color: rgba(255,106,31,0.45); }
.member-row__rank { font-family:"Cinzel",serif; font-weight:900; font-size:1.05rem; color:var(--bronze); width:30px; text-align:center; flex:none; }
.member-row__main { min-width:0; flex:1; }
.member-row__name { font-family:"Cinzel",serif; font-weight:700; font-size:1.02rem; display:flex; align-items:center; gap:8px; }
.member-row__sub { color:var(--muted); font-size:.8rem; margin-top:2px; }
.member-row__cap { font-family:"Cinzel",serif; font-weight:700; font-size:1.1rem; color:var(--ember-2); white-space:nowrap; }

/* ── character page ──────────────────────────────────────────────────── */
.char-head { display:flex; align-items:flex-start; gap:18px; flex-wrap:wrap; }
.char-emblem { width:64px; height:64px; border-radius:14px; flex:none; display:grid; place-items:center;
  font-family:"Cinzel",serif; font-weight:900; font-size:1.8rem; color:#0a0807; }
.char-id { min-width:0; }
.char-name { font-family:"Cinzel",serif; font-weight:900; font-size: clamp(1.5rem,4vw,2.3rem); margin:0; line-height:1.1; }
.char-union { font-family:"Cinzel",serif; font-weight:700; letter-spacing:.04em; margin:4px 0 0; }
.char-meta { display:flex; gap:10px; flex-wrap:wrap; margin-top:10px; }

.char-grid { display:grid; grid-template-columns: 1.1fr 0.9fr; gap:18px; margin-top:22px; align-items:start; }
@media (max-width: 820px){ .char-grid { grid-template-columns: 1fr; } }

/* capital bars */
.bars { display:flex; flex-direction:column; gap:11px; }
.bar { }
.bar__top { display:flex; justify-content:space-between; font-size:.8rem; margin-bottom:4px; }
.bar__k { font-family:"Cinzel",serif; letter-spacing:.04em; color:var(--muted); text-transform:uppercase; font-size:.68rem; }
.bar__v { font-family:"Cinzel",serif; color:var(--parchment); }
.bar__track { height:9px; border-radius:6px; background:rgba(255,255,255,0.06); overflow:hidden; }
.bar__fill { height:100%; border-radius:6px; background:linear-gradient(90deg,var(--ember-deep),var(--ember-2)); }

/* equipment paper-doll */
.equip-grid { display:grid; grid-template-columns: repeat(2, 1fr); gap:10px; }
.equip-slot {
  border-radius:11px; padding:11px 12px; border:1px solid rgba(214,163,94,0.22);
  background:linear-gradient(180deg, rgba(22,16,13,0.8), rgba(11,8,7,0.85)); min-height:58px;
}
.equip-slot.empty { opacity:.55; }
/* icon on the left, label+name stacked on the right */
.equip-slot { display:grid; grid-template-columns:30px 1fr; column-gap:11px; align-content:center; }
.equip-slot__icon { grid-column:1; grid-row:1 / span 3; align-self:center; width:30px; height:30px; color:var(--bronze); }
.equip-slot__icon svg { width:100%; height:100%; display:block; filter:drop-shadow(0 1px 2px rgba(0,0,0,.6)); }
.equip-slot.empty .equip-slot__icon { color:var(--muted); opacity:.45; }
.equip-slot.enchanted .equip-slot__icon { color:#9fe6ff; }
.equip-slot__slot, .equip-slot__name, .equip-slot__stars { grid-column:2; }
.equip-slot__slot { font-family:"Cinzel",serif; font-size:.6rem; letter-spacing:.12em; text-transform:uppercase; color:var(--muted); }
.equip-slot__name { font-family:"Spectral",serif; font-size:.96rem; color:var(--parchment); margin-top:3px; line-height:1.15; }
.equip-slot__stars { color:var(--ember-2); font-size:.78rem; letter-spacing:1px; margin-top:3px; }

/* radar / septagon */
.radar-wrap { display:grid; place-items:center; }
.radar-wrap svg { width:100%; max-width:340px; height:auto; }
.radar-poly { fill: rgba(255,106,31,0.22); stroke: var(--ember); stroke-width:2; }
.radar-grid { fill:none; stroke: rgba(214,163,94,0.18); stroke-width:1; }
.radar-axis { stroke: rgba(214,163,94,0.16); stroke-width:1; }
.radar-dot { fill: var(--ember-2); }
.radar-label { fill: var(--muted); font-family:"Cinzel",serif; font-size:10px; letter-spacing:.04em; }

/* haul */
.haul-list { display:flex; flex-direction:column; gap:8px; }
.haul-row { display:flex; align-items:center; gap:10px; }
.haul-row__name { font-size:.86rem; width:130px; flex:none; color:var(--parchment); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.haul-row__track { flex:1; height:7px; border-radius:5px; background:rgba(255,255,255,0.06); overflow:hidden; }
.haul-row__fill { height:100%; background:linear-gradient(90deg, var(--bronze), var(--ember-2)); border-radius:5px; }
.haul-row__v { font-family:"Cinzel",serif; font-size:.78rem; color:var(--muted); width:64px; text-align:right; flex:none; }

/* states */
.lb-state { text-align:center; color:var(--muted); padding:60px 20px; font-style:italic; }
.lb-state.err { color:#e9a; }
.muted { color: var(--muted); }
a.plain { color: var(--ember-2); text-decoration:none; }
a.plain:hover { text-decoration:underline; }

/* ── Discord link bits ───────────────────────────────────────────────── */
.verified { color:#8ea4ff; font-size:.82rem; }
.verified--lg { font-size:1rem; vertical-align:middle; }
.member-row__av { width:32px; height:32px; border-radius:50%; flex:none; object-fit:cover;
  border:1px solid rgba(88,101,242,0.5); box-shadow:0 0 8px rgba(88,101,242,0.25); }
.char-emblem--av { object-fit:cover; border:2px solid rgba(88,101,242,0.55); box-shadow:0 0 16px rgba(88,101,242,0.3); }

/* ── logo home button + faint page texture (replaces the plain text back button) ── */
.lb-home { border: none; background: none; padding: 2px; }
.lb-home:hover { transform: translateY(-1px); border: none; }
.lb-logo {
  height: 46px; width: auto; display: block; opacity: .92;
  transition: opacity .2s, transform .15s;
  filter: drop-shadow(0 2px 10px rgba(0,0,0,0.7));
}
.lb-home:hover .lb-logo { opacity: 1; transform: scale(1.04); }

/* faint emblem behind everything so panels don't float on pure black */
.lb-body::before {
  content: ""; position: fixed; inset: 0; z-index: -1; pointer-events: none;
  background: url("/assets/emblem.png") center center / cover no-repeat;
  opacity: 0.08;
}
.lb-body::after {
  content: ""; position: fixed; inset: 0; z-index: -1; pointer-events: none;
  background: radial-gradient(1100px 620px at 50% -8%, rgba(255,106,31,0.10), transparent 60%),
              linear-gradient(180deg, rgba(10,8,7,0.35), rgba(10,8,7,0.78));
}
.lb-wrap { position: relative; z-index: 0; }

/* ── member-row overlap fix: let the middle shrink/truncate, keep the number clear ── */
.member-row { gap: 12px; }
.member-row__main { min-width: 0; overflow: hidden; }
.member-row__name { min-width: 0; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.member-row__sub { display: flex; align-items: center; flex-wrap: wrap; gap: 4px 8px; min-width: 0; }
.member-row__on { font-size: .64rem; padding: 1px 7px; }
.member-row__cap { flex: none; margin-left: auto; padding-left: 6px; font-size: 1.02rem; }

/* ── equipment: enchant badges + hover tooltips ──────────────────────── */
.equip-slot { position: relative; overflow: visible; cursor: default; transition: border-color .18s, transform .12s, box-shadow .18s; }
.equip-slot:not(.empty):hover, .equip-slot:not(.empty):focus { transform: translateY(-2px); border-color: rgba(255,155,61,0.5); box-shadow: 0 8px 22px rgba(0,0,0,0.5); outline: none; }

/* enchanted gear: cyan rune glow + corner badge */
.equip-slot.enchanted { border-color: rgba(127,212,255,0.55); box-shadow: inset 0 0 0 1px rgba(127,212,255,0.18), 0 0 16px rgba(127,212,255,0.12); }
.equip-slot.enchanted .equip-slot__name { color: #d7f1ff; }
.equip-slot__ench {
  position: absolute; top: 8px; right: 9px;
  font-family: "Cinzel", serif; font-weight: 700; font-size: .72rem;
  color: #061018; background: linear-gradient(180deg,#bfeaff,#7fd4ff);
  padding: 1px 7px; border-radius: 999px; box-shadow: 0 0 10px rgba(127,212,255,0.5);
}

/* tooltip */
.equip-tip {
  position: absolute; left: 50%; bottom: calc(100% + 10px); transform: translateX(-50%) translateY(4px);
  width: max-content; max-width: 240px; z-index: 30; pointer-events: none;
  opacity: 0; transition: opacity .15s, transform .15s;
  background: linear-gradient(180deg, rgba(24,17,14,0.98), rgba(12,9,8,0.98));
  border: 1px solid rgba(214,163,94,0.45); border-radius: 11px; padding: 11px 13px;
  box-shadow: 0 14px 36px rgba(0,0,0,0.7);
}
.equip-tip::after { content:""; position:absolute; top:100%; left:50%; transform:translateX(-50%);
  border:7px solid transparent; border-top-color: rgba(214,163,94,0.45); }
.equip-slot:hover .equip-tip, .equip-slot:focus .equip-tip { opacity: 1; transform: translateX(-50%) translateY(0); }
.equip-tip__name { font-family:"Cinzel",serif; font-weight:700; font-size:.98rem; color: var(--parchment); margin-bottom:7px; }
.equip-tip__row { display:flex; justify-content:space-between; gap:18px; font-size:.8rem; color: var(--muted); padding:2px 0; }
.equip-tip__row > span:last-child { color: var(--parchment); font-family:"Cinzel",serif; }
.equip-tip__ench { color:#7fd4ff !important; font-family:"Cinzel",serif; font-weight:700; }
.equip-tip__prefab { margin-top:7px; padding-top:7px; border-top:1px solid rgba(214,163,94,0.15); font-size:.66rem; color: var(--muted); font-family:"Cinzel",serif; letter-spacing:.03em; }
