/* =========================================================
   CODEX STAGING API / LOGIN ADDITIONS
   Safe to load after your existing styles.css.
   ========================================================= */

.login-panel {
  max-width: 760px !important;
  margin: 0 auto !important;
}

.login-form {
  display: grid !important;
  gap: 14px !important;
  margin-top: 18px !important;
}

.login-error {
  border-color: rgba(217, 154, 165, 0.42) !important;
  background: rgba(120, 45, 48, 0.22) !important;
}

.admin-user-box {
  display: grid !important;
  gap: 6px !important;
  margin-top: 14px !important;
}

.admin-user-box strong,
.admin-user-box small {
  display: block !important;
}

.category-pill {
  border-color: rgba(244, 217, 157, 0.28) !important;
  background:
    radial-gradient(circle at 0% 0%, rgba(217, 154, 165, 0.18), transparent 36%),
    rgba(80, 52, 45, 0.40) !important;
  color: #f4d99d !important;
}

.character-resource-links {
  margin-top: 22px !important;
  padding: 16px !important;
  border-radius: 20px !important;
  border: 1.5px solid rgba(239, 202, 151, 0.24) !important;
  background:
    radial-gradient(circle at 100% 0%, rgba(217, 154, 165, 0.10), transparent 36%),
    rgba(255, 238, 220, 0.060) !important;
}

.character-resource-links .card-title {
  margin-bottom: 12px !important;
}

.resource-link-row {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 10px !important;
}

.resource-link-button {
  text-decoration: none !important;
}

.field-block {
  display: grid !important;
  gap: 8px !important;
}

.field-block.wide,
.form-actions.wide {
  grid-column: 1 / -1 !important;
}

.field-label {
  color: var(--muted) !important;
  font-size: 12px !important;
  text-transform: uppercase !important;
  letter-spacing: 0.12em !important;
}

.checkbox-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(210px, 1fr)) !important;
  gap: 8px !important;
}

.checkbox-pill {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  min-height: 42px !important;
  padding: 9px 11px !important;
  border-radius: 14px !important;
  border: 1.5px solid rgba(239, 202, 151, 0.20) !important;
  background: rgba(255, 238, 220, 0.075) !important;
  color: var(--text) !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
  font-size: 13px !important;
}

.checkbox-pill input {
  width: auto !important;
  accent-color: #d7ad69 !important;
}

.checkbox-pill span {
  line-height: 1.25 !important;
}

.users-admin .record-table {
  margin-top: 14px !important;
}

/* =========================================================
   PART 3 — MEMBER PERMISSIONS UI
   ========================================================= */

.permissions-panel {
  margin-top: 28px !important;
  padding: 18px !important;
  border-radius: 24px !important;
  border: 2px solid rgba(239, 202, 151, 0.24) !important;
  background:
    radial-gradient(circle at 100% 0%, rgba(217, 154, 165, 0.12), transparent 36%),
    rgba(255, 238, 220, 0.060) !important;
}

.permission-record-list {
  display: grid !important;
  gap: 9px !important;
  margin-top: 16px !important;
  max-height: 420px !important;
  overflow: auto !important;
  padding-right: 6px !important;
}

.permission-row {
  display: grid !important;
  grid-template-columns: auto minmax(0, 1fr) !important;
  gap: 12px !important;
  align-items: center !important;
  padding: 12px 13px !important;
  border-radius: 16px !important;
  border: 1.5px solid rgba(239, 202, 151, 0.18) !important;
  background: rgba(255, 238, 220, 0.055) !important;
  color: var(--text) !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
}

.permission-row input {
  width: auto !important;
  accent-color: #d7ad69 !important;
}

.permission-row strong,
.permission-row small {
  display: block !important;
}

.permission-row small {
  margin-top: 5px !important;
  color: var(--muted2) !important;
  line-height: 1.35 !important;
}

.permission-row:hover {
  border-color: rgba(244, 217, 157, 0.34) !important;
  background: rgba(255, 238, 220, 0.095) !important;
}

/* =========================================================
   EDITABLE WIZARDING GUIDE SECTIONS
   ========================================================= */

.magic-guide-intro-list {
  display: grid !important;
  gap: 14px !important;
  margin: 18px 0 26px !important;
}

.magic-guide-intro-list .magic-info-box {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
}

.magic-guide-intro-list .magic-info-box p {
  max-width: 980px !important;
  font-size: 17px !important;
  line-height: 1.65 !important;
}

.magic-guide-overview,
.magic-branch-text-sections {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)) !important;
  gap: 18px !important;
  margin: 26px 0 !important;
}

.magic-branch-text-sections {
  margin-top: 0 !important;
  margin-bottom: 22px !important;
}

.guide-text-section {
  padding: 22px !important;
  border: 2px solid rgba(244, 217, 157, 0.42) !important;
  border-radius: 24px !important;
  background:
    radial-gradient(circle at 100% 0%, rgba(244, 217, 157, 0.12), transparent 36%),
    radial-gradient(circle at 0% 100%, rgba(217, 154, 165, 0.10), transparent 38%),
    rgba(62, 43, 37, 0.58) !important;
  box-shadow:
    0 18px 42px rgba(34, 20, 17, 0.26),
    inset 0 1px 0 rgba(255, 244, 234, 0.10) !important;
}

.guide-text-section h3 {
  margin: 0 0 12px !important;
  color: #fff8ef !important;
  font-family: Georgia, "Times New Roman", serif !important;
  font-size: 26px !important;
  line-height: 1.15 !important;
}

.guide-section-body p {
  margin: 0 0 12px !important;
  color: var(--muted) !important;
  line-height: 1.65 !important;
}

.guide-section-body p:last-child {
  margin-bottom: 0 !important;
}

.magic-branch-section {
  margin-top: 34px !important;
  padding: 24px !important;
  border: 2.5px solid rgba(244, 217, 157, 0.46) !important;
  border-radius: 30px !important;
  background:
    linear-gradient(135deg, rgba(255, 238, 220, 0.070), rgba(80, 52, 45, 0.24)),
    radial-gradient(circle at 100% 0%, rgba(217, 154, 165, 0.13), transparent 35%) !important;
  box-shadow:
    0 24px 60px rgba(34, 20, 17, 0.30),
    inset 0 1px 0 rgba(255, 244, 234, 0.09) !important;
}

.magic-guide-box {
  padding: 18px !important;
  border: 2px solid rgba(239, 202, 151, 0.34) !important;
  border-radius: 24px !important;
  background:
    radial-gradient(circle at 0% 0%, rgba(244, 217, 157, 0.10), transparent 36%),
    rgba(255, 238, 220, 0.075) !important;
  box-shadow:
    0 14px 34px rgba(34, 20, 17, 0.22),
    inset 0 1px 0 rgba(255, 244, 234, 0.08) !important;
}


/* =========================================================
   CODEx LINKING / PROFILE / ADMIN UX PATCH
   ========================================================= */

.permalink-actions {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
  margin: 10px 0 16px !important;
}

.permalink-actions a {
  text-decoration: none !important;
}

.identity-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)) !important;
  gap: 14px !important;
  margin-top: 18px !important;
}

.identity-box {
  padding: 15px !important;
  border-radius: 18px !important;
  border: 1.5px solid rgba(239, 202, 151, 0.24) !important;
  background:
    radial-gradient(circle at 100% 0%, rgba(217, 154, 165, 0.08), transparent 34%),
    rgba(255, 238, 220, 0.060) !important;
}

.identity-box p {
  margin: 8px 0 0 !important;
  color: var(--muted) !important;
  line-height: 1.45 !important;
}

.identity-box strong {
  color: var(--text) !important;
}

.profile-avatar {
  width: 200px !important;
  height: 300px !important;
  max-width: 200px !important;
  max-height: 300px !important;
  object-fit: cover !important;
  border-radius: 22px !important;
}

.profile-layout {
  grid-template-columns: 220px minmax(0, 1fr) !important;
  align-items: start !important;
}

.collection-admin-head {
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 12px !important;
}

.user-row.is-inactive {
  opacity: 0.62 !important;
}

.user-row .actions {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
  justify-content: flex-end !important;
}

button:disabled {
  opacity: 0.45 !important;
  cursor: not-allowed !important;
}

@media (max-width: 760px) {
  .profile-layout {
    grid-template-columns: 1fr !important;
  }

  .profile-avatar {
    width: 200px !important;
    height: 300px !important;
  }
}

/* =========================================================
   FORCED PASSWORD CHANGE
   ========================================================= */
.password-change-panel .admin-user-box {
  margin-top: 18px !important;
}

.password-change-panel .form-actions {
  margin-top: 4px !important;
}

/* =========================================================
   FEATUREBATCH 5 — USER EDITING + ACCOUNT PASSWORD PANEL
   ========================================================= */

.login-success {
  border-color: rgba(173, 211, 153, 0.42) !important;
  background: rgba(64, 103, 57, 0.22) !important;
}

.user-edit-panel {
  margin-top: 26px !important;
}

.user-setting-checkbox {
  justify-content: flex-start !important;
}

.user-setting-checkbox input:disabled,
.user-edit-panel input:disabled,
.user-edit-panel select:disabled {
  opacity: 0.55 !important;
  cursor: not-allowed !important;
}

.user-row.is-inactive {
  opacity: 0.72 !important;
}

.user-row .actions {
  align-items: center !important;
}

/* =========================================================
   FEATUREBATCH 6 — FAMILY CRESTS / RELATIONSHIP POLISH
   ========================================================= */

.family-crest-card {
  display: grid !important;
  gap: 9px !important;
  width: 200px !important;
  margin: 16px 0 0 !important;
}

.family-crest-image {
  display: block !important;
  width: 200px !important;
  height: 300px !important;
  object-fit: cover !important;
  border-radius: 22px !important;
  border: 2px solid rgba(244, 217, 157, 0.34) !important;
  background: rgba(255, 238, 220, 0.06) !important;
  box-shadow:
    0 18px 42px rgba(34, 20, 17, 0.28),
    inset 0 1px 0 rgba(255, 244, 234, 0.10) !important;
}

.family-crest-card figcaption {
  color: var(--muted2) !important;
  font-size: 12px !important;
  text-align: center !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
}

.profile-media-column {
  display: grid !important;
  gap: 14px !important;
  justify-items: start !important;
}

.family-page-top {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) 220px !important;
  gap: 24px !important;
  align-items: start !important;
}

.family-page-top .family-crest-card {
  margin-top: 0 !important;
  justify-self: end !important;
}

.family-facts-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)) !important;
  gap: 14px !important;
  margin: 18px 0 !important;
}

.inline-link-list {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
  margin-top: 8px !important;
}

.inline-link-button {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: auto !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
  color: #f4d99d !important;
  font: inherit !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
  text-decoration: underline !important;
  cursor: pointer !important;
}

.inline-link-button:hover {
  color: #fff8ef !important;
}

.sibling-card {
  grid-column: 1 / -1 !important;
}

.sibling-group {
  display: grid !important;
  gap: 5px !important;
  margin-top: 12px !important;
  padding-top: 10px !important;
  border-top: 1px solid rgba(239, 202, 151, 0.18) !important;
}

.sibling-group strong {
  color: #fff8ef !important;
  font-family: Georgia, "Times New Roman", serif !important;
  font-size: 17px !important;
}

.character-record-groups {
  display: grid !important;
  gap: 24px !important;
  margin-top: 18px !important;
}

.character-record-group {
  padding: 16px !important;
  border: 2px solid rgba(239, 202, 151, 0.24) !important;
  border-radius: 24px !important;
  background: rgba(255, 238, 220, 0.045) !important;
}

.character-record-group-head {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 12px !important;
  margin-bottom: 12px !important;
  padding-bottom: 10px !important;
  border-bottom: 1px solid rgba(239, 202, 151, 0.18) !important;
}

.character-record-group-head .card-title {
  margin: 0 !important;
  font-size: 24px !important;
}

.flow-union.related-union {
  border-color: rgba(201, 196, 187, 0.85) !important;
  box-shadow:
    0 0 0 3px rgba(201, 196, 187, 0.14),
    0 10px 30px rgba(34, 20, 17, 0.24) !important;
}

.edge-related-union path,
.react-flow__edge.edge-related-union path {
  stroke-dasharray: 8 5 !important;
  stroke: rgba(201, 196, 187, 0.95) !important;
}

.relationship-summary {
  border-color: rgba(244, 217, 157, 0.34) !important;
}

@media (max-width: 820px) {
  .family-page-top {
    grid-template-columns: 1fr !important;
  }

  .family-page-top .family-crest-card {
    justify-self: start !important;
  }
}


/* =========================================================
   FEATUREBATCH 7 — PARENT RELATIONSHIP DETAILS
   ========================================================= */

.parent-guardian-card .parent-detail-list {
  display: grid !important;
  gap: 8px !important;
}

.parent-detail {
  padding: 8px 10px !important;
  border-radius: 14px !important;
  border: 1px solid rgba(239, 202, 151, 0.18) !important;
  background: rgba(255, 238, 220, 0.045) !important;
}

.parent-detail.parent-adopted {
  border-color: rgba(217, 154, 165, 0.30) !important;
}

.parent-detail.parent-step {
  border-color: rgba(201, 196, 187, 0.30) !important;
}

.parent-detail.parent-biological {
  border-color: rgba(244, 217, 157, 0.26) !important;
}

.relationship-summary p {
  margin: 0 0 8px !important;
}

.relationship-summary p:last-child {
  margin-bottom: 0 !important;
}

/* =========================================================
   FEATUREBATCH 13 — DASHBOARD VISUAL POLISH
   Ornate KB emblem, rose panel, slideshow badges, house directory,
   and cleaner Codex at a Glance cards.
   ========================================================= */

.brand-mark {
  width: 68px !important;
  height: 68px !important;
  min-width: 68px !important;
  border: 0 !important;
  border-radius: 50% !important;
  background: url("./assets/ui/kb-emblem-ornate.png") center / contain no-repeat !important;
  box-shadow:
    0 0 0 1px rgba(244, 217, 157, 0.18),
    0 0 26px rgba(244, 217, 157, 0.18) !important;
  color: transparent !important;
  font-size: 0 !important;
  overflow: visible !important;
}

.brand-mark::before,
.brand-mark::after {
  display: none !important;
}

.hero-main {
  position: relative !important;
  overflow: hidden !important;
}

.hero-main > * {
  position: relative !important;
  z-index: 2 !important;
}

.hero-main::before {
  content: "" !important;
  position: absolute !important;
  z-index: 1 !important;
  left: 18px !important;
  top: 82px !important;
  bottom: 150px !important;
  width: 128px !important;
  background: url("./assets/ui/rose-panel-gothic.png") center / cover no-repeat !important;
  opacity: 0.42 !important;
  pointer-events: none !important;
  filter: saturate(0.92) contrast(1.05) brightness(1.05) !important;
  -webkit-mask-image: linear-gradient(to right, rgba(0,0,0,0.98), rgba(0,0,0,0.70), rgba(0,0,0,0.18), transparent) !important;
  mask-image: linear-gradient(to right, rgba(0,0,0,0.98), rgba(0,0,0,0.70), rgba(0,0,0,0.18), transparent) !important;
}

@media (min-width: 980px) {
  .hero-main .kicker,
  .hero-main .huge-title,
  .hero-main .lede,
  .hero-main .search-row {
    margin-left: 118px !important;
  }
}

.cinematic-photo {
  position: relative !important;
}

.cinematic-corner-badge {
  position: absolute !important;
  z-index: 5 !important;
  right: 18px !important;
  top: 18px !important;
  width: 76px !important;
  height: 76px !important;
  object-fit: contain !important;
  filter:
    drop-shadow(0 12px 18px rgba(22, 12, 10, 0.62))
    drop-shadow(0 0 8px rgba(244, 217, 157, 0.16)) !important;
  opacity: 0.94 !important;
  pointer-events: none !important;
}

.featured-panel {
  display: flex !important;
  flex-direction: column !important;
  gap: 18px !important;
}

.featured-list {
  display: grid !important;
  gap: 14px !important;
}

.house-directory {
  margin-top: 8px !important;
  padding-top: 18px !important;
  border-top: 1.5px solid rgba(239, 202, 151, 0.24) !important;
}

.house-directory-head {
  margin-bottom: 12px !important;
}

.house-directory-list {
  display: grid !important;
  gap: 12px !important;
}

.house-directory-card {
  position: relative !important;
  display: grid !important;
  grid-template-columns: 86px minmax(0, 1fr) !important;
  gap: 14px !important;
  align-items: start !important;
  padding: 16px !important;
  border-radius: 22px !important;
  border: 1.75px solid rgba(239, 202, 151, 0.24) !important;
  background:
    radial-gradient(circle at 100% 0%, rgba(244, 217, 157, 0.10), transparent 35%),
    linear-gradient(135deg, rgba(255, 238, 220, 0.070), rgba(50, 30, 26, 0.24)) !important;
  box-shadow:
    0 16px 36px rgba(31, 18, 15, 0.22),
    inset 0 1px 0 rgba(255, 244, 234, 0.09) !important;
  overflow: hidden !important;
}

.house-directory-card::after {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  pointer-events: none !important;
  opacity: 0.18 !important;
}

.house-directory-card.house-gryffindor::after {
  background: linear-gradient(90deg, rgba(149, 40, 38, 0.35), transparent 62%) !important;
}

.house-directory-card.house-slytherin::after {
  background: linear-gradient(90deg, rgba(35, 94, 63, 0.34), transparent 62%) !important;
}

.house-directory-card.house-ravenclaw::after {
  background: linear-gradient(90deg, rgba(42, 73, 109, 0.34), transparent 62%) !important;
}

.house-directory-card.house-hufflepuff::after {
  background: linear-gradient(90deg, rgba(154, 113, 45, 0.28), transparent 62%) !important;
}

.house-directory-badge {
  position: relative !important;
  z-index: 2 !important;
  width: 82px !important;
  height: 82px !important;
  object-fit: contain !important;
  filter: drop-shadow(0 10px 16px rgba(21, 12, 10, 0.56)) !important;
}

.house-directory-copy {
  position: relative !important;
  z-index: 2 !important;
}

.house-directory-copy h3 {
  margin: 0 0 4px !important;
  color: #fff8ef !important;
  font-family: Georgia, "Times New Roman", serif !important;
  font-size: 24px !important;
  line-height: 1.05 !important;
}

.house-tagline {
  margin: 0 0 7px !important;
  color: #f4d99d !important;
  font-size: 13px !important;
  line-height: 1.35 !important;
}

.house-history,
.house-head {
  margin: 0 0 9px !important;
  color: var(--muted) !important;
  font-size: 13px !important;
  line-height: 1.45 !important;
}

.house-head button,
.house-member-list button {
  border: 0 !important;
  padding: 0 !important;
  background: transparent !important;
  color: #f4d99d !important;
  text-decoration: underline !important;
  cursor: pointer !important;
  font: inherit !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
}

.house-member-list {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 6px 9px !important;
  margin-top: 8px !important;
}

.house-member-list button,
.house-member-list span {
  display: inline-flex !important;
  align-items: center !important;
  min-height: 24px !important;
  border-radius: 999px !important;
  padding: 3px 8px !important;
  border: 1px solid rgba(239, 202, 151, 0.20) !important;
  background: rgba(255, 238, 220, 0.055) !important;
  color: var(--muted) !important;
  text-decoration: none !important;
  font-size: 12px !important;
}

.house-member-list button:hover {
  color: #fff8ef !important;
  border-color: rgba(244, 217, 157, 0.38) !important;
  background: rgba(255, 238, 220, 0.10) !important;
}

.glance-stats {
  gap: 14px !important;
}

.glance-stat {
  position: relative !important;
  display: grid !important;
  grid-template-columns: 54px minmax(0, 1fr) !important;
  align-items: center !important;
  gap: 12px !important;
  min-height: 94px !important;
  padding: 15px !important;
  border: 1.75px solid rgba(239, 202, 151, 0.28) !important;
  background:
    radial-gradient(circle at 100% 0%, rgba(244, 217, 157, 0.11), transparent 36%),
    rgba(255, 238, 220, 0.070) !important;
  box-shadow:
    0 14px 32px rgba(31, 18, 15, 0.20),
    inset 0 1px 0 rgba(255, 244, 234, 0.09) !important;
}

.glance-icon {
  width: 54px !important;
  height: 54px !important;
  object-fit: cover !important;
  border-radius: 15px !important;
  filter: drop-shadow(0 8px 12px rgba(22, 12, 10, 0.46)) !important;
}

.glance-stat b {
  display: block !important;
  color: #f4d99d !important;
  font-family: Georgia, "Times New Roman", serif !important;
  font-size: 28px !important;
  line-height: 1 !important;
}

.glance-stat span {
  display: block !important;
  margin-top: 5px !important;
  color: var(--muted2) !important;
  letter-spacing: 0.13em !important;
}

@media (max-width: 900px) {
  .hero-main::before {
    opacity: 0.20 !important;
    width: 110px !important;
  }

  .hero-main .kicker,
  .hero-main .huge-title,
  .hero-main .lede,
  .hero-main .search-row {
    margin-left: 0 !important;
  }

  .cinematic-corner-badge {
    width: 58px !important;
    height: 58px !important;
  }

  .house-directory-card {
    grid-template-columns: 68px minmax(0, 1fr) !important;
  }

  .house-directory-badge {
    width: 66px !important;
    height: 66px !important;
  }
}

/* =========================================================
   FEATUREBATCH 14 — ROSE VELVET RETHEME + SPEED FIXES
   Optimized UI assets, richer rose/gold/green palette, softer rose blend,
   bottom-right slideshow badges, and no extra KB outer ring.
   ========================================================= */

:root {
  --text: #fff8ef;
  --muted: #eadbd0;
  --muted2: #c7ad9e;
  --kb-ink: #1b1210;
  --kb-green: #17261f;
  --kb-green-soft: #26392f;
  --kb-rose-dark: #4a2d2b;
  --kb-rose: #7a4d49;
  --kb-blush: #c88d86;
  --kb-gold: #e8c37e;
  --kb-gold-soft: #b98c58;
}

html,
body {
  background:
    radial-gradient(circle at 12% 12%, rgba(122, 77, 73, 0.42), transparent 31%),
    radial-gradient(circle at 88% 16%, rgba(31, 72, 53, 0.40), transparent 34%),
    radial-gradient(circle at 58% 92%, rgba(176, 119, 79, 0.22), transparent 34%),
    linear-gradient(135deg, #211411 0%, #4d312e 45%, #26362e 100%) !important;
}

.app-shell {
  background:
    radial-gradient(circle at 2% 50%, rgba(217, 154, 165, 0.09), transparent 28%),
    radial-gradient(circle at 92% 72%, rgba(33, 72, 53, 0.12), transparent 30%) !important;
}

.kb-header,
.panel {
  border-color: rgba(232, 195, 126, 0.42) !important;
  background:
    radial-gradient(circle at 15% 0%, rgba(198, 141, 134, 0.14), transparent 34%),
    radial-gradient(circle at 92% 12%, rgba(38, 57, 47, 0.28), transparent 42%),
    linear-gradient(135deg, rgba(99, 63, 56, 0.74), rgba(56, 35, 31, 0.82) 52%, rgba(32, 42, 35, 0.66)) !important;
  box-shadow:
    0 30px 80px rgba(23, 12, 10, 0.32),
    inset 0 1px 0 rgba(255, 244, 234, 0.10) !important;
}

.kb-header {
  background:
    radial-gradient(circle at 8% 50%, rgba(232, 195, 126, 0.11), transparent 25%),
    radial-gradient(circle at 82% 0%, rgba(38, 57, 47, 0.24), transparent 40%),
    linear-gradient(90deg, rgba(42, 28, 25, 0.92), rgba(74, 45, 43, 0.88), rgba(29, 43, 35, 0.72)) !important;
}

.nav-tabs button,
.secondary,
.sidebar-list button,
.admin-tabs button {
  border-color: rgba(232, 195, 126, 0.26) !important;
  background: rgba(255, 238, 220, 0.065) !important;
}

.nav-tabs button:hover,
.secondary:hover,
.sidebar-list button:hover,
.admin-tabs button:hover {
  border-color: rgba(232, 195, 126, 0.48) !important;
  background:
    radial-gradient(circle at 0% 0%, rgba(198, 141, 134, 0.16), transparent 45%),
    rgba(255, 238, 220, 0.10) !important;
}

.nav-tabs button.active,
.pill-button,
button.active {
  background:
    linear-gradient(135deg, #f0cf93, #f3bcae) !important;
  color: #33201c !important;
  border-color: rgba(255, 238, 220, 0.42) !important;
  box-shadow: 0 12px 26px rgba(42, 20, 17, 0.24) !important;
}

input,
select,
textarea {
  background:
    radial-gradient(circle at 0% 0%, rgba(38, 57, 47, 0.20), transparent 45%),
    rgba(52, 34, 31, 0.46) !important;
  border-color: rgba(232, 195, 126, 0.28) !important;
}

input:focus,
select:focus,
textarea:focus {
  border-color: rgba(232, 195, 126, 0.62) !important;
  box-shadow: 0 0 0 3px rgba(232, 195, 126, 0.14) !important;
}

/* Fancy KB emblem: keep the generated emblem, remove the extra CSS ring/circle. */
.brand-mark {
  width: 58px !important;
  height: 58px !important;
  min-width: 58px !important;
  border: 0 !important;
  border-radius: 0 !important;
  background-color: transparent !important;
  background-image: url("./assets/ui/kb-emblem-ornate.png") !important;
  background-position: center !important;
  background-size: contain !important;
  background-repeat: no-repeat !important;
  box-shadow: none !important;
  outline: 0 !important;
}

.brand-mark::before,
.brand-mark::after {
  display: none !important;
}

/* Rose panel: larger, warmer, and masked so it melts into the hero instead of looking like a block. */
.hero-main::before {
  left: 0 !important;
  top: 0 !important;
  bottom: 0 !important;
  width: 255px !important;
  background-image: url("./assets/ui/rose-panel-gothic.png") !important;
  background-position: left center !important;
  background-size: cover !important;
  background-repeat: no-repeat !important;
  opacity: 0.74 !important;
  filter: saturate(1.22) contrast(1.08) brightness(0.96) !important;
  mix-blend-mode: soft-light !important;
  -webkit-mask-image: linear-gradient(to right, rgba(0,0,0,1) 0%, rgba(0,0,0,.92) 34%, rgba(0,0,0,.48) 66%, transparent 100%) !important;
  mask-image: linear-gradient(to right, rgba(0,0,0,1) 0%, rgba(0,0,0,.92) 34%, rgba(0,0,0,.48) 66%, transparent 100%) !important;
}

.hero-main::after {
  content: "" !important;
  position: absolute !important;
  z-index: 1 !important;
  inset: 0 auto 0 0 !important;
  width: 310px !important;
  pointer-events: none !important;
  background:
    linear-gradient(to right, transparent 0%, rgba(84, 51, 46, 0.10) 44%, rgba(84, 51, 46, 0.42) 74%, transparent 100%),
    radial-gradient(circle at 24% 55%, rgba(217, 154, 165, 0.18), transparent 46%) !important;
}

@media (min-width: 980px) {
  .hero-main .kicker,
  .hero-main .huge-title,
  .hero-main .lede,
  .hero-main .search-row {
    margin-left: 110px !important;
  }
}

/* Badges belong at the bottom-right of slideshow portraits so faces stay clean. */
.cinematic-corner-badge {
  top: auto !important;
  right: 18px !important;
  bottom: 18px !important;
  width: 68px !important;
  height: 68px !important;
  object-fit: contain !important;
  opacity: 0.96 !important;
  filter:
    drop-shadow(0 12px 18px rgba(22, 12, 10, 0.70))
    drop-shadow(0 0 10px rgba(232, 195, 126, 0.18)) !important;
}

.character-card,
.timeline-card,
.record-row,
.family-card,
.ship-thread,
.magic-guide-box,
.guide-text-section,
.house-directory-card,
.glance-stat {
  border-color: rgba(232, 195, 126, 0.32) !important;
  background:
    radial-gradient(circle at 100% 0%, rgba(38, 57, 47, 0.18), transparent 40%),
    radial-gradient(circle at 0% 100%, rgba(198, 141, 134, 0.11), transparent 42%),
    rgba(83, 53, 47, 0.54) !important;
}

.featured-panel .character-card {
  background:
    radial-gradient(circle at 100% 0%, rgba(38, 57, 47, 0.26), transparent 39%),
    linear-gradient(135deg, rgba(101, 66, 58, 0.64), rgba(55, 35, 31, 0.78)) !important;
}

.house-directory-card.house-slytherin {
  border-color: rgba(116, 161, 113, 0.34) !important;
  background:
    radial-gradient(circle at 0% 0%, rgba(25, 81, 55, 0.33), transparent 48%),
    rgba(64, 43, 37, 0.62) !important;
}

.house-directory-card.house-ravenclaw {
  border-color: rgba(106, 139, 166, 0.34) !important;
  background:
    radial-gradient(circle at 0% 0%, rgba(37, 73, 104, 0.34), transparent 48%),
    rgba(64, 43, 37, 0.62) !important;
}

.house-directory-card.house-gryffindor {
  border-color: rgba(183, 92, 80, 0.38) !important;
  background:
    radial-gradient(circle at 0% 0%, rgba(127, 42, 38, 0.34), transparent 48%),
    rgba(64, 43, 37, 0.62) !important;
}

.house-directory-card.house-hufflepuff {
  border-color: rgba(204, 158, 72, 0.36) !important;
  background:
    radial-gradient(circle at 0% 0%, rgba(150, 112, 44, 0.30), transparent 48%),
    rgba(64, 43, 37, 0.62) !important;
}

.house-directory-badge {
  width: 74px !important;
  height: 74px !important;
}

.glance-stats {
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
}

.glance-stat {
  min-height: 82px !important;
  grid-template-columns: 44px minmax(0, 1fr) !important;
  gap: 10px !important;
  padding: 13px !important;
}

.glance-icon {
  width: 44px !important;
  height: 44px !important;
  border-radius: 12px !important;
  object-fit: cover !important;
}

.glance-stat b {
  color: #f1cf91 !important;
  font-size: 25px !important;
}

.kicker,
.house-tagline,
.category-pill,
.meta-pill {
  color: #f1cf91 !important;
}

@media (max-width: 900px) {
  .hero-main::before {
    width: 190px !important;
    opacity: 0.42 !important;
  }

  .hero-main::after {
    width: 220px !important;
  }

  .cinematic-corner-badge {
    width: 54px !important;
    height: 54px !important;
    right: 12px !important;
    bottom: 12px !important;
  }

  .glance-stats {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

/* =========================================================
   FEATUREBATCH 15 — STRONGER ROSE VEIL + RICHER VELVET COLOR
   Makes the gothic rose visibly present without becoming a hard block.
   ========================================================= */

:root {
  --kb-ink: #160f0d;
  --kb-green: #14241d;
  --kb-green-soft: #20362a;
  --kb-rose-dark: #42221f;
  --kb-rose: #7d4744;
  --kb-blush: #c28a82;
  --kb-gold: #edca88;
  --kb-gold-soft: #bb8c57;
}

html,
body {
  background:
    radial-gradient(circle at 7% 12%, rgba(126, 62, 58, 0.55), transparent 29%),
    radial-gradient(circle at 88% 18%, rgba(23, 58, 41, 0.52), transparent 35%),
    radial-gradient(circle at 42% 100%, rgba(131, 78, 53, 0.30), transparent 36%),
    linear-gradient(135deg, #160f0d 0%, #4d2d29 43%, #17291f 100%) !important;
}

.kb-header,
.panel {
  border-color: rgba(237, 202, 136, 0.46) !important;
}

.dashboard-hero .hero-main {
  background:
    radial-gradient(circle at 17% 48%, rgba(117, 52, 48, 0.40), transparent 34%),
    radial-gradient(circle at 94% 5%, rgba(32, 54, 42, 0.36), transparent 42%),
    linear-gradient(135deg, rgba(91, 50, 45, 0.86), rgba(50, 30, 27, 0.86) 55%, rgba(31, 48, 39, 0.64)) !important;
}

/* Stronger visible rose: no soft-light washout, no rectangular block edge. */
.hero-main::before {
  content: "" !important;
  position: absolute !important;
  z-index: 1 !important;
  left: 0 !important;
  top: 0 !important;
  bottom: 0 !important;
  width: 305px !important;
  background-image: url("./assets/ui/rose-panel-gothic.png") !important;
  background-position: left center !important;
  background-size: cover !important;
  background-repeat: no-repeat !important;
  opacity: 0.98 !important;
  mix-blend-mode: normal !important;
  filter: saturate(1.38) contrast(1.18) brightness(0.86) !important;
  pointer-events: none !important;
  -webkit-mask-image:
    linear-gradient(to right,
      rgba(0,0,0,1) 0%,
      rgba(0,0,0,1) 34%,
      rgba(0,0,0,.82) 51%,
      rgba(0,0,0,.36) 72%,
      transparent 100%) !important;
  mask-image:
    linear-gradient(to right,
      rgba(0,0,0,1) 0%,
      rgba(0,0,0,1) 34%,
      rgba(0,0,0,.82) 51%,
      rgba(0,0,0,.36) 72%,
      transparent 100%) !important;
}

/* Color veil over the rose so it belongs to the panel instead of looking pasted on. */
.hero-main::after {
  content: "" !important;
  position: absolute !important;
  z-index: 1 !important;
  inset: 0 auto 0 0 !important;
  width: 390px !important;
  pointer-events: none !important;
  background:
    linear-gradient(to right,
      rgba(22, 12, 10, 0.10) 0%,
      rgba(72, 34, 31, 0.12) 34%,
      rgba(91, 50, 45, 0.36) 63%,
      rgba(83, 53, 47, 0.74) 100%),
    radial-gradient(circle at 23% 57%, rgba(204, 118, 112, 0.20), transparent 42%),
    radial-gradient(circle at 6% 18%, rgba(237, 202, 136, 0.10), transparent 26%) !important;
}

@media (min-width: 980px) {
  .hero-main .kicker,
  .hero-main .huge-title,
  .hero-main .lede,
  .hero-main .search-row {
    margin-left: 122px !important;
  }
}

/* Darker, richer card color to better match the rose art and deep green badges. */
.featured-panel .character-card,
.character-card,
.timeline-card,
.record-row,
.family-card,
.ship-thread,
.magic-guide-box,
.guide-text-section,
.house-directory-card,
.glance-stat {
  background:
    radial-gradient(circle at 100% 0%, rgba(24, 58, 40, 0.22), transparent 40%),
    radial-gradient(circle at 0% 100%, rgba(171, 83, 80, 0.15), transparent 42%),
    linear-gradient(135deg, rgba(98, 56, 50, 0.66), rgba(48, 30, 27, 0.76)) !important;
  border-color: rgba(237, 202, 136, 0.36) !important;
}

.hero-slideshow,
.cinematic-stage {
  background:
    radial-gradient(circle at 12% 34%, rgba(120, 55, 51, 0.22), transparent 36%),
    radial-gradient(circle at 88% 16%, rgba(24, 58, 40, 0.22), transparent 38%),
    rgba(42, 25, 22, 0.62) !important;
}

.cinematic-corner-badge {
  right: 16px !important;
  bottom: 16px !important;
  width: 62px !important;
  height: 62px !important;
}

@media (max-width: 900px) {
  .hero-main::before {
    width: 210px !important;
    opacity: 0.72 !important;
  }
  .hero-main::after {
    width: 280px !important;
  }
  .hero-main .kicker,
  .hero-main .huge-title,
  .hero-main .lede,
  .hero-main .search-row {
    margin-left: 0 !important;
  }
}


/* =========================================================
   FEATUREBATCH 16 — RIGHT PANEL / HOUSE DIRECTORY / GLANCE POLISH
   Moves Codex at a Glance into the sidebar and gives the right side
   the richer finished-dashboard treatment.
   ========================================================= */

.featured-panel {
  position: relative !important;
  overflow: hidden !important;
  background:
    radial-gradient(circle at 88% 8%, rgba(21, 53, 39, 0.42), transparent 34%),
    radial-gradient(circle at 8% 22%, rgba(125, 57, 52, 0.34), transparent 32%),
    linear-gradient(160deg, rgba(54, 32, 29, 0.94), rgba(34, 23, 20, 0.94) 54%, rgba(18, 34, 27, 0.82)) !important;
  box-shadow:
    0 28px 70px rgba(17, 10, 8, 0.34),
    inset 0 1px 0 rgba(255, 244, 234, 0.09) !important;
}

.featured-panel::before {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  pointer-events: none !important;
  background:
    linear-gradient(90deg, rgba(237, 202, 136, 0.08), transparent 16%, transparent 84%, rgba(237, 202, 136, 0.07)),
    radial-gradient(circle at 50% 0%, rgba(237, 202, 136, 0.10), transparent 42%) !important;
  opacity: 0.9 !important;
}

.featured-panel > * {
  position: relative !important;
  z-index: 1 !important;
}

.featured-list {
  gap: 14px !important;
}

.featured-panel .character-card {
  position: relative !important;
  overflow: hidden !important;
  min-height: 122px !important;
  border-width: 1.7px !important;
  border-color: rgba(237, 202, 136, 0.43) !important;
  background:
    radial-gradient(circle at 12% 20%, rgba(214, 136, 123, 0.16), transparent 34%),
    radial-gradient(circle at 96% 8%, rgba(37, 78, 54, 0.26), transparent 38%),
    linear-gradient(135deg, rgba(107, 62, 55, 0.74), rgba(50, 31, 27, 0.82)) !important;
  box-shadow:
    0 16px 36px rgba(21, 12, 10, 0.26),
    inset 0 1px 0 rgba(255, 244, 234, 0.08) !important;
}

.featured-panel .character-card::after {
  content: "" !important;
  position: absolute !important;
  right: -54px !important;
  top: -74px !important;
  width: 170px !important;
  height: 170px !important;
  border-radius: 50% !important;
  background: radial-gradient(circle, rgba(237, 202, 136, 0.12), transparent 68%) !important;
  pointer-events: none !important;
}

.featured-panel .avatar-thumb {
  border: 1.5px solid rgba(237, 202, 136, 0.44) !important;
  box-shadow: 0 8px 18px rgba(14, 8, 7, 0.28) !important;
}

.house-directory {
  margin-top: 28px !important;
  padding-top: 24px !important;
  border-top: 1px solid rgba(237, 202, 136, 0.24) !important;
}

.house-directory-head {
  margin-bottom: 14px !important;
}

.house-directory-head .card-sub {
  margin-top: 3px !important;
  color: rgba(255, 244, 234, 0.72) !important;
}

.house-directory-list {
  display: grid !important;
  gap: 13px !important;
}

.house-directory-card {
  position: relative !important;
  display: grid !important;
  grid-template-columns: 76px minmax(0, 1fr) !important;
  gap: 15px !important;
  align-items: start !important;
  overflow: hidden !important;
  min-height: 150px !important;
  padding: 16px 18px !important;
  border-width: 1.7px !important;
  box-shadow:
    0 17px 42px rgba(18, 10, 8, 0.24),
    inset 0 1px 0 rgba(255, 244, 234, 0.08) !important;
}

.house-directory-card::before {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  pointer-events: none !important;
  background:
    linear-gradient(90deg, rgba(255, 244, 234, 0.05), transparent 30%),
    radial-gradient(circle at 90% 12%, rgba(237, 202, 136, 0.12), transparent 35%) !important;
}

.house-directory-card::after {
  content: "›" !important;
  position: absolute !important;
  right: 18px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  color: rgba(237, 202, 136, 0.70) !important;
  font-family: Georgia, serif !important;
  font-size: 34px !important;
  line-height: 1 !important;
  opacity: 0.7 !important;
}

.house-directory-card.house-gryffindor {
  border-color: rgba(223, 142, 104, 0.50) !important;
  background:
    radial-gradient(circle at 0% 10%, rgba(130, 38, 35, 0.48), transparent 48%),
    linear-gradient(135deg, rgba(91, 39, 35, 0.84), rgba(46, 28, 25, 0.86)) !important;
}

.house-directory-card.house-slytherin {
  border-color: rgba(125, 174, 121, 0.46) !important;
  background:
    radial-gradient(circle at 0% 10%, rgba(28, 91, 62, 0.54), transparent 48%),
    linear-gradient(135deg, rgba(35, 70, 51, 0.80), rgba(42, 29, 25, 0.88)) !important;
}

.house-directory-card.house-ravenclaw {
  border-color: rgba(117, 151, 177, 0.48) !important;
  background:
    radial-gradient(circle at 0% 10%, rgba(43, 80, 112, 0.52), transparent 48%),
    linear-gradient(135deg, rgba(36, 58, 78, 0.82), rgba(38, 28, 27, 0.88)) !important;
}

.house-directory-card.house-hufflepuff {
  border-color: rgba(219, 176, 92, 0.50) !important;
  background:
    radial-gradient(circle at 0% 10%, rgba(157, 112, 43, 0.48), transparent 48%),
    linear-gradient(135deg, rgba(91, 67, 36, 0.80), rgba(42, 29, 25, 0.88)) !important;
}

.house-directory-badge {
  width: 76px !important;
  height: 76px !important;
  object-fit: contain !important;
  filter: drop-shadow(0 12px 18px rgba(7, 4, 3, 0.38)) saturate(1.05) !important;
  position: relative !important;
  z-index: 1 !important;
}

.house-directory-copy {
  position: relative !important;
  z-index: 1 !important;
  padding-right: 26px !important;
}

.house-directory-copy h3 {
  margin: 0 0 3px !important;
  color: #fff7e9 !important;
  font-family: Georgia, "Times New Roman", serif !important;
  font-size: 25px !important;
  line-height: 1.05 !important;
}

.house-tagline {
  margin: 0 0 8px !important;
  color: #f0cd8a !important;
  font-size: 13px !important;
  line-height: 1.35 !important;
}

.house-history {
  margin: 0 0 10px !important;
  color: rgba(255, 244, 234, 0.72) !important;
  font-size: 13px !important;
  line-height: 1.45 !important;
}

.house-head {
  margin: 0 0 9px !important;
  color: rgba(255, 244, 234, 0.78) !important;
  font-size: 12.5px !important;
}

.house-head button,
.house-member-list button {
  border: 0 !important;
  padding: 0 !important;
  background: transparent !important;
  color: #f0cd8a !important;
  text-decoration: underline !important;
  text-underline-offset: 3px !important;
  cursor: pointer !important;
}

.house-member-list {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 6px !important;
}

.house-member-list button,
.house-member-list span {
  display: inline-flex !important;
  align-items: center !important;
  min-height: 22px !important;
  padding: 3px 8px !important;
  border-radius: 999px !important;
  border: 1px solid rgba(237, 202, 136, 0.22) !important;
  background: rgba(18, 13, 11, 0.24) !important;
  color: rgba(255, 244, 234, 0.78) !important;
  font-size: 11px !important;
  text-decoration: none !important;
}

.codex-glance-sidebar {
  margin-top: 27px !important;
  padding-top: 23px !important;
  border-top: 1px solid rgba(237, 202, 136, 0.24) !important;
}

.glance-sidebar-head {
  margin-bottom: 12px !important;
}

.codex-glance-sidebar .glance-stats {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 12px !important;
}

.codex-glance-sidebar .glance-stat {
  min-height: 92px !important;
  align-items: center !important;
  grid-template-columns: 52px minmax(0, 1fr) !important;
  padding: 14px !important;
  border-width: 1.7px !important;
  background:
    radial-gradient(circle at 0% 0%, rgba(237, 202, 136, 0.13), transparent 36%),
    radial-gradient(circle at 100% 100%, rgba(26, 68, 47, 0.22), transparent 42%),
    linear-gradient(135deg, rgba(67, 42, 36, 0.78), rgba(30, 22, 19, 0.84)) !important;
}

.codex-glance-sidebar .glance-icon {
  width: 52px !important;
  height: 52px !important;
  border-radius: 14px !important;
  filter: drop-shadow(0 10px 14px rgba(8, 5, 4, 0.34)) !important;
}

.codex-glance-sidebar .glance-stat b {
  display: block !important;
  color: #f4d99d !important;
  font-size: 25px !important;
  line-height: 1 !important;
}

.codex-glance-sidebar .glance-stat span {
  display: block !important;
  margin-top: 6px !important;
  color: rgba(255, 244, 234, 0.66) !important;
  font-size: 11px !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase !important;
}

.dashboard-hero .hero-main > .stats.glance-stats {
  display: none !important;
}

@media (max-width: 1100px) {
  .codex-glance-sidebar .glance-stats {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 760px) {
  .house-directory-card {
    grid-template-columns: 58px minmax(0, 1fr) !important;
    padding: 14px !important;
  }

  .house-directory-badge {
    width: 58px !important;
    height: 58px !important;
  }

  .house-directory-copy h3 {
    font-size: 21px !important;
  }

  .codex-glance-sidebar .glance-stats {
    grid-template-columns: 1fr !important;
  }
}

/* =========================================================
   FEATUREBATCH 17 — DASHBOARD LAYOUT + ANCIENT HOUSE COLORS
   ========================================================= */

.dashboard-sidebar {
  position: relative !important;
  overflow: hidden !important;
  background:
    radial-gradient(circle at 88% 4%, rgba(19, 51, 39, 0.36), transparent 30%),
    radial-gradient(circle at 10% 20%, rgba(92, 39, 42, 0.28), transparent 34%),
    linear-gradient(160deg, rgba(55, 33, 30, 0.94), rgba(33, 23, 20, 0.96) 58%, rgba(19, 32, 27, 0.86)) !important;
  box-shadow:
    0 28px 70px rgba(17, 10, 8, 0.32),
    inset 0 1px 0 rgba(255, 244, 234, 0.09) !important;
}

.dashboard-sidebar::before {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  pointer-events: none !important;
  background:
    linear-gradient(90deg, rgba(237, 202, 136, 0.06), transparent 18%, transparent 82%, rgba(237, 202, 136, 0.05)),
    radial-gradient(circle at 50% 0%, rgba(237, 202, 136, 0.08), transparent 42%) !important;
  opacity: 0.84 !important;
}

.dashboard-sidebar > * {
  position: relative !important;
  z-index: 1 !important;
}

.dashboard-featured-row {
  position: relative !important;
  z-index: 2 !important;
  margin-top: 24px !important;
  padding: 22px !important;
  border-radius: 26px !important;
  border: 1.8px solid rgba(237, 202, 136, 0.34) !important;
  background:
    radial-gradient(circle at 94% 0%, rgba(19, 55, 40, 0.22), transparent 36%),
    radial-gradient(circle at 4% 20%, rgba(134, 68, 63, 0.20), transparent 38%),
    rgba(34, 22, 20, 0.38) !important;
  box-shadow:
    0 20px 46px rgba(20, 12, 10, 0.22),
    inset 0 1px 0 rgba(255, 244, 234, 0.08) !important;
}

.dashboard-section-head {
  margin-bottom: 14px !important;
}

.dashboard-section-head .card-sub {
  margin-top: 5px !important;
  color: rgba(255, 244, 234, 0.70) !important;
}

.dashboard-featured-grid {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 14px !important;
}

.dashboard-featured-grid .character-card {
  position: relative !important;
  overflow: hidden !important;
  min-height: 126px !important;
  border-width: 1.7px !important;
  border-color: rgba(237, 202, 136, 0.38) !important;
  background:
    radial-gradient(circle at 12% 22%, rgba(121, 57, 52, 0.18), transparent 32%),
    radial-gradient(circle at 94% 10%, rgba(24, 65, 44, 0.20), transparent 40%),
    linear-gradient(135deg, rgba(93, 54, 49, 0.60), rgba(40, 27, 24, 0.78)) !important;
  box-shadow:
    0 16px 34px rgba(18, 10, 8, 0.24),
    inset 0 1px 0 rgba(255, 244, 234, 0.075) !important;
}

.dashboard-featured-grid .avatar-thumb {
  border: 1.5px solid rgba(237, 202, 136, 0.40) !important;
  box-shadow: 0 8px 18px rgba(14, 8, 7, 0.26) !important;
}

.codex-glance-top {
  margin-top: 0 !important;
  padding-top: 0 !important;
  border-top: 0 !important;
  margin-bottom: 28px !important;
  padding-bottom: 24px !important;
  border-bottom: 1px solid rgba(237, 202, 136, 0.20) !important;
}

.codex-glance-sidebar .glance-stat {
  border-color: rgba(237, 202, 136, 0.34) !important;
  background:
    radial-gradient(circle at 0% 0%, rgba(237, 202, 136, 0.11), transparent 35%),
    radial-gradient(circle at 100% 100%, rgba(20, 58, 40, 0.24), transparent 44%),
    linear-gradient(135deg, rgba(72, 42, 36, 0.72), rgba(29, 22, 19, 0.86)) !important;
}

.house-directory {
  margin-top: 0 !important;
  padding-top: 0 !important;
  border-top: 0 !important;
}

.house-directory-card {
  min-height: 142px !important;
  border-color: rgba(214, 179, 121, 0.28) !important;
  filter: saturate(0.82) brightness(0.96) !important;
}

.house-directory-card.house-gryffindor {
  border-color: rgba(165, 93, 70, 0.42) !important;
  background:
    radial-gradient(circle at 0% 10%, rgba(82, 31, 31, 0.38), transparent 48%),
    radial-gradient(circle at 96% 90%, rgba(116, 76, 39, 0.18), transparent 42%),
    linear-gradient(135deg, rgba(68, 34, 31, 0.84), rgba(39, 28, 25, 0.91)) !important;
}

.house-directory-card.house-slytherin {
  border-color: rgba(79, 122, 86, 0.40) !important;
  background:
    radial-gradient(circle at 0% 10%, rgba(24, 65, 45, 0.40), transparent 48%),
    radial-gradient(circle at 96% 92%, rgba(94, 63, 38, 0.14), transparent 42%),
    linear-gradient(135deg, rgba(28, 54, 42, 0.82), rgba(38, 29, 25, 0.92)) !important;
}

.house-directory-card.house-ravenclaw {
  border-color: rgba(83, 107, 124, 0.42) !important;
  background:
    radial-gradient(circle at 0% 10%, rgba(31, 55, 72, 0.42), transparent 48%),
    radial-gradient(circle at 96% 92%, rgba(94, 63, 38, 0.14), transparent 42%),
    linear-gradient(135deg, rgba(31, 44, 58, 0.84), rgba(37, 29, 27, 0.92)) !important;
}

.house-directory-card.house-hufflepuff {
  border-color: rgba(157, 119, 55, 0.42) !important;
  background:
    radial-gradient(circle at 0% 10%, rgba(101, 73, 34, 0.38), transparent 48%),
    radial-gradient(circle at 96% 92%, rgba(35, 57, 39, 0.14), transparent 42%),
    linear-gradient(135deg, rgba(66, 52, 34, 0.82), rgba(39, 29, 25, 0.92)) !important;
}

.house-directory-badge {
  filter: drop-shadow(0 12px 18px rgba(7, 4, 3, 0.38)) saturate(0.82) brightness(0.92) sepia(0.08) !important;
}

.house-tagline {
  color: rgba(238, 202, 138, 0.78) !important;
}

.house-history,
.house-head,
.house-directory-head .card-sub {
  color: rgba(255, 244, 234, 0.67) !important;
}

@media (max-width: 900px) {
  .dashboard-featured-grid {
    grid-template-columns: 1fr !important;
  }
}

/* =========================================================
   FEATUREBATCH 19 — SHIP TRACKER QUIET ROMANCE POLISH
   Same dashboard theme, less busy: ornate framing, gold emblem,
   cleaner edit placement, and romantic/friendship ship type support.
   ========================================================= */

/* Make the KB emblem carry more weight in the main bar without adding a second ring. */
.brand-mark {
  width: 82px !important;
  height: 82px !important;
  min-width: 82px !important;
  border-radius: 0 !important;
  box-shadow:
    0 18px 34px rgba(18, 10, 8, 0.36),
    0 0 22px rgba(237, 202, 136, 0.16) !important;
}

.kb-header .brand {
  gap: 18px !important;
}

.ship-page {
  position: relative !important;
  overflow: hidden !important;
}

.ship-page::before {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  pointer-events: none !important;
  opacity: 0.24 !important;
  background:
    radial-gradient(circle at 18% 18%, rgba(143, 65, 58, 0.23), transparent 34%),
    radial-gradient(circle at 84% 16%, rgba(33, 73, 50, 0.18), transparent 32%),
    radial-gradient(circle at 42% 76%, rgba(237, 202, 136, 0.08), transparent 36%) !important;
}

.ship-page > * {
  position: relative !important;
  z-index: 1 !important;
}

.ship-layout {
  align-items: start !important;
}

.ship-detail {
  position: relative !important;
  overflow: hidden !important;
  background:
    radial-gradient(circle at 0% 0%, rgba(112, 46, 42, 0.20), transparent 38%),
    radial-gradient(circle at 100% 12%, rgba(23, 61, 43, 0.20), transparent 34%),
    linear-gradient(135deg, rgba(90, 55, 49, 0.64), rgba(47, 31, 28, 0.84)) !important;
}

.ship-detail::after {
  content: "" !important;
  position: absolute !important;
  right: -80px !important;
  top: -95px !important;
  width: 270px !important;
  height: 270px !important;
  pointer-events: none !important;
  opacity: 0.11 !important;
  border-radius: 50% !important;
  background:
    radial-gradient(circle, rgba(237, 202, 136, 0.25), transparent 46%),
    url("./assets/ui/rose-panel-gothic.png") center / cover no-repeat !important;
  filter: saturate(1.15) contrast(1.1) !important;
}

.ship-detail-hero {
  position: relative !important;
  padding: 24px !important;
  border: 2px solid rgba(237, 202, 136, 0.30) !important;
  border-radius: 30px !important;
  background:
    linear-gradient(135deg, rgba(255, 238, 220, 0.070), rgba(31, 52, 40, 0.13)),
    rgba(44, 28, 25, 0.28) !important;
  box-shadow:
    0 24px 58px rgba(22, 12, 10, 0.22),
    inset 0 1px 0 rgba(255, 244, 234, 0.08) !important;
}

.ship-detail-heading {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto !important;
  gap: 18px !important;
  align-items: start !important;
}

.ship-title {
  font-size: 42px !important;
  line-height: 1 !important;
  margin-top: 8px !important;
  margin-bottom: 12px !important;
}

.ship-actions {
  display: flex !important;
  flex-wrap: wrap !important;
  justify-content: flex-end !important;
  gap: 10px !important;
}

.ship-type-ribbon {
  display: inline-flex !important;
  align-items: center !important;
  gap: 10px !important;
  width: fit-content !important;
  padding: 8px 14px !important;
  border-radius: 999px !important;
  border: 1.5px solid rgba(237, 202, 136, 0.34) !important;
  background:
    radial-gradient(circle at 0% 0%, rgba(237, 202, 136, 0.16), transparent 40%),
    rgba(38, 24, 21, 0.36) !important;
  color: #f2d69b !important;
  font-size: 12px !important;
  font-weight: 800 !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
}

.ship-type-ribbon-icon {
  display: inline-grid !important;
  place-items: center !important;
  width: 22px !important;
  height: 22px !important;
}

.ship-summary {
  max-width: 920px !important;
  margin: 18px 0 0 !important;
}

.ship-pair {
  position: relative !important;
  margin-top: 26px !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) 96px minmax(0, 1fr) !important;
  align-items: center !important;
  gap: 22px !important;
}

.ship-pair::before {
  content: "" !important;
  position: absolute !important;
  left: 24% !important;
  right: 24% !important;
  top: 50% !important;
  height: 1px !important;
  background: linear-gradient(to right, transparent, rgba(237, 202, 136, 0.45), transparent) !important;
  pointer-events: none !important;
}

.ship-person {
  position: relative !important;
  min-height: 140px !important;
  display: grid !important;
  grid-template-columns: auto minmax(0, 1fr) !important;
  align-items: center !important;
  gap: 16px !important;
  padding: 22px !important;
  border: 2px solid rgba(237, 202, 136, 0.25) !important;
  border-radius: 26px !important;
  background:
    radial-gradient(circle at 0% 0%, color-mix(in srgb, var(--house-color, #eacb89) 32%, transparent), transparent 38%),
    linear-gradient(135deg, rgba(111, 70, 61, 0.62), rgba(51, 34, 30, 0.75)) !important;
  box-shadow: 0 16px 38px rgba(22, 12, 10, 0.18) !important;
}

.ship-person .avatar-thumb {
  width: 68px !important;
  height: 68px !important;
  min-width: 68px !important;
  border-radius: 18px !important;
  box-shadow: 0 0 0 2px rgba(237, 202, 136, 0.24), 0 12px 20px rgba(16, 9, 7, 0.26) !important;
}

.ship-person-copy strong,
.ship-person strong {
  display: block !important;
  font-family: Georgia, "Times New Roman", serif !important;
  font-size: 27px !important;
  line-height: 1.05 !important;
  color: #fff8ef !important;
}

.ship-person-copy small,
.ship-person small {
  display: block !important;
  margin-top: 8px !important;
  color: var(--muted) !important;
  line-height: 1.35 !important;
}

.ship-heart-large {
  position: relative !important;
  z-index: 2 !important;
  display: grid !important;
  place-items: center !important;
  width: 92px !important;
  height: 92px !important;
  margin: 0 auto !important;
  border-radius: 50% !important;
  border: 2px solid rgba(237, 202, 136, 0.42) !important;
  background:
    radial-gradient(circle at 35% 25%, rgba(255, 244, 214, 0.24), transparent 26%),
    radial-gradient(circle, rgba(137, 77, 42, 0.72), rgba(39, 24, 21, 0.88)) !important;
  color: #edca88 !important;
  box-shadow:
    0 18px 38px rgba(22, 12, 10, 0.34),
    inset 0 1px 0 rgba(255, 244, 234, 0.18),
    0 0 32px rgba(237, 202, 136, 0.11) !important;
}

.ship-heart-large::before,
.ship-heart-large::after {
  content: "" !important;
  position: absolute !important;
  inset: 11px !important;
  border-radius: 50% !important;
  border: 1px solid rgba(255, 244, 218, 0.16) !important;
}

.ship-heart-large::after {
  inset: 22px !important;
  border-color: rgba(237, 202, 136, 0.18) !important;
}

.ship-type-svg {
  width: 54px !important;
  height: 54px !important;
  color: #edca88 !important;
  filter: drop-shadow(0 4px 8px rgba(18, 10, 8, 0.55)) !important;
}

.ship-type-symbol.friendship {
  display: grid !important;
  place-items: center !important;
  width: 54px !important;
  height: 54px !important;
  color: #edca88 !important;
  font-family: Georgia, "Times New Roman", serif !important;
  font-size: 44px !important;
  line-height: 1 !important;
  text-shadow: 0 4px 9px rgba(18, 10, 8, 0.55) !important;
}

.ship-heart {
  display: grid !important;
  place-items: center !important;
  width: 46px !important;
  height: 46px !important;
  border-radius: 16px !important;
  border: 1.5px solid rgba(237, 202, 136, 0.26) !important;
  background: rgba(36, 24, 21, 0.34) !important;
  color: #edca88 !important;
}

.ship-heart .ship-type-svg,
.ship-heart .ship-type-symbol.friendship {
  width: 27px !important;
  height: 27px !important;
  font-size: 24px !important;
}

.ship-list-item small {
  opacity: 0.86 !important;
}

.ship-meta-row {
  margin-top: 20px !important;
}

.ship-timeline-head {
  margin-top: 30px !important;
  padding-top: 22px !important;
  border-top: 1.5px solid rgba(237, 202, 136, 0.20) !important;
}

.ship-timeline-head .card-title {
  font-size: 34px !important;
  margin-top: 6px !important;
}

.ship-thread {
  border-width: 2px !important;
  background:
    radial-gradient(circle at 0% 0%, rgba(112, 46, 42, 0.22), transparent 38%),
    radial-gradient(circle at 100% 0%, rgba(23, 61, 43, 0.14), transparent 32%),
    linear-gradient(135deg, rgba(75, 45, 39, 0.78), rgba(43, 28, 25, 0.84)) !important;
}

.ship-thread h4 {
  font-size: 31px !important;
}

.ship-thread small {
  color: #e6c286 !important;
  letter-spacing: 0.16em !important;
}

.ship-type-friendship .ship-heart-large,
.ship-type-friendship .ship-heart {
  color: #e8cb8f !important;
}

.ship-type-friendship .ship-type-ribbon {
  border-color: rgba(157, 188, 162, 0.34) !important;
  background:
    radial-gradient(circle at 0% 0%, rgba(34, 88, 61, 0.20), transparent 40%),
    rgba(38, 24, 21, 0.36) !important;
}

@media (max-width: 900px) {
  .ship-detail-heading {
    grid-template-columns: 1fr !important;
  }

  .ship-actions {
    justify-content: flex-start !important;
  }

  .ship-pair {
    grid-template-columns: 1fr !important;
  }

  .ship-pair::before {
    display: none !important;
  }

  .ship-heart-large {
    width: 76px !important;
    height: 76px !important;
  }
}


/* =========================================================
   SHIP TRACKER PAIR COMFORT FIX — featurebatch 20
   Wider cards, larger portraits, and centered heart without name clipping.
   ========================================================= */

/* Let the pair breathe without forcing the heart to steal a whole column. */
.ship-pair {
  position: relative !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) !important;
  gap: clamp(84px, 10vw, 118px) !important;
  align-items: stretch !important;
  margin-top: 30px !important;
  width: 100% !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
  overflow: visible !important;
}

.ship-pair::before {
  left: 24% !important;
  right: 24% !important;
  top: 50% !important;
  z-index: 0 !important;
}

/* Bigger, sturdier person cards. */
.ship-person {
  position: relative !important;
  z-index: 1 !important;
  min-width: 0 !important;
  width: 100% !important;
  min-height: 170px !important;
  display: grid !important;
  grid-template-columns: 92px minmax(0, 1fr) !important;
  align-items: center !important;
  gap: 22px !important;
  padding: 26px 28px !important;
  box-sizing: border-box !important;
  overflow: visible !important;
}

/* Larger portraits so faces read clearly. */
.ship-person .avatar-thumb,
.ship-person img.avatar-thumb {
  width: 84px !important;
  height: 84px !important;
  min-width: 84px !important;
  border-radius: 20px !important;
  object-fit: cover !important;
}

/* Give the text column permission to shrink and wrap normally. */
.ship-person > div,
.ship-person .ship-person-copy {
  min-width: 0 !important;
  max-width: 100% !important;
}

.ship-person-copy strong,
.ship-person strong,
.ship-person h3,
.ship-person .card-title {
  display: block !important;
  max-width: 100% !important;
  white-space: normal !important;
  overflow: visible !important;
  text-overflow: clip !important;
  overflow-wrap: normal !important;
  word-break: normal !important;
  hyphens: none !important;
  font-size: clamp(29px, 2.55vw, 38px) !important;
  line-height: 0.98 !important;
  margin: 0 0 10px !important;
}

.ship-person-copy small,
.ship-person small,
.ship-person p {
  display: block !important;
  max-width: 100% !important;
  white-space: normal !important;
  overflow: visible !important;
  line-height: 1.35 !important;
}

/* Center heart floats between cards instead of consuming layout width. */
.ship-heart-large {
  position: absolute !important;
  z-index: 3 !important;
  left: 50% !important;
  top: 50% !important;
  transform: translate(-50%, -50%) !important;
  width: 112px !important;
  height: 112px !important;
  min-width: 112px !important;
  min-height: 112px !important;
  display: grid !important;
  place-items: center !important;
  margin: 0 !important;
  padding: 0 !important;
  line-height: 0 !important;
  box-sizing: border-box !important;
}

.ship-heart-large > * {
  display: grid !important;
  place-items: center !important;
  line-height: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
}

.ship-heart-large svg,
.ship-heart-large .ship-type-svg,
.ship-heart-large .ship-type-symbol {
  width: 58px !important;
  height: 58px !important;
  min-width: 58px !important;
  min-height: 58px !important;
  display: block !important;
  margin: 0 !important;
  transform: translateY(1px) !important;
}

/* Small ribbon icon stays small; the center medallion stays large. */
.ship-type-ribbon-icon .ship-type-svg,
.ship-type-ribbon-icon .ship-type-svg.romantic,
.ship-type-ribbon-icon .ship-type-symbol.friendship {
  width: 18px !important;
  height: 18px !important;
  min-width: 18px !important;
  max-width: 18px !important;
  font-size: 18px !important;
  line-height: 1 !important;
  transform: none !important;
}

@media (max-width: 980px) {
  .ship-pair {
    grid-template-columns: 1fr !important;
    gap: 22px !important;
  }

  .ship-heart-large {
    position: relative !important;
    left: auto !important;
    top: auto !important;
    transform: none !important;
    margin: 0 auto !important;
    width: 96px !important;
    height: 96px !important;
    min-width: 96px !important;
    min-height: 96px !important;
  }

  .ship-person {
    grid-template-columns: 84px minmax(0, 1fr) !important;
    min-height: 150px !important;
  }
}

@media (max-width: 620px) {
  .ship-person {
    grid-template-columns: 1fr !important;
    text-align: center !important;
    justify-items: center !important;
  }
}

/* =========================================================
   FEATUREBATCH 21 — SHIP TRACKER PAIR PORTRAIT CARDS
   Fixes long names by making each ship card a portrait-style card.
   ========================================================= */

.ship-detail .ship-pair {
  position: relative !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) !important;
  gap: 64px !important;
  align-items: stretch !important;
  width: 100% !important;
  max-width: 100% !important;
  margin: 30px 0 22px !important;
  padding: 0 !important;
  overflow: visible !important;
}

.ship-detail .ship-pair::before {
  content: "" !important;
  position: absolute !important;
  left: 50% !important;
  top: 50% !important;
  width: 72px !important;
  height: 1px !important;
  transform: translate(-50%, -50%) !important;
  background: linear-gradient(90deg, transparent, rgba(241, 200, 115, .52), transparent) !important;
  z-index: 1 !important;
}

.ship-detail .ship-pair > .ship-person {
  position: relative !important;
  z-index: 2 !important;
  min-width: 0 !important;
  width: 100% !important;
  max-width: 100% !important;
  min-height: 235px !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 14px !important;
  text-align: center !important;
  padding: 30px 28px 28px !important;
  box-sizing: border-box !important;
  overflow: hidden !important;
}

.ship-detail .ship-pair > .ship-person:first-child {
  padding-right: 52px !important;
}

.ship-detail .ship-pair > .ship-person:last-child {
  padding-left: 52px !important;
}

.ship-detail .ship-person .avatar-thumb,
.ship-detail .ship-person img.avatar-thumb {
  width: 96px !important;
  height: 96px !important;
  min-width: 96px !important;
  border-radius: 24px !important;
  object-fit: cover !important;
  margin: 0 !important;
  box-shadow:
    0 12px 28px rgba(16, 8, 6, .34),
    0 0 0 2px rgba(244, 217, 157, .30) !important;
}

.ship-detail .ship-person .ship-person-copy,
.ship-detail .ship-person > div:not(.avatar-thumb) {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  display: block !important;
  text-align: center !important;
}

.ship-detail .ship-person-copy strong,
.ship-detail .ship-person strong,
.ship-detail .ship-person h3,
.ship-detail .ship-person .card-title {
  display: block !important;
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 0 9px !important;
  white-space: normal !important;
  overflow: visible !important;
  text-overflow: clip !important;
  overflow-wrap: normal !important;
  word-break: keep-all !important;
  hyphens: none !important;
  font-size: clamp(27px, 2.35vw, 36px) !important;
  line-height: 1.02 !important;
  text-align: center !important;
}

.ship-detail .ship-person-copy small,
.ship-detail .ship-person small,
.ship-detail .ship-person p {
  display: block !important;
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 !important;
  white-space: normal !important;
  overflow: visible !important;
  overflow-wrap: normal !important;
  word-break: normal !important;
  line-height: 1.35 !important;
  text-align: center !important;
}

.ship-detail .ship-heart-large {
  position: absolute !important;
  z-index: 5 !important;
  left: 50% !important;
  top: 50% !important;
  transform: translate(-50%, -50%) !important;
  width: 112px !important;
  height: 112px !important;
  min-width: 112px !important;
  min-height: 112px !important;
  display: grid !important;
  place-items: center !important;
  margin: 0 !important;
  padding: 0 !important;
  line-height: 0 !important;
  pointer-events: none !important;
}

.ship-detail .ship-heart-large > * {
  display: grid !important;
  place-items: center !important;
  margin: 0 !important;
  padding: 0 !important;
  line-height: 0 !important;
}

.ship-detail .ship-heart-large svg,
.ship-detail .ship-heart-large .ship-type-svg,
.ship-detail .ship-heart-large .ship-type-symbol {
  width: 58px !important;
  height: 58px !important;
  min-width: 58px !important;
  min-height: 58px !important;
  margin: 0 !important;
  transform: translateY(1px) !important;
}

@media (max-width: 980px) {
  .ship-detail .ship-pair {
    grid-template-columns: 1fr !important;
    gap: 22px !important;
  }

  .ship-detail .ship-pair::before {
    display: none !important;
  }

  .ship-detail .ship-heart-large {
    position: relative !important;
    left: auto !important;
    top: auto !important;
    transform: none !important;
    margin: -4px auto !important;
    pointer-events: auto !important;
  }

  .ship-detail .ship-pair > .ship-person,
  .ship-detail .ship-pair > .ship-person:first-child,
  .ship-detail .ship-pair > .ship-person:last-child {
    padding: 28px !important;
  }
}


/* =========================================================
   FEATUREBATCH 22 — SHIP PAIR ACTUAL PORTRAIT OVERRIDE
   This block intentionally sits last and overrides the older horizontal rules.
   ========================================================= */

html body .ship-detail .ship-pair {
  position: relative !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) !important;
  gap: 76px !important;
  align-items: stretch !important;
  width: 100% !important;
  max-width: 100% !important;
  margin: 32px 0 22px !important;
  padding: 0 8px !important;
  box-sizing: border-box !important;
  overflow: visible !important;
}

html body .ship-detail .ship-pair > .ship-person,
html body .ship-detail .ship-pair > button.ship-person,
html body .ship-detail .ship-pair > .ship-person:first-child,
html body .ship-detail .ship-pair > .ship-person:last-child {
  position: relative !important;
  z-index: 2 !important;
  width: 100% !important;
  min-width: 0 !important;
  max-width: none !important;
  min-height: 250px !important;
  box-sizing: border-box !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 14px !important;
  text-align: center !important;
  padding: 30px 30px 28px !important;
  overflow: hidden !important;
}

html body .ship-detail .ship-person .avatar-thumb,
html body .ship-detail .ship-person img.avatar-thumb {
  width: 108px !important;
  height: 108px !important;
  min-width: 108px !important;
  border-radius: 24px !important;
  object-fit: cover !important;
  margin: 0 auto !important;
}

html body .ship-detail .ship-person strong,
html body .ship-detail .ship-person h3,
html body .ship-detail .ship-person .card-title {
  display: block !important;
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 0 8px !important;
  padding: 0 !important;
  text-align: center !important;
  white-space: normal !important;
  overflow: visible !important;
  text-overflow: clip !important;
  overflow-wrap: normal !important;
  word-break: normal !important;
  hyphens: none !important;
  font-size: clamp(27px, 2.1vw, 34px) !important;
  line-height: 1.04 !important;
}

html body .ship-detail .ship-person small,
html body .ship-detail .ship-person p {
  display: block !important;
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 !important;
  text-align: center !important;
  white-space: normal !important;
  overflow-wrap: normal !important;
  word-break: normal !important;
  line-height: 1.35 !important;
}

html body .ship-detail .ship-heart-large {
  position: absolute !important;
  z-index: 6 !important;
  left: 50% !important;
  top: 50% !important;
  transform: translate(-50%, -50%) !important;
  width: 118px !important;
  height: 118px !important;
  min-width: 118px !important;
  min-height: 118px !important;
  display: grid !important;
  place-items: center !important;
  margin: 0 !important;
  padding: 0 !important;
  line-height: 0 !important;
  pointer-events: none !important;
}

html body .ship-detail .ship-heart-large > *,
html body .ship-detail .ship-heart-large svg,
html body .ship-detail .ship-heart-large .ship-type-svg,
html body .ship-detail .ship-heart-large .ship-type-symbol {
  display: grid !important;
  place-items: center !important;
  margin: 0 !important;
  line-height: 0 !important;
}

html body .ship-detail .ship-heart-large svg,
html body .ship-detail .ship-heart-large .ship-type-svg,
html body .ship-detail .ship-heart-large .ship-type-symbol {
  width: 62px !important;
  height: 62px !important;
  min-width: 62px !important;
  min-height: 62px !important;
  transform: translateY(1px) !important;
}

html body .ship-detail .ship-meta-row {
  margin-top: 24px !important;
}

@media (max-width: 980px) {
  html body .ship-detail .ship-pair {
    grid-template-columns: 1fr !important;
    gap: 18px !important;
    padding: 0 !important;
  }

  html body .ship-detail .ship-heart-large {
    position: relative !important;
    left: auto !important;
    top: auto !important;
    transform: none !important;
    margin: -4px auto !important;
  }
}
