:root{
  --bg:#0b0f14;
  --bg2:#0f1620;
  --panel:#121b26;
  --panel2:#0e141d;
  --txt:#e8edf3;
  --muted:#aab4c0;
  --line:#223042;
  --accent:#88c0d0;
  --accent2:#5e81ac;
  --danger:#d35d6e;
  --ok:#59d07f;
  --warn:#e7b75f;
  --shadow:0 18px 45px rgba(0,0,0,.45);
  --radius:16px;
  --radius2:12px;
  --pad:18px;
}

*{box-sizing:border-box}

html,body{height:100%}

html{background:var(--bg)}

body{
  margin:0;
  min-height:100%;
  color:var(--txt);
  background:var(--bg);
  font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,Noto Sans,sans-serif;
  line-height:1.45;
  position:relative;
  overflow-x:hidden;

  /* Page FX hooks (PASS 2): override per page via [data-page] / [data-world-page] */
  --page-bg-image:none;
  --page-bg-opacity:.16;
  --page-atmo-opacity:1;

  /* HUD/topbar overlay art */
  --hud-image:none;
  --hud-opacity:.40;
}

/* Fullscreen background art layer */
body::before{
  content:"";
  position:fixed;
  inset:0;
  background:var(--page-bg-image) center/cover no-repeat;
  opacity:var(--page-bg-opacity);
  filter:saturate(1.05) contrast(1.05);
  pointer-events:none;
  z-index:-2;
  transform:translate3d(0,0,0);
}

/* Ambient atmosphere gradients */
body::after{
  content:"";
  position:fixed;
  inset:0;
  background:
    radial-gradient(900px 520px at 18% 0%, rgba(136,192,208,.12), transparent 60%),
    radial-gradient(1100px 700px at 100% 10%, rgba(94,129,172,.10), transparent 55%);
  opacity:var(--page-atmo-opacity);
  pointer-events:none;
  z-index:-1;
}

@keyframes bgdrift{
  0%{transform:translate3d(0,0,0) scale(1)}
  50%{transform:translate3d(-14px,-10px,0) scale(1.02)}
  100%{transform:translate3d(0,0,0) scale(1)}
}
body::before{animation:bgdrift 18s ease-in-out infinite}
@media (prefers-reduced-motion: reduce){
  body::before{animation:none}
}

/* Page presets (swap these assets freely later) */
body[data-page="login"]{
  --page-bg-image:url('/assets/ui/bg_login.svg');
  --page-bg-opacity:.22;
  --hud-image:url('/assets/ui/hud_login.svg');
  --hud-opacity:.55;
}
body[data-page="register"]{
  --page-bg-image:url('/assets/ui/bg_login.svg');
  --page-bg-opacity:.20;
  --hud-image:url('/assets/ui/hud_login.svg');
  --hud-opacity:.50;
}
body[data-page="characters"]{
  --page-bg-image:url('/assets/ui/bg_characters.svg');
  --page-bg-opacity:.18;
  --hud-image:url('/assets/ui/hud_characters.svg');
  --hud-opacity:.45;
}
body[data-page="character_create"]{
  --page-bg-image:url('/assets/ui/bg_characters.svg');
  --page-bg-opacity:.16;
  --hud-image:url('/assets/ui/hud_characters.svg');
  --hud-opacity:.40;
}

/* World defaults (can be overridden per world page via [data-world-page]) */
body.world{
  --page-bg-image:url('/assets/ui/bg_world.svg');
  --page-bg-opacity:.13;
  --page-atmo-opacity:.95;
  --hud-image:url('/assets/ui/hud_world.svg');
  --hud-opacity:.35;
}

/* Optional per-world-page hooks (leave assets undefined unless you add them) */
body.world[data-world-page="lobbies"]{--page-bg-opacity:.15}
body.world[data-world-page="match_view"]{--page-bg-opacity:.12}
body.world[data-world-page="inventory"]{--page-bg-opacity:.14}

a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}

code{
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.07);
  padding:2px 7px;
  border-radius:999px;
  color:#d9e6ff;
}

.container{max-width:1100px;margin:0 auto;padding:var(--pad)}

/* Top bar (non-world pages) */
.app-header{
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(13,18,26,.82);
  border-bottom:1px solid var(--line);
  backdrop-filter:blur(10px);
  overflow:hidden;
  isolation:isolate;
}

.app-header::before{
  content:"";
  position:absolute;
  inset:0;
  background:var(--hud-image) center/cover no-repeat;
  opacity:var(--hud-opacity);
  pointer-events:none;
  z-index:-1;
  filter:saturate(1.05) contrast(1.05);
}

.app-header-inner{
  max-width:1100px;
  margin:0 auto;
  padding:14px var(--pad);
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  justify-content:space-between;
  gap:14px;
}

.brand{display:flex;flex-direction:column;gap:2px;min-width:180px}
.brand strong{font-size:18px;letter-spacing:.02em}
.brand .sub{font-size:12px;color:var(--muted)}

.topnav{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end}
.topnav a{
  color:var(--txt);
  padding:8px 10px;
  border-radius:12px;
  border:1px solid transparent;
}
.topnav a:hover{background:rgba(255,255,255,.05);border-color:rgba(255,255,255,.06);text-decoration:none}

.topnav form{display:inline}

.btn{
  display:inline-flex;
  align-items:center;
  flex-wrap:wrap;
  justify-content:center;
  gap:8px;
  padding:9px 12px;
  border-radius:12px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.04);
  color:var(--txt);
  cursor:pointer;
  line-height:1;
}
.btn-xs{
  padding:6px 9px;
  font-size:12px;
  border-radius:10px;
  gap:6px;
}
.btn:hover{background:rgba(255,255,255,.07)}
.btn:disabled{opacity:.45;cursor:not-allowed}
.btn-primary{border-color:rgba(136,192,208,.55);background:rgba(136,192,208,.10)}
.btn-primary:hover{background:rgba(136,192,208,.16)}
.btn-danger{border-color:rgba(211,93,110,.6);background:rgba(211,93,110,.10)}
.btn-danger:hover{background:rgba(211,93,110,.16)}

/* Legacy helpers used by older templates/scripts (kept for consistency) */
.btn-sm{padding:7px 10px;font-size:12px;border-radius:11px;gap:6px}
.btn-ghost{background:rgba(0,0,0,.12);border-color:rgba(255,255,255,.08)}
.btn-ghost:hover{background:rgba(255,255,255,.05);border-color:rgba(255,255,255,.12)}

/* Cards + typography */
.card{
  border:1px solid var(--line);
  background:linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.03));
  border-radius:var(--radius);
  padding:16px;
  box-shadow:var(--shadow);
}

/* Nested panels inside cards shouldn't stack heavy shadows */
.card .card{box-shadow:none;background:rgba(0,0,0,.18)}

/* HUD toast popups (challenge notifications etc.) */
.hud-toast{
  background:linear-gradient(180deg, rgba(18,22,28,.94), rgba(12,15,20,.90));
  border-color:rgba(255,255,255,.10);
  backdrop-filter:blur(10px);
}

.muted{color:var(--muted)}

h1,h2,h3{margin:0 0 10px 0}
h1{font-size:26px;letter-spacing:.01em}
h2{font-size:20px}
h3{font-size:16px;color:#d7e2f3}

.grid{display:grid;gap:16px}
@media (min-width: 920px){.grid.two{grid-template-columns:1fr 1fr}}

/* Character page: keep stat cards readable; only go 2-up on wider screens. */
.char-stats-grid{grid-template-columns:1fr}
@media (min-width: 1200px){.char-stats-grid{grid-template-columns:1fr 1fr}}

/* Forms */
.form{display:grid;gap:12px}
.field{display:grid;gap:6px}
.field label{font-size:13px;color:var(--muted)}

input:not([type]),input[type="text"],input[type="password"],input[type="email"],input[type="number"],input[type="search"],select,textarea{
  width:100%;
  padding:10px 12px;
  color:var(--txt);
  background:rgba(0,0,0,.22);
  border:1px solid rgba(255,255,255,.10);
  border-radius:12px;
  outline:none;
  color-scheme:dark;
  min-width:0;
}

/* HOTFIX-21: native form/dropdown readability.
   Browser support for <option> hover is uneven, but these rules keep
   Chromium/Brave/Firefox dark-theme selects readable instead of falling
   back to black text on pale option panes. */
select{
  appearance:auto;
  background-color:rgba(7,11,17,.94);
  color:var(--txt);
}
select option,
select optgroup{
  background-color:#0f1620;
  color:#e8edf3;
}
select option:checked{
  background-color:#223042;
  color:#ffffff;
}
select option:disabled,
select:disabled,
input:disabled,
textarea:disabled{
  color:rgba(232,237,243,.50);
  background-color:rgba(8,12,18,.70);
  border-color:rgba(255,255,255,.07);
  opacity:.75;
}
select:hover,
input:hover,
textarea:hover{border-color:rgba(255,255,255,.16)}

/* Custom select (progressive enhancement via /assets/js/core/nselect.js) */
.nselect-wrap{position:relative}
.nselect-native{position:absolute!important;opacity:0!important;pointer-events:none!important;width:0!important;height:0!important}
.nselect-btn{
  width:100%;
  padding:10px 12px;
  color:var(--txt);
  background:rgba(0,0,0,.22);
  border:1px solid rgba(255,255,255,.10);
  border-radius:12px;
  outline:none;
  cursor:pointer;
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  justify-content:space-between;
  gap:10px;
}
.nselect-btn:hover{background:rgba(0,0,0,.28)}
.nselect-wrap.open .nselect-btn,
.nselect-btn:focus{border-color:rgba(136,192,208,.65);box-shadow:0 0 0 3px rgba(136,192,208,.14)}
.nselect-btn-text{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.nselect-btn-chev{opacity:.8}
.nselect-btn-chev::before{content:"▾"}

.nselect-menu{
  position:absolute;
  left:0;right:0;
  top:calc(100% + 6px);
  background:linear-gradient(180deg, rgba(18,27,38,.98), rgba(14,20,29,.98));
  border:1px solid var(--line);
  border-radius:14px;
  box-shadow:var(--shadow);
  padding:6px;
  max-height:280px;
  overflow:auto;
  display:none;
  z-index:500;
}
.nselect-wrap.open .nselect-menu{display:block}

.nselect-item{
  width:100%;
  display:flex;
  align-items:center;
  text-align:left;
  padding:10px 12px;
  border-radius:12px;
  border:1px solid transparent;
  background:transparent;
  color:var(--txt);
  cursor:pointer;
}
.nselect-item:hover{background:rgba(255,255,255,.05);border-color:rgba(255,255,255,.06)}
.nselect-item:focus{outline:none;box-shadow:0 0 0 3px rgba(136,192,208,.12)}
.nselect-item.is-selected{background:rgba(136,192,208,.10);border-color:rgba(136,192,208,.35)}
.nselect-item.is-disabled{opacity:.45;cursor:not-allowed}

input.num{max-width:120px}

textarea{min-height:120px;resize:vertical}
input:focus,select:focus,textarea:focus{border-color:rgba(136,192,208,.65);box-shadow:0 0 0 3px rgba(136,192,208,.14)}
input:focus-visible,select:focus-visible,textarea:focus-visible,.btn:focus-visible,.linkbtn:focus-visible{outline:2px solid rgba(136,192,208,.75);outline-offset:2px}

.help{font-size:12px;color:var(--muted)}

.alert{border-radius:14px;padding:10px 12px;border:1px solid var(--line);background:rgba(255,255,255,.03)}
.alert.error,.alert.alert-error{border-color:rgba(211,93,110,.55);background:rgba(211,93,110,.10);color:#ffd4da}
.alert.ok,.alert.alert-ok{border-color:rgba(163,190,140,.45);background:rgba(163,190,140,.10);color:#eaffdf}
.alert.warn,.alert.alert-warn{border-color:rgba(235,203,139,.45);background:rgba(235,203,139,.10);color:#fff0cf}

/* Lists */
.list{margin:0;padding-left:18px}
.list li{margin:6px 0}

.divider{height:1px;background:var(--line);margin:14px 0}

/* Tables */
.table-wrap{overflow:auto;border:1px solid var(--line);border-radius:14px;background:rgba(0,0,0,.14)}
.table{width:100%;border-collapse:collapse;min-width:560px}
.table th,.table td{padding:10px 12px;border-bottom:1px solid rgba(255,255,255,.06);text-align:left;vertical-align:middle}
.table th{font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.table tr:last-child td{border-bottom:none}
.table-compact th,.table-compact td{padding:8px 10px}

/* Utility alignment helpers */
.is-right{text-align:right !important}
.is-center{text-align:center !important}

.pill{display:inline-block;padding:3px 10px;border:1px solid rgba(255,255,255,.10);border-radius:999px;font-size:12px;color:#d6e4ff;background:rgba(255,255,255,.04)}
.pill-ok{border-color:rgba(163,190,140,.35);background:rgba(163,190,140,.10)}
.pill-warn{border-color:rgba(235,203,139,.35);background:rgba(235,203,139,.10)}
.pill-bad{border-color:rgba(191,97,106,.35);background:rgba(191,97,106,.10)}

.linkbtn{
  background:none;
  border:none;
  padding:0;
  color:var(--accent);
  cursor:pointer;
  text-align:left;
  font:inherit;
}
.linkbtn:hover{text-decoration:underline}

.ok{color:var(--ok)}
.warn{color:var(--warn)}
.bad{color:var(--danger)}

/* Characters page */
.char-list{display:grid;gap:10px;margin:0;padding:0;list-style:none}
.char-item{
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  justify-content:space-between;
  gap:12px;
  padding:12px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(0,0,0,.18);
}
.char-meta{display:flex;flex-direction:column;gap:2px}
.char-name{font-weight:700}
.char-lvl{font-size:12px;color:var(--muted)}

.char-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end}
.char-visibility{display:flex;align-items:center;gap:10px}
.char-status{flex:1 1 260px;min-width:220px;display:flex;flex-direction:column;gap:6px}
.char-hp{display:flex;flex-direction:column;gap:6px}
.char-hpbar{height:10px;border-radius:999px;overflow:hidden;border:1px solid rgba(255,255,255,.10);background:rgba(0,0,0,.22)}
.char-hpfill{height:100%;width:0;background:rgba(191,97,106,.75)}
.char-hpmeta{display:flex;align-items:center;justify-content:space-between;gap:12px;font-size:12px;color:var(--muted)}
.char-hptext{color:#d6e4ff}
.char-hptimer{white-space:nowrap}
.char-badges{display:flex;gap:6px;flex-wrap:wrap}

/* Toggle switch (characters visibility) */
.toggle{display:inline-flex;align-items:center;gap:8px;user-select:none;cursor:pointer}
.toggle input{position:absolute;opacity:0;pointer-events:none}
.toggle-slider{width:44px;height:24px;border-radius:999px;position:relative;flex:0 0 auto;
  border:1px solid rgba(255,255,255,.10);background:rgba(0,0,0,.22);box-shadow:inset 0 0 0 1px rgba(0,0,0,.2)
}
.toggle-slider::after{content:"";position:absolute;top:50%;left:3px;transform:translateY(-50%);
  width:18px;height:18px;border-radius:999px;background:rgba(255,255,255,.86);
  box-shadow:0 2px 10px rgba(0,0,0,.35);transition:transform .15s ease, background .15s ease
}
.toggle input:checked + .toggle-slider{background:rgba(157,94,255,.18);border-color:rgba(157,94,255,.35)}
.toggle input:checked + .toggle-slider::after{transform:translate(20px,-50%)}
.toggle-text{font-size:12px;color:var(--muted)}

/* Toggle size variant (used in Match statistics tab) */
.toggle.toggle-xs{gap:0}
.toggle.toggle-xs .toggle-slider{width:34px;height:18px}
.toggle.toggle-xs .toggle-slider::after{width:14px;height:14px;left:2px}
.toggle.toggle-xs input:checked + .toggle-slider::after{transform:translate(16px,-50%)}

@media (max-width: 420px){
  .char-actions{justify-content:space-between}
  .toggle-text{display:none}
}

/* Character create */
.cc-layout{
  display:grid;
  gap:16px;
  grid-template-areas:
    "identity"
    "portrait"
    "stats"
    "weapons"
    "actions";
}
@media (min-width: 1040px){
  .cc-layout{
    /* Desktop: keep grid items sized to content (no stretching into empty-looking cards) */
    align-items:start;
    align-content:start;
    grid-auto-rows:min-content;
    grid-template-columns:minmax(0,1fr) minmax(0,1fr);
    grid-template-areas:
      "identity portrait"
      "stats weapons"
      "actions actions";
  }
  /* Extra safety: ensure children never stretch */
  .cc-layout > *{align-self:start}
}


.cc-identity{grid-area:identity}
.cc-portrait{grid-area:portrait}
.cc-stats{grid-area:stats}
.cc-weapons{grid-area:weapons}
.cc-actions{grid-area:actions;display:flex;align-items:center;gap:12px;flex-wrap:wrap}

.portraits{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:12px}
.portrait{
  border:1px solid rgba(255,255,255,.10);
  border-radius:16px;
  padding:10px;
  background:rgba(0,0,0,.18);
  text-align:center;
}
.portrait img{width:78px;height:78px;display:block;margin:6px auto 10px auto;object-fit:contain}
.portrait input{width:auto}

.section-row td{
  background:rgba(255,255,255,.03);
  font-weight:800;
  letter-spacing:.10em;
  text-transform:uppercase;
  font-size:11px;
  color:var(--muted);
}

.wep-row.unaffordable{opacity:.55}

/* Modal */
.cc-modal{position:fixed;inset:0;display:none;align-items:center;justify-content:center;z-index:9999}
.cc-modal.open{display:flex}
.cc-modal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.60)}
.cc-modal-card{
  position:relative;
  max-width:920px;
  width:min(92vw,920px);
  max-height:86vh;
  overflow:auto;
  background:linear-gradient(180deg, rgba(18,27,38,.98), rgba(14,20,29,.98));
  border-radius:18px;
  border:1px solid var(--line);
  box-shadow:var(--shadow);
}
.cc-modal-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid rgba(255,255,255,.08)}
.cc-modal-body{padding:16px}
.cc-modal-grid{display:grid;grid-template-columns:1fr;gap:14px}
@media (min-width: 860px){.cc-modal-grid{grid-template-columns:260px 1fr}}
.cc-modal-img{width:260px;height:260px;object-fit:contain;border:1px solid rgba(255,255,255,.08);border-radius:14px;background:rgba(0,0,0,.25)}
.cc-modal-close{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.10);border-radius:12px;padding:7px 10px;color:var(--txt);cursor:pointer}
.cc-modal-close:hover{background:rgba(255,255,255,.07)}
.cc-modal-h{margin:14px 0 6px 0}
.cc-list{margin:0;padding-left:18px}

/* World layout overrides */
body.world{background:var(--bg)}
.hud{
  position:sticky;
  top:0;
  z-index:60;
  background:rgba(18,27,38,.90);
  border-bottom:1px solid var(--line);
  padding:10px 14px;
  display:grid;
  grid-template-columns:minmax(280px,420px) minmax(260px,1fr) minmax(250px,auto);
  grid-template-areas:"hud-char hud-vitals hud-right";
  align-items:center;
  gap:12px;
  backdrop-filter:blur(10px);
  overflow:hidden;
  isolation:isolate;
}
.hud::before{
  content:"";
  position:absolute;
  inset:0;
  background:var(--hud-image) center/cover no-repeat;
  opacity:var(--hud-opacity);
  pointer-events:none;
  z-index:-1;
  filter:saturate(1.05) contrast(1.05);
}
.hud small{color:var(--muted)}
.hud .stats{display:flex;gap:12px;flex-wrap:wrap;min-width:0}
.hud > .hud-char{grid-area:hud-char}
.hud > .hud-vitals{grid-area:hud-vitals}
.hud > .hud-right{grid-area:hud-right}
.hud-right{display:flex;align-items:center;justify-content:flex-end;gap:12px;flex-wrap:nowrap;min-width:0}
.hud-actions{display:flex;flex-direction:column;gap:6px;align-items:stretch;flex:0 0 auto}
.hud-actions .btn{width:100%;white-space:nowrap}
.hud-links{display:flex;align-items:center;gap:10px;flex-wrap:nowrap;white-space:nowrap;min-width:0}
.hud-links a{white-space:nowrap}
.hud-links form{display:inline-flex;margin:0}

/* HOTFIX-21: explicit HUD responsive grid.
   Desktop keeps one row. Medium widths intentionally move secondary
   controls to a clean second row before random wrapping can happen. */
@media (max-width: 1199px){
  .hud{
    grid-template-columns:minmax(260px,380px) minmax(260px,1fr);
    grid-template-areas:
      "hud-char hud-vitals"
      "hud-right hud-right";
    align-items:start;
  }
  .hud-right{
    justify-content:space-between;
    width:100%;
    padding-top:2px;
    border-top:1px solid rgba(255,255,255,.06);
  }
  .hud-actions{flex-direction:row;flex-wrap:wrap}
  .hud-actions .btn{width:auto}
}
@media (max-width: 900px){
  /* Mobile/tablet: let the HUD scroll away naturally instead of pinning the whole page under it. */
  .hud{
    position:relative;
    top:auto;
    z-index:40;
    grid-template-columns:1fr;
    grid-template-areas:
      "hud-char"
      "hud-vitals"
      "hud-right";
    padding:10px 12px;
    align-items:stretch;
  }
  .hud-right{align-items:stretch;justify-content:space-between;gap:10px}
}
@media (max-width: 640px){
  .hud-right{flex-direction:column}
  .hud-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px}
  .hud-actions .btn{width:100%}
  .hud-links{justify-content:space-between;width:100%;gap:8px}
  .hud-links .btn{padding:8px 10px}
}
@media (max-width: 420px){
  .hud-actions{grid-template-columns:1fr}
  .hud-links{align-items:stretch}
  .hud-links form{display:flex}
  .hud-links .btn{width:100%}
}


/* Character widget (portrait + name/level + XP + wallet) */
.hud-char{
  display:flex;
  align-items:center;
  gap:10px;
  padding:7px 11px;
  border:1px solid rgba(255,255,255,.10);
  border-radius:14px;
  background:rgba(0,0,0,.18);
  box-shadow:0 8px 24px rgba(0,0,0,.22);
  width:fit-content;
  max-width:460px;
}
.hud-char-portrait{
  width:44px;
  height:44px;
  border-radius:12px;
  object-fit:cover;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.05);
  flex:0 0 auto;
}
.hud-char-main{display:flex;flex-direction:column;gap:8px;min-width:0;flex:1 1 auto}
.hud-char-top{display:flex;flex-direction:column;gap:2px;min-width:0}
.hud-char-name{font-size:15px;line-height:1.1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.hud-char-level{color:var(--muted);line-height:1.1}
.hud-char-xp-top{display:flex;justify-content:space-between;align-items:baseline;gap:10px;font-size:11px;line-height:1}
.hud-char-xp-label{letter-spacing:.10em;text-transform:uppercase;color:var(--muted)}
.hud-char-xp-val{font-variant-numeric:tabular-nums;color:var(--txt)}
.hud-char-xp-track{height:7px;margin-top:6px;border-radius:999px;overflow:hidden;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08)}
.hud-char-xp-track span{display:block;height:100%;width:0;background:linear-gradient(90deg, rgba(232,197,83,.85), rgba(255,221,130,.55))}

.hud-char-money{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.hud-char-money-icon{width:18px;height:18px;opacity:.95;flex:0 0 auto}

@media (max-width: 720px){
  .hud-char{max-width:none;width:100%}
}

.hud-vitals{display:flex;flex-direction:column;gap:6px;min-width:220px;flex:1 1 260px;max-width:320px}
.hud-vitals-row{display:flex;gap:8px;align-items:stretch}
.hud-vitals-row .hud-vbar-hp{flex:1 1 auto;min-width:220px}
.hud-buffs{display:flex;align-items:center;justify-content:center;padding:6px 8px;border:1px solid rgba(255,255,255,.10);border-radius:14px;background:rgba(0,0,0,.18);box-shadow:0 8px 24px rgba(0,0,0,.22)}
.hud-buffs-inner{display:flex;gap:6px;align-items:center;max-width:190px;overflow-x:auto;overflow-y:hidden;padding-bottom:2px}
.hud-buffs-inner::-webkit-scrollbar{height:6px}
.hud-buffs-inner::-webkit-scrollbar-thumb{background:rgba(255,255,255,.12);border-radius:999px}
.hud-buffs-empty{font-size:11px;color:var(--muted);white-space:nowrap}
.hud-buff{width:34px;height:34px;border-radius:999px;position:relative;padding:2px;flex:0 0 auto;background:conic-gradient(var(--accent) calc(var(--p,0)*1turn), rgba(255,255,255,.10) 0)}
.hud-buff-inner{width:100%;height:100%;border-radius:999px;overflow:hidden;border:1px solid rgba(255,255,255,.12);background:rgba(0,0,0,.35);display:flex;align-items:center;justify-content:center}
.hud-buff img{width:100%;height:100%;object-fit:cover;display:block}
.hud-buff-time{position:absolute;right:1px;bottom:1px;padding:2px 5px;border-radius:999px;background:rgba(0,0,0,.75);border:1px solid rgba(255,255,255,.15);font-size:10px;line-height:1;font-variant-numeric:tabular-nums;color:var(--txt)}
.hud-vbar{padding:6px 10px;border:1px solid rgba(255,255,255,.10);border-radius:14px;background:rgba(0,0,0,.18);box-shadow:0 8px 24px rgba(0,0,0,.22)}
.hud-vbar-top{display:flex;justify-content:space-between;align-items:baseline;gap:10px;font-size:12px;line-height:1}
.hud-vbar-label{letter-spacing:.10em;text-transform:uppercase;color:var(--muted)}
.hud-vbar-val{font-variant-numeric:tabular-nums;color:var(--txt)}
.hud-vbar-track{height:8px;margin-top:6px;border-radius:999px;overflow:hidden;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08)}
.hud-vbar-track span{display:block;height:100%;width:0}
.hud-vbar-hp .hud-vbar-track span{background:linear-gradient(90deg, rgba(238,93,116,.90), rgba(255,160,170,.70))}
.hud-vbar-xp .hud-vbar-track span{background:linear-gradient(90deg, rgba(232,197,83,.85), rgba(255,221,130,.55))}
.hud-vbar-sub{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-top:6px;font-size:11px;line-height:1;color:var(--muted)}
.hud-vbar-full,.hud-vbar-tick{display:inline-flex;align-items:center;gap:6px;font-variant-numeric:tabular-nums}
.hud-hourglass{width:14px;height:14px;opacity:.85}
@media (max-width: 720px){.hud-vitals{min-width:unset;flex:1 1 100%;max-width:none}.hud-vitals-row{flex-wrap:wrap}.hud-buffs{width:100%;justify-content:flex-start}.hud-buffs-inner{max-width:none}}

.hud-wallet{display:flex;align-items:center;gap:10px;padding:6px 10px;border:1px solid rgba(255,255,255,.10);border-radius:14px;background:rgba(0,0,0,.18);box-shadow:0 8px 24px rgba(0,0,0,.22)}
.hud-wallet-icon{width:22px;height:22px;opacity:.95;flex:0 0 auto}
.hud-wallet-money{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.hud-currency{display:flex;align-items:center;gap:6px;font-size:13px;line-height:1;color:var(--txt)}
.hud-coin{width:16px;height:16px;opacity:.95}
@media (max-width: 720px){.hud-wallet{padding:5px 8px}.hud-currency{font-size:12px}}

.shell{display:grid;grid-template-columns:260px 1fr;min-height:calc(100vh - 0px)}
.world-nav{background:var(--panel2);border-right:1px solid var(--line);padding:12px}
.world-nav h3{margin:14px 0 8px;font-size:12px;letter-spacing:.10em;text-transform:uppercase;color:var(--muted)}
.world-nav a{display:block;padding:8px 10px;border-radius:12px;color:var(--txt)}
.world-nav a:hover{background:rgba(255,255,255,.05);text-decoration:none}
.world-nav a.is-active{background:rgba(136,192,208,.12);box-shadow:0 0 0 1px rgba(136,192,208,.35) inset}
.world-nav a.is-locked{opacity:.45;cursor:not-allowed}
.world-nav a.is-locked:hover{background:rgba(255,255,255,.03)}
.world-nav.is-nochar-locked h3{opacity:.35}
.world-nav.is-nochar-locked a{opacity:.35}
.world-nav.is-nochar-locked a:hover{background:rgba(255,255,255,.03)}
.world-content{padding:18px;max-width:980px;min-width:0;width:min(100%,980px)}

@media (max-width: 900px){
  /* Keep the main shell compact and prevent the nav row from stretching on short pages. */
  .shell{
    grid-template-columns:1fr;
    grid-template-rows:auto minmax(0,1fr);
    min-height:0;
    align-content:start;
  }
  .world-nav{
    position:sticky;
    top:0;
    z-index:45;
    border-right:none;
    border-bottom:1px solid var(--line);
    display:flex;
    gap:8px;
    overflow-x:auto;
    overflow-y:hidden;
    white-space:nowrap;
    flex-wrap:nowrap;
    align-items:center;
    align-self:start;
    min-height:64px;
    padding:10px 12px;
    box-sizing:border-box;
    background:rgba(14,20,29,.96);
    backdrop-filter:blur(10px);
    box-shadow:0 10px 24px rgba(0,0,0,.22);
    scrollbar-width:none;
    -ms-overflow-style:none;
    scroll-snap-type:x proximity;
    overscroll-behavior-x:contain;
    touch-action:pan-x;
  }
  .world-nav::-webkit-scrollbar{display:none}
  .world-nav h3{display:none}
  .world-nav a{
    flex:0 0 auto;
    display:inline-flex;
    align-items:center;
    gap:8px;
    min-height:40px;
    white-space:nowrap;
    scroll-snap-align:start;
  }
  .world-content{padding:14px;max-width:none;width:100%}
}

@media (max-width: 560px){
  .app-header-inner{padding:12px 14px;gap:10px}
  .brand{min-width:unset}
  .container{padding:14px}
  .topnav{gap:6px}
  .topnav a{padding:8px 8px}
}

/* Character create page: ensure the outer holder always expands with content */
.cc-page{
  height:auto !important;
  max-height:none !important;
  min-height:0 !important;
  overflow:visible !important;
  display:flow-root;
}

/* Phase 0.7 character creator UI tweaks */
@media (min-width: 1040px){
  .cc-layout{
    /* Make the whole creator fit a single viewport height on desktop */
    height: calc(100vh - 210px);
    grid-template-rows: minmax(0, 1fr) minmax(0, 1fr) auto;
    align-items: stretch;
    align-content: stretch;
    grid-auto-rows: auto;
  }
  .cc-layout > *{align-self: stretch; min-height:0}
}

/* Make the four main cards behave like panels with internal scroll */
.cc-identity,.cc-portrait,.cc-stats,.cc-weapons{display:flex;flex-direction:column;min-height:0}
.cc-identity .form{flex:1;min-height:0;overflow:auto;padding-right:4px}
.cc-portrait .portraits{flex:1;min-height:0;overflow:auto;padding-right:4px}
.cc-stats .table-wrap,.cc-weapons .table-wrap{flex:1;min-height:0}

/* Portrait grid: stable tiles (no overlap) + full-size images */
.cc-portrait .portraits{
  /* Mobile / narrow: allow flexible columns */
  grid-template-columns:repeat(auto-fill, minmax(160px, 1fr));
  align-content:start;
  /* More breathing room so tiles/selection don't touch each other or the panel */
  gap:16px;
  padding:12px;
  padding-right:16px; /* keep space for scrollbar */
}
@media (min-width: 1040px){
  .cc-portrait .portraits{
    /* Desktop: keep a stable multi-column grid so tiles don't blow up */
    grid-template-columns:repeat(2, minmax(0, 1fr));
    gap:18px;
    padding:14px;
    padding-right:18px;
  }
}


.cc-portrait .portrait{
  position:relative;
  display:block;
  padding:0;
  border-radius:14px;
  overflow:hidden;
  cursor:pointer;
  background:rgba(0,0,0,.12);
  border:1px solid rgba(255,255,255,.06);

  /* Prevent "thin strip" collapse on desktop: force a stable box */
  aspect-ratio: 1 / 1;
  min-height: 150px;
}
@media (min-width: 1040px){
  .cc-portrait .portrait{min-height: 190px}
}

/* Fill the tile */
.cc-portrait .portrait img,
.cc-portrait .portrait .portrait-empty{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
}
.cc-portrait .portrait img{display:block;object-fit:cover}
.cc-portrait .portrait .portrait-empty{
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  justify-content:center;
  color:var(--muted);
  font-size:12px;
}
.cc-portrait .portrait input{position:absolute;inset:0;opacity:0}
.cc-portrait .portrait.is-selected{outline:2px solid rgba(136,192,208,.85);outline-offset:2px}

/* Tighten tables inside creator */
.cc-stats .table, .cc-weapons .table{min-width:0}
.cc-stats .table th,.cc-stats .table td{padding:8px 10px}
.cc-weapons .table th,.cc-weapons .table td{padding:8px 10px}

/* =========================
   World: Overview dashboard
   ========================= */
.overview-head{display:flex;flex-direction:column;gap:10px;align-items:flex-start;justify-content:space-between;margin-bottom:12px}
.overview-actions{display:flex;gap:8px;flex-wrap:wrap}
@media (min-width: 700px){.overview-head{flex-direction:row;align-items:center}}

.overview-snapshot{display:flex;gap:14px;align-items:flex-start}
.overview-portrait{
  width:92px;height:92px;object-fit:cover;
  border-radius:16px;
  background:rgba(0,0,0,.25);
  border:1px solid rgba(255,255,255,.10);
}
@media (min-width: 920px){.overview-portrait{width:120px;height:120px}}

.overview-name{font-size:22px;font-weight:800;letter-spacing:.02em}
.overview-res{display:grid;gap:10px;margin-top:12px}
.overview-res-row{display:grid;grid-template-columns:72px 1fr 92px;align-items:center;gap:10px}
@media (max-width: 560px){.overview-res-row{grid-template-columns:62px 1fr 72px;gap:8px}}
.overview-res-label{font-size:12px;letter-spacing:.10em;text-transform:uppercase;color:var(--muted)}
.overview-res-val{text-align:right;font-variant-numeric:tabular-nums}

/* Tier rows (HP/Stamina hidden behind labels) */
.overview-tier-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:6px 0}
.overview-tier-row + .overview-tier-row{border-top:1px solid rgba(255,255,255,.06)}

.overview-bar{height:10px;border-radius:999px;overflow:hidden;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08)}
.overview-bar span{display:block;height:100%;background:rgba(136,192,208,.55)}
.overview-bar.is-hp span{background:linear-gradient(90deg, rgba(238,93,116,.90), rgba(255,160,170,.70))}

.overview-stats{display:grid;grid-template-columns:1fr;gap:10px;margin-top:12px}
@media (min-width: 520px){.overview-stats{grid-template-columns:1fr 1fr}}
.overview-stat{
  border:1px solid rgba(255,255,255,.08);
  background:rgba(0,0,0,.18);
  border-radius:14px;
  padding:12px;
  display:grid;
  grid-template-columns:1fr auto;
  grid-template-rows:auto auto;
}
.overview-stat-label{font-weight:700}
.overview-stat-code{color:var(--muted);font-size:12px;letter-spacing:.10em;text-transform:uppercase}
.overview-stat-val{grid-row:1 / span 2;grid-column:2;font-size:22px;font-weight:800;align-self:center;font-variant-numeric:tabular-nums}

.overview-todo{margin:10px 0 0 18px;display:grid;gap:6px}

/* Tabs for Character page */
.overview-tabs{display:flex;flex-wrap:wrap;gap:8px}
.btn.btn-tab{padding:8px 10px;font-size:13px;line-height:1.2;background:rgba(0,0,0,.18);border:1px solid rgba(255,255,255,.10)}
.btn.btn-tab.is-active{background:rgba(136,192,208,.12);border-color:rgba(136,192,208,.35)}
.btn.btn-tab:disabled{opacity:.55;cursor:not-allowed}

/* Hub lists */
.hub-list{display:grid;gap:10px;margin-top:12px}
.hub-row{display:grid;grid-template-columns:40px 1fr auto;gap:10px;align-items:center;padding:10px;border:1px solid rgba(255,255,255,.08);border-radius:14px;background:rgba(0,0,0,.16)}
.hub-portrait{width:40px;height:40px;border-radius:12px;object-fit:cover;border:1px solid rgba(255,255,255,.10);background:rgba(0,0,0,.25)}
.hub-name{font-weight:800}
.hub-right{text-align:right;font-variant-numeric:tabular-nums;white-space:nowrap}
@media (max-width: 560px){.hub-row{grid-template-columns:40px 1fr}.hub-right{grid-column:1 / -1;text-align:left;padding-left:50px}}

.hub-news{display:grid;gap:12px;margin-top:12px}
.hub-news-item{padding:10px;border:1px solid rgba(255,255,255,.08);border-radius:14px;background:rgba(0,0,0,.16)}
.hub-news-head{display:flex;align-items:baseline;justify-content:space-between;gap:12px}
.hub-news-title{font-weight:800}

/* Hub pulse + modules */
.hub-stack{display:grid;gap:16px}

.hub-pulse{display:grid;gap:12px;margin-top:10px}
@media (min-width: 920px){.hub-pulse{grid-template-columns:1fr 1fr 1fr}}

.hub-pulse-card{padding:12px;border:1px solid rgba(255,255,255,.08);border-radius:14px;background:rgba(0,0,0,.16)}
.hub-queue{display:grid;gap:8px;margin-top:10px}
.hub-queue-row{display:flex;align-items:center;justify-content:space-between;gap:10px}

.hub-metrics{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;margin:10px 0}
.hub-metric{padding:10px;border:1px solid rgba(255,255,255,.06);border-radius:14px;background:rgba(0,0,0,.12)}
.hub-metric-num{font-size:22px;font-weight:900;font-variant-numeric:tabular-nums}
@media (max-width: 560px){.hub-metrics{grid-template-columns:1fr;}}

.hub-todos{margin:10px 0 0 18px;display:grid;gap:6px}

.hub-guild{display:grid;gap:10px;margin-top:12px}
.hub-guild-row{padding:10px;border:1px solid rgba(255,255,255,.08);border-radius:14px;background:rgba(0,0,0,.16)}
.hub-guild-title{font-weight:800}

.hub-deaths{display:grid;gap:10px;margin-top:12px}
.hub-death-row{padding:10px;border:1px solid rgba(255,255,255,.08);border-radius:14px;background:rgba(0,0,0,.16)}
.hub-death-name{font-weight:800}

.hub-prog{display:grid;grid-template-columns:1fr;gap:12px;margin-top:12px}
@media (min-width: 920px){.hub-prog{grid-template-columns:1fr 1fr}}
.hub-subhead{font-weight:800;margin-bottom:8px}
.hub-rank{margin:0;padding-left:18px;display:grid;gap:8px}
.hub-rank li{display:flex;align-items:center;justify-content:space-between;gap:10px}

/* =========================
   Character page: profile + belt modal
   ========================= */
.charpage{display:block}
.overview-top-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}
.overview-top-actions{display:flex;gap:8px;flex-wrap:wrap}
.overview-top-body{display:flex;gap:14px;align-items:flex-start}
.overview-top-meta{flex:1;min-width:0}
.overview-pools{display:grid;gap:10px;margin-top:12px}
@media (min-width: 700px){.overview-pools{gap:12px}}
.pool{display:block}

.overview-bio{margin-top:14px}
.overview-bio-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:8px}
.bio-view p{margin:0}
.bio-form textarea{min-height:120px}
.bio-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}

.is-hidden{display:none !important}

.charpage .pill{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;border:1px solid rgba(255,255,255,.10);background:rgba(0,0,0,.20);font-size:12px}
.charpage .pill-ok{border-color:rgba(163,190,140,.35);background:rgba(163,190,140,.10)}

.scroll-y{max-height:180px;overflow:auto}
.no-scroll{overflow:hidden}

/* Stat delta colors */
.delta-pos{color:rgba(163,190,140,.95);font-weight:700}
.delta-neg{color:rgba(211,93,110,.95);font-weight:700}

/* Modal */
.modal-root{
  position:fixed;
  inset:0;
  display:none;
  z-index:1000;
  overflow-x:hidden;
  overflow-y:auto;
  overscroll-behavior:contain;
  -webkit-overflow-scrolling:touch;
}
.modal-root.is-open{display:block}
.modal-overlay{position:absolute;inset:0;background:rgba(0,0,0,.62);backdrop-filter:blur(3px)}
.modal{
  position:relative;
  width:min(980px, calc(100% - 22px));
  max-height:calc(min(100dvh, 100vh) - 22px);
  margin:11px auto;
  border:1px solid rgba(255,255,255,.12);
  background:linear-gradient(180deg, rgba(26,29,34,.96), rgba(16,18,22,.96));
  border-radius:16px;
  box-shadow:0 22px 60px rgba(0,0,0,.55);
  overflow:hidden;
  display:flex;
  flex-direction:column;
}
.modal-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;border-bottom:1px solid rgba(255,255,255,.08);flex:0 0 auto}
.modal-body{
  padding:14px;
  flex:1 1 auto;
  min-height:0;
  overflow-x:hidden;
  overflow-y:auto;
  max-height:none;
  overscroll-behavior:contain;
  -webkit-overflow-scrolling:touch;
  touch-action:pan-y;
}
@media (max-width: 760px){
  .modal-root{padding:8px 0}
  .modal{width:min(980px, calc(100% - 16px));max-height:calc(min(100dvh, 100vh) - 16px);margin:8px auto}
  .modal-header{padding:12px}
  .modal-body{padding:12px}
}

/* Shop: buy confirm */
.shop-buy-grid{display:grid;grid-template-columns:56px 1fr;gap:12px;align-items:center}
.shop-buy-img{width:56px;height:56px;border-radius:14px;object-fit:cover;border:1px solid rgba(255,255,255,.10);background:rgba(0,0,0,.22)}
.shop-buy-name{font-weight:900;font-size:16px;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.qty-stepper{display:grid;grid-template-columns:auto 92px auto;gap:8px;align-items:center;max-width:260px}
.qty-stepper input{width:100%;text-align:center;padding:8px 10px;border-radius:12px;border:1px solid rgba(255,255,255,.10);background:rgba(0,0,0,.18);color:rgba(236,239,244,.95)}
.checkbox-row{display:flex;align-items:center;gap:10px;user-select:none}
.checkbox-row input{width:16px;height:16px}

/* Belt slots + consumables */
.belt-slots{display:grid;gap:10px;margin-top:10px}
@media (min-width: 520px){.belt-slots{grid-template-columns:1fr 1fr}}
.belt-slot{padding:10px;border:1px solid rgba(255,255,255,.08);border-radius:14px;background:rgba(0,0,0,.16)}
.belt-slot.is-active{border-color:rgba(136,192,208,.45);box-shadow:0 0 0 1px rgba(136,192,208,.18) inset}
.belt-slot.is-locked{opacity:.55;cursor:not-allowed;position:relative}
.belt-slot.is-locked::after{content:'LOCKED';position:absolute;top:10px;right:12px;font-size:10px;letter-spacing:.08em;color:rgba(255,255,255,.65)}
.belt-slot.is-locked a,.belt-slot.is-locked button{pointer-events:none}
.belt-slot-top{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:6px}
.belt-slot-name{font-weight:900}

.consumable-list{display:grid;gap:8px;margin-top:10px}
.consumable-row{
  width:100%;
  text-align:left;
  display:grid;
  grid-template-columns:44px 1fr auto;
  gap:10px;
  align-items:center;
  padding:10px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(0,0,0,.16);
  cursor:pointer;
}
.consumable-row:hover{background:rgba(0,0,0,.22)}
.consumable-icon{width:44px;height:44px;border-radius:12px;object-fit:cover;border:1px solid rgba(255,255,255,.10);background:rgba(0,0,0,.22)}
.consumable-name{font-weight:900}
.consumable-right{font-variant-numeric:tabular-nums}

/* Active buffs (character page timers) */
.buff-icon{width:34px;height:34px;border-radius:12px;object-fit:cover;border:1px solid rgba(255,255,255,.10);background:rgba(0,0,0,.22)}
.buff-lines{display:grid;gap:2px;line-height:1.25}
.buff-remaining{font-variant-numeric:tabular-nums;white-space:nowrap}

/* =========================
   Tables: responsive helper
   ========================= */
.table-responsive,
.table-scroll{
  overflow-x:auto;
  overflow-y:hidden;
  border:1px solid rgba(255,255,255,.08);
  border-radius:14px;
  background:rgba(0,0,0,.14);
  -webkit-overflow-scrolling:touch;
}
.table-responsive .table{min-width:0}
.table-responsive table,
.table-scroll table{
  width:100%;
  border-collapse:collapse;
}
.table-responsive.is-wide table,
.table-scroll.is-wide table{min-width:760px}
.table-responsive th,
.table-responsive td,
.table-scroll th,
.table-scroll td{white-space:nowrap}
.table-responsive td:first-child,
.table-scroll td:first-child{white-space:normal}
.library-items-table{min-width:0;table-layout:fixed}
.library-items-table th,
.library-items-table td{vertical-align:middle}
.library-items-table th:nth-child(1),
.library-items-table td:nth-child(1){width:42%}
.library-items-table th:nth-child(2),
.library-items-table td:nth-child(2){width:auto}
.library-items-table th:nth-child(3),
.library-items-table td:nth-child(3){width:76px}
.library-items-table th:nth-child(4),
.library-items-table td:nth-child(4){width:96px}
.library-items-table .lib-item-cell{min-width:0;max-width:none}
.library-items-table .library-item-info-cell{white-space:normal;color:var(--muted);font-size:.92em;line-height:1.35;overflow-wrap:anywhere}
.library-items-table [data-item-sources]{white-space:nowrap}
@media (max-width: 700px){
  .library-items-table th:nth-child(1),
  .library-items-table td:nth-child(1){width:46%}
  .library-items-table th:nth-child(2),
  .library-items-table td:nth-child(2){width:34%}
  .library-items-table th:nth-child(3),
  .library-items-table td:nth-child(3){width:54px}
  .library-items-table th:nth-child(4),
  .library-items-table td:nth-child(4){width:82px}
  .library-items-table .btn-xs{padding-left:8px;padding-right:8px}
}

/* =========================
   Equipment tab layout
   ========================= */
.equip-layout{display:grid;grid-template-columns:1fr;gap:12px}
@media (min-width: 720px){.equip-layout{grid-template-columns:1fr 1fr;gap:14px}}
@media (min-width: 1100px){.equip-layout{grid-template-columns:1fr 1fr 1fr;gap:14px}}
.equip-col{display:grid;gap:12px;align-content:start;min-width:0}
.equip-duo{display:grid;grid-template-columns:1fr 1fr;gap:12px;min-width:0}

.equip-slot{border:1px solid rgba(255,255,255,.10);background:rgba(0,0,0,.16);border-radius:16px;padding:10px;min-width:0}
.equip-slot.is-disabled{opacity:.75}
.equip-slot-title{display:flex;align-items:center;justify-content:space-between;gap:10px;font-weight:900}
.equip-slot-inner{display:grid;grid-template-columns:64px 1fr;gap:10px;align-items:center;margin-top:10px;min-width:0}
.equip-slot--tall .equip-slot-inner{grid-template-columns:1fr}
.equip-slot--compact .equip-slot-inner{grid-template-columns:1fr}

.equip-slot-preview img{width:64px;height:64px;object-fit:cover;border-radius:14px;background:rgba(0,0,0,.25);border:1px solid rgba(255,255,255,.10)}
.equip-slot--tall .equip-slot-preview img{width:100%;height:170px}
@media (min-width: 1100px){.equip-slot--tall .equip-slot-preview img{height:210px}}
.equip-slot--compact .equip-slot-preview img{width:100%;height:84px}

.equip-slot-controls{min-width:0}
.equip-slot-controls select{width:100%;max-width:100%;margin:0;padding-right:34px}
/* Ensure long names stay readable */
.equip-slot-controls select, .equip-slot-controls option{font-size:13px;line-height:1.2}

/* Prevent odd squeezing at mid widths */
@media (max-width: 980px){
  .equip-duo{grid-template-columns:1fr}
}

/* =========================
   Inventory page
   ========================= */
.inv-head{display:flex;align-items:baseline;justify-content:space-between;gap:12px;flex-wrap:wrap}
.inv-toolbar{display:flex;flex-direction:column;gap:10px;margin-top:12px}
@media (min-width: 720px){.inv-toolbar{flex-direction:row;align-items:flex-end;justify-content:space-between}}
.inv-search{max-width:560px;width:100%}
.inv-summary{white-space:nowrap}

.inv-tabs{margin-top:12px;display:flex;gap:8px;flex-wrap:nowrap;overflow-x:auto;padding-bottom:2px}
.inv-tabs::-webkit-scrollbar{height:6px}
.inv-tabs::-webkit-scrollbar-thumb{background:rgba(255,255,255,.10);border-radius:999px}

.inv-list{display:grid;gap:10px;margin-top:12px}
.inv-row{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center;padding:10px;border:1px solid rgba(255,255,255,.08);border-radius:14px;background:rgba(0,0,0,.16)}
.inv-left{display:flex;align-items:center;gap:10px;min-width:0}
.inv-icon{width:36px;height:36px;border-radius:12px;object-fit:cover;border:1px solid rgba(255,255,255,.10);background:rgba(0,0,0,.22);flex:0 0 auto}
.inv-namebtn{background:transparent;border:0;padding:0;margin:0;color:var(--link);font-weight:900;text-align:left;cursor:pointer;min-width:0}
.inv-namebtn:hover{text-decoration:underline}
.inv-right{display:flex;gap:8px;flex-wrap:wrap;align-items:center;justify-content:flex-end;font-variant-numeric:tabular-nums}
.inv-actions{display:flex;gap:6px;flex-wrap:wrap;align-items:center}
.inv-actions .btn{padding:6px 10px;font-size:12px;line-height:1}
.inv-actions .btn.btn-ghost{opacity:.95}
.inv-actions .btn.is-disabled{opacity:.55}

.inv-empty{padding:12px;border:1px dashed rgba(255,255,255,.18);border-radius:14px;color:var(--muted);background:rgba(0,0,0,.12)}


/* =========================
   Lobbies (Patch 80)
   ========================= */
#lobbiesList{gap:12px}
#lobbyTeam1,#lobbyTeam2{gap:8px}
#lobbyChatList{gap:8px;overflow-x:hidden}
#lobbiesList .lobby-right{flex-direction:column;align-items:flex-end;gap:4px}
#lobbiesList .lobby-right .btn{margin-top:0}

/* Lobby room rows (team slots + chat): make left column compact and allow message wrapping */
.lobby-room-row{grid-template-columns:auto 1fr}
.lobby-room-row .inv-left{min-width:110px}
.lobby-room-row .inv-right{justify-content:flex-start;min-width:0}
.lobby-room-row .lobby-chat-msg{
  /* Long unbroken strings (e.g. spammy input) must wrap instead of forcing a horizontal scrollbar */
  min-width:0;
  max-width:100%;
  flex:1 1 auto;
  white-space:pre-wrap;
  overflow-wrap:anywhere;
  word-break:break-word;
}

.lobby-actionsbar{display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.lobby-ready{margin-left:auto;display:flex;align-items:center;gap:8px}

@media (max-width: 640px){
  #lobbiesList .lobby-right{align-items:flex-start}
  #lobbiesList .lobby-right .btn{width:100%;justify-content:center}
  .lobby-ready{margin-left:0;width:100%;justify-content:flex-start}
  .lobby-actionsbar .btn{flex:1 1 calc(50% - 8px)}
  .lobby-actionsbar .btn.lobby-leave,.lobby-actionsbar .btn.lobby-disband{flex:1 1 100%}
}

@media (max-width: 420px){
  .lobby-actionsbar .btn{flex:1 1 100%}
}

/* =========================
   Shops (Patch 4)
   ========================= */
.shops-alert{margin-top:10px}
.shops-block{margin-top:12px}
.shops-pre{white-space:pre-line}
.page-banner-wrap{
  margin-top:12px;
  position:relative;
  width:100%;
  /*
    Banners are authored in 4:1 (1920x480). Keep the container 4:1.
    Avoid max-height clamps on desktop (they break the ratio and create a "zoom" feel).
  */
  aspect-ratio:4 / 1;
  overflow:hidden;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(0,0,0,.22);
}

/* Render banners as backgrounds for consistent fill + future text overlays */
.page-banner{
  width:100%;
  height:100%;
  display:block;
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
}

/* Subtle readability layer (text can sit above later) */
.page-banner-wrap::after{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:linear-gradient(90deg, rgba(0,0,0,.38), rgba(0,0,0,.16) 40%, rgba(0,0,0,.08));
}

@media (max-width: 720px){
  /* On small screens we allow a softer cap to keep above-the-fold clean */
  .page-banner-wrap{max-height:140px;border-radius:12px}
}

.shop-row{color:inherit;text-decoration:none}
.shop-row:hover{text-decoration:none;border-color:rgba(136,192,208,.35);background:rgba(0,0,0,.22)}
.shop-main{min-width:0}
.shop-top{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.shop-name{font-weight:900;color:var(--txt)}
.shop-desc{font-size:13px;margin-top:2px}
.shop-meta{font-size:12px;margin-top:4px;display:flex;gap:8px;flex-wrap:wrap}
.shop-dot{opacity:.7}
.shop-link{font-size:12px;white-space:nowrap}

.badge-open,.badge-closed{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;border-radius:999px;border:1px solid rgba(255,255,255,.10);font-size:12px;line-height:1.2}
.badge-open{border-color:rgba(163,190,140,.45);background:rgba(163,190,140,.10);color:#eaffdf}
.badge-closed{border-color:rgba(235,203,139,.45);background:rgba(235,203,139,.10);color:#fff0cf}

/* =========================
   Generic tabs (Patch 11)
   ========================= */
.tabs-bar{margin-top:12px;display:flex;gap:8px;flex-wrap:nowrap;overflow-x:auto;padding-bottom:2px}
.tabs-bar::-webkit-scrollbar{height:6px}
.tabs-bar::-webkit-scrollbar-thumb{background:rgba(255,255,255,.10);border-radius:999px}

.tabs-btn{
  flex:0 0 auto;
  padding:8px 10px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(0,0,0,.16);
  color:var(--txt);
  cursor:pointer;
  font:inherit;
  line-height:1;
}
.tabs-btn:hover{background:rgba(255,255,255,.05);border-color:rgba(255,255,255,.14)}
.tabs-btn:focus{outline:none;box-shadow:0 0 0 3px rgba(136,192,208,.12);border-color:rgba(136,192,208,.45)}
.tabs-btn.is-active{border-color:rgba(136,192,208,.55);background:rgba(136,192,208,.12)}

.tabs-panel{display:none;margin-top:12px}
.tabs-panel.is-active{display:block}

/* =========================
   Adventurers Guild (Patch 11)
   ========================= */
.guild-intro{margin-top:12px}
.guild-kv{display:grid;gap:12px;margin-top:12px}
@media (min-width: 860px){.guild-kv{grid-template-columns:1fr 1fr}}

.guild-box{border:1px solid rgba(255,255,255,.08);border-radius:14px;background:rgba(0,0,0,.14)}
.guild-box-title{padding:10px 12px;border-bottom:1px solid rgba(255,255,255,.06);font-size:12px;letter-spacing:.10em;text-transform:uppercase;color:var(--muted)}
.guild-box-body{padding:12px;display:grid;gap:10px}
.guild-box-text{margin:0}

.guild-meter{display:grid;gap:8px}
.guild-meter-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:8px 10px;border:1px solid rgba(255,255,255,.08);border-radius:12px;background:rgba(0,0,0,.14)}

.guild-controls{display:flex;gap:10px;flex-wrap:wrap;align-items:flex-end;margin-top:12px}
.guild-controls-right{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.guild-actions{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-top:10px}
.dir-name{cursor:default}

.table-sort{background:transparent;border:0;padding:0;margin:0;color:var(--txt);font:inherit;font-weight:800;cursor:pointer}
.table-sort:hover{text-decoration:underline}
.table-sort::after{content:"";display:inline-block;width:10px;margin-left:6px;opacity:.65}
.table-sort[data-dir="asc"]::after{content:"▲";font-size:10px}
.table-sort[data-dir="desc"]::after{content:"▼";font-size:10px}

/* Match statistics tables should fit cards without forcing horizontal scroll. */
.matchstats-table{min-width:0}

/* Match statistics: show ~10 rows before scrolling. */
.matchstats-scroll{max-height:min(420px, 52vh);overflow:auto}

.adv-namebtn{background:transparent;border:0;padding:0;margin:0;color:var(--link);font-weight:900;text-align:left;cursor:pointer}
.adv-namebtn:hover{text-decoration:underline}

/* Adventurers roster table */
.guild-roster-wrap{margin-top:12px}
.guild-roster-wrap .table{min-width:620px}
.guild-roster-table{width:100%}
.guild-roster-table th,.guild-roster-table td{padding:12px 12px;vertical-align:middle}
.guild-roster-table thead th{text-align:center}
.guild-roster-table tbody td:nth-child(n+2){text-align:center}
.guild-roster-table tbody td:first-child{text-align:left}
.guild-roster-table thead th{border-bottom:1px solid rgba(255,255,255,.10);background:rgba(0,0,0,.10)}
.guild-roster-table td{border-bottom:1px solid rgba(255,255,255,.08)}
.guild-roster-table tbody tr:hover{background:rgba(0,0,0,.20)}
.guild-roster-table td:nth-child(4){font-variant-numeric:tabular-nums}
.guild-roster-table td:last-child{white-space:nowrap}
.guild-roster-table .table-sort{display:inline-flex;align-items:center;justify-content:center;gap:6px;width:100%;color:var(--muted);font-weight:800;letter-spacing:.08em;text-transform:uppercase}
.guild-roster-table .table-sort:hover{color:var(--txt);text-decoration:none}
.guild-roster-table .adv-namebtn{color:var(--txt);font-size:14px;font-weight:900}
.guild-roster-table .adv-namebtn:hover{color:var(--link);text-decoration:none}

.guild-dir-wrap{margin-top:12px}
.guild-dir-wrap .table{min-width:620px}
.guild-dir-table{width:100%}
.guild-dir-table th,.guild-dir-table td{padding:12px 12px;vertical-align:middle}
.guild-dir-table thead th{text-align:center}
.guild-dir-table tbody td:nth-child(n+2){text-align:center}
.guild-dir-table tbody td:first-child{text-align:left}
.guild-dir-table thead th{border-bottom:1px solid rgba(255,255,255,.10);background:rgba(0,0,0,.10)}
.guild-dir-table td{border-bottom:1px solid rgba(255,255,255,.08)}
.guild-dir-table tbody tr:hover{background:rgba(0,0,0,.20)}
.guild-dir-table td:nth-child(2),.guild-dir-table td:nth-child(3){font-variant-numeric:tabular-nums}
.guild-dir-table td:last-child{white-space:nowrap}
.guild-dir-table .table-sort{display:inline-flex;align-items:center;justify-content:center;gap:6px;width:100%;color:var(--muted);font-weight:800;letter-spacing:.08em;text-transform:uppercase}
.guild-dir-table .table-sort:hover{color:var(--txt);text-decoration:none}
.guild-dir-table .adv-namebtn{color:var(--txt);font-size:14px;font-weight:900}
.guild-dir-table .adv-namebtn:hover{color:var(--link);text-decoration:none}

.public-profile{display:grid;gap:12px}
.public-profile-top{display:grid;grid-template-columns:120px 1fr;gap:14px;align-items:start}
@media (max-width: 560px){.public-profile-top{grid-template-columns:1fr}}
.public-profile-img{width:120px;height:120px;object-fit:cover;border-radius:16px;border:1px solid rgba(255,255,255,.10);background:rgba(0,0,0,.22)}
@media (max-width: 560px){.public-profile-img{width:100%;height:180px}}
.public-profile-meta{min-width:0}
.public-profile-bio{
  margin:8px 0 0 0;
  white-space:pre-wrap;
  max-height:120px;
  overflow:auto;
  padding-right:6px;
  overflow-wrap:anywhere;
}
.public-profile-bio::-webkit-scrollbar{width:8px}
.public-profile-bio::-webkit-scrollbar-thumb{background:rgba(255,255,255,.10);border-radius:999px}
.public-profile-bio--art{
  font-family:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  font-size:13px;
  line-height:1.2;
}

.public-profile-badges{display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.public-profile-badges .pill{display:inline-flex;align-items:center;gap:6px}
.public-profile-tiers{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:8px;margin-top:10px}
.public-profile-tier{display:flex;justify-content:space-between;gap:10px;align-items:center;padding:8px 10px;border:1px solid rgba(255,255,255,.08);border-radius:12px;background:rgba(0,0,0,.14)}
.public-profile-tier span{color:var(--muted);font-size:12px;letter-spacing:.06em;text-transform:uppercase}
.public-profile-tier strong{font-weight:900}
.pp-stats{display:grid;gap:10px}
.pp-stats-grid{display:grid;gap:10px;grid-template-columns:1fr}
@media (min-width: 880px){.pp-stats-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}

.pp-stats-card{display:flex;flex-direction:column;min-width:0;min-height:0;max-height:min(420px, 60vh)}
.pp-stats-card .table-wrap{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden}
.pp-stats-card .table{min-width:0 !important;table-layout:fixed;width:100%}
.pp-stats-card .table th,.pp-stats-card .table td{white-space:nowrap}
.pp-stats-card .table th:first-child,.pp-stats-card .table td:first-child{white-space:normal;overflow-wrap:anywhere}
.pp-stats-card .table th.is-right,.pp-stats-card .table td.is-right{width:110px}
.pp-equip-item{display:flex;align-items:center;gap:10px;min-width:0}
.pp-equip-icon{width:28px;height:28px;border-radius:10px;object-fit:cover;border:1px solid rgba(255,255,255,.10);background:rgba(0,0,0,.20);flex:0 0 auto}
.pp-equip-icon.is-empty{opacity:.35}
.pp-equip-item .linkbtn{color:var(--txt);font-weight:900;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
.pp-equip-item .linkbtn:hover{color:var(--link)}

@media (max-width: 560px){
  .inv-row{grid-template-columns:1fr}
  .inv-right{justify-content:flex-start;padding-left:46px}
}

/* =========================
   Inventory: item inspect modal
   ========================= */
.inv-modal-grid{display:grid;grid-template-columns:1fr;gap:14px;align-items:start}
@media (min-width: 760px){.inv-modal-grid{grid-template-columns:240px 1fr}}
.inv-modal-media{min-width:0}
.inv-modal-img{width:100%;height:auto;max-height:240px;object-fit:cover;border-radius:14px;border:1px solid rgba(255,255,255,.10);background:rgba(0,0,0,.22)}
.inv-modal-title{font-size:18px;font-weight:900}
.inv-modal-tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:10px}
.inv-modal-block{margin-top:8px}
.inv-modal-h{margin:0 0 6px 0;font-size:12px;letter-spacing:.10em;text-transform:uppercase;color:var(--muted)}
.inv-modal-desc{margin:0;white-space:pre-line}
.inv-modal-split{display:grid;grid-template-columns:1fr;gap:14px}
@media (min-width: 760px){.inv-modal-split{grid-template-columns:1fr 1fr}}
.inv-modal-list{margin:0;padding-left:18px;display:grid;gap:6px}

/* Bank (Phase 0.14) */
.bank-head{display:flex;flex-direction:column;gap:10px}
.bank-toolbar{display:flex;flex-direction:column;gap:10px;margin-top:12px}
@media (min-width: 720px){.bank-toolbar{flex-direction:row;align-items:flex-end;justify-content:space-between}}
.bank-search{max-width:560px;width:100%}
.bank-tabs{margin-top:12px;display:flex;gap:8px;flex-wrap:nowrap;overflow-x:auto;padding-bottom:2px}
.bank-tabs::-webkit-scrollbar{height:6px}
.bank-tabs::-webkit-scrollbar-thumb{background:rgba(255,255,255,.10);border-radius:999px}
.bank-panel{margin-top:12px}
.bank-wallet{border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:10px;background:rgba(0,0,0,.14)}
.bank-wallet-row{display:flex;flex-direction:column;gap:12px}
@media (min-width: 840px){.bank-wallet-row{flex-direction:row;justify-content:space-between;align-items:flex-end}}
.bank-h{font-size:12px;letter-spacing:.10em;text-transform:uppercase;color:var(--muted);margin-bottom:6px}
.bank-money{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.bank-currency{display:flex;gap:10px;flex-wrap:wrap;align-items:flex-end}
.bank-currency .field{min-width:120px}
.bank-list{display:grid;gap:10px;margin-top:12px}
.bank-row{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center;padding:10px;border:1px solid rgba(255,255,255,.08);border-radius:14px;background:rgba(0,0,0,.16)}
.bank-left{display:flex;align-items:center;gap:10px;min-width:0}
.bank-icon{width:36px;height:36px;border-radius:12px;object-fit:cover;border:1px solid rgba(255,255,255,.10);background:rgba(0,0,0,.22);flex:0 0 auto}
.bank-namebtn{background:transparent;border:0;padding:0;margin:0;color:var(--link);font-weight:900;text-align:left;cursor:pointer;min-width:0}
.bank-namebtn:hover{text-decoration:underline}
.bank-right{display:flex;gap:8px;flex-wrap:wrap;align-items:center;justify-content:flex-end;font-variant-numeric:tabular-nums}
.bank-actions{display:flex;gap:6px;flex-wrap:wrap;align-items:center}
.bank-actions .btn{padding:6px 10px;font-size:12px;line-height:1}
.bank-empty{padding:12px;border:1px dashed rgba(255,255,255,.18);border-radius:14px;color:var(--muted);background:rgba(0,0,0,.12)}
@media (max-width: 520px){
  .bank-row{grid-template-columns:1fr}
  .bank-right{justify-content:flex-start;padding-left:46px}
}

/* Admin (Phase 0.15) */
.admin-search-results{margin-top:10px;display:grid;gap:10px}
.admin-item-row{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center;padding:10px;border:1px solid rgba(255,255,255,.08);border-radius:14px;background:rgba(0,0,0,.16)}
.admin-item-left{min-width:0}
.admin-item-title{font-weight:900;line-height:1.15;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.admin-item-actions{display:flex;gap:6px;flex-wrap:wrap;align-items:center;justify-content:flex-end}
.admin-item-actions .btn{padding:6px 10px;font-size:12px;line-height:1}
@media (max-width: 520px){
  .admin-item-row{grid-template-columns:1fr}
  .admin-item-actions{justify-content:flex-start}
}

/* Admin (Phase 0.16) */
.admin-tabs,.admin-subtabs{display:flex;gap:8px;flex-wrap:nowrap;overflow-x:auto;padding-bottom:2px}
.admin-tabs::-webkit-scrollbar,.admin-subtabs::-webkit-scrollbar{height:6px}
.admin-tabs::-webkit-scrollbar-thumb,.admin-subtabs::-webkit-scrollbar-thumb{background:rgba(255,255,255,.10);border-radius:999px}
.admin-subtabs{margin-top:10px}
.admin-pager{display:flex;gap:8px;align-items:center;flex-wrap:wrap}

/* Dynamic form rows (items create/edit) */
.admin-dyn-row{display:grid;grid-template-columns:1fr 160px auto;gap:10px;align-items:end;margin-bottom:10px}
.admin-dyn-row .btn{padding:6px 10px;font-size:12px;line-height:1}
.admin-dyn-remove{width:34px;min-width:34px;justify-content:center;padding:6px 0}

/* Effects rows: wrap instead of overflowing the center column */
.admin-dyn-row.admin-dyn-row-effects{
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 10px;
  align-items: end;
}
.admin-dyn-row-effects > *{ min-width: 0; }
.admin-dyn-row-effects .admin-dyn-remove{ justify-self: end; }
@media (max-width: 900px){
  .admin-dyn-row.admin-dyn-row-effects{grid-template-columns:repeat(2, minmax(0, 1fr));}
}

/* Consumable effects rows */
.admin-dyn-row.admin-dyn-row-cfx{
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 10px;
  align-items: end;
}
.admin-dyn-row-cfx > *{ min-width: 0; }
.admin-dyn-row-cfx .admin-dyn-remove{ justify-self: end; }
@media (max-width: 900px){
  .admin-dyn-row.admin-dyn-row-cfx{grid-template-columns:repeat(2, minmax(0, 1fr));}
}

.admin-fx-presetbar{
  margin-top: 10px;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 10px;
  align-items: end;
}
.admin-fx-presetbar > *{ min-width: 0; }
.admin-fx-presetbar .field{margin:0;}
@media (max-width:1100px){
  .admin-fx-presetbar{ grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)) !important; }
}
@media (max-width:700px){
  .admin-fx-presetbar{ grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)) !important; }
  .admin-dyn-row{grid-template-columns:1fr 1fr;}
  .admin-dyn-remove{width:100%;min-width:0}
}

/* If the consumable effects card is hidden, let proc effects span full width */
@media (min-width: 920px){
  .admin-fx-grid.single{grid-template-columns:1fr !important;}
}

/* Match result spoiler + loot box */
.spoiler{margin-top:8px}
.spoiler > summary{
  list-style:none;
  cursor:pointer;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:10px;
  padding:8px 10px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(0,0,0,.18);
}
.spoiler > summary::-webkit-details-marker{display:none}
.spoiler[open] > summary{
  border-color:rgba(136,192,208,.55);
  background:rgba(0,0,0,.24);
}
.spoiler-content{margin-top:10px}

.loot-list{margin:6px 0 0 0; padding-left:18px; display:grid; gap:6px}
@media (max-width: 920px){.loot-grid{grid-template-columns:1fr!important}}


/* Match history table tweaks */
.match-history-table td{vertical-align:top}
.match-history-table th.mh-center,.match-history-table td.mh-center{text-align:center}
.match-history-table td.mh-participants{text-align:left}

/* Generic center helper (used across multiple tables/pages) */
.mt-center{text-align:center}


/* Monsters list (portrait-first, centered numeric columns) */
.monsters-table td{vertical-align:middle}
.monsters-table th.mt-center,.monsters-table td.mt-center{text-align:center}
.monster-portrait{
  width:48px;
  height:48px;
  display:block;
  border-radius:12px;
  object-fit:cover;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(0,0,0,.18);
  margin:0 auto;
}
.monster-name{font-weight:700; letter-spacing:.02em}
.monster-namebtn{font-weight:800; letter-spacing:.02em}
.monster-namebtn:hover{color:var(--link); text-decoration:none}
@media (max-width: 600px){
  .monster-portrait{width:42px;height:42px;border-radius:10px}
}


/* Dungeons */
.dungeons-table td{vertical-align:middle}
.dungeons-table th,.dungeons-table td{text-align:center}

.library-encounter-list{overflow-x:auto;max-width:100%;-webkit-overflow-scrolling:touch}
.library-encounter-table tbody tr td{transition:background .16s ease,border-color .16s ease}
.library-encounter-table tbody tr + tr td{border-top:1px solid rgba(255,255,255,.12)}
.library-encounter-table tbody tr:hover td{background:rgba(255,255,255,.03)}
.library-encounter-table tbody td{padding-top:12px;padding-bottom:12px}
.library-encounter-table tbody td:first-child{padding-left:14px}
.library-encounter-table tbody td:last-child{padding-right:14px}

.dungeon-waves-table th,.dungeon-waves-table td{text-align:center}


/* Library live tabs: stable search shells + fit-safe vertical list/detail panels */
.library-vertical-panel{
  display:grid;
  grid-template-columns:minmax(0,1fr);
  gap:12px;
  margin-top:8px;
  align-items:start;
  max-width:100%;
}
.library-results-region,
.library-results-grid,
.library-results-list,
.library-detail-below{
  min-width:0;
  max-width:100%;
}
.library-results-list{overflow-x:auto;-webkit-overflow-scrolling:touch}
.library-list-card,.library-detail-card{min-width:0;max-width:100%;overflow:hidden}
.library-panel-head,.library-detail-head{
  display:flex;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
  align-items:flex-end;
}
.library-panel-title,.library-detail-title{min-width:0}
.library-panel-controls{display:flex;gap:6px;flex-wrap:wrap;align-items:center;min-width:0}
.library-panel-controls .input{min-width:180px;max-width:100%}
.library-entity-list{width:100%;table-layout:auto;min-width:0}
.library-entity-list th,.library-entity-list td{vertical-align:middle}
.library-entity-name-cell{min-width:12rem;max-width:26rem;text-align:left!important}
.library-entity-name,.library-row-title{
  display:block;
  font-weight:800;
  line-height:1.22;
  min-width:0;
  max-width:100%;
  white-space:normal;
  overflow-wrap:break-word;
  word-break:normal;
  hyphens:auto;
}
.library-entity-meta{display:none;margin-top:3px;line-height:1.2;overflow-wrap:break-word;word-break:normal}
.library-entity-actions .btn{white-space:nowrap}
.library-pager{margin-top:10px;min-width:0;max-width:100%}
.library-pager-inner{display:flex;gap:6px;align-items:center;flex-wrap:wrap;min-width:0;max-width:100%}
.library-pager-status{padding:0 4px;white-space:nowrap}
.library-card-row td{min-width:0}
.library-filter-notice{margin-bottom:8px;padding:6px 8px;border:1px solid rgba(136,192,208,.22);border-radius:10px;background:rgba(136,192,208,.07)}
.library-entity-row.is-selected td,
.library-encounter-row.is-selected td,
.library-monster-row.is-selected td{
  background:rgba(136,192,208,.10);
  border-color:rgba(136,192,208,.32);
}
.library-entity-row.is-selected .library-entity-name{color:#eaf7ff}
.library-detail-scroll{min-width:0;max-width:100%;overflow:hidden}
.library-detail-inner{min-width:0;max-width:100%}
.library-detail-desc{margin-top:6px;white-space:normal;overflow-wrap:break-word;word-break:normal}
.library-detail-meta{margin-top:10px;display:grid;gap:4px;min-width:0}
.library-detail-section{margin-top:14px;min-width:0;max-width:100%}
.library-floor-block{margin-top:14px;min-width:0;max-width:100%}
.library-detail-table-wrap,.library-waves-table-wrap{overflow-x:auto;max-width:100%;-webkit-overflow-scrolling:touch}
.library-monster-detail-inner{display:grid;gap:0;min-width:0;max-width:100%}
.library-monster-detail-media{margin-top:10px;min-width:0;max-width:100%}
.library-monster-detail-img{display:block;max-width:100%;max-height:280px;border-radius:12px;object-fit:cover;border:1px solid rgba(255,255,255,.10);background:rgba(0,0,0,.22)}
.library-monster-equipment,.library-monster-drops{border-top:1px solid rgba(255,255,255,.08);padding-top:12px}
.library-monster-detail-table-wrap{overflow-x:auto;max-width:100%;-webkit-overflow-scrolling:touch}
.library-monster-detail-table{width:100%;min-width:520px;table-layout:auto;border-collapse:collapse}
.library-monster-detail-table th,.library-monster-detail-table td{padding:9px 10px;vertical-align:middle;border-top:1px solid rgba(255,255,255,.08)}
.library-monster-detail-table thead th{font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);background:rgba(0,0,0,.12)}
.library-detail-item-mini{display:flex;gap:10px;align-items:center;min-width:0;max-width:100%}
.library-detail-item-iconbtn{padding:0!important;line-height:0;flex:0 0 auto}
.library-detail-item-icon{width:34px;height:34px;border-radius:11px;object-fit:cover;border:1px solid rgba(255,255,255,.10);background:rgba(0,0,0,.22)}
.library-detail-item-text{min-width:0;max-width:100%}
.library-detail-item-name{display:block;max-width:100%;padding:0!important;font-weight:900;color:var(--txt);text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.library-detail-item-name:hover{color:var(--link);text-decoration:none}
.library-detail-item-meta{line-height:1.18;white-space:normal;overflow-wrap:anywhere}
.library-monster-detail-slot,.library-monster-detail-req,.library-monster-detail-dropped,.library-monster-detail-last{white-space:nowrap}
@media (max-width: 640px){
  .library-monster-detail-table{min-width:0}
  .library-monster-detail-table thead{display:none}
  .library-monster-detail-table,.library-monster-detail-table tbody,.library-monster-detail-table tr,.library-monster-detail-table td{display:block;width:100%}
  .library-monster-detail-table tr{padding:9px 0;border-top:1px solid rgba(255,255,255,.08)}
  .library-monster-detail-table td{border:0;padding:3px 0!important;text-align:left!important;white-space:normal}
  .library-monster-detail-slot::before{content:"Slot: ";color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.08em}
  .library-monster-detail-req::before{content:"Req: ";color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.08em}
  .library-monster-detail-dropped::before{content:"Recorded: ";color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.08em}
  .library-monster-detail-last::before{content:"Last drop: ";color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.08em}
}
.library-waves-table{min-width:560px;max-width:none;table-layout:fixed}
.library-waves-table th,.library-waves-table td{white-space:nowrap}
.library-waves-table th:nth-child(2),.library-waves-table td:nth-child(2){width:auto;white-space:normal}
.library-enemy-cell{white-space:normal!important;overflow-wrap:break-word;word-break:normal;min-width:220px;max-width:100%}
@media (max-width: 980px){
  .library-vertical-panel{grid-template-columns:1fr}
  .library-panel-controls{width:100%}
  .library-panel-controls .input{flex:1 1 220px}
}

@media (max-width: 760px){
  .library-encounter-table thead{display:none}
  .library-encounter-table,
  .library-encounter-table tbody,
  .library-encounter-table tr,
  .library-encounter-table td{display:block;width:100%}
  .library-encounter-table tr.library-entity-row{
    padding:10px 12px;
    border-bottom:1px solid rgba(255,255,255,.10);
  }
  .library-encounter-table tr.library-entity-row:last-child{border-bottom:0}
  .library-encounter-table tr.library-entity-row td{
    border:0;
    padding:3px 0!important;
    text-align:left!important;
    white-space:normal;
  }
  .library-entity-name-cell{min-width:0;max-width:none}
  .library-entity-meta{display:block}
  .library-entity-rec,.library-entity-floors,.library-entity-last,.library-entity-level,.library-entity-seen{display:none!important}
  .library-entity-actions{margin-top:8px}
}

@media (max-width: 640px){
  .library-panel-head,.library-detail-head{align-items:flex-start}
  .library-panel-controls .input{flex-basis:100%;width:100%;max-width:none!important}
  .library-waves-table{min-width:560px}
}

.dungeon-inspect-head{
  display:flex;
  gap:12px;
  align-items:flex-start;
}
.dungeon-inspect-text{flex:1; min-width:0}
.dungeon-portrait{
  width:72px;
  height:72px;
  display:block;
  border-radius:16px;
  object-fit:cover;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(0,0,0,.18);
}
@media (max-width: 600px){
  .dungeon-portrait{width:56px;height:56px;border-radius:14px}
}


/* Active Context HUD widget */
.hud-active-context{
  display:flex;
  align-items:center;
  justify-content:center;
  padding:7px 10px;
  border:1px solid rgba(255,255,255,.10);
  border-radius:14px;
  background:rgba(0,0,0,.18);
  box-shadow:0 8px 24px rgba(0,0,0,.22);
  min-width:190px;
}
.hud-active-context.is-hidden{display:none}
.hud-active-context-link{
  display:flex;
  flex-direction:column;
  gap:6px;
  text-decoration:none;
  color:var(--txt);
  min-width:0;
}
.hud-active-context-link.is-disabled{cursor:default;opacity:.90}
.hud-active-context .ac-name{
  font-size:11px;
  letter-spacing:.10em;
  text-transform:uppercase;
  color:var(--muted);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  max-width:260px;
}
.hud-active-context .ac-line{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.hud-active-context .ac-status{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:2px 8px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.06);
  font-size:11px;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--txt);
}
.hud-active-context[data-status="not_ready"] .ac-status{
  border-color:rgba(255,120,120,.35);
  background:rgba(255,120,120,.10);
}
.hud-active-context[data-status="starting"] .ac-status{
  border-color:rgba(136,192,208,.40);
  background:rgba(136,192,208,.10);
}
.hud-active-context .ac-extra{
  font-size:10px;
  letter-spacing:.10em;
  text-transform:uppercase;
  color:var(--muted);
}
.hud-active-context.is-afk-warning{
  border-color:rgba(235,203,139,.72);
  background:linear-gradient(180deg, rgba(96,64,24,.24), rgba(52,28,12,.22));
  box-shadow:0 0 0 1px rgba(235,203,139,.18), 0 10px 28px rgba(0,0,0,.28), 0 0 24px rgba(235,203,139,.16);
}
.hud-active-context.is-afk-warning .ac-name,
.hud-active-context.is-afk-warning .ac-extra{
  color:#ffe7ae;
}
.hud-active-context.is-afk-warning .ac-status{
  border-color:rgba(255,184,77,.72);
  background:rgba(255,184,77,.18);
  color:#fff3d7;
  box-shadow:0 0 16px rgba(255,184,77,.14);
}

.idle-warning-overlay{
  position:fixed;
  inset:0;
  z-index:10020;
  display:none;
  align-items:center;
  justify-content:center;
  pointer-events:none;
  padding:24px;
  background:radial-gradient(circle at center, rgba(255,196,76,.14), rgba(8,12,20,.44) 58%, rgba(4,6,12,.72) 100%);
  backdrop-filter:blur(3px);
}
.idle-warning-overlay.is-visible{display:flex;}
.idle-warning-card{
  width:min(820px, calc(100vw - 32px));
  pointer-events:none;
  text-align:center;
  padding:32px 32px 28px;
  border-radius:24px;
  border:2px solid rgba(255,194,88,.72);
  background:linear-gradient(180deg, rgba(74,48,8,.96), rgba(38,22,4,.96));
  box-shadow:0 24px 60px rgba(0,0,0,.45), 0 0 42px rgba(255,194,88,.18), inset 0 1px 0 rgba(255,255,255,.08);
}
.idle-warning-eyebrow{
  color:#ffe3a1;
  font-size:13px;
  letter-spacing:.22em;
  text-transform:uppercase;
  margin-bottom:8px;
}
.idle-warning-title{
  color:#fff7db;
  font-size:clamp(34px, 5.6vw, 56px);
  font-weight:900;
  letter-spacing:.04em;
  line-height:1;
}
.idle-warning-countdown{
  margin-top:14px;
  color:#ffd86e;
  font-weight:900;
  font-size:clamp(52px, 10vw, 96px);
  line-height:1;
  text-shadow:0 0 28px rgba(255,194,88,.22);
}
.idle-warning-copy{
  margin-top:12px;
  color:#fff0bf;
  font-size:clamp(14px, 2.3vw, 19px);
  letter-spacing:.08em;
  text-transform:uppercase;
}

body.is-idle-warning-active .hud-active-context{
  box-shadow:0 0 0 1px rgba(255,194,88,.22), 0 12px 30px rgba(0,0,0,.34), 0 0 20px rgba(255,194,88,.10);
}

/* HOTFIX-23: horizontal nav scroll + drag affordance + discreet back-to-top. */
[data-horizontal-nav]{
  scrollbar-width:thin;
  scrollbar-color:rgba(136,192,208,.45) rgba(255,255,255,.06);
  -webkit-overflow-scrolling:touch;
}
[data-horizontal-nav].is-overflowing{cursor:grab}
[data-horizontal-nav].is-dragging{cursor:grabbing;user-select:none;scroll-behavior:auto}
[data-horizontal-nav].is-dragging a,
[data-horizontal-nav].is-dragging button{pointer-events:none}
[data-horizontal-nav]:focus-within{scrollbar-color:rgba(136,192,208,.70) rgba(255,255,255,.08)}
[data-horizontal-nav]::-webkit-scrollbar{display:block;height:8px;width:8px}
[data-horizontal-nav]::-webkit-scrollbar-track{background:rgba(255,255,255,.05);border-radius:999px}
[data-horizontal-nav]::-webkit-scrollbar-thumb{background:rgba(136,192,208,.35);border-radius:999px}
[data-horizontal-nav]::-webkit-scrollbar-thumb:hover{background:rgba(136,192,208,.55)}

.topnav[data-horizontal-nav]{
  overflow-x:auto;
  overflow-y:hidden;
  flex-wrap:nowrap;
  max-width:100%;
  padding-bottom:2px;
  overscroll-behavior-x:contain;
  touch-action:pan-x;
}
.topnav[data-horizontal-nav] a,
.topnav[data-horizontal-nav] form,
.topnav[data-horizontal-nav] .btn{flex:0 0 auto;white-space:nowrap}

@media (max-width: 900px){
  .world-nav[data-horizontal-nav]{
    scrollbar-width:thin;
    cursor:grab;
    mask-image:linear-gradient(90deg, transparent 0, #000 18px, #000 calc(100% - 18px), transparent 100%);
  }
  .world-nav[data-horizontal-nav] a:focus-visible{
    outline:2px solid rgba(136,192,208,.85);
    outline-offset:2px;
  }
}

.back-to-top-wrap{
  display:flex;
  justify-content:flex-end;
  margin:22px 0 0;
  padding-top:10px;
}
.back-to-top{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:6px;
  min-height:34px;
  padding:7px 11px;
  border:1px solid rgba(136,192,208,.28);
  border-radius:999px;
  color:var(--muted);
  background:rgba(0,0,0,.18);
  box-shadow:0 8px 22px rgba(0,0,0,.18);
  font-size:12px;
  letter-spacing:.02em;
}
.back-to-top:hover,
.back-to-top:focus-visible{
  color:var(--txt);
  text-decoration:none;
  border-color:rgba(136,192,208,.55);
  background:rgba(136,192,208,.09);
}
@media (max-width: 640px){
  .back-to-top-wrap{justify-content:center;margin-top:18px}
  .back-to-top{width:100%;max-width:260px}
}

/* HOTFIX-24: Goblin Bouncer warning/cooldown page polish. */
.goblin-bouncer-card{
  max-width:920px;
  margin:0 auto;
  overflow:hidden;
}
.goblin-bouncer-layout{
  display:grid;
  grid-template-columns:minmax(150px, 220px) minmax(0, 1fr);
  gap:22px;
  align-items:start;
}
.goblin-bouncer-portrait{
  min-height:220px;
  border:1px solid rgba(136,192,208,.20);
  border-radius:20px;
  background:linear-gradient(180deg, rgba(136,192,208,.08), rgba(0,0,0,.20));
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.06), 0 18px 40px rgba(0,0,0,.25);
}
.goblin-bouncer-portrait img{
  width:100%;
  height:100%;
  min-height:220px;
  object-fit:cover;
  display:block;
}
.goblin-bouncer-portrait-fallback{
  width:86px;
  height:86px;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  border:1px solid rgba(231,183,95,.42);
  color:#ffe4a7;
  background:radial-gradient(circle at 35% 25%, rgba(231,183,95,.22), rgba(0,0,0,.24));
  font-weight:900;
  letter-spacing:.08em;
  font-size:26px;
}
.goblin-bouncer-eyebrow{
  text-transform:uppercase;
  letter-spacing:.18em;
}
.goblin-bouncer-title{
  margin:6px 0 0;
  font-size:clamp(30px, 4vw, 48px);
  line-height:1;
}
.goblin-bouncer-alert{margin-top:14px}
.goblin-bouncer-reason{
  display:flex;
  flex-wrap:wrap;
  gap:8px 10px;
  align-items:center;
  margin-top:14px;
  padding:10px 12px;
  border:1px solid rgba(255,255,255,.08);
  border-radius:14px;
  background:rgba(0,0,0,.14);
}
.goblin-bouncer-reason .muted{
  text-transform:uppercase;
  letter-spacing:.12em;
  font-size:11px;
}
.goblin-bouncer-status{
  margin-top:16px;
  background:rgba(255,255,255,0.03);
  border-color:rgba(255,255,255,.10);
}
.goblin-bouncer-status-top{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  align-items:center;
  justify-content:space-between;
}
.goblin-bouncer-status-badge{
  display:inline-flex;
  align-items:center;
  min-height:28px;
  padding:5px 10px;
  border-radius:999px;
  font-weight:800;
  letter-spacing:.02em;
  border:1px solid currentColor;
  background:rgba(255,255,255,.04);
}
.goblin-bouncer-warning-count{
  font-size:22px;
  line-height:1;
}
.goblin-bouncer-status.is-green{
  border-color:rgba(89,208,127,.42);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.05), 0 0 28px rgba(89,208,127,.05);
}
.goblin-bouncer-status.is-green .goblin-bouncer-status-badge,
.goblin-bouncer-status.is-green .goblin-bouncer-warning-count{color:#b9ffc9}
.goblin-bouncer-status.is-yellow{
  border-color:rgba(231,183,95,.52);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.05), 0 0 28px rgba(231,183,95,.06);
}
.goblin-bouncer-status.is-yellow .goblin-bouncer-status-badge,
.goblin-bouncer-status.is-yellow .goblin-bouncer-warning-count{color:#ffe4a7}
.goblin-bouncer-status.is-red{
  border-color:rgba(211,93,110,.62);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.05), 0 0 32px rgba(211,93,110,.08);
}
.goblin-bouncer-status.is-red .goblin-bouncer-status-badge,
.goblin-bouncer-status.is-red .goblin-bouncer-warning-count{color:#ffc1ca}
@media (max-width:720px){
  .goblin-bouncer-layout{grid-template-columns:1fr}
  .goblin-bouncer-portrait{min-height:150px}
  .goblin-bouncer-portrait img{min-height:150px}
}

/* HOTFIX-36: Library item category/adaptive filter fitment */
.library-filter-grid [data-it-type]{min-width:150px}
.library-advanced-grid [data-advanced-filter]{min-width:0}
.library-items-table .lib-item-cell button[data-item-inspect]{max-width:100%}
.library-items-table .library-item-info-cell span{display:block;min-width:0;overflow-wrap:anywhere}
@media (max-width:760px){
  .library-filter-grid [data-it-type]{min-width:0;width:100%}
  .library-advanced-grid{grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}
  .library-items-table th:nth-child(4),
  .library-items-table td:nth-child(4){width:76px}
}

/* HOTFIX-37: Guild quest objective labels */
.quest-objective-pill{
  display:inline-flex;
  align-items:center;
  max-width:100%;
  min-height:24px;
  padding:3px 9px;
  border-radius:999px;
  border:1px solid rgba(231,183,95,.36);
  background:linear-gradient(180deg,rgba(231,183,95,.14),rgba(0,0,0,.12));
  color:#ffe1a1;
  font-weight:800;
  font-size:12px;
  letter-spacing:.02em;
  white-space:normal;
  overflow-wrap:anywhere;
}
.quest-objective-hint{margin-top:4px;max-width:260px;line-height:1.25}
@media (max-width:720px){
  .quest-objective-hint{max-width:none}
}

/* HOTFIX-38: Tactics modal alignment cleanup */
.tactics-modal,
.tactics-modal *{box-sizing:border-box}
.tactics-modal .tactics-modal__dialog{width:min(1040px, calc(100% - 22px))}
.tactics-modal__title-block{min-width:0}
.tactics-modal__body{display:grid;gap:12px;overflow-x:hidden}
.tactics-modal__mode-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
  align-items:stretch;
  min-width:0;
}
.tactics-modal__mode-card{
  display:grid;
  gap:12px;
  align-content:start;
  min-width:0;
  overflow:visible;
  background:linear-gradient(180deg, rgba(255,255,255,.052), rgba(0,0,0,.16));
}
.tactics-modal__mode-title{margin:0;color:#d7e2f3;line-height:1.2}
.tactics-modal__control-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
  align-items:start;
  min-width:0;
}
.tactics-modal__field{
  display:grid;
  grid-template-rows:auto minmax(42px,auto);
  gap:6px;
  min-width:0;
}
.tactics-modal__field--with-help{grid-template-rows:auto minmax(42px,auto) minmax(28px,auto)}
.tactics-modal__field label{
  min-height:16px;
  display:flex;
  align-items:end;
  font-size:13px;
  line-height:1.2;
  color:var(--muted);
}
.tactics-modal__field select,
.tactics-modal__field input,
.tactics-modal__field .nselect-wrap,
.tactics-modal__field .nselect-btn{
  width:100%;
  min-width:0;
  max-width:100%;
}
.tactics-modal__field select,
.tactics-modal__field input,
.tactics-modal__field .nselect-btn{
  min-height:42px;
  height:42px;
  padding-top:9px;
  padding-bottom:9px;
  line-height:1.25;
}
.tactics-modal__field input[type="number"]{appearance:textfield}
.tactics-modal__field input[type="number"]::-webkit-outer-spin-button,
.tactics-modal__field input[type="number"]::-webkit-inner-spin-button{margin:0}
.tactics-modal__field .nselect-wrap{position:relative;align-self:start}
.tactics-modal__field .nselect-menu{
  top:calc(100% + 6px);
  left:0;
  right:0;
  min-width:100%;
  z-index:1200;
}
.tactics-modal__help{
  min-height:28px;
  line-height:1.15;
}
.tactics-modal__help small,
.tactics-modal__footer-help small{line-height:1.25}
.tactics-modal__footer-card{margin-top:0;display:grid;gap:8px;min-width:0}
.tactics-modal__actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  align-items:center;
  min-width:0;
}
.tactics-modal__status{display:inline-flex;align-items:center;min-height:32px;min-width:80px}
.tactics-modal__footer-help{line-height:1.25}
@media (max-width: 860px){
  .tactics-modal__mode-grid{grid-template-columns:1fr}
}
@media (max-width: 560px){
  .tactics-modal .tactics-modal__dialog{width:min(980px, calc(100% - 16px))}
  .tactics-modal__control-grid{grid-template-columns:1fr}
  .tactics-modal__field,
  .tactics-modal__field--with-help{grid-template-rows:auto minmax(42px,auto) auto}
  .tactics-modal__help{min-height:0}
  .tactics-modal__actions{align-items:stretch}
  .tactics-modal__actions .btn{flex:1 1 160px;justify-content:center}
  .tactics-modal__status{flex:1 1 100%;min-height:22px}
}

/* HOTFIX-40: shared combat option controls + percent HP bars */
.combat-options,
.combat-options *{box-sizing:border-box}
.combat-options{display:grid;gap:12px;min-width:0;overflow:visible}
.combat-options__grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
  align-items:start;
  min-width:0;
}
.combat-options__field{
  display:grid;
  gap:6px;
  align-content:start;
  min-width:0;
}
.combat-options__field--wide{grid-column:1 / -1}
.combat-options__field label{
  display:flex;
  align-items:end;
  gap:6px;
  min-height:17px;
  color:var(--muted);
  font-size:13px;
  line-height:1.2;
}
.combat-options__field select,
.combat-options__field input,
.combat-options__field .input,
.combat-options__field .nselect-wrap,
.combat-options__field .nselect-btn{
  width:100%;
  min-width:0;
  max-width:100%;
}
.combat-options__field select,
.combat-options__field input,
.combat-options__field .input,
.combat-options__field .nselect-btn{
  min-height:42px;
  height:42px;
  padding-top:9px;
  padding-bottom:9px;
  line-height:1.25;
}
.combat-options__field input[type="number"]{appearance:textfield}
.combat-options__field input[type="number"]::-webkit-outer-spin-button,
.combat-options__field input[type="number"]::-webkit-inner-spin-button{margin:0}
.combat-options__field .nselect-wrap{position:relative;align-self:start;overflow:visible}
.combat-options__field .nselect-menu{top:calc(100% + 6px);left:0;right:0;min-width:100%;z-index:1200}
.combat-options__percent{display:grid;grid-template-columns:minmax(96px,1fr) minmax(92px,1.1fr) minmax(42px,auto);gap:8px;align-items:center;min-width:0}
.combat-options__percent input{min-width:0;text-align:center}
.combat-options__percent-bar{height:10px;border-radius:999px;overflow:hidden;background:rgba(0,0,0,.34);border:1px solid rgba(255,255,255,.10);box-shadow:inset 0 1px 4px rgba(0,0,0,.45)}
.combat-options__percent-fill{display:block;height:100%;width:0%;border-radius:999px;background:linear-gradient(90deg, rgba(136,192,208,.42), rgba(163,190,140,.58));transition:width .14s ease-out}
.combat-options__percent-value{min-width:42px;text-align:right;color:#d7e2f3;font-size:12px;font-weight:700;font-variant-numeric:tabular-nums}
.combat-options__hint{margin:0;color:var(--muted);line-height:1.25}
.combat-options__hint--top{margin-bottom:10px}
.combat-options__hint small{line-height:1.25}
.combat-options__actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-top:2px;min-width:0}
.combat-options__actions--end{justify-content:flex-end;margin-top:14px}
.combat-options__actions .btn{min-width:0}
@media (max-width: 680px){
  .combat-options__grid{grid-template-columns:1fr}
  .combat-options__percent{grid-template-columns:minmax(82px,1fr) minmax(80px,1fr) minmax(42px,auto)}
  .combat-options__actions--end{justify-content:stretch}
  .combat-options__actions .btn{flex:1 1 150px;justify-content:center}
}
@media (max-width: 420px){
  .combat-options__percent{grid-template-columns:1fr minmax(44px,auto)}
  .combat-options__percent input{grid-column:1 / -1;text-align:left}
  .combat-options__percent-value{text-align:right}
}

/* HOTFIX-42: match lobby local tactics override panel */
.lobby-controls-card,
.lobby-controls-card *{box-sizing:border-box}
.lobby-controls-card{overflow:visible;min-width:0}
.lobby-controls-card__head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;flex-wrap:wrap;min-width:0}
.lobby-tactics-panel{margin-top:12px;padding:12px;border:1px solid rgba(255,255,255,.08);border-radius:12px;background:rgba(0,0,0,.16);overflow:visible;min-width:0}
.lobby-tactics-panel__head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;flex-wrap:wrap;min-width:0;margin-bottom:10px}
.lobby-tactics-panel__head h3{margin:0 0 4px}
.lobby-tactics-status{min-height:18px;text-align:right;font-size:12px;line-height:1.35;flex:0 1 220px}
.lobby-ready-panel{margin-top:12px;display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;padding:10px 12px;border:1px solid rgba(163,190,140,.18);border-radius:12px;background:rgba(163,190,140,.07);min-width:0}
.lobby-ready-panel__toggle{display:inline-flex;align-items:center;gap:10px;margin:0;font-weight:800;color:#e8f0dc;letter-spacing:.01em}
.lobby-ready-panel__toggle input{width:auto;min-width:18px;height:18px;margin:0;accent-color:#a3be8c}
.lobby-controls-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center;min-width:0}
.lobby-controls-actions .btn{min-width:0}
@media (max-width:680px){
  .lobby-tactics-panel__head{display:grid;gap:8px}
  .lobby-tactics-status{text-align:left;flex:auto}
  .lobby-ready-panel{align-items:flex-start}
  .lobby-controls-actions .btn{flex:1 1 140px;justify-content:center}
}

/* HOTFIX-43/44: Random queue local PVP tactics override panel */
.queue-join-card,
.queue-join-card *{box-sizing:border-box}
.queue-join-card{overflow:visible;min-width:0}
.queue-join-card__head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;flex-wrap:wrap;min-width:0;margin-bottom:12px}
.queue-options-panel{margin-top:12px;padding:12px;border:1px solid rgba(255,255,255,.08);border-radius:12px;background:rgba(0,0,0,.16);overflow:visible;min-width:0}
.queue-options-grid{display:grid;gap:12px;min-width:0;overflow:visible}
.queue-options-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;align-items:start;min-width:0;overflow:visible}
.queue-options-row--hp{align-items:stretch}
.queue-options-row--hp .combat-options__field{height:100%}
.queue-options-row--hp .combat-options__percent{align-items:center}
.queue-options-actions{display:grid;grid-template-columns:minmax(220px,1fr) minmax(180px,auto);gap:12px;align-items:end;min-width:0;overflow:visible;padding-top:4px;border-top:1px solid rgba(255,255,255,.06)}
.queue-options-actions__narrative{min-width:0}
.queue-options-actions__submit{display:flex;align-items:flex-end;justify-content:flex-end;gap:10px;flex-wrap:wrap;min-width:0}
.queue-options-actions__submit .btn{min-width:150px;justify-content:center}
.queue-options-status{min-height:18px;font-size:12px;line-height:1.35;text-align:right;flex:1 1 170px}
.queue-options-status[data-locked="1"]{color:#e4c787}
.queue-options-panel input.is-locked{opacity:.78;border-color:rgba(235,203,139,.30);background:rgba(235,203,139,.08);cursor:not-allowed}
@media (max-width:680px){
  .queue-join-card__head{display:grid;gap:8px}
  .queue-options-row,
  .queue-options-actions{grid-template-columns:1fr}
  .queue-options-actions__submit{justify-content:stretch}
  .queue-options-actions__submit .btn{flex:1 1 160px}
  .queue-options-status{text-align:left}
}

/* HOTFIX-45: Library Items pagination/page-size controls */
.library-items-summary-row{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  flex-wrap:wrap;
  margin-top:10px;
}
.library-items-pager{
  display:flex;
  gap:8px;
  align-items:center;
  flex-wrap:wrap;
}
.library-items-page-size{min-width:96px}
.library-items-page-size select{min-width:86px}
.library-items-pagination-bottom{
  justify-content:flex-end;
  margin-top:10px;
}
@media (max-width:760px){
  .library-items-summary-row{align-items:flex-start;flex-direction:column}
  .library-items-pager,.library-items-pagination-bottom{justify-content:flex-start;width:100%}
  .library-items-page-size{min-width:0;width:100%}
  .library-items-page-size select{width:100%;min-width:0}
}
