/* Final xianxia repaint layer.
   This file is loaded after page-local CSS so the visual skin stays coherent
   without changing existing HTML actions or gameplay logic. */
:root {
  --xx-ink: #061013;
  --xx-ink-2: #0b1919;
  --xx-jade: #2f6f65;
  --xx-jade-soft: rgba(86, 180, 157, 0.18);
  --xx-gold: #d7a957;
  --xx-gold-2: #ffe4a3;
  --xx-red: #8d3b2f;
  --xx-paper: #efe0bf;
  --xx-muted: #bda988;
  --xx-line: rgba(223, 181, 95, 0.54);
  --xx-line-soft: rgba(223, 181, 95, 0.25);
  --xx-panel: rgba(7, 15, 16, 0.9);
  --xx-panel-2: rgba(19, 34, 31, 0.88);
  --xx-bg-image: url("../images/ui/xianxia-sect-bg.webp");
}

/* Adventure screen: scenic map route layout */
body.adventure-page {
  --adventure-panel: rgba(2, 8, 9, 0.78);
  --adventure-line: rgba(226, 185, 95, 0.48);
  --adventure-gold: #f4d878;
  --adventure-ink: #061011;
  --adventure-text: #fff3c7;
  --adventure-muted: #b6c6bc;
  min-height: 100dvh !important;
  overflow: hidden !important;
  background:
    radial-gradient(ellipse at 50% 0%, rgba(235, 201, 116, 0.12), transparent 36%),
    linear-gradient(90deg, rgba(0, 9, 11, 0.92), rgba(3, 13, 13, 0.58) 48%, rgba(0, 7, 9, 0.92)),
    url("../images/map/generated/qingyunxianshan.webp") center top / auto 100% no-repeat fixed !important;
  color: var(--adventure-text) !important;
}

body.adventure-page::before {
  content: "" !important;
  position: fixed !important;
  inset: 0 !important;
  pointer-events: none !important;
  z-index: 0 !important;
  background:
    linear-gradient(180deg, rgba(0, 0, 0, 0.08), rgba(0, 0, 0, 0.54)),
    radial-gradient(ellipse at 50% 48%, transparent 0 34%, rgba(0, 0, 0, 0.38) 78%) !important;
}

body.adventure-page .main-container {
  width: min(100%, 700px) !important;
  height: 100dvh !important;
  margin: 0 auto !important;
  padding: 12px 12px 80px !important;
  display: grid !important;
  grid-template-rows: auto auto minmax(0, 1fr) !important;
  gap: 10px !important;
  overflow: hidden !important;
  position: relative !important;
  z-index: 1 !important;
  background:
    linear-gradient(90deg, rgba(0, 0, 0, 0.28), transparent 18%, transparent 82%, rgba(0, 0, 0, 0.28)),
    rgba(0, 6, 8, 0.16) !important;
}

body.adventure-page .page-header {
  margin: 0 !important;
  padding: 13px 16px 12px !important;
  border-radius: 6px 18px 6px 18px !important;
  border: 1px solid var(--adventure-line) !important;
  background:
    linear-gradient(90deg, rgba(15, 31, 27, 0.9), rgba(5, 13, 13, 0.72)),
    radial-gradient(ellipse at 12% 0%, rgba(255, 228, 151, 0.15), transparent 38%) !important;
  box-shadow: 0 10px 22px rgba(0, 0, 0, 0.34), inset 0 1px 0 rgba(255, 239, 193, 0.08) !important;
  text-align: left !important;
  backdrop-filter: none !important;
}

body.adventure-page .adventure-title-block {
  display: grid !important;
  grid-template-columns: auto 1fr !important;
  grid-template-areas:
    "kicker title"
    "kicker subtitle" !important;
  gap: 2px 11px !important;
  align-items: center !important;
}

body.adventure-page .page-kicker {
  grid-area: kicker !important;
  writing-mode: vertical-rl !important;
  letter-spacing: 0 !important;
  min-height: 48px !important;
  padding: 6px 4px !important;
  color: #1d1304 !important;
  font-size: 11px !important;
  font-weight: 800 !important;
  border-radius: 2px !important;
  background: linear-gradient(180deg, #fff0ad, #c28b2b) !important;
}

body.adventure-page .page-title {
  grid-area: title !important;
  margin: 0 !important;
  color: #fff0b1 !important;
  font-size: 23px !important;
  line-height: 1.05 !important;
  text-align: left !important;
  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.86), 0 0 14px rgba(241, 204, 112, 0.28) !important;
}

body.adventure-page .page-subtitle {
  grid-area: subtitle !important;
  color: #cfdbc8 !important;
  font-size: 12px !important;
  line-height: 1.35 !important;
}

body.adventure-page .adventure-tabs {
  margin: 0 !important;
  padding: 4px !important;
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 4px !important;
  border: 1px solid rgba(226, 185, 95, 0.34) !important;
  border-radius: 999px !important;
  background: rgba(1, 7, 8, 0.76) !important;
  box-shadow: inset 0 1px 0 rgba(255, 239, 193, 0.06) !important;
}

body.adventure-page .tab {
  height: 36px !important;
  padding: 0 10px !important;
  border: 0 !important;
  border-radius: 999px !important;
  background: transparent !important;
  color: #b9c8bf !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  letter-spacing: 0 !important;
}

body.adventure-page .tab.active {
  color: #1b1204 !important;
  background: linear-gradient(180deg, #fff0ad, #c58a25) !important;
  text-shadow: none !important;
  box-shadow: 0 7px 16px rgba(0, 0, 0, 0.28), inset 0 1px 0 rgba(255, 255, 255, 0.42) !important;
}

body.adventure-page .tab.active::after {
  display: none !important;
}

body.adventure-page .tab-content {
  min-height: 0 !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  padding: 1px 2px 10px !important;
}

body.adventure-page .tab-content:not(.active) {
  display: none !important;
}

body.adventure-page .tab-content.active,
body.adventure-page .map-areas {
  display: grid !important;
  grid-template-columns: 1fr !important;
  align-content: start !important;
  gap: 12px !important;
}

body.adventure-page .map-area {
  min-height: 214px !important;
  margin: 0 !important;
  padding: 14px !important;
  display: grid !important;
  grid-template-columns: 1fr auto !important;
  grid-template-rows: auto 1fr auto auto !important;
  gap: 9px !important;
  overflow: hidden !important;
  position: relative !important;
  border-radius: 18px 4px 18px 4px !important;
  border: 1px solid rgba(236, 200, 116, 0.58) !important;
  background-image: none !important;
  background-color: #061011 !important;
  box-shadow: 0 15px 28px rgba(0, 0, 0, 0.38), inset 0 0 0 1px rgba(255, 239, 193, 0.06) !important;
  transition: transform 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease !important;
  backdrop-filter: none !important;
}

body.adventure-page .map-area::before {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  z-index: 0 !important;
  background-image: var(--map-art) !important;
  background-size: cover !important;
  background-position: center !important;
  transform: scale(1.01) !important;
}

body.adventure-page .map-artwork {
  position: absolute !important;
  inset: 0 !important;
  z-index: 0 !important;
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center !important;
  opacity: 1 !important;
  transform: scale(1.01) !important;
  pointer-events: none !important;
}

body.adventure-page .map-area::after {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  z-index: 1 !important;
  pointer-events: none !important;
  background:
    linear-gradient(90deg, rgba(1, 7, 8, 0.68) 0%, rgba(1, 7, 8, 0.24) 44%, rgba(1, 7, 8, 0.02) 76%),
    linear-gradient(180deg, rgba(0, 0, 0, 0.04), rgba(0, 0, 0, 0.36)),
    radial-gradient(ellipse at 78% 35%, rgba(255, 223, 132, 0.08), transparent 38%) !important;
}

body.adventure-page .map-area:first-child {
  min-height: 268px !important;
}

body.adventure-page .map-area:hover {
  transform: translateY(-1px) !important;
  border-color: rgba(255, 229, 154, 0.82) !important;
  box-shadow: 0 18px 34px rgba(0, 0, 0, 0.46), 0 0 22px rgba(218, 171, 76, 0.13) !important;
}

body.adventure-page .map-area.locked {
  opacity: 1 !important;
  filter: saturate(0.72) brightness(0.82) !important;
  border-color: rgba(132, 141, 130, 0.42) !important;
}

body.adventure-page .map-area.locked::after {
  background:
    linear-gradient(90deg, rgba(0, 0, 0, 0.76), rgba(4, 10, 12, 0.46) 55%, rgba(0, 0, 0, 0.26)),
    repeating-linear-gradient(135deg, rgba(255, 255, 255, 0.025) 0 1px, transparent 1px 9px) !important;
}

body.adventure-page .map-overlay {
  display: none !important;
}

body.adventure-page .map-area > * {
  position: relative !important;
  z-index: 2 !important;
}

body.adventure-page .map-area > .map-artwork {
  position: absolute !important;
  z-index: 0 !important;
}

body.adventure-page .area-header {
  grid-column: 1 / 3 !important;
  display: grid !important;
  grid-template-columns: 1fr auto !important;
  gap: 10px !important;
  align-items: start !important;
  margin: 0 !important;
}

body.adventure-page .area-name {
  width: fit-content !important;
  max-width: 100% !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  color: #fff1b4 !important;
  font-size: 23px !important;
  line-height: 1.1 !important;
  font-weight: 900 !important;
  text-align: left !important;
  text-shadow: 0 2px 10px rgba(0, 0, 0, 0.9), 0 0 16px rgba(241, 205, 105, 0.32) !important;
  backdrop-filter: none !important;
}

body.adventure-page .area-progress {
  min-width: 62px !important;
  padding: 5px 9px !important;
  border-radius: 999px !important;
  border: 1px solid rgba(235, 201, 116, 0.55) !important;
  background: rgba(1, 7, 8, 0.64) !important;
  color: #f6dc87 !important;
  font-size: 12px !important;
  text-align: center !important;
  box-shadow: inset 0 1px 0 rgba(255, 242, 193, 0.08) !important;
}

body.adventure-page .area-description {
  grid-column: 1 / 2 !important;
  align-self: end !important;
  max-width: 430px !important;
  margin: 0 !important;
  padding: 10px 12px !important;
  border-radius: 10px 2px 10px 2px !important;
  border: 1px solid rgba(226, 185, 95, 0.24) !important;
  background: rgba(1, 8, 10, 0.54) !important;
  color: #dce6da !important;
  font-size: 13px !important;
  line-height: 1.55 !important;
  text-align: left !important;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.86) !important;
  backdrop-filter: none !important;
}

body.adventure-page .map-limits {
  grid-column: 1 / 2 !important;
  justify-content: flex-start !important;
  flex-wrap: wrap !important;
  gap: 7px !important;
  margin: 0 !important;
}

body.adventure-page .map-limit,
body.adventure-page .info-item {
  padding: 5px 9px !important;
  border-radius: 999px !important;
  background: rgba(1, 7, 8, 0.64) !important;
  border: 1px solid rgba(226, 185, 95, 0.28) !important;
  color: #e6dba6 !important;
  font-size: 11px !important;
  box-shadow: inset 0 1px 0 rgba(255, 242, 193, 0.06) !important;
  backdrop-filter: none !important;
}

body.adventure-page .map-limit.entry {
  color: #f1bd72 !important;
  border-color: rgba(213, 132, 54, 0.46) !important;
}

body.adventure-page .map-limit.realm {
  color: #b7f1dc !important;
  border-color: rgba(96, 196, 160, 0.42) !important;
}

body.adventure-page .area-info {
  grid-column: 1 / 2 !important;
  justify-content: flex-start !important;
  gap: 7px !important;
  margin: 0 !important;
}

body.adventure-page .info-value {
  color: #edf3dc !important;
  font-size: 11px !important;
  text-shadow: none !important;
}

body.adventure-page .enter-button {
  grid-column: 2 / 3 !important;
  grid-row: 3 / 5 !important;
  align-self: end !important;
  justify-self: end !important;
  min-width: 104px !important;
  height: 42px !important;
  margin: 0 !important;
  padding: 0 18px !important;
  border: 1px solid rgba(255, 238, 177, 0.72) !important;
  border-radius: 999px !important;
  background: linear-gradient(180deg, #fff0ad 0%, #d5a13e 48%, #9a5d18 100%) !important;
  color: #1d1203 !important;
  font-size: 14px !important;
  font-weight: 900 !important;
  box-shadow: 0 10px 20px rgba(0, 0, 0, 0.38), inset 0 1px 0 rgba(255, 255, 255, 0.48) !important;
  text-shadow: none !important;
}

body.adventure-page .enter-button:hover {
  transform: translateY(-1px) !important;
  box-shadow: 0 12px 24px rgba(0, 0, 0, 0.45), 0 0 18px rgba(244, 216, 120, 0.24) !important;
}

body.adventure-page .enter-button:disabled {
  color: #9da6a0 !important;
  border-color: rgba(141, 148, 141, 0.34) !important;
  background: linear-gradient(180deg, rgba(84, 91, 84, 0.92), rgba(42, 45, 40, 0.92)) !important;
  box-shadow: none !important;
}

body.adventure-page .lock-icon {
  top: 52px !important;
  right: 16px !important;
  width: 34px !important;
  height: 34px !important;
  padding: 0 !important;
  border-radius: 999px !important;
  background-color: rgba(3, 7, 8, 0.7) !important;
  border: 1px solid rgba(194, 92, 76, 0.55) !important;
  box-shadow: 0 8px 18px rgba(0, 0, 0, 0.36) !important;
}

body.adventure-page .empty-state {
  margin: 0 !important;
  padding: 32px 16px !important;
  border-radius: 14px 4px 14px 4px !important;
  border: 1px dashed rgba(226, 185, 95, 0.38) !important;
  background: rgba(2, 8, 9, 0.62) !important;
  color: #d8c98f !important;
}

body.adventure-page .stage-selector-overlay {
  padding: 16px !important;
  background:
    radial-gradient(ellipse at 50% 26%, rgba(225, 190, 106, 0.16), transparent 34%),
    rgba(0, 0, 0, 0.82) !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

body.adventure-page .stage-selector-dialog {
  width: min(92vw, 420px) !important;
  padding: 18px !important;
  border: 1px solid rgba(239, 205, 127, 0.72) !important;
  border-radius: 18px 4px 18px 4px !important;
  color: #fff0bd !important;
  background:
    linear-gradient(180deg, rgba(255, 236, 177, 0.08), transparent 26%),
    linear-gradient(145deg, rgba(25, 45, 40, 0.96), rgba(4, 11, 12, 0.98)) !important;
  box-shadow: 0 24px 56px rgba(0, 0, 0, 0.58), inset 0 1px 0 rgba(255, 242, 194, 0.12) !important;
}

body.adventure-page .stage-selector-dialog h3 {
  margin: 0 0 12px !important;
  color: #ffe4a3 !important;
  font-size: 18px !important;
  text-shadow: 0 2px 10px rgba(0, 0, 0, 0.8) !important;
}

body.adventure-page .stage-selector-dialog p {
  margin: 0 0 14px !important;
  color: #c9d5c9 !important;
  font-size: 13px !important;
  line-height: 1.5 !important;
}

body.adventure-page .stage-selector-dialog label {
  color: #ffe4a3 !important;
}

body.adventure-page #targetStage {
  width: 94px !important;
  height: 38px !important;
  border: 1px solid rgba(226, 185, 95, 0.62) !important;
  border-radius: 10px 2px 10px 2px !important;
  background: rgba(1, 7, 8, 0.78) !important;
  color: #fff3c7 !important;
  font-weight: 800 !important;
}

body.adventure-page #confirmEnterBtn,
body.adventure-page #cancelEnterBtn {
  min-width: 112px !important;
  height: 38px !important;
  margin: 0 5px !important;
  padding: 0 16px !important;
  border-radius: 999px !important;
  font-weight: 800 !important;
}

body.adventure-page #cancelEnterBtn {
  border-color: rgba(202, 215, 199, 0.28) !important;
  color: #dfe8d6 !important;
  background: linear-gradient(180deg, rgba(39, 52, 48, 0.98), rgba(13, 20, 20, 0.98)) !important;
  box-shadow: none !important;
}

@media (max-width: 520px) {
  body.adventure-page .main-container {
    padding: 9px 9px 76px !important;
    gap: 8px !important;
  }

  body.adventure-page .page-header {
    padding: 11px 12px !important;
  }

  body.adventure-page .page-title {
    font-size: 20px !important;
  }

  body.adventure-page .page-subtitle {
    font-size: 11px !important;
  }

  body.adventure-page .map-area,
  body.adventure-page .map-area:first-child {
    min-height: 218px !important;
    padding: 12px !important;
  }

  body.adventure-page .area-name {
    font-size: 20px !important;
  }

  body.adventure-page .area-description {
    grid-column: 1 / 3 !important;
    max-width: none !important;
    font-size: 12px !important;
    padding: 9px 10px !important;
  }

  body.adventure-page .map-limits,
  body.adventure-page .area-info {
    grid-column: 1 / 3 !important;
  }

  body.adventure-page .enter-button {
    grid-column: 2 / 3 !important;
    grid-row: 4 / 5 !important;
    min-width: 88px !important;
    height: 38px !important;
    padding: 0 14px !important;
  }
}

html,
body {
  background-color: var(--xx-ink) !important;
}

body {
  color: var(--xx-paper) !important;
  font-family: "Microsoft YaHei", "PingFang SC", "Noto Serif SC", serif !important;
  background:
    linear-gradient(180deg, rgba(2, 7, 8, 0.28), rgba(2, 7, 8, 0.82)),
    var(--xx-bg-image) center top / auto 100% no-repeat fixed !important;
}

body::before {
  background:
    radial-gradient(ellipse at 50% 18%, rgba(255, 222, 139, 0.18), transparent 34%),
    linear-gradient(180deg, rgba(2, 7, 8, 0.18), rgba(2, 7, 8, 0.78) 72%, rgba(1, 4, 5, 0.94)) !important;
}

.main-container,
.game-interface,
.page-container,
.container {
  color: var(--xx-paper) !important;
}

body :is(.user-info-bar, .game-world, .menu-container, .attribute-panel, .attributes-section,
.cultivation-panel, .shop-container, .shop-section, .alchemy-container, .alchemy-section,
.equipment-container, .equipment-panel, .settings-container, .settings-section, .sect-container,
.sect-panel, .beast-hall-container, .beast-panel, .secret-realms-container, .realm-card,
.adventure-container, .adventure-panel, .spirit-root-container, .spirit-root-panel,
.refinement-container, .refinement-panel, .character-creation-container, .character-panel,
.arena-victory-panel, .modal-content, .popup-container, .loading-panel,
.inventory-section, .character-equipment-section, .equipment-slots-area) {
  color: var(--xx-paper) !important;
  background:
    linear-gradient(180deg, rgba(255, 236, 176, 0.055), transparent 18%),
    linear-gradient(145deg, rgba(25, 45, 40, 0.9), rgba(5, 12, 13, 0.94) 56%, rgba(3, 8, 9, 0.98)) !important;
  border: 1px solid var(--xx-line) !important;
  border-radius: 10px 2px 10px 2px !important;
  box-shadow:
    0 18px 38px rgba(0, 0, 0, 0.45),
    inset 0 1px 0 rgba(255, 242, 194, 0.12),
    inset 0 0 0 1px rgba(255, 244, 210, 0.035) !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

body :is(.header, .page-header, .section-header, .shop-header, .sect-header,
.settings-header, .attributes-header, .modal-header, .popup-header) {
  background:
    linear-gradient(90deg, rgba(7, 13, 14, 0.94), rgba(36, 52, 42, 0.86), rgba(7, 13, 14, 0.94)) !important;
  border: 1px solid var(--xx-line) !important;
  border-radius: 10px 2px 10px 2px !important;
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.28), inset 0 1px 0 rgba(255, 236, 174, 0.12) !important;
}

body :is(h1, h2, h3, .game-title, .page-title, .section-title, .panel-title,
.modal-title, .header-title, .username, .item-name, .weapon-name) {
  color: var(--xx-gold-2) !important;
  letter-spacing: 0 !important;
  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.86), 0 0 18px rgba(215, 169, 87, 0.3) !important;
}

body :is(p, small, .description, .item-desc, .user-level, .stat-label, .empty-message) {
  color: var(--xx-muted) !important;
}

body :is(button, .btn, .game-button, .menu-button, .action-button, .action-btn,
.modal-btn, .shop-btn, .buy-btn, .purchase-btn, .request-btn, .detail-btn,
.primary-btn, .secondary-btn, .tab-button, .filter-btn,
.avatar-customization-button, .avatar-modal-btn) {
  border-radius: 8px 2px 8px 2px !important;
  border: 1px solid rgba(255, 226, 148, 0.62) !important;
  color: #26190a !important;
  background:
    linear-gradient(180deg, rgba(255, 232, 163, 0.98), rgba(190, 122, 43, 0.96) 58%, rgba(95, 55, 25, 0.98)) !important;
  box-shadow: 0 8px 17px rgba(0, 0, 0, 0.34), inset 0 1px 0 rgba(255, 255, 226, 0.5) !important;
  text-shadow: 0 1px 0 rgba(255, 237, 182, 0.38) !important;
}

body :is(button, .btn, .game-button, .action-button, .action-btn, .modal-btn,
.shop-btn, .buy-btn, .purchase-btn, .tab-button, .filter-btn):hover {
  filter: brightness(1.08) saturate(1.05);
  transform: translateY(-1px);
}

body :is(.shop-item, .shop-card, .product-card, .goods-item, .setting-item,
.setting-card, .attribute-compact-item, .spirit-card, .sect-card, .task-card,
.member-card, .beast-card, .alchemy-card, .recipe-card, .furnace-card,
.refinement-card, .equipment-slot, .weapon-slot, .inventory-item,
.material-item, .item-card, .tab, .filter-item, .skill-info, .weapon-skill) {
  background:
    radial-gradient(circle at 50% 0%, rgba(255, 232, 158, 0.12), transparent 45%),
    linear-gradient(180deg, rgba(26, 49, 43, 0.92), rgba(6, 14, 15, 0.96)) !important;
  border: 1px solid rgba(201, 157, 78, 0.48) !important;
  border-radius: 8px 2px 8px 2px !important;
  box-shadow: 0 9px 20px rgba(0, 0, 0, 0.3), inset 0 1px 0 rgba(255, 242, 195, 0.08) !important;
}

input,
select,
textarea,
.modal-input,
.form-input {
  color: var(--xx-paper) !important;
  background: rgba(3, 9, 10, 0.76) !important;
  border: 1px solid var(--xx-line-soft) !important;
  border-radius: 8px 2px 8px 2px !important;
  box-shadow: inset 0 2px 8px rgba(0, 0, 0, 0.48) !important;
}

.bottom-navigation {
  height: 64px !important;
  background:
    linear-gradient(180deg, rgba(25, 30, 26, 0.52), rgba(5, 9, 10, 0.96)),
    radial-gradient(ellipse at 50% 0%, rgba(215, 169, 87, 0.22), transparent 64%) !important;
  border-top: 1px solid rgba(255, 225, 149, 0.56) !important;
  box-shadow: 0 -14px 28px rgba(0, 0, 0, 0.44), inset 0 1px 0 rgba(255, 241, 193, 0.1) !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

.bottom-navigation .nav-btn {
  min-width: 54px !important;
  padding: 6px 10px !important;
  color: var(--xx-muted) !important;
  background: transparent !important;
  border-color: transparent !important;
  box-shadow: none !important;
  text-shadow: none !important;
}

.bottom-navigation .nav-btn.active {
  color: var(--xx-gold-2) !important;
  background: radial-gradient(ellipse at 50% 12%, rgba(216, 180, 94, 0.3), rgba(216, 180, 94, 0.08) 58%, transparent 70%) !important;
}

.bottom-navigation .nav-btn-text {
  color: currentColor !important;
  font-size: 10px !important;
}

.user-avatar {
  position: relative !important;
  overflow: visible !important;
}

.user-avatar-content {
  z-index: 2 !important;
}

.user-avatar::before {
  content: "" !important;
  display: block !important;
  position: absolute !important;
  inset: 0 !important;
  z-index: 4 !important;
  pointer-events: none !important;
  background-image: var(--avatar-frame, url("../images/head/base1.png")) !important;
  background-position: center !important;
  background-repeat: no-repeat !important;
  background-size: contain !important;
  filter: drop-shadow(0 0 7px rgba(255, 229, 150, 0.38)) !important;
}

.user-avatar-frame {
  display: block !important;
  position: absolute !important;
  inset: 0 !important;
  z-index: 5 !important;
  pointer-events: none !important;
  background-position: center !important;
  background-repeat: no-repeat !important;
  background-size: contain !important;
  filter: drop-shadow(0 0 7px rgba(255, 229, 150, 0.38)) !important;
}

body.game-page {
  background:
    linear-gradient(180deg, rgba(2, 7, 8, 0.08), rgba(2, 7, 8, 0.74)),
    var(--xx-bg-image) center top / auto 100% no-repeat fixed !important;
}

body.game-page .main-container.game-interface {
  padding: 10px 14px 70px !important;
  gap: 8px !important;
}

body.game-page .user-info-bar {
  min-height: 74px !important;
  padding: 8px 10px !important;
  border-radius: 12px 2px 12px 2px !important;
  background:
    linear-gradient(90deg, rgba(4, 11, 12, 0.92), rgba(28, 44, 36, 0.78), rgba(5, 10, 10, 0.9)) !important;
}

body.game-page .user-avatar {
  width: 66px !important;
  height: 66px !important;
  flex: 0 0 66px !important;
}

body.game-page .user-avatar-content {
  top: 11px !important;
  left: 11px !important;
  width: 44px !important;
  height: 44px !important;
  border-radius: 50% !important;
}

body.game-page .game-world {
  min-height: 570px !important;
  border: 0 !important;
  border-radius: 0 !important;
  background:
    linear-gradient(180deg, rgba(3, 8, 9, 0.01), rgba(3, 8, 9, 0.12) 42%, rgba(2, 6, 7, 0.72)),
    radial-gradient(ellipse at 50% 78%, rgba(223, 181, 95, 0.1), transparent 34%) !important;
  box-shadow: inset 0 -22px 42px rgba(0, 0, 0, 0.38) !important;
}

body.game-page .game-world::before {
  background:
    linear-gradient(90deg, rgba(1, 5, 6, 0.48), transparent 22%, transparent 78%, rgba(1, 5, 6, 0.5)),
    radial-gradient(ellipse at 50% 77%, transparent 0 22%, rgba(0, 0, 0, 0.44) 82%) !important;
}

body.game-page .game-world::after {
  left: 21% !important;
  right: 21% !important;
  bottom: 44px !important;
  height: 150px !important;
  opacity: 0.55 !important;
  background:
    radial-gradient(ellipse at 50% 78%, rgba(255, 221, 133, 0.2), transparent 55%),
    radial-gradient(ellipse at 50% 22%, rgba(70, 159, 137, 0.16), transparent 65%) !important;
}

body.game-page .button-grid {
  padding: 28px 14px 34px !important;
  grid-template-columns: 118px 1fr 118px !important;
  grid-template-rows: 82px 1fr 92px !important;
  gap: 8px 12px !important;
}

body.game-page .function-button {
  width: 112px !important;
  height: 38px !important;
  padding: 0 10px !important;
  border-radius: 8px 2px 8px 2px !important;
  background:
    linear-gradient(90deg, rgba(4, 9, 10, 0.86), rgba(35, 54, 44, 0.72)),
    linear-gradient(180deg, rgba(255, 239, 181, 0.08), transparent) !important;
}

body.game-page .function-icon {
  width: 21px !important;
  height: 21px !important;
}

body.game-page .function-text {
  font-size: 13px !important;
}

body.game-page .cultivation-platform {
  width: 96px !important;
  height: 96px !important;
  margin-bottom: 42px !important;
  overflow: visible !important;
  background:
    radial-gradient(circle at 50% 44%, rgba(255, 242, 190, 0.9) 0 7%, rgba(197, 145, 61, 0.62) 18%, rgba(20, 45, 40, 0.94) 42%, rgba(4, 9, 10, 0.98) 69%) !important;
  box-shadow:
    0 0 0 1px rgba(255, 232, 154, 0.72),
    0 0 26px rgba(216, 180, 90, 0.36),
    0 12px 28px rgba(0, 0, 0, 0.5),
    inset 0 0 18px rgba(104, 214, 192, 0.13) !important;
}

body.game-page .cultivation-platform::before {
  inset: -24px !important;
  border-radius: 50% !important;
  background:
    radial-gradient(circle, transparent 0 54%, rgba(77, 153, 135, 0.12) 55% 70%, transparent 71%),
    conic-gradient(from 0deg, transparent, rgba(229, 198, 114, 0.22), transparent, rgba(81, 167, 145, 0.16), transparent) !important;
  filter: none !important;
}

body.game-page .cultivation-platform::after {
  inset: -7px !important;
  border-radius: 50% !important;
  background: none !important;
  border: 1px solid rgba(229, 198, 114, 0.28) !important;
  box-shadow: none !important;
}

body.game-page .cultivation-progress-ring {
  inset: 0 !important;
  top: 0 !important;
  left: 0 !important;
  width: 100% !important;
  height: 100% !important;
  overflow: visible !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

body.game-page .cultivation-progress-background {
  stroke: rgba(255, 239, 183, 0.2) !important;
}

body.game-page .cultivation-progress-foreground {
  stroke: #ffe176 !important;
  filter: drop-shadow(0 0 5px rgba(255, 225, 118, 0.7)) !important;
}

.item-detail-popup {
  background:
    radial-gradient(ellipse at 50% 28%, rgba(80, 160, 136, 0.12), transparent 34%),
    rgba(1, 5, 6, 0.82) !important;
  z-index: 20000 !important;
}

.item-detail-popup .popup-content-area {
  max-height: min(72vh, 560px) !important;
  background:
    linear-gradient(180deg, rgba(255, 236, 177, 0.08), transparent 24%),
    linear-gradient(145deg, rgba(28, 45, 39, 0.98), rgba(5, 12, 13, 0.98)) !important;
  border: 1px solid rgba(230, 191, 106, 0.72) !important;
  border-radius: 12px 2px 12px 2px !important;
}

.popup-button-area,
.item-detail-popup .action-buttons {
  background: rgba(5, 12, 13, 0.84) !important;
  border: 1px solid rgba(216, 183, 107, 0.35) !important;
  border-radius: 10px 2px 10px 2px !important;
}

.repair-confirm-popup,
.recycle-confirm-popup,
.confirm-popup,
.confirm-dialog {
  z-index: 130000 !important;
}

.repair-confirm-popup {
  background:
    radial-gradient(ellipse at 50% 20%, rgba(255, 217, 128, 0.16), transparent 34%),
    rgba(1, 5, 6, 0.9) !important;
}

.equipment-slot,
.weapon-slot,
.inventory-item {
  overflow: hidden !important;
}

.slot-item-image,
.weapon-slot-image,
.item-icon,
.inventory-item-image {
  filter: drop-shadow(0 4px 8px rgba(0, 0, 0, 0.58)) drop-shadow(0 0 8px rgba(216, 183, 107, 0.22));
}

.weapon-durability-text,
.durability-text {
  color: #fff0bc !important;
  text-shadow: 0 1px 3px rgba(0, 0, 0, 0.9) !important;
}

.battle-ui-container {
  background:
    linear-gradient(180deg, rgba(1, 5, 6, 0.04), rgba(1, 5, 6, 0.38) 70%, rgba(1, 4, 5, 0.72)),
    url("../images/ui/xianxia-battle-arena.webp") center top / auto 100% no-repeat fixed !important;
}

.battle-ui-container::before {
  background:
    radial-gradient(ellipse at 50% 18%, rgba(255, 222, 139, 0.12), transparent 24%),
    linear-gradient(90deg, rgba(0, 0, 0, 0.34), transparent 22%, transparent 78%, rgba(0, 0, 0, 0.34)),
    linear-gradient(180deg, rgba(2, 7, 8, 0.1), rgba(2, 7, 8, 0.22) 50%, rgba(1, 5, 6, 0.66)) !important;
}

.battle-ui-icon {
  width: 16px !important;
  height: 16px !important;
  display: inline-block !important;
  vertical-align: -3px !important;
  margin-right: 5px !important;
  background-position: center !important;
  background-repeat: no-repeat !important;
  background-size: contain !important;
  filter: drop-shadow(0 1px 2px rgba(0, 0, 0, 0.72)) !important;
}

.battle-ui-icon-victory {
  background-image: url("../images/ui/icon-victory.svg") !important;
}

.battle-ui-icon-spirit-stone {
  background-image: url("../images/ui/icon-spirit-stone.svg") !important;
}

.battle-ui-icon-gold {
  background-image: url("../images/ui/icon-gold.svg") !important;
}

.battle-ui-icon-adventure {
  background-image: url("../images/ui/icon-adventure.svg") !important;
}

.battle-ui-icon-loot {
  background-image: url("../images/ui/icon-loot.svg") !important;
}

.battle-ui-icon-warning {
  background-image: url("../images/ui/icon-warning.svg") !important;
}

.battle-ui-icon-back {
  background-image: url("../images/ui/icon-back.svg") !important;
}

.battle-exit-button::before {
  content: "" !important;
  width: 19px !important;
  height: 19px !important;
  display: block !important;
  background: url("../images/ui/icon-back.svg") center / contain no-repeat !important;
  transform: none !important;
}

.adventure-info,
.reward-label,
.rewards-title,
.drops-title,
.victory-title {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 4px !important;
}

.battle-header,
.area-info,
.battle-status,
.round-display,
.battle-speed-toggle,
.battle-exit-button,
.character-info,
.skill-info,
.weapon-skill,
.battle-bubble-hint {
  background:
    linear-gradient(180deg, rgba(255, 238, 181, 0.07), transparent 26%),
    linear-gradient(145deg, rgba(12, 24, 24, 0.9), rgba(5, 10, 11, 0.86)) !important;
  border: 1px solid var(--xx-line-soft) !important;
  border-radius: 8px 2px 8px 2px !important;
  box-shadow: 0 8px 18px rgba(0, 0, 0, 0.35), inset 0 1px 0 rgba(255, 240, 187, 0.08) !important;
}

@media (max-width: 480px) {
  body.game-page .main-container.game-interface {
    padding: 8px 9px 68px !important;
  }

  body.game-page .user-avatar {
    width: 58px !important;
    height: 58px !important;
    flex-basis: 58px !important;
  }

  body.game-page .user-avatar-content {
    top: 10px !important;
    left: 10px !important;
    width: 38px !important;
    height: 38px !important;
  }

  body.game-page .button-grid {
    grid-template-columns: 94px 1fr 94px !important;
    grid-template-rows: 70px 1fr 82px !important;
    padding: 20px 6px 28px !important;
  }

  body.game-page .function-button {
    width: 90px !important;
    height: 36px !important;
    gap: 6px !important;
  }

  body.game-page .function-text {
    font-size: 12px !important;
  }

  body.game-page .cultivation-platform {
    width: 88px !important;
    height: 88px !important;
  }
}

/* Cultivation screen: cave altar layout */
body.cultivation-page {
  --xx-bg-image: url("../images/ui/xianxia-cultivation-cave.webp");
  min-height: 100vh;
  height: 100dvh;
  overflow: hidden !important;
  background:
    linear-gradient(180deg, rgba(1, 5, 6, 0), rgba(1, 5, 6, 0.08) 62%, rgba(1, 5, 6, 0.22)),
    var(--xx-bg-image) center top / auto 100% no-repeat fixed !important;
}

body.cultivation-page::before {
  background:
    linear-gradient(90deg, rgba(0, 0, 0, 0.05), transparent 24%, transparent 76%, rgba(0, 0, 0, 0.06)),
    linear-gradient(180deg, rgba(2, 8, 9, 0), rgba(1, 5, 6, 0.02) 72%, rgba(1, 4, 5, 0.12)) !important;
}

body.cultivation-page .main-container {
  width: min(100vw, 650px) !important;
  min-height: 0 !important;
  height: 100dvh !important;
  margin: 0 auto !important;
  padding: 12px 10px 76px !important;
  box-sizing: border-box !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 8px !important;
  overflow-x: hidden !important;
  overflow-y: hidden !important;
  background: transparent !important;
}

body.cultivation-page .header {
  display: none !important;
}

body.cultivation-page .header-title {
  font-size: 16px !important;
  gap: 8px !important;
}

body.cultivation-page .back-btn {
  min-width: 58px !important;
  height: 30px !important;
  padding: 0 9px !important;
  border-radius: 999px !important;
  color: var(--xx-gold-2) !important;
  background: rgba(2, 7, 8, 0.56) !important;
  border: 1px solid rgba(226, 185, 95, 0.52) !important;
  box-shadow: inset 0 1px 0 rgba(255, 244, 205, 0.08) !important;
}

body.cultivation-page .cultivation-container {
  flex: 1 1 auto !important;
  min-height: 0 !important;
  display: grid !important;
  grid-template-rows: auto minmax(0, 1fr) auto auto !important;
  gap: 8px !important;
  overflow: hidden !important;
}

body.cultivation-page .realm-section {
  order: 0 !important;
  min-height: 0 !important;
  padding: 18px 16px 16px !important;
  display: flex !important;
  align-items: flex-start !important;
  justify-content: center !important;
  overflow: hidden !important;
  border-color: rgba(226, 185, 95, 0.42) !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  background:
    linear-gradient(180deg, rgba(1, 6, 7, 0), rgba(1, 6, 7, 0.015) 45%, rgba(1, 6, 7, 0.07)),
    radial-gradient(ellipse at 50% 80%, rgba(255, 226, 142, 0.035), transparent 42%) !important;
  box-shadow:
    inset 0 0 0 1px rgba(255, 241, 192, 0.04),
    inset 0 -64px 86px rgba(0, 0, 0, 0.12) !important;
}

body.cultivation-page .realm-section::before {
  inset: auto auto 0 50% !important;
  width: 320px !important;
  height: 116px !important;
  top: auto !important;
  left: 50% !important;
  transform: translateX(-50%) !important;
  border-radius: 50% !important;
  background:
    radial-gradient(ellipse at 50% 70%, rgba(255, 226, 142, 0.08), transparent 54%),
    radial-gradient(ellipse at 50% 44%, rgba(70, 159, 137, 0.07), transparent 64%) !important;
  filter: none !important;
  opacity: 0.16 !important;
  animation: none !important;
}

body.cultivation-page .realm-section::after {
  display: none !important;
}

body.cultivation-page .realm-info {
  width: 100% !important;
  max-width: 560px !important;
  z-index: 2 !important;
  display: grid !important;
  grid-template-columns: 1fr auto !important;
  grid-template-areas:
    "realm rate"
    "progress progress" !important;
  gap: 10px 14px !important;
  text-align: left !important;
}

body.cultivation-page .cultivation-standee-shell {
  position: absolute !important;
  left: 50% !important;
  bottom: 4px !important;
  width: min(286px, 44vw) !important;
  height: 286px !important;
  transform: translateX(-50%) !important;
  z-index: 1 !important;
  pointer-events: none !important;
  display: flex !important;
  align-items: flex-end !important;
  justify-content: center !important;
}

body.cultivation-page .cultivation-standee-aura {
  position: absolute !important;
  left: 50% !important;
  bottom: 5px !important;
  width: 150px !important;
  height: 40px !important;
  transform: translateX(-50%) !important;
  border-radius: 50% !important;
  background:
    radial-gradient(ellipse at 50% 50%, rgba(255, 224, 142, 0.34), rgba(90, 159, 139, 0.18) 48%, transparent 72%) !important;
  filter: blur(1px) !important;
  opacity: 0.82 !important;
}

body.cultivation-page .cultivation-standee {
  position: relative !important;
  z-index: 2 !important;
  max-width: 100% !important;
  max-height: 100% !important;
  object-fit: contain !important;
  object-position: center bottom !important;
  filter:
    drop-shadow(0 18px 28px rgba(0, 0, 0, 0.76))
    drop-shadow(0 0 20px rgba(255, 225, 150, 0.14)) !important;
  transform-origin: 50% 88% !important;
}

body.cultivation-page .cultivation-standee-shell.is-tribulating .cultivation-standee {
  filter:
    drop-shadow(0 18px 28px rgba(0, 0, 0, 0.82))
    drop-shadow(0 0 32px rgba(165, 218, 255, 0.36)) !important;
}

body.cultivation-page .cultivation-standee-shell.is-soul-damaged .cultivation-standee {
  animation: xxStandeeSoulWounded 2.4s ease-in-out infinite !important;
  filter:
    sepia(0.38)
    saturate(1.38)
    hue-rotate(318deg)
    brightness(0.9)
    drop-shadow(0 18px 28px rgba(0, 0, 0, 0.82))
    drop-shadow(0 0 26px rgba(198, 41, 43, 0.48)) !important;
}

body.cultivation-page .cultivation-standee-shell.is-soul-damaged .cultivation-standee-aura {
  background:
    radial-gradient(ellipse at 50% 50%, rgba(205, 48, 45, 0.36), rgba(110, 26, 24, 0.16) 48%, transparent 72%) !important;
}

.standee-healing-plus {
  position: absolute !important;
  z-index: 6 !important;
  width: 22px !important;
  height: 22px !important;
  transform: translate(-50%, 0) !important;
  color: #ff4747 !important;
  font-size: 22px !important;
  line-height: 22px !important;
  font-weight: 900 !important;
  text-align: center !important;
  text-shadow:
    0 0 6px rgba(255, 55, 55, 0.95),
    0 0 16px rgba(255, 26, 26, 0.62) !important;
  pointer-events: none !important;
  animation: xxHealingPlusFloat 1.65s ease-out forwards !important;
}

.tribulation-standee-proxy {
  position: fixed !important;
  z-index: 10001 !important;
  object-fit: contain !important;
  object-position: center bottom !important;
  pointer-events: none !important;
  transform-origin: 50% 82% !important;
  filter:
    drop-shadow(0 20px 30px rgba(0, 0, 0, 0.84))
    drop-shadow(0 0 18px rgba(255, 235, 170, 0.28)) !important;
}

.tribulation-standee-proxy.is-struck {
  animation: xxTribulationStruck 0.62s cubic-bezier(.2,.88,.26,1.12) both !important;
}

.tribulation-standee-proxy.is-success {
  animation: xxTribulationAscend 1.7s ease-out both !important;
}

.tribulation-standee-proxy.is-failure {
  animation: xxTribulationFailure 1.55s ease-out both !important;
}

.tribulation-impact-burst,
.tribulation-shock-ring,
.tribulation-foot-converge,
.tribulation-outcome-effect {
  position: fixed !important;
  pointer-events: none !important;
  transform: translate(-50%, -50%) !important;
}

.tribulation-lightning-texture {
  position: fixed !important;
  z-index: 10002 !important;
  pointer-events: none !important;
  transform-origin: 50% 0 !important;
  background-image: url("../images/ui/tribulation-lightning.png") !important;
  background-position: center top !important;
  background-repeat: no-repeat !important;
  background-size: 100% 100% !important;
  mix-blend-mode: screen !important;
  filter:
    drop-shadow(0 0 10px var(--lightning-color, #cdefff))
    drop-shadow(0 0 24px var(--lightning-color, #cdefff)) !important;
  animation: xxLightningTextureStrike 0.24s ease-out forwards, xxLightningTextureFlicker 2.55s 0.24s ease-in-out forwards !important;
}

.tribulation-lightning-texture.is-main {
  opacity: 0;
}

.tribulation-lightning-texture.is-sub {
  z-index: 10001 !important;
  opacity: 0;
  filter:
    drop-shadow(0 0 7px var(--lightning-color, #cdefff))
    drop-shadow(0 0 14px var(--lightning-color, #cdefff)) !important;
  animation: xxLightningTextureStrike 0.2s ease-out forwards, xxLightningTextureFlicker 1.8s 0.2s ease-in-out forwards !important;
}

.tribulation-impact-burst {
  width: calc(88px * var(--impact-scale, 1)) !important;
  height: calc(88px * var(--impact-scale, 1)) !important;
  z-index: 10004 !important;
  border-radius: 50% !important;
  background:
    radial-gradient(circle, rgba(255, 255, 255, 0.96), var(--impact-color, #d7f1ff) 28%, transparent 66%) !important;
  box-shadow:
    0 0 24px var(--impact-color, #d7f1ff),
    0 0 62px rgba(255, 255, 255, 0.45) !important;
  mix-blend-mode: screen !important;
  animation: xxImpactBurst 0.72s ease-out forwards !important;
}

.tribulation-shock-ring {
  width: 54px !important;
  height: 22px !important;
  z-index: 10003 !important;
  border: 1px solid var(--impact-color, #d7f1ff) !important;
  border-radius: 50% !important;
  box-shadow: 0 0 18px var(--impact-color, #d7f1ff) !important;
  animation: xxShockRing 0.86s ease-out forwards !important;
}

.tribulation-foot-converge {
  width: calc(44px * var(--impact-scale, 1)) !important;
  height: calc(18px * var(--impact-scale, 1)) !important;
  z-index: 10004 !important;
  border-radius: 50% !important;
  background:
    radial-gradient(ellipse at 50% 50%, rgba(255, 255, 255, 0.94), var(--impact-color, #d7f1ff) 34%, transparent 72%) !important;
  box-shadow:
    0 0 18px var(--impact-color, #d7f1ff),
    0 0 44px rgba(255, 255, 255, 0.38) !important;
  mix-blend-mode: screen !important;
  animation: xxFootConverge 0.72s ease-out forwards !important;
}

.tribulation-outcome-effect {
  width: 1px !important;
  height: 1px !important;
  z-index: 10005 !important;
}

.tribulation-outcome-effect::before {
  content: "" !important;
  position: absolute !important;
  left: 50% !important;
  top: 50% !important;
  width: 210px !important;
  height: 210px !important;
  transform: translate(-50%, -50%) !important;
  border-radius: 50% !important;
}

.tribulation-outcome-effect.is-success::before {
  background:
    radial-gradient(circle, rgba(255, 246, 183, 0.62), rgba(105, 226, 180, 0.24) 42%, transparent 70%) !important;
  animation: xxOutcomeBloom 1.6s ease-out forwards !important;
}

.tribulation-outcome-effect.is-failure::before {
  background:
    radial-gradient(circle, rgba(150, 173, 188, 0.38), rgba(80, 78, 90, 0.22) 44%, transparent 72%) !important;
  animation: xxOutcomeCollapse 1.35s ease-out forwards !important;
}

.tribulation-outcome-effect span {
  position: absolute !important;
  left: 0 !important;
  top: 0 !important;
  width: 5px !important;
  height: 5px !important;
  border-radius: 50% !important;
  transform: translate(-50%, -50%) !important;
}

.tribulation-outcome-effect.is-success span {
  background: #fff0a8 !important;
  box-shadow: 0 0 12px rgba(255, 236, 155, 0.9) !important;
  animation: xxSuccessMote 1.45s ease-out forwards !important;
}

.tribulation-outcome-effect.is-failure span {
  width: 4px !important;
  height: 14px !important;
  border-radius: 2px !important;
  background: #8aa0aa !important;
  box-shadow: 0 0 10px rgba(139, 167, 176, 0.72) !important;
  animation: xxFailureShard 1.1s ease-in forwards !important;
}

@keyframes xxTribulationStruck {
  0% { transform: translateY(0) scale(1); filter: brightness(1) drop-shadow(0 20px 30px rgba(0,0,0,0.84)); }
  15% { transform: translateY(-6px) scale(1.035); filter: brightness(2.6) saturate(1.2) drop-shadow(0 0 36px rgba(185,232,255,0.92)); }
  34% { transform: translateY(3px) translateX(-2px) scale(0.99); filter: brightness(0.82) saturate(0.82) drop-shadow(0 0 24px rgba(118,179,209,0.62)); }
  56% { transform: translateY(-2px) translateX(2px) scale(1.012); filter: brightness(1.85) drop-shadow(0 0 30px rgba(232,244,255,0.72)); }
  100% { transform: translateY(0) scale(1); filter: brightness(1.02) drop-shadow(0 20px 30px rgba(0,0,0,0.84)); }
}

@keyframes xxImpactBurst {
  0% { opacity: 0; transform: translate(-50%, -50%) scale(0.22); }
  24% { opacity: 1; }
  100% { opacity: 0; transform: translate(-50%, -50%) scale(1.65); }
}

@keyframes xxLightningTextureStrike {
  0% { opacity: 0; clip-path: inset(0 0 100% 0); }
  42% { opacity: 1; }
  100% { opacity: 0.96; clip-path: inset(0 0 0 0); }
}

@keyframes xxLightningTextureFlicker {
  0%, 14%, 28%, 42%, 64% { opacity: 0.98; }
  8%, 22%, 36%, 55% { opacity: 0.42; }
  78% { opacity: 0.72; }
  100% { opacity: 0; }
}

@keyframes xxShockRing {
  0% { opacity: 0.92; transform: translate(-50%, -50%) scale(0.5); }
  100% { opacity: 0; transform: translate(-50%, -50%) scale(3.5); }
}

@keyframes xxFootConverge {
  0% { opacity: 0; transform: translate(-50%, -50%) scale(0.26); }
  24% { opacity: 1; }
  100% { opacity: 0; transform: translate(-50%, -50%) scale(2.1); }
}

@keyframes xxTribulationAscend {
  0% { transform: translateY(0) scale(1); filter: brightness(1.08) drop-shadow(0 0 20px rgba(255,236,172,0.3)); }
  36% { transform: translateY(-8px) scale(1.025); filter: brightness(1.9) drop-shadow(0 0 42px rgba(255,236,172,0.84)); }
  100% { transform: translateY(-3px) scale(1.01); filter: brightness(1.28) drop-shadow(0 0 28px rgba(108,224,181,0.52)); }
}

@keyframes xxTribulationFailure {
  0% { transform: translateY(0) scale(1); filter: brightness(1); }
  28% { transform: translateY(4px) scale(0.985); filter: brightness(0.56) grayscale(0.45) drop-shadow(0 0 22px rgba(118,137,148,0.7)); }
  62% { transform: translateY(0) translateX(-3px) scale(0.995); }
  100% { transform: translateY(3px) scale(0.99); filter: brightness(0.82) grayscale(0.28) drop-shadow(0 18px 26px rgba(0,0,0,0.86)); }
}

@keyframes xxOutcomeBloom {
  0% { opacity: 0; transform: translate(-50%, -50%) scale(0.36) rotate(0deg); }
  34% { opacity: 0.95; }
  100% { opacity: 0; transform: translate(-50%, -50%) scale(1.85) rotate(24deg); }
}

@keyframes xxOutcomeCollapse {
  0% { opacity: 0; transform: translate(-50%, -50%) scale(1.3); }
  28% { opacity: 0.8; }
  100% { opacity: 0; transform: translate(-50%, -50%) scale(0.42); }
}

@keyframes xxSuccessMote {
  0% { opacity: 0; transform: translate(-50%, -50%) scale(0.2); }
  18% { opacity: 1; }
  100% { opacity: 0; transform: translate(calc(-50% + var(--tx)), calc(-50% + var(--ty))) scale(0.95); }
}

@keyframes xxFailureShard {
  0% { opacity: 0; transform: translate(-50%, -50%) rotate(0deg); }
  18% { opacity: 0.9; }
  100% { opacity: 0; transform: translate(calc(-50% + var(--tx)), calc(-50% + var(--ty))) rotate(84deg); }
}

@keyframes xxStandeeSoulWounded {
  0%, 100% { transform: translateY(0) scale(1); opacity: 0.96; }
  50% { transform: translateY(1px) scale(0.992); opacity: 0.88; }
}

@keyframes xxHealingPlusFloat {
  0% { opacity: 0; transform: translate(-50%, 6px) scale(0.68); }
  18% { opacity: 1; }
  100% { opacity: 0; transform: translate(calc(-50% + 18px), -62px) scale(1.14); }
}

body.cultivation-page .current-realm {
  grid-area: realm !important;
  margin: 0 !important;
  font-size: 20px !important;
  line-height: 1.2 !important;
  color: var(--xx-gold-2) !important;
}

body.cultivation-page .qi-progress {
  grid-area: progress !important;
  margin: 0 !important;
  align-self: end !important;
}

body.cultivation-page .breakthrough-info {
  grid-area: rate !important;
  justify-self: end !important;
  align-self: center !important;
  display: inline-flex !important;
  gap: 6px !important;
  margin: 0 !important;
  padding: 6px 10px !important;
  border: 1px solid rgba(226, 185, 95, 0.36) !important;
  border-radius: 999px !important;
  background: rgba(2, 8, 9, 0.56) !important;
  font-size: 12px !important;
  white-space: nowrap !important;
}

body.cultivation-page .success-rate {
  color: #96e6c8 !important;
  font-size: 13px !important;
}

body.cultivation-page .progress-bar,
body.cultivation-page .soul-recovery-bar {
  height: 16px !important;
  border: 1px solid rgba(226, 185, 95, 0.34) !important;
  border-radius: 999px !important;
  background: rgba(1, 6, 7, 0.72) !important;
  box-shadow: inset 0 2px 8px rgba(0, 0, 0, 0.64), 0 0 12px rgba(0, 0, 0, 0.28) !important;
}

body.cultivation-page .progress-bar::before {
  display: none !important;
}

body.cultivation-page .progress-fill,
body.cultivation-page .soul-recovery-fill {
  background: linear-gradient(90deg, #215a4e, #74d5b5 56%, #ffe39b) !important;
  border-radius: 999px !important;
  box-shadow: 0 0 13px rgba(116, 213, 181, 0.34), inset 0 1px 0 rgba(255, 249, 214, 0.32) !important;
}

body.cultivation-page .progress-fill::before,
body.cultivation-page .progress-fill::after {
  display: none !important;
}

body.cultivation-page .progress-text {
  font-size: 11px !important;
  color: #fff3c9 !important;
  letter-spacing: 0 !important;
}

body.cultivation-page .functions-section {
  order: -1 !important;
  min-height: 0 !important;
  display: block !important;
}

body.cultivation-page .function-panel,
body.cultivation-page .cultivation-progress-section,
body.cultivation-page .actions-section {
  min-height: 0 !important;
  height: auto !important;
  padding: 10px !important;
  border-radius: 10px 2px 10px 2px !important;
  background:
    linear-gradient(180deg, rgba(255, 236, 177, 0.055), transparent 26%),
    rgba(3, 10, 11, 0.76) !important;
}

body.cultivation-page .functions-section .function-panel {
  padding: 8px 10px !important;
}

body.cultivation-page .panel-title,
body.cultivation-page .progress-title {
  margin: 0 0 8px !important;
  text-align: left !important;
  font-size: 12px !important;
  color: var(--xx-gold-2) !important;
}

body.cultivation-page .functions-section .panel-title {
  margin-bottom: 6px !important;
}

body.cultivation-page .cultivation-status-grid {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 8px !important;
}

body.cultivation-page .functions-section .cultivation-status-grid {
  gap: 7px !important;
}

body.cultivation-page .status-item {
  min-height: 62px !important;
  padding: 9px 10px !important;
  display: grid !important;
  grid-template-columns: 28px 1fr !important;
  grid-template-areas:
    "icon value"
    "icon name" !important;
  align-items: center !important;
  text-align: left !important;
  background:
    linear-gradient(90deg, rgba(18, 38, 34, 0.86), rgba(4, 10, 11, 0.78)) !important;
  border: 1px solid rgba(226, 185, 95, 0.3) !important;
  border-radius: 8px 2px 8px 2px !important;
}

body.cultivation-page .functions-section .status-item {
  min-height: 52px !important;
  padding: 7px 10px !important;
  grid-template-columns: 24px 1fr !important;
}

body.cultivation-page .status-icon {
  grid-area: icon !important;
  width: 24px !important;
  height: 24px !important;
  margin: 0 !important;
}

body.cultivation-page .functions-section .status-icon {
  width: 22px !important;
  height: 22px !important;
}

body.cultivation-page .status-value {
  grid-area: value !important;
  color: #fff0bb !important;
  font-size: 13px !important;
  font-weight: 700 !important;
}

body.cultivation-page .status-name {
  grid-area: name !important;
  color: var(--xx-muted) !important;
  font-size: 10px !important;
}

body.cultivation-page .cultivation-progress-section {
  order: 1 !important;
  border-color: rgba(179, 94, 41, 0.55) !important;
  background:
    linear-gradient(90deg, rgba(74, 35, 15, 0.72), rgba(6, 12, 12, 0.8)) !important;
}

body.cultivation-page .actions-section {
  order: 2 !important;
}

body.cultivation-page .progress-info {
  margin-top: 7px !important;
  text-align: right !important;
  font-size: 11px !important;
  color: #d8bd7c !important;
}

body.cultivation-page .action-buttons-grid {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 8px !important;
}

body.cultivation-page .action-button {
  min-height: 64px !important;
  padding: 9px 8px !important;
  display: grid !important;
  grid-template-columns: 28px 1fr !important;
  grid-template-areas:
    "icon text"
    "icon desc" !important;
  align-items: center !important;
  text-align: left !important;
  color: var(--xx-paper) !important;
  border-radius: 9px 2px 9px 2px !important;
  background:
    linear-gradient(90deg, rgba(25, 45, 39, 0.92), rgba(9, 18, 18, 0.94)) !important;
  border: 1px solid rgba(226, 185, 95, 0.42) !important;
  box-shadow: 0 8px 16px rgba(0, 0, 0, 0.28), inset 0 1px 0 rgba(255, 244, 205, 0.08) !important;
  text-shadow: none !important;
}

body.cultivation-page .action-button:disabled {
  opacity: 0.48 !important;
  filter: grayscale(0.5) !important;
}

body.cultivation-page .action-icon {
  grid-area: icon !important;
  width: 24px !important;
  height: 24px !important;
  margin: 0 !important;
}

body.cultivation-page .action-text {
  grid-area: text !important;
  color: #fff0bb !important;
  font-size: 13px !important;
  font-weight: 700 !important;
}

body.cultivation-page .action-description {
  grid-area: desc !important;
  margin: 2px 0 0 !important;
  color: var(--xx-muted) !important;
  font-size: 10px !important;
}

body.cultivation-page :is(.technique-modal, .breakthrough-modal, .fragment-synthesis-modal,
.detail-modal, .soul-pill-modal) {
  background:
    radial-gradient(ellipse at 50% 32%, rgba(87, 180, 154, 0.12), transparent 34%),
    rgba(1, 5, 6, 0.84) !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

body.cultivation-page :is(.technique-modal-content, .breakthrough-modal-content,
.fragment-synthesis-modal-content, .detail-modal-content, #soulPillModal > div) {
  width: min(92vw, 520px) !important;
  max-width: 520px !important;
  max-height: 84vh !important;
  padding: 16px !important;
  color: var(--xx-paper) !important;
  border: 1px solid rgba(226, 185, 95, 0.64) !important;
  border-radius: 12px 2px 12px 2px !important;
  background:
    linear-gradient(180deg, rgba(255, 236, 177, 0.08), transparent 22%),
    linear-gradient(145deg, rgba(26, 44, 38, 0.98), rgba(4, 10, 11, 0.98)) !important;
  box-shadow: 0 18px 40px rgba(0, 0, 0, 0.58), inset 0 1px 0 rgba(255, 242, 196, 0.1) !important;
}

body.cultivation-page :is(.technique-title, .breakthrough-title,
.fragment-synthesis-title, .detail-modal-title) {
  color: var(--xx-gold-2) !important;
  font-size: 17px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 7px !important;
}

body.cultivation-page .fragment-synthesis-modal {
  align-items: center !important;
  padding: 12px !important;
  overflow: hidden !important;
}

body.cultivation-page .fragment-synthesis-modal-content {
  width: min(88vw, 520px) !important;
  max-width: 520px !important;
  height: min(78dvh, 720px) !important;
  max-height: calc(100dvh - 48px) !important;
  margin: 0 !important;
  padding: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  overflow: hidden !important;
}

body.cultivation-page .fragment-synthesis-title {
  flex: 0 0 auto !important;
  margin: 0 !important;
  padding: 18px 18px 12px !important;
  border-bottom: 1px solid rgba(226, 185, 95, 0.34) !important;
  background: linear-gradient(180deg, rgba(255, 236, 177, 0.08), transparent) !important;
}

body.cultivation-page .fragment-synthesis-content {
  flex: 1 1 auto !important;
  min-height: 0 !important;
  height: 0 !important;
  padding: 14px 18px 16px !important;
  display: flex !important;
  flex-direction: column !important;
  overflow: hidden !important;
}

body.cultivation-page .synthesis-main-content {
  flex: 1 1 auto !important;
  min-height: 0 !important;
  height: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  overflow: hidden !important;
}

body.cultivation-page .synthesis-recipes-section {
  height: 100% !important;
  min-height: 0 !important;
  margin: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  overflow: hidden !important;
}

body.cultivation-page .recipes-title {
  flex: 0 0 auto !important;
  margin: 0 0 8px !important;
  padding-bottom: 7px !important;
  font-size: 15px !important;
}

body.cultivation-page .recipes-list {
  flex: 1 1 auto !important;
  min-height: 0 !important;
  max-height: none !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  padding-right: 6px !important;
  padding-bottom: 2px !important;
  gap: 8px !important;
  scrollbar-width: thin !important;
  scrollbar-color: rgba(226, 185, 95, 0.72) rgba(3, 10, 11, 0.44) !important;
}

body.cultivation-page .recipes-list::-webkit-scrollbar {
  width: 6px !important;
}

body.cultivation-page .recipes-list::-webkit-scrollbar-track {
  background: rgba(3, 10, 11, 0.46) !important;
  border-radius: 999px !important;
}

body.cultivation-page .recipes-list::-webkit-scrollbar-thumb {
  background: linear-gradient(180deg, #f2d687, #8a5b1e) !important;
  border-radius: 999px !important;
}

body.cultivation-page .recipe-item {
  padding: 10px 12px !important;
  border-radius: 8px 2px 8px 2px !important;
  background:
    linear-gradient(90deg, rgba(22, 43, 36, 0.86), rgba(5, 13, 13, 0.9)) !important;
}

body.cultivation-page .recipe-item:hover {
  transform: none !important;
}

body.cultivation-page .recipe-header {
  margin-bottom: 4px !important;
  gap: 8px !important;
}

body.cultivation-page .recipe-name {
  min-width: 0 !important;
  color: #d9b85d !important;
  font-size: 13px !important;
}

body.cultivation-page .recipe-status {
  flex: 0 0 auto !important;
  font-size: 11px !important;
  padding: 2px 7px !important;
}

body.cultivation-page .recipe-details,
body.cultivation-page .recipe-requirement {
  font-size: 11px !important;
  line-height: 1.45 !important;
}

body.cultivation-page .synthesize-button {
  height: 34px !important;
  margin-top: 8px !important;
  padding: 0 12px !important;
  border-radius: 7px !important;
}

body.cultivation-page .fragment-synthesis-buttons {
  flex: 0 0 auto !important;
  margin: 12px 0 0 !important;
  padding-top: 12px !important;
  border-top: 1px solid rgba(226, 185, 95, 0.24) !important;
}

body.cultivation-page .fragment-synthesis-button {
  min-width: 110px !important;
  height: 34px !important;
  padding: 0 18px !important;
  border-radius: 9px 2px 9px 2px !important;
}

body.cultivation-page :is(.technique-item, .pill-item, .recipe-item,
.fragment-item, .efficiency-item, .stat-item, .realm-transition,
.success-rate-section, .risk-warning, .breakthrough-pills,
.efficiency-calculation, .technique-progress-section) {
  background:
    linear-gradient(180deg, rgba(255, 236, 177, 0.055), rgba(3, 10, 11, 0.74)) !important;
  border: 1px solid rgba(226, 185, 95, 0.28) !important;
  border-radius: 8px 2px 8px 2px !important;
}

body.cultivation-page .risk-warning {
  border-color: rgba(190, 79, 62, 0.42) !important;
}

body.cultivation-page .risk-text {
  color: #e4b69e !important;
}

@media (max-width: 520px) {
  body.cultivation-page .main-container {
    padding: 8px 8px 74px !important;
  }

  body.cultivation-page .cultivation-container {
    grid-template-rows: auto minmax(0, 1fr) auto auto !important;
  }

  body.cultivation-page .realm-section {
    min-height: 0 !important;
    padding: 15px 12px 14px !important;
  }

  body.cultivation-page .cultivation-standee-shell {
    width: min(230px, 54vw) !important;
    height: 224px !important;
    bottom: 2px !important;
  }

  body.cultivation-page .realm-info {
    grid-template-columns: 1fr !important;
    grid-template-areas:
      "realm"
      "rate"
      "progress" !important;
    gap: 7px !important;
  }

  body.cultivation-page .breakthrough-info {
    justify-self: start !important;
  }

  body.cultivation-page .fragment-synthesis-modal {
    padding: 8px !important;
  }

  body.cultivation-page .fragment-synthesis-modal-content {
    width: min(96vw, 520px) !important;
    height: calc(100dvh - 24px) !important;
    max-height: calc(100dvh - 24px) !important;
  }

  body.cultivation-page .fragment-synthesis-title {
    padding: 14px 14px 10px !important;
    font-size: 15px !important;
  }

  body.cultivation-page .fragment-synthesis-content {
    padding: 10px 12px 12px !important;
  }

  body.cultivation-page .recipe-item {
    padding: 9px 10px !important;
  }

  body.cultivation-page .synthesize-button,
  body.cultivation-page .fragment-synthesis-button {
    height: 32px !important;
  }

  body.cultivation-page .cultivation-status-grid,
  body.cultivation-page .action-buttons-grid {
    gap: 6px !important;
  }

  body.cultivation-page .action-button {
    min-height: 58px !important;
    grid-template-columns: 1fr !important;
    grid-template-areas:
      "icon"
      "text"
      "desc" !important;
    justify-items: center !important;
    text-align: center !important;
  }

  body.cultivation-page .action-text {
    font-size: 12px !important;
  }

  body.cultivation-page .action-description {
    font-size: 9px !important;
  }
}
