/* Ecosystem overrides on top of monsters-legacy.css */

.mon-page { max-width: 1300px; margin: 0 auto; }

.mon-head {
  display: flex; align-items: flex-end; justify-content: space-between;
  gap: 1.5rem; flex-wrap: wrap;
  padding-bottom: 1.1rem; border-bottom: 1px solid var(--border);
  margin-bottom: 1.5rem;
}
.mon-head-kicker {
  display: inline-flex; align-items: center; gap: .5rem;
  padding: .25rem .7rem; border-radius: 999px;
  border: 1px solid rgba(214,178,87,.3); background: rgba(214,178,87,.08);
  color: var(--gold); font-size: .7rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: .1em; margin-bottom: .5rem;
}
.mon-head-title h1 {
  margin: 0 0 .4rem; font-size: clamp(1.7rem, 3vw, 2.4rem); line-height: 1.1;
  font-family: var(--display); letter-spacing: .02em;
  background: linear-gradient(135deg, #ffffff 10%, #f0d97a 55%, #d6b257 95%);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
.mon-head-sub { margin: 0; color: var(--muted); font-size: .9rem; line-height: 1.55; max-width: 760px; }

/* Container */
#monsters_card { color: var(--text); }

/* Filter row layout (Bootstrap grid classes aren't loaded) */
#monsters_card .row { display: flex; flex-wrap: wrap; gap: .75rem; margin: 0 0 1rem; }
#monsters_card .row > [class*="col-"] { flex: 1 1 180px; padding: 0; }
#monsters_card .row > .col-lg-1 { flex: 0 0 120px; }
#monsters_card .row > .col-lg-2 { flex: 0 0 180px; }
#monsters_card .row > .col-lg-3 { flex: 1 1 220px; }
#monsters_card .row > .col-lg-4 { flex: 2 1 260px; min-width: 220px; }
#monsters_card .align-items-end { align-items: flex-end; }
#monsters_card .justify-content-end { justify-content: flex-end; }
#monsters_card .mt-3 { margin-top: 1rem; }
#monsters_card .mt-2 { margin-top: .5rem; }
#monsters_card .mb-1 { margin-bottom: .25rem !important; }
#monsters_card .fw-bold { font-weight: 700; color: var(--muted); text-transform: uppercase; letter-spacing: .08em; font-size: .72rem; }

/* Labels + inputs */
#monsters_card .form-label {
  font-size: .68rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: .08em; color: var(--muted);
  margin: 0 0 .25rem;
  display: block;
}
#monsters_card .form-control,
#monsters_card .form-select {
  width: 100%;
  padding: .45rem .7rem;
  background: rgba(8,8,14,.5);
  border: 1px solid var(--border);
  border-radius: 8px;
  color: var(--text);
  font-family: inherit;
  font-size: .85rem;
}
#monsters_card .form-control:focus,
#monsters_card .form-select:focus { border-color: var(--gold); outline: none; }
#monsters_card .form-control-sm,
#monsters_card .form-select-sm { padding: .4rem .65rem; font-size: .82rem; }

/* Buttons */
#monsters_card .btn {
  display: inline-flex; align-items: center; gap: .35rem;
  padding: .45rem .8rem;
  border-radius: 8px;
  font: inherit;
  font-size: .8rem; font-weight: 700;
  background: transparent;
  border: 1px solid var(--border);
  color: var(--muted);
  cursor: pointer;
  transition: all .15s ease;
  white-space: nowrap;
}
#monsters_card .btn:hover:not(:disabled) { color: var(--text); border-color: var(--violet); background: rgba(139,112,255,.1); }
#monsters_card .btn:disabled { opacity: .45; cursor: not-allowed; }
#monsters_card .btn-outline-secondary,
#monsters_card .btn-outline-warning { color: var(--muted); border-color: var(--border); }
#monsters_card .btn-outline-warning:hover:not(:disabled) { color: var(--gold-hi); border-color: var(--gold); background: rgba(214,178,87,.08); }
#monsters_card .w-100 { width: 100%; justify-content: center; }
#monsters_card .btn-group { display: inline-flex; gap: .35rem; }

/* Type tile picker — round icons, labels below, single row (15 tiles incl. All) */
#monsters_card .monsters_picker-grid {
  display: flex;
  flex-wrap: nowrap;
  justify-content: center;
  gap: .4rem;
  overflow-x: auto;
  padding-bottom: .25rem;
}
#monsters_card .monsters_pick {
  flex: 0 0 auto;
  width: auto !important;
  display: inline-flex !important;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  gap: .3rem;
  padding: .3rem .25rem !important;
  border: 1px solid transparent !important;
  border-radius: 10px !important;
  background: transparent !important;
  color: var(--muted) !important;
  transition: color .15s ease, background .15s ease, border-color .15s ease, transform .15s ease;
}
#monsters_card .monsters_pick:hover { color: var(--text) !important; background: rgba(139,112,255,.08) !important; }
#monsters_card .monsters_pick.is-selected {
  border-color: rgba(214,178,87,.45) !important;
  background: rgba(214,178,87,.08) !important;
  color: var(--gold-hi) !important;
}
#monsters_card .monsters_pick.opacity-50 { opacity: .55; }

#monsters_card .monsters_pick-imgwrap {
  position: relative;
  width: 44px;
  height: 44px;
  display: block;
  border-radius: 50%;
  border: 1px solid var(--border);
  background: rgba(255,255,255,.04);
  overflow: hidden;
}
#monsters_card .monsters_pick.is-selected .monsters_pick-imgwrap {
  border-color: var(--gold);
  box-shadow: 0 0 0 2px rgba(214,178,87,.25);
}
#monsters_card .monsters_pick-img {
  width: 100%;
  height: 100%;
  border: none !important;
  border-radius: 50% !important;
  background: transparent !important;
  padding: 0 !important;
  object-fit: cover;
  display: block;
}
#monsters_card .monsters_pick-check {
  position: absolute;
  top: -4px; right: -4px;
  font-size: .75rem;
  color: var(--gold-hi);
  background: var(--panel);
  border-radius: 50%;
  padding: 1px;
}

#monsters_card .monsterIconLabel {
  font-size: .68rem;
  font-weight: 600;
  color: inherit;
  margin-top: 0;
  line-height: 1;
  white-space: nowrap;
  letter-spacing: .02em;
}

/* Multiselect (size / habitat) */
#monsters_card .monsters_ms { position: relative; }
#monsters_card .monsters_ms_btn {
  width: 100%;
  text-align: left;
  padding: .45rem .7rem;
  background: rgba(8,8,14,.5);
  border: 1px solid var(--border);
  border-radius: 8px;
  color: var(--text);
  font: inherit;
  font-size: .82rem;
  cursor: pointer;
}
#monsters_card .monsters_ms_btn:hover { border-color: var(--violet); }
#monsters_card .monsters_ms_panel {
  display: none;
  position: absolute;
  top: calc(100% + 4px); left: 0;
  min-width: 100%;
  background: linear-gradient(180deg, var(--panel-top), var(--panel));
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: .5rem;
  z-index: 60;
  box-shadow: 0 14px 40px rgba(0,0,0,.55);
  max-height: 260px;
  overflow: auto;
}
#monsters_card .monsters_ms.is-open .monsters_ms_panel { display: block; }
#monsters_card .monsters_ms_item { padding: .2rem .25rem; font-size: .85rem; color: var(--muted); }
#monsters_card .monsters_ms_item label { display: flex; align-items: center; gap: .45rem; cursor: pointer; }
#monsters_card .monsters_ms_item input { accent-color: var(--violet); }
#monsters_card .monsters_ms_item[aria-selected="true"] { color: var(--text); }

/* Table */
#monsters_card .table-responsive { overflow-x: auto; border-radius: 12px; border: 1px solid var(--border-soft); }
#monsters_card table { width: 100%; border-collapse: collapse; font-size: .88rem; color: var(--text); }
#monsters_card table th {
  background: rgba(139,112,255,.08);
  color: var(--muted);
  font-size: .7rem; text-transform: uppercase; letter-spacing: .08em;
  padding: .55rem .75rem;
  text-align: left;
  border-bottom: 1px solid var(--border);
  cursor: pointer;
  user-select: none;
}
#monsters_card table th:hover { color: var(--text); }
#monsters_card table td {
  padding: .5rem .75rem;
  border-bottom: 1px solid var(--border-soft);
}
#monsters_card table tbody tr { transition: background .15s ease; cursor: pointer; }
#monsters_card table tbody tr:hover { background: rgba(139,112,255,.05); }
#monsters_card .monsters_sort-ind { font-size: .7rem; color: var(--faint); margin-left: .2rem; }

/* Pagination */
#monsters_card #monsters_pagerInfo { color: var(--muted); font-size: .82rem; }
#monsters_card #monsters_pageSize { width: 90px; }

/* Overlay (close-up statblock) — legacy uses outer flex panel + inner "card".
   Strip the outer panel's chrome so only the inner renders as a card. */
#monsters_overlay.monsters_overlay-panel {
  position: fixed;
  inset: 0;
  z-index: 200;
  display: flex;
  justify-content: center;
  align-items: flex-start;
  overflow-y: auto;
  padding: 4rem 1rem 2rem;
  background: rgba(4,4,10,.78) !important;
  backdrop-filter: blur(6px);
  color: var(--text);
  border: none !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}
#monsters_overlay .monsters_overlay-inner {
  width: 100%;
  max-width: 1100px;
  margin: 0 auto;
  background: linear-gradient(180deg, var(--panel-top), var(--panel)) !important;
  border: 1px solid var(--border) !important;
  border-radius: 14px !important;
  box-shadow: 0 24px 80px rgba(0,0,0,.6) !important;
  padding: 1rem 1.25rem 1.25rem !important;
  color: var(--text) !important;
}
#monsters_overlay h2 { font-family: var(--display); color: var(--gold-hi); margin: 0 0 .3rem; }
#monsters_overlay .monsters_stat-meta { color: var(--muted); border-color: var(--border-soft); }
#monsters_overlay .monsters_section-title {
  color: var(--gold); font-family: var(--display);
  border-bottom: 1px solid var(--border-soft);
  margin-top: .75rem; margin-bottom: .4rem;
  padding-bottom: .2rem;
}
#monsters_overlay .monsters_prop { color: var(--text); }
#monsters_overlay .monsters_prop strong { color: var(--gold); }
#monsters_overlay .monsters_statBlockTable {
  width: 100%; border-collapse: collapse; margin-right: 1rem;
  background: rgba(8,8,14,.3);
  border: 1px solid var(--border-soft);
  border-radius: 8px;
  overflow: hidden;
  margin-bottom: .75rem;
}
#monsters_overlay .monsters_statBlockTable th,
#monsters_overlay .monsters_statBlockTable td {
  padding: .35rem .55rem;
  text-align: center;
  border-bottom: 1px solid rgba(255,255,255,.04);
}
#monsters_overlay .monsters_statBlockTable th {
  background: rgba(139,112,255,.08);
  color: var(--muted);
  font-size: .65rem; text-transform: uppercase; letter-spacing: .08em;
}
#monsters_overlay .monsters_abilityScore-grid { display: flex; gap: .75rem; flex-wrap: wrap; margin-bottom: .75rem; }
#monsters_overlay .monsters_statBlockContainer { flex: 1 1 280px; }
#monsters_overlay .monsters_topRow { display: flex; gap: 1rem; align-items: flex-start; margin-bottom: .75rem; }
#monsters_overlay .monsters_topProps { flex: 1 1 auto; }
#monsters_overlay .monsters_portraitWrap { flex: 0 0 auto; max-width: 220px; }
#monsters_overlay .monsters_image { max-width: 220px; border-radius: 8px; border: 1px solid var(--border-soft); }
#monsters_overlay .monsters_columnLayout { display: block; }
#monsters_overlay .monsters_rollBtn {
  background: rgba(139,112,255,.1);
  border: 1px solid rgba(139,112,255,.4);
  color: #b29cff;
  border-radius: 6px;
  padding: .15rem .5rem;
  font-size: .72rem;
  cursor: pointer;
  margin-left: .35rem;
}
#monsters_overlay .monsters_rollBtn:hover { background: rgba(139,112,255,.22); color: #fff; }
#monsters_overlay .monsters_sensesList { list-style: none; padding: 0; margin: 0; display: flex; flex-wrap: wrap; gap: .5rem; }
#monsters_overlay .monsters_sensesList li {
  padding: .15rem .55rem;
  border-radius: 999px;
  background: rgba(255,255,255,.04);
  border: 1px solid var(--border-soft);
  font-size: .82rem;
  color: var(--muted);
}

/* Show/hide helpers */
#monsters_card .d-none,
#monsters_overlay .d-none { display: none !important; }
#monsters_card .d-flex { display: flex; }
#monsters_card .flex-wrap { flex-wrap: wrap; }
#monsters_card .gap-2 { gap: .5rem; }
#monsters_card .gap-3 { gap: 1rem; }
#monsters_card .text-muted { color: var(--muted); }
#monsters_card .small { font-size: .82rem; color: var(--muted); }
#monsters_card .w-10 { width: 80px; }
#monsters_card .ms-1 { margin-left: .2rem; }
#monsters_card .ms-2 { margin-left: .5rem; }
#monsters_card .me-2 { margin-right: .5rem; }
#monsters_card .mb-2 { margin-bottom: .5rem; }

body.monsters-ovr-open { overflow: hidden; }

/* ── Specificity-bump overrides for legacy brown theme ── */
#monsters_card #monsters_tbl thead th {
  background: rgba(139,112,255,.08) !important;
  color: var(--muted) !important;
  border-color: var(--border) !important;
}
#monsters_card #monsters_tbl tbody td { border-color: var(--border-soft) !important; }

#monsters_overlay .monsters_stat-meta,
#monsters_overlay .monsters_hr-bar { border-color: var(--border-soft) !important; }
#monsters_overlay .js-name,
#monsters_overlay .monsters_prop strong { color: var(--gold) !important; }
#monsters_overlay .monsters_ability {
  background: rgba(8,8,14,.4) !important;
  border: 1px solid var(--border-soft) !important;
  border-radius: 8px !important;
}

/* Kill legacy brown tint + missing-mask fetch */
#monsters_card .monsters_pick.is-selected .monsters_pick-imgwrap::after { display: none !important; }
#monsters_card .monsters_pick.is-selected .monsters_pick-img { box-shadow: none !important; }
