*,
    *::before,
    *::after {
      box-sizing: border-box;
      margin: 0;
      padding: 0
    }

    :root {
      --bg: #0B0E14;
      --surface: #0f1218;
      --surface2: #141820;
      --row-alt: #0d1017;
      --hover: #161b26;
      --border: #1a1f2e;
      --border2: #202638;
      --muted: #7d86a9;
      --text: #c3c9e6;
      --bright: #dde0f5;
      --white: #eef0fc;
      --desc-lines: 2;
      /* Discord Blurple — główna nawigacja */
      --blurple: #5865F2;
      --blurple-light: #7983f5;
      --blurple-dim: rgba(88, 101, 242, .15);
      --blurple-border: rgba(88, 101, 242, .45);
      /* Royal Glimmer — akcenty UI */
      --royal-blue: #293C7C;
      --royal-teal: #024944;
      --royal-crimson: #812B4A;
      --royal-gold: #C7984F;
      --gold-dim: rgba(199, 152, 79, .15);
      --gold-border: rgba(199, 152, 79, .4);
      --crimson-dim: rgba(129, 43, 74, .2);
      --crimson-border: rgba(129, 43, 74, .5);
      /* source badges */
      --sa: #2aaa88;
      --sa-bg: rgba(2, 73, 68, .28);
      --sk: #7983f5;
      --sk-bg: rgba(88, 101, 242, .18);
      --sd: #C7984F;
      --sd-bg: rgba(199, 152, 79, .14);
      --st: #58a6ff;
      --st-bg: rgba(88, 166, 255, .18);
      --ss: #9b7cff;
      --ss-bg: rgba(155, 124, 255, .16);
      --sm: #ff8f66;
      --sm-bg: rgba(255, 143, 102, .16);
      /* subtle inclusive accents */
      --pride-red: #ff6b7c;
      --pride-orange: #ffad5c;
      --pride-yellow: #ffd76a;
      --pride-green: #7bdd8d;
      --pride-blue: #63a9ff;
      --pride-violet: #b78cff;
      --trans-blue: #72c8ff;
      --trans-pink: #f7a8d6;
      --trans-white: #f6f4ff;
      --femboy-pink: #ff8fc9;
      --femboy-blue: #9bc6ff;
      --furry-amber: #ffbf74;
      --furry-rose: #ff8e99;
      --inclusive-glow: rgba(255, 178, 217, .16);
      /* PL flag */
      --flag-active: #160d10;
      --flag-border: rgba(220, 36, 36, .55);
      --focus: rgba(199, 152, 79, .5);
      --ease-out-quart: cubic-bezier(0.25, 1, 0.5, 1);
      --ease-out-expo: cubic-bezier(0.16, 1, 0.3, 1);
    }

    html {
      scroll-behavior: smooth
    }

    body {
      font-family: 'Manrope', 'Inter', Helvetica, Arial, sans-serif;
      background: var(--bg);
      color: var(--text);
      font-size: 14px;
      line-height: 1.4;
      min-height: 100vh;
      -webkit-font-smoothing: antialiased
    }

    .hdr {
      position: sticky;
      top: 0;
      z-index: 100;
      background:
        radial-gradient(circle at top left, rgba(247, 168, 214, .09), transparent 30%),
        radial-gradient(circle at top right, rgba(114, 200, 255, .08), transparent 28%),
        linear-gradient(180deg, rgba(15, 18, 24, .98), rgba(15, 18, 24, .94));
      border-bottom: 1px solid var(--border2);
      padding: 12px 28px;
      display: flex;
      align-items: center;
      gap: 14px;
      overflow: clip
    }

    .hdr-logo {
      position: relative;
      font-size: 12px;
      font-weight: 800;
      letter-spacing: .14em;
      color: #fff;
      text-transform: uppercase;
      padding: 5px 11px;
      border: 1px solid rgba(247, 168, 214, .36);
      border-radius: 5px;
      white-space: nowrap;
      flex-shrink: 0;
      line-height: 1;
      background:
        linear-gradient(120deg, rgba(255, 107, 124, .22), rgba(255, 173, 92, .16) 22%, rgba(255, 215, 106, .12) 38%, rgba(123, 221, 141, .14) 52%, rgba(99, 169, 255, .16) 70%, rgba(183, 140, 255, .2));
      box-shadow: 0 0 18px rgba(247, 168, 214, .1), inset 0 1px 0 rgba(255, 255, 255, .08);
      isolation: isolate
    }

    .hdr-logo::before {
      content: "";
      position: absolute;
      inset: 0;
      background: linear-gradient(105deg, transparent 20%, rgba(255, 255, 255, .18) 46%, transparent 58%);
      transform: translateX(-130%);
      animation: logo-sheen 6.5s var(--ease-out-expo) infinite;
      pointer-events: none
    }

    .hdr-logo::after {
      content: "";
      position: absolute;
      inset: auto 6px -1px 6px;
      height: 2px;
      border-radius: 999px;
      background: linear-gradient(90deg, var(--trans-blue), var(--trans-pink), var(--femboy-pink), var(--pride-violet));
      opacity: .9
    }

    .hdr-sep {
      width: 1px;
      height: 22px;
      background: var(--border2);
      flex-shrink: 0
    }

    .flag-toggle {
      display: flex;
      gap: 3px;
      background: rgba(0, 0, 0, .2);
      border: 1px solid var(--border2);
      border-radius: 7px;
      padding: 3px;
      flex-shrink: 0
    }

    .flag-btn {
      display: flex;
      align-items: center;
      gap: 6px;
      padding: 7px 12px;
      min-height: 38px;
      border-radius: 4px;
      border: none;
      background: transparent;
      cursor: pointer;
      font-family: inherit;
      font-size: 12px;
      font-weight: 500;
      color: var(--muted);
      transition: all .15s;
      white-space: nowrap;
      user-select: none
    }

    .flag-btn .fe {
      font-size: 15px;
      line-height: 1
    }

    .flag-btn:hover {
      color: var(--text)
    }

    .flag-btn.active {
      background: var(--flag-active);
      border: 1px solid var(--flag-border);
      color: var(--white)
    }

    .flag-btn.active .fl {
      color: var(--blurple-light)
    }

    #btn-pl.active {
      background: linear-gradient(135deg, rgba(220,36,36,.2) 0%, rgba(255,255,255,.07) 100%);
      border: 1px solid rgba(220, 36, 36, .6);
      color: #fff;
      box-shadow: 0 0 12px rgba(220, 36, 36, .2), 0 0 28px rgba(220, 36, 36, .08)
    }

    #btn-pl.active .fl {
      background: linear-gradient(90deg, #ffffff 45%, #dc2424 55%);
      -webkit-background-clip: text;
      -webkit-text-fill-color: transparent;
      background-clip: text;
      font-weight: 700
    }

    .hdr-info {
      display: flex;
      flex-direction: column;
      gap: 1px
    }

    .hdr-title {
      font-size: 13.5px;
      font-weight: 600;
      color: var(--white);
      letter-spacing: -.01em;
      white-space: nowrap
    }

    .hdr-sub {
      font-size: 11px;
      color: var(--muted);
      line-height: 1.45
    }

    .hdr-right {
      margin-left: auto;
      display: flex;
      align-items: center;
      gap: 12px;
      flex-shrink: 0
    }

    .hdr-count {
      text-align: right
    }

    .hdr-n {
      font-size: 18px;
      font-weight: 700;
      color: var(--white);
      letter-spacing: -.02em;
      line-height: 1
    }

    .hdr-nl {
      font-size: 10px;
      color: var(--muted);
      margin-top: 2px;
      letter-spacing: .05em;
      text-transform: uppercase
    }

    .discord-btn {
      display: inline-flex;
      align-items: center;
      gap: 6px;
      min-height: 38px;
      padding: 7px 12px;
      border-radius: 4px;
      background: rgba(88, 101, 242, .16);
      border: 1px solid rgba(88, 101, 242, .38);
      color: var(--blurple-light);
      font-size: 12px;
      line-height: 1;
      font-weight: 600;
      text-decoration: none;
      white-space: nowrap;
      transition: all .15s;
      flex-shrink: 0
    }

    .discord-btn:hover {
      background: rgba(88, 101, 242, .3);
      border-color: rgba(88, 101, 242, .65);
      color: #a5aaff;
      box-shadow: 0 0 14px rgba(88, 101, 242, .18)
    }

    .discord-btn svg {
      flex-shrink: 0
    }

    .ts {
      position: sticky;
      top: var(--hdr-h, 52px);
      z-index: 50;
      background: rgba(26, 24, 37, .97);
      backdrop-filter: blur(20px);
      border-bottom: 1px solid var(--border)
    }

    .tb {
      padding: 10px 28px;
      display: flex;
      gap: 9px;
      align-items: center;
      flex-wrap: nowrap
    }

    .sw {
      position: relative;
      flex: 1;
      min-width: 220px;
      max-width: 360px;
      z-index: 60
    }

    .sw svg {
      position: absolute;
      left: 9px;
      top: 50%;
      transform: translateY(-50%);
      color: var(--muted);
      pointer-events: none
    }

    input[type=search] {
      width: 100%;
      min-height: 38px;
      padding: 8px 11px 8px 30px;
      background: rgba(0, 0, 0, .25);
      border: 1px solid var(--border2);
      border-radius: 6px;
      color: var(--white);
      font-family: inherit;
      font-size: 13px;
      outline: none;
      transition: border-color .15s;
      position: relative;
      z-index: 61
    }

    input[type=search]:focus {
      border-color: var(--royal-gold);
      box-shadow: 0 0 0 2px rgba(199, 152, 79, .12)
    }

    input[type=search]::placeholder {
      color: var(--muted)
    }

    .pills-bar {
      padding: 8px 28px 10px;
      display: flex;
      justify-content: center;
      flex-wrap: wrap;
      gap: 4px;
      border-bottom: 1px solid var(--border)
    }

    .pills {
      display: flex;
      gap: 4px;
      flex-wrap: wrap;
      justify-content: center;
      max-height: none
    }

    .pill {
      position: relative;
      display: inline-flex;
      align-items: center;
      gap: 5px;
      min-height: var(--pill-min-h, 32px);
      padding: var(--pill-pad-y, 5px) var(--pill-pad-x, 10px);
      border-radius: 12px;
      font-size: var(--pill-font, 11px);
      font-weight: 500;
      cursor: pointer;
      user-select: none;
      white-space: nowrap;
      border: 1px solid color-mix(in srgb, var(--cat-ink, #8e97bf) 24%, var(--border2) 76%);
      color: var(--cat-text, #c8cde8);
      background: linear-gradient(180deg, color-mix(in srgb, var(--cat-ink, #8e97bf) 10%, transparent), color-mix(in srgb, var(--cat-ink, #8e97bf) 3%, transparent));
      transition: transform .22s var(--ease-out-quart), border-color .22s var(--ease-out-quart), background .22s var(--ease-out-quart), color .22s var(--ease-out-quart), box-shadow .22s var(--ease-out-quart);
      line-height: 1.5;
      overflow: hidden
    }

    .pill:hover {
      color: color-mix(in srgb, var(--cat-text, #c8cde8) 82%, white 18%);
      border-color: color-mix(in srgb, var(--cat-ink, #8e97bf) 36%, white 8%, var(--border2) 56%);
      background: linear-gradient(180deg, color-mix(in srgb, var(--cat-ink, #8e97bf) 14%, transparent), color-mix(in srgb, var(--cat-ink, #8e97bf) 4%, transparent));
      transform: translateY(-1px)
    }

    .pill.on {
      background: linear-gradient(180deg, color-mix(in srgb, var(--cat-ink, #8e97bf) 18%, transparent), color-mix(in srgb, var(--cat-ink, #8e97bf) 7%, transparent));
      border-color: color-mix(in srgb, var(--cat-ink, #8e97bf) 46%, transparent);
      color: var(--cat-text, #d4a96a);
      font-weight: 600;
      box-shadow: 0 8px 24px rgba(0, 0, 0, .16)
    }

    .pill::before {
      content: "";
      position: absolute;
      inset: auto 10px 0 10px;
      height: 2px;
      border-radius: 999px;
      background: color-mix(in srgb, var(--cat-ink, #7f89b6) 75%, white 25%);
      opacity: .55;
      transform: scaleX(.18);
      transform-origin: left center;
      transition: transform .24s var(--ease-out-quart), opacity .24s var(--ease-out-quart);
      pointer-events: none
    }

    .pill:hover::before,
    .pill.on::before {
      transform: scaleX(1);
      opacity: .95
    }

    .pill[data-accent="pride"] {
      border-color: rgba(183, 140, 255, .32);
      background: linear-gradient(135deg, rgba(255, 107, 124, .08), rgba(99, 169, 255, .05) 55%, rgba(183, 140, 255, .08));
    }

    .pill[data-accent="pride"].on {
      color: #ffe7f4;
      border-color: rgba(247, 168, 214, .5);
      background: linear-gradient(135deg, rgba(255, 107, 124, .18), rgba(255, 173, 92, .14) 20%, rgba(255, 215, 106, .12) 36%, rgba(123, 221, 141, .12) 54%, rgba(99, 169, 255, .14) 72%, rgba(183, 140, 255, .18));
      box-shadow: 0 10px 24px rgba(247, 168, 214, .12)
    }

    .pill[data-accent="trans"] {
      border-color: rgba(114, 200, 255, .35)
    }

    .pill[data-accent="trans"].on {
      color: #eef9ff;
      border-color: rgba(247, 168, 214, .48);
      background: linear-gradient(135deg, rgba(114, 200, 255, .2), rgba(246, 244, 255, .1) 50%, rgba(247, 168, 214, .22))
    }

    .pill[data-accent="femboy"] {
      border-color: rgba(255, 143, 201, .32)
    }

    .pill[data-accent="femboy"].on {
      color: #ffeef7;
      border-color: rgba(255, 143, 201, .48);
      background: linear-gradient(135deg, rgba(255, 143, 201, .22), rgba(155, 198, 255, .16))
    }

    .pill[data-accent="furry"] {
      border-color: rgba(255, 191, 116, .32)
    }

    .pill[data-accent="furry"].on {
      color: #fff0dd;
      border-color: rgba(255, 191, 116, .48);
      background: linear-gradient(135deg, rgba(255, 191, 116, .22), rgba(255, 142, 153, .15))
    }

    .pill[data-tone="gold"] {
      --pill-ink: #d9a25a;
      border-color: rgba(217, 162, 90, .26);
      background: linear-gradient(180deg, rgba(217, 162, 90, .1), rgba(217, 162, 90, .03));
      color: #e3c18f
    }

    .pill[data-tone="blue"] {
      --pill-ink: #80a8ff;
      border-color: rgba(128, 168, 255, .26);
      background: linear-gradient(180deg, rgba(128, 168, 255, .09), rgba(128, 168, 255, .025));
      color: #b8cfff
    }

    .pill[data-tone="rose"] {
      --pill-ink: #e38da4;
      border-color: rgba(227, 141, 164, .24);
      background: linear-gradient(180deg, rgba(227, 141, 164, .09), rgba(227, 141, 164, .025));
      color: #efbdcb
    }

    .pill[data-tone="emerald"] {
      --pill-ink: #61c3a1;
      border-color: rgba(97, 195, 161, .24);
      background: linear-gradient(180deg, rgba(97, 195, 161, .09), rgba(97, 195, 161, .025));
      color: #a6e2cf
    }

    .pill[data-tone="violet"] {
      --pill-ink: #a793ff;
      border-color: rgba(167, 147, 255, .25);
      background: linear-gradient(180deg, rgba(167, 147, 255, .09), rgba(167, 147, 255, .025));
      color: #d0c7ff
    }

    .pill[data-tone="amber"] {
      --pill-ink: #e0b35d;
      border-color: rgba(224, 179, 93, .26);
      background: linear-gradient(180deg, rgba(224, 179, 93, .1), rgba(224, 179, 93, .03));
      color: #efcf95
    }

    .pill[data-tone="cyan"] {
      --pill-ink: #72c8d8;
      border-color: rgba(114, 200, 216, .24);
      background: linear-gradient(180deg, rgba(114, 200, 216, .09), rgba(114, 200, 216, .025));
      color: #b2e7ee
    }

    .pill[data-tone="slate"] {
      --pill-ink: #8e97bf;
      border-color: rgba(142, 151, 191, .2);
      background: linear-gradient(180deg, rgba(142, 151, 191, .07), rgba(142, 151, 191, .02));
      color: #c2c8e3
    }

    .pill-n {
      font-size: var(--pill-count-font, 10px);
      font-weight: 700;
      color: rgba(255, 255, 255, .35);
      background: color-mix(in srgb, var(--cat-ink, #8e97bf) 14%, rgba(0, 0, 0, .25));
      border-radius: 8px;
      padding: 0 var(--pill-count-pad-x, 5px);
      line-height: 1.6;
      letter-spacing: .02em
    }

    .pill.on .pill-n {
      color: color-mix(in srgb, var(--cat-text, #d4a96a) 82%, white 18%);
      background: color-mix(in srgb, var(--cat-ink, #8e97bf) 20%, transparent)
    }

    .sgrp {
      display: flex;
      gap: 3px;
      margin-left: auto;
      flex-wrap: wrap;
      justify-content: flex-end
    }

    .sbtn {
      min-height: 36px;
      padding: 7px 10px;
      border-radius: 5px;
      font-size: 12px;
      cursor: pointer;
      user-select: none;
      white-space: nowrap;
      border: 1px solid transparent;
      color: var(--muted);
      background: transparent;
      font-family: inherit;
      font-weight: 500;
      transition: all .12s
    }

    .sbtn:hover {
      color: var(--text);
      background: var(--surface)
    }

    .sbtn.on {
      background: var(--surface);
      border-color: var(--border2);
      color: var(--bright)
    }

    .rc {
      font-size: 11px;
      color: var(--muted);
      white-space: nowrap;
      font-variant-numeric: tabular-nums
    }

    .rc strong {
      color: var(--text)
    }

    .tw {
      overflow-x: auto;
      overflow-y: clip;
      padding: 0 28px 60px
    }

    table {
      width: 100%;
      min-width: 860px;
      border-collapse: collapse;
      margin-top: 10px;
      table-layout: fixed
    }

    thead th {
      position: static;
      z-index: 20;
      text-align: left;
      font-size: 10.5px;
      letter-spacing: .08em;
      text-transform: uppercase;
      color: var(--muted);
      font-weight: 700;
      padding: 8px 10px;
      border-bottom: 1px solid var(--border2);
      background: rgba(15, 18, 24, .96);
    }

    thead th:last-child,
    thead th:nth-child(3),
    thead th:nth-child(4) {
      text-align: center;
    }

    col.col-num {
      width: 38px
    }

    col.col-name {
      width: 232px
    }

    col.col-mem {
      width: 100px
    }

    col.col-cat {
      width: 146px
    }

    col.col-desc {
      width: auto
    }

    col.col-link {
      width: 88px
    }

    tbody tr {
      border-bottom: 1px solid rgba(80, 75, 120, .34);
      position: relative;
      z-index: 1;
      animation: row-enter .48s var(--ease-out-expo) both;
      animation-delay: calc(var(--row-index, 0) * 18ms);
    }

    tbody tr:nth-child(even) {
      background: rgba(26, 24, 40, .58)
    }

    tbody tr:hover {
      background: rgba(41, 60, 124, .12) !important;
      transition: background .1s
    }

    tbody tr[data-accent="pride"] {
      border-bottom-color: rgba(247, 168, 214, .26)
    }

    tbody tr[data-accent="pride"] td:first-child,
    tbody tr[data-accent="trans"] td:first-child,
    tbody tr[data-accent="femboy"] td:first-child,
    tbody tr[data-accent="furry"] td:first-child {
      background-repeat: no-repeat;
      background-size: 3px calc(100% - 12px);
      background-position: left center
    }

    tbody tr[data-accent="pride"] td:first-child {
      background-image: linear-gradient(180deg, var(--pride-red), var(--pride-orange) 20%, var(--pride-yellow) 38%, var(--pride-green) 56%, var(--pride-blue) 76%, var(--pride-violet))
    }

    tbody tr[data-accent="trans"] td:first-child {
      background-image: linear-gradient(180deg, var(--trans-blue), var(--trans-white) 50%, var(--trans-pink))
    }

    tbody tr[data-accent="femboy"] td:first-child {
      background-image: linear-gradient(180deg, var(--femboy-blue), var(--femboy-pink))
    }

    tbody tr[data-accent="furry"] td:first-child {
      background-image: linear-gradient(180deg, var(--furry-amber), var(--furry-rose))
    }

    tbody td {
      padding-top: 10px;
      padding-bottom: 10px
    }

    td {
      padding: 5px 10px;
      vertical-align: middle;
      overflow: hidden
    }

    .td-num {
      color: rgba(107, 112, 143, .5);
      font-size: 10.5px;
      text-align: right;
      padding-right: 10px;
      font-variant-numeric: tabular-nums;
      white-space: nowrap;
      letter-spacing: .02em
    }

    .src-badge {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      width: 17px;
      height: 17px;
      border-radius: 5px;
      font-size: 9.5px;
      font-weight: 800;
      flex-shrink: 0;
      margin-right: 7px;
      vertical-align: middle;
      position: relative;
      top: -1px;
      letter-spacing: 0
    }

    .src-a {
      background: var(--sa-bg);
      color: var(--sa);
      border: 1px solid rgba(2, 73, 68, .5)
    }

    .src-k {
      background: var(--sk-bg);
      color: var(--sk);
      border: 1px solid rgba(88, 101, 242, .3)
    }

    .src-d {
      background: var(--sd-bg);
      color: var(--sd);
      border: 1px solid rgba(199, 152, 79, .28)
    }

    .src-t {
      background: var(--st-bg);
      color: var(--st);
      border: 1px solid rgba(88, 166, 255, .35)
    }

    .src-s {
      background: var(--ss-bg);
      color: var(--ss);
      border: 1px solid rgba(155, 124, 255, .35)
    }

    .src-m {
      background: var(--sm-bg);
      color: var(--sm);
      border: 1px solid rgba(255, 143, 102, .35)
    }

    .ni {
      display: flex;
      align-items: flex-start;
      overflow: hidden
    }

    .ni a {
      color: var(--white);
      font-weight: 700;
      font-size: 13.5px;
      text-decoration: none;
      transition: color .12s;
      display: block;
      line-height: 1.35;
      white-space: nowrap;
      overflow: hidden;
      text-overflow: ellipsis
    }

    .ni a:hover {
      color: var(--royal-gold)
    }

    .td-mem {
      text-align: right;
      white-space: nowrap;
      font-weight: 700;
      font-size: 13px;
      color: var(--white);
      font-variant-numeric: tabular-nums;
      font-family: ui-monospace, "SF Mono", "Cascadia Code", Consolas, monospace;
      letter-spacing: -.02em
    }

    .est {
      font-size: 9px;
      color: var(--muted);
      font-weight: 400;
      display: block;
      text-align: right;
      margin-top: 1px
    }

    .cat-chip {
      position: relative;
      display: inline-block;
      max-width: 168px;
      overflow: hidden;
      text-overflow: ellipsis;
      white-space: nowrap;
      padding: 3px 8px;
      border-radius: 20px;
      font-size: 9.5px;
      font-weight: 700;
      background: linear-gradient(135deg, color-mix(in srgb, var(--cat-ink, #8e97bf) 16%, transparent), color-mix(in srgb, var(--cat-ink, #8e97bf) 5%, transparent));
      color: var(--cat-text, #8fa0e0);
      border: 1px solid color-mix(in srgb, var(--cat-ink, #8e97bf) 34%, transparent);
      vertical-align: middle;
      letter-spacing: .03em;
      text-transform: uppercase;
      transition: transform .22s var(--ease-out-quart), box-shadow .22s var(--ease-out-quart), border-color .22s var(--ease-out-quart), color .22s var(--ease-out-quart)
    }

    .cat-chip::after {
      content: "";
      position: absolute;
      inset: 0;
      background: linear-gradient(110deg, transparent 15%, rgba(255, 255, 255, .12) 47%, transparent 63%);
      transform: translateX(-140%);
      opacity: 0;
      transition: transform .5s var(--ease-out-expo), opacity .22s var(--ease-out-quart);
      pointer-events: none
    }

    tbody tr:hover .cat-chip::after,
    .pill:hover::after {
      transform: translateX(120%);
      opacity: 1
    }

    .pill::after {
      content: "";
      position: absolute;
      inset: 0;
      border-radius: inherit;
      background: linear-gradient(110deg, transparent 20%, rgba(255, 255, 255, .1) 48%, transparent 62%);
      transform: translateX(-140%);
      opacity: 0;
      transition: transform .5s var(--ease-out-expo), opacity .22s var(--ease-out-quart);
      pointer-events: none
    }

    .cat-chip[data-accent="pride"] {
      background: linear-gradient(135deg, rgba(255, 107, 124, .16), rgba(255, 173, 92, .12) 20%, rgba(255, 215, 106, .08) 35%, rgba(123, 221, 141, .1) 52%, rgba(99, 169, 255, .12) 72%, rgba(183, 140, 255, .16));
      color: #ffe5f1;
      border-color: rgba(247, 168, 214, .5);
      box-shadow: 0 0 0 1px rgba(247, 168, 214, .08), 0 6px 16px rgba(247, 168, 214, .08)
    }

    .cat-chip[data-accent="trans"] {
      background: linear-gradient(135deg, rgba(114, 200, 255, .18), rgba(246, 244, 255, .08) 50%, rgba(247, 168, 214, .18));
      color: #eef9ff;
      border-color: rgba(114, 200, 255, .46)
    }

    .cat-chip[data-accent="femboy"] {
      background: linear-gradient(135deg, rgba(255, 143, 201, .2), rgba(155, 198, 255, .16));
      color: #fff0f7;
      border-color: rgba(255, 143, 201, .48)
    }

    .cat-chip[data-accent="furry"] {
      background: linear-gradient(135deg, rgba(255, 191, 116, .22), rgba(255, 142, 153, .14));
      color: #fff0df;
      border-color: rgba(255, 191, 116, .45)
    }

    .di {
      overflow: hidden;
      display: -webkit-box;
      -webkit-line-clamp: var(--desc-lines);
      -webkit-box-orient: vertical;
      word-break: break-word;
      font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
      font-size: 12px;
      font-weight: 400;
      color: #929bc0;
      line-height: 1.55
    }

    .di mark {
      background: rgba(199, 152, 79, .22);
      color: #e8c080;
      border-radius: 2px;
      padding: 0 2px;
      font-style: normal
    }

    td.td-cat {
      text-align: center
    }

    .td-link {
      text-align: center;
      padding: 5px 6px
    }

    .join-btn {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      min-height: 38px;
      padding: 8px 14px;
      border-radius: 6px;
      font-size: 11.5px;
      font-weight: 700;
      text-decoration: none;
      white-space: nowrap;
      color: #f0c0cc;
      background: rgba(129, 43, 74, .22);
      border: 1px solid rgba(129, 43, 74, .5);
      transition: all .15s;
      font-family: inherit;
      width: 100%;
      letter-spacing: .04em
    }

    .join-btn[data-accent="pride"] {
      color: #ffe1ee;
      border-color: rgba(247, 168, 214, .42);
      background: linear-gradient(135deg, rgba(255, 107, 124, .2), rgba(99, 169, 255, .12) 55%, rgba(183, 140, 255, .18))
    }

    .join-btn[data-accent="trans"] {
      color: #eef9ff;
      border-color: rgba(114, 200, 255, .42);
      background: linear-gradient(135deg, rgba(114, 200, 255, .18), rgba(247, 168, 214, .16))
    }

    .join-btn[data-accent="femboy"] {
      color: #fff0f8;
      border-color: rgba(255, 143, 201, .42);
      background: linear-gradient(135deg, rgba(255, 143, 201, .22), rgba(155, 198, 255, .12))
    }

    .join-btn[data-accent="furry"] {
      color: #fff0df;
      border-color: rgba(255, 191, 116, .42);
      background: linear-gradient(135deg, rgba(255, 191, 116, .22), rgba(255, 142, 153, .12))
    }

    .join-btn:hover {
      background: rgba(129, 43, 74, .45);
      border-color: rgba(160, 55, 90, .8);
      color: #ffd8e4;
      transform: translateY(-1px);
      box-shadow: 0 4px 16px rgba(129, 43, 74, .35), 0 0 0 1px rgba(160, 55, 90, .2)
    }

    .pgn {
      display: flex;
      align-items: center;
      gap: 8px;
      padding: 14px 28px 0;
      flex-wrap: wrap
    }

    .pgn-info {
      font-size: 11.5px;
      color: var(--muted)
    }

    .pgn-info strong {
      color: var(--text)
    }

    .pgn-btns {
      display: flex;
      gap: 4px;
      margin-left: auto;
      flex-wrap: wrap
    }

    .pgn-btn {
      min-height: 34px;
      padding: 7px 10px;
      border-radius: 5px;
      font-size: 11.5px;
      font-weight: 500;
      cursor: pointer;
      border: 1px solid var(--border2);
      color: var(--muted);
      background: transparent;
      font-family: inherit;
      transition: all .12s
    }

    .pgn-btn:hover:not(:disabled) {
      color: var(--text);
      border-color: var(--muted)
    }

    .pgn-btn:disabled {
      opacity: .35;
      cursor: default
    }

    .pgn-btn.cur {
      background: var(--gold-dim);
      border-color: var(--gold-border);
      color: var(--royal-gold);
      font-weight: 600
    }

    .empty-state {
      display: flex;
      flex-direction: column;
      align-items: center;
      justify-content: center;
      padding: 90px 40px;
      text-align: center;
      gap: 12px
    }

    .empty-state .es-icon {
      font-size: 38px;
      opacity: .35
    }

    .empty-state .es-title {
      font-size: 15px;
      font-weight: 600;
      color: var(--white)
    }

    .empty-state .es-sub {
      font-size: 12.5px;
      color: var(--muted);
      max-width: 400px;
      line-height: 1.65
    }

    .empty-state code {
      background: var(--surface);
      border: 1px solid var(--border2);
      padding: 2px 7px;
      border-radius: 4px;
      font-size: 11.5px;
      color: var(--royal-gold)
    }

    .loading {
      display: flex;
      flex-direction: column;
      align-items: center;
      justify-content: center;
      gap: 10px;
      padding: 80px;
      color: var(--muted);
      font-size: 13px
    }

    .spinner {
      width: 18px;
      height: 18px;
      border: 2px solid var(--border2);
      border-top-color: var(--royal-gold);
      border-radius: 50%;
      animation: spin .7s linear infinite
    }

    @keyframes spin {
      to {
        transform: rotate(360deg)
      }
    }

    @keyframes logo-sheen {
      0%, 70%, 100% {
        transform: translateX(-130%)
      }

      18%, 32% {
        transform: translateX(130%)
      }
    }

    @keyframes row-enter {
      from {
        opacity: 0;
        transform: translateY(8px)
      }

      to {
        opacity: 1;
        transform: translateY(0)
      }
    }

    .no-res {
      text-align: center;
      padding: 80px;
      color: var(--muted);
      font-size: 14px
    }

    .retry-btn {
      min-height: 36px;
      padding: 8px 12px;
      border-radius: 6px;
      border: 1px solid var(--gold-border);
      background: var(--gold-dim);
      color: var(--royal-gold);
      font-family: inherit;
      font-size: 12px;
      font-weight: 600;
      cursor: pointer;
      transition: all .15s;
    }

    .retry-btn:hover {
      filter: brightness(1.08);
    }

    ::-webkit-scrollbar {
      width: 4px;
      height: 4px
    }

    ::-webkit-scrollbar-track {
      background: transparent
    }

    ::-webkit-scrollbar-thumb {
      background: var(--border2);
      border-radius: 2px
    }

    a:focus-visible,
    button:focus-visible,
    input:focus-visible,
    .pill:focus-visible {
      outline: 2px solid var(--focus);
      outline-offset: 2px;
    }

    @media(max-width:1024px) {
      col.col-name {
        width: 208px
      }

      col.col-mem {
        width: 88px
      }

      col.col-cat {
        width: 124px
      }
    }

    @media(max-width:800px) {
      :root {
        --desc-lines: 2;
      }

      .hdr,
      .tb,
      .tw,
      .pgn {
        padding-left: 14px;
        padding-right: 14px
      }

      .hdr {
        flex-wrap: wrap;
        row-gap: 8px;
        padding-top: 10px;
        padding-bottom: 10px
      }

      .hdr-info {
        order: 3;
        flex: 1 1 100%
      }

      .hdr-sub {
        display: none
      }

      .hdr-right {
        order: 2;
        width: auto;
        margin-left: auto;
        justify-content: flex-end;
        gap: 8px
      }

      .tb {
        display: grid;
        grid-template-columns: 1fr auto;
        grid-template-areas:
          "search search"
          "sort meta";
        align-items: center;
        row-gap: 8px
      }

      .sw {
        grid-area: search;
        flex: unset;
        max-width: none
      }

      .sgrp {
        grid-area: sort;
        margin-left: 0;
        width: auto;
        justify-content: flex-start
      }

      .rc {
        grid-area: meta;
        width: auto;
        margin-left: auto;
        text-align: right
      }

      .discord-btn {
        display: none
      }

      .flag-btn .fl {
        display: none
      }

      .hdr-sep {
        display: none
      }

      .tw {
        overflow-x: clip;
      }

      table {
        min-width: 100%;
        table-layout: auto;
      }

      #tbl colgroup {
        display: none;
      }

      thead {
        display: none;
      }

      #tbl tbody {
        display: block;
        width: 100%;
      }

      #tbl tbody tr {
        display: grid;
        width: 100%;
        grid-template-columns: minmax(0, 1fr) auto;
        grid-template-areas:
          "name mem"
          "cat cat"
          "desc desc"
          "link link";
        column-gap: 10px;
        row-gap: 0;
        padding: 13px 0 12px;
        border-bottom: 1px solid rgba(80, 75, 120, .32);
        background: transparent !important;
      }

      #tbl tbody tr td {
        display: block;
        width: auto !important;
        max-width: none !important;
        padding: 0;
        overflow: visible;
        background: transparent;
        border: none;
      }

      #tbl tbody tr td.td-num {
        display: none;
      }

      #tbl tbody tr[data-accent="pride"],
      #tbl tbody tr[data-accent="trans"],
      #tbl tbody tr[data-accent="femboy"],
      #tbl tbody tr[data-accent="furry"] {
        background-size: 3px calc(100% - 14px) !important;
        background-position: left center !important;
        background-repeat: no-repeat !important;
      }

      #tbl tbody tr[data-accent="pride"] {
        background-image: linear-gradient(180deg, var(--pride-red), var(--pride-orange) 20%, var(--pride-yellow) 38%, var(--pride-green) 56%, var(--pride-blue) 76%, var(--pride-violet)) !important;
      }

      #tbl tbody tr[data-accent="trans"] {
        background-image: linear-gradient(180deg, var(--trans-blue), var(--trans-white) 50%, var(--trans-pink)) !important;
      }

      #tbl tbody tr[data-accent="femboy"] {
        background-image: linear-gradient(180deg, var(--femboy-blue), var(--femboy-pink)) !important;
      }

      #tbl tbody tr[data-accent="furry"] {
        background-image: linear-gradient(180deg, var(--furry-amber), var(--furry-rose)) !important;
      }

      #tbl tbody tr td:nth-child(2) {
        grid-area: name;
        padding-right: 8px;
      }

      #tbl tbody tr td:nth-child(2) .ni {
        align-items: flex-start;
      }

      #tbl tbody tr td:nth-child(2) .ni a {
        display: -webkit-box;
        overflow: hidden;
        -webkit-box-orient: vertical;
        font-size: 15px;
        font-weight: 700;
        line-height: 1.35;
        -webkit-line-clamp: 2;
      }

      #tbl tbody tr td.td-mem {
        grid-area: mem;
        text-align: right;
        font-size: 15px;
        font-weight: 700;
        line-height: 1.25;
      }

      #tbl tbody tr td.td-mem .est {
        text-align: right;
        font-size: 10px;
        margin-top: 2px;
      }

      #tbl tbody tr td.td-cat {
        grid-area: cat;
        text-align: left;
        padding-top: 9px;
        align-self: center;
      }

      .cat-chip {
        max-width: min(100%, 170px);
        font-size: 11px;
        padding: 4px 9px;
      }

      #tbl tbody tr td:nth-child(5) {
        grid-area: desc;
        padding-top: 9px;
      }

      #tbl tbody tr td:nth-child(5) .di {
        -webkit-line-clamp: var(--desc-lines);
        font-size: 13px;
        line-height: 1.45;
        color: var(--text);
      }

      #tbl tbody tr td.td-link {
        grid-area: link;
        text-align: left;
        padding-top: 10px;
        align-self: center;
      }

      .join-btn {
        width: 100%;
        display: inline-flex;
        min-height: 42px;
        padding: 10px 16px;
        font-size: 13px;
        border-radius: 8px;
      }

      .sbtn,
      .discord-btn,
      .flag-btn,
      input[type=search] {
        min-height: 42px;
      }

      .pills-bar {
        overflow-x: auto;
        overflow-y: hidden;
        justify-content: flex-start;
        flex-wrap: nowrap;
        padding-top: 10px;
        padding-bottom: 12px;
      }

      .pills {
        gap: 6px;
        flex-wrap: nowrap;
        justify-content: flex-start;
        width: max-content;
        min-width: 100%;
        padding-right: 8px;
      }

      .sbtn {
        min-width: 72px
      }


      .pill {
        --pill-min-h: 30px;
        --pill-pad-y: 4px;
        --pill-pad-x: 9px;
        --pill-font: 10px;
        --pill-count-font: 9px;
      }
    }

    @media(max-width:420px) {
      .hdr-title {
        font-size: 13px;
      }

      .hdr-sub {
        font-size: 10px;
      }

      #tbl tbody tr td:nth-child(2) .ni a {
        font-size: 14px;
      }

      #tbl tbody tr td.td-mem {
        font-size: 14px;
      }

      .cat-chip {
        max-width: 155px;
        font-size: 10.5px;
      }

      .join-btn {
        min-height: 40px;
        padding: 9px 13px;
        font-size: 12px;
      }

      .hdr-count {
        min-width: 76px;
      }
    }

    @media (prefers-reduced-motion: reduce) {
      html {
        scroll-behavior: auto
      }

      *,
      *::before,
      *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
      }
    }
