/* BALELE Phase 6 Step 2A-3 — final global User Decorator normalization.
   This stylesheet is intentionally enqueued last. It makes all user displays
   consume the same CSS variables from balele-points instead of page-specific
   hard-coded colors. */

.balele-user-decorator,
.user-decorator,
.balele-my-wall-avatar,
.balele-points-avatar-wrap,
.balele-comment-user-decorator {
  --balele-level-color: var(--balele-level-color, #7c3aed);
  --balele-nickname-color: var(--balele-nickname-color, #1f2937);
}

/* Avatar frame: My Account, Points, My Wall, Public Wall, Pin Modal, Comments. */
.balele-user-avatar-frame,
.user-decorator-avatar-wrap,
.balele-my-wall-avatar,
.balele-points-avatar-wrap,
.balele-comment-avatar-wrap {
  position: relative !important;
  overflow: visible !important;
  border: 3px solid var(--balele-level-color, #7c3aed) !important;
  background: #fff !important;
  box-shadow:
    0 0 0 1px color-mix(in srgb, var(--balele-level-color, #7c3aed) 18%, transparent),
    0 12px 28px color-mix(in srgb, var(--balele-level-color, #7c3aed) 22%, transparent),
    0 10px 28px rgba(0,0,0,.10) !important;
}

.balele-user-avatar-frame img,
.user-decorator-avatar-wrap img,
.balele-my-wall-avatar img,
.balele-points-avatar,
.balele-comment-avatar-wrap img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block !important;
}

/* Keep the existing shapes while unifying the treatment. */
.balele-user-avatar-frame,
.balele-points-avatar-wrap,
.user-decorator-avatar-wrap,
.balele-comment-avatar-wrap {
  border-radius: 999px !important;
}
.balele-user-avatar-frame img,
.balele-points-avatar,
.user-decorator-avatar-wrap img,
.balele-comment-avatar-wrap img {
  border-radius: 999px !important;
}
.balele-my-wall-avatar {
  border-radius: 24px !important;
}
.balele-my-wall-avatar img {
  border-radius: 20px !important;
}

/* Level badge: one visual language everywhere. */
.balele-user-level-badge,
.user-decorator-level-corner,
.balele-my-wall-lv,
.balele-points-level-badge,
.balele-comment-level-badge {
  position: absolute !important;
  right: -8px !important;
  bottom: -8px !important;
  z-index: 5 !important;
  min-width: 34px !important;
  height: 24px !important;
  padding: 0 8px !important;
  border-radius: 999px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  background: var(--balele-level-color, #7c3aed) !important;
  color: #fff !important;
  border: 2px solid rgba(255,255,255,.92) !important;
  box-shadow: 0 8px 18px color-mix(in srgb, var(--balele-level-color, #7c3aed) 28%, transparent) !important;
  font-size: 11px !important;
  font-weight: 900 !important;
  line-height: 1 !important;
  white-space: nowrap !important;
}

/* Nickname color: all contexts read the Points setting. */
.balele-user-name--lv1,
.balele-user-name--lv2,
.balele-user-name--lv3,
.balele-user-name--lv4,
.balele-user-name--lv5,
.user-decorator-nickname,
.balele-comment-nickname,
.balele-my-wall-title h1[class*="balele-user-name"],
.balele-member-wall-title h1[class*="balele-user-name"] {
  color: var(--balele-nickname-color, #1f2937) !important;
}

/* Small diamond / level icon beside nickname. */
.user-decorator-badge,
.balele-user-decorator-icon,
.balele-comment-decorator-icon {
  display: inline-block !important;
  width: 12px !important;
  height: 12px !important;
  flex: 0 0 auto !important;
  border-radius: 3px !important;
  transform: rotate(45deg) !important;
  background: var(--balele-level-color, #7c3aed) !important;
  box-shadow: 0 0 0 2px rgba(255,255,255,.92), 0 4px 10px rgba(0,0,0,.16) !important;
}

/* Pin Modal owner should not fall back to page-specific level-1/2/3 colors. */
.balele-modal-owner.user-decorator {
  --balele-level-color: var(--balele-level-color, #7c3aed);
  --balele-nickname-color: var(--balele-nickname-color, #1f2937);
}

/* Comments: compact, but still shows unified avatar frame and nickname color. */
.balele-modal-comment {
  align-items: flex-start;
}
.balele-comment-user-decorator {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  width: 100%;
}
.balele-comment-avatar-wrap {
  width: 42px !important;
  height: 42px !important;
  flex: 0 0 42px !important;
  border-width: 2px !important;
}
.balele-comment-level-badge {
  min-width: 26px !important;
  height: 17px !important;
  padding: 0 5px !important;
  font-size: 9px !important;
  right: -7px !important;
  bottom: -5px !important;
  border-width: 1px !important;
}
.balele-comment-body {
  min-width: 0;
}
.balele-comment-name-row {
  display: flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
}
.balele-comment-nickname {
  font-weight: 900;
}
.balele-comment-body p {
  margin-top: 2px;
}

@media (max-width: 760px) {
  .balele-user-level-badge,
  .user-decorator-level-corner,
  .balele-my-wall-lv,
  .balele-points-level-badge {
    min-width: 30px !important;
    height: 22px !important;
    font-size: 10px !important;
    right: -7px !important;
    bottom: -7px !important;
  }
}

/* Phase 6 Step 2A-4 — force nested modal/comment elements to inherit
   the real backend-configured color instead of old static lv1/lv2 classes. */
.user-decorator .user-decorator-avatar-wrap,
.user-decorator .user-decorator-level-corner,
.user-decorator .user-decorator-badge,
.balele-comment-user-decorator .balele-comment-avatar-wrap,
.balele-comment-user-decorator .balele-comment-level-badge,
.balele-comment-user-decorator .balele-comment-decorator-icon {
  --balele-level-color: inherit !important;
}

.user-decorator .user-decorator-nickname,
.balele-comment-user-decorator .balele-comment-nickname,
.balele-account-hero-copy h1[class*="balele-user-name--"] {
  color: var(--balele-nickname-color, #1f2937) !important;
}

/* Do not let old diamond-bronze/silver/gold classes override the configured color. */
.user-decorator .user-decorator-badge[class*="diamond-"],
.balele-comment-user-decorator .balele-comment-decorator-icon[class*="diamond-"] {
  background: var(--balele-level-color, #7c3aed) !important;
}

/* Keep account hero aligned with the unified decorator model. */
.balele-account-hero .balele-user-decorator,
.balele-account-hero .balele-user-avatar-frame,
.balele-account-hero .balele-user-level-badge {
  --balele-level-color: inherit;
}


/* Phase 6 Step 2A-5 — comment decorator final bridge.
   Comments may have compact markup, so force every nested element to consume
   the root CSS variables that JS writes from the backend decorator model. */
.balele-comment-user-decorator[style*="--balele-level-color"] .balele-comment-avatar-wrap,
.balele-comment-user-decorator[style*="--balele-level-color"] .balele-comment-level-badge,
.balele-comment-user-decorator[style*="--balele-level-color"] .balele-comment-decorator-icon {
  border-color: var(--balele-level-color) !important;
  background-color: var(--balele-level-color) !important;
  background: var(--balele-level-color) !important;
  box-shadow: 0 8px 18px color-mix(in srgb, var(--balele-level-color) 26%, transparent) !important;
}
.balele-comment-user-decorator[style*="--balele-nickname-color"] .balele-comment-nickname {
  color: var(--balele-nickname-color) !important;
}


/* Phase 6 Step 6G — backend level icon bridge.
   If Points level config has a custom Icon value such as ☀, emoji:☀,
   icon:sun, icon:star, icon:crown, etc., show that symbol beside the nickname
   instead of the old hard-coded diamond shape. */
.user-decorator-badge.is-level-symbol,
.balele-user-decorator-icon.is-level-symbol,
.balele-comment-decorator-icon.is-level-symbol {
  width: auto !important;
  height: auto !important;
  min-width: 16px !important;
  min-height: 16px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  transform: none !important;
  border-radius: 0 !important;
  background: transparent !important;
  background-color: transparent !important;
  box-shadow: none !important;
  color: var(--balele-level-color, #7c3aed) !important;
  font-size: 18px !important;
  line-height: 1 !important;
  font-weight: 900 !important;
  text-shadow: 0 2px 8px color-mix(in srgb, var(--balele-level-color, #7c3aed) 24%, transparent) !important;
}

.balele-comment-decorator-icon.is-level-symbol {
  font-size: 15px !important;
}

/* Phase 6 Step 6H — level custom icon should be a clean inline symbol only.
   Backend-configured symbols / icon codes must not inherit the old diamond
   background, colored square, rotation, border, or shadow. */
.user-decorator .user-decorator-badge.is-level-symbol,
.user-decorator[style*="--balele-level-color"] .user-decorator-badge.is-level-symbol,
.balele-user-decorator-icon.is-level-symbol,
.balele-user-decorator-icon.is-level-symbol[class*="diamond-"],
.balele-comment-user-decorator .balele-comment-decorator-icon.is-level-symbol,
.balele-comment-user-decorator[style*="--balele-level-color"] .balele-comment-decorator-icon.is-level-symbol,
.balele-comment-decorator-icon.is-level-symbol[class*="diamond-"],
body.balele-ui-v56 .balele-modal-owner .user-decorator-badge.is-level-symbol,
body.balele-ui-v56 .balele-modal-owner .balele-user-decorator-icon.is-level-symbol,
body.balele-ui-v56 .balele-comment-user-decorator .balele-comment-decorator-icon.is-level-symbol {
  width: auto !important;
  height: auto !important;
  min-width: 0 !important;
  min-height: 0 !important;
  padding: 0 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  vertical-align: -0.08em !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  background-color: transparent !important;
  background-image: none !important;
  box-shadow: none !important;
  filter: none !important;
  transform: none !important;
  color: var(--balele-level-color, currentColor) !important;
  font-size: 1em !important;
  line-height: 1 !important;
  font-weight: 900 !important;
  text-shadow: none !important;
}

body.balele-ui-v56 .balele-comment-user-decorator .balele-comment-decorator-icon.is-level-symbol {
  font-size: 1em !important;
}
