/**
 * Sailor Piece interactive wiki (React island). Scoped under .sailor-piece-wiki.
 * Uses tokens from public/css/base.css.
 */

/* SEO snapshot only (wiki.astro); not a global .visually-hidden to avoid clashes with CMP/ad overlays. */
.sp-wiki__seo-sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.sailor-piece-wiki {
  --sp-wiki-icon-frame: 112px;

  color: var(--ty-text);
  font-family: var(--ty-font-sans);
  margin: 0 -25px 0;
  width: calc(100% + 50px);
  max-width: none;
  box-sizing: border-box;
}

@media (max-width: 1080px) {
  .sailor-piece-wiki {
    width: calc(100% + 40px);
    margin-left: -20px;
    margin-right: -20px;
  }
}

@media (max-width: 768px) {
  .sailor-piece-wiki {
    width: calc(100% + 30px);
    margin-left: -15px;
    margin-right: -15px;
  }
}

.sailor-piece-wiki * {
  box-sizing: border-box;
}

.sp-wiki__alert {
  border-bottom: 1px solid var(--ty-border-muted);
  padding: 8px 24px;
  text-align: center;
  font-size: 0.85rem;
  color: var(--ty-text-muted);
}

.sp-wiki__alert strong {
  color: #4ade80;
}

.sp-wiki__alert .sp-wiki__accent-text {
  color: var(--ty-accent-solid);
}

.sp-wiki__header {
  padding: 24px 24px 0;
  border-bottom: 1px solid var(--ty-border-muted);
  background: linear-gradient(180deg, rgba(43, 42, 60, 0.35) 0%, transparent 100%);
}

.sp-wiki__inner {
  margin: 0 auto;
}

.sp-wiki__title {
  font-size: clamp(1.35rem, 3vw, 2rem);
  font-weight: 800;
  margin: 0 0 6px;
  color: var(--ty-text);
  letter-spacing: -0.02em;
  line-height: 1.15;
}

.sp-wiki__subtitle {
  margin: 0 0 20px;
  font-size: 0.95rem;
  color: var(--ty-text-muted);
}

.sp-wiki__search-wrap {
  position: relative;
  max-width: 480px;
  margin-bottom: 20px;
}

.sp-wiki__search-icon {
  position: absolute;
  left: 12px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--ty-text-muted);
  font-size: 0.95rem;
  pointer-events: none;
}

.sp-wiki__search {
  width: 100%;
  padding: 9px 36px 9px 38px;
  background: var(--ty-dark-bg);
  border: 1px solid var(--ty-border-muted);
  border-radius: var(--ty-radius);
  color: var(--ty-text);
  font-size: 0.9rem;
  outline: none;
  transition: border-color 0.15s;
}

.sp-wiki__search:focus {
  border-color: var(--ty-accent-solid);
}

.sp-wiki__search-clear {
  position: absolute;
  right: 10px;
  top: 50%;
  transform: translateY(-50%);
  background: none;
  border: none;
  color: var(--ty-text-muted);
  cursor: pointer;
  font-size: 1rem;
  padding: 4px;
  line-height: 1;
}

.sp-wiki__search-clear:hover {
  color: var(--ty-text);
}

.sp-wiki__search-summary {
  margin: -8px 0 16px;
  font-size: 0.8rem;
  color: var(--ty-text-muted);
  line-height: 1.4;
}

.sp-wiki__search-no-tabs {
  margin: 0 0 16px;
  font-size: 0.85rem;
  color: var(--ty-text-muted);
}

.sp-wiki__no-matches {
  margin: 24px 16px;
  padding: 20px;
  text-align: center;
  font-size: 0.95rem;
  color: #94a3b8;
  border: 1px solid var(--ty-border-muted, #334155);
  border-radius: 2px;
  background: rgba(30, 41, 59, 0.35);
}

/* Search hit highlight (wiki tables & code cards) — dark ground + light text for contrast */
mark.sp-wiki__hl {
  background: rgba(113, 63, 18, 0.92);
  color: #fffbeb;
  padding: 0 3px;
  border-radius: var(--ty-radius);
  font-weight: 700;
  box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.35);
}

.sp-wiki__tabs {
  display: flex;
  gap: 2px;
  overflow-x: auto;
  padding-bottom: 0;
  scrollbar-width: thin;
}

.sp-wiki__tab {
  padding: 10px 14px;
  border: none;
  cursor: pointer;
  background: transparent;
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--ty-text-muted);
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  white-space: nowrap;
  transition: color 0.15s, border-color 0.15s;
  font-family: var(--ty-font-sans);
}

.sp-wiki__tab:hover {
  color: var(--ty-text);
}

.sp-wiki__tab--active {
  color: var(--ty-accent-solid);
  border-bottom-color: var(--ty-accent-solid);
}

.sp-wiki__tab-count {
  margin-left: 6px;
  font-size: 0.65rem;
  background: var(--uibluegray);
  color: var(--ty-text-muted);
  padding: 1px 6px;
  border-radius: var(--ty-radius);
  font-variant-numeric: tabular-nums;
}

.sp-wiki__tab--active .sp-wiki__tab-count {
  background: rgba(122, 90, 248, 0.25);
  color: #d4bfff;
}

.sp-wiki__tab--no-hits:not(.sp-wiki__tab--active) {
  opacity: 0.55;
}

.sp-wiki__tab-count--zero {
  opacity: 0.7;
}

.sp-wiki__content {
  margin: 0 auto;
  padding: 24px 24px 40px;
}

.sp-wiki__footer-note {
  border-top: 1px solid var(--ty-border-muted);
  padding: 16px 24px;
  text-align: center;
  font-size: 0.7rem;
  color: var(--ty-text-muted);
  line-height: 1.5;
}

/* Codes */
.sp-wiki__hint-box {
  background: var(--indigoblue);
  border: 1px solid var(--ty-border-muted);
  border-radius: var(--ty-radius);
  padding: 14px 18px;
  margin-bottom: 24px;
}

.sp-wiki__hint-box p {
  margin: 0;
  font-size: 0.85rem;
  color: var(--ty-text-muted);
  line-height: 1.5;
}

.sp-wiki__hint-arrow {
  color: var(--ty-accent-solid);
}

.sp-wiki__codes-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 12px;
}

.sp-wiki__code-card {
  background: var(--ty-dark-bg);
  border: 1px solid var(--ty-border-muted);
  border-radius: var(--ty-radius);
  padding: 14px 16px;
  cursor: pointer;
  transition: border-color 0.15s, box-shadow 0.15s;
}

.sp-wiki__code-card:hover {
  border-color: rgba(122, 90, 248, 0.45);
}

.sp-wiki__code-card--copied {
  border-color: #22c55e;
  box-shadow: 0 0 0 1px rgba(34, 197, 94, 0.25);
}

.sp-wiki__code-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 8px;
}

.sp-wiki__code-value {
  font-family: ui-monospace, monospace;
  color: var(--ty-accent-solid);
  font-size: 0.9rem;
  font-weight: 700;
  letter-spacing: 0.04em;
}

.sp-wiki__code-card--copied .sp-wiki__code-value {
  color: #4ade80;
}

.sp-wiki__code-copy-hint {
  font-size: 0.65rem;
  color: var(--ty-text-muted);
  font-variant-numeric: tabular-nums;
}

.sp-wiki__code-desc {
  margin: 0 0 8px;
  font-size: 0.8rem;
  color: var(--ty-text-muted);
  line-height: 1.5;
}

.sp-wiki__code-tags {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.sp-wiki__tag {
  background: var(--uibluegray);
  font-size: 0.65rem;
  padding: 2px 8px;
  border-radius: var(--ty-radius);
  color: var(--ty-text-muted);
}

.sp-wiki__tag--level {
  color: #f5e6a8;
}

/* Tables */
.sp-wiki__table-wrap {
  overflow-x: auto;
  margin-bottom: 8px;
}

.sp-wiki__table {
  width: 100%;
  border-collapse: collapse;
  min-width: 860px;
}

.sp-wiki__table--swords {
  min-width: 1160px;
}

.sp-wiki__table--fighting-styles {
  min-width: 1080px;
}

.sp-wiki__thead-row {
  background: var(--uibluegray);
}

.sp-wiki__th {
  padding: 10px 12px;
  text-align: left;
  cursor: pointer;
  color: var(--ty-text-muted);
  font-weight: 600;
  font-size: 0.7rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  user-select: none;
  white-space: nowrap;
  border-bottom: 1px solid var(--ty-border-muted);
  transition: color 0.15s;
}

.sp-wiki__th--active {
  color: var(--ty-accent-solid);
}

.sp-wiki__th--static {
  cursor: default;
  user-select: none;
}

.sp-wiki__th--static .sp-wiki__sort-icon {
  display: none;
}

/* Quadratischer Rahmen: feste Seitenlänge + aspect-ratio (kein hochkantes Kästchen bei Platzhalter/IMG). */
.sp-wiki__item-icon-frame {
  display: flex;
  align-items: center;
  justify-content: center;
  width: var(--sp-wiki-icon-frame);
  height: var(--sp-wiki-icon-frame);
  min-width: var(--sp-wiki-icon-frame);
  min-height: var(--sp-wiki-icon-frame);
  max-width: var(--sp-wiki-icon-frame);
  max-height: var(--sp-wiki-icon-frame);
  aspect-ratio: 1 / 1;
  flex-shrink: 0;
  margin: 0 auto;
  box-sizing: border-box;
  border-radius: var(--ty-radius);
  background: var(--uibluegray);
  border: 1px solid var(--ty-border-muted);
  overflow: hidden;
}

.sp-wiki__item-icon {
  display: block;
  width: 100%;
  height: 100%;
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
  object-position: center;
}

.sp-wiki__sort-icon {
  margin-left: 4px;
  opacity: 0.35;
  font-size: 0.65rem;
}

.sp-wiki__th--active .sp-wiki__sort-icon {
  opacity: 1;
}

.sp-wiki__tr {
  background: var(--ty-dark-bg);
}

.sp-wiki__tr--even {
  background: rgba(39, 40, 49, 0.55);
}

.sp-wiki__tr:hover {
  background: var(--ty-hover-surface);
}

.sp-wiki__td {
  padding: 9px 12px;
  border-bottom: 1px solid var(--ty-border-muted);
  font-size: 0.85rem;
  color: var(--ty-text);
  vertical-align: top;
}

.sp-wiki__td--mono {
  font-family: ui-monospace, monospace;
  font-variant-numeric: tabular-nums;
}

.sp-wiki__td--center {
  text-align: center;
}

.sp-wiki__strong {
  color: var(--ty-text);
  font-weight: 600;
}

.sp-wiki__muted {
  color: var(--ty-text-muted);
  font-size: 0.8rem;
}

.sp-wiki__gold {
  color: #f5e6a8;
}

.sp-wiki__purple {
  color: #c4b5fd;
}

.sp-wiki__danger {
  color: #f87171;
}

.sp-wiki__stat-high {
  color: #f43f5e;
}

.sp-wiki__stat-ok {
  color: #4ade80;
}

/* Filter chips */
.sp-wiki__filter-row {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-bottom: 16px;
}

.sp-wiki__chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 14px;
  border-radius: var(--ty-radius);
  border: 1px solid var(--ty-border-muted);
  cursor: pointer;
  font-size: 0.75rem;
  font-weight: 600;
  background: transparent;
  color: var(--ty-text-muted);
  transition: border-color 0.15s, color 0.15s, background 0.15s;
  font-family: var(--ty-font-sans);
}

.sp-wiki__chip-count {
  font-size: 0.65rem;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  padding: 1px 5px;
  border-radius: var(--ty-radius);
  background: rgba(0, 0, 0, 0.35);
  color: var(--ty-text-muted);
}

.sp-wiki__chip--active .sp-wiki__chip-count {
  background: rgba(122, 90, 248, 0.35);
  color: #e8e0ff;
}

.sp-wiki__chip:hover {
  color: var(--ty-text);
  border-color: rgba(122, 90, 248, 0.4);
}

.sp-wiki__chip--active {
  background: rgba(122, 90, 248, 0.18);
  border-color: var(--ty-accent-solid);
  color: #d4bfff;
}

/* Rarity badge */
.sp-wiki__rarity {
  display: inline-block;
  padding: 1px 7px;
  border-radius: var(--ty-radius);
  font-size: 0.7rem;
  font-weight: 600;
  white-space: nowrap;
  border: 1px solid var(--ty-border-muted);
  background: rgba(90, 93, 107, 0.25);
  color: var(--ty-text);
}

.sp-wiki__rarity[data-rarity="Rare"] {
  border-color: #3d6b9e;
  background: rgba(61, 107, 158, 0.28);
  color: #93c5fd;
}

.sp-wiki__rarity[data-rarity="Epic"] {
  border-color: var(--ty-accent-solid);
  background: rgba(122, 90, 248, 0.22);
  color: #e8e2ff;
}

.sp-wiki__rarity[data-rarity="Legendary"] {
  border-color: #c9a227;
  background: rgba(201, 162, 39, 0.2);
  color: #f5e6a8;
}

.sp-wiki__rarity[data-rarity="Mythical"],
.sp-wiki__rarity[data-rarity="Mythical Paramecia"],
.sp-wiki__rarity[data-rarity="Mythical Zoan"] {
  border-color: #c45c8a;
  background: rgba(196, 92, 138, 0.22);
  color: #ffd6e8;
}

.sp-wiki__rarity[data-rarity="Mythical S+"] {
  border-color: #8b5cf6;
  background: rgba(139, 92, 246, 0.22);
  color: #f0e6ff;
}

.sp-wiki__rarity[data-rarity="Secret"] {
  border-color: #059669;
  background: rgba(5, 150, 105, 0.2);
  color: #6ee7b7;
}

/* Tier */
.sp-wiki__tier {
  font-family: ui-monospace, monospace;
  font-weight: 700;
  font-size: 0.85rem;
}

.sp-wiki__tier[data-tier="D"] {
  color: #9ca3af;
}
.sp-wiki__tier[data-tier="C"] {
  color: #4ade80;
}
.sp-wiki__tier[data-tier="B"] {
  color: #60a5fa;
}
.sp-wiki__tier[data-tier="A"] {
  color: #c4b5fd;
}
.sp-wiki__tier[data-tier="S"] {
  color: #fbbf24;
}
.sp-wiki__tier[data-tier="S+"] {
  color: #fb7185;
}

.sp-wiki__type-pill {
  font-size: 0.7rem;
  padding: 2px 8px;
  border-radius: var(--ty-radius);
  background: var(--uibluegray);
  color: #93c5fd;
}

.sp-wiki__type-pill--spec {
  background: rgba(201, 162, 39, 0.2);
  color: #f5e6a8;
}

.sp-wiki__sea-pill {
  font-size: 0.7rem;
  padding: 2px 8px;
  border-radius: var(--ty-radius);
  background: var(--uibluegray);
  color: #93c5fd;
}

.sp-wiki__sea-pill--2 {
  background: rgba(139, 92, 246, 0.22);
  color: #e9d5ff;
}

.sp-wiki__island-name--sea2 {
  color: #d8b4fe;
}

.sp-wiki__fruit-banner {
  background: var(--ty-dark-bg);
  border: 1px solid var(--ty-border-muted);
  border-radius: var(--ty-radius);
  padding: 12px 16px;
  margin-bottom: 16px;
  font-size: 0.8rem;
  color: var(--ty-text-muted);
}

.sp-wiki__fruit-banner strong {
  color: var(--ty-accent-solid);
}

.sp-wiki__order-num {
  color: var(--ty-text-muted);
}

@media (max-width: 768px) {
  .sailor-piece-wiki {
    --sp-wiki-icon-frame: 88px;
  }

  .sp-wiki__th,
  .sp-wiki__td {
    padding: 8px 8px;
    font-size: 0.8rem;
  }

  .sp-wiki__title {
    font-size: 1.25rem;
  }
}

/* ── Entity detail pages & shared sp-* tables (bosses/swords/specs/islands) ── */
.sp-table-wrap {
  overflow-x: auto;
}

.sp-table {
  width: 100%;
  border-collapse: collapse;
}

.sp-table th {
  padding: 10px 14px;
  text-align: left;
  background: var(--ty-dark-bg, #0a0e16);
  color: var(--ty-accent-solid, #7c5cff);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  white-space: nowrap;
  border-bottom: 1px solid var(--ty-border-muted, #1e293b);
}

.sp-table td {
  padding: 9px 14px;
  border-bottom: 1px solid var(--ty-border-muted, #0f172a);
  font-size: 13px;
  color: var(--ty-text-muted, #cbd5e1);
  vertical-align: top;
}

.sp-table tr:nth-child(even) td {
  background: rgba(0, 0, 0, 0.15);
}

/* Swords index: weapon icons (same assets as wiki `loadSailorPieceWeaponImageMap`) */
.sp-swords-index-table {
  --sp-wiki-icon-frame: 72px;
}

.sp-swords-index-table .sp-swords-index__th-icon {
  text-align: center;
}

.sp-swords-index-table .sp-swords-index__icon-cell {
  vertical-align: middle;
  width: 84px;
}

.sp-detail-hero {
  margin: 24px 0 20px;
}

.sp-detail-title {
  font-size: clamp(22px, 4vw, 36px);
  font-weight: 900;
  margin: 0 0 12px;
  background: linear-gradient(135deg, var(--ty-accent-solid, #7c5cff), #a78bfa);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.sp-detail-meta {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  align-items: center;
}

.sp-detail-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: 16px;
  margin-top: 24px;
}

.sp-detail-card {
  background: var(--ty-dark-bg, #0d1117);
  border: 1px solid var(--ty-border-muted, #1e293b);
  border-radius: var(--ty-radius);
  padding: 20px 22px;
}

.sp-detail-card h2 {
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--ty-accent-solid, #7c5cff);
  margin: 0 0 14px;
}

.sp-detail-card--wide {
  grid-column: 1 / -1;
}

.sp-chip {
  background: #1e293b;
  color: #94a3b8;
  padding: 4px 12px;
  border-radius: var(--ty-radius);
  font-size: 12px;
}

.sp-chip a {
  color: #94a3b8;
  text-decoration: none;
}

.sp-chip a:hover {
  color: var(--ty-accent-solid, #7c5cff);
}

.sp-rarity {
  padding: 2px 8px;
  border-radius: var(--ty-radius);
  font-size: 11px;
  font-weight: 700;
}

.sp-rarity[data-rarity="Common"] {
  background: #1a1d21;
  color: #9ca3af;
}

.sp-rarity[data-rarity="Rare"] {
  background: #0f2044;
  color: #60a5fa;
}

.sp-rarity[data-rarity="Epic"] {
  background: #1a0d3a;
  color: #a78bfa;
}

.sp-rarity[data-rarity="Legendary"] {
  background: #2a1a00;
  color: #fbbf24;
}

.sp-rarity[data-rarity="Mythical"] {
  background: #2a0d0d;
  color: #f87171;
}

.sp-rarity[data-rarity="Secret"] {
  background: #1a0a2e;
  color: #e879f9;
}

.sp-tier {
  font-family: ui-monospace, monospace;
  font-weight: 700;
  font-size: 13px;
}

.sp-tier[data-tier="S+"] {
  color: #f43f5e;
  text-shadow: 0 0 10px #f43f5e66;
}

.sp-tier[data-tier="S"] {
  color: #f59e0b;
}

.sp-tier[data-tier="A"] {
  color: #a855f7;
}

.sp-tier[data-tier="B"] {
  color: #3b82f6;
}

.sp-tier[data-tier="C"] {
  color: #22c55e;
}

.sp-tier[data-tier="D"] {
  color: #6b7280;
}

.sp-sea[data-sea="2"] {
  background: #1a0a2e;
  color: #e879f9;
  padding: 2px 8px;
  border-radius: var(--ty-radius);
  font-size: 11px;
}

.sp-sea[data-sea="1"] {
  background: #0f172a;
  color: #60a5fa;
  padding: 2px 8px;
  border-radius: var(--ty-radius);
  font-size: 11px;
}

.sp-type[data-type="Spec"] {
  color: #fbbf24;
}

.sp-type[data-type="Melee"] {
  color: #60a5fa;
}

.sp-entity-link {
  color: var(--ty-text, #e2e8f0);
  font-weight: 600;
  text-decoration: none;
}

.sp-entity-link:hover {
  color: var(--ty-accent-solid, #7c5cff);
}

.sp-wiki__entity-link {
  color: inherit;
}

.sp-wiki__entity-link:hover .sp-wiki__strong {
  color: var(--ty-accent-solid);
}

.sp-loc-link {
  color: #94a3b8;
  font-size: 12px;
  text-decoration: none;
}

.sp-loc-link:hover {
  color: var(--ty-accent-solid, #7c5cff);
}

.sp-tag {
  display: inline-block;
  padding: 2px 8px;
  border-radius: var(--ty-radius);
  font-size: 11px;
  text-decoration: none;
  margin: 2px;
}

.sp-tag--boss {
  background: #2a0d0d;
  color: #f87171;
}

.sp-tag--boss:hover {
  background: #3a1010;
}

.sp-tag--sword {
  background: #0f2044;
  color: #60a5fa;
}

.sp-tag--spec {
  background: #1a0d3a;
  color: #a78bfa;
}

.sp-link-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.sp-link-list a {
  display: flex;
  gap: 8px;
  align-items: center;
  text-decoration: none;
  color: #cbd5e1;
  padding: 6px 8px;
  border-radius: var(--ty-radius);
}

.sp-link-list a:hover {
  background: #1e293b;
  color: var(--ty-accent-solid, #7c5cff);
}

.sp-upgrade-link {
  display: flex;
  gap: 10px;
  align-items: center;
  padding: 10px 12px;
  background: #0a1628;
  border: 1px solid rgba(0, 229, 255, 0.15);
  border-radius: var(--ty-radius);
  text-decoration: none;
  color: #e2e8f0;
}

.sp-upgrade-link:hover {
  border-color: rgba(0, 229, 255, 0.4);
}

.sp-title-drop {
  margin-top: 12px;
  padding: 10px;
  background: #1a1200;
  border-radius: var(--ty-radius);
  font-size: 13px;
}

.sp-mono {
  font-family: ui-monospace, monospace;
}

.sp-gold {
  color: #fbbf24;
}

.sp-bold {
  font-weight: 600;
  color: var(--ty-text, #e2e8f0);
}

.sp-small {
  font-size: 12px;
}

.sp-muted {
  color: #475569;
}

.sp-note {
  color: #94a3b8;
  font-size: 12px;
  font-style: italic;
}

.sp-requirements {
  background: #1e293b;
  padding: 8px 12px;
  border-radius: var(--ty-radius);
  margin-top: 10px;
  font-size: 12px;
}

.sp-dl {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 6px 16px;
  font-size: 13px;
}

.sp-dl dt {
  color: #64748b;
  font-weight: 600;
}

.sp-dl dd {
  color: #cbd5e1;
  margin: 0;
}

.sp-drop-rate {
  color: #fbbf24;
  font-size: 11px;
  font-family: ui-monospace, monospace;
}

/* Systems compendium (Races / Traits / … tabs inside .sailor-piece-wiki) */
.sailor-piece-wiki .sp-wiki__compendium-embed {
  margin: 0 0 8px;
  padding: 0 8px 20px;
  color: var(--ty-text, #e2e8f0);
  font-family: var(--ty-font-sans);
}

.sailor-piece-wiki .sp-wiki__compendium-intro,
.sailor-piece-wiki .sp-wiki__compendium-inner {
  max-width: 100%;
  overflow-x: auto;
}

.sailor-piece-wiki .sp-wiki__compendium-intro {
  margin-bottom: 20px;
}

.sailor-piece-wiki .sp-wiki__compendium-intro h2 {
  font-size: clamp(1.25rem, 2.5vw, 1.65rem);
  font-weight: 800;
  margin: 0 0 12px;
  color: var(--ty-text, #e2e8f0);
  line-height: 1.25;
}

.sailor-piece-wiki .sp-wiki__compendium-inner h3 {
  font-size: 1.05rem;
  font-weight: 700;
  margin: 8px 0 10px;
  color: var(--ty-text, #e2e8f0);
  border-bottom: 1px solid var(--ty-border-muted, #334155);
  padding-bottom: 6px;
}

.sailor-piece-wiki .sp-wiki__compendium-intro p,
.sailor-piece-wiki .sp-wiki__compendium-intro li,
.sailor-piece-wiki .sp-wiki__compendium-inner p,
.sailor-piece-wiki .sp-wiki__compendium-inner li {
  font-size: 0.95rem;
  line-height: 1.6;
  color: #cbd5e1;
}

.sailor-piece-wiki .sp-wiki__compendium-intro a,
.sailor-piece-wiki .sp-wiki__compendium-inner a {
  color: var(--ty-accent-solid, #7c5cff);
  text-decoration: none;
  font-weight: 600;
  border-radius: 2px;
}

.sailor-piece-wiki .sp-wiki__compendium-intro a:hover,
.sailor-piece-wiki .sp-wiki__compendium-inner a:hover {
  text-decoration: underline;
}

.sailor-piece-wiki .sp-wiki__compendium-intro hr,
.sailor-piece-wiki .sp-wiki__compendium-inner hr {
  border: 0;
  border-top: 1px solid var(--ty-border-muted, #334155);
  margin: 20px 0;
}

.sailor-piece-wiki .sp-wiki__compendium-inner table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.8rem;
  margin: 12px 0 20px;
  min-width: 520px;
}

.sailor-piece-wiki .sp-wiki__compendium-inner th,
.sailor-piece-wiki .sp-wiki__compendium-inner td {
  border: 1px solid var(--ty-border-muted, #334155);
  padding: 8px 10px;
  text-align: left;
  vertical-align: top;
}

.sailor-piece-wiki .sp-wiki__compendium-inner th {
  background: rgba(43, 42, 60, 0.45);
  font-weight: 700;
  color: var(--ty-text, #e2e8f0);
}

.sailor-piece-wiki .sp-wiki__compendium-intro strong,
.sailor-piece-wiki .sp-wiki__compendium-inner strong {
  color: var(--ty-text, #e2e8f0);
}
