/* Shared site styles for auth pages (kept small on purpose). */
.topbar { display:flex; justify-content:space-between; align-items:center; gap:12px; margin-bottom: 14px; }
.nav a { color:#a7a7ff; text-decoration:none; margin-right: 10px; font-weight:600; }
.nav a:hover { text-decoration: underline; }
.flash { padding: 10px 12px; border-radius: 10px; background:#0f0f16; border:1px solid #2a2a38; color:#a7a7b8; margin: 10px 0; }
.flash.err { border-color:#5d2b2b; color:#ffbdbd; }
.flash.ok { border-color:#2b5d3a; color:#bdf6c8; }
.flash.warn { border-color:#5d552b; color:#ffe7b0; }
.table { width:100%; border-collapse: collapse; table-layout: fixed; }
.table th, .table td { border-bottom: 1px solid #2a2a38; padding: 10px 8px; text-align:left; overflow-wrap:anywhere; word-break: break-word; }
.small { font-size: 12px; color:#a7a7b8; }

input:disabled,
select:disabled,
textarea:disabled{
  opacity: 0.55;
  cursor: not-allowed;
  filter: grayscale(40%);
}

/* Create character layout */
.cc-grid{ display:grid; grid-template-columns: 1fr 1.35fr; gap: 14px; align-items:flex-start; }
@media (max-width: 920px){ .cc-grid{ grid-template-columns: 1fr; } }

.cc-summary{ display:flex; gap: 12px; align-items:stretch; flex-wrap:wrap; padding: 10px 12px; border-radius: 12px; background:#0f0f16; border:1px solid #2a2a38; margin-bottom: 12px; }
.cc-kpi{ display:flex; flex-direction:column; justify-content:center; min-width: 120px; }
.cc-kpi span{ font-size: 11px; text-transform: uppercase; letter-spacing: .10em; color:#bdbdd6; }
.cc-kpi b{ font-size: 18px; font-weight: 900; color:#e8e8ff; }
.cc-split{ flex: 1 1 auto; align-self:center; text-align:right; font-size: 12px; color:#a7a7b8; }
@media (max-width: 520px){ .cc-split{ text-align:left; } }

.cc-table{ table-layout: auto; }
.cc-table th.cc-num, .cc-table td.cc-num{ text-align:right; }
.cc-input{ width: 92px; min-width: 0; padding: 6px 8px; text-align:right; }
.cc-section td{ padding: 12px 8px; font-size: 11px; text-transform: uppercase; letter-spacing: .12em; color:#bdbdd6; font-weight: 900; background:#0b0b10; }
.cc-actions{ display:flex; gap: 12px; align-items:center; justify-content:space-between; flex-wrap:wrap; margin-top: 12px; }
.cc-status{ font-weight: 800; color:#d6d6e8; }


/* World layout */
.world-layout{ display:flex; gap:14px; align-items:flex-start; }
.world-side{ width: 240px; flex: 0 0 240px; position: sticky; top: 12px; }
.world-main{ flex: 1 1 auto; min-width: 0; }
.world-content{ margin-top: 12px; }
.side-title{ font-size: 12px; text-transform: uppercase; letter-spacing: .08em; color:#bdbdd6; margin: 10px 0 6px; }
.side-link{ display:block; padding: 8px 10px; border-radius: 10px; color:#a7a7ff; text-decoration:none; border: 1px solid transparent; }
.side-link:hover{ background:#0f0f16; border-color:#2a2a38; }

.world-top{ display:flex; justify-content: space-between; align-items:flex-start; gap:12px; padding: 12px; border-radius: 14px; background:#0f0f16; border:1px solid #2a2a38; flex-wrap: wrap; }
.world-top-left{ flex: 1 1 420px; min-width: 0; }
.world-top-equip{ flex: 1 1 100%; width:100%; }
.world-charname{ font-size: 20px; font-weight: 800; color:#e8e8ff; line-height: 1.1; }
.world-statusline{ margin-top: 8px; display:flex; gap:8px; align-items:center; flex-wrap:wrap; }


.world-top-right{ flex: 0 1 420px; min-width: 0; display:flex; flex-direction:column; gap:10px; align-items:flex-end; }
.world-toplinks{ margin-left:auto; display:flex; gap:8px; align-items:center; justify-content:flex-end; flex-wrap:wrap; }
.world-top-widgets{
  width:100%;
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  align-items:stretch;
  justify-content:flex-start;
}
.world-widget{ border:1px solid #2a2a38; background:#0b0b10; border-radius: 14px; padding: 10px 12px; min-width: 0; }
/* Make the timers widget willing to shrink so the league widget can stay on the same row. */
.world-widget.timers{ flex: 1 1 auto; min-width: 240px; }
.timers-list{ display:flex; flex-direction:column; gap:6px; }
.timer-row{ display:flex; justify-content:space-between; align-items:center; gap:10px; padding: 6px 8px; border-radius: 12px; border:1px solid rgba(255,255,255,0.08); background:#0f0f16; text-decoration:none; color:#e8e8ff; }
.timer-row:hover{ filter: brightness(1.15); }
.timer-name{ font-size: 12px; font-weight: 800; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.timer-meta{ font-size: 11px; color:#bdbdd6; white-space:nowrap; }
.world-widget.league{ border-color: var(--league-border, #2a2a38); }
.world-widget.league.league-compact{ flex: 0 0 110px; padding: 6px 6px; margin-left:auto; }
.world-widget.league.league-compact .league-badge{ width:40px; height:40px; flex: 0 0 40px; }
.world-widget.league.league-compact .league-elo{ font-size:12px; }

@media (min-width: 760px){
  /* With only timers+league we keep a single row.
     When stat-points exists: keep timers+league on the first row, and put stat-points on the next row. */
  .world-top-widgets:not(.has-statpoints){ flex-wrap:nowrap; }
  .world-top-widgets.has-statpoints{ flex-wrap:wrap; }
  .world-top-widgets.has-statpoints .world-widget.timers{ flex: 1 1 auto; min-width: 240px; order: 1; }
  .world-top-widgets.has-statpoints .world-widget.league{ order: 2; margin-left:auto; }
  .world-top-widgets.has-statpoints .world-widget.statpoints{ flex: 1 1 100%; order: 3; min-width: 0; }
}
.widget-head{ font-size: 11px; text-transform: uppercase; letter-spacing: .10em; color:#bdbdd6; margin-bottom: 8px; font-weight: 900; }
.league-body{ display:flex; align-items:center; gap:10px; }
.world-widget.league.league-compact .league-body{ justify-content:center; }
.world-widget.league.league-compact .widget-head{ margin-bottom: 4px; font-size: 10px; }
.league-badge{ position:relative; width:52px; height:52px; flex: 0 0 52px; }
.league-badge img{ width:100%; height:100%; display:block; }
.league-elo{ position:absolute; inset:0; display:flex; align-items:center; justify-content:center; font-weight:900; font-size:14px; color:#0b0b10; text-shadow: 0 1px 0 rgba(255,255,255,0.25); }
.league-name{ font-weight: 900; color:#e8e8ff; }

.league-pill{ display:inline-flex; align-items:center; gap:8px; border:1px solid var(--league-border, #2a2a38); background:#0b0b10; padding: 6px 10px; border-radius: 999px; }
.league-pill-img{ width:22px; height:22px; display:block; }

@media (max-width: 720px){
  .world-top-right{ min-width: 0; width:100%; align-items:flex-start; }
  .world-top-widgets{ justify-content:flex-start; }
  .world-toplinks{ width:100%; margin-left:0; justify-content:flex-start; }
}

/* Prevent the equipment paper-doll UI from forcing horizontal overflow */
.equip-d2-grid{ width:100%; max-width:100%; min-width:0; }
.equip-d2-slot{ min-width:0; overflow:hidden; }
.equip-d2-select{ min-width:0; max-width:100%; box-sizing:border-box; }


/* Top panel identity + bars */
.world-identity{ display:flex; gap:12px; align-items:center; }
.world-avatar{ width:56px; height:56px; flex: 0 0 56px; border-radius: 14px; border:1px solid #2a2a38; background:#0b0b10; display:flex; align-items:center; justify-content:center; overflow:hidden; }
.world-avatar-placeholder{ font-weight:900; font-size:20px; color:#e8e8ff; }
.world-avatar-img{ width:100%; height:100%; object-fit:cover; display:block; }

.world-bars{ margin-top: 10px; display:flex; flex-direction:column; gap: 8px; }
.prog-row{ display:flex; flex-direction:column; gap: 6px; }
.prog-meta{ display:flex; justify-content:space-between; align-items:baseline; gap:10px; font-size: 12px; color:#a7a7b8; }
.prog-meta span:first-child{ text-transform:uppercase; letter-spacing: .10em; color:#bdbdd6; font-weight: 800; }
.prog-bar{ height: 10px; border-radius: 999px; background:#0b0b10; border:1px solid #2a2a38; overflow:hidden; }
.prog-fill{ height:100%; width:0; border-radius: 999px; background:#2b2be0; }
.prog-row.prog-hp .prog-fill{ background:#2b6be0; }
.prog-row.prog-xp .prog-fill{ background:#7a2be0; }

@media (max-width: 560px){
  .world-avatar{ width:44px; height:44px; flex-basis:44px; border-radius: 12px; }
  .world-avatar-placeholder{ font-size: 16px; }
}

@media (max-width: 860px){
  .world-identity{ flex-wrap:wrap; }
  .world-toplinks{ flex: 1 1 100%; margin-left: 0; justify-content:flex-start; }
}

.badge{ display:inline-flex; align-items:center; gap:6px; padding: 4px 8px; border-radius: 999px; font-size: 12px; border:1px solid #2a2a38; background:#11111a; color:#d6d6e8; }
.badge-hp{ border-color:#2b3a5d; color:#cfe1ff; }
.badge-dead{ border-color:#5d2b2b; color:#ffbdbd; }
.badge-hospital{ border-color:#5d552b; color:#ffe7b0; }

.equip-mini{ margin-top: 10px; display:grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 8px 12px; }
.equip-mini-item{ display:flex; gap:8px; justify-content:space-between; padding: 8px 10px; border-radius: 12px; background:#0f0f16; border:1px solid #2a2a38; }
.equip-mini-slot{ font-size: 11px; letter-spacing: .06em; text-transform: uppercase; color:#bdbdd6; }
.equip-mini-name{ font-size: 12px; color:#e8e8ff; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; max-width: 220px; }

/* Collapsible equipment shell */
.equip-mini-shell{ margin-top: 10px; padding: 10px 12px; border-radius: 16px; border:1px solid #2a2a38; background:#0f0f16; }
.equip-mini-shell-head{ display:flex; justify-content:flex-end; align-items:center; margin-bottom: 10px; }
.equip-mini-toggle{ cursor:pointer; padding: 6px 10px; border-radius: 999px; border:1px solid #2a2a38; background:#0b0b10; color:#e8e8ff; font-weight:700; letter-spacing:.02em; }
.equip-mini-toggle:hover{ filter: brightness(1.15); }
.equip-mini-shell.is-collapsed .equip-mini-shell-body{ display:none; }

.equip-mini-form{ margin-top: 0; }
.equip-mini-select{ width: 100%; max-width: 230px; padding: 6px 8px; border-radius: 10px; border:1px solid #2a2a38; background:#0b0b10; color:#e8e8ff; font-size: 12px; }
.equip-mini-select:focus{ outline:none; border-color:#3a3a58; }
.equip-mini-actions{ display:flex; gap:10px; align-items:center; flex-wrap:wrap; margin-top: 10px; }
.equip-bonus-box{ margin-top: 10px; padding: 10px; border-radius: 14px; border:1px solid #2a2a38; background:#0b0b10; }
.equip-bonus-title{ font-size: 11px; text-transform:uppercase; letter-spacing:.10em; color:#bdbdd6; margin-bottom: 8px; }
.equip-bonus-list{ max-height: 140px; overflow:auto; display:grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap:6px 12px; }
.equip-bonus-row{ display:flex; justify-content:space-between; align-items:baseline; gap:10px; font-size:12px; color:#d6d6e8; border-bottom: 1px dashed rgba(255,255,255,0.06); padding-bottom: 4px; }
.equip-bonus-row b{ font-weight:800; }
@media (max-width: 720px){ .equip-bonus-list{ grid-template-columns: 1fr; } }


/* Diablo-2-ish equipment paper-doll layout (still uses selects) */
.equip-d2-grid{
  margin-top: 10px;
  display:grid;
  grid-template-columns: 1.25fr 0.85fr 1.8fr 0.85fr 1.25fr;
  grid-template-areas:
    "main . head . off"
    "main art1 neck art2 off"
    "main . body . off"
    "main . body . off"
    "main ring1 belt ring2 off"
    "hands . legs . shoes"
    "hands . legs . shoes";
  gap: 10px;
  width: 100%;
  max-width: 100%;
  min-width: 0;
}

/* Slot size hints (min-height) */
.equip-d2-slot.area-main,
.equip-d2-slot.area-off{ min-height: 240px; }
.equip-d2-slot.area-head,
.equip-d2-slot.area-hands,
.equip-d2-slot.area-shoes{ min-height: 210px; }
.equip-d2-slot.area-neck,
.equip-d2-slot.area-belt{ min-height: 70px; }
.equip-d2-slot.area-body,
.equip-d2-slot.area-legs{ min-height: 210px; }
.equip-d2-slot.area-ring1,
.equip-d2-slot.area-ring2,
.equip-d2-slot.area-art1,
.equip-d2-slot.area-art2{ min-height: 90px; }

/* Artifacts align with neck row */
.equip-d2-slot.area-art1,
.equip-d2-slot.area-art2{ min-height: 70px; }

/* Rings should match the artifact slot size. */
.equip-d2-slot.area-ring1,
.equip-d2-slot.area-ring2{ min-height: 70px; }

@media (max-width: 720px){
  .equip-d2-grid{
    grid-template-columns: repeat(2, minmax(0, 1fr));
    grid-template-areas:
      "head head"
      "art1 art2"
      "neck neck"
      "main off"
      "body body"
      "belt belt"
      "ring1 ring2"
      "hands shoes"
      "legs legs";
  }
  .equip-d2-slot.area-main,
  .equip-d2-slot.area-off{ min-height: 180px; }
  .equip-d2-slot.area-head,
  .equip-d2-slot.area-hands,
  .equip-d2-slot.area-shoes,
  .equip-d2-slot.area-body,
  .equip-d2-slot.area-legs{ min-height: 160px; }
}

.equip-d2-slot{
  padding: 8px 10px;
  border-radius: 12px;
  background:#0f0f16;
  border:1px solid #2a2a38;
  display:flex;
  flex-direction:column;
  gap:6px;
  min-height: 64px;
  min-width: 0;
  overflow: hidden;
}

.equip-d2-label{ font-size: 11px; letter-spacing: .08em; text-transform: uppercase; color:#bdbdd6; }
.equip-d2-img{ flex: 1 1 auto; min-height: 44px; border-radius: 10px; border:1px dashed rgba(255,255,255,0.14); background:#0b0b10; display:flex; align-items:center; justify-content:center; padding: 8px; }
.equip-d2-img-ph{ font-size: 12px; color:#6f6f86; text-align:center; overflow:hidden; text-overflow:ellipsis; }
.equip-d2-select{ width: 100%; padding: 6px 8px; border-radius: 10px; border:1px solid #2a2a38; background:#0b0b10; color:#e8e8ff; font-size: 12px; margin-top:auto; }
.equip-d2-select{ box-sizing: border-box; max-width: 100%; min-width: 0; }
.equip-d2-select:focus{ outline:none; border-color:#3a3a58; }
.equip-d2-hint{ margin-top: -2px; }

.area-head{ grid-area: head; }
.area-neck{ grid-area: neck; }
.area-ring1{ grid-area: ring1; }
.area-ring2{ grid-area: ring2; }
.area-body{ grid-area: body; }
.area-belt{ grid-area: belt; }
.area-legs{ grid-area: legs; }
.area-shoes{ grid-area: shoes; }
.area-hands{ grid-area: hands; }
.area-main{ grid-area: main; }
.area-off{ grid-area: off; }
.area-art1{ grid-area: art1; }
.area-art2{ grid-area: art2; }

.battle-log{ padding: 10px 12px; border-radius: 12px; background:#0b0b10; border:1px solid #2a2a38; }
.battle-line{ font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, "Liberation Mono", monospace; font-size: 12px; color:#d6d6e8; padding: 3px 0; border-bottom: 1px dashed rgba(42,42,56,0.45); }
.battle-line:last-child{ border-bottom: 0; }

@media (max-width: 980px){
  .world-layout{ flex-direction: column; }
  .world-side{ width:auto; position: static; }
  .equip-mini{ grid-template-columns: 1fr; }
  .equip-mini-name{ max-width: 100%; }

  .equip-d2-grid{
    grid-template-columns: repeat(2, minmax(0, 1fr));
    grid-template-areas:
      "head neck"
      "ring1 ring2"
      "main off"
      "body body"
      "belt belt"
      "legs legs"
      "hands shoes"
      "art1 art2";
  }

  .equip-d2-slot.area-main,
  .equip-d2-slot.area-off{ min-height: 180px; }
  .equip-d2-slot.area-head,
  .equip-d2-slot.area-hands,
  .equip-d2-slot.area-shoes,
  .equip-d2-slot.area-body,
  .equip-d2-slot.area-legs{ min-height: 160px; }
}

@media (max-width: 520px){
  .equip-d2-grid{ grid-template-columns: 1fr; grid-template-areas:
      "head" "neck" "ring1" "ring2" "main" "off" "body" "belt" "legs" "hands" "shoes" "art1" "art2"; }
}

/* Simple modal (used for PvP challenge dialogs) */
.modal-backdrop{ position:fixed; inset:0; display:none; align-items:center; justify-content:center; padding:16px; background: rgba(0,0,0,.55); z-index: 999; }
.modal-backdrop.open{ display:flex; }
.modal{ width:100%; max-width: 560px; background:#13131a; border:1px solid #2a2a38; border-radius: 14px; padding: 16px; box-shadow: 0 10px 40px rgba(0,0,0,.5); }
.modal-head{ display:flex; justify-content:space-between; align-items:center; gap:12px; margin-bottom: 10px; }
.modal-title{ font-size: 16px; font-weight: 800; }
.modal-close{ display:inline-flex; align-items:center; justify-content:center; width:32px; height:32px; border-radius: 10px; border:1px solid #2a2a38; background:#0f0f16; color:#a7a7b8; cursor:pointer; }
.modal-close:hover{ filter: brightness(1.05); }
.modal-actions{ display:flex; gap:10px; justify-content:flex-end; align-items:center; margin-top: 12px; }

/* Characters list helpers */

.pill.is-active{ border-color:#bdbdd6; color:#e9e9ff; background:#15151f; }
.pill-danger{ border-color:#5d2b2b; color:#ffbdbd; }

/* Admin header/nav: slightly larger pills for easier clicking */
.admin-header .pill{ padding: 12px 20px; font-size: 14px; }
.btn-danger{ background:#b12a2a; border:0; color:#fff; border-radius:10px; padding:10px 14px; cursor:pointer; font-weight:700; }
.btn-danger:hover{ filter: brightness(1.05); }
.char-table .char-actions{ white-space: nowrap; }
.char-table tr.is-active{ background: rgba(43, 43, 224, 0.10); }
.char-active{ margin-left: 8px; border-color: rgba(43, 43, 224, 0.5); color:#d7d7ff; }

/* Item links + item inspection modal */
.item-link{ color:#a7a7ff; text-decoration:none; }
.item-link:hover{ text-decoration: underline; }

.item-inspect-modal{ max-width: 980px; padding: 18px; }
.item-inspect-grid{ display:grid; grid-template-columns: 1.35fr 1fr; gap: 18px; }
@media (max-width: 860px){ .item-inspect-grid{ grid-template-columns: 1fr; } }

.item-inspect-section{ margin-top: 12px; padding-top: 12px; border-top: 1px solid #2a2a38; }
.item-inspect-section:first-child{ margin-top:0; padding-top:0; border-top:0; }
.item-inspect-h{ font-size: 11px; text-transform: uppercase; letter-spacing: .10em; color:#bdbdd6; margin-bottom: 8px; font-weight: 800; }
.item-inspect-desc{ color:#d6d6e8; white-space:pre-wrap; line-height: 1.5; }
.item-inspect-image{ border:1px solid #2a2a38; border-radius: 14px; background:#0b0b10; padding: 12px; display:flex; align-items:center; justify-content:center; min-height: 260px; }
.item-inspect-img{ max-width: 100%; max-height: 340px; object-fit:contain; border-radius: 10px; background:#fff; padding: 8px; }
.item-inspect-img-ph{ width:100%; height:100%; display:flex; align-items:center; justify-content:center; color:#a7a7b8; font-size: 12px; text-transform: uppercase; letter-spacing: .10em; }
.item-inspect-modal .kv-row{ display:flex; justify-content:space-between; align-items:baseline; gap: 12px; font-size: 13px; color:#d6d6e8; border-bottom: 1px dashed rgba(255,255,255,0.06); padding-bottom: 4px; }
.item-inspect-modal .kv-row span{ color:#a7a7b8; }
.item-inspect-modal .kv-row b{ font-weight:900; color:#e8e8ff; }
.item-inspect-facts, .item-inspect-kv, .item-inspect-consumable{ display:flex; flex-direction:column; gap: 8px; }
.item-inspect-eff{ margin-top: 10px; padding-top: 10px; border-top: 1px dashed rgba(255,255,255,0.08); }
.item-inspect-eff div{ font-size:12px; color:#d6d6e8; margin: 4px 0; }

/* Badge tiers used for public/combat-style ratings */
.badge-bad{ border-color:#5d2b2b; color:#ffbdbd; }
.badge-average{ border-color:#5d552b; color:#ffe7b0; }
.badge-good{ border-color:#2b5d3a; color:#bfffd0; }
.badge-master{ border-color:#3a2b5d; color:#e6d6ff; }

/* Sortable table headers */
th.sortable{ cursor:pointer; user-select:none; }
th.sortable:hover{ filter: brightness(1.05); }
.sort-ind{ font-size: 11px; margin-left: 6px; color:#a7a7b8; }

/* Monster inspect */
.monster-inspect-modal{ max-width: 1080px; padding: 18px; }
.monster-inspect-badges{ display:flex; flex-wrap:wrap; gap: 8px; margin: 4px 0 10px; }
.monster-inspect-grid{ display:grid; grid-template-columns: 1.35fr 1fr; gap: 18px; }
@media (max-width: 860px){ .monster-inspect-grid{ grid-template-columns: 1fr; } }

.monster-inspect-section{ margin-top: 12px; padding-top: 12px; border-top: 1px solid #2a2a38; }
.monster-inspect-section:first-child{ margin-top:0; padding-top:0; border-top:0; }
.monster-inspect-h{ font-size: 11px; text-transform: uppercase; letter-spacing: .10em; color:#bdbdd6; margin-bottom: 8px; font-weight: 800; }
.monster-inspect-desc{ color:#d6d6e8; white-space:pre-wrap; line-height: 1.5; }
.monster-inspect-image{ border:1px solid #2a2a38; border-radius: 14px; background:#0b0b10; padding: 12px; display:flex; align-items:center; justify-content:center; min-height: 240px; }
.monster-inspect-img{ max-width: 100%; max-height: 320px; object-fit:contain; border-radius: 10px; background:#fff; padding: 8px; }
.monster-inspect-img-ph{ width:100%; height:100%; display:flex; align-items:center; justify-content:center; color:#a7a7b8; font-size: 12px; text-transform: uppercase; letter-spacing: .10em; }
.monster-inspect-modal .kv-row{ display:flex; justify-content:space-between; align-items:baseline; gap: 12px; font-size: 13px; color:#d6d6e8; border-bottom: 1px dashed rgba(255,255,255,0.06); padding-bottom: 4px; }
.monster-inspect-modal .kv-row span{ color:#a7a7b8; }
.monster-inspect-modal .kv-row b{ font-weight:900; color:#e8e8ff; }
.monster-inspect-facts, .monster-inspect-kv, .monster-inspect-stats{ display:flex; flex-direction:column; gap: 8px; }

/* Minor: avoid double padding in right-side modal-actions inside the monster modal */
.monster-inspect-modal .modal-actions{ justify-content:flex-start; }

/* Battle view layout */
.battle-summary-grid{display:flex;gap:14px;flex-wrap:wrap;align-items:flex-start}
.battle-summary-main{flex:1 1 280px;min-width:240px}
.battle-summary-side{flex:0 0 280px;min-width:240px}
.battle-sidebox{border:1px solid #d6d6d6;border-radius:10px;padding:10px;background:#fff}
.battle-sidebox-title{font-weight:700;text-transform:uppercase;letter-spacing:.04em;margin-bottom:6px}

.battle-team-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px}
.battle-team{border:1px solid #d6d6d6;border-radius:12px;padding:10px;background:#fff}
.battle-team-title{font-weight:700;text-transform:uppercase;letter-spacing:.04em}
.battle-team-members a{word-break:break-word}

/* Optional accent borders per team */
.battle-team-a{box-shadow:inset 0 0 0 3px rgba(220, 38, 38, .20)}
.battle-team-b{box-shadow:inset 0 0 0 3px rgba(37, 99, 235, .20)}
.battle-team-c{box-shadow:inset 0 0 0 3px rgba(22, 163, 74, .20)}
.battle-team-d{box-shadow:inset 0 0 0 3px rgba(147, 51, 234, .20)}

/* Stat points (level-up spending) */
.sp-left{ color:#ffbdbd; font-weight: 800; }

.world-widget.statpoints{ border-color:#2b5d3a; background: rgba(43, 93, 58, 0.12); }
.world-widget.statpoints .spw-body{ display:flex; justify-content:space-between; align-items:center; gap: 12px; flex-wrap:wrap; }
.world-widget.statpoints .spw-text{ flex: 1 1 140px; }
.world-widget.statpoints .pill{ margin-left:auto; }
.world-widget.statpoints .spw-text{ font-size: 12px; color:#d6d6e8; }
.world-widget.statpoints .spw-text b{ color:#bdf6c8; }

.pill-ok{ border-color:#2b5d3a; color:#bdf6c8; }

.sp-points{ float:right; font-size: 12px; font-weight: 700; color:#a7a7b8; }
.sp-points b{ color:#e8e8ff; }

.spend-table{ table-layout:auto; }
.sp-th{ text-align:right; width: 110px; }
.sp-input{ width: 86px; min-width: 0; padding: 6px 8px; text-align:right; border-radius: 10px; }

.spend-bar{ display:flex; justify-content:space-between; align-items:center; gap: 12px; flex-wrap:wrap; margin: 12px 0 0; padding: 10px 12px; border-radius: 12px; background:#0f0f16; border:1px solid #2a2a38; }
.spend-meta{ font-size: 12px; color:#a7a7b8; }
.spend-meta b{ color:#e8e8ff; }
#spRemain.is-neg{ color:#ffbdbd; }
