/* NordVader Plugin Showcase block */

body:has(.nv-plugin-showcase-hide-footer) footer {
    display: none !important;
}

.nv-plugin-showcase {
    width: 100%;
    min-height: calc(100vh - 82px);
    padding: var(--nv-plugin-showcase-padding-top, 56px) 28px var(--nv-plugin-showcase-padding-bottom, 72px);
    display: flex;
    align-items: center;
    justify-content: center;
    box-sizing: border-box;
}

.nv-plugin-showcase.alignfull {
    width: 100vw;
    max-width: none;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
}

.nv-plugin-showcase-shell {
    width: min(1320px, 100%);
    position: relative;
    padding: 44px;
    background:
        radial-gradient(circle at 14% 18%, rgba(255, 20, 20, 0.15), transparent 32%),
        radial-gradient(circle at 88% 68%, rgba(255, 20, 20, 0.10), transparent 36%),
        linear-gradient(135deg, rgba(8, 8, 10, 0.84), rgba(6, 6, 8, 0.60));
    border: 1px solid rgba(255, 255, 255, 0.10);
    box-shadow:
        0 32px 92px rgba(0, 0, 0, 0.62),
        inset 0 1px 0 rgba(255, 255, 255, 0.04);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    overflow: hidden;
    box-sizing: border-box;
}

.nv-plugin-showcase-shell::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    background:
        linear-gradient(90deg, rgba(255, 26, 26, 0.20), transparent 20%, transparent 80%, rgba(255, 26, 26, 0.12)),
        linear-gradient(rgba(255, 255, 255, 0.03) 1px, transparent 1px);
    background-size: 100% 100%, 100% 42px;
    opacity: 0.34;
}

.nv-plugin-showcase-head,
.nv-plugin-showcase-featured,
.nv-plugin-showcase-grid {
    position: relative;
    z-index: 1;
}

.nv-plugin-showcase-head {
    display: grid;
    grid-template-columns: 0.9fr 1.1fr;
    gap: 42px;
    align-items: end;
    margin-bottom: 28px;
}

.nv-plugin-showcase-kicker {
    margin: 0 0 16px;
    color: #ff1a1a;
    font-family: Arial, Helvetica, sans-serif;
    font-size: 12px;
    font-weight: 900;
    letter-spacing: 0.22em;
    text-transform: uppercase;
}

.nv-plugin-showcase h1 {
    margin: 0;
    color: #ffffff;
    font-family: Arial, Helvetica, sans-serif;
    font-size: clamp(52px, 7vw, 92px);
    font-weight: 950;
    line-height: 0.88;
    letter-spacing: -0.055em;
    text-shadow:
        0 0 18px rgba(0, 0, 0, 0.95),
        0 10px 30px rgba(0, 0, 0, 0.75);
}

.nv-plugin-showcase-lead {
    max-width: 760px;
    margin: 0;
    color: rgba(255, 255, 255, 0.76);
    font-family: "Courier New", monospace;
    font-size: 15px;
    font-weight: 700;
    line-height: 1.72;
    text-shadow: 0 0 12px rgba(0, 0, 0, 0.95);
}

.nv-plugin-showcase-featured {
    display: grid;
    grid-template-columns: 1.12fr 0.88fr;
    gap: 0;
    margin-bottom: 22px;
    background:
        linear-gradient(135deg, rgba(255, 26, 26, 0.12), rgba(9, 9, 12, 0.92)),
        rgba(9, 9, 12, 0.92);
    border: 1px solid rgba(255, 26, 26, 0.24);
    box-shadow: 0 24px 66px rgba(0, 0, 0, 0.42);
    overflow: hidden;
}

.nv-plugin-showcase-featured-media,
.nv-plugin-showcase-card-media {
    position: relative;
    background:
        radial-gradient(circle at 36% 34%, rgba(255, 26, 26, 0.16), transparent 36%),
        linear-gradient(145deg, rgba(18, 18, 24, 0.92), rgba(4, 4, 6, 0.98));
    overflow: hidden;
    isolation: isolate;
}

.nv-plugin-showcase-featured-media {
    min-height: 360px;
}

.nv-plugin-showcase-card-media {
    aspect-ratio: 16 / 9;
    border-bottom: 1px solid rgba(255, 255, 255, 0.07);
}

.nv-plugin-showcase-poster,
.nv-plugin-showcase-preview-video {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
}

.nv-plugin-showcase-poster {
    z-index: 1;
    transform: scale(1.015);
    transition: transform 0.22s ease, opacity 0.22s ease, filter 0.22s ease;
}

.nv-plugin-showcase-preview-video {
    z-index: 2;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.22s ease;
    background: #050507;
}

.nv-plugin-showcase-featured:hover .nv-plugin-showcase-preview-video,
.nv-plugin-showcase-card:hover .nv-plugin-showcase-preview-video,
.nv-plugin-showcase-card.is-previewing .nv-plugin-showcase-preview-video,
.nv-plugin-showcase-featured.is-previewing .nv-plugin-showcase-preview-video {
    opacity: 1;
}

.nv-plugin-showcase-featured:hover .nv-plugin-showcase-poster,
.nv-plugin-showcase-card:hover .nv-plugin-showcase-poster {
    transform: scale(1.06);
    filter: brightness(0.72) contrast(1.08);
}

.nv-plugin-showcase-media-placeholder {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    color: rgba(255, 26, 26, 0.38);
    font-family: Arial, Helvetica, sans-serif;
    font-size: clamp(46px, 7vw, 92px);
    font-weight: 950;
    letter-spacing: -0.06em;
    text-shadow: 0 0 28px rgba(255, 26, 26, 0.14);
}

.nv-plugin-showcase-badge {
    position: absolute;
    left: 16px;
    top: 16px;
    z-index: 4;
    padding: 7px 9px;
    color: #ffffff;
    background: rgba(255, 26, 26, 0.78);
    border: 1px solid rgba(255, 255, 255, 0.10);
    font-family: Arial, Helvetica, sans-serif;
    font-size: 10px;
    font-weight: 900;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    box-shadow: 0 10px 26px rgba(0, 0, 0, 0.50);
}

.nv-plugin-showcase-featured-content {
    min-height: 360px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 34px;
    box-sizing: border-box;
}

.nv-plugin-showcase-featured-top,
.nv-plugin-showcase-card-top {
    display: flex;
    align-items: center;
    gap: 12px;
}

.nv-plugin-showcase-mark {
    width: 42px;
    height: 42px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 42px;
    color: #ff1a1a;
    font-family: Arial, Helvetica, sans-serif;
    font-size: 14px;
    font-weight: 950;
    line-height: 1;
    background: rgba(255, 26, 26, 0.10);
    border: 1px solid rgba(255, 26, 26, 0.26);
    box-shadow: inset 0 0 22px rgba(255, 26, 26, 0.08);
}

.nv-plugin-showcase-category,
.nv-plugin-showcase-card-category {
    color: #ff1a1a;
    font-family: Arial, Helvetica, sans-serif;
    font-size: 11px;
    font-weight: 900;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.nv-plugin-showcase-featured h2 {
    margin: 24px 0 12px;
    color: #ffffff;
    font-family: Arial, Helvetica, sans-serif;
    font-size: clamp(40px, 4.4vw, 68px);
    font-weight: 950;
    line-height: 0.9;
    letter-spacing: -0.055em;
    text-shadow: 0 0 18px rgba(0, 0, 0, 0.95);
}

.nv-plugin-showcase-subtitle {
    margin: 0 0 14px;
    color: rgba(255, 255, 255, 0.78);
    font-family: "Courier New", monospace;
    font-size: 15px;
    font-weight: 700;
    line-height: 1.5;
}

.nv-plugin-showcase-description {
    margin: 0 0 18px;
    color: rgba(255, 255, 255, 0.66);
    font-family: "Courier New", monospace;
    font-size: 14px;
    font-weight: 700;
    line-height: 1.62;
}

.nv-plugin-showcase-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin: 0 0 18px;
}

.nv-plugin-showcase-chips span {
    display: inline-flex;
    align-items: center;
    min-height: 26px;
    padding: 5px 8px;
    color: rgba(255, 255, 255, 0.78);
    background: rgba(255, 255, 255, 0.045);
    border: 1px solid rgba(255, 255, 255, 0.08);
    font-family: Arial, Helvetica, sans-serif;
    font-size: 11px;
    font-weight: 900;
    letter-spacing: 0.02em;
    text-transform: uppercase;
}

.nv-plugin-showcase-actions,
.nv-plugin-showcase-card-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.nv-plugin-showcase-button,
.nv-plugin-showcase-mini-button {
    color: #ffffff !important;
    text-decoration: none !important;
    box-sizing: border-box;
}

.nv-plugin-showcase-button {
    display: inline-flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    min-width: 170px;
    padding: 13px 15px;
    background: rgba(8, 8, 10, 0.74);
    border: 1px solid rgba(255, 255, 255, 0.10);
    font-family: Arial, Helvetica, sans-serif;
    font-size: 13px;
    font-weight: 900;
    transition: transform 0.18s ease, border-color 0.18s ease, background 0.18s ease;
}

.nv-plugin-showcase-button-main {
    border-color: rgba(255, 26, 26, 0.34);
    background: rgba(255, 26, 26, 0.10);
}

.nv-plugin-showcase-button:hover,
.nv-plugin-showcase-mini-button:hover {
    transform: translateY(-2px);
    border-color: rgba(255, 26, 26, 0.56);
    background: rgba(255, 26, 26, 0.16);
}

.nv-plugin-showcase-button em {
    color: #ff1a1a;
    font-style: normal;
}

.nv-plugin-showcase-grid {
    display: grid;
    gap: 12px;
}

.nv-plugin-showcase-columns-1 .nv-plugin-showcase-grid {
    grid-template-columns: 1fr;
}

.nv-plugin-showcase-columns-2 .nv-plugin-showcase-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.nv-plugin-showcase-columns-3 .nv-plugin-showcase-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.nv-plugin-showcase-columns-4 .nv-plugin-showcase-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.nv-plugin-showcase-card {
    position: relative;
    min-width: 0;
    background:
        linear-gradient(145deg, rgba(255, 255, 255, 0.035), rgba(255, 255, 255, 0.01)),
        rgba(10, 10, 13, 0.84);
    border: 1px solid rgba(255, 255, 255, 0.085);
    box-shadow: 0 16px 38px rgba(0, 0, 0, 0.28);
    overflow: hidden;
    transition: transform 0.18s ease, border-color 0.18s ease, background 0.18s ease;
}

.nv-plugin-showcase-card:hover,
.nv-plugin-showcase-card.is-open {
    transform: translateY(-2px);
    border-color: rgba(255, 26, 26, 0.46);
    background:
        linear-gradient(145deg, rgba(255, 26, 26, 0.10), rgba(255, 255, 255, 0.015)),
        rgba(14, 14, 18, 0.94);
}

.nv-plugin-showcase-card-content {
    padding: 18px;
}

.nv-plugin-showcase-card h3 {
    margin: 18px 0 8px;
    color: #ffffff;
    font-family: Arial, Helvetica, sans-serif;
    font-size: 24px;
    font-weight: 950;
    line-height: 1.02;
    letter-spacing: -0.035em;
}

.nv-plugin-showcase-card:hover h3,
.nv-plugin-showcase-card.is-open h3 {
    color: #ff1a1a;
}

.nv-plugin-showcase-card .nv-plugin-showcase-subtitle {
    margin-bottom: 12px;
    font-size: 13px;
    color: rgba(255, 255, 255, 0.62);
}

.nv-plugin-showcase-card .nv-plugin-showcase-chips {
    margin-bottom: 12px;
}

.nv-plugin-showcase-card .nv-plugin-showcase-chips span {
    min-height: 22px;
    padding: 4px 7px;
    font-size: 10px;
}

.nv-plugin-showcase-details-toggle {
    width: 100%;
    min-height: 34px;
    display: inline-flex;
    align-items: center;
    justify-content: space-between;
    padding: 8px 10px;
    color: rgba(255, 255, 255, 0.82);
    background: rgba(255, 255, 255, 0.035);
    border: 1px solid rgba(255, 255, 255, 0.07);
    font-family: Arial, Helvetica, sans-serif;
    font-size: 12px;
    font-weight: 900;
    cursor: pointer;
}

.nv-plugin-showcase-details-toggle:hover {
    color: #ff1a1a;
    border-color: rgba(255, 26, 26, 0.32);
}

.nv-plugin-showcase-card.is-open .nv-plugin-showcase-details-toggle span {
    transform: rotate(180deg);
}

.nv-plugin-showcase-card-details {
    max-height: 0;
    opacity: 0;
    overflow: hidden;
    transition: max-height 0.22s ease, opacity 0.18s ease, margin-top 0.18s ease;
}

.nv-plugin-showcase-card.is-open .nv-plugin-showcase-card-details {
    max-height: 420px;
    opacity: 1;
    margin-top: 14px;
}

.nv-plugin-showcase-card-details p {
    margin: 0 0 14px;
    color: rgba(255, 255, 255, 0.66);
    font-family: "Courier New", monospace;
    font-size: 13px;
    font-weight: 700;
    line-height: 1.55;
}

.nv-plugin-showcase-mini-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 32px;
    padding: 8px 10px;
    background: rgba(8, 8, 10, 0.74);
    border: 1px solid rgba(255, 255, 255, 0.10);
    font-family: Arial, Helvetica, sans-serif;
    font-size: 12px;
    font-weight: 900;
}

.nv-plugin-showcase-mini-button-main {
    border-color: rgba(255, 26, 26, 0.34);
    background: rgba(255, 26, 26, 0.10);
}

@media (max-width: 1120px) {
    .nv-plugin-showcase-columns-4 .nv-plugin-showcase-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (max-width: 980px) {
    .nv-plugin-showcase-head,
    .nv-plugin-showcase-featured {
        grid-template-columns: 1fr;
    }

    .nv-plugin-showcase-featured-content,
    .nv-plugin-showcase-featured-media {
        min-height: 0;
    }

    .nv-plugin-showcase-featured-media {
        aspect-ratio: 16 / 9;
    }

    .nv-plugin-showcase-columns-3 .nv-plugin-showcase-grid,
    .nv-plugin-showcase-columns-4 .nv-plugin-showcase-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 700px) {
    .nv-plugin-showcase {
        padding: var(--nv-plugin-showcase-padding-top, 56px) 16px var(--nv-plugin-showcase-padding-bottom, 64px);
        align-items: flex-start;
    }

    .nv-plugin-showcase-shell {
        padding: 26px;
    }

    .nv-plugin-showcase-grid,
    .nv-plugin-showcase-columns-2 .nv-plugin-showcase-grid,
    .nv-plugin-showcase-columns-3 .nv-plugin-showcase-grid,
    .nv-plugin-showcase-columns-4 .nv-plugin-showcase-grid {
        grid-template-columns: 1fr;
    }

    .nv-plugin-showcase-featured-content {
        padding: 24px;
    }

    .nv-plugin-showcase-button {
        width: 100%;
    }
}

/* v0.6.0 - filters, details panel, gallery, meta */
.nv-plugin-showcase-filters {
    position: relative;
    z-index: 1;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin: 0 0 18px;
}

.nv-plugin-showcase-filters button {
    min-height: 32px;
    padding: 7px 11px;
    color: rgba(255, 255, 255, 0.72);
    background: rgba(255, 255, 255, 0.035);
    border: 1px solid rgba(255, 255, 255, 0.08);
    font-family: Arial, Helvetica, sans-serif;
    font-size: 11px;
    font-weight: 900;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    cursor: pointer;
}

.nv-plugin-showcase-filters button:hover,
.nv-plugin-showcase-filters button.is-active {
    color: #ff1a1a;
    background: rgba(255, 26, 26, 0.10);
    border-color: rgba(255, 26, 26, 0.34);
}

.nv-plugin-showcase-preview-label {
    position: absolute;
    right: 14px;
    top: 14px;
    z-index: 4;
    padding: 7px 9px;
    color: rgba(255, 255, 255, 0.86);
    background: rgba(0, 0, 0, 0.62);
    border: 1px solid rgba(255, 255, 255, 0.10);
    font-family: Arial, Helvetica, sans-serif;
    font-size: 10px;
    font-weight: 900;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    opacity: 0.78;
}

.nv-plugin-showcase-meta {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px;
    margin: 0 0 18px;
}

.nv-plugin-showcase-meta div {
    min-width: 0;
    padding: 10px;
    background: rgba(255, 255, 255, 0.035);
    border: 1px solid rgba(255, 255, 255, 0.07);
}

.nv-plugin-showcase-meta small {
    display: block;
    margin-bottom: 5px;
    color: rgba(255, 26, 26, 0.92);
    font-family: Arial, Helvetica, sans-serif;
    font-size: 9px;
    font-weight: 900;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.nv-plugin-showcase-meta strong {
    display: block;
    color: rgba(255, 255, 255, 0.80);
    font-family: "Courier New", monospace;
    font-size: 12px;
    font-weight: 700;
    line-height: 1.35;
}

.nv-plugin-showcase-card .nv-plugin-showcase-meta {
    grid-template-columns: 1fr;
    margin-bottom: 12px;
}

.nv-plugin-showcase-card .nv-plugin-showcase-meta div {
    padding: 8px;
}

.nv-plugin-showcase-card .nv-plugin-showcase-meta strong {
    font-size: 11px;
}

.nv-plugin-showcase-panel-stage {
    position: relative;
    z-index: 1;
    margin-top: 18px;
}

.nv-plugin-showcase-panel {
    display: none;
    grid-template-columns: minmax(0, 1.04fr) minmax(0, 0.96fr);
    gap: 0;
    background:
        linear-gradient(135deg, rgba(255, 26, 26, 0.12), rgba(9, 9, 12, 0.94)),
        rgba(9, 9, 12, 0.94);
    border: 1px solid rgba(255, 26, 26, 0.24);
    box-shadow: 0 24px 66px rgba(0, 0, 0, 0.44);
    overflow: hidden;
}

.nv-plugin-showcase-panel.is-active {
    display: grid;
}

.nv-plugin-showcase-panel-media {
    position: relative;
    min-width: 0;
    min-height: 380px;
    background: rgba(0, 0, 0, 0.36);
}

.nv-plugin-showcase-panel-media > .nv-plugin-showcase-card-media {
    height: 100%;
    min-height: 380px;
    aspect-ratio: auto;
    border-bottom: 0;
}

.nv-plugin-showcase-panel-content {
    min-width: 0;
    padding: 32px;
    box-sizing: border-box;
}

.nv-plugin-showcase-panel-top {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 18px;
}

.nv-plugin-showcase-badge-inline {
    padding: 7px 9px;
    color: #ffffff;
    background: rgba(255, 26, 26, 0.22);
    border: 1px solid rgba(255, 26, 26, 0.36);
    font-family: Arial, Helvetica, sans-serif;
    font-size: 10px;
    font-weight: 900;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.nv-plugin-showcase-panel-close {
    margin-left: auto;
    width: 36px;
    height: 36px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: rgba(255, 255, 255, 0.74);
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.08);
    font-size: 22px;
    font-weight: 700;
    line-height: 1;
    cursor: pointer;
}

.nv-plugin-showcase-panel-close:hover {
    color: #ff1a1a;
    border-color: rgba(255, 26, 26, 0.34);
}

.nv-plugin-showcase-panel h3 {
    margin: 0 0 10px;
    color: #ffffff;
    font-family: Arial, Helvetica, sans-serif;
    font-size: clamp(34px, 4vw, 58px);
    font-weight: 950;
    line-height: 0.92;
    letter-spacing: -0.05em;
    text-shadow: 0 0 18px rgba(0, 0, 0, 0.95);
}

.nv-plugin-showcase-details-description {
    margin: 0 0 18px;
    color: rgba(255, 255, 255, 0.68);
    font-family: "Courier New", monospace;
    font-size: 14px;
    font-weight: 700;
    line-height: 1.64;
}

.nv-plugin-showcase-gallery {
    margin: 18px 0;
}

.nv-plugin-showcase-gallery-main {
    position: relative;
    overflow: hidden;
    aspect-ratio: 16 / 9;
    background: rgba(0, 0, 0, 0.42);
    border: 1px solid rgba(255, 255, 255, 0.08);
}

.nv-plugin-showcase-gallery-main img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
}

.nv-plugin-showcase-gallery-thumbs {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 7px;
    margin-top: 8px;
}

.nv-plugin-showcase-gallery-thumbs button {
    position: relative;
    aspect-ratio: 16 / 9;
    padding: 0;
    overflow: hidden;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.08);
    cursor: pointer;
}

.nv-plugin-showcase-gallery-thumbs button.is-active,
.nv-plugin-showcase-gallery-thumbs button:hover {
    border-color: rgba(255, 26, 26, 0.56);
}

.nv-plugin-showcase-gallery-thumbs img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
    opacity: 0.78;
}

.nv-plugin-showcase-gallery-thumbs button.is-active img,
.nv-plugin-showcase-gallery-thumbs button:hover img {
    opacity: 1;
}

.nv-plugin-showcase-detail-panel .nv-plugin-showcase-card.is-open {
    border-color: rgba(255, 26, 26, 0.64);
}

.nv-plugin-showcase-detail-panel .nv-plugin-showcase-card.is-open .nv-plugin-showcase-details-toggle {
    color: #ff1a1a;
    border-color: rgba(255, 26, 26, 0.40);
    background: rgba(255, 26, 26, 0.10);
}

.nv-plugin-showcase-detail-panel .nv-plugin-showcase-card.is-open .nv-plugin-showcase-details-toggle span {
    transform: none;
}

.nv-plugin-showcase-card[hidden] {
    display: none !important;
}

@media (max-width: 980px) {
    .nv-plugin-showcase-panel {
        grid-template-columns: 1fr;
    }

    .nv-plugin-showcase-panel-media,
    .nv-plugin-showcase-panel-media > .nv-plugin-showcase-card-media {
        min-height: 0;
    }

    .nv-plugin-showcase-panel-media > .nv-plugin-showcase-card-media {
        aspect-ratio: 16 / 9;
    }
}

@media (max-width: 700px) {
    .nv-plugin-showcase-meta {
        grid-template-columns: 1fr;
    }

    .nv-plugin-showcase-panel-content {
        padding: 24px;
    }

    .nv-plugin-showcase-gallery-thumbs {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

/* v0.7.0 quick view trailer and card-click refinements */
.nv-plugin-showcase-card-clickable .nv-plugin-showcase-card {
    cursor: pointer;
}

.nv-plugin-showcase-card-clickable .nv-plugin-showcase-card a,
.nv-plugin-showcase-card-clickable .nv-plugin-showcase-card button,
.nv-plugin-showcase-card-clickable .nv-plugin-showcase-card video {
    cursor: auto;
}

.nv-plugin-showcase-trailer {
    position: relative;
    margin: 18px 0;
    aspect-ratio: 16 / 9;
    overflow: hidden;
    background: rgba(0, 0, 0, 0.45);
    border: 1px solid rgba(255, 255, 255, 0.09);
    box-shadow: 0 16px 38px rgba(0, 0, 0, 0.32);
}

.nv-plugin-showcase-trailer iframe {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    display: block;
    border: 0;
}

.nv-plugin-showcase-trailer + .nv-plugin-showcase-meta,
.nv-plugin-showcase-trailer + .nv-plugin-showcase-gallery {
    margin-top: 18px;
}

/* =========================================================
   NordVader Asset detail pages
   ========================================================= */

.nv-asset-page {
    width: 100%;
    padding: var(--nv-plugin-showcase-padding-top, 48px) 28px var(--nv-plugin-showcase-padding-bottom, 72px);
    box-sizing: border-box;
}

.nv-asset-page-shell {
    width: min(1240px, 100%);
    margin: 0 auto;
}

.nv-asset-page-panel {
    display: grid;
    grid-template-columns: minmax(0, 1.1fr) minmax(320px, 0.9fr);
    gap: 0;
    opacity: 1 !important;
    visibility: visible !important;
    pointer-events: auto !important;
}

.nv-asset-page-content {
    margin: 22px 0;
    color: rgba(255, 255, 255, 0.78);
    font-family: "Courier New", monospace;
    font-size: 15px;
    font-weight: 700;
    line-height: 1.7;
}

.nv-asset-page-content p,
.nv-asset-page-content ul,
.nv-asset-page-content ol {
    margin-top: 0;
    margin-bottom: 16px;
}

.nv-asset-page-content h2,
.nv-asset-page-content h3,
.nv-asset-page-content h4 {
    color: #fff;
    font-family: Arial, Helvetica, sans-serif;
    font-weight: 950;
    letter-spacing: -0.03em;
}

.nv-asset-page-nav {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    margin-top: 18px;
}

.nv-asset-page-nav a {
    display: inline-flex;
    align-items: center;
    min-height: 42px;
    padding: 10px 14px;
    color: rgba(255, 255, 255, 0.86) !important;
    text-decoration: none !important;
    background: rgba(10, 10, 13, 0.78);
    border: 1px solid rgba(255, 255, 255, 0.09);
    font-family: Arial, Helvetica, sans-serif;
    font-size: 13px;
    font-weight: 900;
    box-sizing: border-box;
}

.nv-asset-page-nav a:hover {
    color: #ff1a1a !important;
    border-color: rgba(255, 26, 26, 0.46);
    background: rgba(18, 18, 22, 0.94);
}

@media (max-width: 900px) {
    .nv-asset-page {
        padding-left: 16px;
        padding-right: 16px;
    }

    .nv-asset-page-panel {
        grid-template-columns: 1fr;
    }

    .nv-asset-page-nav {
        flex-direction: column;
        align-items: stretch;
    }
}

/* =========================================================
   NordVader Asset Detail Page v1.0
   ========================================================= */

.nv-asset-detail {
    width: 100%;
    min-height: 100vh;
    padding: 42px 24px 84px;
    box-sizing: border-box;
}

.nv-asset-detail-shell {
    width: min(1320px, 100%);
    margin: 0 auto;
    padding: 42px;
    position: relative;
    background:
        radial-gradient(circle at 15% 18%, rgba(255, 20, 20, 0.14), transparent 34%),
        linear-gradient(135deg, rgba(8, 8, 10, 0.82), rgba(6, 6, 8, 0.58));
    border: 1px solid rgba(255, 255, 255, 0.10);
    box-shadow: 0 30px 90px rgba(0, 0, 0, 0.62), inset 0 1px 0 rgba(255, 255, 255, 0.04);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    overflow: hidden;
}

.nv-asset-detail-shell::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    background:
        linear-gradient(90deg, rgba(255, 26, 26, 0.20), transparent 20%, transparent 80%, rgba(255, 26, 26, 0.12)),
        linear-gradient(rgba(255, 255, 255, 0.035) 1px, transparent 1px);
    background-size: 100% 100%, 100% 42px;
    opacity: 0.34;
}

.nv-asset-detail-head,
.nv-asset-detail-hero,
.nv-asset-detail-body,
.nv-asset-detail-nav {
    position: relative;
    z-index: 1;
}

.nv-asset-detail-head {
    display: grid;
    grid-template-columns: minmax(0, 0.92fr) minmax(0, 1.08fr);
    gap: 42px;
    align-items: end;
    margin-bottom: 30px;
}

.nv-asset-detail-head h1 {
    margin: 0;
    color: #fff;
    font-family: Arial, Helvetica, sans-serif;
    font-size: clamp(44px, 5.6vw, 84px);
    font-weight: 950;
    line-height: 0.9;
    letter-spacing: -0.055em;
    text-shadow: 0 0 18px rgba(0,0,0,0.95), 0 10px 30px rgba(0,0,0,0.75);
}

.nv-asset-detail-hero {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 360px;
    gap: 22px;
    align-items: start;
    margin-bottom: 24px;
}

.nv-asset-detail-media {
    min-width: 0;
}

.nv-asset-detail-media-stage {
    position: relative;
    aspect-ratio: 16 / 9;
    background: rgba(5, 5, 8, 0.86);
    border: 1px solid rgba(255, 255, 255, 0.09);
    box-shadow: 0 18px 54px rgba(0,0,0,0.44);
    overflow: hidden;
}

.nv-asset-detail-slide {
    position: absolute;
    inset: 0;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.18s ease;
}

.nv-asset-detail-slide.is-active {
    opacity: 1;
    pointer-events: auto;
}

.nv-asset-detail-slide img,
.nv-asset-detail-slide video,
.nv-asset-detail-slide iframe {
    display: block;
    width: 100%;
    height: 100%;
    border: 0;
    object-fit: cover;
    background: #050506;
}

.nv-asset-detail-slide iframe {
    object-fit: initial;
}

.nv-asset-detail-media-empty {
    aspect-ratio: 16 / 9;
    display: grid;
    place-items: center;
    color: rgba(255, 26, 26, 0.55);
    font-family: Arial, Helvetica, sans-serif;
    font-size: clamp(68px, 12vw, 160px);
    font-weight: 950;
    letter-spacing: -0.08em;
    background: rgba(8, 8, 12, 0.88);
    border: 1px solid rgba(255, 26, 26, 0.22);
}

.nv-asset-detail-media-arrow {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 42px;
    height: 58px;
    border: 1px solid rgba(255,255,255,0.12);
    background: rgba(5,5,7,0.62);
    color: #fff;
    font-size: 40px;
    line-height: 1;
    cursor: pointer;
    z-index: 3;
}

.nv-asset-detail-media-prev { left: 12px; }
.nv-asset-detail-media-next { right: 12px; }

.nv-asset-detail-media-arrow:hover {
    color: #ff1a1a;
    background: rgba(12,12,16,0.86);
    border-color: rgba(255,26,26,0.42);
}

.nv-asset-detail-media-thumbs {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(110px, 1fr));
    gap: 10px;
    margin-top: 12px;
}

.nv-asset-detail-media-thumbs button {
    min-height: 62px;
    padding: 0;
    cursor: pointer;
    background: rgba(12,12,16,0.86);
    border: 1px solid rgba(255,255,255,0.10);
    overflow: hidden;
}

.nv-asset-detail-media-thumbs button.is-active,
.nv-asset-detail-media-thumbs button:hover {
    border-color: rgba(255,26,26,0.72);
}

.nv-asset-detail-media-thumbs img {
    display: block;
    width: 100%;
    height: 62px;
    object-fit: cover;
}

.nv-asset-detail-media-thumbs span {
    display: grid;
    place-items: center;
    min-height: 62px;
    color: #ff1a1a;
    font-family: Arial, Helvetica, sans-serif;
    font-weight: 950;
    background: rgba(255,26,26,0.08);
}

.nv-asset-detail-sidebar {
    position: sticky;
    top: 24px;
}

.nv-asset-detail-sidebar-card {
    padding: 26px;
    background: rgba(12, 12, 16, 0.88);
    border: 1px solid rgba(255, 255, 255, 0.10);
    box-shadow: 0 18px 54px rgba(0,0,0,0.36);
}

.nv-asset-detail-sidebar-card h3 {
    margin: 18px 0 8px;
    color: #fff;
    font-family: Arial, Helvetica, sans-serif;
    font-size: 28px;
    font-weight: 950;
    line-height: 0.98;
    letter-spacing: -0.04em;
}

.nv-asset-detail-breadcrumb {
    margin: 0 0 14px;
    color: rgba(255,255,255,0.58);
    font-family: "Courier New", monospace;
    font-size: 12px;
    font-weight: 700;
}

.nv-asset-detail-rating {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 18px;
    color: #fff;
    font-family: Arial, Helvetica, sans-serif;
}

.nv-asset-detail-rating span {
    color: #ffcc28;
    letter-spacing: 0.02em;
}

.nv-asset-detail-rating small {
    color: rgba(255,255,255,0.6);
}

.nv-asset-detail-values {
    display: grid;
    gap: 10px;
    margin: 20px 0;
}

.nv-asset-detail-values div {
    padding: 12px;
    background: rgba(255,255,255,0.035);
    border: 1px solid rgba(255,255,255,0.08);
}

.nv-asset-detail-values small {
    display: block;
    margin-bottom: 5px;
    color: #ff1a1a;
    font-family: Arial, Helvetica, sans-serif;
    font-size: 10px;
    font-weight: 900;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.nv-asset-detail-values strong {
    display: block;
    color: rgba(255,255,255,0.86);
    font-family: "Courier New", monospace;
    font-size: 13px;
    line-height: 1.35;
}

.nv-asset-detail-sidebar-actions {
    display: grid;
    gap: 10px;
}

.nv-asset-detail-button {
    display: flex;
    align-items: center;
    justify-content: space-between;
    min-height: 42px;
    padding: 0 14px;
    color: #fff !important;
    text-decoration: none !important;
    font-family: Arial, Helvetica, sans-serif;
    font-size: 12px;
    font-weight: 900;
    background: rgba(255,255,255,0.045);
    border: 1px solid rgba(255,255,255,0.10);
}

.nv-asset-detail-button::after { content: "→"; color: #ff1a1a; }
.nv-asset-detail-button-main { border-color: rgba(255,26,26,0.42); background: rgba(255,26,26,0.12); }
.nv-asset-detail-button:hover { color: #ff1a1a !important; border-color: rgba(255,26,26,0.55); }

.nv-asset-detail-body {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
}

.nv-asset-detail-main {
    display: grid;
    gap: 18px;
}

.nv-asset-detail-section,
.nv-asset-detail-related {
    padding: 28px;
    background: rgba(12, 12, 16, 0.72);
    border: 1px solid rgba(255, 255, 255, 0.08);
    box-shadow: 0 14px 42px rgba(0,0,0,0.24);
}

.nv-asset-detail-section h2,
.nv-asset-detail-related h2 {
    margin: 0 0 18px;
    color: #fff;
    font-family: Arial, Helvetica, sans-serif;
    font-size: clamp(24px, 2.4vw, 34px);
    font-weight: 950;
    line-height: 1;
    letter-spacing: -0.04em;
}

.nv-asset-detail-section p,
.nv-asset-detail-section li,
.nv-asset-page-content {
    color: rgba(255,255,255,0.78);
    font-family: "Courier New", monospace;
    font-size: 15px;
    font-weight: 700;
    line-height: 1.68;
}

.nv-asset-detail-section ul {
    margin: 0;
    padding-left: 22px;
}

.nv-asset-page-content > *:first-child { margin-top: 0; }
.nv-asset-page-content > *:last-child { margin-bottom: 0; }

.nv-asset-detail-related-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 14px;
}

.nv-asset-detail-related-card {
    display: block;
    min-width: 0;
    color: #fff !important;
    text-decoration: none !important;
    background: rgba(8,8,12,0.8);
    border: 1px solid rgba(255,255,255,0.08);
    overflow: hidden;
}

.nv-asset-detail-related-card img {
    display: block;
    width: 100%;
    aspect-ratio: 16 / 9;
    object-fit: cover;
}

.nv-asset-detail-related-card > span {
    display: grid;
    place-items: center;
    aspect-ratio: 16 / 9;
    color: rgba(255,26,26,0.6);
    font-family: Arial, Helvetica, sans-serif;
    font-size: 46px;
    font-weight: 950;
    background: rgba(255,26,26,0.08);
}

.nv-asset-detail-related-card strong {
    display: block;
    padding: 12px 12px 4px;
    font-family: Arial, Helvetica, sans-serif;
    font-size: 15px;
    font-weight: 900;
    line-height: 1.1;
}

.nv-asset-detail-related-card small {
    display: block;
    padding: 0 12px 12px;
    color: rgba(255,255,255,0.58);
    font-family: "Courier New", monospace;
    font-size: 12px;
    font-weight: 700;
}

.nv-asset-detail-related-card:hover {
    border-color: rgba(255,26,26,0.50);
}

.nv-asset-detail-nav {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    gap: 14px;
    margin-top: 22px;
}

.nv-asset-detail-nav a {
    min-height: 54px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 12px 16px;
    color: #fff !important;
    text-decoration: none !important;
    font-family: Arial, Helvetica, sans-serif;
    font-size: 12px;
    font-weight: 900;
    line-height: 1.3;
    background: rgba(12,12,16,0.82);
    border: 1px solid rgba(255,255,255,0.09);
}

.nv-asset-detail-nav a:first-child { justify-content: flex-start; }
.nv-asset-detail-nav a:last-child { justify-content: flex-end; text-align: right; }
.nv-asset-detail-nav a:hover { color: #ff1a1a !important; border-color: rgba(255,26,26,0.45); }

@media (max-width: 1100px) {
    .nv-asset-detail-head,
    .nv-asset-detail-hero {
        grid-template-columns: 1fr;
    }

    .nv-asset-detail-sidebar {
        position: static;
    }

    .nv-asset-detail-related-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 700px) {
    .nv-asset-detail {
        padding: 24px 14px 60px;
    }

    .nv-asset-detail-shell {
        padding: 22px;
    }

    .nv-asset-detail-media-thumbs,
    .nv-asset-detail-related-grid {
        grid-template-columns: 1fr;
    }

    .nv-asset-detail-nav {
        grid-template-columns: 1fr;
    }

    .nv-asset-detail-section,
    .nv-asset-detail-related {
        padding: 20px;
    }
}

/* =========================================================
   NordVader Asset Detail Page v1.0.2 - smart content layout
   ========================================================= */

.nv-asset-detail-head,
.nv-asset-detail-hero,
.nv-asset-detail-layout,
.nv-asset-detail-nav {
    position: relative;
    z-index: 1;
}

.nv-asset-detail-layout {
    display: grid;
    grid-template-columns: 190px minmax(0, 1fr);
    gap: 22px;
    align-items: start;
    margin-top: 24px;
}

.nv-asset-detail-page-nav {
    position: sticky;
    top: 92px;
    display: grid;
    gap: 8px;
    padding: 16px;
    background: rgba(8, 8, 11, 0.74);
    border: 1px solid rgba(255, 255, 255, 0.08);
    box-shadow: 0 14px 38px rgba(0,0,0,0.26);
}

.nv-asset-detail-page-nav strong {
    color: rgba(255, 255, 255, 0.92);
    font-family: Arial, Helvetica, sans-serif;
    font-size: 12px;
    font-weight: 950;
    text-transform: uppercase;
    letter-spacing: 0.12em;
}

.nv-asset-detail-page-nav a {
    display: flex;
    align-items: center;
    min-height: 34px;
    padding: 0 10px;
    color: rgba(255, 255, 255, 0.62) !important;
    font-family: "Courier New", monospace;
    font-size: 12px;
    font-weight: 800;
    text-decoration: none !important;
    border: 1px solid transparent;
    background: rgba(255, 255, 255, 0.025);
}

.nv-asset-detail-page-nav a:hover {
    color: #ff1a1a !important;
    border-color: rgba(255, 26, 26, 0.30);
    background: rgba(255, 26, 26, 0.06);
}

.nv-asset-detail-main {
    gap: 22px;
}

.nv-asset-detail-section-head {
    display: grid;
    gap: 8px;
    margin-bottom: 18px;
}

.nv-asset-detail-section-head span {
    color: #ff1a1a;
    font-family: Arial, Helvetica, sans-serif;
    font-size: 10px;
    font-weight: 950;
    letter-spacing: 0.18em;
    text-transform: uppercase;
}

.nv-asset-detail-section-head h2 {
    margin: 0 !important;
}

.nv-asset-detail-feature-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
}

.nv-asset-detail-feature-card {
    min-height: 132px;
    padding: 18px;
    background: linear-gradient(135deg, rgba(255,255,255,0.045), rgba(255,26,26,0.025));
    border: 1px solid rgba(255, 255, 255, 0.08);
}

.nv-asset-detail-feature-card small {
    display: inline-grid;
    place-items: center;
    width: 36px;
    height: 28px;
    margin-bottom: 24px;
    color: #ff1a1a;
    font-family: Arial, Helvetica, sans-serif;
    font-size: 11px;
    font-weight: 950;
    background: rgba(255, 26, 26, 0.10);
    border: 1px solid rgba(255, 26, 26, 0.28);
}

.nv-asset-detail-feature-card h3 {
    margin: 0 0 8px;
    color: #fff;
    font-family: Arial, Helvetica, sans-serif;
    font-size: 20px;
    font-weight: 950;
    line-height: 1.05;
    letter-spacing: -0.035em;
}

.nv-asset-detail-feature-card p {
    margin: 0;
    color: rgba(255, 255, 255, 0.68);
    font-family: "Courier New", monospace;
    font-size: 13px;
    font-weight: 700;
    line-height: 1.55;
}

.nv-asset-detail-smart-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.2fr) minmax(260px, 0.8fr);
    gap: 18px;
}

.nv-asset-detail-compact-section {
    min-height: 100%;
}

.nv-asset-detail-lines {
    display: grid;
    gap: 10px;
}

.nv-asset-detail-line {
    display: grid;
    gap: 4px;
    padding: 13px 14px;
    background: rgba(255, 255, 255, 0.035);
    border: 1px solid rgba(255, 255, 255, 0.07);
}

.nv-asset-detail-line strong {
    color: rgba(255, 255, 255, 0.92);
    font-family: Arial, Helvetica, sans-serif;
    font-size: 13px;
    font-weight: 950;
    line-height: 1.25;
}

.nv-asset-detail-line span {
    color: rgba(255, 255, 255, 0.64);
    font-family: "Courier New", monospace;
    font-size: 12px;
    font-weight: 700;
    line-height: 1.55;
}

.nv-asset-detail-deep-dive {
    padding: 0;
}

.nv-asset-detail-accordion-stack {
    display: grid;
    gap: 12px;
}

.nv-asset-detail-accordion {
    background: rgba(12, 12, 16, 0.72);
    border: 1px solid rgba(255, 255, 255, 0.08);
    box-shadow: 0 14px 42px rgba(0,0,0,0.20);
}

.nv-asset-detail-accordion summary {
    min-height: 64px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 0 22px;
    cursor: pointer;
    color: #fff;
    font-family: Arial, Helvetica, sans-serif;
    font-size: 22px;
    font-weight: 950;
    line-height: 1;
    letter-spacing: -0.03em;
    list-style: none;
}

.nv-asset-detail-accordion summary::-webkit-details-marker {
    display: none;
}

.nv-asset-detail-accordion summary em {
    color: #ff1a1a;
    font-family: "Courier New", monospace;
    font-size: 12px;
    font-style: normal;
    font-weight: 900;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.nv-asset-detail-accordion[open] summary em {
    color: rgba(255,255,255,0.58);
}

.nv-asset-detail-accordion[open] summary em::before {
    content: "Close";
}

.nv-asset-detail-accordion[open] summary em {
    font-size: 0;
}

.nv-asset-detail-accordion[open] summary em::before {
    font-size: 12px;
}

.nv-asset-detail-accordion-body {
    padding: 0 22px 22px;
}

.nv-asset-detail-tags .nv-plugin-showcase-chips {
    margin-top: 0;
}

.nv-asset-detail-related {
    scroll-margin-top: 90px;
}

.nv-asset-detail-overview,
.nv-asset-detail-feature-section,
.nv-asset-detail-compact-section,
.nv-asset-detail-deep-dive,
.nv-asset-detail-related {
    scroll-margin-top: 90px;
}

.nv-asset-detail-section.nv-asset-detail-tags {
    padding-bottom: 24px;
}

@media (max-width: 1180px) {
    .nv-asset-detail-layout {
        grid-template-columns: 1fr;
    }

    .nv-asset-detail-page-nav {
        position: static;
        display: flex;
        flex-wrap: wrap;
    }
}

@media (max-width: 900px) {
    .nv-asset-detail-feature-grid,
    .nv-asset-detail-smart-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 700px) {
    .nv-asset-detail-page-nav {
        padding: 12px;
    }

    .nv-asset-detail-page-nav a {
        min-height: 32px;
    }

    .nv-asset-detail-feature-card {
        min-height: 0;
    }
}

/* =========================================================
   NordVader Plugin Showcase v1.0.3 - local page CTA, modal quick view, media safety
   ========================================================= */

.nv-plugin-showcase-featured {
    grid-template-columns: minmax(420px, 1.05fr) minmax(0, 0.95fr);
}

.nv-plugin-showcase-featured-media,
.nv-plugin-showcase-featured-content,
.nv-plugin-showcase-card,
.nv-plugin-showcase-panel,
.nv-plugin-showcase-panel-media,
.nv-plugin-showcase-panel-content {
    min-width: 0;
}

.nv-plugin-showcase-featured h2,
.nv-plugin-showcase-panel h3,
.nv-plugin-showcase-card h3 {
    overflow-wrap: anywhere;
    word-break: normal;
}

.nv-plugin-showcase-featured-media {
    aspect-ratio: 16 / 9;
    min-height: 0;
}

.nv-plugin-showcase-featured-media .nv-plugin-showcase-poster,
.nv-plugin-showcase-featured-media .nv-plugin-showcase-preview-video,
.nv-plugin-showcase-card-media .nv-plugin-showcase-poster,
.nv-plugin-showcase-card-media .nv-plugin-showcase-preview-video,
.nv-plugin-showcase-gallery-main img {
    object-fit: cover;
}

.nv-plugin-showcase-card-controls {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(112px, auto);
    gap: 8px;
    align-items: stretch;
}

.nv-plugin-showcase-card-page-link,
.nv-plugin-showcase-details-toggle {
    min-height: 36px;
}

.nv-plugin-showcase-card-page-link {
    display: inline-flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    padding: 8px 10px;
    color: #ffffff !important;
    background: rgba(255, 26, 26, 0.09);
    border: 1px solid rgba(255, 26, 26, 0.32);
    font-family: Arial, Helvetica, sans-serif;
    font-size: 12px;
    font-weight: 950;
    text-decoration: none !important;
    box-sizing: border-box;
}

.nv-plugin-showcase-card-page-link em {
    color: #ff1a1a;
    font-style: normal;
}

.nv-plugin-showcase-card-page-link:hover {
    color: #ffffff !important;
    background: rgba(255, 26, 26, 0.18);
    border-color: rgba(255, 26, 26, 0.58);
}

.nv-plugin-showcase-card-controls .nv-plugin-showcase-details-toggle {
    width: auto;
}

html.nv-plugin-showcase-modal-open {
    overflow: hidden;
}

.nv-plugin-showcase-panel-stage {
    position: fixed;
    z-index: 99999;
    inset: 0;
    display: none;
    align-items: center;
    justify-content: center;
    margin: 0;
    padding: 32px;
    box-sizing: border-box;
}

.nv-plugin-showcase-panel-stage.is-active {
    display: flex;
}

.nv-plugin-showcase-panel-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.78);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
}

.nv-plugin-showcase-panel {
    position: relative;
    width: min(1180px, calc(100vw - 64px));
    max-height: min(820px, calc(100vh - 64px));
    display: none;
    grid-template-columns: minmax(0, 1.1fr) minmax(360px, 0.9fr);
    overflow: auto;
    transform: scale(0.965) translateY(12px);
    opacity: 0;
    transition: transform 0.18s ease, opacity 0.18s ease;
}

.nv-plugin-showcase-panel.is-active {
    display: grid;
    transform: scale(1) translateY(0);
    opacity: 1;
}

.nv-plugin-showcase-panel-media {
    display: grid;
    align-content: start;
    gap: 14px;
    min-height: 0;
    padding: 24px;
    box-sizing: border-box;
}

.nv-plugin-showcase-panel-media > .nv-plugin-showcase-card-media {
    width: 100%;
    height: auto;
    min-height: 0;
    aspect-ratio: 16 / 9;
    border: 1px solid rgba(255, 255, 255, 0.08);
}

.nv-plugin-showcase-panel-media > .nv-plugin-showcase-card-media .nv-plugin-showcase-poster,
.nv-plugin-showcase-panel-media > .nv-plugin-showcase-card-media .nv-plugin-showcase-preview-video {
    object-fit: cover;
}

.nv-plugin-showcase-panel .nv-plugin-showcase-gallery-main {
    aspect-ratio: 16 / 9;
}

.nv-plugin-showcase-panel .nv-plugin-showcase-gallery-main img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    background: rgba(0,0,0,0.40);
}

.nv-plugin-showcase-panel-content {
    max-height: none;
    overflow: visible;
}

.nv-plugin-showcase-panel-close {
    position: sticky;
    top: 0;
    z-index: 2;
}

@media (max-width: 980px) {
    .nv-plugin-showcase-featured {
        grid-template-columns: 1fr;
    }

    .nv-plugin-showcase-panel {
        grid-template-columns: 1fr;
        width: min(720px, calc(100vw - 28px));
        max-height: calc(100vh - 28px);
    }

    .nv-plugin-showcase-panel-stage {
        padding: 14px;
    }
}

@media (max-width: 700px) {
    .nv-plugin-showcase-card-controls {
        grid-template-columns: 1fr;
    }
}

/* Let the selected theme/template control the outer post layout. */
.single-nv_plugin_asset .nv-asset-template-main,
.post-type-nv_plugin_asset .nv-asset-template-main,
.single-nv_plugin_asset .nv-asset-detail,
.single-nv_plugin_asset .nv-asset-detail-shell {
    max-width: none;
}

/* =========================================================
   v1.0.4 - Showcase layout and fullscreen Quick View polish
   ========================================================= */
.nv-plugin-showcase-featured {
    grid-template-columns: minmax(420px, 1.05fr) minmax(0, 0.95fr);
    align-items: stretch;
    min-height: 430px;
}

.nv-plugin-showcase-featured-media {
    height: 100%;
    min-height: 430px;
    aspect-ratio: auto;
}

.nv-plugin-showcase-featured-media .nv-plugin-showcase-poster,
.nv-plugin-showcase-featured-media .nv-plugin-showcase-preview-video {
    object-fit: cover;
    object-position: center;
}

.nv-plugin-showcase-featured-content {
    min-height: 0;
    justify-content: center;
    padding: clamp(28px, 3vw, 46px);
}

.nv-plugin-showcase-featured h2 {
    max-width: 100%;
    font-size: clamp(34px, 3.25vw, 56px);
    line-height: 0.92;
    letter-spacing: -0.05em;
}

.nv-plugin-showcase-featured .nv-plugin-showcase-description {
    display: -webkit-box;
    -webkit-line-clamp: 5;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.nv-plugin-showcase-featured .nv-plugin-showcase-chips {
    max-height: 76px;
    overflow: hidden;
}

.nv-plugin-showcase-card-media .nv-plugin-showcase-poster,
.nv-plugin-showcase-card-media .nv-plugin-showcase-preview-video {
    object-fit: cover;
    object-position: center;
}

.nv-plugin-showcase-panel-stage {
    position: fixed;
    z-index: 99999;
    inset: 0;
    margin: 0;
    padding: 24px;
    display: none;
    align-items: stretch;
    justify-content: center;
    box-sizing: border-box;
}

.nv-plugin-showcase-panel-stage.is-active {
    display: flex;
}

.nv-plugin-showcase-panel {
    width: min(1560px, calc(100vw - 48px));
    height: calc(100vh - 48px);
    max-height: none;
    display: none;
    grid-template-columns: minmax(0, 1.28fr) minmax(420px, 0.72fr);
    overflow: hidden;
    background:
        linear-gradient(135deg, rgba(255, 26, 26, 0.13), rgba(9, 9, 12, 0.97)),
        rgba(9, 9, 12, 0.97);
}

.nv-plugin-showcase-panel.is-active {
    display: grid;
}

.nv-plugin-showcase-panel-media {
    min-height: 0;
    height: 100%;
    padding: clamp(18px, 2vw, 34px);
    overflow: auto;
    background:
        radial-gradient(circle at 32% 20%, rgba(255, 26, 26, 0.10), transparent 40%),
        rgba(5, 5, 8, 0.48);
}

.nv-plugin-showcase-panel-media .nv-asset-detail-media-stage {
    aspect-ratio: 16 / 9;
    max-height: min(68vh, 720px);
}

.nv-plugin-showcase-panel-media .nv-asset-detail-slide img,
.nv-plugin-showcase-panel-media .nv-asset-detail-slide video {
    object-fit: contain;
}

.nv-plugin-showcase-panel-media .nv-asset-detail-slide iframe {
    object-fit: initial;
}

.nv-plugin-showcase-panel-media .nv-asset-detail-media-thumbs {
    grid-template-columns: repeat(auto-fill, minmax(118px, 1fr));
}

.nv-plugin-showcase-panel-content {
    min-height: 0;
    height: 100%;
    max-height: none;
    overflow: auto;
    padding: clamp(24px, 2.7vw, 46px);
    box-sizing: border-box;
}

.nv-plugin-showcase-panel h3 {
    font-size: clamp(40px, 4.2vw, 72px);
    line-height: 0.9;
    letter-spacing: -0.055em;
}

.nv-plugin-showcase-panel .nv-plugin-showcase-details-description {
    display: block;
    max-width: 720px;
}

.nv-plugin-showcase-panel .nv-plugin-showcase-actions {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.nv-plugin-showcase-panel .nv-plugin-showcase-button {
    width: 100%;
    min-width: 0;
}

.nv-plugin-showcase-panel .nv-asset-detail-media {
    width: 100%;
}

.nv-plugin-showcase-panel-close {
    position: sticky;
    top: 0;
    margin-left: auto;
}

@media (max-width: 1180px) {
    .nv-plugin-showcase-featured {
        grid-template-columns: 1fr;
        min-height: 0;
    }

    .nv-plugin-showcase-featured-media {
        height: auto;
        min-height: 0;
        aspect-ratio: 16 / 9;
    }

    .nv-plugin-showcase-panel {
        grid-template-columns: 1fr;
        width: min(920px, calc(100vw - 28px));
        height: calc(100vh - 28px);
    }

    .nv-plugin-showcase-panel-stage {
        padding: 14px;
    }

    .nv-plugin-showcase-panel-media,
    .nv-plugin-showcase-panel-content {
        height: auto;
        overflow: visible;
    }

    .nv-plugin-showcase-panel {
        overflow: auto;
    }
}

@media (max-width: 700px) {
    .nv-plugin-showcase-panel .nv-plugin-showcase-actions {
        grid-template-columns: 1fr;
    }

    .nv-plugin-showcase-panel h3 {
        font-size: clamp(34px, 11vw, 52px);
    }
}

/* =========================================================
   v1.0.6 - compact featured, centered quick view, better asset details
   ========================================================= */
.nv-plugin-showcase-featured {
    grid-template-columns: minmax(420px, 1fr) minmax(0, 1fr);
    align-items: start;
    min-height: 0;
}

.nv-plugin-showcase-featured-media {
    height: auto;
    min-height: 0;
    aspect-ratio: 16 / 9;
    align-self: start;
}

.nv-plugin-showcase-featured-content {
    align-self: stretch;
    min-height: 0;
    padding: clamp(24px, 2.4vw, 34px);
    justify-content: flex-start;
}

.nv-plugin-showcase-featured h2 {
    margin-top: 18px;
    font-size: clamp(28px, 3vw, 46px);
    line-height: 0.94;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.nv-plugin-showcase-featured .nv-plugin-showcase-description {
    -webkit-line-clamp: 4;
    margin-bottom: 14px;
}

.nv-plugin-showcase-featured .nv-plugin-showcase-meta {
    margin-bottom: 14px;
}

.nv-plugin-showcase-featured .nv-plugin-showcase-chips {
    max-height: 64px;
    margin-bottom: 14px;
}

.nv-plugin-showcase-featured .nv-plugin-showcase-button {
    min-height: 38px;
    padding: 10px 13px;
}

.nv-plugin-showcase-card-page-link,
.nv-plugin-showcase-details-toggle,
.nv-plugin-showcase-button,
.nv-plugin-showcase-mini-button,
.nv-asset-detail-button,
.nv-asset-detail-media-thumbs button,
.nv-asset-detail-media-arrow,
.nv-asset-detail-page-nav a,
.nv-asset-detail-related-card,
.nv-asset-detail-nav a {
    cursor: pointer !important;
}

.nv-plugin-showcase-card-clickable .nv-plugin-showcase-card a,
.nv-plugin-showcase-card-clickable .nv-plugin-showcase-card button,
.nv-plugin-showcase-card-clickable .nv-plugin-showcase-card video {
    cursor: pointer !important;
}

.nv-plugin-showcase-panel-stage {
    align-items: center;
    justify-content: center;
    padding: 28px;
}

.nv-plugin-showcase-panel {
    width: min(1480px, calc(100vw - 56px));
    height: min(860px, calc(100vh - 56px));
    max-height: calc(100vh - 56px);
    grid-template-columns: minmax(0, 1.12fr) minmax(380px, 0.88fr);
}

.nv-plugin-showcase-panel-media {
    overflow: hidden;
    display: flex;
    flex-direction: column;
}

.nv-plugin-showcase-panel-media .nv-asset-detail-media {
    display: flex;
    flex-direction: column;
    min-height: 0;
    height: 100%;
}

.nv-plugin-showcase-panel-media .nv-asset-detail-media-stage {
    flex: 1 1 auto;
    min-height: 280px;
    max-height: none;
    aspect-ratio: auto;
}

.nv-plugin-showcase-panel-media .nv-asset-detail-media-thumbs {
    flex: 0 0 auto;
    grid-template-columns: repeat(auto-fill, minmax(104px, 1fr));
    max-height: 164px;
    overflow: auto;
    padding-right: 4px;
}

.nv-plugin-showcase-panel-content {
    overflow: auto;
}

.nv-plugin-showcase-panel h3 {
    font-size: clamp(34px, 3.2vw, 56px);
    line-height: 0.93;
    display: -webkit-box;
    -webkit-line-clamp: 4;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.nv-plugin-showcase-panel .nv-plugin-showcase-details-description {
    font-size: 13px;
    line-height: 1.58;
}

.nv-plugin-showcase-panel .nv-plugin-showcase-meta {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.nv-plugin-showcase-panel .nv-plugin-showcase-actions {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.nv-asset-detail-spec-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
}

.nv-asset-detail-spec-card {
    min-width: 0;
    padding: 16px;
    background: linear-gradient(135deg, rgba(255,255,255,0.045), rgba(255,26,26,0.022));
    border: 1px solid rgba(255,255,255,0.08);
}

.nv-asset-detail-spec-card small {
    display: block;
    margin-bottom: 9px;
    color: #ff1a1a;
    font-family: Arial, Helvetica, sans-serif;
    font-size: 10px;
    font-weight: 950;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.nv-asset-detail-spec-card strong {
    display: block;
    color: rgba(255,255,255,0.90);
    font-family: "Courier New", monospace;
    font-size: 13px;
    font-weight: 800;
    line-height: 1.45;
}

.nv-asset-detail-spec-card ul {
    margin: 0;
    padding-left: 18px;
}

.nv-asset-detail-spec-card li {
    color: rgba(255,255,255,0.74);
    font-size: 13px;
    line-height: 1.42;
}

.nv-asset-detail-accordion-body .nv-asset-detail-spec-grid + .nv-asset-detail-lines {
    margin-top: 14px;
}

@media (max-width: 1180px) {
    .nv-plugin-showcase-featured {
        grid-template-columns: 1fr;
    }

    .nv-plugin-showcase-panel {
        grid-template-columns: 1fr;
        width: min(980px, calc(100vw - 28px));
        height: min(900px, calc(100vh - 28px));
    }

    .nv-plugin-showcase-panel-media {
        max-height: 56vh;
    }
}

@media (max-width: 780px) {
    .nv-plugin-showcase-panel-stage {
        padding: 12px;
    }

    .nv-plugin-showcase-panel {
        width: calc(100vw - 24px);
        height: calc(100vh - 24px);
        max-height: calc(100vh - 24px);
    }

    .nv-plugin-showcase-panel .nv-plugin-showcase-meta,
    .nv-plugin-showcase-panel .nv-plugin-showcase-actions,
    .nv-asset-detail-spec-grid {
        grid-template-columns: 1fr;
    }

    .nv-plugin-showcase-featured h2 {
        -webkit-line-clamp: 4;
    }
}

/* =========================================================
   v1.0.7 - featured fit, centered media, fixed modal viewport, horizontal chip rail
   ========================================================= */
html.nv-plugin-showcase-modal-open,
body.nv-plugin-showcase-modal-open {
    overflow: hidden;
}

.nv-plugin-showcase-featured {
    grid-template-columns: minmax(400px, 1.08fr) minmax(340px, 0.92fr);
    gap: clamp(20px, 2vw, 28px);
    align-items: center;
}

.nv-plugin-showcase-featured-media {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    align-self: center;
    justify-self: stretch;
    overflow: hidden;
    aspect-ratio: 16 / 9;
    min-height: 0;
}

.nv-plugin-showcase-featured-media .nv-plugin-showcase-poster,
.nv-plugin-showcase-featured-media .nv-plugin-showcase-preview-video {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center center;
}

.nv-plugin-showcase-featured-content {
    align-self: center;
    min-height: 0;
    height: 100%;
    padding: clamp(18px, 2vw, 26px);
    gap: 10px;
    overflow: hidden;
}

.nv-plugin-showcase-featured-top {
    margin-bottom: 8px;
}

.nv-plugin-showcase-featured h2 {
    margin-top: 10px;
    margin-bottom: 10px;
    font-size: clamp(24px, 2.45vw, 40px);
    line-height: 0.92;
    -webkit-line-clamp: 3;
}

.nv-plugin-showcase-featured .nv-plugin-showcase-subtitle {
    margin-bottom: 8px;
    font-size: 12px;
    line-height: 1.45;
}

.nv-plugin-showcase-featured .nv-plugin-showcase-description {
    margin-bottom: 10px;
    font-size: 13px;
    line-height: 1.48;
    -webkit-line-clamp: 4;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.nv-plugin-showcase-featured .nv-plugin-showcase-meta {
    margin-bottom: 10px;
    gap: 8px;
}

.nv-plugin-showcase-featured .nv-plugin-showcase-meta > div {
    padding: 10px 10px 12px;
}

.nv-plugin-showcase-chips {
    display: flex;
    flex-wrap: nowrap;
    gap: 8px;
    margin: 0 0 14px;
    overflow-x: auto;
    overflow-y: hidden;
    padding-bottom: 4px;
    white-space: nowrap;
    scrollbar-width: thin;
}

.nv-plugin-showcase-chips::-webkit-scrollbar {
    height: 6px;
}

.nv-plugin-showcase-chips::-webkit-scrollbar-thumb {
    background: rgba(255, 255, 255, 0.20);
}

.nv-plugin-showcase-chips span {
    flex: 0 0 auto;
}

.nv-plugin-showcase-featured .nv-plugin-showcase-chips {
    max-height: none;
    margin-bottom: 10px;
}

.nv-plugin-showcase-featured .nv-plugin-showcase-actions {
    margin-top: auto;
    gap: 8px;
}

.nv-plugin-showcase-featured .nv-plugin-showcase-button {
    min-height: 36px;
    padding: 9px 12px;
}

.nv-plugin-showcase-panel-stage {
    position: fixed !important;
    inset: 0 !important;
    width: 100vw;
    height: 100vh;
    padding: 20px;
    align-items: center !important;
    justify-content: center !important;
}

.nv-plugin-showcase-panel {
    width: min(1460px, calc(100vw - 40px));
    height: min(820px, calc(100vh - 40px));
    max-height: calc(100vh - 40px);
    margin: auto;
    align-self: center;
    grid-template-columns: minmax(0, 1.06fr) minmax(360px, 0.94fr);
}

.nv-plugin-showcase-panel-media,
.nv-plugin-showcase-panel-content {
    min-height: 0;
}

.nv-plugin-showcase-panel-media {
    justify-content: center;
}

.nv-plugin-showcase-panel-media .nv-asset-detail-media-stage {
    min-height: 0;
    max-height: min(58vh, 620px);
    display: flex;
    align-items: center;
    justify-content: center;
}

.nv-plugin-showcase-panel-media .nv-asset-detail-slide img,
.nv-plugin-showcase-panel-media .nv-asset-detail-slide video,
.nv-plugin-showcase-panel-media .nv-asset-detail-slide iframe {
    object-position: center center;
}

@media (max-width: 1180px) {
    .nv-plugin-showcase-featured {
        grid-template-columns: 1fr;
    }

    .nv-plugin-showcase-featured-content {
        height: auto;
        overflow: visible;
    }

    .nv-plugin-showcase-panel {
        width: min(980px, calc(100vw - 24px));
        height: min(860px, calc(100vh - 24px));
        max-height: calc(100vh - 24px);
        grid-template-columns: 1fr;
    }
}

@media (max-width: 780px) {
    .nv-plugin-showcase-panel-stage {
        padding: 12px;
    }

    .nv-plugin-showcase-panel {
        width: calc(100vw - 24px);
        height: calc(100vh - 24px);
        max-height: calc(100vh - 24px);
    }

    .nv-plugin-showcase-featured h2 {
        font-size: clamp(26px, 8vw, 38px);
    }
}

/* =========================================================
   v1.0.8 - featured block equal-height tightening, hidden chip scrollbars
   ========================================================= */
.nv-plugin-showcase-featured {
    grid-template-columns: minmax(420px, 1.14fr) minmax(320px, 0.86fr);
    align-items: stretch;
}

.nv-plugin-showcase-featured-media,
.nv-plugin-showcase-featured-content {
    height: clamp(330px, 29vw, 432px);
}

.nv-plugin-showcase-featured-media {
    aspect-ratio: auto;
}

.nv-plugin-showcase-featured-content {
    justify-content: flex-start;
}

.nv-plugin-showcase-featured h2 {
    font-size: clamp(22px, 2.2vw, 36px);
    line-height: 0.9;
    -webkit-line-clamp: 3;
    overflow: hidden;
}

.nv-plugin-showcase-featured .nv-plugin-showcase-description {
    -webkit-line-clamp: 3;
    font-size: 12px;
    line-height: 1.42;
}

.nv-plugin-showcase-featured .nv-plugin-showcase-meta > div {
    padding: 9px 10px 10px;
}

.nv-plugin-showcase-featured .nv-plugin-showcase-actions {
    margin-top: 0;
}

.nv-plugin-showcase-featured .nv-plugin-showcase-chips {
    margin-bottom: 8px;
}

.nv-plugin-showcase-chips {
    scrollbar-width: none;
    -ms-overflow-style: none;
}

.nv-plugin-showcase-chips::-webkit-scrollbar {
    display: none;
    width: 0;
    height: 0;
}

@media (max-width: 1180px) {
    .nv-plugin-showcase-featured-media,
    .nv-plugin-showcase-featured-content {
        height: auto;
    }
}

/* =========================================================
   v1.0.9 - Steam-like featured showcase slider
   ========================================================= */
.nv-plugin-showcase-steam-featured {
    margin-bottom: 26px;
}

.nv-plugin-showcase-steam-stage {
    position: relative;
    min-height: 420px;
    border: 1px solid rgba(255, 32, 32, 0.28);
    background: linear-gradient(180deg, rgba(45, 6, 10, 0.82), rgba(12, 9, 16, 0.92));
    overflow: hidden;
}

.nv-plugin-showcase-steam-slide {
    position: absolute;
    inset: 0;
    display: grid;
    grid-template-columns: minmax(0, 1.6fr) minmax(320px, 0.84fr);
    align-items: center;
    gap: 18px;
    padding: 18px;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.35s ease;
}

.nv-plugin-showcase-steam-slide.is-active {
    opacity: 1;
    pointer-events: auto;
}

.nv-plugin-showcase-steam-media-wrap,
.nv-plugin-showcase-steam-copy {
    min-width: 0;
}

.nv-plugin-showcase-steam-media-wrap {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 100%;
}

.nv-plugin-showcase-steam-featured .nv-plugin-showcase-featured-media {
    width: 100%;
    height: 100%;
    min-height: 384px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #05070d;
}

.nv-plugin-showcase-steam-featured .nv-plugin-showcase-featured-media .nv-plugin-showcase-poster,
.nv-plugin-showcase-steam-featured .nv-plugin-showcase-featured-media .nv-plugin-showcase-preview-video {
    width: 100%;
    height: 100%;
    object-fit: contain;
    object-position: center center;
}

.nv-plugin-showcase-steam-copy {
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 12px;
    min-height: 100%;
}

.nv-plugin-showcase-steam-copy h2 {
    margin: 0;
    font-size: clamp(32px, 3vw, 58px);
    line-height: 0.9;
    letter-spacing: -0.04em;
    overflow-wrap: anywhere;
}

.nv-plugin-showcase-steam-promo {
    margin: 0;
    color: rgba(245, 242, 244, 0.9);
    font-size: 14px;
    line-height: 1.55;
    display: -webkit-box;
    -webkit-line-clamp: 6;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.nv-plugin-showcase-steam-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 4px;
}

.nv-plugin-showcase-steam-actions .nv-plugin-showcase-button {
    min-width: 170px;
}

.nv-plugin-showcase-steam-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.nv-plugin-showcase-steam-meta span {
    display: inline-flex;
    align-items: center;
    min-height: 28px;
    padding: 6px 10px;
    border: 1px solid rgba(255, 255, 255, 0.12);
    background: rgba(255, 255, 255, 0.04);
    color: rgba(255, 255, 255, 0.8);
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

.nv-plugin-showcase-steam-nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 54px;
    height: 108px;
    border: 0;
    background: rgba(9, 20, 34, 0.66);
    color: #ffffff;
    font-size: 52px;
    line-height: 1;
    cursor: pointer;
    z-index: 3;
    transition: background 0.2s ease, color 0.2s ease;
}

.nv-plugin-showcase-steam-nav:hover,
.nv-plugin-showcase-steam-nav:focus-visible {
    background: rgba(19, 39, 63, 0.88);
    color: #ffeded;
}

.nv-plugin-showcase-steam-nav.is-prev { left: 0; }
.nv-plugin-showcase-steam-nav.is-next { right: 0; }

.nv-plugin-showcase-steam-dots {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 14px 0 2px;
}

.nv-plugin-showcase-steam-dots button {
    width: 44px;
    height: 8px;
    border: 0;
    background: rgba(255, 255, 255, 0.18);
    cursor: pointer;
    transition: background 0.2s ease, transform 0.2s ease;
}

.nv-plugin-showcase-steam-dots button.is-active,
.nv-plugin-showcase-steam-dots button:hover,
.nv-plugin-showcase-steam-dots button:focus-visible {
    background: #8dc3ff;
    transform: scaleY(1.1);
}

@media (max-width: 1100px) {
    .nv-plugin-showcase-steam-stage {
        min-height: 0;
    }

    .nv-plugin-showcase-steam-slide {
        position: relative;
        grid-template-columns: 1fr;
        padding: 14px;
        display: none;
    }

    .nv-plugin-showcase-steam-slide.is-active {
        display: grid;
    }

    .nv-plugin-showcase-steam-featured .nv-plugin-showcase-featured-media {
        min-height: 280px;
    }

    .nv-plugin-showcase-steam-copy h2 {
        font-size: clamp(26px, 5.4vw, 42px);
    }

    .nv-plugin-showcase-steam-nav {
        width: 44px;
        height: 72px;
        font-size: 38px;
    }
}

/* =========================================================
   v1.0.10 - cleaner promo slider: one CTA, clipped title, YouTube hover preview
   ========================================================= */
.nv-plugin-showcase-preview-youtube {
    position: absolute;
    inset: 0;
    z-index: 2;
    width: 100%;
    height: 100%;
    border: 0;
    display: block;
    opacity: 0;
    pointer-events: none;
    background: #050507;
    transition: opacity 0.22s ease;
}

.nv-plugin-showcase-featured:hover .nv-plugin-showcase-preview-youtube,
.nv-plugin-showcase-card:hover .nv-plugin-showcase-preview-youtube,
.nv-plugin-showcase-featured.is-previewing .nv-plugin-showcase-preview-youtube,
.nv-plugin-showcase-card.is-previewing .nv-plugin-showcase-preview-youtube {
    opacity: 1;
}

.nv-plugin-showcase-featured.is-previewing .nv-plugin-showcase-preview-video,
.nv-plugin-showcase-card.is-previewing .nv-plugin-showcase-preview-video {
    opacity: 1;
}

.nv-plugin-showcase-featured.is-previewing .nv-plugin-showcase-poster,
.nv-plugin-showcase-card.is-previewing .nv-plugin-showcase-poster {
    opacity: 0;
}

.nv-plugin-showcase-steam-stage {
    min-height: 360px;
}

.nv-plugin-showcase-steam-slide {
    grid-template-columns: minmax(0, 1.68fr) minmax(280px, 0.74fr);
    gap: 18px;
    overflow: hidden;
}

.nv-plugin-showcase-steam-featured .nv-plugin-showcase-featured-media {
    min-height: 318px;
    max-height: 318px;
}

.nv-plugin-showcase-steam-copy {
    overflow: hidden;
    min-height: 0;
    max-height: 318px;
    justify-content: center;
    padding-right: 8px;
}

.nv-plugin-showcase-steam-copy .nv-plugin-showcase-featured-top {
    flex: 0 0 auto;
}

.nv-plugin-showcase-steam-copy h2 {
    font-family: Arial, Helvetica, sans-serif;
    font-size: clamp(28px, 2.45vw, 44px);
    line-height: 0.9;
    letter-spacing: -0.045em;
    max-height: calc(0.9em * 2);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
    overflow-wrap: anywhere;
    word-break: normal;
}

.nv-plugin-showcase-steam-promo {
    font-size: 13px;
    line-height: 1.45;
    -webkit-line-clamp: 5;
}

.nv-plugin-showcase-steam-actions {
    flex: 0 0 auto;
}

.nv-plugin-showcase-steam-actions .nv-plugin-showcase-button {
    min-width: 178px;
    max-width: 220px;
}

.nv-plugin-showcase-steam-copy .nv-plugin-showcase-button:not(.nv-plugin-showcase-button-main) {
    display: none !important;
}

@media (max-width: 1100px) {
    .nv-plugin-showcase-steam-featured .nv-plugin-showcase-featured-media {
        min-height: 260px;
        max-height: 260px;
    }

    .nv-plugin-showcase-steam-copy {
        max-height: none;
        padding-right: 0;
    }
}

/* =========================================================
   v1.1.0 - Steam-like asset showcase slider
   ========================================================= */
.nv-plugin-showcase-steam-featured-v2 {
    margin: 8px 0 28px;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-stage {
    min-height: 360px;
    border: 1px solid rgba(255, 32, 32, 0.34);
    background:
        radial-gradient(circle at 72% 28%, rgba(255, 44, 44, 0.10), transparent 34%),
        linear-gradient(90deg, rgba(10, 12, 18, 0.94), rgba(17, 13, 18, 0.96) 58%, rgba(36, 9, 13, 0.92));
    box-shadow: 0 22px 60px rgba(0, 0, 0, 0.36);
    overflow: hidden;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-slide {
    padding: 0;
    display: block;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-link {
    position: absolute;
    inset: 0;
    display: grid;
    grid-template-columns: minmax(0, 1.68fr) minmax(310px, 0.92fr);
    gap: 0;
    color: inherit;
    text-decoration: none;
    cursor: pointer;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-link:hover,
.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-link:focus-visible {
    color: inherit;
    text-decoration: none;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-media-wrap {
    position: relative;
    height: 100%;
    min-width: 0;
    display: block;
    background: #03060c;
    overflow: hidden;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-media-wrap::after {
    content: "";
    position: absolute;
    top: 0;
    right: -1px;
    bottom: 0;
    width: 32%;
    z-index: 5;
    pointer-events: none;
    background: linear-gradient(90deg, rgba(3, 6, 12, 0), rgba(9, 10, 14, 0.66) 58%, rgba(14, 10, 14, 0.96));
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-featured-media {
    width: 100%;
    height: 100%;
    min-height: 0;
    aspect-ratio: auto;
    border: 0;
    background: #03060c;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-featured-media .nv-plugin-showcase-poster,
.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-featured-media .nv-plugin-showcase-preview-video,
.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-featured-media .nv-plugin-showcase-preview-youtube {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center center;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-badge {
    z-index: 7;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-preview-label {
    z-index: 7;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-copy {
    position: relative;
    z-index: 6;
    min-width: 0;
    min-height: 0;
    display: grid;
    grid-template-rows: auto auto minmax(0, 1fr) auto;
    align-content: stretch;
    gap: 14px;
    padding: 30px 28px 26px;
    background:
        radial-gradient(circle at 80% 12%, rgba(255, 255, 255, 0.06), transparent 30%),
        linear-gradient(135deg, rgba(18, 18, 24, 0.92), rgba(37, 8, 13, 0.9));
    overflow: hidden;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-copy h2 {
    margin: 0;
    max-width: 100%;
    color: #f4f1f4;
    font-family: Arial, Helvetica, sans-serif;
    font-size: clamp(25px, 2vw, 36px);
    font-weight: 500;
    line-height: 1.05;
    letter-spacing: -0.025em;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    overflow-wrap: anywhere;
    text-shadow: 0 8px 20px rgba(0, 0, 0, 0.55);
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-thumbs {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
    min-height: 0;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-thumbs span {
    position: relative;
    display: block;
    aspect-ratio: 16 / 9;
    overflow: hidden;
    background: rgba(0, 0, 0, 0.42);
    border: 1px solid rgba(255, 255, 255, 0.08);
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-thumbs img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center center;
    display: block;
    transition: transform 0.28s ease, opacity 0.28s ease;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-link:hover .nv-plugin-showcase-steam-thumbs img {
    opacity: 0.92;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-promo {
    margin: 0;
    color: rgba(246, 242, 245, 0.88);
    font-family: Arial, Helvetica, sans-serif;
    font-size: 14px;
    font-weight: 500;
    line-height: 1.42;
    display: -webkit-box;
    -webkit-line-clamp: 4;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    min-height: 32px;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-price {
    display: inline-flex;
    align-items: center;
    min-height: 30px;
    padding: 6px 10px;
    background: rgba(0, 0, 0, 0.72);
    color: #ffffff;
    font-family: Arial, Helvetica, sans-serif;
    font-size: 13px;
    font-weight: 800;
    letter-spacing: 0.02em;
    text-transform: uppercase;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-readmore {
    margin-left: auto;
    color: #ff3131;
    font-family: Arial, Helvetica, sans-serif;
    font-size: 12px;
    font-weight: 900;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    white-space: nowrap;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-readmore em {
    margin-left: 10px;
    font-style: normal;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-nav {
    width: 58px;
    height: 118px;
    background: rgba(4, 14, 26, 0.58);
    z-index: 10;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-nav.is-prev {
    left: 0;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-nav.is-next {
    right: 0;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-dots {
    padding-top: 12px;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-dots button {
    width: 38px;
    height: 7px;
    border-radius: 0;
    background: rgba(255, 255, 255, 0.20);
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-dots button.is-active {
    background: #8dc3ff;
}

@media (max-width: 1120px) {
    .nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-stage {
        min-height: 0;
    }

    .nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-slide {
        position: relative;
        display: none;
    }

    .nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-slide.is-active {
        display: block;
    }

    .nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-link {
        position: relative;
        grid-template-columns: 1fr;
    }

    .nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-media-wrap {
        height: auto;
        aspect-ratio: 16 / 9;
    }

    .nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-media-wrap::after {
        display: none;
    }

    .nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-copy {
        padding: 20px;
    }
}

@media (max-width: 720px) {
    .nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-thumbs {
        display: none;
    }

    .nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-copy h2 {
        font-size: 28px;
    }

    .nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-nav {
        width: 42px;
        height: 76px;
    }
}

/* =========================================================
   v1.1.1 - Steam slider interactions: media hover video + thumbnail preview
   ========================================================= */
.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-thumbs span {
    cursor: pointer;
    outline: 0;
    transition: border-color 0.18s ease, box-shadow 0.18s ease, transform 0.18s ease, opacity 0.18s ease;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-thumbs span:hover,
.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-thumbs span:focus-visible,
.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-thumbs span.is-active {
    border-color: rgba(255, 40, 40, 0.82);
    box-shadow: 0 0 0 1px rgba(255, 20, 20, 0.26), 0 0 22px rgba(255, 0, 0, 0.18);
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-media-wrap:hover .nv-plugin-showcase-poster {
    transform: scale(1.025);
    filter: brightness(0.86) contrast(1.08);
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-slide.is-previewing .nv-plugin-showcase-preview-video,
.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-slide.is-previewing .nv-plugin-showcase-preview-youtube {
    opacity: 1;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-slide.is-previewing .nv-plugin-showcase-poster {
    opacity: 0;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-slide.is-thumb-previewing .nv-plugin-showcase-poster {
    opacity: 1;
    filter: none;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-slide.is-thumb-previewing .nv-plugin-showcase-preview-video,
.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-slide.is-thumb-previewing .nv-plugin-showcase-preview-youtube {
    opacity: 0;
}

/* =========================================================
   v1.1.2 - tighter Steam-style hero proportions
   ========================================================= */
.nv-plugin-showcase-steam-featured-v2 {
    margin: 10px 0 30px;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-stage {
    min-height: clamp(390px, 31vw, 440px);
    border-color: rgba(255, 32, 32, 0.42);
    background:
        radial-gradient(circle at 72% 30%, rgba(105, 133, 160, 0.10), transparent 28%),
        linear-gradient(90deg, rgba(5, 8, 13, 0.98) 0%, rgba(7, 12, 18, 0.98) 62%, rgba(14, 22, 31, 0.96) 100%);
    box-shadow: 0 20px 54px rgba(0, 0, 0, 0.55);
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-link {
    grid-template-columns: minmax(0, 2.15fr) minmax(270px, 0.82fr);
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-media-wrap {
    background: #03060b;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-media-wrap::after {
    right: 0;
    width: 40%;
    background: linear-gradient(90deg, rgba(3, 6, 12, 0) 0%, rgba(4, 7, 12, 0.40) 48%, rgba(7, 11, 17, 0.98) 100%);
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-featured-media .nv-plugin-showcase-poster,
.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-featured-media .nv-plugin-showcase-preview-video,
.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-featured-media .nv-plugin-showcase-preview-youtube {
    object-fit: cover;
    object-position: center center;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-copy {
    padding: 28px 24px 22px;
    gap: 12px;
    background:
        linear-gradient(135deg, rgba(8, 14, 22, 0.98), rgba(10, 19, 30, 0.96) 54%, rgba(11, 17, 25, 0.98)),
        repeating-linear-gradient(45deg, rgba(255, 255, 255, 0.025) 0 1px, transparent 1px 7px);
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-featured-top {
    display: none;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-copy h2 {
    display: block;
    width: 100%;
    max-width: 100%;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    overflow-wrap: normal;
    word-break: normal;
    font-size: clamp(24px, 1.9vw, 34px);
    font-weight: 500;
    line-height: 1.08;
    letter-spacing: -0.02em;
    color: rgba(244, 247, 250, 0.96);
    text-shadow: 0 2px 18px rgba(0, 0, 0, 0.62);
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-thumbs {
    gap: 8px;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-thumbs span {
    border: 0;
    background: #0a1018;
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.04);
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-thumbs span:hover,
.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-thumbs span:focus-visible,
.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-thumbs span.is-active {
    border-color: transparent;
    box-shadow: inset 0 0 0 2px rgba(141, 195, 255, 0.78), 0 0 20px rgba(0, 0, 0, 0.34);
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-promo {
    max-width: 96%;
    color: rgba(236, 242, 248, 0.9);
    font-size: 13px;
    line-height: 1.42;
    -webkit-line-clamp: 3;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-footer {
    align-items: end;
    margin-top: auto;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-readmore {
    color: #ff3737;
    text-shadow: 0 0 18px rgba(255, 0, 0, 0.18);
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-dots {
    padding-top: 13px;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-dots button {
    width: 34px;
    height: 8px;
    background: rgba(180, 190, 202, 0.24);
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-dots button.is-active {
    background: #8cc7ff;
}

@media (max-width: 1120px) {
    .nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-stage {
        min-height: 0;
    }

    .nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-link {
        grid-template-columns: 1fr;
    }
}

/* =========================================================
   v1.1.3 - Steam hero alignment cleanup
   ========================================================= */
.nv-plugin-showcase-steam-featured-v2 {
    margin: 10px 0 30px;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-stage {
    min-height: clamp(410px, 33vw, 462px);
    background:
        radial-gradient(circle at 80% 18%, rgba(110, 142, 170, 0.11), transparent 26%),
        linear-gradient(90deg, rgba(4, 8, 13, 0.98) 0%, rgba(7, 11, 17, 0.98) 63%, rgba(9, 14, 21, 0.98) 100%);
    box-shadow: 0 22px 56px rgba(0, 0, 0, 0.56);
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-slide {
    overflow: hidden;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-link {
    grid-template-columns: minmax(0, 1.92fr) minmax(300px, 0.98fr);
    align-items: stretch;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-media-wrap {
    padding: 16px 0 16px 16px;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    background: linear-gradient(180deg, rgba(4, 8, 13, 0.94), rgba(4, 8, 13, 0.98));
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-media-wrap::after {
    width: 36%;
    right: 0;
    background: linear-gradient(90deg, rgba(3, 6, 10, 0) 0%, rgba(5, 9, 14, 0.66) 52%, rgba(8, 12, 18, 0.98) 100%);
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-featured-media {
    width: 100%;
    max-width: none;
    height: auto;
    aspect-ratio: 616 / 353;
    align-self: center;
    box-shadow: 0 14px 32px rgba(0, 0, 0, 0.28);
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-featured-media .nv-plugin-showcase-poster,
.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-featured-media .nv-plugin-showcase-preview-video,
.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-featured-media .nv-plugin-showcase-preview-youtube {
    width: 100%;
    height: 100%;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-copy {
    padding: 18px 18px 16px 6px;
    grid-template-rows: auto minmax(0, 1fr) auto;
    gap: 14px;
    background:
        linear-gradient(180deg, rgba(17, 27, 40, 0.92), rgba(12, 20, 30, 0.98)),
        repeating-linear-gradient(45deg, rgba(255, 255, 255, 0.018) 0 1px, transparent 1px 8px);
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-copy h2 {
    margin: 0;
    font-size: clamp(24px, 2vw, 30px);
    font-weight: 500;
    line-height: 1.06;
    letter-spacing: -0.03em;
    color: #f4f8fc;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-thumbs {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
    align-content: start;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-thumbs span {
    aspect-ratio: 16 / 9;
    border: 1px solid rgba(255, 255, 255, 0.06);
    background: #0a121c;
    overflow: hidden;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-thumbs img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center center;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-promo,
.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-price {
    display: none !important;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-footer {
    margin-top: auto;
    min-height: 28px;
    justify-content: flex-end;
    align-items: flex-end;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-readmore {
    margin-left: 0;
    color: #ff3131;
    font-size: 12px;
    letter-spacing: 0.08em;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-nav {
    width: 52px;
    height: 100px;
    background: rgba(4, 13, 24, 0.66);
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-nav:hover,
.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-nav:focus-visible {
    background: rgba(12, 29, 47, 0.92);
}

@media (max-width: 1120px) {
    .nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-link {
        grid-template-columns: 1fr;
    }

    .nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-media-wrap {
        padding: 14px 14px 0;
    }

    .nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-copy {
        padding: 16px 14px 14px;
    }
}


/* =========================================================
   v1.1.4 - fixed Steam hero vertical centering and slide proportions
   ========================================================= */
.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-stage {
    min-height: 0 !important;
    height: auto !important;
    aspect-ratio: 940 / 353;
    max-height: 430px;
    background:
        radial-gradient(circle at 82% 16%, rgba(110, 142, 170, 0.11), transparent 26%),
        linear-gradient(90deg, rgba(4, 8, 13, 0.98) 0%, rgba(6, 10, 16, 0.99) 66%, rgba(8, 13, 20, 0.99) 100%) !important;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-link {
    grid-template-columns: minmax(0, 65.5%) minmax(270px, 34.5%) !important;
    align-items: stretch !important;
    height: 100%;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-media-wrap {
    height: 100% !important;
    min-height: 0 !important;
    padding: 0 !important;
    display: block !important;
    align-items: initial !important;
    justify-content: initial !important;
    background: #03070d !important;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-featured-media {
    width: 100% !important;
    height: 100% !important;
    min-height: 0 !important;
    max-height: none !important;
    aspect-ratio: auto !important;
    display: block !important;
    align-self: stretch !important;
    box-shadow: none !important;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-featured-media .nv-plugin-showcase-poster,
.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-featured-media .nv-plugin-showcase-preview-video,
.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-featured-media .nv-plugin-showcase-preview-youtube {
    inset: 0 !important;
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    object-position: center center !important;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-media-wrap::after {
    width: 34% !important;
    background: linear-gradient(90deg, rgba(3, 7, 12, 0) 0%, rgba(4, 8, 14, 0.54) 48%, rgba(8, 13, 20, 0.99) 100%) !important;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-copy {
    height: 100% !important;
    min-height: 0 !important;
    max-height: none !important;
    align-self: stretch !important;
    padding: 22px 16px 18px 16px !important;
    grid-template-rows: auto minmax(0, 1fr) auto !important;
    gap: 12px !important;
    background:
        linear-gradient(180deg, rgba(17, 27, 40, 0.96), rgba(10, 17, 26, 0.99)),
        repeating-linear-gradient(45deg, rgba(255, 255, 255, 0.018) 0 1px, transparent 1px 8px) !important;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-copy h2 {
    display: block !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    -webkit-line-clamp: initial !important;
    max-height: none !important;
    font-size: clamp(23px, 2.0vw, 31px) !important;
    line-height: 1.05 !important;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-thumbs {
    gap: 8px !important;
    align-content: start !important;
    align-self: start !important;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-footer {
    align-self: end !important;
    min-height: 26px !important;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-dots {
    padding-top: 10px !important;
}

@media (max-width: 1120px) {
    .nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-stage {
        aspect-ratio: auto !important;
        max-height: none !important;
    }

    .nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-link {
        grid-template-columns: 1fr !important;
        height: auto !important;
    }

    .nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-media-wrap {
        aspect-ratio: 16 / 9;
        height: auto !important;
    }

    .nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-copy {
        height: auto !important;
    }
}


/* =========================================================
   v1.1.5 - tighten Steam right rail alignment to match reference
   ========================================================= */
.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-stage {
    max-height: 436px !important;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-link {
    grid-template-columns: minmax(0, 68.5%) minmax(290px, 31.5%) !important;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-media-wrap::after {
    width: 26% !important;
    background: linear-gradient(90deg, rgba(3, 7, 12, 0) 0%, rgba(4, 8, 14, 0.72) 58%, rgba(8, 13, 20, 0.98) 100%) !important;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-copy {
    padding: 12px 14px 12px 0 !important;
    gap: 10px !important;
    grid-template-rows: auto auto 1fr auto !important;
    align-content: start !important;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-featured-top,
.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-copy h2,
.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-footer {
    padding-left: 14px !important;
    padding-right: 14px !important;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-copy h2 {
    margin: 0 !important;
    font-size: clamp(21px, 1.95vw, 31px) !important;
    line-height: 1.02 !important;
    min-height: 0 !important;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-thumbs {
    width: 100% !important;
    margin: 0 !important;
    gap: 6px !important;
    align-self: start !important;
    align-content: start !important;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-thumbs span {
    border: 0 !important;
    box-shadow: none !important;
    background: rgba(255,255,255,0.02) !important;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-thumbs img {
    display: block !important;
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    object-position: center center !important;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-footer {
    margin-top: auto !important;
    min-height: 30px !important;
    justify-content: flex-end !important;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-readmore {
    margin-left: 0 !important;
}

@media (max-width: 1120px) {
    .nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-copy {
        padding: 14px !important;
    }

    .nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-featured-top,
    .nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-copy h2,
    .nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-footer {
        padding-left: 0 !important;
        padding-right: 0 !important;
    }
}


/* =========================================================
   v1.1.6 - center Steam right thumbnails vertically
   ========================================================= */
.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-copy {
    grid-template-rows: auto minmax(0, 1fr) auto !important;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-thumbs {
    align-self: center !important;
    align-content: center !important;
    margin-top: 0 !important;
    margin-bottom: 0 !important;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-footer {
    align-self: end !important;
}

@media (max-width: 1120px) {
    .nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-thumbs {
        align-self: start !important;
        align-content: start !important;
    }
}


/* =========================================================
   v1.1.7 - Steam title row polish
   ========================================================= */
.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-copy {
    grid-template-rows: 84px minmax(0, 1fr) 42px !important;
    padding: 0 14px 12px 0 !important;
    gap: 0 !important;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-copy h2 {
    box-sizing: border-box !important;
    width: 100% !important;
    min-height: 84px !important;
    max-height: 84px !important;
    margin: 0 !important;
    padding: 18px 14px 0 14px !important;
    color: #f2f7fb !important;
    font-size: clamp(23px, 1.7vw, 30px) !important;
    font-weight: 500 !important;
    line-height: 1.12 !important;
    letter-spacing: -0.035em !important;
    white-space: normal !important;
    overflow: hidden !important;
    text-overflow: clip !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 2 !important;
    -webkit-box-orient: vertical !important;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-thumbs {
    align-self: center !important;
    align-content: center !important;
    margin: 0 !important;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-footer {
    min-height: 42px !important;
    height: 42px !important;
    padding: 0 14px !important;
    align-self: stretch !important;
    align-items: center !important;
    justify-content: flex-end !important;
}

@media (max-width: 1120px) {
    .nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-copy {
        grid-template-rows: auto auto auto !important;
        padding: 14px !important;
        gap: 12px !important;
    }

    .nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-copy h2 {
        min-height: 0 !important;
        max-height: none !important;
        padding: 0 !important;
    }

    .nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-footer {
        height: auto !important;
        min-height: 32px !important;
        padding: 0 !important;
    }
}

/* =========================================================
   v1.1.9 - Steam side rail: independent vertical centering + empty placeholders
   ========================================================= */
.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-copy {
    position: relative !important;
    display: block !important;
    padding: 0 !important;
    overflow: hidden !important;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-copy h2 {
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    z-index: 2 !important;
    box-sizing: border-box !important;
    width: 100% !important;
    min-height: 74px !important;
    max-height: 74px !important;
    margin: 0 !important;
    padding: 17px 14px 0 14px !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 2 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-thumbs {
    position: absolute !important;
    left: 0 !important;
    right: 0 !important;
    top: 52% !important;
    transform: translateY(-50%) !important;
    z-index: 1 !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 6px !important;
    align-content: center !important;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-thumbs span {
    aspect-ratio: 16 / 9 !important;
    min-width: 0 !important;
    overflow: hidden !important;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-thumb-placeholder {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    border: 1px solid rgba(255, 32, 32, 0.22) !important;
    background:
        radial-gradient(circle at 50% 50%, rgba(255, 0, 0, 0.18), transparent 48%),
        linear-gradient(135deg, rgba(19, 9, 12, 0.98), rgba(10, 11, 17, 0.98)) !important;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-thumb-placeholder strong {
    color: rgba(255, 22, 22, 0.58) !important;
    font-family: Arial, Helvetica, sans-serif !important;
    font-size: clamp(22px, 2vw, 38px) !important;
    font-weight: 900 !important;
    line-height: 1 !important;
    letter-spacing: -0.06em !important;
    text-transform: uppercase !important;
    text-shadow: 0 0 18px rgba(255, 0, 0, 0.16) !important;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-footer {
    position: absolute !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    z-index: 2 !important;
    box-sizing: border-box !important;
    height: 46px !important;
    min-height: 46px !important;
    padding: 0 14px 14px 14px !important;
    display: flex !important;
    align-items: flex-end !important;
    justify-content: flex-end !important;
}

@media (max-width: 1120px) {
    .nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-copy {
        display: grid !important;
        grid-template-rows: auto auto auto !important;
        padding: 14px !important;
        gap: 12px !important;
    }

    .nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-copy h2,
    .nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-thumbs,
    .nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-footer {
        position: static !important;
        transform: none !important;
        padding: 0 !important;
        height: auto !important;
        min-height: 0 !important;
        max-height: none !important;
    }
}


/* =========================================================
   v1.1.9 - asset page media slider arrow/click fixes
   ========================================================= */
.nv-asset-detail-media {
    position: relative;
}

.nv-asset-detail-media-stage {
    position: relative;
}

.nv-asset-detail-media-arrow {
    top: 50%;
    transform: translateY(-50%);
    z-index: 12;
    display: grid;
    place-items: center;
}

.nv-asset-detail-media-prev {
    left: 12px;
}

.nv-asset-detail-media-next {
    right: 12px;
}

.nv-asset-detail-slide.is-active img {
    cursor: pointer;
}

.nv-asset-detail-slide.is-active img:hover {
    filter: brightness(1.04);
}


/* =========================================================
   v1.1.11 - compact asset page deep-dive and related block
   ========================================================= */
.nv-asset-detail-main {
    gap: 18px !important;
}

.nv-asset-detail-deep-dive.nv-asset-detail-section {
    padding: 22px !important;
    background:
        radial-gradient(circle at 85% 10%, rgba(255, 26, 26, 0.055), transparent 30%),
        rgba(10, 10, 14, 0.76) !important;
}

.nv-asset-detail-deep-dive .nv-asset-detail-section-head {
    display: flex !important;
    align-items: end !important;
    justify-content: space-between !important;
    gap: 18px !important;
    margin-bottom: 14px !important;
}

.nv-asset-detail-deep-dive .nv-asset-detail-section-head h2 {
    font-size: clamp(22px, 2vw, 30px) !important;
    line-height: 0.95 !important;
}

.nv-asset-detail-accordion-stack {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 10px !important;
}

.nv-asset-detail-compact-accordion {
    overflow: hidden !important;
    background: rgba(8, 8, 12, 0.88) !important;
    border: 1px solid rgba(255, 255, 255, 0.075) !important;
    box-shadow: none !important;
}

.nv-asset-detail-compact-accordion summary {
    min-height: 54px !important;
    display: grid !important;
    grid-template-columns: 1fr auto auto !important;
    align-items: center !important;
    gap: 10px !important;
    padding: 0 14px !important;
    font-size: 17px !important;
}

.nv-asset-detail-compact-accordion summary span {
    min-width: 0 !important;
    overflow: hidden !important;
    white-space: nowrap !important;
    text-overflow: ellipsis !important;
}

.nv-asset-detail-compact-accordion summary small {
    color: rgba(255, 255, 255, 0.44) !important;
    font-family: "Courier New", monospace !important;
    font-size: 10px !important;
    font-weight: 800 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.06em !important;
}

.nv-asset-detail-compact-accordion summary em {
    font-size: 10px !important;
}

.nv-asset-detail-compact-accordion[open] {
    grid-column: 1 / -1 !important;
    border-color: rgba(255, 26, 26, 0.26) !important;
    background:
        linear-gradient(135deg, rgba(255, 26, 26, 0.045), rgba(255, 255, 255, 0.025)),
        rgba(8, 8, 12, 0.94) !important;
}

.nv-asset-detail-compact-accordion[open] summary {
    border-bottom: 1px solid rgba(255, 255, 255, 0.07) !important;
}

.nv-asset-detail-compact-accordion .nv-asset-detail-accordion-body {
    padding: 14px !important;
}

.nv-asset-detail-compact-accordion .nv-asset-detail-lines {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 8px !important;
}

.nv-asset-detail-compact-accordion .nv-asset-detail-line {
    min-height: 54px !important;
    padding: 10px 12px !important;
    background: rgba(255, 255, 255, 0.032) !important;
}

.nv-asset-detail-compact-accordion .nv-asset-detail-line strong {
    font-size: 12px !important;
}

.nv-asset-detail-compact-accordion .nv-asset-detail-line span {
    font-size: 11px !important;
    line-height: 1.45 !important;
}

.nv-asset-detail-compact-accordion .nv-asset-detail-spec-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 8px !important;
}

.nv-asset-detail-compact-accordion .nv-asset-detail-spec-card {
    min-height: 72px !important;
    padding: 12px !important;
}

.nv-asset-detail-related.nv-asset-detail-section {
    margin-top: 12px !important;
    padding: 22px !important;
    background:
        linear-gradient(90deg, rgba(255, 26, 26, 0.06), rgba(255, 255, 255, 0.018)),
        rgba(10, 10, 14, 0.78) !important;
}

.nv-asset-detail-related .nv-asset-detail-section-head {
    margin-bottom: 14px !important;
}

.nv-asset-detail-related .nv-asset-detail-section-head h2 {
    font-size: clamp(22px, 2vw, 30px) !important;
}

.nv-asset-detail-related-grid {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    gap: 10px !important;
}

.nv-asset-detail-related-card {
    position: relative !important;
    display: grid !important;
    grid-template-rows: auto minmax(0, 1fr) !important;
    min-height: 172px !important;
    background: rgba(8, 8, 12, 0.86) !important;
    border: 1px solid rgba(255, 255, 255, 0.085) !important;
    transition: transform 0.18s ease, border-color 0.18s ease, background 0.18s ease !important;
}

.nv-asset-detail-related-card:hover {
    transform: translateY(-2px) !important;
    border-color: rgba(255, 26, 26, 0.42) !important;
    background: rgba(16, 16, 22, 0.94) !important;
}

.nv-asset-detail-related-card img,
.nv-asset-detail-related-card > span {
    aspect-ratio: 16 / 8.7 !important;
}

.nv-asset-detail-related-card strong {
    padding: 10px 10px 2px !important;
    font-size: 13px !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 2 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
}

.nv-asset-detail-related-card small {
    padding: 0 10px 10px !important;
    font-size: 11px !important;
}

.nv-asset-detail-related-empty {
    display: grid !important;
    gap: 4px !important;
    padding: 16px !important;
    background: rgba(255,255,255,0.035) !important;
    border: 1px solid rgba(255,255,255,0.08) !important;
}

.nv-asset-detail-related-empty strong {
    color: #fff !important;
    font-family: Arial, Helvetica, sans-serif !important;
    font-size: 16px !important;
    font-weight: 900 !important;
}

.nv-asset-detail-related-empty span {
    color: rgba(255,255,255,0.58) !important;
    font-family: "Courier New", monospace !important;
    font-size: 12px !important;
    font-weight: 700 !important;
}

.nv-asset-detail-related-cta,
.nv-asset-detail-nav > a {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 10px !important;
    min-height: 42px !important;
    margin-top: 14px !important;
    padding: 0 18px !important;
    color: #fff !important;
    text-decoration: none !important;
    font-family: Arial, Helvetica, sans-serif !important;
    font-size: 12px !important;
    font-weight: 950 !important;
    letter-spacing: 0.02em !important;
    background: rgba(255,255,255,0.035) !important;
    border: 1px solid rgba(255,255,255,0.10) !important;
}

.nv-asset-detail-related-cta:hover,
.nv-asset-detail-nav > a:hover {
    color: #ff1a1a !important;
    border-color: rgba(255,26,26,0.42) !important;
}

.nv-asset-detail-related-cta em {
    color: #ff1a1a !important;
    font-style: normal !important;
}

.nv-asset-detail-nav {
    margin-top: 18px !important;
    gap: 10px !important;
}

.nv-asset-detail-nav a {
    min-height: 46px !important;
}

@media (max-width: 1180px) {
    .nv-asset-detail-accordion-stack,
    .nv-asset-detail-compact-accordion .nv-asset-detail-lines,
    .nv-asset-detail-compact-accordion .nv-asset-detail-spec-grid {
        grid-template-columns: 1fr !important;
    }

    .nv-asset-detail-related-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }
}

@media (max-width: 720px) {
    .nv-asset-detail-related-grid {
        grid-template-columns: 1fr !important;
    }
}

/* =========================================================
   v1.1.13 - asset details header fix and quick view footer actions
   ========================================================= */
.nv-asset-detail-deep-dive {
    clear: both;
    position: relative;
    z-index: 1;
    overflow: visible;
}

.nv-asset-detail-deep-dive > .nv-asset-detail-section-head {
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-start !important;
    justify-content: flex-start !important;
    gap: 8px !important;
    margin: 0 0 16px !important;
    padding: 0 !important;
    clear: both !important;
}

.nv-asset-detail-deep-dive > .nv-asset-detail-section-head h2 {
    position: static !important;
    float: none !important;
    clear: both !important;
    display: block !important;
    width: auto !important;
    max-width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    transform: none !important;
    text-align: left !important;
    white-space: normal !important;
    color: #fff !important;
    font-family: Arial, Helvetica, sans-serif !important;
    font-size: clamp(24px, 2.1vw, 34px) !important;
    font-weight: 950 !important;
    line-height: 0.98 !important;
    letter-spacing: -0.04em !important;
}

.nv-asset-detail-deep-dive > .nv-asset-detail-section-head span {
    position: static !important;
    float: none !important;
    display: block !important;
}

.nv-plugin-showcase-panel {
    grid-template-rows: minmax(0, 1fr) auto !important;
}

.nv-plugin-showcase-panel-media,
.nv-plugin-showcase-panel-content {
    grid-row: 1 !important;
    min-height: 0 !important;
}

.nv-plugin-showcase-panel-footer {
    grid-column: 1 / -1;
    grid-row: 2;
    position: relative;
    z-index: 7;
    padding: 12px clamp(18px, 2.2vw, 34px) 16px;
    background:
        linear-gradient(180deg, rgba(5, 5, 8, 0.18), rgba(5, 5, 8, 0.96)),
        rgba(7, 7, 10, 0.92);
    border-top: 1px solid rgba(255, 26, 26, 0.26);
    box-shadow: 0 -16px 36px rgba(0, 0, 0, 0.38);
}

.nv-plugin-showcase-panel-footer .nv-plugin-showcase-actions {
    width: 100%;
    max-width: 880px;
    margin: 0 auto !important;
    display: flex !important;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 10px;
}

.nv-plugin-showcase-panel-footer .nv-plugin-showcase-button {
    width: min(210px, 100%) !important;
    min-width: 150px;
    flex: 0 1 190px;
    justify-content: space-between;
}

.nv-plugin-showcase-panel-content .nv-plugin-showcase-actions {
    display: none !important;
}

@media (max-width: 1180px) {
    .nv-plugin-showcase-panel {
        grid-template-rows: auto auto auto !important;
    }

    .nv-plugin-showcase-panel-media,
    .nv-plugin-showcase-panel-content,
    .nv-plugin-showcase-panel-footer {
        grid-column: 1 / -1 !important;
        grid-row: auto !important;
    }

    .nv-plugin-showcase-panel-footer .nv-plugin-showcase-button {
        flex-basis: 170px;
    }
}

@media (max-width: 700px) {
    .nv-plugin-showcase-panel-footer .nv-plugin-showcase-actions {
        display: grid !important;
        grid-template-columns: 1fr;
    }

    .nv-plugin-showcase-panel-footer .nv-plugin-showcase-button {
        width: 100% !important;
        flex-basis: auto;
    }
}


/* =========================================================
   v1.1.14 - clean card CTAs and stable Quick View action dock
   ========================================================= */
.nv-plugin-showcase .nv-plugin-showcase-card {
    cursor: pointer !important;
}

.nv-plugin-showcase-card-controls {
    display: none !important;
}

.nv-plugin-showcase-card-content {
    padding-bottom: clamp(18px, 1.6vw, 24px) !important;
}

.nv-plugin-showcase-card h3 {
    margin-bottom: 8px !important;
}

.nv-plugin-showcase-panel {
    grid-template-rows: minmax(0, 1fr) !important;
}

.nv-plugin-showcase-panel-media {
    grid-column: 1 !important;
    grid-row: 1 !important;
    min-height: 0 !important;
}

.nv-plugin-showcase-panel-content {
    grid-column: 2 !important;
    grid-row: 1 !important;
    min-height: 0 !important;
    height: auto !important;
    max-height: none !important;
    overflow: hidden !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: stretch !important;
}

.nv-plugin-showcase-panel-scroll {
    flex: 1 1 auto;
    min-height: 0;
    overflow: auto;
    padding-right: 4px;
    scrollbar-width: thin;
    scrollbar-color: rgba(255, 26, 26, 0.42) rgba(255, 255, 255, 0.06);
}

.nv-plugin-showcase-panel-scroll::-webkit-scrollbar {
    width: 8px;
}

.nv-plugin-showcase-panel-scroll::-webkit-scrollbar-track {
    background: rgba(255, 255, 255, 0.04);
}

.nv-plugin-showcase-panel-scroll::-webkit-scrollbar-thumb {
    background: rgba(255, 26, 26, 0.42);
}

.nv-plugin-showcase-panel-content > .nv-plugin-showcase-panel-footer {
    grid-column: auto !important;
    grid-row: auto !important;
    position: relative !important;
    z-index: 8 !important;
    flex: 0 0 auto !important;
    margin: clamp(16px, 2vh, 26px) 0 0 !important;
    padding: clamp(14px, 1.5vh, 20px) 0 0 !important;
    background:
        linear-gradient(180deg, rgba(20, 4, 6, 0), rgba(20, 4, 6, 0.92) 48%, rgba(10, 6, 8, 0.98)),
        transparent !important;
    border-top: 1px solid rgba(255, 26, 26, 0.22) !important;
    box-shadow: none !important;
}

.nv-plugin-showcase-panel-content > .nv-plugin-showcase-panel-footer .nv-plugin-showcase-actions {
    width: min(100%, 700px) !important;
    max-width: 700px !important;
    margin: 0 auto !important;
    display: flex !important;
    flex-wrap: wrap !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 10px !important;
}

.nv-plugin-showcase-panel-content > .nv-plugin-showcase-panel-footer .nv-plugin-showcase-button {
    flex: 0 1 204px !important;
    width: 204px !important;
    min-width: 0 !important;
    min-height: 42px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    box-sizing: border-box !important;
}

.nv-plugin-showcase-panel-content .nv-plugin-showcase-details-content .nv-plugin-showcase-actions,
.nv-plugin-showcase-panel-content .nv-plugin-showcase-card-actions {
    display: none !important;
}

@media (max-width: 1180px) {
    .nv-plugin-showcase-panel {
        grid-template-rows: auto auto !important;
    }

    .nv-plugin-showcase-panel-media,
    .nv-plugin-showcase-panel-content {
        grid-column: 1 / -1 !important;
        grid-row: auto !important;
    }

    .nv-plugin-showcase-panel-content {
        max-height: min(62vh, 680px) !important;
    }
}

@media (max-width: 760px) {
    .nv-plugin-showcase-panel-content > .nv-plugin-showcase-panel-footer .nv-plugin-showcase-actions {
        display: grid !important;
        grid-template-columns: 1fr !important;
    }

    .nv-plugin-showcase-panel-content > .nv-plugin-showcase-panel-footer .nv-plugin-showcase-button {
        width: 100% !important;
        flex-basis: auto !important;
    }
}


/* =========================================================
   v1.1.15 - Quick View bottom action dock fix
   ========================================================= */
.nv-plugin-showcase-panel-content {
    display: grid !important;
    grid-template-rows: minmax(0, 1fr) auto !important;
    align-content: stretch !important;
    overflow: hidden !important;
}

.nv-plugin-showcase-panel-scroll {
    grid-row: 1 !important;
    min-height: 0 !important;
    max-height: none !important;
    overflow: auto !important;
}

.nv-plugin-showcase-panel-content > footer.nv-plugin-showcase-panel-footer {
    grid-row: 2 !important;
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    flex: none !important;
    position: relative !important;
    z-index: 20 !important;
    margin: clamp(14px, 1.8vh, 22px) 0 0 !important;
    padding: clamp(13px, 1.4vh, 18px) 0 0 !important;
    background:
        linear-gradient(180deg, rgba(19, 4, 7, 0), rgba(19, 4, 7, 0.72) 38%, rgba(11, 5, 7, 0.98) 100%) !important;
    border-top: 1px solid rgba(255, 26, 26, 0.24) !important;
    box-shadow: 0 -18px 34px rgba(0, 0, 0, 0.24) !important;
}

.nv-plugin-showcase-panel-content > footer.nv-plugin-showcase-panel-footer > .nv-plugin-showcase-actions,
.nv-plugin-showcase-panel-content > .nv-plugin-showcase-panel-footer > .nv-plugin-showcase-actions {
    display: flex !important;
    visibility: visible !important;
    opacity: 1 !important;
    flex-wrap: wrap !important;
    justify-content: center !important;
    align-items: center !important;
    align-content: center !important;
    gap: 10px !important;
    width: min(100%, 672px) !important;
    max-width: 672px !important;
    margin: 0 auto !important;
    padding: 0 !important;
}

.nv-plugin-showcase-panel-content > footer.nv-plugin-showcase-panel-footer > .nv-plugin-showcase-actions > .nv-plugin-showcase-button,
.nv-plugin-showcase-panel-content > .nv-plugin-showcase-panel-footer > .nv-plugin-showcase-actions > .nv-plugin-showcase-button {
    display: inline-flex !important;
    visibility: visible !important;
    opacity: 1 !important;
    flex: 0 1 204px !important;
    width: 204px !important;
    max-width: 204px !important;
    min-width: 0 !important;
    min-height: 42px !important;
    box-sizing: border-box !important;
    align-items: center !important;
    justify-content: space-between !important;
}

.nv-plugin-showcase-panel-content > footer.nv-plugin-showcase-panel-footer > .nv-plugin-showcase-actions > .nv-plugin-showcase-button:nth-last-child(1):first-child,
.nv-plugin-showcase-panel-content > .nv-plugin-showcase-panel-footer > .nv-plugin-showcase-actions > .nv-plugin-showcase-button:nth-last-child(1):first-child {
    margin-left: auto !important;
    margin-right: auto !important;
}

.nv-plugin-showcase-panel-content .nv-plugin-showcase-details-content > .nv-plugin-showcase-actions,
.nv-plugin-showcase-panel-content .nv-plugin-showcase-card-actions {
    display: none !important;
}

.nv-plugin-showcase .nv-plugin-showcase-card .nv-plugin-showcase-card-actions,
.nv-plugin-showcase .nv-plugin-showcase-card .nv-plugin-showcase-actions,
.nv-plugin-showcase .nv-plugin-showcase-card-controls {
    display: none !important;
}

@media (max-width: 760px) {
    .nv-plugin-showcase-panel-content > footer.nv-plugin-showcase-panel-footer > .nv-plugin-showcase-actions,
    .nv-plugin-showcase-panel-content > .nv-plugin-showcase-panel-footer > .nv-plugin-showcase-actions {
        display: grid !important;
        grid-template-columns: 1fr !important;
        width: 100% !important;
        max-width: none !important;
    }

    .nv-plugin-showcase-panel-content > footer.nv-plugin-showcase-panel-footer > .nv-plugin-showcase-actions > .nv-plugin-showcase-button,
    .nv-plugin-showcase-panel-content > .nv-plugin-showcase-panel-footer > .nv-plugin-showcase-actions > .nv-plugin-showcase-button {
        width: 100% !important;
        max-width: none !important;
        flex-basis: auto !important;
    }
}


/* =========================================================
   v1.1.16 - center Steam-like featured slider horizontally
   ========================================================= */
.nv-plugin-showcase-steam-featured-v2 {
    width: 100% !important;
    margin-left: auto !important;
    margin-right: auto !important;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-stage {
    width: min(1120px, 100%) !important;
    margin-left: auto !important;
    margin-right: auto !important;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-dots {
    width: min(1120px, 100%) !important;
    margin-left: auto !important;
    margin-right: auto !important;
}

/* =========================================================
   v1.1.17 - Product details fixed tabs with shared panel
   ========================================================= */
.nv-asset-detail-deep-dive .nv-asset-detail-accordion-stack[data-nv-asset-detail-tabs="1"] {
    display: block !important;
}

.nv-asset-detail-tab-row {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 10px !important;
    align-items: stretch !important;
}

.nv-asset-detail-tab-row .nv-asset-detail-tab {
    appearance: none !important;
    -webkit-appearance: none !important;
    width: 100% !important;
    min-height: 54px !important;
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) auto auto !important;
    align-items: center !important;
    gap: 10px !important;
    padding: 0 14px !important;
    margin: 0 !important;
    cursor: pointer !important;
    color: #fff !important;
    text-align: left !important;
    font-family: Arial, Helvetica, sans-serif !important;
    font-size: 17px !important;
    font-weight: 950 !important;
    line-height: 1 !important;
    letter-spacing: -0.03em !important;
    background: rgba(8, 8, 12, 0.88) !important;
    border: 1px solid rgba(255, 255, 255, 0.075) !important;
    box-shadow: none !important;
}

.nv-asset-detail-tab-row .nv-asset-detail-tab:hover,
.nv-asset-detail-tab-row .nv-asset-detail-tab:focus-visible,
.nv-asset-detail-tab-row .nv-asset-detail-tab.is-active {
    border-color: rgba(255, 26, 26, 0.36) !important;
    background:
        linear-gradient(135deg, rgba(255, 26, 26, 0.09), rgba(255, 255, 255, 0.025)),
        rgba(8, 8, 12, 0.94) !important;
}

.nv-asset-detail-tab-row .nv-asset-detail-tab span {
    min-width: 0 !important;
    overflow: hidden !important;
    white-space: nowrap !important;
    text-overflow: ellipsis !important;
}

.nv-asset-detail-tab-row .nv-asset-detail-tab small {
    color: rgba(255, 255, 255, 0.44) !important;
    font-family: "Courier New", monospace !important;
    font-size: 10px !important;
    font-weight: 800 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.06em !important;
}

.nv-asset-detail-tab-row .nv-asset-detail-tab em {
    color: #ff1a1a !important;
    font-family: "Courier New", monospace !important;
    font-size: 10px !important;
    font-style: normal !important;
    font-weight: 900 !important;
    letter-spacing: 0.08em !important;
    text-transform: uppercase !important;
}

.nv-asset-detail-tab-row .nv-asset-detail-tab.is-active em {
    color: rgba(255, 255, 255, 0.62) !important;
}

.nv-asset-detail-tab-panels {
    margin-top: 10px !important;
}

.nv-asset-detail-tab-panel[hidden] {
    display: none !important;
}

.nv-asset-detail-tab-panel.is-active {
    display: block !important;
    padding: 14px !important;
    border: 1px solid rgba(255, 26, 26, 0.26) !important;
    background:
        linear-gradient(135deg, rgba(255, 26, 26, 0.045), rgba(255, 255, 255, 0.025)),
        rgba(8, 8, 12, 0.94) !important;
}

.nv-asset-detail-tab-panel .nv-asset-detail-lines {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 8px !important;
}

.nv-asset-detail-tab-panel .nv-asset-detail-line {
    min-height: 54px !important;
    padding: 10px 12px !important;
    background: rgba(255, 255, 255, 0.032) !important;
}

.nv-asset-detail-tab-panel .nv-asset-detail-line strong {
    font-size: 12px !important;
}

.nv-asset-detail-tab-panel .nv-asset-detail-line span {
    font-size: 11px !important;
    line-height: 1.45 !important;
}

.nv-asset-detail-tab-panel .nv-asset-detail-spec-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 8px !important;
}

@media (max-width: 780px) {
    .nv-asset-detail-tab-row {
        grid-template-columns: 1fr !important;
    }

    .nv-asset-detail-tab-panel .nv-asset-detail-lines,
    .nv-asset-detail-tab-panel .nv-asset-detail-spec-grid {
        grid-template-columns: 1fr !important;
    }
}


/* =========================================================
   v1.1.18 - larger asset media thumbnails
   ========================================================= */
.nv-asset-detail-media-thumbs {
    display: grid !important;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)) !important;
    gap: 12px !important;
    margin-top: 14px !important;
    align-items: stretch !important;
    align-content: start !important;
}

.nv-asset-detail-media-thumbs button {
    width: 100% !important;
    min-height: 0 !important;
    height: auto !important;
    aspect-ratio: 16 / 9 !important;
    padding: 0 !important;
    display: block !important;
    box-sizing: border-box !important;
}

.nv-asset-detail-media-thumbs img,
.nv-asset-detail-media-thumbs span {
    display: block !important;
    width: 100% !important;
    height: 100% !important;
    min-height: 0 !important;
    object-fit: cover !important;
}

.nv-asset-detail-media-thumbs span {
    display: grid !important;
    place-items: center !important;
}

.nv-plugin-showcase-panel-media .nv-asset-detail-media-thumbs {
    grid-template-columns: repeat(auto-fit, minmax(132px, 1fr)) !important;
    gap: 10px !important;
    max-height: clamp(178px, 24vh, 260px) !important;
    overflow: auto !important;
    padding-right: 0 !important;
    scrollbar-width: none !important;
}

.nv-plugin-showcase-panel-media .nv-asset-detail-media-thumbs::-webkit-scrollbar {
    display: none !important;
}

.nv-plugin-showcase-panel-media .nv-asset-detail-media-thumbs button {
    aspect-ratio: 16 / 9 !important;
}

@media (max-width: 900px) {
    .nv-asset-detail-media-thumbs,
    .nv-plugin-showcase-panel-media .nv-asset-detail-media-thumbs {
        grid-template-columns: repeat(auto-fit, minmax(108px, 1fr)) !important;
        gap: 8px !important;
    }
}


/* =========================================================
   v1.1.19 - asset media thumbs: max two rows + horizontal rail
   ========================================================= */
.nv-asset-detail-media {
    position: relative !important;
}

.nv-asset-detail-media-thumbs {
    display: grid !important;
    grid-template-columns: none !important;
    grid-template-rows: repeat(2, minmax(0, auto)) !important;
    grid-auto-flow: column !important;
    grid-auto-columns: calc((100% - 48px) / 5) !important;
    gap: 10px 12px !important;
    margin-top: 12px !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
    overscroll-behavior-x: contain !important;
    scroll-snap-type: x proximity !important;
    scrollbar-width: none !important;
    -ms-overflow-style: none !important;
    padding: 0 !important;
    max-height: calc((((100% - 48px) / 5) * 0.5625 * 2) + 10px) !important;
}

.nv-asset-detail-media-thumbs::-webkit-scrollbar {
    display: none !important;
    width: 0 !important;
    height: 0 !important;
}

.nv-asset-detail-media-thumbs button {
    width: 100% !important;
    height: auto !important;
    min-height: 0 !important;
    aspect-ratio: 16 / 9 !important;
    scroll-snap-align: start !important;
}

.nv-asset-detail-media-thumbs img,
.nv-asset-detail-media-thumbs span {
    width: 100% !important;
    height: 100% !important;
    min-height: 0 !important;
}

.nv-asset-detail-media.has-thumb-overflow .nv-asset-detail-media-thumbs {
    padding-right: 34px !important;
}

.nv-asset-detail-thumb-scroll {
    position: absolute !important;
    z-index: 8 !important;
    bottom: 12px !important;
    width: 28px !important;
    height: 74px !important;
    display: none !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 0 !important;
    cursor: pointer !important;
    color: #fff !important;
    background: rgba(5, 8, 13, 0.78) !important;
    border: 1px solid rgba(255, 255, 255, 0.09) !important;
    font-family: Arial, Helvetica, sans-serif !important;
    font-size: 30px !important;
    font-weight: 900 !important;
    line-height: 1 !important;
    box-shadow: 0 10px 24px rgba(0, 0, 0, 0.36) !important;
}

.nv-asset-detail-media.has-thumb-overflow .nv-asset-detail-thumb-scroll {
    display: flex !important;
}

.nv-asset-detail-thumb-scroll:hover,
.nv-asset-detail-thumb-scroll:focus-visible {
    color: #ff1a1a !important;
    border-color: rgba(255, 26, 26, 0.52) !important;
    background: rgba(10, 12, 18, 0.94) !important;
}

.nv-asset-detail-thumb-scroll.is-disabled {
    opacity: 0.22 !important;
    pointer-events: none !important;
}

.nv-asset-detail-thumb-scroll-prev {
    left: 0 !important;
}

.nv-asset-detail-thumb-scroll-next {
    right: 0 !important;
}

@media (max-width: 700px) {
    .nv-asset-detail-media-thumbs {
        grid-auto-columns: calc((100% - 24px) / 3) !important;
        max-height: calc((((100% - 24px) / 3) * 0.5625 * 2) + 10px) !important;
    }
}


/* =========================================================
   v1.1.20 - hard center Steam-like featured carousel
   ========================================================= */
.nv-plugin-showcase-steam-featured-v2 {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: flex-start !important;
    width: 100% !important;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-stage {
    position: relative !important;
    left: 50% !important;
    transform: translateX(-50%) !important;
    width: min(1120px, calc(100% - clamp(32px, 6vw, 96px))) !important;
    max-width: 1120px !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    align-self: auto !important;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-dots {
    position: relative !important;
    left: 50% !important;
    transform: translateX(-50%) !important;
    width: min(1120px, calc(100% - clamp(32px, 6vw, 96px))) !important;
    max-width: 1120px !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    justify-content: center !important;
}

@media (max-width: 700px) {
    .nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-stage,
    .nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-dots {
        width: 100% !important;
        left: auto !important;
        transform: none !important;
    }
}


/* =========================================================
   v1.1.21 - rollback hard-left transform and center by margins
   ========================================================= */
.nv-plugin-showcase-steam-featured-v2 {
    width: 100% !important;
    display: block !important;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-stage {
    left: auto !important;
    right: auto !important;
    transform: none !important;
    width: calc(100% - clamp(32px, 6vw, 96px)) !important;
    max-width: 1120px !important;
    margin-left: auto !important;
    margin-right: auto !important;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-dots {
    left: auto !important;
    right: auto !important;
    transform: none !important;
    width: calc(100% - clamp(32px, 6vw, 96px)) !important;
    max-width: 1120px !important;
    margin-left: auto !important;
    margin-right: auto !important;
    justify-content: center !important;
}

@media (max-width: 700px) {
    .nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-stage,
    .nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-dots {
        width: 100% !important;
        max-width: 100% !important;
    }
}


/* =========================================================
   v1.1.23 - prevent featured title clipping in Steam slider
   ========================================================= */
.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-copy h2 {
    line-height: 1.16 !important;
    padding-bottom: 0.16em !important;
    max-height: calc(2 * 1.16em + 0.20em) !important;
    box-sizing: content-box !important;
    overflow: hidden !important;
}

.nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-copy {
    grid-template-rows: minmax(2.7em, auto) minmax(0, 1fr) auto !important;
}

@media (max-width: 720px) {
    .nv-plugin-showcase-steam-featured-v2 .nv-plugin-showcase-steam-copy h2 {
        line-height: 1.12 !important;
        padding-bottom: 0.14em !important;
        max-height: calc(2 * 1.12em + 0.18em) !important;
    }
}

/* NordVader Asset Signal - v1.1.31 */
.nv-ui-icon {
    width: 22px;
    height: 22px;
    display: inline-block;
    fill: none;
    stroke: currentColor;
    stroke-width: 1.85;
    stroke-linecap: round;
    stroke-linejoin: round;
    vector-effect: non-scaling-stroke;
}

.nv-asset-signal {
    --nv-signal-border: rgba(255, 26, 26, 0.20);
    --nv-signal-bg: rgba(255,255,255,0.035);
    --nv-signal-text: rgba(255,255,255,0.86);
    --nv-signal-muted: rgba(255,255,255,0.56);
    --nv-signal-hot: #ff1a1a;
    --nv-signal-good: #35e46f;
    color: var(--nv-signal-text);
    font-family: Arial, Helvetica, sans-serif;
}

.nv-asset-signal-title {
    margin: 0 0 12px;
    color: var(--nv-signal-hot);
    font-size: 11px;
    font-weight: 950;
    line-height: 1;
    letter-spacing: 0.22em;
    text-transform: uppercase;
}

.nv-asset-signal-grid {
    display: grid;
    gap: 8px;
}

.nv-asset-signal-metric {
    min-width: 0;
    display: flex;
    align-items: center;
    gap: 12px;
    background: var(--nv-signal-bg);
    border: 1px solid rgba(255,255,255,0.08);
    transition: border-color .18s ease, background .18s ease, transform .18s ease;
}

.nv-asset-signal-metric:hover {
    border-color: rgba(255, 26, 26, 0.42);
    background: rgba(255, 26, 26, 0.07);
}

.nv-asset-signal-icon {
    flex: 0 0 auto;
    display: grid;
    place-items: center;
    color: rgba(255,255,255,0.82);
}

.nv-asset-signal-metric--downloads .nv-asset-signal-icon,
.nv-asset-signal-metric--wishlists .nv-asset-signal-icon,
.nv-asset-signal-metric--trending .nv-asset-signal-icon { color: #ff1a1a; }
.nv-asset-signal-metric--rating .nv-asset-signal-icon { color: #fff; }

.nv-asset-signal-copy {
    min-width: 0;
    display: grid;
    gap: 2px;
}

.nv-asset-signal-copy small {
    color: var(--nv-signal-muted);
    font-size: 11px;
    font-weight: 850;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.nv-asset-signal-copy strong {
    color: #fff;
    font-size: 24px;
    font-weight: 950;
    line-height: 1;
    letter-spacing: -0.035em;
}

.nv-asset-signal-copy em {
    color: var(--nv-signal-muted);
    font-family: "Courier New", monospace;
    font-size: 12px;
    font-style: normal;
    line-height: 1.15;
}

.nv-asset-signal-copy em:first-letter { color: var(--nv-signal-good); }

.nv-asset-signal--card {
    margin: 12px 0 12px;
}

.nv-asset-signal--card .nv-asset-signal-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 6px;
}

.nv-asset-signal--card .nv-asset-signal-metric {
    min-height: 34px;
    padding: 7px 9px;
    gap: 8px;
}

.nv-asset-signal--card .nv-ui-icon {
    width: 18px;
    height: 18px;
}

.nv-asset-signal--card .nv-asset-signal-copy small,
.nv-asset-signal--card .nv-asset-signal-copy em {
    display: none;
}

.nv-asset-signal--card .nv-asset-signal-copy strong {
    font-size: 14px;
    letter-spacing: 0;
}

.nv-asset-signal--compact-inline .nv-asset-signal-metric,
.nv-asset-signal--compact-icons .nv-asset-signal-metric {
    background: rgba(255,255,255,0.022);
}

.nv-asset-signal--bottom-bar .nv-asset-signal-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.nv-asset-signal--bottom-bar .nv-asset-signal-metric {
    border-color: rgba(255,255,255,0.07);
    border-top-color: rgba(255,26,26,0.22);
}

.nv-asset-signal--hero {
    width: min(100%, 360px);
    margin-top: 22px;
}

.nv-asset-signal--hero .nv-asset-signal-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.nv-asset-signal--hero .nv-asset-signal-metric {
    min-height: 54px;
    padding: 10px 14px;
    background: rgba(9, 10, 14, 0.78);
    border-color: rgba(255,255,255,0.10);
    box-shadow: inset 0 0 0 1px rgba(255,26,26,0.06), 0 18px 45px rgba(0,0,0,0.25);
}

.nv-asset-signal--hero .nv-asset-signal-copy strong {
    font-size: 20px;
}

.nv-asset-signal--hero .nv-asset-signal-copy em {
    display: none;
}

.nv-asset-signal--boxed-mini .nv-asset-signal-metric,
.nv-asset-signal--split-cards .nv-asset-signal-metric {
    border-color: rgba(255, 26, 26, 0.25);
}

.nv-asset-signal--sidebar {
    margin: 18px 0;
    padding: 18px;
    border: 1px solid rgba(255, 26, 26, 0.18);
    background: rgba(255, 26, 26, 0.025);
}

.nv-asset-signal--sidebar .nv-asset-signal-metric {
    min-height: 44px;
    padding: 10px 12px;
}

.nv-asset-signal--sidebar .nv-asset-signal-copy {
    grid-template-columns: minmax(0, 1fr) auto;
    width: 100%;
    align-items: center;
}

.nv-asset-signal--sidebar .nv-asset-signal-copy small {
    grid-column: 2;
    grid-row: 1 / span 2;
    align-self: center;
    text-align: right;
}

.nv-asset-signal--sidebar .nv-asset-signal-copy strong {
    grid-column: 1;
    font-size: 18px;
}

.nv-asset-signal--sidebar .nv-asset-signal-copy em {
    grid-column: 1;
}

.nv-asset-signal--content {
    margin: 22px 0 28px;
    padding: 22px 24px;
    border: 1px solid rgba(255, 26, 26, 0.22);
    background:
        linear-gradient(135deg, rgba(255, 26, 26, 0.06), rgba(255,255,255,0.018)),
        rgba(10,10,13,0.68);
}

.nv-asset-signal--content .nv-asset-signal-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 18px;
}

.nv-asset-signal--cards-4up .nv-asset-signal-grid,
.nv-asset-signal--detailed-strip .nv-asset-signal-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.nv-asset-signal--content .nv-asset-signal-metric {
    min-height: 78px;
    padding: 14px 18px;
    background: rgba(255,255,255,0.026);
}

.nv-asset-signal--panel {
    margin: 16px 0;
    padding: 16px;
    background: rgba(255,255,255,0.035);
    border: 1px solid rgba(255, 26, 26, 0.18);
}

.nv-asset-signal--panel .nv-asset-signal-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.nv-asset-signal--panel .nv-asset-signal-metric {
    padding: 10px;
}

.nv-asset-signal--panel .nv-asset-signal-copy strong {
    font-size: 18px;
}

.nv-asset-detail-button .nv-ui-icon,
.nv-plugin-showcase-button .nv-ui-icon,
.nv-plugin-showcase-mini-button .nv-ui-icon {
    width: 18px;
    height: 18px;
    margin-right: 8px;
}

@media (max-width: 860px) {
    .nv-asset-signal--content .nv-asset-signal-grid,
    .nv-asset-signal--cards-4up .nv-asset-signal-grid,
    .nv-asset-signal--detailed-strip .nv-asset-signal-grid {
        grid-template-columns: 1fr;
    }
    .nv-asset-signal--hero {
        width: 100%;
    }
}

/* =========================================================
   v1.1.33 - concept-matched Asset Signal and featured slider variants
   ========================================================= */
.nv-plugin-showcase-steam-featured--classic .nv-asset-signal--featured,
.nv-plugin-showcase-steam-featured--classic .nv-plugin-showcase-steam-proof {
    display: none !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-stage {
    border-color: rgba(255, 26, 26, 0.34) !important;
    background:
        radial-gradient(circle at 70% 20%, rgba(255, 26, 26, 0.08), transparent 30%),
        linear-gradient(90deg, rgba(6, 7, 11, 0.98) 0%, rgba(7, 10, 16, 0.98) 64%, rgba(12, 17, 25, 0.98) 100%) !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-link {
    grid-template-columns: minmax(0, 64%) minmax(295px, 36%) !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-copy {
    padding: 22px 26px 18px !important;
    display: grid !important;
    grid-template-rows: auto auto minmax(0, 1fr) auto !important;
    gap: 14px !important;
    background:
        linear-gradient(180deg, rgba(15, 24, 35, 0.96), rgba(8, 12, 18, 0.98)),
        radial-gradient(circle at 0% 50%, rgba(56, 170, 255, 0.08), transparent 42%) !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-copy h2 {
    color: rgba(255, 255, 255, 0.91) !important;
    font-size: clamp(24px, 2.0vw, 32px) !important;
    line-height: 1.04 !important;
    letter-spacing: -0.035em !important;
    text-shadow: 0 14px 28px rgba(0, 0, 0, 0.44) !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-thumbs {
    display: none !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-footer {
    align-self: end !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-readmore {
    color: #ff3232 !important;
    font-size: 11px !important;
    font-weight: 950 !important;
    letter-spacing: 0.18em !important;
    text-transform: uppercase !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-nav {
    background: rgba(10, 15, 23, 0.78) !important;
    border-color: rgba(255, 255, 255, 0.06) !important;
    color: rgba(255, 255, 255, 0.92) !important;
}

.nv-asset-signal--featured {
    margin: 2px 0 0 !important;
    width: 100% !important;
}

.nv-asset-signal--featured .nv-asset-signal-title {
    margin-bottom: 9px !important;
    color: #ff3232 !important;
    font-size: 10px !important;
    letter-spacing: 0.22em !important;
}

.nv-asset-signal--featured .nv-asset-signal-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 10px !important;
}

.nv-asset-signal--featured .nv-asset-signal-metric {
    min-height: 60px !important;
    padding: 12px 14px !important;
    display: grid !important;
    grid-template-columns: 24px minmax(0, 1fr) !important;
    gap: 10px !important;
    background: rgba(255, 255, 255, 0.032) !important;
    border: 1px solid rgba(255, 255, 255, 0.055) !important;
    box-shadow: inset 0 -2px 0 rgba(255, 26, 26, 0.28) !important;
}

.nv-asset-signal--featured .nv-asset-signal-icon {
    color: #ff3232 !important;
    align-self: center !important;
}

.nv-asset-signal--featured .nv-ui-icon {
    width: 23px !important;
    height: 23px !important;
    stroke-width: 1.9 !important;
}

.nv-asset-signal--featured .nv-asset-signal-copy {
    gap: 1px !important;
}

.nv-asset-signal--featured .nv-asset-signal-copy small {
    order: 2 !important;
    color: rgba(255,255,255,0.55) !important;
    font-size: 10px !important;
    letter-spacing: 0.10em !important;
}

.nv-asset-signal--featured .nv-asset-signal-copy strong {
    order: 1 !important;
    color: rgba(255,255,255,0.92) !important;
    font-size: 22px !important;
    font-weight: 900 !important;
    letter-spacing: -0.04em !important;
}

.nv-asset-signal--featured .nv-asset-signal-copy em {
    display: none !important;
}

.nv-plugin-showcase-steam-proof {
    display: grid;
    gap: 13px;
    align-content: start;
    margin-top: 2px;
}

.nv-plugin-showcase-steam-proof-item {
    display: grid;
    grid-template-columns: 30px minmax(0, 1fr);
    grid-template-rows: auto auto;
    column-gap: 13px;
    align-items: center;
    color: rgba(255,255,255,0.78);
}

.nv-plugin-showcase-steam-proof-item > span {
    grid-row: 1 / span 2;
    display: grid;
    place-items: center;
    color: rgba(255,255,255,0.56);
}

.nv-plugin-showcase-steam-proof-item .nv-ui-icon {
    width: 24px;
    height: 24px;
    stroke-width: 1.55;
}

.nv-plugin-showcase-steam-proof-item strong {
    color: rgba(255,255,255,0.86);
    font-size: 13px;
    font-weight: 850;
    letter-spacing: 0.01em;
    line-height: 1.1;
}

.nv-plugin-showcase-steam-proof-item small {
    color: rgba(255,255,255,0.50);
    font-size: 11px;
    line-height: 1.25;
}

/* Make catalog-card metrics closer to the generated concept: subtle dark cells, no loud bars. */
.nv-plugin-showcase-card .nv-asset-signal--card {
    margin: 13px 0 10px !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 6px !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-metric {
    min-height: 36px !important;
    padding: 8px 10px !important;
    background: rgba(255, 255, 255, 0.020) !important;
    border: 1px solid rgba(255, 255, 255, 0.055) !important;
    box-shadow: inset 0 -1px 0 rgba(255, 26, 26, 0.16) !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-icon {
    color: rgba(255, 45, 45, 0.88) !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-copy strong {
    color: rgba(255,255,255,0.84) !important;
    font-size: 14px !important;
    font-weight: 850 !important;
}

.nv-plugin-showcase-card .nv-asset-signal--bottom-bar .nv-asset-signal-metric {
    box-shadow: inset 0 -2px 0 rgba(255, 26, 26, 0.22) !important;
}

@media (max-width: 1120px) {
    .nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-link {
        grid-template-columns: 1fr !important;
    }
    .nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-thumbs {
        display: grid !important;
    }
}


/* =========================================================
   v1.1.34 - tighter concept match for Signal Panel slider
   ========================================================= */
.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-stage {
    min-height: 314px !important;
    overflow: hidden !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-link {
    grid-template-columns: minmax(0, 63.5%) minmax(318px, 36.5%) !important;
    min-height: 314px !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-media-wrap {
    min-height: 314px !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-copy {
    min-width: 0 !important;
    padding: 24px 31px 20px !important;
    display: grid !important;
    grid-template-rows: auto auto minmax(0, 1fr) auto !important;
    gap: 18px !important;
    align-content: stretch !important;
    overflow: hidden !important;
    background:
        linear-gradient(180deg, rgba(16, 25, 37, 0.98), rgba(8, 12, 18, 0.985)),
        radial-gradient(circle at 0% 50%, rgba(49, 166, 255, 0.075), transparent 46%) !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-copy h2 {
    min-width: 0 !important;
    max-width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    color: rgba(255, 255, 255, 0.92) !important;
    font-size: clamp(24px, 1.55vw, 31px) !important;
    line-height: 1.02 !important;
    letter-spacing: -0.045em !important;
    font-weight: 900 !important;
    text-transform: none !important;
    overflow: hidden !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 2 !important;
    -webkit-box-orient: vertical !important;
    text-shadow: 0 12px 24px rgba(0, 0, 0, 0.48) !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured {
    align-self: start !important;
    margin: 0 !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-title {
    margin: 0 0 10px !important;
    color: #ff3030 !important;
    font-size: 9px !important;
    line-height: 1 !important;
    font-weight: 950 !important;
    letter-spacing: 0.24em !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 9px !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-metric {
    min-height: 55px !important;
    padding: 10px 12px !important;
    display: grid !important;
    grid-template-columns: 22px minmax(0, 1fr) !important;
    align-items: center !important;
    gap: 9px !important;
    background: rgba(255, 255, 255, 0.028) !important;
    border: 1px solid rgba(255, 255, 255, 0.045) !important;
    box-shadow: inset 0 -2px 0 rgba(255, 26, 26, 0.24) !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-icon {
    align-self: center !important;
    justify-self: center !important;
    color: #ff3030 !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-ui-icon {
    width: 21px !important;
    height: 21px !important;
    stroke-width: 1.7 !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-copy {
    min-width: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 2px !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-copy strong {
    order: 1 !important;
    font-size: 20px !important;
    line-height: 0.95 !important;
    font-weight: 850 !important;
    letter-spacing: -0.035em !important;
    color: rgba(255,255,255,0.90) !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-copy small {
    order: 2 !important;
    font-size: 9px !important;
    line-height: 1 !important;
    font-weight: 900 !important;
    letter-spacing: 0.13em !important;
    color: rgba(255,255,255,0.52) !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-proof {
    margin: 0 !important;
    gap: 12px !important;
    align-self: start !important;
    overflow: hidden !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-proof-item {
    grid-template-columns: 26px minmax(0, 1fr) !important;
    column-gap: 12px !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-proof-item .nv-ui-icon {
    width: 22px !important;
    height: 22px !important;
    stroke-width: 1.45 !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-proof-item strong {
    font-size: 12px !important;
    line-height: 1.05 !important;
    font-weight: 850 !important;
    color: rgba(255,255,255,0.86) !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-proof-item small {
    font-size: 10px !important;
    line-height: 1.15 !important;
    color: rgba(255,255,255,0.47) !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-footer {
    margin: 0 !important;
    align-self: end !important;
    justify-self: end !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-readmore {
    padding: 0 !important;
    color: #ff3030 !important;
    font-size: 10px !important;
    line-height: 1 !important;
    font-weight: 950 !important;
    letter-spacing: 0.19em !important;
    text-transform: uppercase !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-nav.is-next {
    right: 0 !important;
    transform: translateY(-50%) !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-nav.is-prev {
    left: 0 !important;
    transform: translateY(-50%) !important;
}

/* Catalog cards: keep the generated concept proportions and prevent the zero rows from eating the card. */
.nv-plugin-showcase-card .nv-asset-signal--card {
    margin: 9px 0 8px !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-metric {
    min-height: 31px !important;
    padding: 6px 8px !important;
    gap: 7px !important;
    background: rgba(255, 255, 255, 0.018) !important;
    border-color: rgba(255, 255, 255, 0.05) !important;
    box-shadow: none !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-ui-icon {
    width: 15px !important;
    height: 15px !important;
    stroke-width: 1.6 !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-copy strong {
    font-size: 12px !important;
    line-height: 1 !important;
    font-weight: 850 !important;
}

@media (max-width: 1120px) {
    .nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-link {
        grid-template-columns: 1fr !important;
    }
    .nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-copy h2 {
        -webkit-line-clamp: 3 !important;
    }
}


/* =========================================================
   v1.1.35 - Signal Panel slider hard override: concept-accurate right rail
   Fixes older Steam slider absolute-position rules that pushed metrics under the title.
   ========================================================= */
.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-stage {
    min-height: 0 !important;
    height: auto !important;
    aspect-ratio: 940 / 353 !important;
    max-height: 430px !important;
    border-color: rgba(255, 26, 26, 0.38) !important;
    background:
        radial-gradient(circle at 68% 28%, rgba(69, 129, 180, 0.08), transparent 30%),
        linear-gradient(90deg, rgba(5, 6, 10, 0.99) 0%, rgba(6, 8, 13, 0.99) 63%, rgba(12, 18, 27, 0.99) 100%) !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-link {
    display: grid !important;
    grid-template-columns: minmax(0, 64%) minmax(304px, 36%) !important;
    height: 100% !important;
    min-height: 0 !important;
    align-items: stretch !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-media-wrap {
    min-height: 0 !important;
    height: 100% !important;
    padding: 0 !important;
    background: #03060b !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-copy {
    position: relative !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: flex-start !important;
    align-items: stretch !important;
    height: 100% !important;
    min-height: 0 !important;
    padding: clamp(18px, 1.6vw, 24px) clamp(20px, 2.1vw, 30px) clamp(16px, 1.5vw, 22px) clamp(18px, 1.8vw, 26px) !important;
    gap: clamp(10px, 1vw, 15px) !important;
    overflow: hidden !important;
    background:
        linear-gradient(180deg, rgba(15, 23, 34, 0.98), rgba(8, 13, 20, 0.995)),
        radial-gradient(circle at 0% 52%, rgba(74, 157, 220, 0.08), transparent 44%) !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-copy h2 {
    position: static !important;
    z-index: auto !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 2 !important;
    -webkit-box-orient: vertical !important;
    width: 100% !important;
    min-width: 0 !important;
    min-height: 0 !important;
    max-height: calc(2 * 1.06em) !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: hidden !important;
    white-space: normal !important;
    text-overflow: ellipsis !important;
    color: rgba(246, 249, 252, 0.94) !important;
    font-family: Arial, Helvetica, sans-serif !important;
    font-size: clamp(20px, 1.52vw, 28px) !important;
    font-weight: 500 !important;
    line-height: 1.06 !important;
    letter-spacing: -0.04em !important;
    text-transform: none !important;
    text-shadow: 0 10px 26px rgba(0, 0, 0, 0.48) !important;
    box-sizing: border-box !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured {
    position: static !important;
    z-index: auto !important;
    flex: 0 0 auto !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-title {
    margin: 0 0 8px !important;
    color: #ff3030 !important;
    font-size: 9px !important;
    font-weight: 950 !important;
    line-height: 1 !important;
    letter-spacing: 0.23em !important;
    text-transform: uppercase !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-grid {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 8px !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-metric {
    min-height: 45px !important;
    padding: 8px 10px !important;
    display: grid !important;
    grid-template-columns: 20px minmax(0, 1fr) !important;
    gap: 8px !important;
    align-items: center !important;
    background: rgba(255, 255, 255, 0.026) !important;
    border: 1px solid rgba(255, 255, 255, 0.048) !important;
    box-shadow: inset 0 -1px 0 rgba(255, 26, 26, 0.30) !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-icon {
    display: grid !important;
    place-items: center !important;
    color: #ff3030 !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-ui-icon {
    width: 18px !important;
    height: 18px !important;
    stroke-width: 1.75 !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-copy {
    display: flex !important;
    flex-direction: column !important;
    gap: 2px !important;
    min-width: 0 !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-copy strong {
    order: 1 !important;
    color: rgba(255, 255, 255, 0.91) !important;
    font-size: clamp(15px, 1.05vw, 20px) !important;
    font-weight: 650 !important;
    line-height: 0.96 !important;
    letter-spacing: -0.025em !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-copy small {
    order: 2 !important;
    display: block !important;
    color: rgba(255, 255, 255, 0.50) !important;
    font-size: 8px !important;
    font-weight: 900 !important;
    line-height: 1 !important;
    letter-spacing: 0.13em !important;
    text-transform: uppercase !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-copy em {
    display: none !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-proof {
    position: static !important;
    flex: 1 1 auto !important;
    min-height: 0 !important;
    display: grid !important;
    align-content: start !important;
    gap: clamp(8px, 0.85vw, 12px) !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: hidden !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-proof-item {
    display: grid !important;
    grid-template-columns: 24px minmax(0, 1fr) !important;
    grid-template-rows: auto auto !important;
    column-gap: 11px !important;
    align-items: center !important;
    min-height: 31px !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-proof-item > span {
    grid-row: 1 / span 2 !important;
    display: grid !important;
    place-items: center !important;
    color: rgba(255, 255, 255, 0.50) !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-proof-item .nv-ui-icon {
    width: 20px !important;
    height: 20px !important;
    stroke-width: 1.45 !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-proof-item strong {
    color: rgba(255, 255, 255, 0.84) !important;
    font-size: clamp(10px, 0.82vw, 12px) !important;
    font-weight: 850 !important;
    line-height: 1.05 !important;
    letter-spacing: 0 !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-proof-item small {
    color: rgba(255, 255, 255, 0.46) !important;
    font-size: clamp(8px, 0.7vw, 10px) !important;
    line-height: 1.12 !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-thumbs {
    display: none !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-footer {
    position: static !important;
    z-index: auto !important;
    flex: 0 0 auto !important;
    width: 100% !important;
    min-height: 0 !important;
    height: auto !important;
    margin: 0 !important;
    padding: 0 !important;
    display: flex !important;
    align-items: flex-end !important;
    justify-content: flex-end !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-readmore {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: flex-end !important;
    gap: 7px !important;
    margin: 0 !important;
    padding: 0 !important;
    color: #ff3030 !important;
    font-size: 10px !important;
    font-weight: 950 !important;
    line-height: 1 !important;
    letter-spacing: 0.18em !important;
    text-transform: uppercase !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-nav.is-next {
    right: 0 !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-nav.is-prev {
    left: 0 !important;
}

/* Catalog metrics like the generated reference: compact dark cells, no oversized rows. */
.nv-plugin-showcase-card .nv-asset-signal--card {
    margin: 10px 0 8px !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 5px !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-metric {
    min-height: 28px !important;
    padding: 5px 8px !important;
    gap: 7px !important;
    background: rgba(255, 255, 255, 0.018) !important;
    border: 1px solid rgba(255, 255, 255, 0.045) !important;
    box-shadow: none !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-ui-icon {
    width: 14px !important;
    height: 14px !important;
    stroke-width: 1.65 !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-copy strong {
    color: rgba(255, 255, 255, 0.78) !important;
    font-size: 12px !important;
    font-weight: 800 !important;
    line-height: 1 !important;
    letter-spacing: 0 !important;
}

@media (max-width: 1120px) {
    .nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-stage {
        aspect-ratio: auto !important;
        max-height: none !important;
    }

    .nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-link {
        grid-template-columns: 1fr !important;
        height: auto !important;
    }

    .nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-copy h2 {
        max-height: none !important;
        -webkit-line-clamp: 3 !important;
    }

    .nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-thumbs {
        display: grid !important;
        position: static !important;
        transform: none !important;
    }
}

/* =========================================================
   v1.1.36 - Concept-match pass for Featured Signal Panel.
   Brings the right rail closer to the generated reference:
   larger ghost-gray proof icons, stronger typography, cleaner spacing,
   compact market cells with red icons and green underline accents.
   ========================================================= */
.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-copy {
    padding: clamp(22px, 2vw, 30px) clamp(30px, 2.7vw, 42px) clamp(18px, 1.8vw, 26px) clamp(26px, 2.4vw, 38px) !important;
    gap: clamp(13px, 1.2vw, 18px) !important;
    background:
        radial-gradient(circle at 0% 45%, rgba(76, 150, 210, 0.055), transparent 42%),
        linear-gradient(180deg, rgba(15, 24, 35, 0.985), rgba(8, 13, 20, 0.995)) !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-copy h2 {
    max-width: 96% !important;
    max-height: calc(2 * 1.12em) !important;
    color: rgba(245, 248, 252, 0.92) !important;
    font-size: clamp(22px, 1.75vw, 31px) !important;
    font-weight: 460 !important;
    line-height: 1.12 !important;
    letter-spacing: -0.045em !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-title {
    margin: 0 0 9px !important;
    color: #ff3030 !important;
    font-size: 9px !important;
    font-weight: 950 !important;
    line-height: 1 !important;
    letter-spacing: 0.25em !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-grid {
    gap: 9px !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-metric {
    position: relative !important;
    min-height: 51px !important;
    padding: 8px 12px 9px 12px !important;
    grid-template-columns: 26px minmax(0, 1fr) !important;
    gap: 10px !important;
    align-items: center !important;
    background: rgba(255, 255, 255, 0.028) !important;
    border: 1px solid rgba(255, 255, 255, 0.052) !important;
    box-shadow: none !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-metric::after {
    content: "" !important;
    position: absolute !important;
    left: 12px !important;
    right: auto !important;
    bottom: 0 !important;
    width: 42% !important;
    height: 2px !important;
    background: #1fd46a !important;
    box-shadow: 0 0 10px rgba(31, 212, 106, 0.35) !important;
    opacity: 0.9 !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-icon {
    align-self: center !important;
    color: #ff3030 !important;
    opacity: 0.96 !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-ui-icon {
    width: 22px !important;
    height: 22px !important;
    stroke-width: 1.65 !important;
    filter: drop-shadow(0 0 8px rgba(255, 35, 35, 0.16)) !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-copy {
    gap: 3px !important;
    justify-content: center !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-copy strong {
    color: rgba(248, 250, 252, 0.94) !important;
    font-size: clamp(17px, 1.18vw, 22px) !important;
    font-weight: 520 !important;
    line-height: 0.98 !important;
    letter-spacing: -0.02em !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-copy small {
    color: rgba(255, 255, 255, 0.56) !important;
    font-size: 8px !important;
    font-weight: 950 !important;
    line-height: 1 !important;
    letter-spacing: 0.15em !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-proof {
    gap: clamp(12px, 1vw, 16px) !important;
    margin-top: 2px !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-proof-item {
    grid-template-columns: 32px minmax(0, 1fr) !important;
    column-gap: 13px !important;
    min-height: 39px !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-proof-item > span {
    width: 32px !important;
    height: 32px !important;
    color: rgba(205, 214, 222, 0.46) !important;
    opacity: 1 !important;
    filter: drop-shadow(0 0 12px rgba(190, 210, 230, 0.055)) !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-proof-item .nv-ui-icon {
    width: 25px !important;
    height: 25px !important;
    stroke-width: 1.38 !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-proof-item strong {
    color: rgba(244, 247, 250, 0.82) !important;
    font-size: clamp(11px, 0.94vw, 14px) !important;
    font-weight: 820 !important;
    line-height: 1.06 !important;
    letter-spacing: -0.01em !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-proof-item small {
    color: rgba(244, 247, 250, 0.48) !important;
    font-size: clamp(9px, 0.72vw, 11px) !important;
    font-weight: 520 !important;
    line-height: 1.12 !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-footer {
    padding-right: 2px !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-readmore {
    font-size: 10px !important;
    letter-spacing: 0.19em !important;
}

/* Card metric refinements: closer to the mockup - compact, readable, with a small green accent line. */
.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-metric {
    position: relative !important;
    min-height: 30px !important;
    padding: 6px 9px !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-metric::after {
    content: "" !important;
    position: absolute !important;
    left: 8px !important;
    bottom: 0 !important;
    width: 46% !important;
    height: 2px !important;
    background: #1fd46a !important;
    opacity: 0.85 !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-ui-icon {
    width: 13px !important;
    height: 13px !important;
    color: #ff3030 !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-copy strong {
    color: rgba(255, 255, 255, 0.82) !important;
    font-size: 12px !important;
    font-weight: 780 !important;
}

/* =========================================================
   v1.1.37 - Featured signal panel polish
   Higher fidelity to the approved NordVader reference.
   ========================================================= */
.nv-ui-icon .nv-ui-icon-tone {
    stroke: rgba(214, 221, 230, 0.62);
    fill: none;
}

.nv-ui-icon .nv-ui-icon-accent {
    stroke: #ff3b39;
    fill: none;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-stage {
    aspect-ratio: 940 / 346 !important;
    max-height: 418px !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-link {
    grid-template-columns: minmax(0, 67%) minmax(292px, 33%) !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-copy {
    padding: clamp(14px, 1.35vw, 18px) clamp(22px, 2vw, 30px) clamp(14px, 1.2vw, 18px) clamp(20px, 1.8vw, 28px) !important;
    gap: 12px !important;
    background:
        radial-gradient(circle at 0% 44%, rgba(52, 122, 175, 0.08), transparent 42%),
        linear-gradient(180deg, rgba(15, 23, 34, 0.985), rgba(8, 13, 20, 0.995)) !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-copy h2 {
    max-width: 100% !important;
    max-height: calc(2 * 1.08em) !important;
    margin: 0 0 2px !important;
    color: rgba(245, 248, 252, 0.93) !important;
    font-family: Arial, Helvetica, sans-serif !important;
    font-size: clamp(18px, 1.34vw, 24px) !important;
    font-weight: 520 !important;
    line-height: 1.08 !important;
    letter-spacing: -0.048em !important;
    text-wrap: balance !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured {
    margin-top: 2px !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-title {
    margin: 0 0 10px !important;
    font-size: 9px !important;
    font-weight: 950 !important;
    letter-spacing: 0.24em !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-grid {
    gap: 10px !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-metric {
    min-height: 54px !important;
    padding: 9px 13px 10px !important;
    grid-template-columns: 24px minmax(0, 1fr) !important;
    gap: 11px !important;
    align-items: center !important;
    background: rgba(255, 255, 255, 0.032) !important;
    border: 1px solid rgba(255, 255, 255, 0.05) !important;
    box-shadow: inset 0 -1px 0 rgba(255, 255, 255, 0.03) !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-metric::after {
    left: 14px !important;
    width: 44% !important;
    height: 2px !important;
    background: #24d36d !important;
    opacity: 0.9 !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-icon {
    color: transparent !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-ui-icon {
    width: 20px !important;
    height: 20px !important;
    stroke-width: 1.55 !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-ui-icon .nv-ui-icon-tone {
    stroke: rgba(214, 221, 230, 0.70) !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-ui-icon .nv-ui-icon-accent {
    stroke: #ff3a39 !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-copy {
    gap: 2px !important;
    align-content: center !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-copy strong {
    color: rgba(247, 249, 252, 0.95) !important;
    font-size: clamp(17px, 1.2vw, 23px) !important;
    font-weight: 620 !important;
    line-height: 0.98 !important;
    letter-spacing: -0.024em !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-copy small {
    color: rgba(255, 255, 255, 0.56) !important;
    font-size: 8px !important;
    font-weight: 950 !important;
    letter-spacing: 0.16em !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-proof {
    gap: 13px !important;
    margin-top: 2px !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-proof-item {
    grid-template-columns: 30px minmax(0, 1fr) !important;
    column-gap: 12px !important;
    min-height: 36px !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-proof-item > span {
    width: 30px !important;
    height: 30px !important;
    color: rgba(202, 210, 218, 0.46) !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-proof-item .nv-ui-icon {
    width: 22px !important;
    height: 22px !important;
    stroke-width: 1.45 !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-proof-item .nv-ui-icon .nv-ui-icon-tone {
    stroke: currentColor !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-proof-item .nv-ui-icon .nv-ui-icon-accent {
    stroke: currentColor !important;
    opacity: 0.58 !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-proof-item strong {
    color: rgba(244, 247, 250, 0.83) !important;
    font-size: clamp(11px, 0.9vw, 13px) !important;
    font-weight: 820 !important;
    line-height: 1.06 !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-proof-item small {
    color: rgba(244, 247, 250, 0.47) !important;
    font-size: clamp(9px, 0.72vw, 10px) !important;
    font-weight: 520 !important;
    line-height: 1.14 !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-footer {
    margin-top: auto !important;
    padding-top: 2px !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-readmore {
    font-size: 10px !important;
    letter-spacing: 0.18em !important;
}

/* Card signal strip closer to the reference */
.nv-plugin-showcase-card .nv-asset-signal--card {
    margin-top: 2px !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-grid {
    gap: 8px !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-metric {
    min-height: 32px !important;
    padding: 7px 10px !important;
    background: rgba(255, 255, 255, 0.02) !important;
    border: 1px solid rgba(255, 255, 255, 0.055) !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-metric::after {
    left: 9px !important;
    width: 48% !important;
    height: 2px !important;
    background: #24d36d !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-ui-icon {
    width: 14px !important;
    height: 14px !important;
    stroke-width: 1.55 !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-ui-icon .nv-ui-icon-tone {
    stroke: rgba(208, 214, 222, 0.68) !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-ui-icon .nv-ui-icon-accent {
    stroke: #ff3a39 !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-copy strong {
    font-size: 13px !important;
    font-weight: 780 !important;
    color: rgba(255,255,255,0.84) !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-copy small {
    font-size: 0 !important;
    line-height: 0 !important;
}

/* =========================================================
   v1.1.38 - Exact-reference pass: icons, footer CTA, rail spacing
   ========================================================= */
.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-link {
    grid-template-columns: minmax(0, 67.8%) minmax(300px, 32.2%) !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-copy {
    position: relative !important;
    padding: 18px 26px 44px 24px !important;
    gap: 13px !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-copy h2 {
    font-size: clamp(18px, 1.18vw, 22px) !important;
    font-weight: 500 !important;
    line-height: 1.08 !important;
    letter-spacing: -0.038em !important;
    margin-bottom: 0 !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-title {
    margin-bottom: 8px !important;
    font-size: 8px !important;
    line-height: 1 !important;
    letter-spacing: 0.28em !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-grid {
    gap: 9px !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-metric {
    min-height: 52px !important;
    padding: 9px 12px !important;
    grid-template-columns: 26px minmax(0, 1fr) !important;
    gap: 11px !important;
    background: rgba(255, 255, 255, 0.027) !important;
    border-color: rgba(255, 255, 255, 0.047) !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-metric::after {
    left: 12px !important;
    bottom: 0 !important;
    width: 42% !important;
    height: 2px !important;
    background: #20d56a !important;
    box-shadow: none !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-ui-icon {
    width: 23px !important;
    height: 23px !important;
    stroke-width: 1.65 !important;
    overflow: visible !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-ui-icon .nv-ui-icon-tone {
    stroke: rgba(207, 214, 222, 0.66) !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-ui-icon .nv-ui-icon-accent {
    stroke: #ff2a2a !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-ui-icon-download .nv-ui-icon-tone {
    stroke: rgba(207, 214, 222, 0.58) !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-ui-icon-download .nv-ui-icon-accent,
.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-ui-icon-heart .nv-ui-icon-accent {
    stroke: #ff1f22 !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-copy strong {
    font-size: clamp(18px, 1.15vw, 22px) !important;
    font-weight: 520 !important;
    line-height: 0.95 !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-copy small {
    font-size: 7px !important;
    font-weight: 950 !important;
    letter-spacing: 0.18em !important;
    color: rgba(255,255,255,0.52) !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-proof {
    gap: 12px !important;
    margin-top: 0 !important;
    padding-left: 2px !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-proof-item {
    grid-template-columns: 29px minmax(0, 1fr) !important;
    column-gap: 12px !important;
    min-height: 33px !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-proof-item > span {
    width: 27px !important;
    height: 27px !important;
    color: rgba(201, 209, 218, 0.45) !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-proof-item .nv-ui-icon {
    width: 22px !important;
    height: 22px !important;
    stroke-width: 1.35 !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-proof-item strong {
    font-size: clamp(10px, 0.78vw, 12px) !important;
    font-weight: 800 !important;
    color: rgba(244,247,250,0.82) !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-proof-item small {
    font-size: clamp(8px, 0.64vw, 9px) !important;
    color: rgba(244,247,250,0.43) !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-footer {
    position: absolute !important;
    right: 24px !important;
    bottom: 15px !important;
    display: flex !important;
    visibility: visible !important;
    opacity: 1 !important;
    width: auto !important;
    height: auto !important;
    min-height: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    pointer-events: none !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-readmore {
    display: inline-flex !important;
    visibility: visible !important;
    opacity: 1 !important;
    color: #ff2b2b !important;
    font-size: 9px !important;
    font-weight: 950 !important;
    letter-spacing: 0.18em !important;
    line-height: 1 !important;
    text-transform: uppercase !important;
    text-shadow: none !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-readmore em {
    font-style: normal !important;
    margin-left: 4px !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-nav.is-next {
    right: -1px !important;
    width: 46px !important;
    background: rgba(6, 9, 14, 0.62) !important;
}

/* reference-like tiny card icons */
.nv-plugin-showcase-card .nv-asset-signal--card .nv-ui-icon-download .nv-ui-icon-tone,
.nv-plugin-showcase-card .nv-asset-signal--card .nv-ui-icon-heart .nv-ui-icon-tone {
    stroke: rgba(210, 216, 224, 0.62) !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-ui-icon-download .nv-ui-icon-accent,
.nv-plugin-showcase-card .nv-asset-signal--card .nv-ui-icon-heart .nv-ui-icon-accent {
    stroke: #ff2326 !important;
}

/* =========================================================
   v1.1.39 - Reference-locked featured signal panel
   Matches the assembled target: larger title, aligned metrics, proof rows, and View Details CTA.
   ========================================================= */
.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-stage {
    aspect-ratio: 940 / 345 !important;
    max-height: 420px !important;
    border: 1px solid rgba(255, 26, 26, 0.38) !important;
    background: linear-gradient(90deg, rgba(3,5,9,0.99) 0%, rgba(4,6,11,0.99) 66%, rgba(10,16,25,0.99) 100%) !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-link {
    display: grid !important;
    grid-template-columns: minmax(0, 66.2%) minmax(310px, 33.8%) !important;
    height: 100% !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-copy {
    position: relative !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    justify-content: flex-start !important;
    padding: 28px 38px 38px 40px !important;
    gap: 0 !important;
    overflow: hidden !important;
    background:
        radial-gradient(circle at 0% 45%, rgba(70, 132, 184, 0.07), transparent 42%),
        linear-gradient(180deg, rgba(15, 23, 34, 0.985), rgba(8, 13, 20, 0.995)) !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-copy h2 {
    position: static !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 2 !important;
    -webkit-box-orient: vertical !important;
    max-width: 100% !important;
    max-height: calc(2 * 1.08em) !important;
    margin: 0 0 22px !important;
    padding: 0 !important;
    overflow: hidden !important;
    color: rgba(246, 249, 252, 0.94) !important;
    font-family: Arial, Helvetica, sans-serif !important;
    font-size: clamp(21px, 1.45vw, 28px) !important;
    font-weight: 500 !important;
    line-height: 1.08 !important;
    letter-spacing: -0.048em !important;
    text-transform: none !important;
    text-shadow: 0 8px 18px rgba(0,0,0,0.38) !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured {
    width: 100% !important;
    margin: 0 0 17px !important;
    padding: 0 !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-title {
    margin: 0 0 10px !important;
    color: #ff3030 !important;
    font-size: 9px !important;
    font-weight: 950 !important;
    line-height: 1 !important;
    letter-spacing: 0.255em !important;
    text-transform: uppercase !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-grid {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 10px !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-metric {
    position: relative !important;
    display: grid !important;
    grid-template-columns: 25px minmax(0, 1fr) !important;
    align-items: center !important;
    gap: 12px !important;
    min-height: 60px !important;
    padding: 10px 12px 11px !important;
    background: rgba(255, 255, 255, 0.028) !important;
    border: 1px solid rgba(255, 255, 255, 0.058) !important;
    box-shadow: inset 0 -1px 0 rgba(255, 255, 255, 0.025) !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-metric::after {
    content: "" !important;
    position: absolute !important;
    left: 14px !important;
    bottom: 0 !important;
    width: 47% !important;
    height: 2px !important;
    background: #22cf69 !important;
    box-shadow: none !important;
    opacity: 0.95 !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-icon {
    display: grid !important;
    place-items: center !important;
    color: transparent !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-ui-icon {
    width: 22px !important;
    height: 22px !important;
    stroke-width: 1.42 !important;
    overflow: visible !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-ui-icon .nv-ui-icon-tone {
    stroke: rgba(214, 221, 230, 0.64) !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-ui-icon .nv-ui-icon-accent {
    stroke: #ff2b2b !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-copy {
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
    gap: 3px !important;
    min-width: 0 !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-copy strong {
    order: 1 !important;
    color: rgba(248, 250, 252, 0.94) !important;
    font-size: clamp(17px, 1.22vw, 23px) !important;
    font-weight: 560 !important;
    line-height: 0.95 !important;
    letter-spacing: -0.018em !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-copy small {
    order: 2 !important;
    display: block !important;
    color: rgba(255, 255, 255, 0.58) !important;
    font-size: 8px !important;
    font-weight: 950 !important;
    line-height: 1 !important;
    letter-spacing: 0.17em !important;
    text-transform: uppercase !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-copy em {
    display: none !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-proof {
    display: grid !important;
    align-content: start !important;
    gap: 14px !important;
    margin: 0 !important;
    padding: 0 0 34px !important;
    overflow: hidden !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-proof-item {
    display: grid !important;
    grid-template-columns: 28px minmax(0, 1fr) !important;
    grid-template-rows: auto auto !important;
    column-gap: 14px !important;
    align-items: center !important;
    min-height: 39px !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-proof-item > span {
    grid-row: 1 / span 2 !important;
    width: 28px !important;
    height: 28px !important;
    display: grid !important;
    place-items: center !important;
    color: rgba(202, 211, 220, 0.46) !important;
    opacity: 1 !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-proof-item .nv-ui-icon {
    width: 22px !important;
    height: 22px !important;
    stroke-width: 1.35 !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-proof-item .nv-ui-icon .nv-ui-icon-tone,
.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-proof-item .nv-ui-icon .nv-ui-icon-accent {
    stroke: currentColor !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-proof-item strong {
    color: rgba(244, 247, 250, 0.84) !important;
    font-size: clamp(12px, 0.92vw, 14px) !important;
    font-weight: 820 !important;
    line-height: 1.05 !important;
    letter-spacing: -0.012em !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-proof-item small {
    color: rgba(244, 247, 250, 0.48) !important;
    font-size: clamp(9px, 0.72vw, 11px) !important;
    font-weight: 520 !important;
    line-height: 1.12 !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-footer {
    position: absolute !important;
    right: 30px !important;
    bottom: 20px !important;
    display: flex !important;
    justify-content: flex-end !important;
    align-items: center !important;
    visibility: visible !important;
    opacity: 1 !important;
    width: auto !important;
    height: auto !important;
    padding: 0 !important;
    margin: 0 !important;
    pointer-events: auto !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-readmore {
    display: inline-flex !important;
    align-items: center !important;
    gap: 7px !important;
    color: #ff3030 !important;
    font-size: 10px !important;
    font-weight: 950 !important;
    line-height: 1 !important;
    letter-spacing: 0.17em !important;
    text-transform: uppercase !important;
    visibility: visible !important;
    opacity: 1 !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-readmore em {
    margin-left: 1px !important;
    font-style: normal !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-nav.is-next {
    right: 0 !important;
    width: 48px !important;
    height: 66px !important;
    background: rgba(5, 8, 13, 0.68) !important;
    color: rgba(255,255,255,0.92) !important;
    font-size: 46px !important;
    line-height: 1 !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-nav.is-prev {
    left: 0 !important;
    width: 48px !important;
    height: 66px !important;
    background: rgba(5, 8, 13, 0.68) !important;
    color: rgba(255,255,255,0.92) !important;
    font-size: 46px !important;
    line-height: 1 !important;
}


/* =========================================================
   v1.1.40 - Featured slider final sizing pass
   Removes featured-only green metric underlines, makes metric cells smaller,
   and pins View Details inside the right panel.
   ========================================================= */
.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-copy {
    padding: clamp(18px, 1.45vw, 22px) clamp(24px, 2vw, 30px) clamp(20px, 1.5vw, 24px) clamp(22px, 1.8vw, 28px) !important;
    gap: 14px !important;
    overflow: hidden !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-copy h2 {
    margin: 0 0 2px !important;
    font-size: clamp(19px, 1.38vw, 25px) !important;
    font-weight: 520 !important;
    line-height: 1.08 !important;
    letter-spacing: -0.045em !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured {
    margin: 0 !important;
    padding: 0 !important;
    width: 100% !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-title {
    margin: 0 0 9px !important;
    font-size: 9px !important;
    letter-spacing: 0.24em !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-grid {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(122px, 142px)) !important;
    justify-content: start !important;
    align-items: stretch !important;
    gap: 9px !important;
    width: auto !important;
    max-width: 100% !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-metric {
    min-height: 44px !important;
    max-height: 44px !important;
    padding: 7px 10px !important;
    grid-template-columns: 22px minmax(0, 1fr) !important;
    gap: 9px !important;
    align-items: center !important;
    background: rgba(255, 255, 255, 0.028) !important;
    border: 1px solid rgba(255, 255, 255, 0.052) !important;
    box-shadow: none !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-metric::after {
    display: none !important;
    content: none !important;
    width: 0 !important;
    height: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-icon {
    width: 22px !important;
    height: 22px !important;
    display: grid !important;
    place-items: center !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-ui-icon {
    width: 19px !important;
    height: 19px !important;
    stroke-width: 1.55 !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-copy {
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
    gap: 2px !important;
    min-width: 0 !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-copy strong {
    font-size: clamp(15px, 1.05vw, 18px) !important;
    font-weight: 580 !important;
    line-height: 0.98 !important;
    letter-spacing: -0.018em !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-copy small {
    font-size: 7px !important;
    font-weight: 950 !important;
    letter-spacing: 0.17em !important;
    line-height: 1 !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-proof {
    gap: 13px !important;
    margin-top: 2px !important;
    padding: 0 0 54px !important;
    overflow: hidden !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-proof-item {
    grid-template-columns: 30px minmax(0, 1fr) !important;
    column-gap: 13px !important;
    min-height: 39px !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-proof-item > span {
    width: 30px !important;
    height: 30px !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-proof-item .nv-ui-icon {
    width: 22px !important;
    height: 22px !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-proof-item strong {
    font-size: clamp(11px, 0.9vw, 13px) !important;
    font-weight: 820 !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-proof-item small {
    font-size: clamp(8px, 0.68vw, 10px) !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-footer {
    position: absolute !important;
    right: 28px !important;
    bottom: 19px !important;
    z-index: 30 !important;
    display: flex !important;
    justify-content: flex-end !important;
    align-items: center !important;
    width: auto !important;
    height: auto !important;
    min-height: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    visibility: visible !important;
    opacity: 1 !important;
    transform: none !important;
    pointer-events: auto !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-readmore {
    display: inline-flex !important;
    visibility: visible !important;
    opacity: 1 !important;
    align-items: center !important;
    justify-content: flex-end !important;
    gap: 7px !important;
    color: #ff3030 !important;
    font-size: 10px !important;
    font-weight: 950 !important;
    line-height: 1 !important;
    letter-spacing: 0.18em !important;
    text-transform: uppercase !important;
    white-space: nowrap !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-readmore em {
    display: inline-block !important;
    font-style: normal !important;
    margin-left: 1px !important;
}

/* =========================================================
   v1.1.41 - Featured signal panel vertical alignment
   Lowers the right-panel content stack and keeps View Details visible.
   ========================================================= */
.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-copy {
    position: relative !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: flex-start !important;
    padding-top: clamp(34px, 2.45vw, 42px) !important;
    padding-right: clamp(26px, 2vw, 32px) !important;
    padding-bottom: 48px !important;
    padding-left: clamp(22px, 1.8vw, 28px) !important;
    gap: 14px !important;
    overflow: visible !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-copy h2,
.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured,
.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-proof {
    transform: translateY(8px) !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-copy h2 {
    margin-bottom: 4px !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-proof {
    padding-bottom: 38px !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-thumbs {
    display: none !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-footer {
    position: absolute !important;
    right: 30px !important;
    bottom: 22px !important;
    z-index: 80 !important;
    display: flex !important;
    justify-content: flex-end !important;
    align-items: center !important;
    width: auto !important;
    height: auto !important;
    min-width: 120px !important;
    min-height: 18px !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: visible !important;
    visibility: visible !important;
    opacity: 1 !important;
    transform: none !important;
    pointer-events: auto !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-readmore {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: flex-end !important;
    gap: 7px !important;
    color: #ff3030 !important;
    font-size: 10px !important;
    font-weight: 950 !important;
    line-height: 1 !important;
    letter-spacing: 0.18em !important;
    text-transform: uppercase !important;
    white-space: nowrap !important;
    visibility: visible !important;
    opacity: 1 !important;
}


/* =========================================================
   v1.1.42 - Featured signal panel final visibility and title scale
   Makes title larger and forces the View Details CTA to render inside the visible panel.
   ========================================================= */
.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-copy {
    position: relative !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: flex-start !important;
    padding-top: clamp(42px, 3.05vw, 54px) !important;
    padding-right: clamp(26px, 2.05vw, 34px) !important;
    padding-bottom: 54px !important;
    padding-left: clamp(25px, 2.05vw, 34px) !important;
    gap: 13px !important;
    overflow: visible !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-copy h2 {
    transform: translateY(6px) !important;
    margin: 0 0 5px !important;
    max-height: calc(2 * 1.08em) !important;
    color: rgba(245, 248, 252, 0.95) !important;
    font-family: Arial, Helvetica, sans-serif !important;
    font-size: clamp(21px, 1.55vw, 29px) !important;
    font-weight: 540 !important;
    line-height: 1.08 !important;
    letter-spacing: -0.052em !important;
    z-index: 8 !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured,
.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-proof {
    transform: translateY(8px) !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-title {
    margin-bottom: 8px !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-metric {
    min-height: 48px !important;
    padding: 7px 12px 8px !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-proof {
    gap: 11px !important;
    padding-bottom: 26px !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-footer {
    position: absolute !important;
    right: clamp(24px, 2.05vw, 34px) !important;
    bottom: 18px !important;
    z-index: 999 !important;
    display: block !important;
    width: auto !important;
    min-width: 138px !important;
    height: 18px !important;
    min-height: 18px !important;
    max-height: none !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: visible !important;
    clip: auto !important;
    visibility: visible !important;
    opacity: 1 !important;
    transform: none !important;
    pointer-events: auto !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-readmore,
.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-readmore:visited {
    position: relative !important;
    z-index: 1000 !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: flex-end !important;
    gap: 7px !important;
    color: #ff3030 !important;
    opacity: 1 !important;
    visibility: visible !important;
    text-indent: 0 !important;
    font-size: 10px !important;
    font-weight: 950 !important;
    line-height: 1 !important;
    letter-spacing: 0.18em !important;
    text-transform: uppercase !important;
    white-space: nowrap !important;
    text-shadow: 0 0 10px rgba(255, 24, 24, 0.22) !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-readmore em {
    display: inline-block !important;
    color: #ff3030 !important;
    font-style: normal !important;
    font-size: 12px !important;
    line-height: 1 !important;
    opacity: 1 !important;
    visibility: visible !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-nav.is-next {
    z-index: 50 !important;
}


/* =========================================================
   v1.1.43 - Reference-locked showcase cards + featured CTA visibility
   Top showcase cards and right featured panel tuned to match the approved reference.
   ========================================================= */

/* ---- catalog cards ---- */
.nv-plugin-showcase-grid {
    gap: 14px !important;
}

.nv-plugin-showcase-card {
    position: relative !important;
    display: flex !important;
    flex-direction: column !important;
    min-height: 100% !important;
    background: linear-gradient(180deg, rgba(8, 10, 16, 0.98) 0%, rgba(6, 8, 13, 0.99) 100%) !important;
    border: 1px solid rgba(255, 34, 34, 0.18) !important;
    overflow: hidden !important;
}

.nv-plugin-showcase-card-media {
    position: relative !important;
}

.nv-plugin-showcase-card-media::before {
    content: "";
    position: absolute;
    top: 9px;
    right: 9px;
    z-index: 8;
    width: 18px;
    height: 18px;
    opacity: 0.92;
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='rgba(255,255,255,0.96)' stroke-width='1.75' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 20.1c-1.1-.8-7.1-5-8.2-9-.6-2.4.9-4.7 3.5-4.7 1.8 0 3.1 1 4.7 2.8 1.6-1.8 2.9-2.8 4.7-2.8 2.6 0 4.1 2.3 3.5 4.7-1.1 4-7.1 8.2-8.2 9z'/%3E%3C/svg%3E");
    pointer-events: none;
}

.nv-plugin-showcase-card-content {
    display: flex !important;
    flex-direction: column !important;
    flex: 1 1 auto !important;
    padding: 16px 18px 18px !important;
}

.nv-plugin-showcase-card-top {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    margin-bottom: 14px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-mark {
    min-width: 38px !important;
    min-height: 38px !important;
    padding: 0 6px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-size: 12px !important;
    font-weight: 900 !important;
    line-height: 1 !important;
    letter-spacing: 0.18em !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-category {
    font-size: 11px !important;
    font-weight: 800 !important;
    line-height: 1 !important;
    letter-spacing: 0.18em !important;
    color: #ff4545 !important;
}

.nv-plugin-showcase-card h3 {
    margin: 0 0 8px !important;
    font-family: Arial, Helvetica, sans-serif !important;
    font-size: 18px !important;
    font-weight: 700 !important;
    line-height: 0.98 !important;
    letter-spacing: -0.045em !important;
    color: rgba(245, 247, 251, 0.96) !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-subtitle {
    margin: 0 0 14px !important;
    font-family: Arial, Helvetica, sans-serif !important;
    font-size: 11px !important;
    font-weight: 600 !important;
    line-height: 1.3 !important;
    color: rgba(236, 239, 243, 0.72) !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card {
    margin-top: auto !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-grid {
    gap: 10px !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-metric {
    min-height: 44px !important;
    padding: 9px 12px 10px !important;
    grid-template-columns: 18px minmax(0,1fr) !important;
    gap: 9px !important;
    background: rgba(255,255,255,0.02) !important;
    border: 1px solid rgba(255,255,255,0.06) !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-metric::after {
    left: 11px !important;
    width: 47% !important;
    height: 2px !important;
    background: #26d56f !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-icon {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-ui-icon {
    width: 15px !important;
    height: 15px !important;
    stroke-width: 1.55 !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-ui-icon .nv-ui-icon-tone {
    stroke: rgba(205, 213, 223, 0.72) !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-ui-icon .nv-ui-icon-accent {
    stroke: #ff2f31 !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-copy {
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-start !important;
    justify-content: center !important;
    gap: 2px !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-copy strong {
    order: 1 !important;
    margin: 0 !important;
    font-family: Arial, Helvetica, sans-serif !important;
    font-size: 13px !important;
    font-weight: 700 !important;
    line-height: 1 !important;
    color: rgba(248,249,251,0.92) !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-copy small {
    order: 2 !important;
    margin: 0 !important;
    font-size: 7px !important;
    font-weight: 900 !important;
    line-height: 1 !important;
    letter-spacing: 0.16em !important;
    color: rgba(255,255,255,0.52) !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-chips {
    gap: 8px !important;
    margin-top: 8px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-chips span {
    min-height: 30px !important;
    padding: 0 12px !important;
    font-size: 10px !important;
    font-weight: 850 !important;
    line-height: 1 !important;
    letter-spacing: 0.15em !important;
}

/* ---- featured right panel ---- */
.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-copy {
    position: relative !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: flex-start !important;
    padding: 46px 28px 62px 26px !important;
    gap: 13px !important;
    overflow: visible !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-copy h2 {
    margin: 0 0 2px !important;
    font-family: Arial, Helvetica, sans-serif !important;
    font-size: clamp(22px, 1.6vw, 30px) !important;
    font-weight: 500 !important;
    line-height: 1.06 !important;
    letter-spacing: -0.05em !important;
    color: rgba(246,248,251,0.96) !important;
    transform: none !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured,
.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-proof {
    transform: none !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured {
    margin-top: 2px !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-title {
    margin-bottom: 9px !important;
    font-size: 10px !important;
    font-weight: 900 !important;
    line-height: 1 !important;
    letter-spacing: 0.24em !important;
    color: #ff3a3a !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-grid {
    gap: 10px !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-metric {
    min-height: 58px !important;
    padding: 9px 14px 10px !important;
    grid-template-columns: 24px minmax(0,1fr) !important;
    gap: 11px !important;
    background: rgba(255,255,255,0.024) !important;
    border: 1px solid rgba(255,255,255,0.05) !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-metric::after {
    display: none !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-icon {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-ui-icon {
    width: 19px !important;
    height: 19px !important;
    stroke-width: 1.5 !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-ui-icon .nv-ui-icon-tone {
    stroke: rgba(198, 206, 216, 0.66) !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-ui-icon .nv-ui-icon-accent {
    stroke: #ff2b2d !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-copy {
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-start !important;
    justify-content: center !important;
    gap: 3px !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-copy strong {
    order: 1 !important;
    margin: 0 !important;
    font-family: Arial, Helvetica, sans-serif !important;
    font-size: 15px !important;
    font-weight: 500 !important;
    line-height: 1 !important;
    color: rgba(247,248,250,0.93) !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-copy small {
    order: 2 !important;
    margin: 0 !important;
    font-size: 8px !important;
    font-weight: 900 !important;
    line-height: 1 !important;
    letter-spacing: 0.15em !important;
    color: rgba(255,255,255,0.48) !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-proof {
    gap: 13px !important;
    padding-left: 1px !important;
    padding-bottom: 28px !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-proof-item {
    grid-template-columns: 24px minmax(0,1fr) !important;
    column-gap: 13px !important;
    min-height: 35px !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-proof-item > span {
    width: 22px !important;
    height: 22px !important;
    color: rgba(188,196,205,0.48) !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-proof-item .nv-ui-icon {
    width: 18px !important;
    height: 18px !important;
    stroke-width: 1.35 !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-proof-item .nv-ui-icon .nv-ui-icon-tone {
    stroke: rgba(185,194,204,0.58) !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-proof-item .nv-ui-icon .nv-ui-icon-accent {
    stroke: rgba(185,194,204,0.58) !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-proof-item strong {
    font-family: Arial, Helvetica, sans-serif !important;
    font-size: 11px !important;
    font-weight: 700 !important;
    line-height: 1.05 !important;
    color: rgba(242,245,249,0.85) !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-proof-item small {
    font-size: 9px !important;
    font-weight: 500 !important;
    line-height: 1.2 !important;
    color: rgba(236,240,244,0.45) !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-footer {
    position: absolute !important;
    right: 28px !important;
    bottom: 18px !important;
    z-index: 999 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: flex-end !important;
    width: auto !important;
    min-width: 120px !important;
    min-height: 14px !important;
    height: auto !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: visible !important;
    visibility: visible !important;
    opacity: 1 !important;
    pointer-events: none !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-readmore,
.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-readmore:visited {
    position: relative !important;
    z-index: 1000 !important;
    display: inline-flex !important;
    align-items: center !important;
    gap: 7px !important;
    color: #ff3436 !important;
    font-size: 10px !important;
    font-weight: 900 !important;
    line-height: 1 !important;
    letter-spacing: 0.18em !important;
    text-transform: uppercase !important;
    white-space: nowrap !important;
    visibility: visible !important;
    opacity: 1 !important;
    text-shadow: none !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-readmore em {
    color: inherit !important;
    font-style: normal !important;
    font-size: 12px !important;
    line-height: 1 !important;
}


/* =========================================================
   v1.1.44 - Catalog card metrics only.
   Featured showcase/vitrine remains untouched.
   Card metrics are muted inline, without boxes or green accent lines.
   ========================================================= */

.nv-plugin-showcase-card .nv-asset-signal--card {
    margin: 10px 0 8px !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-grid {
    display: flex !important;
    align-items: center !important;
    justify-content: flex-start !important;
    gap: 22px !important;
    margin: 0 !important;
    padding: 0 !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-metric {
    width: auto !important;
    min-width: 0 !important;
    min-height: 0 !important;
    padding: 0 !important;
    display: inline-flex !important;
    grid-template-columns: none !important;
    align-items: center !important;
    justify-content: flex-start !important;
    gap: 7px !important;
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    outline: 0 !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-metric::before,
.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-metric::after {
    display: none !important;
    content: none !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-icon {
    width: 16px !important;
    height: 16px !important;
    min-width: 16px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    color: rgba(185, 193, 203, 0.74) !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-ui-icon {
    width: 15px !important;
    height: 15px !important;
    stroke: rgba(185, 193, 203, 0.74) !important;
    stroke-width: 1.55 !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-ui-icon *,
.nv-plugin-showcase-card .nv-asset-signal--card .nv-ui-icon .nv-ui-icon-tone,
.nv-plugin-showcase-card .nv-asset-signal--card .nv-ui-icon .nv-ui-icon-accent {
    stroke: rgba(185, 193, 203, 0.74) !important;
    fill: none !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-copy {
    display: inline-flex !important;
    flex-direction: row !important;
    align-items: center !important;
    justify-content: flex-start !important;
    gap: 0 !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-copy strong {
    order: 1 !important;
    margin: 0 !important;
    color: rgba(224, 229, 236, 0.80) !important;
    font-family: Arial, Helvetica, sans-serif !important;
    font-size: 14px !important;
    font-weight: 500 !important;
    line-height: 1 !important;
    letter-spacing: 0 !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-copy small,
.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-copy em {
    display: none !important;
}

/* =========================================================
   v1.1.45 - Catalog toolbar + reference card lower blocks.
   Featured showcase/vitrine intentionally untouched.
   ========================================================= */

.nv-plugin-showcase-toolbar {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 18px !important;
    margin: 0 auto 18px !important;
    width: 100% !important;
    max-width: 1180px !important;
}

.nv-plugin-showcase-toolbar .nv-plugin-showcase-filters {
    margin: 0 !important;
    display: flex !important;
    align-items: center !important;
    flex-wrap: wrap !important;
    gap: 7px !important;
}

.nv-plugin-showcase-tools {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: flex-end !important;
    gap: 10px !important;
    margin-left: auto !important;
    flex: 0 0 auto !important;
}

.nv-plugin-showcase-sort {
    position: relative !important;
    display: inline-flex !important;
    align-items: center !important;
    min-width: 98px !important;
}

.nv-plugin-showcase-sort select,
.nv-plugin-showcase-filter-toggle {
    min-height: 34px !important;
    height: 34px !important;
    border: 1px solid rgba(255, 255, 255, 0.11) !important;
    background: rgba(8, 10, 14, 0.92) !important;
    color: rgba(238, 241, 246, 0.86) !important;
    font-family: Arial, Helvetica, sans-serif !important;
    font-size: 10px !important;
    font-weight: 700 !important;
    line-height: 1 !important;
    letter-spacing: 0 !important;
    box-shadow: inset 0 0 0 1px rgba(0,0,0,0.45), 0 10px 26px rgba(0,0,0,0.18) !important;
}

.nv-plugin-showcase-sort select {
    width: 100% !important;
    padding: 0 30px 0 12px !important;
    appearance: auto !important;
    -webkit-appearance: menulist !important;
    border-radius: 0 !important;
}

.nv-plugin-showcase-filter-toggle {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px !important;
    padding: 0 14px !important;
    border-radius: 0 !important;
    cursor: pointer !important;
}

.nv-plugin-showcase-filter-toggle .nv-ui-icon {
    width: 13px !important;
    height: 13px !important;
    stroke: rgba(185, 193, 203, 0.78) !important;
    stroke-width: 1.8 !important;
}

.nv-plugin-showcase-filter-toggle span {
    color: inherit !important;
}

.nv-plugin-showcase-filter-toggle:hover,
.nv-plugin-showcase-sort select:hover {
    border-color: rgba(255, 45, 45, 0.34) !important;
    color: #fff !important;
}

.nv-plugin-showcase-card h3 {
    margin-bottom: 9px !important;
    line-height: 1.04 !important;
    letter-spacing: -0.028em !important;
    overflow-wrap: normal !important;
    word-break: normal !important;
    hyphens: none !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-subtitle {
    margin-bottom: 14px !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card {
    margin: 0 0 14px !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-grid {
    gap: 20px !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-metric {
    gap: 7px !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-icon,
.nv-plugin-showcase-card .nv-asset-signal--card .nv-ui-icon {
    width: 14px !important;
    height: 14px !important;
    min-width: 14px !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-copy strong {
    font-size: 13px !important;
    font-weight: 500 !important;
    color: rgba(225, 230, 237, 0.82) !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-chips {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 7px !important;
    margin-top: auto !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-chips span {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 100% !important;
    min-height: 29px !important;
    padding: 0 10px !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
    background: rgba(255, 255, 255, 0.035) !important;
    border: 1px solid rgba(255,255,255,0.07) !important;
    color: rgba(235, 238, 244, 0.78) !important;
    box-shadow: inset 0 0 0 1px rgba(0,0,0,0.36) !important;
}

@media (max-width: 760px) {
    .nv-plugin-showcase-toolbar {
        align-items: stretch !important;
        flex-direction: column !important;
    }
    .nv-plugin-showcase-tools {
        width: 100% !important;
        justify-content: flex-start !important;
        margin-left: 0 !important;
    }
}


/* =========================================================
   v1.1.46 - Catalog card metrics/chips refinement only.
   Featured showcase/vitrine is intentionally untouched.
   ========================================================= */

/* Card metrics: two subtle cells, larger centered values, muted gray icons. */
.nv-plugin-showcase-card .nv-asset-signal--card {
    width: 100% !important;
    margin: 2px 0 10px !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-grid {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    align-items: stretch !important;
    justify-content: stretch !important;
    gap: 8px !important;
    width: 100% !important;
    padding: 0 !important;
    margin: 0 !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-metric {
    display: inline-flex !important;
    flex-direction: row !important;
    align-items: center !important;
    justify-content: center !important;
    width: 100% !important;
    min-width: 0 !important;
    min-height: 28px !important;
    height: 28px !important;
    padding: 0 10px !important;
    gap: 8px !important;
    background: rgba(255, 255, 255, 0.018) !important;
    border: 1px solid rgba(255, 255, 255, 0.045) !important;
    box-shadow: inset 0 0 0 1px rgba(0,0,0,0.18) !important;
    outline: none !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-metric::before,
.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-metric::after {
    display: none !important;
    content: none !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-icon {
    width: 15px !important;
    height: 15px !important;
    min-width: 15px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    color: rgba(170, 178, 188, 0.76) !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-ui-icon {
    width: 14px !important;
    height: 14px !important;
    min-width: 14px !important;
    stroke-width: 1.5 !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-ui-icon,
.nv-plugin-showcase-card .nv-asset-signal--card .nv-ui-icon *,
.nv-plugin-showcase-card .nv-asset-signal--card .nv-ui-icon .nv-ui-icon-tone,
.nv-plugin-showcase-card .nv-asset-signal--card .nv-ui-icon .nv-ui-icon-accent {
    stroke: rgba(168, 177, 188, 0.78) !important;
    fill: none !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-copy {
    display: inline-flex !important;
    flex: 0 0 auto !important;
    align-items: center !important;
    justify-content: center !important;
    min-width: 0 !important;
    gap: 0 !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-copy strong {
    order: 1 !important;
    display: inline-block !important;
    margin: 0 !important;
    color: rgba(221, 226, 234, 0.84) !important;
    font-family: Arial, Helvetica, sans-serif !important;
    font-size: 15px !important;
    font-weight: 500 !important;
    line-height: 1 !important;
    letter-spacing: 0 !important;
    text-align: center !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-copy small,
.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-copy em {
    display: none !important;
}

/* Chips: thinner, darker, less bold, closer to the lower reference. */
.nv-plugin-showcase-card .nv-plugin-showcase-chips {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 7px !important;
    margin-top: 0 !important;
    width: 100% !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-chips span {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 100% !important;
    min-height: 28px !important;
    height: 28px !important;
    padding: 0 11px !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
    background: rgba(255, 255, 255, 0.028) !important;
    border: 1px solid rgba(255, 255, 255, 0.055) !important;
    color: rgba(226, 231, 238, 0.74) !important;
    font-family: Arial, Helvetica, sans-serif !important;
    font-size: 10px !important;
    font-weight: 700 !important;
    line-height: 1 !important;
    letter-spacing: 0.145em !important;
    text-transform: uppercase !important;
    box-shadow: inset 0 0 0 1px rgba(0,0,0,0.26) !important;
}

/* Keep lower card rhythm closer to the target. */
.nv-plugin-showcase-card .nv-plugin-showcase-subtitle {
    margin-bottom: 13px !important;
}

.nv-plugin-showcase-card h3 {
    margin-bottom: 8px !important;
}


/* =========================================================
   v1.1.47 - Card metrics/chips pixel refinement only.
   Featured showcase/vitrine is not touched.
   ========================================================= */

.nv-plugin-showcase-card .nv-asset-signal--card {
    width: 100% !important;
    margin: 4px 0 8px !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-grid {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 6px !important;
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-metric {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 9px !important;
    width: 100% !important;
    min-width: 0 !important;
    height: 31px !important;
    min-height: 31px !important;
    max-height: 31px !important;
    padding: 0 8px !important;
    border-radius: 6px !important;
    background:
        linear-gradient(180deg, rgba(255,255,255,0.026), rgba(255,255,255,0.014)) !important;
    border: 1px solid rgba(255,255,255,0.052) !important;
    box-shadow:
        inset 0 1px 0 rgba(255,255,255,0.018),
        inset 0 -1px 0 rgba(0,0,0,0.28) !important;
    outline: 0 !important;
    overflow: hidden !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-metric::before,
.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-metric::after {
    display: none !important;
    content: none !important;
    width: 0 !important;
    height: 0 !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-icon {
    flex: 0 0 18px !important;
    width: 18px !important;
    height: 18px !important;
    min-width: 18px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    color: rgba(176, 184, 194, 0.74) !important;
    opacity: 0.94 !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-ui-icon {
    width: 17px !important;
    height: 17px !important;
    min-width: 17px !important;
    stroke-width: 1.65 !important;
    opacity: 0.94 !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-ui-icon,
.nv-plugin-showcase-card .nv-asset-signal--card .nv-ui-icon *,
.nv-plugin-showcase-card .nv-asset-signal--card .nv-ui-icon .nv-ui-icon-tone,
.nv-plugin-showcase-card .nv-asset-signal--card .nv-ui-icon .nv-ui-icon-accent {
    stroke: rgba(178, 187, 198, 0.82) !important;
    fill: none !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-copy {
    display: inline-flex !important;
    flex: 0 1 auto !important;
    min-width: 0 !important;
    align-items: center !important;
    justify-content: center !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-copy strong {
    display: inline-block !important;
    margin: 0 !important;
    font-family: Arial, Helvetica, sans-serif !important;
    font-size: 16px !important;
    font-weight: 500 !important;
    line-height: 1 !important;
    letter-spacing: -0.01em !important;
    color: rgba(230, 235, 242, 0.88) !important;
    text-align: center !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-copy small,
.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-copy em {
    display: none !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-chips {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 6px !important;
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
    margin: 0 !important;
    overflow: hidden !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-chips span {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
    height: 28px !important;
    min-height: 28px !important;
    padding: 0 10px !important;
    border-radius: 5px !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
    background:
        linear-gradient(180deg, rgba(255,255,255,0.036), rgba(255,255,255,0.022)) !important;
    border: 1px solid rgba(255,255,255,0.062) !important;
    box-shadow:
        inset 0 1px 0 rgba(255,255,255,0.02),
        inset 0 -1px 0 rgba(0,0,0,0.30) !important;
    color: rgba(230, 235, 242, 0.78) !important;
    font-family: Arial, Helvetica, sans-serif !important;
    font-size: 9px !important;
    font-weight: 700 !important;
    line-height: 1 !important;
    letter-spacing: 0.145em !important;
    text-transform: uppercase !important;
}

/* Prevent long chip text from pushing into the second chip. */
.nv-plugin-showcase-card .nv-plugin-showcase-chips span:first-child:nth-last-child(2),
.nv-plugin-showcase-card .nv-plugin-showcase-chips span:first-child:nth-last-child(2) ~ span {
    min-width: 0 !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-content {
    min-width: 0 !important;
}


/* =========================================================
   v1.1.49 - Catalog cards only.
   Keeps the featured slider/vitrine untouched.
   Metrics become small separate rounded pills, with muted gray icons and no green accents.
   ========================================================= */

.nv-plugin-showcase-toolbar {
    align-items: center !important;
    justify-content: space-between !important;
    gap: 14px !important;
    margin: 0 auto 18px !important;
    max-width: 1180px !important;
}

.nv-plugin-showcase-toolbar .nv-plugin-showcase-filters {
    display: inline-flex !important;
    align-items: center !important;
    flex: 1 1 auto !important;
    gap: 7px !important;
    min-width: 0 !important;
    margin: 0 !important;
}

.nv-plugin-showcase-toolbar .nv-plugin-showcase-filters button {
    min-height: 30px !important;
    height: 30px !important;
    padding: 0 12px !important;
    border-radius: 999px !important;
    background: rgba(255,255,255,0.024) !important;
    border: 1px solid rgba(255,255,255,0.06) !important;
    box-shadow: none !important;
    color: rgba(218,224,232,0.72) !important;
    font-size: 10px !important;
    font-weight: 650 !important;
    line-height: 1 !important;
    letter-spacing: 0.11em !important;
}

.nv-plugin-showcase-toolbar .nv-plugin-showcase-filters button:hover,
.nv-plugin-showcase-toolbar .nv-plugin-showcase-filters button.is-active {
    color: rgba(245,247,250,0.92) !important;
    background: rgba(255,255,255,0.045) !important;
    border-color: rgba(255,255,255,0.10) !important;
}

.nv-plugin-showcase-tools {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: flex-end !important;
    gap: 8px !important;
    flex: 0 0 auto !important;
    margin-left: auto !important;
}

.nv-plugin-showcase-sort {
    min-width: 108px !important;
}

.nv-plugin-showcase-sort select,
.nv-plugin-showcase-filter-toggle {
    height: 30px !important;
    min-height: 30px !important;
    border-radius: 999px !important;
    background: rgba(255,255,255,0.028) !important;
    border: 1px solid rgba(255,255,255,0.07) !important;
    box-shadow: none !important;
    color: rgba(224,229,236,0.78) !important;
    font-size: 10px !important;
    font-weight: 650 !important;
}

.nv-plugin-showcase-sort select {
    padding: 0 26px 0 12px !important;
}

.nv-plugin-showcase-filter-toggle {
    padding: 0 12px !important;
    gap: 6px !important;
}

.nv-plugin-showcase-filter-toggle .nv-ui-icon {
    width: 13px !important;
    height: 13px !important;
    stroke: rgba(174,184,196,0.78) !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card {
    display: block !important;
    width: auto !important;
    max-width: 100% !important;
    margin: 2px 0 10px !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-grid {
    display: inline-flex !important;
    flex-wrap: wrap !important;
    align-items: center !important;
    justify-content: flex-start !important;
    gap: 8px !important;
    width: auto !important;
    max-width: 100% !important;
    min-width: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-metric {
    display: inline-flex !important;
    flex: 0 0 auto !important;
    flex-direction: row !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 7px !important;
    width: auto !important;
    min-width: 74px !important;
    max-width: 132px !important;
    height: 27px !important;
    min-height: 27px !important;
    max-height: 27px !important;
    padding: 0 10px !important;
    border-radius: 999px !important;
    background: rgba(255,255,255,0.026) !important;
    border: 1px solid rgba(255,255,255,0.052) !important;
    box-shadow: none !important;
    outline: 0 !important;
    overflow: hidden !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-metric::before,
.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-metric::after {
    display: none !important;
    content: none !important;
    width: 0 !important;
    height: 0 !important;
    background: transparent !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-icon {
    flex: 0 0 19px !important;
    width: 19px !important;
    height: 19px !important;
    min-width: 19px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    color: rgba(170,180,192,0.82) !important;
    opacity: 1 !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-ui-icon {
    width: 18px !important;
    height: 18px !important;
    min-width: 18px !important;
    stroke-width: 1.55 !important;
    opacity: 1 !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-ui-icon,
.nv-plugin-showcase-card .nv-asset-signal--card .nv-ui-icon *,
.nv-plugin-showcase-card .nv-asset-signal--card .nv-ui-icon .nv-ui-icon-tone,
.nv-plugin-showcase-card .nv-asset-signal--card .nv-ui-icon .nv-ui-icon-accent {
    stroke: rgba(170,180,192,0.82) !important;
    fill: none !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-copy {
    display: inline-flex !important;
    flex: 0 1 auto !important;
    min-width: 0 !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 0 !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-copy strong {
    display: inline-block !important;
    max-width: 82px !important;
    margin: 0 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
    font-family: Arial, Helvetica, sans-serif !important;
    font-size: 16px !important;
    font-weight: 520 !important;
    line-height: 1 !important;
    letter-spacing: -0.01em !important;
    color: rgba(230,235,242,0.88) !important;
    text-align: center !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-copy small,
.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-copy em {
    display: none !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-chips {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 6px !important;
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
    margin: 0 !important;
    overflow: hidden !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-chips span {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
    height: 24px !important;
    min-height: 24px !important;
    padding: 0 9px !important;
    border-radius: 999px !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
    background: rgba(255,255,255,0.022) !important;
    border: 1px solid rgba(255,255,255,0.050) !important;
    box-shadow: none !important;
    color: rgba(210,218,228,0.70) !important;
    font-family: Arial, Helvetica, sans-serif !important;
    font-size: 8.5px !important;
    font-weight: 600 !important;
    line-height: 1 !important;
    letter-spacing: 0.115em !important;
    text-transform: uppercase !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-content {
    min-width: 0 !important;
}

@media (max-width: 760px) {
    .nv-plugin-showcase-toolbar {
        align-items: stretch !important;
        flex-direction: column !important;
    }

    .nv-plugin-showcase-toolbar .nv-plugin-showcase-filters,
    .nv-plugin-showcase-tools {
        width: 100% !important;
        justify-content: flex-start !important;
        margin-left: 0 !important;
    }
}

/* =========================================================
   v1.1.50 - Catalog card correction pass from latest reference.
   Scope is intentionally limited to the lower catalog card area and toolbar.
   Featured slider/vitrine styles are not targeted here.
   ========================================================= */

.nv-plugin-showcase-toolbar {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    width: 100% !important;
    max-width: none !important;
    gap: 16px !important;
    margin: 0 0 14px !important;
}

.nv-plugin-showcase-toolbar .nv-plugin-showcase-filters {
    display: inline-flex !important;
    align-items: center !important;
    flex: 1 1 auto !important;
    gap: 6px !important;
    min-width: 0 !important;
    margin: 0 !important;
}

.nv-plugin-showcase-toolbar .nv-plugin-showcase-filters button {
    height: 31px !important;
    min-height: 31px !important;
    padding: 0 13px !important;
    border-radius: 2px !important;
    background: rgba(255, 255, 255, 0.018) !important;
    border: 1px solid rgba(255, 255, 255, 0.055) !important;
    box-shadow: inset 0 0 0 1px rgba(0, 0, 0, 0.18) !important;
    color: rgba(211, 216, 225, 0.68) !important;
    font-size: 9.5px !important;
    font-weight: 650 !important;
    line-height: 1 !important;
    letter-spacing: 0.15em !important;
}

.nv-plugin-showcase-toolbar .nv-plugin-showcase-filters button:hover,
.nv-plugin-showcase-toolbar .nv-plugin-showcase-filters button.is-active {
    color: rgba(245, 247, 250, 0.9) !important;
    background: rgba(255, 26, 26, 0.055) !important;
    border-color: rgba(255, 26, 26, 0.22) !important;
}

.nv-plugin-showcase-tools {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: flex-end !important;
    flex: 0 0 auto !important;
    gap: 14px !important;
    margin-left: auto !important;
}

.nv-plugin-showcase-sort {
    display: inline-flex !important;
    width: 110px !important;
    min-width: 110px !important;
}

.nv-plugin-showcase-sort select,
.nv-plugin-showcase-filter-toggle {
    height: 36px !important;
    min-height: 36px !important;
    border-radius: 0 !important;
    background: rgba(8, 8, 12, 0.54) !important;
    border: 1px solid rgba(255, 255, 255, 0.075) !important;
    box-shadow: none !important;
    color: rgba(232, 236, 243, 0.78) !important;
    font-size: 11px !important;
    font-weight: 650 !important;
    line-height: 1 !important;
}

.nv-plugin-showcase-sort select {
    width: 100% !important;
    padding: 0 28px 0 13px !important;
}

.nv-plugin-showcase-filter-toggle {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 86px !important;
    min-width: 86px !important;
    padding: 0 12px !important;
    gap: 7px !important;
}

.nv-plugin-showcase-filter-toggle .nv-ui-icon {
    width: 13px !important;
    height: 13px !important;
    stroke: rgba(172, 182, 195, 0.72) !important;
}

.nv-plugin-showcase-grid {
    align-items: stretch !important;
}

.nv-plugin-showcase-card {
    display: grid !important;
    grid-template-rows: 132px minmax(0, 1fr) !important;
    min-height: 386px !important;
    height: 386px !important;
    max-height: 386px !important;
    overflow: hidden !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-media {
    height: 132px !important;
    min-height: 132px !important;
    max-height: 132px !important;
    aspect-ratio: auto !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-content {
    display: grid !important;
    grid-template-rows: 36px 52px 24px 29px 28px !important;
    align-content: start !important;
    row-gap: 8px !important;
    min-width: 0 !important;
    min-height: 0 !important;
    height: 100% !important;
    padding: 14px !important;
    box-sizing: border-box !important;
    overflow: hidden !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-top {
    height: 36px !important;
    min-height: 36px !important;
    max-height: 36px !important;
    align-items: center !important;
    overflow: hidden !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-mark {
    width: 36px !important;
    height: 36px !important;
    flex: 0 0 36px !important;
    font-size: 12px !important;
    border-radius: 0 !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-category {
    min-width: 0 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
    font-size: 10px !important;
    font-weight: 800 !important;
    letter-spacing: 0.14em !important;
}

.nv-plugin-showcase-card h3.nv-plugin-showcase-marquee {
    position: relative !important;
    display: block !important;
    height: 52px !important;
    min-height: 52px !important;
    max-height: 52px !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: hidden !important;
    color: #f5f7fb !important;
    font-family: Arial, Helvetica, sans-serif !important;
    font-size: 20px !important;
    font-weight: 850 !important;
    line-height: 1.08 !important;
    letter-spacing: -0.045em !important;
    text-shadow: 0 0 16px rgba(0,0,0,0.72) !important;
}

.nv-plugin-showcase-card h3.nv-plugin-showcase-marquee > span {
    display: -webkit-box !important;
    max-width: 100% !important;
    overflow: hidden !important;
    -webkit-box-orient: vertical !important;
    -webkit-line-clamp: 2 !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-subtitle.nv-plugin-showcase-marquee {
    position: relative !important;
    display: block !important;
    height: 24px !important;
    min-height: 24px !important;
    max-height: 24px !important;
    margin: 0 !important;
    overflow: hidden !important;
    color: rgba(229, 234, 242, 0.66) !important;
    font-family: "Courier New", monospace !important;
    font-size: 11px !important;
    font-weight: 650 !important;
    line-height: 1.25 !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-subtitle.nv-plugin-showcase-marquee > span {
    display: block !important;
    max-width: 100% !important;
    overflow: hidden !important;
    white-space: nowrap !important;
    text-overflow: ellipsis !important;
}

.nv-plugin-showcase-card:hover .nv-plugin-showcase-marquee.is-overflowing > span,
.nv-plugin-showcase-card:focus-within .nv-plugin-showcase-marquee.is-overflowing > span {
    display: inline-block !important;
    width: auto !important;
    max-width: none !important;
    min-width: 100% !important;
    white-space: nowrap !important;
    -webkit-line-clamp: unset !important;
    -webkit-box-orient: initial !important;
    text-overflow: clip !important;
    animation: nv-card-marquee-scroll 5.5s ease-in-out infinite alternate !important;
}

@keyframes nv-card-marquee-scroll {
    from { transform: translateX(0); }
    to { transform: translateX(var(--nv-card-marquee-distance, -42px)); }
}

.nv-plugin-showcase-card .nv-asset-signal--card {
    display: block !important;
    align-self: stretch !important;
    width: 100% !important;
    max-width: 100% !important;
    height: 29px !important;
    min-height: 29px !important;
    max-height: 29px !important;
    margin: 0 !important;
    overflow: hidden !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-grid {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    align-items: stretch !important;
    justify-content: stretch !important;
    gap: 6px !important;
    width: 100% !important;
    max-width: 100% !important;
    height: 29px !important;
    min-height: 29px !important;
    max-height: 29px !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: hidden !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-metric {
    display: inline-flex !important;
    flex-direction: row !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 7px !important;
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
    height: 29px !important;
    min-height: 29px !important;
    max-height: 29px !important;
    padding: 0 9px !important;
    border-radius: 4px !important;
    background: rgba(255, 255, 255, 0.018) !important;
    border: 1px solid rgba(255, 255, 255, 0.038) !important;
    box-shadow: inset 0 0 0 1px rgba(0, 0, 0, 0.16) !important;
    outline: 0 !important;
    overflow: hidden !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-metric:hover {
    background: rgba(255, 255, 255, 0.026) !important;
    border-color: rgba(255, 255, 255, 0.055) !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-metric::before,
.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-metric::after {
    display: none !important;
    content: none !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-icon {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    flex: 0 0 16px !important;
    width: 16px !important;
    min-width: 16px !important;
    height: 16px !important;
    color: rgba(163, 171, 184, 0.82) !important;
    opacity: 1 !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-ui-icon {
    width: 15px !important;
    min-width: 15px !important;
    height: 15px !important;
    stroke-width: 1.7 !important;
    opacity: 1 !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-ui-icon,
.nv-plugin-showcase-card .nv-asset-signal--card .nv-ui-icon *,
.nv-plugin-showcase-card .nv-asset-signal--card .nv-ui-icon .nv-ui-icon-tone,
.nv-plugin-showcase-card .nv-asset-signal--card .nv-ui-icon .nv-ui-icon-accent,
.nv-plugin-showcase-card .nv-asset-signal--card .nv-ui-icon-download .nv-ui-icon-tone,
.nv-plugin-showcase-card .nv-asset-signal--card .nv-ui-icon-download .nv-ui-icon-accent,
.nv-plugin-showcase-card .nv-asset-signal--card .nv-ui-icon-heart .nv-ui-icon-tone,
.nv-plugin-showcase-card .nv-asset-signal--card .nv-ui-icon-heart .nv-ui-icon-accent {
    stroke: rgba(163, 171, 184, 0.82) !important;
    fill: none !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-copy {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    flex: 0 1 auto !important;
    min-width: 0 !important;
    height: 100% !important;
    gap: 0 !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-copy strong {
    display: inline-block !important;
    max-width: 68px !important;
    margin: 0 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
    color: rgba(223, 229, 238, 0.84) !important;
    font-family: Arial, Helvetica, sans-serif !important;
    font-size: 13.5px !important;
    font-weight: 500 !important;
    line-height: 1 !important;
    letter-spacing: 0.02em !important;
    text-align: center !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-copy small,
.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-copy em {
    display: none !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-chips {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    align-self: stretch !important;
    gap: 6px !important;
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
    height: 28px !important;
    min-height: 28px !important;
    max-height: 28px !important;
    margin: 0 !important;
    overflow: hidden !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-chips span {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
    height: 28px !important;
    min-height: 28px !important;
    max-height: 28px !important;
    padding: 0 10px !important;
    border-radius: 4px !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
    background: rgba(255, 255, 255, 0.020) !important;
    border: 1px solid rgba(255, 255, 255, 0.040) !important;
    box-shadow: inset 0 0 0 1px rgba(0, 0, 0, 0.16) !important;
    color: rgba(202, 210, 223, 0.70) !important;
    font-family: Arial, Helvetica, sans-serif !important;
    font-size: 8.5px !important;
    font-weight: 550 !important;
    line-height: 1 !important;
    letter-spacing: 0.18em !important;
    text-transform: uppercase !important;
}

@media (max-width: 760px) {
    .nv-plugin-showcase-toolbar {
        align-items: stretch !important;
        flex-direction: column !important;
    }

    .nv-plugin-showcase-toolbar .nv-plugin-showcase-filters,
    .nv-plugin-showcase-tools {
        width: 100% !important;
        justify-content: flex-start !important;
        margin-left: 0 !important;
    }

    .nv-plugin-showcase-tools {
        gap: 8px !important;
    }

    .nv-plugin-showcase-card {
        grid-template-rows: 150px minmax(0, 1fr) !important;
        min-height: 404px !important;
        height: 404px !important;
        max-height: 404px !important;
    }

    .nv-plugin-showcase-card .nv-plugin-showcase-card-media {
        height: 150px !important;
        min-height: 150px !important;
        max-height: 150px !important;
    }
}

/* =========================================================
   v1.1.51 - Catalog lower controls collision fix.
   Scope: lower catalog cards + catalog toolbar only. Featured slider/vitrine untouched.
   ========================================================= */

/* Toolbar: reference uses square controls, not pills. */
.nv-plugin-showcase-toolbar .nv-plugin-showcase-filters button,
.nv-plugin-showcase-sort select,
.nv-plugin-showcase-filter-toggle {
    border-radius: 0 !important;
    box-sizing: border-box !important;
}

.nv-plugin-showcase-sort select,
.nv-plugin-showcase-filter-toggle {
    height: 35px !important;
    min-height: 35px !important;
    background: rgba(8, 9, 13, 0.58) !important;
    border-color: rgba(255, 255, 255, 0.07) !important;
}

/* Card content stays in strict vertical slots so long text cannot push metrics/tags down. */
.nv-plugin-showcase-card .nv-plugin-showcase-card-content {
    display: grid !important;
    grid-template-rows: 36px 52px 24px 29px 28px !important;
    row-gap: 8px !important;
    padding: 14px !important;
    min-width: 0 !important;
    overflow: hidden !important;
    box-sizing: border-box !important;
}

.nv-plugin-showcase-card h3.nv-plugin-showcase-marquee,
.nv-plugin-showcase-card .nv-plugin-showcase-subtitle.nv-plugin-showcase-marquee {
    min-width: 0 !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
}

/* Metrics: two independent faint blocks with a real gap. No shared bar, no center divider illusion. */
.nv-plugin-showcase-card .nv-asset-signal--card {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    height: 29px !important;
    min-height: 29px !important;
    max-height: 29px !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: visible !important;
    box-sizing: border-box !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-grid {
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: nowrap !important;
    align-items: stretch !important;
    justify-content: flex-start !important;
    column-gap: 8px !important;
    row-gap: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
    height: 29px !important;
    min-height: 29px !important;
    max-height: 29px !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: visible !important;
    box-sizing: border-box !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-metric {
    display: flex !important;
    flex: 0 1 calc((100% - 8px) / 2) !important;
    width: calc((100% - 8px) / 2) !important;
    min-width: 0 !important;
    max-width: calc((100% - 8px) / 2) !important;
    height: 29px !important;
    min-height: 29px !important;
    max-height: 29px !important;
    box-sizing: border-box !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px !important;
    padding: 0 8px !important;
    border-radius: 2px !important;
    background: rgba(255, 255, 255, 0.018) !important;
    border: 1px solid rgba(255, 255, 255, 0.036) !important;
    box-shadow: inset 0 0 0 1px rgba(0, 0, 0, 0.14) !important;
    outline: 0 !important;
    overflow: hidden !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-metric::before,
.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-metric::after {
    display: none !important;
    content: none !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-icon {
    display: flex !important;
    flex: 0 0 15px !important;
    width: 15px !important;
    min-width: 15px !important;
    height: 15px !important;
    min-height: 15px !important;
    align-items: center !important;
    justify-content: center !important;
    color: rgba(165, 173, 186, 0.78) !important;
    opacity: 1 !important;
    line-height: 1 !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-ui-icon {
    display: block !important;
    width: 15px !important;
    min-width: 15px !important;
    height: 15px !important;
    min-height: 15px !important;
    stroke-width: 1.65 !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-ui-icon,
.nv-plugin-showcase-card .nv-asset-signal--card .nv-ui-icon *,
.nv-plugin-showcase-card .nv-asset-signal--card .nv-ui-icon .nv-ui-icon-tone,
.nv-plugin-showcase-card .nv-asset-signal--card .nv-ui-icon .nv-ui-icon-accent,
.nv-plugin-showcase-card .nv-asset-signal--card .nv-ui-icon-download .nv-ui-icon-tone,
.nv-plugin-showcase-card .nv-asset-signal--card .nv-ui-icon-download .nv-ui-icon-accent,
.nv-plugin-showcase-card .nv-asset-signal--card .nv-ui-icon-heart .nv-ui-icon-tone,
.nv-plugin-showcase-card .nv-asset-signal--card .nv-ui-icon-heart .nv-ui-icon-accent {
    stroke: rgba(165, 173, 186, 0.78) !important;
    fill: none !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-copy {
    display: flex !important;
    flex: 0 1 auto !important;
    min-width: 0 !important;
    height: 100% !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 0 !important;
    line-height: 1 !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-copy strong {
    display: block !important;
    max-width: 58px !important;
    margin: 0 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
    color: rgba(219, 225, 235, 0.82) !important;
    font-family: Arial, Helvetica, sans-serif !important;
    font-size: 13.5px !important;
    font-weight: 500 !important;
    line-height: 1 !important;
    letter-spacing: 0 !important;
    text-align: center !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-copy small,
.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-copy em {
    display: none !important;
}

/* Chips: same two-block behavior as metrics. Real column gap prevents visual collision. */
.nv-plugin-showcase-card .nv-plugin-showcase-chips {
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: nowrap !important;
    align-items: stretch !important;
    justify-content: flex-start !important;
    column-gap: 8px !important;
    row-gap: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    height: 28px !important;
    min-height: 28px !important;
    max-height: 28px !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: visible !important;
    box-sizing: border-box !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-chips span {
    display: flex !important;
    flex: 0 1 calc((100% - 8px) / 2) !important;
    width: calc((100% - 8px) / 2) !important;
    min-width: 0 !important;
    max-width: calc((100% - 8px) / 2) !important;
    height: 28px !important;
    min-height: 28px !important;
    max-height: 28px !important;
    box-sizing: border-box !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 0 9px !important;
    border-radius: 2px !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
    background: rgba(255, 255, 255, 0.020) !important;
    border: 1px solid rgba(255, 255, 255, 0.038) !important;
    box-shadow: inset 0 0 0 1px rgba(0, 0, 0, 0.14) !important;
    color: rgba(202, 210, 223, 0.70) !important;
    font-family: Arial, Helvetica, sans-serif !important;
    font-size: 8.5px !important;
    font-weight: 540 !important;
    line-height: 1 !important;
    letter-spacing: 0.13em !important;
    text-transform: uppercase !important;
}

@media (max-width: 420px) {
    .nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-grid,
    .nv-plugin-showcase-card .nv-plugin-showcase-chips {
        column-gap: 6px !important;
    }

    .nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-metric,
    .nv-plugin-showcase-card .nv-plugin-showcase-chips span {
        flex-basis: calc((100% - 6px) / 2) !important;
        width: calc((100% - 6px) / 2) !important;
        max-width: calc((100% - 6px) / 2) !important;
    }
}

/* =========================================================
   v1.1.52 - Catalog metrics subtle pass + working filters/favorites.
   Scope: lower catalog cards and catalog toolbar only. Featured slider/vitrine untouched.
   ========================================================= */

.nv-plugin-showcase-card .nv-plugin-showcase-card-media::before {
    display: none !important;
    content: none !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-metric {
    background: rgba(255, 255, 255, 0.010) !important;
    border-color: rgba(255, 255, 255, 0.024) !important;
    box-shadow: inset 0 0 0 1px rgba(0, 0, 0, 0.18) !important;
    border-radius: 2px !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-metric:hover {
    background: rgba(255, 255, 255, 0.018) !important;
    border-color: rgba(255, 255, 255, 0.042) !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-icon {
    flex-basis: 18px !important;
    width: 18px !important;
    min-width: 18px !important;
    height: 18px !important;
    min-height: 18px !important;
    color: rgba(172, 180, 192, 0.86) !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-ui-icon {
    width: 17px !important;
    min-width: 17px !important;
    height: 17px !important;
    min-height: 17px !important;
    stroke-width: 1.7 !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-ui-icon,
.nv-plugin-showcase-card .nv-asset-signal--card .nv-ui-icon *,
.nv-plugin-showcase-card .nv-asset-signal--card .nv-ui-icon .nv-ui-icon-tone,
.nv-plugin-showcase-card .nv-asset-signal--card .nv-ui-icon .nv-ui-icon-accent,
.nv-plugin-showcase-card .nv-asset-signal--card .nv-ui-icon-download .nv-ui-icon-tone,
.nv-plugin-showcase-card .nv-asset-signal--card .nv-ui-icon-download .nv-ui-icon-accent,
.nv-plugin-showcase-card .nv-asset-signal--card .nv-ui-icon-heart .nv-ui-icon-tone,
.nv-plugin-showcase-card .nv-asset-signal--card .nv-ui-icon-heart .nv-ui-icon-accent {
    stroke: rgba(172, 180, 192, 0.86) !important;
    fill: none !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-copy strong {
    color: rgba(224, 230, 239, 0.82) !important;
}

.nv-plugin-showcase-favorite-button {
    position: absolute !important;
    top: 9px !important;
    right: 9px !important;
    z-index: 24 !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 24px !important;
    height: 24px !important;
    padding: 0 !important;
    margin: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    color: rgba(235, 239, 247, 0.92) !important;
    cursor: pointer !important;
    opacity: 0.95 !important;
    line-height: 1 !important;
    transform: none !important;
}

.nv-plugin-showcase-favorite-button .nv-ui-icon {
    display: none !important;
}

.nv-plugin-showcase-favorite-button::before {
    content: "♡" !important;
    display: block !important;
    color: rgba(235, 239, 247, 0.92) !important;
    font-family: Arial, Helvetica, sans-serif !important;
    font-size: 22px !important;
    font-weight: 400 !important;
    line-height: 1 !important;
    text-shadow: 0 0 8px rgba(0, 0, 0, 0.72) !important;
}

.nv-plugin-showcase-favorite-button:hover::before,
.nv-plugin-showcase-favorite-button:focus-visible::before {
    content: "♥" !important;
    color: rgba(255, 78, 78, 0.94) !important;
    text-shadow: 0 0 12px rgba(255, 24, 24, 0.34) !important;
}

.nv-plugin-showcase-favorite-button.is-active::before,
.nv-plugin-showcase-card.is-favorite .nv-plugin-showcase-favorite-button::before {
    content: "♥" !important;
    color: rgba(255, 48, 48, 0.98) !important;
    text-shadow: 0 0 13px rgba(255, 24, 24, 0.42) !important;
}

.nv-plugin-showcase-toolbar {
    position: relative !important;
}

.nv-plugin-showcase-filter-toggle.is-active {
    border-color: rgba(255, 48, 48, 0.24) !important;
    background: rgba(255, 255, 255, 0.045) !important;
}

.nv-plugin-showcase-filter-panel {
    position: absolute !important;
    right: 0 !important;
    top: calc(100% + 8px) !important;
    z-index: 60 !important;
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 7px !important;
    width: 190px !important;
    padding: 9px !important;
    background: rgba(8, 9, 13, 0.94) !important;
    border: 1px solid rgba(255, 255, 255, 0.07) !important;
    box-shadow: 0 18px 44px rgba(0, 0, 0, 0.42) !important;
}

.nv-plugin-showcase-filter-panel[hidden] {
    display: none !important;
}

.nv-plugin-showcase-filter-panel button {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    width: 100% !important;
    height: 30px !important;
    padding: 0 10px !important;
    border-radius: 0 !important;
    border: 1px solid rgba(255, 255, 255, 0.055) !important;
    background: rgba(255, 255, 255, 0.018) !important;
    color: rgba(214, 220, 232, 0.78) !important;
    font-family: Arial, Helvetica, sans-serif !important;
    font-size: 9px !important;
    font-weight: 750 !important;
    line-height: 1 !important;
    letter-spacing: 0.12em !important;
    text-transform: uppercase !important;
    cursor: pointer !important;
}

.nv-plugin-showcase-filter-panel button::after {
    content: "" !important;
    width: 7px !important;
    height: 7px !important;
    border: 1px solid rgba(255, 255, 255, 0.18) !important;
    background: transparent !important;
}

.nv-plugin-showcase-filter-panel button.is-active {
    border-color: rgba(255, 48, 48, 0.28) !important;
    color: rgba(245, 247, 251, 0.90) !important;
    background: rgba(255, 48, 48, 0.055) !important;
}

.nv-plugin-showcase-filter-panel button.is-active::after {
    background: rgba(255, 48, 48, 0.92) !important;
    border-color: rgba(255, 48, 48, 0.92) !important;
}

.nv-plugin-showcase-filter-panel .nv-plugin-showcase-filter-clear {
    margin-top: 2px !important;
    color: rgba(255, 88, 88, 0.88) !important;
}

.nv-plugin-showcase-filter-panel .nv-plugin-showcase-filter-clear::after {
    display: none !important;
}

@media (max-width: 760px) {
    .nv-plugin-showcase-filter-panel {
        position: relative !important;
        top: auto !important;
        right: auto !important;
        width: 100% !important;
        grid-column: 1 / -1 !important;
        margin-top: 8px !important;
    }
}

.nv-plugin-showcase-toolbar {
    z-index: 40 !important;
}

/* =========================================================
   v1.1.53 - Catalog metric faintness + reliable sort/marquee behavior.
   Scope: lower catalog cards and catalog toolbar only. Featured slider untouched.
   ========================================================= */

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-metric {
    background: rgba(255, 255, 255, 0.004) !important;
    border-color: rgba(255, 255, 255, 0.014) !important;
    box-shadow: none !important;
    opacity: 0.94 !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-metric:hover,
.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-metric:focus-within {
    background: rgba(255, 255, 255, 0.012) !important;
    border-color: rgba(255, 255, 255, 0.032) !important;
    opacity: 1 !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-icon {
    flex-basis: 20px !important;
    width: 20px !important;
    min-width: 20px !important;
    height: 20px !important;
    min-height: 20px !important;
    color: rgba(174, 182, 194, 0.84) !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-ui-icon {
    width: 19px !important;
    min-width: 19px !important;
    height: 19px !important;
    min-height: 19px !important;
    stroke-width: 1.58 !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-ui-icon,
.nv-plugin-showcase-card .nv-asset-signal--card .nv-ui-icon *,
.nv-plugin-showcase-card .nv-asset-signal--card .nv-ui-icon .nv-ui-icon-tone,
.nv-plugin-showcase-card .nv-asset-signal--card .nv-ui-icon .nv-ui-icon-accent,
.nv-plugin-showcase-card .nv-asset-signal--card .nv-ui-icon-download .nv-ui-icon-tone,
.nv-plugin-showcase-card .nv-asset-signal--card .nv-ui-icon-download .nv-ui-icon-accent,
.nv-plugin-showcase-card .nv-asset-signal--card .nv-ui-icon-heart .nv-ui-icon-tone,
.nv-plugin-showcase-card .nv-asset-signal--card .nv-ui-icon-heart .nv-ui-icon-accent {
    stroke: rgba(174, 182, 194, 0.84) !important;
    fill: none !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-copy strong {
    color: rgba(226, 231, 240, 0.80) !important;
}

.nv-plugin-showcase-sort select option {
    background: #17191f !important;
    color: rgba(240, 243, 248, 0.88) !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-marquee:not(.is-overflowing) > span {
    animation: none !important;
    transform: none !important;
}

/* =========================================================
   v1.1.54 - Featured slider responsive sizing fix.
   Scope: featured signal-panel only. Keeps desktop visual intact,
   but lets the hero collapse cleanly on tablet/mobile widths.
   ========================================================= */

.nv-plugin-showcase,
.nv-plugin-showcase-shell,
.nv-plugin-showcase-steam-featured,
.nv-plugin-showcase-steam-stage,
.nv-plugin-showcase-steam-slide,
.nv-plugin-showcase-steam-link,
.nv-plugin-showcase-steam-media-wrap,
.nv-plugin-showcase-steam-copy {
    max-width: 100% !important;
    box-sizing: border-box !important;
}

.nv-plugin-showcase {
    overflow-x: clip !important;
}

@media (max-width: 1120px) {
    .nv-plugin-showcase-steam-featured--signal-panel {
        width: 100% !important;
        min-width: 0 !important;
        margin-left: 0 !important;
        margin-right: 0 !important;
    }

    .nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-stage {
        width: 100% !important;
        min-width: 0 !important;
        min-height: 0 !important;
        height: auto !important;
        max-height: none !important;
        aspect-ratio: auto !important;
        overflow: hidden !important;
    }

    .nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-slide {
        position: relative !important;
        inset: auto !important;
        width: 100% !important;
        min-width: 0 !important;
        height: auto !important;
        min-height: 0 !important;
        display: none !important;
        padding: 0 !important;
        opacity: 0 !important;
        pointer-events: none !important;
        overflow: hidden !important;
        transform: none !important;
    }

    .nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-slide.is-active {
        display: block !important;
        opacity: 1 !important;
        pointer-events: auto !important;
    }

    .nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-link {
        position: relative !important;
        inset: auto !important;
        display: grid !important;
        grid-template-columns: minmax(0, 1fr) !important;
        grid-template-rows: auto auto !important;
        width: 100% !important;
        min-width: 0 !important;
        height: auto !important;
        min-height: 0 !important;
        overflow: hidden !important;
    }

    .nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-media-wrap {
        width: 100% !important;
        min-width: 0 !important;
        height: auto !important;
        min-height: 0 !important;
        aspect-ratio: 16 / 9 !important;
        padding: 0 !important;
        overflow: hidden !important;
    }

    .nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-media-wrap::after {
        display: none !important;
        content: none !important;
    }

    .nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-featured-media {
        width: 100% !important;
        height: 100% !important;
        min-width: 0 !important;
        min-height: 0 !important;
        max-height: none !important;
        aspect-ratio: auto !important;
    }

    .nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-featured-media .nv-plugin-showcase-poster,
    .nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-featured-media .nv-plugin-showcase-preview-video,
    .nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-featured-media .nv-plugin-showcase-preview-youtube {
        width: 100% !important;
        height: 100% !important;
        object-fit: cover !important;
        object-position: center center !important;
    }

    .nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-copy {
        position: relative !important;
        width: 100% !important;
        min-width: 0 !important;
        height: auto !important;
        min-height: 0 !important;
        max-height: none !important;
        padding: clamp(18px, 4.4vw, 28px) !important;
        gap: clamp(10px, 2vw, 14px) !important;
        overflow: hidden !important;
        transform: none !important;
    }

    .nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-copy h2,
    .nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured,
    .nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-proof {
        transform: none !important;
    }

    .nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-copy h2 {
        margin: 0 0 2px !important;
        max-width: 100% !important;
        max-height: none !important;
        font-size: clamp(21px, 4.2vw, 32px) !important;
        line-height: 1.04 !important;
        -webkit-line-clamp: 2 !important;
    }

    .nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured {
        margin: 0 !important;
    }

    .nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
        gap: 10px !important;
        width: 100% !important;
    }

    .nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-metric {
        min-width: 0 !important;
        width: auto !important;
        max-width: none !important;
    }

    .nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-proof {
        margin: 0 !important;
        padding: 0 0 28px !important;
        gap: 10px !important;
        overflow: hidden !important;
    }

    .nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-footer {
        right: clamp(18px, 4.4vw, 28px) !important;
        bottom: 14px !important;
    }

    .nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-nav {
        top: clamp(92px, 24vw, 220px) !important;
        width: 44px !important;
        height: 74px !important;
        font-size: 42px !important;
        transform: translateY(-50%) !important;
    }
}

@media (max-width: 700px) {
    .nv-plugin-showcase-shell {
        padding: clamp(18px, 5vw, 26px) !important;
    }

    .nv-plugin-showcase-head {
        grid-template-columns: 1fr !important;
        gap: 18px !important;
        margin-bottom: 22px !important;
    }

    .nv-plugin-showcase h1 {
        font-size: clamp(48px, 14vw, 74px) !important;
    }

    .nv-plugin-showcase-lead {
        font-size: 14px !important;
        line-height: 1.55 !important;
    }

    .nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-copy {
        padding: 18px !important;
    }

    .nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-grid {
        gap: 8px !important;
    }

    .nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-metric {
        min-height: 42px !important;
        max-height: none !important;
        padding: 7px 9px !important;
        grid-template-columns: 20px minmax(0, 1fr) !important;
        gap: 8px !important;
    }

    .nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-ui-icon {
        width: 18px !important;
        height: 18px !important;
    }

    .nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-proof {
        padding-bottom: 24px !important;
    }

    .nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-proof-item {
        min-height: 30px !important;
        grid-template-columns: 24px minmax(0, 1fr) !important;
        column-gap: 9px !important;
    }

    .nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-proof-item > span {
        width: 24px !important;
        height: 24px !important;
    }

    .nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-proof-item .nv-ui-icon {
        width: 18px !important;
        height: 18px !important;
    }

    .nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-footer {
        right: 18px !important;
        bottom: 12px !important;
    }

    .nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-nav {
        top: clamp(86px, 24vw, 150px) !important;
        width: 38px !important;
        height: 64px !important;
        font-size: 36px !important;
    }

    .nv-plugin-showcase-steam-dots button {
        width: 36px !important;
        height: 7px !important;
    }
}

@media (max-width: 460px) {
    .nv-plugin-showcase {
        padding-left: 12px !important;
        padding-right: 12px !important;
    }

    .nv-plugin-showcase-shell {
        padding: 14px !important;
    }

    .nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-grid {
        grid-template-columns: 1fr !important;
    }

    .nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-proof {
        display: none !important;
    }

    .nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-footer {
        position: static !important;
        display: flex !important;
        justify-content: flex-start !important;
        min-width: 0 !important;
        height: auto !important;
        min-height: 0 !important;
        margin-top: 4px !important;
    }
}


/* =========================================================
   v1.1.55 - Featured title clamp + stronger featured metric text/icons.
   Scope: featured signal-panel only. Catalog card metrics/chips are untouched.
   ========================================================= */
.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-copy h2 {
    display: -webkit-box !important;
    -webkit-box-orient: vertical !important;
    -webkit-line-clamp: 2 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    max-height: none !important;
    height: auto !important;
    min-height: 0 !important;
    padding: 0 0 3px !important;
    line-height: 1.14 !important;
    word-break: normal !important;
    overflow-wrap: normal !important;
    hyphens: none !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-metric {
    grid-template-columns: 28px minmax(0, 1fr) !important;
    align-items: center !important;
    gap: 12px !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-icon {
    width: 28px !important;
    height: 28px !important;
    min-width: 28px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-ui-icon {
    width: 23px !important;
    height: 23px !important;
    min-width: 23px !important;
    stroke-width: 1.7 !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-copy {
    gap: 4px !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-copy strong {
    font-size: clamp(17px, 1.18vw, 20px) !important;
    font-weight: 600 !important;
    line-height: 1 !important;
    letter-spacing: -0.01em !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-copy small {
    font-size: 8.8px !important;
    font-weight: 950 !important;
    line-height: 1 !important;
    letter-spacing: 0.17em !important;
}

@media (max-width: 1120px) {
    .nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-copy h2 {
        display: -webkit-box !important;
        -webkit-box-orient: vertical !important;
        -webkit-line-clamp: 2 !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
        max-height: none !important;
        padding-bottom: 3px !important;
        line-height: 1.15 !important;
    }

    .nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-metric {
        grid-template-columns: 28px minmax(0, 1fr) !important;
        min-height: 54px !important;
        padding: 9px 12px !important;
        gap: 12px !important;
    }

    .nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-ui-icon {
        width: 23px !important;
        height: 23px !important;
        min-width: 23px !important;
    }

    .nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-copy strong {
        font-size: clamp(16px, 3.1vw, 19px) !important;
    }

    .nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-copy small {
        font-size: 8.5px !important;
    }
}

@media (max-width: 700px) {
    .nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-metric {
        min-height: 52px !important;
        grid-template-columns: 27px minmax(0, 1fr) !important;
        gap: 11px !important;
    }

    .nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-ui-icon {
        width: 22px !important;
        height: 22px !important;
        min-width: 22px !important;
    }

    .nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-copy strong {
        font-size: 16px !important;
    }

    .nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-copy small {
        font-size: 8px !important;
        letter-spacing: 0.16em !important;
    }
}


/* =========================================================
   v1.1.56 - Featured title horizontal ellipsis + larger featured metrics.
   Scope: featured signal-panel only. Catalog cards untouched.
   ========================================================= */
.nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-copy h2 {
    display: block !important;
    -webkit-box-orient: initial !important;
    -webkit-line-clamp: initial !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    max-width: 100% !important;
    width: 100% !important;
    max-height: none !important;
    height: auto !important;
    min-height: 0 !important;
    padding: 0 !important;
    margin: 0 0 4px !important;
    line-height: 1.22 !important;
    box-sizing: border-box !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-grid {
    gap: 12px !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-metric {
    grid-template-columns: 32px minmax(0, 1fr) !important;
    align-items: center !important;
    min-height: 64px !important;
    padding: 10px 15px !important;
    gap: 13px !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-icon {
    width: 32px !important;
    height: 32px !important;
    min-width: 32px !important;
    min-height: 32px !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-ui-icon {
    width: 26px !important;
    height: 26px !important;
    min-width: 26px !important;
    min-height: 26px !important;
    stroke-width: 1.85 !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-copy {
    align-items: center !important;
    justify-content: center !important;
    gap: 5px !important;
    min-width: 0 !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-copy strong {
    font-size: clamp(20px, 1.35vw, 23px) !important;
    font-weight: 650 !important;
    line-height: 1 !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-copy small {
    font-size: 9.8px !important;
    font-weight: 950 !important;
    line-height: 1 !important;
    letter-spacing: 0.18em !important;
}

@media (max-width: 1120px) {
    .nv-plugin-showcase-steam-featured--signal-panel .nv-plugin-showcase-steam-copy h2 {
        display: block !important;
        white-space: nowrap !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
        line-height: 1.22 !important;
        padding: 0 !important;
        margin-bottom: 4px !important;
    }

    .nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-metric {
        grid-template-columns: 31px minmax(0, 1fr) !important;
        min-height: 60px !important;
        padding: 10px 13px !important;
        gap: 12px !important;
    }

    .nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-ui-icon {
        width: 25px !important;
        height: 25px !important;
        min-width: 25px !important;
        min-height: 25px !important;
    }

    .nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-copy strong {
        font-size: clamp(19px, 3.3vw, 22px) !important;
    }

    .nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-copy small {
        font-size: 9.2px !important;
    }
}

@media (max-width: 700px) {
    .nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-metric {
        min-height: 56px !important;
        grid-template-columns: 29px minmax(0, 1fr) !important;
        padding: 9px 11px !important;
        gap: 10px !important;
    }

    .nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-ui-icon {
        width: 24px !important;
        height: 24px !important;
        min-width: 24px !important;
        min-height: 24px !important;
    }

    .nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-copy strong {
        font-size: 19px !important;
    }

    .nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-copy small {
        font-size: 8.8px !important;
    }
}


/* =========================================================
   v1.1.57 - Featured metric copy alignment + tighter vertical metric cells.
   Scope: featured signal-panel only. Catalog cards untouched.
   ========================================================= */
.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-title {
    margin-bottom: 7px !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-grid {
    gap: 10px !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-metric {
    min-height: 52px !important;
    height: 52px !important;
    padding: 7px 12px !important;
    grid-template-columns: 27px minmax(0, 1fr) !important;
    align-items: center !important;
    gap: 10px !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-icon {
    width: 27px !important;
    height: 27px !important;
    min-width: 27px !important;
    min-height: 27px !important;
    justify-self: center !important;
    align-self: center !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-ui-icon {
    width: 23px !important;
    height: 23px !important;
    min-width: 23px !important;
    min-height: 23px !important;
    stroke-width: 1.8 !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-copy {
    min-width: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-start !important;
    justify-content: center !important;
    text-align: left !important;
    gap: 2px !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-copy strong {
    order: 1 !important;
    display: block !important;
    width: 100% !important;
    margin: 0 !important;
    text-align: left !important;
    font-size: clamp(19px, 1.25vw, 22px) !important;
    font-weight: 700 !important;
    line-height: .95 !important;
    letter-spacing: -0.02em !important;
}

.nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-copy small {
    order: 2 !important;
    display: block !important;
    width: 100% !important;
    margin: 0 !important;
    text-align: left !important;
    font-size: 8.8px !important;
    font-weight: 950 !important;
    line-height: 1 !important;
    letter-spacing: .16em !important;
}

@media (max-width: 1120px) {
    .nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-metric {
        min-height: 50px !important;
        height: 50px !important;
        padding: 7px 11px !important;
        grid-template-columns: 26px minmax(0, 1fr) !important;
        gap: 9px !important;
    }

    .nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-icon {
        width: 26px !important;
        height: 26px !important;
        min-width: 26px !important;
        min-height: 26px !important;
    }

    .nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-ui-icon {
        width: 22px !important;
        height: 22px !important;
        min-width: 22px !important;
        min-height: 22px !important;
    }

    .nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-copy strong {
        font-size: clamp(18px, 3vw, 21px) !important;
    }

    .nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-copy small {
        font-size: 8.3px !important;
    }
}

@media (max-width: 700px) {
    .nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-metric {
        min-height: 48px !important;
        height: 48px !important;
        padding: 7px 10px !important;
        grid-template-columns: 25px minmax(0, 1fr) !important;
        gap: 8px !important;
    }

    .nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-icon {
        width: 25px !important;
        height: 25px !important;
        min-width: 25px !important;
        min-height: 25px !important;
    }

    .nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-ui-icon {
        width: 21px !important;
        height: 21px !important;
        min-width: 21px !important;
        min-height: 21px !important;
    }

    .nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-copy strong {
        font-size: 18px !important;
    }

    .nv-plugin-showcase-steam-featured--signal-panel .nv-asset-signal--featured .nv-asset-signal-copy small {
        font-size: 8px !important;
        letter-spacing: .15em !important;
    }
}


/* v1.1.60 - Favorites visual states and local counters. */
.nv-plugin-showcase-favorite-button {
    overflow: visible !important;
    width: 28px !important;
    height: 28px !important;
    color: rgba(238, 242, 250, 0.94) !important;
    transition: transform 140ms ease, opacity 140ms ease !important;
}

.nv-plugin-showcase-favorite-button::before {
    content: "♡" !important;
    color: rgba(238, 242, 250, 0.94) !important;
    font-size: 24px !important;
    line-height: 1 !important;
    text-shadow: 0 0 9px rgba(0, 0, 0, 0.74) !important;
    transition: color 140ms ease, text-shadow 140ms ease, transform 140ms ease !important;
}

.nv-plugin-showcase-favorite-button:hover::before,
.nv-plugin-showcase-favorite-button:focus-visible::before {
    content: "♥" !important;
    color: rgba(255, 58, 58, 0.98) !important;
    text-shadow: 0 0 14px rgba(255, 20, 20, 0.42) !important;
    transform: scale(1.08) !important;
}

.nv-plugin-showcase-favorite-button.is-active::before,
.nv-plugin-showcase-card.is-favorite .nv-plugin-showcase-favorite-button::before {
    content: "♥" !important;
    color: rgba(245, 248, 255, 0.98) !important;
    text-shadow: 0 0 10px rgba(255, 255, 255, 0.26), 0 0 12px rgba(0, 0, 0, 0.64) !important;
    transform: none !important;
}

.nv-plugin-showcase-favorite-button.is-active:hover::before,
.nv-plugin-showcase-favorite-button.is-active:focus-visible::before,
.nv-plugin-showcase-card.is-favorite .nv-plugin-showcase-favorite-button:hover::before,
.nv-plugin-showcase-card.is-favorite .nv-plugin-showcase-favorite-button:focus-visible::before {
    content: "♥" !important;
    color: rgba(255, 58, 58, 0.98) !important;
    text-shadow: 0 0 14px rgba(255, 20, 20, 0.46) !important;
    transform: scale(1.08) !important;
}

.nv-plugin-showcase-favorite-count {
    position: absolute !important;
    top: -5px !important;
    right: -7px !important;
    display: none !important;
    min-width: 14px !important;
    height: 14px !important;
    padding: 0 4px !important;
    border: 1px solid rgba(255, 255, 255, 0.14) !important;
    border-radius: 999px !important;
    background: rgba(255, 42, 42, 0.92) !important;
    color: rgba(255, 255, 255, 0.98) !important;
    font-family: Inter, Arial, sans-serif !important;
    font-size: 9px !important;
    font-weight: 800 !important;
    line-height: 13px !important;
    letter-spacing: 0 !important;
    text-align: center !important;
    box-shadow: 0 0 10px rgba(255, 20, 20, 0.32), 0 4px 12px rgba(0, 0, 0, 0.36) !important;
    pointer-events: none !important;
}

.nv-plugin-showcase-favorite-button.is-active .nv-plugin-showcase-favorite-count,
.nv-plugin-showcase-card.is-favorite .nv-plugin-showcase-favorite-count {
    display: block !important;
}

.nv-plugin-showcase-filter-count {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-width: 18px !important;
    height: 16px !important;
    margin-left: 7px !important;
    padding: 0 5px !important;
    border: 1px solid rgba(255, 255, 255, 0.08) !important;
    border-radius: 999px !important;
    background: rgba(255, 255, 255, 0.055) !important;
    color: rgba(235, 239, 247, 0.74) !important;
    font-size: 10px !important;
    font-weight: 800 !important;
    line-height: 1 !important;
}

.nv-plugin-showcase-filter-panel button.is-active .nv-plugin-showcase-filter-count,
.nv-plugin-showcase-filter-count.has-favorites {
    background: rgba(255, 48, 48, 0.16) !important;
    border-color: rgba(255, 48, 48, 0.24) !important;
    color: rgba(255, 226, 226, 0.96) !important;
}


/* v1.1.61 - Separate local favorites from Fab wishlist metrics.
   Top-right heart = local favorite. Bottom wishlist metric = Fab wishlist count. */
.nv-plugin-showcase-card .nv-asset-signal-metric--wishlists .nv-ui-icon-bookmark,
.nv-plugin-showcase-card .nv-asset-signal-metric--wishlists .nv-ui-icon-bookmark *,
.nv-plugin-showcase-card .nv-asset-signal-metric--wishlists .nv-ui-icon-bookmark .nv-ui-icon-tone,
.nv-plugin-showcase-card .nv-asset-signal-metric--wishlists .nv-ui-icon-bookmark .nv-ui-icon-accent {
    stroke: rgba(174, 182, 194, 0.84) !important;
    fill: none !important;
}

.nv-plugin-showcase-card .nv-asset-signal-metric--wishlists .nv-asset-signal-icon {
    color: rgba(174, 182, 194, 0.84) !important;
}

.nv-plugin-showcase-card .nv-asset-signal-metric--wishlists .nv-ui-icon-bookmark {
    width: 18px !important;
    height: 18px !important;
    stroke-width: 1.62 !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button .nv-ui-icon {
    display: none !important;
}


/* v1.1.62 - Swap visual meanings back:
   top-right bookmark = local site favorite, bottom heart = Fab wishlists. */
.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button::before {
    display: none !important;
    content: none !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button .nv-ui-icon,
.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button .nv-ui-icon-bookmark {
    display: block !important;
    width: 23px !important;
    height: 23px !important;
    min-width: 23px !important;
    min-height: 23px !important;
    stroke-width: 1.7 !important;
    transition: transform 140ms ease, filter 140ms ease !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button .nv-ui-icon-bookmark,
.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button .nv-ui-icon-bookmark *,
.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button .nv-ui-icon-bookmark .nv-ui-icon-tone,
.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button .nv-ui-icon-bookmark .nv-ui-icon-accent {
    stroke: rgba(238, 242, 250, 0.95) !important;
    fill: none !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button:hover .nv-ui-icon-bookmark,
.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button:focus-visible .nv-ui-icon-bookmark {
    transform: scale(1.08) !important;
    filter: drop-shadow(0 0 10px rgba(255, 20, 20, 0.36)) !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button:hover .nv-ui-icon-bookmark,
.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button:hover .nv-ui-icon-bookmark *,
.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button:hover .nv-ui-icon-bookmark .nv-ui-icon-tone,
.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button:hover .nv-ui-icon-bookmark .nv-ui-icon-accent,
.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button:focus-visible .nv-ui-icon-bookmark,
.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button:focus-visible .nv-ui-icon-bookmark *,
.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button:focus-visible .nv-ui-icon-bookmark .nv-ui-icon-tone,
.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button:focus-visible .nv-ui-icon-bookmark .nv-ui-icon-accent {
    stroke: rgba(255, 58, 58, 0.98) !important;
    fill: none !important;
}

.nv-plugin-showcase-card.is-favorite .nv-plugin-showcase-favorite-button .nv-ui-icon-bookmark .nv-ui-icon-tone,
.nv-plugin-showcase-card.is-favorite .nv-plugin-showcase-favorite-button .nv-ui-icon-bookmark .nv-ui-icon-accent,
.nv-plugin-showcase-card.is-favorite .nv-plugin-showcase-favorite-button .nv-ui-icon-bookmark *,
.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button.is-active .nv-ui-icon-bookmark .nv-ui-icon-tone,
.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button.is-active .nv-ui-icon-bookmark .nv-ui-icon-accent,
.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button.is-active .nv-ui-icon-bookmark * {
    stroke: rgba(245, 248, 255, 0.98) !important;
    fill: rgba(245, 248, 255, 0.20) !important;
}

.nv-plugin-showcase-card.is-favorite .nv-plugin-showcase-favorite-button:hover .nv-ui-icon-bookmark .nv-ui-icon-tone,
.nv-plugin-showcase-card.is-favorite .nv-plugin-showcase-favorite-button:hover .nv-ui-icon-bookmark .nv-ui-icon-accent,
.nv-plugin-showcase-card.is-favorite .nv-plugin-showcase-favorite-button:hover .nv-ui-icon-bookmark *,
.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button.is-active:hover .nv-ui-icon-bookmark .nv-ui-icon-tone,
.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button.is-active:hover .nv-ui-icon-bookmark .nv-ui-icon-accent,
.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button.is-active:hover .nv-ui-icon-bookmark * {
    stroke: rgba(255, 58, 58, 0.98) !important;
    fill: rgba(255, 58, 58, 0.22) !important;
}

.nv-plugin-showcase-card .nv-asset-signal-metric--wishlists .nv-ui-icon-heart,
.nv-plugin-showcase-card .nv-asset-signal-metric--wishlists .nv-ui-icon-heart *,
.nv-plugin-showcase-card .nv-asset-signal-metric--wishlists .nv-ui-icon-heart .nv-ui-icon-tone,
.nv-plugin-showcase-card .nv-asset-signal-metric--wishlists .nv-ui-icon-heart .nv-ui-icon-accent {
    stroke: rgba(165, 173, 186, 0.78) !important;
    fill: none !important;
}

.nv-plugin-showcase-card .nv-asset-signal-metric--wishlists .nv-ui-icon-heart {
    width: 18px !important;
    height: 18px !important;
    stroke-width: 1.62 !important;
}


/* v1.1.63 - Make inactive local favorite bookmark muted instead of bright white.
   States: inactive muted gray, hover red, selected white filled, selected hover red filled. */
.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button {
    opacity: 1 !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button .nv-ui-icon-bookmark,
.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button .nv-ui-icon-bookmark *,
.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button .nv-ui-icon-bookmark .nv-ui-icon-tone,
.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button .nv-ui-icon-bookmark .nv-ui-icon-accent {
    stroke: rgba(145, 154, 169, 0.62) !important;
    fill: none !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button:hover .nv-ui-icon-bookmark,
.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button:focus-visible .nv-ui-icon-bookmark {
    transform: scale(1.08) !important;
    filter: drop-shadow(0 0 10px rgba(255, 20, 20, 0.36)) !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button:hover .nv-ui-icon-bookmark,
.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button:hover .nv-ui-icon-bookmark *,
.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button:hover .nv-ui-icon-bookmark .nv-ui-icon-tone,
.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button:hover .nv-ui-icon-bookmark .nv-ui-icon-accent,
.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button:focus-visible .nv-ui-icon-bookmark,
.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button:focus-visible .nv-ui-icon-bookmark *,
.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button:focus-visible .nv-ui-icon-bookmark .nv-ui-icon-tone,
.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button:focus-visible .nv-ui-icon-bookmark .nv-ui-icon-accent {
    stroke: rgba(255, 58, 58, 0.98) !important;
    fill: none !important;
}

.nv-plugin-showcase-card.is-favorite .nv-plugin-showcase-favorite-button .nv-ui-icon-bookmark .nv-ui-icon-tone,
.nv-plugin-showcase-card.is-favorite .nv-plugin-showcase-favorite-button .nv-ui-icon-bookmark .nv-ui-icon-accent,
.nv-plugin-showcase-card.is-favorite .nv-plugin-showcase-favorite-button .nv-ui-icon-bookmark *,
.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button.is-active .nv-ui-icon-bookmark .nv-ui-icon-tone,
.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button.is-active .nv-ui-icon-bookmark .nv-ui-icon-accent,
.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button.is-active .nv-ui-icon-bookmark * {
    stroke: rgba(245, 248, 255, 0.98) !important;
    fill: rgba(245, 248, 255, 0.22) !important;
}

.nv-plugin-showcase-card.is-favorite .nv-plugin-showcase-favorite-button:hover .nv-ui-icon-bookmark .nv-ui-icon-tone,
.nv-plugin-showcase-card.is-favorite .nv-plugin-showcase-favorite-button:hover .nv-ui-icon-bookmark .nv-ui-icon-accent,
.nv-plugin-showcase-card.is-favorite .nv-plugin-showcase-favorite-button:hover .nv-ui-icon-bookmark *,
.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button.is-active:hover .nv-ui-icon-bookmark .nv-ui-icon-tone,
.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button.is-active:hover .nv-ui-icon-bookmark .nv-ui-icon-accent,
.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button.is-active:hover .nv-ui-icon-bookmark * {
    stroke: rgba(255, 58, 58, 0.98) !important;
    fill: rgba(255, 58, 58, 0.24) !important;
}

/* v1.1.64 - Public favorite bookmark counter.
   The badge now shows the shared site-side count, not only the local selected state. */
.nv-plugin-showcase-favorite-count.has-public-favorites,
.nv-plugin-showcase-favorite-button.is-active .nv-plugin-showcase-favorite-count.has-public-favorites,
.nv-plugin-showcase-card.is-favorite .nv-plugin-showcase-favorite-count.has-public-favorites {
    display: block !important;
}

.nv-plugin-showcase-favorite-button[data-nv-plugin-favorite-public-count="0"] .nv-plugin-showcase-favorite-count,
.nv-plugin-showcase-favorite-button:not([data-nv-plugin-favorite-public-count]) .nv-plugin-showcase-favorite-count {
    display: none !important;
}

/* v1.1.65 - rating widget */
.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-metric--rating,
.nv-plugin-showcase-steam-featured .nv-asset-signal--featured .nv-asset-signal-metric--rating,
.nv-asset-signal-rating-widget {
    --nv-rating-accent: #ff8a66;
    --nv-rating-accent-soft: rgba(255, 138, 102, 0.24);
    --nv-rating-glow: rgba(255, 138, 102, 0.26);
    position: relative;
    overflow: hidden;
}

.nv-rating-grade-low {
    --nv-rating-accent: #ff5959;
    --nv-rating-accent-soft: rgba(255, 89, 89, 0.22);
    --nv-rating-glow: rgba(255, 89, 89, 0.28);
}

.nv-rating-grade-mid {
    --nv-rating-accent: #ff9b47;
    --nv-rating-accent-soft: rgba(255, 155, 71, 0.22);
    --nv-rating-glow: rgba(255, 155, 71, 0.28);
}

.nv-rating-grade-high {
    --nv-rating-accent: #67dcff;
    --nv-rating-accent-soft: rgba(103, 220, 255, 0.22);
    --nv-rating-glow: rgba(103, 220, 255, 0.28);
}

.nv-rating-grade-elite {
    --nv-rating-accent: #f7fbff;
    --nv-rating-accent-soft: rgba(247, 251, 255, 0.22);
    --nv-rating-glow: rgba(247, 251, 255, 0.30);
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-metric--rating {
    grid-column: 1 / -1;
    min-height: 72px;
    padding: 12px 14px;
    gap: 14px;
    border-color: rgba(99, 182, 255, 0.28);
    background:
        linear-gradient(135deg, rgba(255, 17, 17, 0.14), rgba(6, 12, 28, 0.92) 40%, rgba(9, 19, 46, 0.96)),
        linear-gradient(180deg, rgba(255,255,255,0.03), rgba(255,255,255,0));
    box-shadow:
        inset 0 0 0 1px rgba(255, 255, 255, 0.03),
        inset 0 0 24px rgba(255, 40, 40, 0.06),
        0 0 18px rgba(0, 0, 0, 0.22);
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-metric--rating::before {
    content: "";
    position: absolute;
    inset: 1px;
    border-radius: inherit;
    pointer-events: none;
    background: linear-gradient(90deg, rgba(255, 24, 24, 0.12), rgba(75, 140, 255, 0.06), rgba(255,255,255,0));
    opacity: 0.9;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-metric--rating:hover {
    border-color: rgba(118, 210, 255, 0.46);
    box-shadow:
        inset 0 0 0 1px rgba(255,255,255,0.04),
        inset 0 0 24px rgba(255, 40, 40, 0.08),
        0 0 0 1px rgba(118, 210, 255, 0.12),
        0 0 24px rgba(103, 220, 255, 0.12);
}

.nv-rating-badge {
    position: relative;
    flex: 0 0 58px;
    width: 58px;
    height: 58px;
    border-radius: 16px;
    background: linear-gradient(180deg, rgba(8, 14, 28, 0.96), rgba(2, 6, 18, 0.98));
    box-shadow:
        inset 0 0 0 1px rgba(255,255,255,0.04),
        inset 0 0 0 2px rgba(255, 24, 24, 0.08),
        0 0 18px rgba(0, 0, 0, 0.24),
        0 0 14px var(--nv-rating-glow);
}

.nv-rating-badge-shell,
.nv-rating-ring-base,
.nv-rating-ring-fill,
.nv-rating-core {
    position: absolute;
    inset: 0;
    border-radius: inherit;
}

.nv-rating-badge-shell::before,
.nv-rating-badge-shell::after {
    content: "";
    position: absolute;
    pointer-events: none;
}

.nv-rating-badge-shell::before {
    inset: 5px;
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 13px;
    box-shadow: inset 0 0 0 1px rgba(255, 14, 14, 0.10);
}

.nv-rating-badge-shell::after {
    left: 50%;
    top: 50%;
    width: 42px;
    height: 42px;
    transform: translate(-50%, -50%) rotate(45deg);
    border: 1px solid rgba(255,255,255,0.06);
    border-radius: 10px;
}

.nv-rating-ring-base,
.nv-rating-ring-fill {
    inset: 10px;
    border-radius: 50%;
    -webkit-mask: radial-gradient(farthest-side, transparent calc(100% - 7px), #000 calc(100% - 6px));
    mask: radial-gradient(farthest-side, transparent calc(100% - 7px), #000 calc(100% - 6px));
}

.nv-rating-ring-base {
    background: conic-gradient(
        from -90deg,
        rgba(255,255,255,0.10) 0deg 60deg,
        transparent 60deg 72deg,
        rgba(255,255,255,0.10) 72deg 132deg,
        transparent 132deg 144deg,
        rgba(255,255,255,0.10) 144deg 204deg,
        transparent 204deg 216deg,
        rgba(255,255,255,0.10) 216deg 276deg,
        transparent 276deg 288deg,
        rgba(255,255,255,0.10) 288deg 348deg,
        transparent 348deg 360deg
    );
}

.nv-rating-ring-fill {
    background: var(--nv-rating-fill-gradient, transparent);
    filter: drop-shadow(0 0 8px var(--nv-rating-glow));
}

.nv-rating-core {
    inset: 18px;
    border-radius: 50%;
    background:
        radial-gradient(circle at 50% 50%, rgba(255,255,255,0.14) 0 10%, transparent 11% 100%),
        linear-gradient(180deg, rgba(255,255,255,0.05), rgba(255,255,255,0));
    box-shadow:
        inset 0 0 0 1px rgba(255,255,255,0.06),
        inset 0 0 12px rgba(255, 20, 20, 0.10);
}

.nv-rating-core::before,
.nv-rating-core::after,
.nv-rating-core i::before,
.nv-rating-core i::after {
    content: "";
    position: absolute;
    left: 50%;
    top: 50%;
    width: 10px;
    height: 1.6px;
    border-radius: 999px;
    background: linear-gradient(90deg, rgba(255,255,255,0.10), var(--nv-rating-accent), rgba(255,255,255,0.18));
    box-shadow: 0 0 8px var(--nv-rating-glow);
    transform-origin: center;
}

.nv-rating-core::before { transform: translate(-50%, -50%) rotate(45deg); }
.nv-rating-core::after { transform: translate(-50%, -50%) rotate(-45deg); }
.nv-rating-core i::before { transform: translate(-50%, -50%) rotate(135deg); }
.nv-rating-core i::after { transform: translate(-50%, -50%) rotate(-135deg); }

.nv-asset-signal-copy--rating {
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 2px;
    min-width: 0;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-copy--rating strong {
    display: flex;
    align-items: baseline;
    gap: 6px;
    color: #f7fbff;
    text-shadow: 0 0 12px rgba(255,255,255,0.10);
}

.nv-asset-signal-copy--rating [data-nv-rating-value-text] {
    font-size: 18px;
    line-height: 1;
}

.nv-rating-max {
    font-size: 11px;
    letter-spacing: 0.18em;
    color: rgba(200, 215, 255, 0.56);
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-copy--rating small {
    font-size: 9px;
    letter-spacing: 0.28em;
    color: rgba(255,255,255,0.54);
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-copy--rating em {
    font-style: normal;
    font-size: 10px;
    letter-spacing: 0.14em;
    color: rgba(190, 202, 225, 0.78);
    text-transform: uppercase;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-metric--rating .nv-asset-signal-copy--rating em span,
.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-metric--rating .nv-asset-signal-copy--rating strong span:first-child {
    color: var(--nv-rating-accent);
}

@media (max-width: 640px) {
    .nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-grid {
        grid-template-columns: 1fr;
    }

    .nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-metric--rating {
        grid-column: auto;
    }
}

/* v1.1.66 - bookmark cyber block + always-visible empty rating */
.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button {
    width: 54px;
    height: 62px;
    top: 12px;
    right: 12px;
    display: grid;
    place-items: center;
    border-radius: 15px 15px 13px 13px;
    border: 1px solid rgba(255, 32, 32, 0.36);
    background:
        linear-gradient(180deg, rgba(9, 15, 30, 0.96), rgba(3, 7, 18, 0.96)),
        radial-gradient(circle at 50% 10%, rgba(255, 40, 40, 0.14), transparent 62%);
    box-shadow:
        inset 0 0 0 1px rgba(255,255,255,0.045),
        inset 0 0 20px rgba(255, 32, 32, 0.06),
        0 0 0 1px rgba(110, 185, 255, 0.08),
        0 10px 26px rgba(0,0,0,0.35),
        0 0 18px rgba(255, 24, 24, 0.10);
    clip-path: polygon(0 0, 100% 0, 100% 76%, 58% 100%, 50% 91%, 42% 100%, 0 76%);
    transform: translateZ(0);
}

.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button::before,
.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button::after {
    content: "";
    position: absolute;
    pointer-events: none;
}

.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button::before {
    inset: 5px;
    border-radius: 11px 11px 9px 9px;
    border: 1px solid rgba(255,255,255,0.075);
    clip-path: polygon(0 0, 100% 0, 100% 72%, 58% 100%, 50% 90%, 42% 100%, 0 72%);
    box-shadow: inset 0 0 0 1px rgba(255, 20, 20, 0.08);
}

.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button::after {
    left: 50%;
    top: 50%;
    width: 32px;
    height: 32px;
    transform: translate(-50%, -52%) rotate(45deg);
    border: 1px solid rgba(95, 175, 255, 0.10);
    border-radius: 8px;
    box-shadow: 0 0 14px rgba(95, 175, 255, 0.06);
}

.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button .nv-ui-icon {
    position: relative;
    z-index: 2;
    width: 24px;
    height: 24px;
    color: rgba(160, 174, 198, 0.88);
    filter: drop-shadow(0 0 8px rgba(0,0,0,0.6));
    transition: color .18s ease, transform .18s ease, filter .18s ease;
}

.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button:hover,
.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button:focus-visible {
    border-color: rgba(255, 42, 42, 0.72);
    box-shadow:
        inset 0 0 0 1px rgba(255,255,255,0.055),
        inset 0 0 22px rgba(255, 32, 32, 0.12),
        0 0 0 1px rgba(255, 42, 42, 0.14),
        0 12px 28px rgba(0,0,0,0.38),
        0 0 24px rgba(255, 24, 24, 0.22);
}

.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button:hover .nv-ui-icon,
.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button:focus-visible .nv-ui-icon {
    color: #ff2b2b;
    transform: translateY(-1px) scale(1.06);
    filter: drop-shadow(0 0 10px rgba(255, 30, 30, 0.34));
}

.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button[aria-pressed="true"] {
    border-color: rgba(130, 205, 255, 0.54);
    background:
        linear-gradient(180deg, rgba(12, 20, 38, 0.98), rgba(4, 9, 22, 0.98)),
        radial-gradient(circle at 50% 12%, rgba(125, 210, 255, 0.17), transparent 62%);
    box-shadow:
        inset 0 0 0 1px rgba(255,255,255,0.065),
        inset 0 0 22px rgba(118, 210, 255, 0.10),
        0 0 0 1px rgba(118, 210, 255, 0.12),
        0 12px 28px rgba(0,0,0,0.38),
        0 0 22px rgba(118, 210, 255, 0.16);
}

.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button[aria-pressed="true"] .nv-ui-icon {
    color: #f6fbff;
    filter: drop-shadow(0 0 11px rgba(150, 220, 255, 0.30));
}

.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button[aria-pressed="true"]:hover .nv-ui-icon,
.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button[aria-pressed="true"]:focus-visible .nv-ui-icon {
    color: #ff2b2b;
    filter: drop-shadow(0 0 12px rgba(255, 30, 30, 0.38));
}

.nv-plugin-showcase-card .nv-plugin-showcase-favorite-count {
    z-index: 3;
    right: -5px;
    bottom: 4px;
    min-width: 18px;
    height: 18px;
    padding: 0 5px;
    border-radius: 999px;
    border: 1px solid rgba(110, 185, 255, 0.28);
    background: rgba(5, 9, 18, 0.92);
    color: rgba(210, 226, 255, 0.85);
    font-size: 10px;
    line-height: 16px;
    box-shadow: 0 0 12px rgba(0,0,0,0.34);
}

.nv-plugin-showcase-card .nv-plugin-showcase-favorite-count.has-public-favorites {
    color: #fff;
    border-color: rgba(255, 42, 42, 0.52);
    background: rgba(75, 5, 9, 0.92);
    box-shadow: 0 0 14px rgba(255, 24, 24, 0.20);
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-metric--rating[data-nv-rating-value="0.0"] {
    --nv-rating-accent: rgba(150, 164, 188, 0.78);
    --nv-rating-glow: rgba(150, 164, 188, 0.08);
    border-color: rgba(150, 164, 188, 0.16);
    background:
        linear-gradient(135deg, rgba(115, 125, 145, 0.08), rgba(6, 12, 24, 0.90) 40%, rgba(7, 13, 28, 0.94)),
        linear-gradient(180deg, rgba(255,255,255,0.025), rgba(255,255,255,0));
}

/* =========================================================
   v1.1.67 - Catalog cards: force visible rating widget + cyber bookmark.
   ========================================================= */
.nv-plugin-showcase-card {
    height: 440px !important;
    min-height: 440px !important;
    max-height: 440px !important;
    grid-template-rows: 132px minmax(0, 1fr) !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-content {
    grid-template-rows: 36px 52px 24px 58px 29px 28px !important;
    row-gap: 8px !important;
    overflow: hidden !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card {
    height: 58px !important;
    min-height: 58px !important;
    max-height: 58px !important;
    overflow: visible !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-grid {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) 74px !important;
    grid-template-rows: 1fr !important;
    gap: 6px !important;
    height: 58px !important;
    min-height: 58px !important;
    max-height: 58px !important;
    overflow: visible !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-metric:not(.nv-asset-signal-metric--rating) {
    height: 58px !important;
    min-height: 58px !important;
    max-height: 58px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 0 8px !important;
    background: rgba(255,255,255,0.016) !important;
    border: 1px solid rgba(255,255,255,0.035) !important;
    border-radius: 4px !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-metric--rating,
.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-rating-widget {
    grid-column: auto !important;
    height: 58px !important;
    min-height: 58px !important;
    max-height: 58px !important;
    width: 74px !important;
    min-width: 74px !important;
    max-width: 74px !important;
    display: grid !important;
    grid-template-columns: 34px minmax(0, 1fr) !important;
    align-items: center !important;
    justify-content: stretch !important;
    gap: 5px !important;
    padding: 7px 6px !important;
    border-radius: 5px !important;
    border: 1px solid rgba(104, 178, 255, 0.24) !important;
    background:
        linear-gradient(135deg, rgba(255, 22, 22, 0.12), rgba(5, 10, 21, 0.94) 45%, rgba(8, 17, 38, 0.96)) !important;
    box-shadow:
        inset 0 0 0 1px rgba(255,255,255,0.035),
        inset 0 0 18px rgba(255, 35, 35, 0.055),
        0 0 16px rgba(0,0,0,0.22) !important;
    overflow: hidden !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-metric--rating::before,
.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-metric--rating::after {
    display: block !important;
    content: "" !important;
    pointer-events: none !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-metric--rating::before {
    position: absolute !important;
    inset: 1px !important;
    border-radius: inherit !important;
    background: linear-gradient(90deg, rgba(255, 30, 30, 0.08), rgba(94, 176, 255, 0.055), transparent) !important;
    opacity: 1 !important;
}

.nv-plugin-showcase-card .nv-asset-signal--card .nv-asset-signal-metric--rating::after {
    position: absolute !important;
    left: 6px !important;
    top: 6px !important;
    width: 32px !important;
    height: 32px !important;
    border: 1px solid rgba(255,255,255,0.045) !important;
    border-radius: 9px !important;
    transform: rotate(45deg) !important;
    opacity: 0.8 !important;
}

.nv-plugin-showcase-card .nv-rating-badge {
    width: 34px !important;
    height: 34px !important;
    min-width: 34px !important;
    flex-basis: 34px !important;
    border-radius: 10px !important;
    z-index: 2 !important;
}

.nv-plugin-showcase-card .nv-rating-ring-base,
.nv-plugin-showcase-card .nv-rating-ring-fill {
    inset: 5px !important;
    -webkit-mask: radial-gradient(farthest-side, transparent calc(100% - 5px), #000 calc(100% - 4px)) !important;
    mask: radial-gradient(farthest-side, transparent calc(100% - 5px), #000 calc(100% - 4px)) !important;
}

.nv-plugin-showcase-card .nv-rating-badge-shell::before {
    inset: 3px !important;
    border-radius: 8px !important;
}

.nv-plugin-showcase-card .nv-rating-badge-shell::after {
    width: 24px !important;
    height: 24px !important;
    border-radius: 6px !important;
}

.nv-plugin-showcase-card .nv-rating-core {
    inset: 12px !important;
}

.nv-plugin-showcase-card .nv-rating-core::before,
.nv-plugin-showcase-card .nv-rating-core::after,
.nv-plugin-showcase-card .nv-rating-core i::before,
.nv-plugin-showcase-card .nv-rating-core i::after {
    width: 7px !important;
    height: 1.2px !important;
}

.nv-plugin-showcase-card .nv-asset-signal-copy--rating {
    position: relative !important;
    z-index: 3 !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-start !important;
    justify-content: center !important;
    gap: 1px !important;
    min-width: 0 !important;
}

.nv-plugin-showcase-card .nv-asset-signal-copy--rating small {
    display: block !important;
    font-size: 6px !important;
    line-height: 1 !important;
    letter-spacing: 0.12em !important;
    color: rgba(210, 220, 240, 0.48) !important;
}

.nv-plugin-showcase-card .nv-asset-signal-copy--rating strong {
    display: flex !important;
    align-items: baseline !important;
    gap: 1px !important;
    font-size: 12px !important;
    line-height: 1 !important;
    letter-spacing: 0 !important;
    color: var(--nv-rating-accent) !important;
}

.nv-plugin-showcase-card .nv-asset-signal-copy--rating [data-nv-rating-value-text] {
    font-size: 12px !important;
    line-height: 1 !important;
    color: var(--nv-rating-accent) !important;
}

.nv-plugin-showcase-card .nv-rating-max {
    display: none !important;
}

.nv-plugin-showcase-card .nv-asset-signal-copy--rating em {
    display: block !important;
    max-width: 100% !important;
    overflow: hidden !important;
    white-space: nowrap !important;
    text-overflow: clip !important;
    font-style: normal !important;
    font-size: 6px !important;
    line-height: 1 !important;
    letter-spacing: 0.06em !important;
    color: rgba(190, 202, 225, 0.62) !important;
    text-transform: uppercase !important;
}

.nv-plugin-showcase-card .nv-asset-signal-copy--rating em::after {
    content: "" !important;
}

.nv-plugin-showcase-card .nv-asset-signal-copy--rating em {
    font-size: 0 !important;
}

.nv-plugin-showcase-card .nv-asset-signal-copy--rating em span {
    font-size: 8px !important;
    color: rgba(230, 238, 255, 0.72) !important;
}

.nv-plugin-showcase-card .nv-asset-signal-copy--rating em span::before {
    content: "(" !important;
}

.nv-plugin-showcase-card .nv-asset-signal-copy--rating em span::after {
    content: ")" !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-chips {
    height: 28px !important;
    min-height: 28px !important;
    max-height: 28px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button {
    width: 44px !important;
    height: 52px !important;
    min-width: 44px !important;
    min-height: 52px !important;
    top: 10px !important;
    right: 10px !important;
    display: grid !important;
    place-items: center !important;
    border-radius: 10px 10px 8px 8px !important;
    border: 1px solid rgba(120, 190, 255, 0.22) !important;
    background:
        linear-gradient(180deg, rgba(7, 13, 28, 0.86), rgba(3, 7, 18, 0.92)),
        radial-gradient(circle at 50% 0%, rgba(255, 40, 40, 0.16), transparent 66%) !important;
    box-shadow:
        inset 0 0 0 1px rgba(255,255,255,0.04),
        inset 0 0 18px rgba(255, 32, 32, 0.045),
        0 0 0 1px rgba(255, 32, 32, 0.09),
        0 8px 18px rgba(0,0,0,0.42) !important;
    clip-path: polygon(0 0,100% 0,100% 74%,58% 100%,50% 90%,42% 100%,0 74%) !important;
    opacity: 1 !important;
    overflow: visible !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button::before {
    display: block !important;
    content: "" !important;
    position: absolute !important;
    inset: 4px !important;
    border: 1px solid rgba(255,255,255,0.07) !important;
    border-radius: 7px 7px 5px 5px !important;
    clip-path: polygon(0 0,100% 0,100% 70%,58% 100%,50% 90%,42% 100%,0 70%) !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button::after {
    display: block !important;
    content: "" !important;
    position: absolute !important;
    left: 50% !important;
    top: 50% !important;
    width: 26px !important;
    height: 26px !important;
    transform: translate(-50%, -55%) rotate(45deg) !important;
    border: 1px solid rgba(95, 175, 255, 0.10) !important;
    border-radius: 7px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button .nv-ui-icon,
.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button .nv-ui-icon-bookmark {
    position: relative !important;
    z-index: 4 !important;
    width: 22px !important;
    height: 22px !important;
    color: rgba(152, 166, 190, 0.90) !important;
    stroke: currentColor !important;
    filter: drop-shadow(0 0 7px rgba(0,0,0,0.64)) !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button:hover,
.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button:focus-visible {
    border-color: rgba(255, 42, 42, 0.62) !important;
    box-shadow:
        inset 0 0 0 1px rgba(255,255,255,0.055),
        inset 0 0 18px rgba(255, 32, 32, 0.12),
        0 0 0 1px rgba(255, 42, 42, 0.15),
        0 8px 20px rgba(0,0,0,0.45),
        0 0 22px rgba(255, 24, 24, 0.20) !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button:hover .nv-ui-icon,
.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button:focus-visible .nv-ui-icon {
    color: #ff3030 !important;
    stroke: currentColor !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button[aria-pressed="true"],
.nv-plugin-showcase-card.is-favorite .nv-plugin-showcase-favorite-button {
    border-color: rgba(150, 220, 255, 0.58) !important;
    background:
        linear-gradient(180deg, rgba(12, 20, 38, 0.95), rgba(4, 9, 22, 0.98)),
        radial-gradient(circle at 50% 0%, rgba(125, 210, 255, 0.20), transparent 66%) !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button[aria-pressed="true"] .nv-ui-icon,
.nv-plugin-showcase-card.is-favorite .nv-plugin-showcase-favorite-button .nv-ui-icon {
    color: #f7fbff !important;
    stroke: currentColor !important;
    filter: drop-shadow(0 0 10px rgba(150, 220, 255, 0.28)) !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button[aria-pressed="true"]:hover .nv-ui-icon,
.nv-plugin-showcase-card.is-favorite .nv-plugin-showcase-favorite-button:hover .nv-ui-icon {
    color: #ff3030 !important;
    stroke: currentColor !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-favorite-count {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    z-index: 5 !important;
    right: -7px !important;
    top: -7px !important;
    bottom: auto !important;
    min-width: 17px !important;
    height: 17px !important;
    padding: 0 4px !important;
    border-radius: 999px !important;
    border: 1px solid rgba(255, 42, 42, 0.56) !important;
    background: rgba(90, 6, 12, 0.96) !important;
    color: #fff !important;
    font-size: 10px !important;
    line-height: 15px !important;
    box-shadow: 0 0 14px rgba(255, 24, 24, 0.22) !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button[data-nv-plugin-favorite-public-count="0"] .nv-plugin-showcase-favorite-count {
    display: none !important;
}

@media (max-width: 720px) {
    .nv-plugin-showcase-card {
        height: 454px !important;
        min-height: 454px !important;
        max-height: 454px !important;
    }

    .nv-plugin-showcase-card .nv-plugin-showcase-card-content {
        grid-template-rows: 36px 52px 24px 58px 29px 28px !important;
    }
}


/* =========================================================
   v1.1.68 - Catalog cards: move rating widget beside title.
   ========================================================= */
.nv-plugin-showcase-card {
    height: 472px !important;
    min-height: 472px !important;
    max-height: 472px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-content {
    grid-template-rows: 36px auto 58px 28px !important;
    row-gap: 10px !important;
    align-content: start !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-summary {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) 120px !important;
    gap: 12px !important;
    align-items: start !important;
    min-width: 0 !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-summary-copy {
    min-width: 0 !important;
    display: grid !important;
    gap: 10px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-summary-copy > h3,
.nv-plugin-showcase-card .nv-plugin-showcase-card-summary-copy > p {
    margin: 0 !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating {
    margin: 0 !important;
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    align-self: start !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-grid {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) !important;
    grid-template-rows: auto !important;
    gap: 0 !important;
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-metric--rating,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-rating-widget {
    width: 120px !important;
    min-width: 120px !important;
    min-height: 102px !important;
    max-height: none !important;
    margin: 0 !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating small {
    display: none !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating strong {
    font-size: 34px !important;
    line-height: 1 !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em {
    font-size: 12px !important;
    line-height: 1.15 !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-badge {
    width: 50px !important;
    height: 50px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-metrics {
    margin: 0 !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-metrics .nv-asset-signal-grid {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    grid-template-rows: 1fr !important;
    gap: 8px !important;
    height: 58px !important;
    min-height: 58px !important;
    max-height: 58px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-metrics .nv-asset-signal-metric {
    height: 58px !important;
    min-height: 58px !important;
    max-height: 58px !important;
}

@media (max-width: 720px) {
    .nv-plugin-showcase-card {
        height: 486px !important;
        min-height: 486px !important;
        max-height: 486px !important;
    }

    .nv-plugin-showcase-card .nv-plugin-showcase-card-content {
        grid-template-rows: 36px auto 58px 28px !important;
    }

    .nv-plugin-showcase-card .nv-plugin-showcase-card-summary {
        grid-template-columns: minmax(0, 1fr) 104px !important;
        gap: 10px !important;
    }

    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-metric--rating,
    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-rating-widget {
        width: 104px !important;
        min-width: 104px !important;
        min-height: 96px !important;
    }

    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-badge {
        width: 44px !important;
        height: 44px !important;
    }

    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating strong {
        font-size: 30px !important;
    }
}


/* =========================================================
   v1.1.69 - Catalog card precision pass: compact rating, full-width metrics, clean bookmark.
   ========================================================= */
.nv-plugin-showcase-card {
    height: 438px !important;
    min-height: 438px !important;
    max-height: 438px !important;
    grid-template-rows: 132px minmax(0, 1fr) !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-content {
    display: grid !important;
    grid-template-rows: 36px 104px 58px 30px !important;
    row-gap: 8px !important;
    align-content: start !important;
    overflow: hidden !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-summary {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) 96px !important;
    gap: 8px !important;
    align-items: start !important;
    min-width: 0 !important;
    width: 100% !important;
    height: 104px !important;
    min-height: 104px !important;
    max-height: 104px !important;
    overflow: hidden !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-summary-copy {
    min-width: 0 !important;
    width: 100% !important;
    display: grid !important;
    grid-template-rows: 50px 22px !important;
    gap: 10px !important;
    overflow: hidden !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-summary-copy > h3 {
    margin: 0 !important;
    min-width: 0 !important;
    max-height: 50px !important;
    overflow: hidden !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-summary-copy > p {
    margin: 0 !important;
    min-width: 0 !important;
    max-height: 22px !important;
    overflow: hidden !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating {
    width: 96px !important;
    min-width: 96px !important;
    max-width: 96px !important;
    height: 76px !important;
    min-height: 76px !important;
    max-height: 76px !important;
    margin: 0 !important;
    align-self: start !important;
    justify-self: end !important;
    overflow: visible !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-grid {
    display: block !important;
    width: 96px !important;
    min-width: 96px !important;
    max-width: 96px !important;
    height: 76px !important;
    min-height: 76px !important;
    max-height: 76px !important;
    overflow: visible !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-metric--rating,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-rating-widget {
    box-sizing: border-box !important;
    width: 96px !important;
    min-width: 96px !important;
    max-width: 96px !important;
    height: 76px !important;
    min-height: 76px !important;
    max-height: 76px !important;
    margin: 0 !important;
    padding: 8px 9px !important;
    display: grid !important;
    grid-template-columns: 34px minmax(0, 1fr) !important;
    gap: 8px !important;
    align-items: center !important;
    justify-content: stretch !important;
    border-radius: 0 !important;
    border: 1px solid rgba(255, 50, 50, 0.42) !important;
    background:
        linear-gradient(135deg, rgba(255, 24, 24, 0.10), rgba(5, 10, 23, 0.88) 44%, rgba(10, 20, 45, 0.74)),
        rgba(5, 8, 16, 0.68) !important;
    box-shadow:
        inset 0 0 0 1px rgba(255, 255, 255, 0.025),
        inset 0 0 24px rgba(255, 26, 26, 0.055),
        0 0 18px rgba(255, 20, 20, 0.08) !important;
    clip-path: polygon(8px 0, calc(100% - 8px) 0, 100% 8px, 100% calc(100% - 8px), calc(100% - 8px) 100%, 8px 100%, 0 calc(100% - 8px), 0 8px) !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-metric--rating::before,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-metric--rating::after {
    opacity: 0.65 !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-badge {
    width: 34px !important;
    height: 34px !important;
    min-width: 34px !important;
    min-height: 34px !important;
    flex-basis: 34px !important;
    border-radius: 10px !important;
    align-self: center !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-badge-shell::before {
    inset: 4px !important;
    border-radius: 8px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-badge-shell::after {
    width: 24px !important;
    height: 24px !important;
    border-radius: 7px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-ring-base,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-ring-fill {
    inset: 7px !important;
    -webkit-mask: radial-gradient(farthest-side, transparent calc(100% - 4px), #000 calc(100% - 3px)) !important;
    mask: radial-gradient(farthest-side, transparent calc(100% - 4px), #000 calc(100% - 3px)) !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-core {
    inset: 13px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating {
    min-width: 0 !important;
    display: grid !important;
    grid-template-rows: 28px 18px !important;
    gap: 2px !important;
    align-content: center !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating small {
    display: none !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating strong {
    display: flex !important;
    align-items: baseline !important;
    gap: 2px !important;
    font-size: 23px !important;
    line-height: 1 !important;
    letter-spacing: 0.03em !important;
    color: #f4f7ff !important;
    white-space: nowrap !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-max {
    display: none !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em {
    display: block !important;
    font-size: 18px !important;
    line-height: 1 !important;
    letter-spacing: 0.06em !important;
    color: rgba(206, 213, 226, 0.72) !important;
    text-transform: none !important;
    white-space: nowrap !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em::before { content: '('; }
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em::after { content: ')'; }
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em { font-size: 0 !important; }
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em::before,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em::after,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em span {
    font-size: 18px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-metrics,
.nv-plugin-showcase-card .nv-plugin-showcase-card-metrics.nv-asset-signal--card {
    display: block !important;
    width: 100% !important;
    min-width: 0 !important;
    max-width: none !important;
    height: 58px !important;
    min-height: 58px !important;
    max-height: 58px !important;
    margin: 0 !important;
    overflow: visible !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-metrics .nv-asset-signal-grid {
    display: grid !important;
    width: 100% !important;
    min-width: 0 !important;
    max-width: none !important;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) !important;
    grid-template-rows: 58px !important;
    gap: 8px !important;
    height: 58px !important;
    min-height: 58px !important;
    max-height: 58px !important;
    overflow: visible !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-metrics .nv-asset-signal-metric,
.nv-plugin-showcase-card .nv-plugin-showcase-card-metrics .nv-asset-signal-metric:not(.nv-asset-signal-metric--rating) {
    box-sizing: border-box !important;
    width: 100% !important;
    min-width: 0 !important;
    max-width: none !important;
    height: 58px !important;
    min-height: 58px !important;
    max-height: 58px !important;
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 15px !important;
    padding: 0 14px !important;
    border-radius: 4px !important;
    background: rgba(255, 255, 255, 0.010) !important;
    border: 1px solid rgba(255, 255, 255, 0.035) !important;
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.006) !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-metrics .nv-asset-signal-icon {
    flex: 0 0 auto !important;
    width: 18px !important;
    height: 18px !important;
    margin: 0 !important;
    color: rgba(205, 214, 228, 0.78) !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-metrics .nv-ui-icon {
    width: 18px !important;
    height: 18px !important;
    color: rgba(205, 214, 228, 0.78) !important;
    stroke: currentColor !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-metrics .nv-ui-icon * {
    stroke: currentColor !important;
    color: currentColor !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-metrics .nv-asset-signal-copy {
    flex: 0 0 auto !important;
    display: block !important;
    min-width: 0 !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-metrics .nv-asset-signal-copy small,
.nv-plugin-showcase-card .nv-plugin-showcase-card-metrics .nv-asset-signal-copy em {
    display: none !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-metrics .nv-asset-signal-copy strong {
    display: block !important;
    font-size: 19px !important;
    line-height: 1 !important;
    letter-spacing: 0.04em !important;
    color: rgba(244, 247, 255, 0.88) !important;
    text-align: left !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button {
    width: 42px !important;
    height: 42px !important;
    padding: 0 !important;
    right: 9px !important;
    top: 8px !important;
    overflow: hidden !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button::before,
.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button::after {
    content: none !important;
    display: none !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button .nv-ui-icon-heart,
.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button svg.nv-ui-icon-heart {
    display: none !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-favorite-count {
    display: none !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button .nv-ui-icon,
.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button svg {
    display: block !important;
    width: 21px !important;
    height: 21px !important;
}

@media (max-width: 720px) {
    .nv-plugin-showcase-card {
        height: 448px !important;
        min-height: 448px !important;
        max-height: 448px !important;
    }

    .nv-plugin-showcase-card .nv-plugin-showcase-card-content {
        grid-template-rows: 36px 104px 58px 30px !important;
    }

    .nv-plugin-showcase-card .nv-plugin-showcase-card-summary {
        grid-template-columns: minmax(0, 1fr) 88px !important;
        gap: 8px !important;
    }

    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating,
    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-grid,
    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-metric--rating,
    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-rating-widget {
        width: 88px !important;
        min-width: 88px !important;
        max-width: 88px !important;
    }

    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-metric--rating,
    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-rating-widget {
        grid-template-columns: 30px minmax(0, 1fr) !important;
        gap: 6px !important;
        padding: 8px 7px !important;
    }

    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-badge {
        width: 30px !important;
        height: 30px !important;
        min-width: 30px !important;
        min-height: 30px !important;
        flex-basis: 30px !important;
    }

    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating strong {
        font-size: 20px !important;
    }

    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em::before,
    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em::after,
    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em span {
        font-size: 15px !important;
    }
}

/* =========================================================
   v1.1.70 - Catalog card metric alignment, rating count clamp, no bookmark number.
   ========================================================= */
.nv-plugin-showcase-card {
    height: 422px !important;
    min-height: 422px !important;
    max-height: 422px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-content {
    grid-template-rows: 36px 96px 46px 28px !important;
    row-gap: 8px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-summary {
    grid-template-columns: minmax(0, 1fr) 96px !important;
    height: 96px !important;
    min-height: 96px !important;
    max-height: 96px !important;
    align-items: start !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-summary-copy {
    grid-template-rows: 50px 20px !important;
    gap: 8px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-grid {
    width: 96px !important;
    min-width: 96px !important;
    max-width: 96px !important;
    height: 60px !important;
    min-height: 60px !important;
    max-height: 60px !important;
    overflow: visible !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-metric--rating,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-rating-widget {
    width: 96px !important;
    min-width: 96px !important;
    max-width: 96px !important;
    height: 60px !important;
    min-height: 60px !important;
    max-height: 60px !important;
    grid-template-columns: 32px minmax(0, 42px) !important;
    gap: 7px !important;
    padding: 7px 8px !important;
    overflow: hidden !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-badge {
    width: 32px !important;
    height: 32px !important;
    min-width: 32px !important;
    min-height: 32px !important;
    flex-basis: 32px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-ring-base,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-ring-fill {
    inset: 6px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-core {
    inset: 12px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating {
    min-width: 0 !important;
    width: 42px !important;
    max-width: 42px !important;
    display: grid !important;
    grid-template-rows: 16px 13px !important;
    gap: 2px !important;
    align-content: center !important;
    justify-items: start !important;
    overflow: hidden !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating strong {
    width: 42px !important;
    max-width: 42px !important;
    font-size: 13px !important;
    line-height: 1 !important;
    letter-spacing: 0.02em !important;
    color: var(--nv-rating-accent) !important;
    overflow: hidden !important;
    white-space: nowrap !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating [data-nv-rating-value-text] {
    font-size: 13px !important;
    line-height: 1 !important;
    color: var(--nv-rating-accent) !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em {
    width: 42px !important;
    max-width: 42px !important;
    font-size: 0 !important;
    line-height: 1 !important;
    color: rgba(218, 225, 238, 0.70) !important;
    overflow: visible !important;
    white-space: nowrap !important;
    text-overflow: clip !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em::before {
    content: '(' !important;
    font-size: 10px !important;
    line-height: 1 !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em::after {
    content: ')' !important;
    font-size: 10px !important;
    line-height: 1 !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em span {
    font-size: 10px !important;
    line-height: 1 !important;
    color: rgba(218, 225, 238, 0.70) !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em span::before,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em span::after {
    content: none !important;
    display: none !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-metrics,
.nv-plugin-showcase-card .nv-plugin-showcase-card-metrics.nv-asset-signal--card,
.nv-plugin-showcase-card .nv-plugin-showcase-card-metrics .nv-asset-signal-grid {
    height: 46px !important;
    min-height: 46px !important;
    max-height: 46px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-metrics .nv-asset-signal-grid {
    grid-template-rows: 46px !important;
    gap: 7px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-metrics .nv-asset-signal-metric,
.nv-plugin-showcase-card .nv-plugin-showcase-card-metrics .nv-asset-signal-metric:not(.nv-asset-signal-metric--rating) {
    height: 46px !important;
    min-height: 46px !important;
    max-height: 46px !important;
    display: grid !important;
    grid-template-columns: 18px min-content !important;
    grid-template-rows: 1fr !important;
    place-content: center !important;
    align-items: center !important;
    justify-items: center !important;
    column-gap: 13px !important;
    padding: 0 10px !important;
    line-height: 1 !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-metrics .nv-asset-signal-icon {
    grid-column: 1 !important;
    grid-row: 1 !important;
    width: 16px !important;
    height: 16px !important;
    min-width: 16px !important;
    display: grid !important;
    place-items: center !important;
    align-self: center !important;
    justify-self: center !important;
    margin: 0 !important;
    line-height: 0 !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-metrics .nv-ui-icon {
    width: 16px !important;
    height: 16px !important;
    display: block !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-metrics .nv-asset-signal-copy {
    grid-column: 2 !important;
    grid-row: 1 !important;
    width: auto !important;
    min-width: 0 !important;
    max-width: 72px !important;
    display: grid !important;
    place-items: center start !important;
    align-self: center !important;
    justify-self: center !important;
    margin: 0 !important;
    line-height: 1 !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-metrics .nv-asset-signal-copy strong {
    display: block !important;
    margin: 0 !important;
    padding: 0 !important;
    font-size: 20px !important;
    line-height: 1 !important;
    letter-spacing: 0.02em !important;
    text-align: left !important;
    align-self: center !important;
    justify-self: start !important;
    transform: none !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button,
.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button.is-active,
.nv-plugin-showcase-card.is-favorite .nv-plugin-showcase-favorite-button {
    overflow: hidden !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button .nv-plugin-showcase-favorite-count,
.nv-plugin-showcase-card .nv-plugin-showcase-favorite-button [data-nv-plugin-favorite-count],
.nv-plugin-showcase-card .nv-plugin-showcase-favorite-count,
.nv-plugin-showcase-card .nv-plugin-showcase-favorite-count.has-public-favorites {
    display: none !important;
    visibility: hidden !important;
    opacity: 0 !important;
    width: 0 !important;
    height: 0 !important;
    min-width: 0 !important;
    max-width: 0 !important;
    overflow: hidden !important;
    pointer-events: none !important;
}

@media (max-width: 720px) {
    .nv-plugin-showcase-card {
        height: 428px !important;
        min-height: 428px !important;
        max-height: 428px !important;
    }

    .nv-plugin-showcase-card .nv-plugin-showcase-card-content {
        grid-template-rows: 36px 96px 46px 28px !important;
    }

    .nv-plugin-showcase-card .nv-plugin-showcase-card-summary {
        grid-template-columns: minmax(0, 1fr) 92px !important;
        height: 96px !important;
        min-height: 96px !important;
        max-height: 96px !important;
    }

    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating,
    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-grid,
    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-metric--rating,
    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-rating-widget {
        width: 92px !important;
        min-width: 92px !important;
        max-width: 92px !important;
        height: 60px !important;
        min-height: 60px !important;
        max-height: 60px !important;
    }

    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-metric--rating,
    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-rating-widget {
        grid-template-columns: 30px minmax(0, 40px) !important;
        gap: 6px !important;
        padding: 7px 7px !important;
    }

    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-badge {
        width: 30px !important;
        height: 30px !important;
        min-width: 30px !important;
        min-height: 30px !important;
    }

    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating,
    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating strong,
    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em {
        width: 40px !important;
        max-width: 40px !important;
    }
}


/* =========================================================
   v1.1.71 - Reference-match polish for catalog rating/bookmark/metrics.
   ========================================================= */
.nv-plugin-showcase-card {
    height: 422px !important;
    min-height: 422px !important;
    max-height: 422px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-content {
    grid-template-rows: 36px 96px 40px 28px !important;
    row-gap: 9px !important;
    align-content: start !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-summary {
    grid-template-columns: minmax(0, 1fr) 112px !important;
    gap: 10px !important;
    height: 96px !important;
    min-height: 96px !important;
    max-height: 96px !important;
    align-items: start !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-summary-copy {
    min-width: 0 !important;
    display: grid !important;
    grid-template-rows: 50px 20px !important;
    gap: 8px !important;
    align-content: start !important;
}

/* Downloads / Wishlists: one centered group, not independently shifted icon/text. */
.nv-plugin-showcase-card .nv-plugin-showcase-card-metrics,
.nv-plugin-showcase-card .nv-plugin-showcase-card-metrics.nv-asset-signal--card,
.nv-plugin-showcase-card .nv-plugin-showcase-card-metrics .nv-asset-signal-grid {
    height: 40px !important;
    min-height: 40px !important;
    max-height: 40px !important;
    margin: 0 !important;
    overflow: hidden !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-metrics .nv-asset-signal-grid {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    grid-template-rows: 40px !important;
    gap: 8px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-metrics .nv-asset-signal-metric,
.nv-plugin-showcase-card .nv-plugin-showcase-card-metrics .nv-asset-signal-metric:not(.nv-asset-signal-metric--rating) {
    position: relative !important;
    height: 40px !important;
    min-height: 40px !important;
    max-height: 40px !important;
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: nowrap !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 14px !important;
    padding: 0 12px !important;
    background: rgba(6, 10, 17, 0.52) !important;
    border: 1px solid rgba(255, 255, 255, 0.045) !important;
    border-radius: 2px !important;
    box-shadow:
        inset 0 0 0 1px rgba(255, 255, 255, 0.012),
        inset 0 -1px 0 rgba(255, 26, 26, 0.055) !important;
    line-height: 1 !important;
    overflow: hidden !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-metrics .nv-asset-signal-metric::before,
.nv-plugin-showcase-card .nv-plugin-showcase-card-metrics .nv-asset-signal-metric::after {
    content: none !important;
    display: none !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-metrics .nv-asset-signal-icon {
    flex: 0 0 auto !important;
    order: 1 !important;
    width: 17px !important;
    height: 17px !important;
    min-width: 17px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    margin: 0 !important;
    padding: 0 !important;
    color: rgba(196, 205, 218, 0.80) !important;
    line-height: 0 !important;
    transform: none !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-metrics .nv-asset-signal-icon .nv-ui-icon,
.nv-plugin-showcase-card .nv-plugin-showcase-card-metrics .nv-asset-signal-icon svg {
    width: 17px !important;
    height: 17px !important;
    display: block !important;
    flex: 0 0 auto !important;
    margin: 0 !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-metrics .nv-asset-signal-copy {
    order: 2 !important;
    flex: 0 0 auto !important;
    min-width: 0 !important;
    width: auto !important;
    max-width: none !important;
    display: contents !important;
    margin: 0 !important;
    padding: 0 !important;
    line-height: 1 !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-metrics .nv-asset-signal-copy small,
.nv-plugin-showcase-card .nv-plugin-showcase-card-metrics .nv-asset-signal-copy em {
    display: none !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-metrics .nv-asset-signal-copy strong {
    order: 2 !important;
    flex: 0 0 auto !important;
    display: block !important;
    width: auto !important;
    min-width: 1ch !important;
    max-width: 7ch !important;
    margin: 0 !important;
    padding: 0 !important;
    color: rgba(232, 236, 244, 0.92) !important;
    font-size: 19px !important;
    font-weight: 650 !important;
    letter-spacing: 0.01em !important;
    line-height: 1 !important;
    text-align: left !important;
    white-space: nowrap !important;
    transform: none !important;
}

/* Rating: angular reference panel, clear value + count, no clipped text. */
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-grid {
    width: 112px !important;
    min-width: 112px !important;
    max-width: 112px !important;
    height: 66px !important;
    min-height: 66px !important;
    max-height: 66px !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: visible !important;
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-metric--rating,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-rating-widget {
    --nv-rating-panel-bg: rgba(6, 9, 20, 0.82);
    position: relative !important;
    isolation: isolate !important;
    width: 112px !important;
    min-width: 112px !important;
    max-width: 112px !important;
    height: 66px !important;
    min-height: 66px !important;
    max-height: 66px !important;
    display: grid !important;
    grid-template-columns: 38px minmax(0, 44px) !important;
    align-items: center !important;
    justify-content: center !important;
    column-gap: 10px !important;
    padding: 8px 10px !important;
    overflow: hidden !important;
    background:
        radial-gradient(circle at 19% 50%, rgba(255, 80, 44, 0.16), transparent 34%),
        linear-gradient(135deg, rgba(255, 25, 25, 0.13), rgba(9, 12, 27, 0.92) 44%, rgba(12, 18, 41, 0.92)) !important;
    border: 1px solid rgba(255, 28, 45, 0.38) !important;
    border-radius: 0 !important;
    clip-path: polygon(10px 0, calc(100% - 10px) 0, 100% 10px, 100% calc(100% - 10px), calc(100% - 10px) 100%, 10px 100%, 0 calc(100% - 10px), 0 10px) !important;
    box-shadow:
        inset 0 0 0 1px rgba(255, 255, 255, 0.018),
        inset 0 0 20px rgba(255, 28, 40, 0.055),
        0 0 14px rgba(255, 24, 42, 0.10) !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-metric--rating::before {
    content: "" !important;
    position: absolute !important;
    inset: 4px !important;
    display: block !important;
    pointer-events: none !important;
    border: 1px solid rgba(255, 255, 255, 0.035) !important;
    border-radius: 0 !important;
    clip-path: polygon(8px 0, calc(100% - 8px) 0, 100% 8px, 100% calc(100% - 8px), calc(100% - 8px) 100%, 8px 100%, 0 calc(100% - 8px), 0 8px) !important;
    background: linear-gradient(90deg, rgba(255, 25, 25, 0.05), rgba(86, 158, 255, 0.035)) !important;
    opacity: 1 !important;
    z-index: -1 !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-metric--rating::after {
    content: "" !important;
    position: absolute !important;
    inset: auto 8px 0 8px !important;
    height: 1px !important;
    display: block !important;
    pointer-events: none !important;
    background: linear-gradient(90deg, transparent, rgba(255, 34, 48, 0.64), transparent) !important;
    opacity: 0.75 !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-badge {
    position: relative !important;
    z-index: 1 !important;
    width: 38px !important;
    height: 38px !important;
    min-width: 38px !important;
    min-height: 38px !important;
    flex: 0 0 38px !important;
    border-radius: 10px !important;
    background: radial-gradient(circle at 50% 50%, rgba(255, 103, 65, 0.16), rgba(3, 6, 15, 0.96) 62%) !important;
    box-shadow:
        inset 0 0 0 1px rgba(255, 255, 255, 0.045),
        inset 0 0 0 2px rgba(255, 30, 38, 0.08),
        0 0 13px var(--nv-rating-glow) !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-ring-base,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-ring-fill {
    inset: 6px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-core {
    inset: 13px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating {
    position: relative !important;
    z-index: 1 !important;
    width: 44px !important;
    min-width: 44px !important;
    max-width: 44px !important;
    display: grid !important;
    grid-template-rows: 20px 16px !important;
    align-content: center !important;
    justify-items: start !important;
    gap: 3px !important;
    overflow: visible !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating small,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-max {
    display: none !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating strong {
    display: block !important;
    width: 44px !important;
    max-width: 44px !important;
    color: var(--nv-rating-accent) !important;
    font-size: 15px !important;
    font-weight: 750 !important;
    letter-spacing: 0.02em !important;
    line-height: 1 !important;
    white-space: nowrap !important;
    text-align: left !important;
    overflow: visible !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating [data-nv-rating-value-text] {
    font-size: 15px !important;
    line-height: 1 !important;
    color: var(--nv-rating-accent) !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em {
    display: block !important;
    width: 44px !important;
    max-width: 44px !important;
    height: 16px !important;
    font-size: 0 !important;
    line-height: 16px !important;
    color: rgba(213, 220, 232, 0.70) !important;
    white-space: nowrap !important;
    overflow: visible !important;
    text-overflow: clip !important;
    text-align: left !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em::before {
    content: '(' !important;
    display: inline !important;
    color: rgba(213, 220, 232, 0.70) !important;
    font-size: 13px !important;
    line-height: 16px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em::after {
    content: ')' !important;
    display: inline !important;
    color: rgba(213, 220, 232, 0.70) !important;
    font-size: 13px !important;
    line-height: 16px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em span {
    display: inline !important;
    color: rgba(213, 220, 232, 0.70) !important;
    font-size: 13px !important;
    line-height: 16px !important;
}

/* Bookmark: angular top-right reference block, only bookmark icon, no count artifacts. */
.nv-plugin-showcase-card > .nv-plugin-showcase-favorite-button,
.nv-plugin-showcase-card > .nv-plugin-showcase-favorite-button.is-active,
.nv-plugin-showcase-card.is-favorite > .nv-plugin-showcase-favorite-button {
    position: absolute !important;
    top: 16px !important;
    right: 14px !important;
    z-index: 7 !important;
    width: 42px !important;
    height: 52px !important;
    min-width: 42px !important;
    min-height: 52px !important;
    padding: 0 !important;
    display: grid !important;
    place-items: center !important;
    overflow: hidden !important;
    border: 1px solid rgba(255, 36, 52, 0.42) !important;
    border-radius: 0 !important;
    background:
        linear-gradient(135deg, rgba(255, 30, 30, 0.14), rgba(5, 10, 20, 0.78) 40%, rgba(8, 13, 28, 0.84)) !important;
    clip-path: polygon(12px 0, 100% 0, 100% calc(100% - 12px), calc(100% - 12px) 100%, 0 100%, 0 12px) !important;
    box-shadow:
        inset 0 0 0 1px rgba(255, 255, 255, 0.03),
        inset 0 0 18px rgba(255, 24, 38, 0.07),
        0 0 18px rgba(255, 24, 38, 0.12) !important;
}

.nv-plugin-showcase-card > .nv-plugin-showcase-favorite-button::before {
    content: "" !important;
    position: absolute !important;
    inset: 5px !important;
    display: block !important;
    pointer-events: none !important;
    border: 1px solid rgba(255, 255, 255, 0.06) !important;
    background: rgba(0, 0, 0, 0.10) !important;
    clip-path: polygon(9px 0, 100% 0, 100% calc(100% - 9px), calc(100% - 9px) 100%, 0 100%, 0 9px) !important;
    opacity: 1 !important;
}

.nv-plugin-showcase-card > .nv-plugin-showcase-favorite-button::after {
    content: "" !important;
    position: absolute !important;
    left: 7px !important;
    right: 7px !important;
    bottom: 6px !important;
    height: 1px !important;
    display: block !important;
    pointer-events: none !important;
    background: linear-gradient(90deg, transparent, rgba(255, 43, 55, 0.70), transparent) !important;
    opacity: 0.80 !important;
}

.nv-plugin-showcase-card > .nv-plugin-showcase-favorite-button .nv-ui-icon,
.nv-plugin-showcase-card > .nv-plugin-showcase-favorite-button svg {
    position: relative !important;
    z-index: 2 !important;
    width: 23px !important;
    height: 23px !important;
    display: block !important;
    color: rgba(232, 238, 247, 0.88) !important;
    margin: 0 !important;
    padding: 0 !important;
    filter: drop-shadow(0 0 7px rgba(255, 255, 255, 0.08)) !important;
}

.nv-plugin-showcase-card > .nv-plugin-showcase-favorite-button .nv-ui-icon-bookmark,
.nv-plugin-showcase-card > .nv-plugin-showcase-favorite-button .nv-ui-icon-bookmark *,
.nv-plugin-showcase-card > .nv-plugin-showcase-favorite-button .nv-ui-icon-bookmark .nv-ui-icon-tone,
.nv-plugin-showcase-card > .nv-plugin-showcase-favorite-button .nv-ui-icon-bookmark .nv-ui-icon-accent {
    stroke: rgba(232, 238, 247, 0.88) !important;
    fill: none !important;
}

.nv-plugin-showcase-card > .nv-plugin-showcase-favorite-button:hover,
.nv-plugin-showcase-card > .nv-plugin-showcase-favorite-button:focus-visible {
    border-color: rgba(255, 45, 61, 0.76) !important;
    box-shadow:
        inset 0 0 0 1px rgba(255, 255, 255, 0.04),
        inset 0 0 20px rgba(255, 24, 38, 0.13),
        0 0 22px rgba(255, 24, 38, 0.22) !important;
}

.nv-plugin-showcase-card > .nv-plugin-showcase-favorite-button:hover .nv-ui-icon-bookmark,
.nv-plugin-showcase-card > .nv-plugin-showcase-favorite-button:hover .nv-ui-icon-bookmark *,
.nv-plugin-showcase-card > .nv-plugin-showcase-favorite-button:focus-visible .nv-ui-icon-bookmark,
.nv-plugin-showcase-card > .nv-plugin-showcase-favorite-button:focus-visible .nv-ui-icon-bookmark * {
    stroke: #ff3348 !important;
}

.nv-plugin-showcase-card > .nv-plugin-showcase-favorite-button.is-active .nv-ui-icon-bookmark,
.nv-plugin-showcase-card.is-favorite > .nv-plugin-showcase-favorite-button .nv-ui-icon-bookmark {
    color: #ff3348 !important;
}

.nv-plugin-showcase-card > .nv-plugin-showcase-favorite-button.is-active .nv-ui-icon-bookmark .nv-ui-icon-tone,
.nv-plugin-showcase-card.is-favorite > .nv-plugin-showcase-favorite-button .nv-ui-icon-bookmark .nv-ui-icon-tone {
    stroke: #ff3348 !important;
    fill: rgba(255, 51, 72, 0.16) !important;
}

.nv-plugin-showcase-card > .nv-plugin-showcase-favorite-button .nv-plugin-showcase-favorite-count,
.nv-plugin-showcase-card > .nv-plugin-showcase-favorite-button [data-nv-plugin-favorite-count],
.nv-plugin-showcase-card > .nv-plugin-showcase-favorite-button [class*="count"],
.nv-plugin-showcase-card > .nv-plugin-showcase-favorite-button [class*="badge"] {
    display: none !important;
    visibility: hidden !important;
    opacity: 0 !important;
    width: 0 !important;
    height: 0 !important;
    overflow: hidden !important;
}

@media (max-width: 720px) {
    .nv-plugin-showcase-card .nv-plugin-showcase-card-summary {
        grid-template-columns: minmax(0, 1fr) 106px !important;
    }

    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating,
    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-grid,
    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-metric--rating,
    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-rating-widget {
        width: 106px !important;
        min-width: 106px !important;
        max-width: 106px !important;
        height: 64px !important;
        min-height: 64px !important;
        max-height: 64px !important;
    }

    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-metric--rating,
    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-rating-widget {
        grid-template-columns: 36px minmax(0, 42px) !important;
        gap: 8px !important;
        padding: 8px 9px !important;
    }

    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-badge {
        width: 36px !important;
        height: 36px !important;
        min-width: 36px !important;
        min-height: 36px !important;
    }

    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating,
    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating strong,
    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em {
        width: 42px !important;
        max-width: 42px !important;
    }
}

/* =========================================================
   v1.1.72 - Reference block rebuild: bookmark + rating panel.
   ========================================================= */
.nv-plugin-showcase-card .nv-plugin-showcase-card-content {
    grid-template-rows: 36px 106px 42px 28px !important;
    row-gap: 9px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-summary {
    grid-template-columns: minmax(0, 1fr) 138px !important;
    gap: 12px !important;
    align-items: center !important;
    min-height: 106px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-summary-copy {
    align-self: center !important;
    min-width: 0 !important;
}

/* Bottom Fab metrics: centered as one whole icon+number group, not separate centered children. */
.nv-plugin-showcase-card .nv-plugin-showcase-card-metrics,
.nv-plugin-showcase-card .nv-plugin-showcase-card-metrics .nv-asset-signal-grid {
    height: 42px !important;
    min-height: 42px !important;
    max-height: 42px !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: visible !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-metrics .nv-asset-signal-grid {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 8px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-metrics .nv-asset-signal-metric {
    height: 42px !important;
    min-height: 42px !important;
    max-height: 42px !important;
    width: 100% !important;
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 17px !important;
    padding: 0 16px !important;
    border: 1px solid rgba(141, 153, 173, 0.105) !important;
    background: linear-gradient(180deg, rgba(17, 21, 31, 0.34), rgba(8, 10, 16, 0.42)) !important;
    box-shadow: inset 0 0 0 1px rgba(255,255,255,0.012) !important;
    overflow: hidden !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-metrics .nv-asset-signal-icon {
    order: 1 !important;
    width: 19px !important;
    height: 19px !important;
    flex: 0 0 19px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    margin: 0 !important;
    padding: 0 !important;
    color: rgba(186, 194, 207, 0.78) !important;
    opacity: 1 !important;
    transform: none !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-metrics .nv-asset-signal-icon svg {
    width: 19px !important;
    height: 19px !important;
    display: block !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-metrics .nv-asset-signal-copy {
    order: 2 !important;
    flex: 0 0 auto !important;
    display: block !important;
    width: auto !important;
    min-width: 0 !important;
    max-width: none !important;
    height: auto !important;
    margin: 0 !important;
    padding: 0 !important;
    line-height: 1 !important;
    transform: none !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-metrics .nv-asset-signal-copy small,
.nv-plugin-showcase-card .nv-plugin-showcase-card-metrics .nv-asset-signal-copy em {
    display: none !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-metrics .nv-asset-signal-copy strong {
    display: block !important;
    margin: 0 !important;
    padding: 0 !important;
    width: auto !important;
    min-width: 0 !important;
    max-width: none !important;
    color: rgba(236, 239, 247, 0.92) !important;
    font-size: 20px !important;
    font-weight: 680 !important;
    letter-spacing: 0.01em !important;
    line-height: 1 !important;
    text-align: left !important;
    white-space: nowrap !important;
}

/* Rating panel: make it read as the generated angular block. */
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-grid {
    width: 138px !important;
    min-width: 138px !important;
    max-width: 138px !important;
    height: 78px !important;
    min-height: 78px !important;
    max-height: 78px !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: visible !important;
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-metric--rating,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-rating-widget {
    --nv-rating-accent: #ff684a;
    --nv-rating-glow: rgba(255, 76, 48, 0.34);
    position: relative !important;
    isolation: isolate !important;
    width: 138px !important;
    min-width: 138px !important;
    max-width: 138px !important;
    height: 78px !important;
    min-height: 78px !important;
    max-height: 78px !important;
    display: grid !important;
    grid-template-columns: 54px 48px !important;
    align-items: center !important;
    justify-content: center !important;
    column-gap: 14px !important;
    padding: 10px 14px !important;
    overflow: hidden !important;
    border: 1px solid rgba(255, 48, 43, 0.62) !important;
    border-radius: 0 !important;
    background:
        radial-gradient(circle at 28% 50%, rgba(255, 78, 42, 0.24), transparent 38%),
        linear-gradient(180deg, rgba(16, 18, 28, 0.96), rgba(5, 8, 16, 0.95)) !important;
    clip-path: polygon(12px 0, calc(100% - 12px) 0, 100% 12px, 100% calc(100% - 12px), calc(100% - 12px) 100%, 12px 100%, 0 calc(100% - 12px), 0 12px) !important;
    box-shadow:
        inset 0 0 0 1px rgba(255,255,255,0.035),
        inset 0 0 24px rgba(255, 34, 34, 0.075),
        0 0 18px rgba(255, 24, 30, 0.16) !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-metric--rating::before {
    content: "" !important;
    position: absolute !important;
    inset: 5px !important;
    display: block !important;
    pointer-events: none !important;
    border: 1px solid rgba(255, 55, 48, 0.24) !important;
    background: linear-gradient(90deg, rgba(255, 36, 36, 0.045), rgba(0, 180, 255, 0.025)) !important;
    clip-path: polygon(10px 0, calc(100% - 10px) 0, 100% 10px, 100% calc(100% - 10px), calc(100% - 10px) 100%, 10px 100%, 0 calc(100% - 10px), 0 10px) !important;
    opacity: 1 !important;
    z-index: -1 !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-metric--rating::after {
    content: "" !important;
    position: absolute !important;
    left: 10px !important;
    right: 10px !important;
    bottom: 7px !important;
    height: 1px !important;
    display: block !important;
    pointer-events: none !important;
    background: linear-gradient(90deg, transparent, rgba(255, 78, 48, 0.82), transparent) !important;
    opacity: 0.82 !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-badge {
    position: relative !important;
    z-index: 1 !important;
    width: 52px !important;
    height: 52px !important;
    min-width: 52px !important;
    min-height: 52px !important;
    flex: 0 0 52px !important;
    border-radius: 50% !important;
    background:
        radial-gradient(circle at 50% 50%, rgba(0,0,0,0.88) 0 24%, transparent 25% 100%),
        radial-gradient(circle at 50% 50%, rgba(255, 93, 49, 0.24), rgba(9, 8, 14, 0.98) 63%) !important;
    box-shadow:
        inset 0 0 0 1px rgba(255,255,255,0.055),
        inset 0 0 0 2px rgba(255, 42, 36, 0.10),
        0 0 16px rgba(255, 69, 40, 0.22) !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-badge-shell::before {
    inset: 4px !important;
    border-radius: 50% !important;
    border-color: rgba(255, 58, 41, 0.24) !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-badge-shell::after {
    display: none !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-ring-base,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-ring-fill {
    inset: 8px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-core {
    inset: 18px !important;
    background: rgba(0,0,0,0.76) !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating {
    position: relative !important;
    z-index: 1 !important;
    display: grid !important;
    grid-template-rows: 30px 22px !important;
    align-content: center !important;
    justify-items: start !important;
    gap: 0 !important;
    width: 48px !important;
    min-width: 48px !important;
    max-width: 48px !important;
    overflow: visible !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating small,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-max {
    display: none !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating strong {
    grid-row: 1 !important;
    display: block !important;
    width: 48px !important;
    max-width: 48px !important;
    margin: 0 !important;
    padding: 0 !important;
    color: rgba(246, 249, 255, 0.94) !important;
    font-size: 26px !important;
    font-weight: 520 !important;
    letter-spacing: 0.01em !important;
    line-height: 30px !important;
    white-space: nowrap !important;
    text-align: left !important;
    overflow: visible !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating [data-nv-rating-value-text] {
    color: rgba(246, 249, 255, 0.94) !important;
    font-size: 26px !important;
    line-height: 30px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em {
    grid-row: 2 !important;
    display: block !important;
    width: 48px !important;
    max-width: 48px !important;
    height: 22px !important;
    margin: 0 !important;
    padding: 0 !important;
    color: rgba(187, 193, 206, 0.64) !important;
    font-size: 21px !important;
    font-style: normal !important;
    font-weight: 460 !important;
    letter-spacing: 0.02em !important;
    line-height: 22px !important;
    text-align: left !important;
    white-space: nowrap !important;
    overflow: visible !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em::before,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em::after {
    content: none !important;
    display: none !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em span {
    color: rgba(187, 193, 206, 0.64) !important;
    font-size: 21px !important;
    line-height: 22px !important;
}

/* Bookmark panel: custom glyph only. No heart icon and no counter can render here. */
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button,
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button.is-active,
.nv-plugin-showcase-card.is-favorite > .nv-plugin-showcase-bookmark-button {
    position: absolute !important;
    top: 18px !important;
    right: 18px !important;
    z-index: 9 !important;
    width: 48px !important;
    height: 58px !important;
    min-width: 48px !important;
    min-height: 58px !important;
    padding: 0 !important;
    display: grid !important;
    place-items: center !important;
    overflow: hidden !important;
    color: transparent !important;
    font-size: 0 !important;
    line-height: 0 !important;
    border: 1px solid rgba(255, 43, 47, 0.64) !important;
    border-radius: 0 !important;
    background:
        radial-gradient(circle at 50% 42%, rgba(255, 34, 38, 0.12), transparent 50%),
        linear-gradient(180deg, rgba(9, 13, 23, 0.78), rgba(2, 6, 13, 0.82)) !important;
    clip-path: polygon(13px 0, 100% 0, 100% calc(100% - 13px), calc(100% - 13px) 100%, 0 100%, 0 13px) !important;
    box-shadow:
        inset 0 0 0 1px rgba(255,255,255,0.032),
        inset 0 0 18px rgba(255, 36, 37, 0.07),
        0 0 20px rgba(255, 28, 38, 0.15) !important;
}

.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button::before {
    content: "" !important;
    position: absolute !important;
    inset: 6px !important;
    display: block !important;
    pointer-events: none !important;
    border: 1px solid rgba(255, 60, 55, 0.28) !important;
    background: rgba(0, 0, 0, 0.08) !important;
    clip-path: polygon(10px 0, 100% 0, 100% calc(100% - 10px), calc(100% - 10px) 100%, 0 100%, 0 10px) !important;
    opacity: 1 !important;
}

.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button::after {
    content: "" !important;
    position: absolute !important;
    left: 8px !important;
    right: 8px !important;
    bottom: 7px !important;
    height: 1px !important;
    display: block !important;
    pointer-events: none !important;
    background: linear-gradient(90deg, transparent, rgba(255, 66, 55, 0.85), transparent) !important;
    opacity: 0.9 !important;
}

.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button > :not(.nv-bookmark-glyph),
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button .nv-ui-icon,
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button .nv-ui-icon-heart,
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button .nv-plugin-showcase-favorite-count,
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button [data-nv-plugin-favorite-count],
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button [class*="count"],
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button [class*="badge"] {
    display: none !important;
    visibility: hidden !important;
    opacity: 0 !important;
}

.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button .nv-bookmark-glyph {
    position: relative !important;
    z-index: 2 !important;
    display: block !important;
    width: 30px !important;
    height: 30px !important;
    color: transparent !important;
}

.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button .nv-bookmark-glyph svg {
    display: block !important;
    width: 30px !important;
    height: 30px !important;
    overflow: visible !important;
}

.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button .nv-bookmark-glyph path {
    fill: none !important;
    stroke: rgba(239, 244, 252, 0.92) !important;
    stroke-width: 1.8 !important;
    stroke-linejoin: round !important;
    stroke-linecap: round !important;
    filter: drop-shadow(0 0 7px rgba(255,255,255,0.10)) !important;
}

.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button:hover,
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button:focus-visible {
    border-color: rgba(255, 61, 57, 0.92) !important;
    box-shadow:
        inset 0 0 0 1px rgba(255,255,255,0.04),
        inset 0 0 22px rgba(255, 38, 40, 0.13),
        0 0 24px rgba(255, 38, 41, 0.26) !important;
}

.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button:hover .nv-bookmark-glyph path,
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button:focus-visible .nv-bookmark-glyph path {
    stroke: #ff3f3b !important;
}

.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button.is-active .nv-bookmark-glyph path,
.nv-plugin-showcase-card.is-favorite > .nv-plugin-showcase-bookmark-button .nv-bookmark-glyph path {
    stroke: rgba(246, 249, 255, 0.96) !important;
    fill: rgba(246, 249, 255, 0.08) !important;
}

@media (max-width: 720px) {
    .nv-plugin-showcase-card .nv-plugin-showcase-card-summary {
        grid-template-columns: minmax(0, 1fr) 128px !important;
    }

    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating,
    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-grid,
    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-metric--rating,
    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-rating-widget {
        width: 128px !important;
        min-width: 128px !important;
        max-width: 128px !important;
        height: 74px !important;
        min-height: 74px !important;
        max-height: 74px !important;
    }

    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-metric--rating,
    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-rating-widget {
        grid-template-columns: 50px 44px !important;
        column-gap: 11px !important;
        padding: 9px 12px !important;
    }

    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-badge {
        width: 48px !important;
        height: 48px !important;
        min-width: 48px !important;
        min-height: 48px !important;
    }

    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating strong,
    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating [data-nv-rating-value-text] {
        font-size: 24px !important;
    }

    .nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button {
        top: 15px !important;
        right: 14px !important;
        width: 44px !important;
        height: 54px !important;
        min-width: 44px !important;
        min-height: 54px !important;
    }
}


/* =========================================================
   v1.1.73 - Hard reference rebuild for catalog bookmark/rating panels.
   Uses polygon border layers instead of regular borders so the red outline
   stays visible on all sides and diagonals like the generated reference.
   ========================================================= */
.nv-plugin-showcase-card .nv-plugin-showcase-card-content {
    grid-template-rows: 36px 108px 40px 28px !important;
    row-gap: 9px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-summary {
    grid-template-columns: minmax(0, 1fr) 150px !important;
    gap: 12px !important;
    align-items: center !important;
    min-height: 108px !important;
}

/* The reference panel is not a soft pill. It is a clipped neon plate. */
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-grid {
    width: 150px !important;
    min-width: 150px !important;
    max-width: 150px !important;
    height: 82px !important;
    min-height: 82px !important;
    max-height: 82px !important;
    margin: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    overflow: visible !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-metric--rating,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-rating-widget {
    --nv-panel-cut: 15px;
    --nv-panel-border: 2px;
    --nv-rating-accent: #ff6242 !important;
    --nv-rating-glow: rgba(255, 73, 43, 0.52) !important;
    position: relative !important;
    isolation: isolate !important;
    width: 150px !important;
    min-width: 150px !important;
    max-width: 150px !important;
    height: 82px !important;
    min-height: 82px !important;
    max-height: 82px !important;
    display: grid !important;
    grid-template-columns: 62px 54px !important;
    column-gap: 16px !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 0 14px !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    overflow: visible !important;
    clip-path: none !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-metric--rating::before {
    content: "" !important;
    position: absolute !important;
    inset: 0 !important;
    z-index: -2 !important;
    display: block !important;
    pointer-events: none !important;
    background: linear-gradient(135deg, #ff332d 0%, #ff6047 48%, rgba(255, 48, 37, 0.62) 100%) !important;
    clip-path: polygon(var(--nv-panel-cut) 0, calc(100% - var(--nv-panel-cut)) 0, 100% var(--nv-panel-cut), 100% calc(100% - var(--nv-panel-cut)), calc(100% - var(--nv-panel-cut)) 100%, var(--nv-panel-cut) 100%, 0 calc(100% - var(--nv-panel-cut)), 0 var(--nv-panel-cut)) !important;
    filter: drop-shadow(0 0 8px rgba(255, 44, 35, 0.42)) drop-shadow(0 0 18px rgba(255, 37, 30, 0.20)) !important;
    opacity: 1 !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-metric--rating::after {
    content: "" !important;
    position: absolute !important;
    inset: var(--nv-panel-border) !important;
    z-index: -1 !important;
    display: block !important;
    pointer-events: none !important;
    background:
        radial-gradient(circle at 27% 50%, rgba(255, 75, 38, 0.27), transparent 38%),
        radial-gradient(circle at 66% 47%, rgba(255, 30, 30, 0.10), transparent 62%),
        linear-gradient(180deg, rgba(12, 15, 23, 0.985), rgba(4, 6, 12, 0.985)) !important;
    clip-path: polygon(calc(var(--nv-panel-cut) - var(--nv-panel-border)) 0, calc(100% - var(--nv-panel-cut) + var(--nv-panel-border)) 0, 100% calc(var(--nv-panel-cut) - var(--nv-panel-border)), 100% calc(100% - var(--nv-panel-cut) + var(--nv-panel-border)), calc(100% - var(--nv-panel-cut) + var(--nv-panel-border)) 100%, calc(var(--nv-panel-cut) - var(--nv-panel-border)) 100%, 0 calc(100% - var(--nv-panel-cut) + var(--nv-panel-border)), 0 calc(var(--nv-panel-cut) - var(--nv-panel-border))) !important;
    box-shadow: inset 0 0 28px rgba(255, 43, 34, 0.10) !important;
    opacity: 1 !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-badge {
    position: relative !important;
    z-index: 2 !important;
    width: 60px !important;
    height: 60px !important;
    min-width: 60px !important;
    min-height: 60px !important;
    flex: 0 0 60px !important;
    border-radius: 50% !important;
    background:
        radial-gradient(circle at center, #020306 0 28%, transparent 29% 100%),
        radial-gradient(circle at 50% 50%, rgba(255, 91, 49, 0.30), rgba(9, 8, 14, 0.98) 64%) !important;
    box-shadow:
        inset 0 0 0 1px rgba(255, 90, 56, 0.32),
        inset 0 0 0 2px rgba(255, 44, 34, 0.11),
        0 0 18px rgba(255, 74, 42, 0.30) !important;
    overflow: visible !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-badge-shell::before {
    inset: 3px !important;
    border-radius: 50% !important;
    border: 1px solid rgba(255, 60, 41, 0.36) !important;
    box-shadow: 0 0 10px rgba(255, 53, 39, 0.18), inset 0 0 12px rgba(255, 53, 39, 0.08) !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-badge-shell::after {
    display: block !important;
    left: 50% !important;
    top: 50% !important;
    width: 70px !important;
    height: 70px !important;
    border-radius: 50% !important;
    border: 1px solid rgba(255, 55, 41, 0.12) !important;
    transform: translate(-50%, -50%) !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-ring-base,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-ring-fill {
    inset: 9px !important;
    -webkit-mask: radial-gradient(farthest-side, transparent calc(100% - 10px), #000 calc(100% - 9px)) !important;
    mask: radial-gradient(farthest-side, transparent calc(100% - 10px), #000 calc(100% - 9px)) !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-ring-base {
    background: conic-gradient(from -90deg,
        rgba(255, 72, 42, 0.15) 0deg 60deg, transparent 60deg 72deg,
        rgba(255, 72, 42, 0.15) 72deg 132deg, transparent 132deg 144deg,
        rgba(255, 72, 42, 0.15) 144deg 204deg, transparent 204deg 216deg,
        rgba(255, 72, 42, 0.15) 216deg 276deg, transparent 276deg 288deg,
        rgba(255, 72, 42, 0.15) 288deg 348deg, transparent 348deg 360deg) !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-ring-fill {
    filter: drop-shadow(0 0 8px rgba(255, 95, 48, 0.95)) drop-shadow(0 0 14px rgba(255, 56, 35, 0.45)) !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-core {
    inset: 21px !important;
    border-radius: 50% !important;
    background: #030407 !important;
    box-shadow: inset 0 0 0 1px rgba(255, 80, 45, 0.18), 0 0 16px rgba(255, 47, 31, 0.12) !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating {
    position: relative !important;
    z-index: 2 !important;
    display: grid !important;
    grid-template-rows: 38px 27px !important;
    align-content: center !important;
    justify-items: start !important;
    gap: 0 !important;
    width: 54px !important;
    min-width: 54px !important;
    max-width: 54px !important;
    padding: 0 !important;
    margin: 0 !important;
    overflow: visible !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating small,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-max {
    display: none !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating strong,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating [data-nv-rating-value-text] {
    display: block !important;
    width: 54px !important;
    max-width: 54px !important;
    margin: 0 !important;
    padding: 0 !important;
    color: rgba(250, 252, 255, 0.96) !important;
    font-size: 30px !important;
    font-weight: 480 !important;
    letter-spacing: 0.02em !important;
    line-height: 38px !important;
    text-align: left !important;
    white-space: nowrap !important;
    overflow: visible !important;
    text-shadow: 0 0 10px rgba(255,255,255,0.09) !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em span {
    display: block !important;
    width: 54px !important;
    max-width: 54px !important;
    margin: 0 !important;
    padding: 0 !important;
    color: rgba(188, 191, 202, 0.72) !important;
    font-size: 24px !important;
    font-style: normal !important;
    font-weight: 430 !important;
    letter-spacing: 0.03em !important;
    line-height: 27px !important;
    text-align: left !important;
    white-space: nowrap !important;
    overflow: visible !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em::before,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em::after {
    display: none !important;
    content: none !important;
}

/* Bookmark reference block: pure CSS glyph, no SVG, no heart, no count. */
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button,
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button.is-active,
.nv-plugin-showcase-card.is-favorite > .nv-plugin-showcase-bookmark-button {
    --nv-bookmark-cut: 15px;
    --nv-bookmark-border: 2px;
    position: absolute !important;
    top: 18px !important;
    right: 18px !important;
    z-index: 12 !important;
    width: 62px !important;
    height: 62px !important;
    min-width: 62px !important;
    min-height: 62px !important;
    max-width: 62px !important;
    max-height: 62px !important;
    padding: 0 !important;
    margin: 0 !important;
    display: grid !important;
    place-items: center !important;
    border: 0 !important;
    border-radius: 0 !important;
    outline: none !important;
    background: transparent !important;
    box-shadow: none !important;
    clip-path: none !important;
    color: transparent !important;
    font-size: 0 !important;
    line-height: 0 !important;
    text-indent: -9999px !important;
    overflow: visible !important;
}

.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button::before {
    content: "" !important;
    position: absolute !important;
    inset: 0 !important;
    z-index: 0 !important;
    display: block !important;
    pointer-events: none !important;
    background: linear-gradient(135deg, #ff312d 0%, #ff5b45 48%, rgba(255, 46, 38, 0.68) 100%) !important;
    clip-path: polygon(var(--nv-bookmark-cut) 0, 100% 0, 100% calc(100% - var(--nv-bookmark-cut)), calc(100% - var(--nv-bookmark-cut)) 100%, 0 100%, 0 var(--nv-bookmark-cut)) !important;
    filter: drop-shadow(0 0 8px rgba(255, 43, 35, 0.43)) drop-shadow(0 0 17px rgba(255, 36, 30, 0.20)) !important;
    opacity: 1 !important;
}

.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button::after {
    content: "" !important;
    position: absolute !important;
    inset: var(--nv-bookmark-border) !important;
    z-index: 1 !important;
    display: block !important;
    pointer-events: none !important;
    background:
        radial-gradient(circle at 54% 44%, rgba(255, 44, 36, 0.13), transparent 52%),
        linear-gradient(180deg, rgba(7, 10, 18, 0.965), rgba(2, 4, 9, 0.965)) !important;
    clip-path: polygon(calc(var(--nv-bookmark-cut) - var(--nv-bookmark-border)) 0, 100% 0, 100% calc(100% - var(--nv-bookmark-cut) + var(--nv-bookmark-border)), calc(100% - var(--nv-bookmark-cut) + var(--nv-bookmark-border)) 100%, 0 100%, 0 calc(var(--nv-bookmark-cut) - var(--nv-bookmark-border))) !important;
    box-shadow: inset 0 0 22px rgba(255, 42, 35, 0.08) !important;
    opacity: 1 !important;
}

.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button > :not(.nv-bookmark-cyber-glyph),
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button svg,
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button path,
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button .nv-bookmark-glyph,
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button .nv-ui-icon,
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button .nv-ui-icon-heart,
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button .nv-plugin-showcase-favorite-count,
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button [data-nv-plugin-favorite-count],
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button [class*="count"],
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button [class*="badge"] {
    display: none !important;
    visibility: hidden !important;
    opacity: 0 !important;
    width: 0 !important;
    height: 0 !important;
    overflow: hidden !important;
}

.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button .nv-bookmark-cyber-glyph {
    position: relative !important;
    z-index: 3 !important;
    display: block !important;
    width: 26px !important;
    height: 33px !important;
    text-indent: 0 !important;
    color: transparent !important;
    background: rgba(245, 248, 255, 0.96) !important;
    clip-path: polygon(15% 0, 85% 0, 85% 100%, 50% 74%, 15% 100%) !important;
    filter: drop-shadow(0 0 7px rgba(255,255,255,0.14)) !important;
}

.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button .nv-bookmark-cyber-glyph::after {
    content: "" !important;
    position: absolute !important;
    inset: 3px 4px 4px 4px !important;
    display: block !important;
    background: #05070e !important;
    clip-path: polygon(18% 0, 82% 0, 82% 100%, 50% 73%, 18% 100%) !important;
}

.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button:hover::before,
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button:focus-visible::before {
    filter: drop-shadow(0 0 10px rgba(255, 55, 41, 0.62)) drop-shadow(0 0 24px rgba(255, 44, 35, 0.33)) !important;
}

.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button:hover .nv-bookmark-cyber-glyph,
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button:focus-visible .nv-bookmark-cyber-glyph {
    background: #ff4d40 !important;
    filter: drop-shadow(0 0 8px rgba(255, 74, 59, 0.44)) !important;
}

.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button.is-active .nv-bookmark-cyber-glyph,
.nv-plugin-showcase-card.is-favorite > .nv-plugin-showcase-bookmark-button .nv-bookmark-cyber-glyph {
    background: rgba(248, 251, 255, 0.98) !important;
}

@media (max-width: 720px) {
    .nv-plugin-showcase-card .nv-plugin-showcase-card-summary {
        grid-template-columns: minmax(0, 1fr) 142px !important;
    }

    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating,
    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-grid,
    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-metric--rating,
    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-rating-widget {
        width: 142px !important;
        min-width: 142px !important;
        max-width: 142px !important;
        height: 78px !important;
        min-height: 78px !important;
        max-height: 78px !important;
    }

    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-metric--rating,
    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-rating-widget {
        grid-template-columns: 56px 50px !important;
        column-gap: 14px !important;
        padding: 0 12px !important;
    }

    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-badge {
        width: 56px !important;
        height: 56px !important;
        min-width: 56px !important;
        min-height: 56px !important;
    }

    .nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button {
        top: 15px !important;
        right: 15px !important;
        width: 58px !important;
        height: 58px !important;
        min-width: 58px !important;
        min-height: 58px !important;
    }
}


/* =========================================================
   v1.1.74 - Reference scale correction.
   Goal: bookmark and rating panels look like the generated reference,
   but scaled down for catalog cards. Rating is compact, not a huge third
   of the card. Bookmark is a visible white outline glyph, no heart/count.
   ========================================================= */
.nv-plugin-showcase-card {
    height: 423px !important;
    min-height: 423px !important;
    max-height: 423px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-content {
    grid-template-rows: 36px 94px 44px 28px !important;
    row-gap: 9px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-summary {
    grid-template-columns: minmax(0, 1fr) 118px !important;
    gap: 10px !important;
    align-items: center !important;
    min-height: 94px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-summary-copy {
    min-width: 0 !important;
    align-self: center !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-grid {
    width: 118px !important;
    min-width: 118px !important;
    max-width: 118px !important;
    height: 60px !important;
    min-height: 60px !important;
    max-height: 60px !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: visible !important;
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-metric--rating,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-rating-widget {
    --nv-panel-cut: 12px !important;
    --nv-panel-border: 2px !important;
    width: 118px !important;
    min-width: 118px !important;
    max-width: 118px !important;
    height: 60px !important;
    min-height: 60px !important;
    max-height: 60px !important;
    display: grid !important;
    grid-template-columns: 46px 44px !important;
    column-gap: 10px !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 0 10px !important;
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    overflow: visible !important;
    isolation: isolate !important;
    clip-path: none !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-metric--rating::before {
    content: "" !important;
    position: absolute !important;
    inset: 0 !important;
    z-index: -2 !important;
    display: block !important;
    background: #ff4b3a !important;
    clip-path: polygon(var(--nv-panel-cut) 0, calc(100% - var(--nv-panel-cut)) 0, 100% var(--nv-panel-cut), 100% calc(100% - var(--nv-panel-cut)), calc(100% - var(--nv-panel-cut)) 100%, var(--nv-panel-cut) 100%, 0 calc(100% - var(--nv-panel-cut)), 0 var(--nv-panel-cut)) !important;
    filter: drop-shadow(0 0 7px rgba(255, 66, 49, 0.54)) drop-shadow(0 0 15px rgba(255, 36, 28, 0.24)) !important;
    opacity: 1 !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-metric--rating::after {
    content: "" !important;
    position: absolute !important;
    inset: var(--nv-panel-border) !important;
    z-index: -1 !important;
    display: block !important;
    background:
        radial-gradient(circle at 30% 50%, rgba(255, 84, 44, 0.22), transparent 42%),
        linear-gradient(180deg, rgba(9, 12, 19, 0.985), rgba(3, 5, 10, 0.985)) !important;
    clip-path: polygon(calc(var(--nv-panel-cut) - var(--nv-panel-border)) 0, calc(100% - var(--nv-panel-cut) + var(--nv-panel-border)) 0, 100% calc(var(--nv-panel-cut) - var(--nv-panel-border)), 100% calc(100% - var(--nv-panel-cut) + var(--nv-panel-border)), calc(100% - var(--nv-panel-cut) + var(--nv-panel-border)) 100%, calc(var(--nv-panel-cut) - var(--nv-panel-border)) 100%, 0 calc(100% - var(--nv-panel-cut) + var(--nv-panel-border)), 0 calc(var(--nv-panel-cut) - var(--nv-panel-border))) !important;
    box-shadow: inset 0 0 20px rgba(255, 43, 34, 0.10) !important;
    opacity: 1 !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-badge {
    width: 44px !important;
    height: 44px !important;
    min-width: 44px !important;
    min-height: 44px !important;
    flex: 0 0 44px !important;
    border-radius: 50% !important;
    background:
        radial-gradient(circle at center, #020306 0 29%, transparent 30% 100%),
        radial-gradient(circle at 50% 50%, rgba(255, 91, 49, 0.30), rgba(9, 8, 14, 0.98) 64%) !important;
    box-shadow:
        inset 0 0 0 1px rgba(255, 90, 56, 0.32),
        0 0 13px rgba(255, 74, 42, 0.30) !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-badge-shell::before {
    inset: 3px !important;
    border-radius: 50% !important;
    border: 1px solid rgba(255, 60, 41, 0.38) !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-badge-shell::after {
    display: block !important;
    left: 50% !important;
    top: 50% !important;
    width: 53px !important;
    height: 53px !important;
    border-radius: 50% !important;
    border: 1px solid rgba(255, 55, 41, 0.12) !important;
    transform: translate(-50%, -50%) !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-ring-base,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-ring-fill {
    inset: 7px !important;
    -webkit-mask: radial-gradient(farthest-side, transparent calc(100% - 7px), #000 calc(100% - 6px)) !important;
    mask: radial-gradient(farthest-side, transparent calc(100% - 7px), #000 calc(100% - 6px)) !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-core {
    inset: 16px !important;
    border-radius: 50% !important;
    background: #030407 !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating {
    width: 44px !important;
    min-width: 44px !important;
    max-width: 44px !important;
    display: grid !important;
    grid-template-rows: 29px 20px !important;
    align-content: center !important;
    justify-items: start !important;
    gap: 0 !important;
    overflow: visible !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating small,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-max {
    display: none !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating strong,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating [data-nv-rating-value-text] {
    width: 44px !important;
    max-width: 44px !important;
    color: rgba(250, 252, 255, 0.96) !important;
    font-size: 24px !important;
    font-weight: 480 !important;
    line-height: 29px !important;
    text-align: left !important;
    white-space: nowrap !important;
    overflow: visible !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em span {
    width: 44px !important;
    max-width: 44px !important;
    color: rgba(188, 191, 202, 0.74) !important;
    font-size: 17px !important;
    font-style: normal !important;
    font-weight: 430 !important;
    letter-spacing: 0.03em !important;
    line-height: 20px !important;
    text-align: left !important;
    white-space: nowrap !important;
    overflow: visible !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em::before,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em::after {
    display: none !important;
    content: none !important;
}

/* Bookmark: exact red cyber plate, white outline bookmark, no heart, no number. */
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button,
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button.is-active,
.nv-plugin-showcase-card.is-favorite > .nv-plugin-showcase-bookmark-button {
    --nv-bookmark-cut: 13px !important;
    --nv-bookmark-border: 2px !important;
    position: absolute !important;
    top: 16px !important;
    right: 16px !important;
    z-index: 30 !important;
    width: 54px !important;
    height: 54px !important;
    min-width: 54px !important;
    min-height: 54px !important;
    max-width: 54px !important;
    max-height: 54px !important;
    display: grid !important;
    place-items: center !important;
    padding: 0 !important;
    margin: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    color: rgba(250, 252, 255, 0.98) !important;
    font-size: 0 !important;
    line-height: 0 !important;
    text-indent: 0 !important;
    overflow: visible !important;
    clip-path: none !important;
}

.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button::before {
    content: "" !important;
    position: absolute !important;
    inset: 0 !important;
    z-index: 0 !important;
    display: block !important;
    background: #ff4a3c !important;
    clip-path: polygon(var(--nv-bookmark-cut) 0, 100% 0, 100% calc(100% - var(--nv-bookmark-cut)), calc(100% - var(--nv-bookmark-cut)) 100%, 0 100%, 0 var(--nv-bookmark-cut)) !important;
    filter: drop-shadow(0 0 7px rgba(255, 67, 51, 0.55)) drop-shadow(0 0 15px rgba(255, 39, 30, 0.25)) !important;
    opacity: 1 !important;
}

.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button::after {
    content: "" !important;
    position: absolute !important;
    inset: var(--nv-bookmark-border) !important;
    z-index: 1 !important;
    display: block !important;
    background:
        radial-gradient(circle at 52% 42%, rgba(255, 57, 45, 0.13), transparent 55%),
        linear-gradient(180deg, rgba(6, 8, 15, 0.985), rgba(2, 4, 9, 0.985)) !important;
    clip-path: polygon(calc(var(--nv-bookmark-cut) - var(--nv-bookmark-border)) 0, 100% 0, 100% calc(100% - var(--nv-bookmark-cut) + var(--nv-bookmark-border)), calc(100% - var(--nv-bookmark-cut) + var(--nv-bookmark-border)) 100%, 0 100%, 0 calc(var(--nv-bookmark-cut) - var(--nv-bookmark-border))) !important;
    box-shadow: inset 0 0 18px rgba(255, 42, 35, 0.10) !important;
    opacity: 1 !important;
}

.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button > :not(.nv-bookmark-only-icon),
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button .nv-plugin-showcase-favorite-count,
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button [data-nv-plugin-favorite-count],
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button [class*="count"],
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button [class*="badge"],
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button .nv-ui-icon-heart,
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button .nv-ui-icon-bookmark {
    display: none !important;
    visibility: hidden !important;
    opacity: 0 !important;
}

.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button .nv-bookmark-only-icon {
    position: relative !important;
    z-index: 3 !important;
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    width: 24px !important;
    height: 31px !important;
    overflow: visible !important;
    color: rgba(248, 251, 255, 0.98) !important;
    stroke: currentColor !important;
    fill: none !important;
    filter: drop-shadow(0 0 5px rgba(255, 255, 255, 0.20)) !important;
    pointer-events: none !important;
}

.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button .nv-bookmark-only-icon path {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    fill: none !important;
    stroke: currentColor !important;
}

.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button:hover .nv-bookmark-only-icon,
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button:focus-visible .nv-bookmark-only-icon {
    color: #ff5545 !important;
    filter: drop-shadow(0 0 8px rgba(255, 74, 59, 0.50)) !important;
}

.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button.is-active .nv-bookmark-only-icon,
.nv-plugin-showcase-card.is-favorite > .nv-plugin-showcase-bookmark-button .nv-bookmark-only-icon {
    color: rgba(250, 252, 255, 0.98) !important;
}

@media (max-width: 720px) {
    .nv-plugin-showcase-card .nv-plugin-showcase-card-summary {
        grid-template-columns: minmax(0, 1fr) 112px !important;
    }
    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating,
    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-grid,
    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-metric--rating,
    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-rating-widget {
        width: 112px !important;
        min-width: 112px !important;
        max-width: 112px !important;
        height: 58px !important;
        min-height: 58px !important;
        max-height: 58px !important;
    }
    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-metric--rating,
    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-rating-widget {
        grid-template-columns: 42px 42px !important;
        column-gap: 9px !important;
        padding: 0 9px !important;
    }
    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-badge {
        width: 42px !important;
        height: 42px !important;
        min-width: 42px !important;
        min-height: 42px !important;
    }
    .nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button {
        top: 14px !important;
        right: 14px !important;
        width: 52px !important;
        height: 52px !important;
        min-width: 52px !important;
        min-height: 52px !important;
    }
}


/* =========================================================
   v1.1.75 - Exact dark reference blocks: no heart in bookmark,
   compact rating, visible frame lines instead of red filled plates.
   ========================================================= */
.nv-plugin-showcase-card {
    height: 446px !important;
    min-height: 446px !important;
    max-height: 446px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-content {
    grid-template-rows: 36px auto 48px 28px !important;
    row-gap: 9px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-summary {
    grid-template-columns: minmax(0, 1fr) 92px !important;
    gap: 8px !important;
    align-items: center !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-summary-copy {
    min-width: 0 !important;
    overflow: hidden !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-summary-copy h3,
.nv-plugin-showcase-card .nv-plugin-showcase-card-summary-copy .nv-plugin-showcase-subtitle {
    max-width: 100% !important;
}

/* Rating block - compact dark panel with real SVG outline frame. */
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-grid,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-metric--rating,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-rating-widget {
    width: 92px !important;
    min-width: 92px !important;
    max-width: 92px !important;
    height: 48px !important;
    min-height: 48px !important;
    max-height: 48px !important;
    margin: 0 !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-metric--rating,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-rating-widget {
    position: relative !important;
    z-index: 0 !important;
    display: grid !important;
    grid-template-columns: 32px 42px !important;
    align-items: center !important;
    justify-content: center !important;
    column-gap: 8px !important;
    padding: 0 7px !important;
    border: 0 !important;
    border-radius: 0 !important;
    outline: 0 !important;
    background: rgba(5, 7, 12, 0.78) !important;
    box-shadow: 0 0 12px rgba(255, 39, 29, 0.14), inset 0 0 18px rgba(255, 48, 32, 0.05) !important;
    clip-path: none !important;
    overflow: visible !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-metric--rating::before,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-metric--rating::after,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-rating-widget::before,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-rating-widget::after {
    display: none !important;
    content: none !important;
}

.nv-plugin-showcase-card .nv-rating-widget-frame {
    position: absolute !important;
    inset: -1px !important;
    z-index: 0 !important;
    display: block !important;
    width: calc(100% + 2px) !important;
    height: calc(100% + 2px) !important;
    overflow: visible !important;
    pointer-events: none !important;
    fill: rgba(4, 6, 10, 0.70) !important;
    stroke: rgba(255, 70, 55, 0.94) !important;
    stroke-width: 1.55 !important;
    vector-effect: non-scaling-stroke !important;
    filter: drop-shadow(0 0 4px rgba(255, 60, 46, 0.56)) drop-shadow(0 0 14px rgba(255, 38, 28, 0.20)) !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-badge {
    position: relative !important;
    z-index: 2 !important;
    width: 31px !important;
    height: 31px !important;
    min-width: 31px !important;
    min-height: 31px !important;
    flex: 0 0 31px !important;
    border-radius: 50% !important;
    background:
        radial-gradient(circle at center, #030406 0 31%, transparent 32% 100%),
        radial-gradient(circle at 50% 50%, rgba(255, 86, 47, 0.28), rgba(7, 7, 11, 0.98) 68%) !important;
    box-shadow: inset 0 0 0 1px rgba(255, 80, 54, 0.34), 0 0 8px rgba(255, 70, 42, 0.28) !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-badge-shell::before {
    inset: 2px !important;
    border-radius: 50% !important;
    border: 1px solid rgba(255, 60, 42, 0.34) !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-badge-shell::after {
    left: 50% !important;
    top: 50% !important;
    width: 40px !important;
    height: 40px !important;
    border-radius: 50% !important;
    border: 1px solid rgba(255, 56, 42, 0.11) !important;
    transform: translate(-50%, -50%) !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-ring-base,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-ring-fill {
    inset: 5px !important;
    -webkit-mask: radial-gradient(farthest-side, transparent calc(100% - 6px), #000 calc(100% - 5px)) !important;
    mask: radial-gradient(farthest-side, transparent calc(100% - 6px), #000 calc(100% - 5px)) !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-core {
    inset: 12px !important;
    border-radius: 50% !important;
    background: #030407 !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-core::before,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-core::after,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-core i::before,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-core i::after {
    width: 7px !important;
    height: 1px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating {
    position: relative !important;
    z-index: 2 !important;
    width: 42px !important;
    min-width: 42px !important;
    max-width: 42px !important;
    display: grid !important;
    grid-template-rows: 25px 16px !important;
    align-content: center !important;
    justify-items: start !important;
    gap: 0 !important;
    overflow: visible !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating small,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-max {
    display: none !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating strong,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating [data-nv-rating-value-text] {
    display: block !important;
    width: 42px !important;
    max-width: 42px !important;
    color: rgba(250, 252, 255, 0.97) !important;
    font-size: 20px !important;
    font-weight: 460 !important;
    line-height: 25px !important;
    letter-spacing: 0.01em !important;
    text-align: left !important;
    white-space: nowrap !important;
    overflow: visible !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em span {
    display: block !important;
    width: 42px !important;
    max-width: 42px !important;
    color: rgba(186, 190, 202, 0.78) !important;
    font-size: 14px !important;
    font-style: normal !important;
    font-weight: 420 !important;
    letter-spacing: 0.02em !important;
    line-height: 16px !important;
    text-align: left !important;
    white-space: nowrap !important;
    overflow: visible !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em::before,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em::after {
    content: none !important;
    display: none !important;
}

/* Bookmark block - same dark reference plate, no red fill, no heart, no number. */
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button {
    position: absolute !important;
    top: 15px !important;
    right: 15px !important;
    z-index: 40 !important;
    width: 46px !important;
    height: 46px !important;
    min-width: 46px !important;
    min-height: 46px !important;
    max-width: 46px !important;
    max-height: 46px !important;
    padding: 0 !important;
    margin: 0 !important;
    border: 0 !important;
    outline: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    display: grid !important;
    place-items: center !important;
    overflow: visible !important;
    color: rgba(250, 252, 255, 0.98) !important;
    font-size: 0 !important;
    line-height: 0 !important;
}

.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button::before,
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button::after {
    display: none !important;
    content: none !important;
}

.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button > :not(.nv-bookmark-only-icon),
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button [class*="heart"],
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button [class*="count"],
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button [class*="badge"],
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button [data-nv-plugin-favorite-count] {
    display: none !important;
    visibility: hidden !important;
    opacity: 0 !important;
}

.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button .nv-bookmark-only-icon {
    display: block !important;
    position: relative !important;
    z-index: 2 !important;
    width: 46px !important;
    height: 46px !important;
    opacity: 1 !important;
    visibility: visible !important;
    overflow: visible !important;
    pointer-events: none !important;
    filter: drop-shadow(0 0 5px rgba(255, 53, 44, 0.30)) !important;
}

.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button .nv-bookmark-frame {
    fill: rgba(4, 6, 10, 0.74) !important;
    stroke: rgba(255, 67, 54, 0.92) !important;
    stroke-width: 1.35 !important;
    vector-effect: non-scaling-stroke !important;
    filter: drop-shadow(0 0 4px rgba(255, 60, 48, 0.52)) drop-shadow(0 0 12px rgba(255, 35, 28, 0.18)) !important;
}

.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button .nv-bookmark-mark {
    fill: none !important;
    stroke: rgba(248, 251, 255, 0.98) !important;
    stroke-width: 2.7 !important;
    stroke-linejoin: miter !important;
    stroke-linecap: square !important;
    vector-effect: non-scaling-stroke !important;
    filter: drop-shadow(0 0 4px rgba(255,255,255,0.22)) !important;
}

.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button:hover .nv-bookmark-frame,
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button:focus-visible .nv-bookmark-frame {
    stroke: rgba(255, 86, 69, 1) !important;
    filter: drop-shadow(0 0 6px rgba(255, 70, 55, 0.70)) drop-shadow(0 0 16px rgba(255, 38, 28, 0.28)) !important;
}

.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button:hover .nv-bookmark-mark,
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button:focus-visible .nv-bookmark-mark,
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button[aria-pressed="true"] .nv-bookmark-mark,
.nv-plugin-showcase-card.is-favorite > .nv-plugin-showcase-bookmark-button .nv-bookmark-mark {
    stroke: rgba(255, 255, 255, 1) !important;
    filter: drop-shadow(0 0 6px rgba(255,255,255,0.34)) !important;
}

@media (max-width: 720px) {
    .nv-plugin-showcase-card .nv-plugin-showcase-card-summary {
        grid-template-columns: minmax(0, 1fr) 88px !important;
    }

    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating,
    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-grid,
    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-metric--rating,
    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-rating-widget {
        width: 88px !important;
        min-width: 88px !important;
        max-width: 88px !important;
        height: 46px !important;
        min-height: 46px !important;
        max-height: 46px !important;
    }

    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-metric--rating,
    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-rating-widget {
        grid-template-columns: 30px 40px !important;
        column-gap: 7px !important;
        padding: 0 6px !important;
    }

    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-badge {
        width: 29px !important;
        height: 29px !important;
        min-width: 29px !important;
        min-height: 29px !important;
    }

    .nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button,
    .nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button .nv-bookmark-only-icon {
        width: 43px !important;
        height: 43px !important;
        min-width: 43px !important;
        min-height: 43px !important;
    }
}


/* --- v1.1.76 final reference block polish --- */
.nv-plugin-showcase-card .nv-plugin-showcase-card-summary {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) auto !important;
    align-items: start !important;
    gap: 0.75rem !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-summary-copy {
    min-width: 0 !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-grid {
    width: 116px !important;
    min-width: 116px !important;
    max-width: 116px !important;
    overflow: visible !important;
    flex: 0 0 116px !important;
    margin: 0 !important;
    align-self: start !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-metric--rating,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-rating-widget {
    position: relative !important;
    display: grid !important;
    grid-template-columns: 42px minmax(0, 1fr) !important;
    align-items: center !important;
    gap: 0.6rem !important;
    width: 116px !important;
    min-width: 116px !important;
    max-width: 116px !important;
    min-height: 58px !important;
    height: 58px !important;
    padding: 7px 10px 7px 8px !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: linear-gradient(180deg, rgba(10, 14, 24, 0.96) 0%, rgba(4, 8, 14, 0.98) 100%) !important;
    box-shadow: 0 0 0 1px rgba(255, 63, 32, 0.72), 0 0 10px rgba(255, 63, 32, 0.18), inset 0 0 14px rgba(0, 0, 0, 0.35) !important;
    clip-path: polygon(12px 0, 100% 0, 100% calc(100% - 12px), calc(100% - 12px) 100%, 0 100%, 0 12px) !important;
    overflow: visible !important;
    isolation: isolate !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-metric--rating::before,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-metric--rating::after {
    content: '' !important;
    position: absolute !important;
    pointer-events: none !important;
    inset: 0 !important;
    border-radius: 0 !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-metric--rating::before {
    clip-path: polygon(12px 0, 100% 0, 100% calc(100% - 12px), calc(100% - 12px) 100%, 0 100%, 0 12px) !important;
    border: 1px solid rgba(255, 84, 48, 0.95) !important;
    box-shadow: inset 0 0 12px rgba(255, 63, 32, 0.10), 0 0 8px rgba(255, 63, 32, 0.16) !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-metric--rating::after {
    inset: 5px !important;
    clip-path: polygon(9px 0, 100% 0, 100% calc(100% - 9px), calc(100% - 9px) 100%, 0 100%, 0 9px) !important;
    border: 1px solid rgba(255, 63, 32, 0.26) !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-widget-frame,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-max,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating small {
    display: none !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-badge {
    position: relative !important;
    width: 38px !important;
    height: 38px !important;
    min-width: 38px !important;
    min-height: 38px !important;
    margin: 0 !important;
    border-radius: 50% !important;
    box-shadow: 0 0 0 1px rgba(255, 79, 39, 0.22), inset 0 0 18px rgba(0, 0, 0, 0.35) !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-badge-shell::before,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-badge-shell::after {
    opacity: 0.95 !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-ring-base,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-ring-fill {
    inset: 3px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-core {
    inset: 12px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating {
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
    align-items: flex-start !important;
    gap: 3px !important;
    min-width: 0 !important;
    overflow: visible !important;
    line-height: 1 !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating strong,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating [data-nv-rating-value-text] {
    display: block !important;
    margin: 0 !important;
    padding: 0 !important;
    font-size: 0.95rem !important;
    line-height: 1 !important;
    font-weight: 800 !important;
    letter-spacing: -0.02em !important;
    color: #f4f6fb !important;
    white-space: nowrap !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em span {
    display: inline-block !important;
    margin: 0 !important;
    padding: 0 !important;
    font-style: normal !important;
    font-size: 0.68rem !important;
    font-weight: 700 !important;
    line-height: 1 !important;
    letter-spacing: -0.01em !important;
    color: rgba(180, 188, 205, 0.92) !important;
    white-space: nowrap !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em::before,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em::after {
    display: inline-block !important;
    font-size: 0.68rem !important;
    line-height: 1 !important;
    color: rgba(180, 188, 205, 0.92) !important;
}

.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button,
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button:hover,
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button:focus-visible,
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button.is-active,
.nv-plugin-showcase-card.is-favorite > .nv-plugin-showcase-bookmark-button {
    position: absolute !important;
    top: 0.72rem !important;
    right: 0.72rem !important;
    left: auto !important;
    bottom: auto !important;
    width: 38px !important;
    height: 38px !important;
    min-width: 38px !important;
    min-height: 38px !important;
    max-width: 38px !important;
    max-height: 38px !important;
    margin: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: rgba(5, 9, 16, 0.92) !important;
    box-shadow: 0 0 0 1px rgba(255, 70, 38, 0.72), inset 0 0 12px rgba(255, 70, 38, 0.08) !important;
    clip-path: polygon(10px 0, 100% 0, 100% calc(100% - 10px), calc(100% - 10px) 100%, 0 100%, 0 10px) !important;
    transform: none !important;
    translate: none !important;
    transition: background-color 0.18s ease, box-shadow 0.18s ease, opacity 0.18s ease, filter 0.18s ease !important;
    overflow: hidden !important;
    z-index: 5 !important;
}

.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button::before,
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button::after {
    content: none !important;
    display: none !important;
}

.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button > :not(.nv-bookmark-only-icon),
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button .nv-plugin-showcase-favorite-count,
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button [data-nv-plugin-favorite-count],
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button [class*="count"],
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button [class*="badge"],
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button .nv-ui-icon-heart,
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button .nv-ui-icon-bookmark {
    display: none !important;
}

.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button .nv-bookmark-only-icon {
    display: block !important;
    width: 38px !important;
    height: 38px !important;
    overflow: visible !important;
}

.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button .nv-bookmark-only-icon .nv-bookmark-frame {
    fill: rgba(4, 8, 14, 0.94) !important;
    stroke: rgba(255, 79, 39, 0.95) !important;
    stroke-width: 1.2 !important;
    filter: drop-shadow(0 0 4px rgba(255, 79, 39, 0.20)) !important;
}

.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button .nv-bookmark-only-icon .nv-bookmark-mark {
    fill: none !important;
    stroke: rgba(245, 247, 252, 0.92) !important;
    stroke-width: 2.1 !important;
    stroke-linejoin: round !important;
    stroke-linecap: round !important;
}

.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button:hover,
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button:focus-visible {
    background: rgba(8, 12, 20, 0.96) !important;
    box-shadow: 0 0 0 1px rgba(255, 86, 52, 0.88), 0 0 8px rgba(255, 86, 52, 0.20), inset 0 0 14px rgba(255, 86, 52, 0.08) !important;
}

.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button.is-active,
.nv-plugin-showcase-card.is-favorite > .nv-plugin-showcase-bookmark-button {
    background: rgba(7, 10, 18, 0.96) !important;
    box-shadow: 0 0 0 1px rgba(255, 86, 52, 0.95), 0 0 10px rgba(255, 86, 52, 0.22), inset 0 0 18px rgba(255, 86, 52, 0.10) !important;
}

.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button.is-active .nv-bookmark-only-icon .nv-bookmark-mark,
.nv-plugin-showcase-card.is-favorite > .nv-plugin-showcase-bookmark-button .nv-bookmark-only-icon .nv-bookmark-mark {
    stroke: #ffffff !important;
}

@media (max-width: 767px) {
    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating,
    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-grid {
        width: 108px !important;
        min-width: 108px !important;
        max-width: 108px !important;
        flex-basis: 108px !important;
    }
    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-metric--rating,
    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-rating-widget {
        width: 108px !important;
        min-width: 108px !important;
        max-width: 108px !important;
        height: 54px !important;
        min-height: 54px !important;
        grid-template-columns: 36px minmax(0, 1fr) !important;
        gap: 0.5rem !important;
    }
    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-badge {
        width: 33px !important;
        height: 33px !important;
        min-width: 33px !important;
        min-height: 33px !important;
    }
    .nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button,
    .nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button:hover,
    .nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button:focus-visible,
    .nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button.is-active,
    .nv-plugin-showcase-card.is-favorite > .nv-plugin-showcase-bookmark-button {
        width: 36px !important;
        height: 36px !important;
        min-width: 36px !important;
        min-height: 36px !important;
    }
    .nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button .nv-bookmark-only-icon {
        width: 36px !important;
        height: 36px !important;
    }
}


/* --- v1.1.77 bookmark hover/active and rating count hard fix --- */
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-grid,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-metric--rating,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-rating-widget {
    overflow: visible !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating strong,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em {
    min-width: 0 !important;
    max-width: none !important;
    overflow: visible !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em {
    display: inline-flex !important;
    flex: 0 0 auto !important;
    align-items: center !important;
    justify-content: flex-start !important;
    gap: 0 !important;
    width: auto !important;
    min-width: 0 !important;
    max-width: max-content !important;
    margin: 0 !important;
    padding: 0 !important;
    font-style: normal !important;
    font-size: 0.68rem !important;
    font-weight: 700 !important;
    line-height: 1 !important;
    letter-spacing: 0 !important;
    color: rgba(185, 194, 210, 0.96) !important;
    white-space: nowrap !important;
    text-align: left !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em::before {
    content: '(' !important;
    display: inline !important;
    margin: 0 !important;
    padding: 0 !important;
    font: inherit !important;
    line-height: 1 !important;
    color: rgba(185, 194, 210, 0.96) !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em::after {
    content: ')' !important;
    display: inline !important;
    margin: 0 !important;
    padding: 0 !important;
    font: inherit !important;
    line-height: 1 !important;
    color: rgba(185, 194, 210, 0.96) !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em span,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em [data-nv-rating-count-text] {
    display: inline !important;
    width: auto !important;
    min-width: 0 !important;
    max-width: none !important;
    margin: 0 !important;
    padding: 0 !important;
    font: inherit !important;
    line-height: 1 !important;
    letter-spacing: 0 !important;
    color: rgba(185, 194, 210, 0.96) !important;
    white-space: nowrap !important;
    text-align: left !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em span::before,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em span::after,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em [data-nv-rating-count-text]::before,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em [data-nv-rating-count-text]::after {
    content: none !important;
    display: none !important;
}

.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button,
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button:hover,
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button:focus-visible,
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button:active,
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button.is-active,
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button[aria-pressed="true"],
.nv-plugin-showcase-card.is-favorite > .nv-plugin-showcase-bookmark-button {
    position: absolute !important;
    top: 0.72rem !important;
    right: 0.72rem !important;
    left: auto !important;
    bottom: auto !important;
    width: 38px !important;
    height: 38px !important;
    min-width: 38px !important;
    min-height: 38px !important;
    max-width: 38px !important;
    max-height: 38px !important;
    margin: 0 !important;
    padding: 0 !important;
    transform: none !important;
    translate: none !important;
    scale: 1 !important;
    transition: background-color .16s ease, box-shadow .16s ease, filter .16s ease, opacity .16s ease !important;
}

.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button .nv-bookmark-only-icon {
    display: block !important;
    width: 38px !important;
    height: 38px !important;
    transform: none !important;
    translate: none !important;
    scale: 1 !important;
}

.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button .nv-bookmark-only-icon .nv-bookmark-frame {
    fill: rgba(5, 8, 14, 0.92) !important;
    stroke: rgba(255, 70, 42, 0.62) !important;
    stroke-width: 1.2 !important;
    filter: drop-shadow(0 0 3px rgba(255, 72, 38, 0.13)) !important;
}

.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button .nv-bookmark-only-icon .nv-bookmark-mark {
    fill: transparent !important;
    stroke: rgba(210, 218, 228, 0.78) !important;
    stroke-width: 2.05 !important;
    stroke-linejoin: round !important;
    stroke-linecap: round !important;
    filter: none !important;
    transition: fill .16s ease, stroke .16s ease, filter .16s ease !important;
}

.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button:hover,
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button:focus-visible {
    background: rgba(9, 11, 18, 0.98) !important;
    box-shadow: 0 0 0 1px rgba(255, 78, 44, 0.92), 0 0 12px rgba(255, 70, 38, 0.28), inset 0 0 16px rgba(255, 70, 38, 0.12) !important;
    filter: brightness(1.16) !important;
}

.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button:hover .nv-bookmark-only-icon .nv-bookmark-frame,
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button:focus-visible .nv-bookmark-only-icon .nv-bookmark-frame {
    stroke: rgba(255, 88, 54, 0.98) !important;
    filter: drop-shadow(0 0 6px rgba(255, 76, 40, 0.32)) !important;
}

.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button:hover .nv-bookmark-only-icon .nv-bookmark-mark,
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button:focus-visible .nv-bookmark-only-icon .nv-bookmark-mark {
    fill: rgba(255, 72, 38, 0.12) !important;
    stroke: #ff5a3c !important;
    filter: drop-shadow(0 0 5px rgba(255, 86, 52, 0.42)) !important;
}

.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button.is-active,
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button[aria-pressed="true"],
.nv-plugin-showcase-card.is-favorite > .nv-plugin-showcase-bookmark-button {
    background: rgba(11, 12, 18, 0.98) !important;
    box-shadow: 0 0 0 1px rgba(255, 88, 54, 1), 0 0 15px rgba(255, 70, 38, 0.36), inset 0 0 18px rgba(255, 70, 38, 0.16) !important;
    filter: brightness(1.08) !important;
}

.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button.is-active .nv-bookmark-only-icon .nv-bookmark-frame,
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button[aria-pressed="true"] .nv-bookmark-only-icon .nv-bookmark-frame,
.nv-plugin-showcase-card.is-favorite > .nv-plugin-showcase-bookmark-button .nv-bookmark-only-icon .nv-bookmark-frame {
    stroke: rgba(255, 92, 58, 1) !important;
    filter: drop-shadow(0 0 7px rgba(255, 76, 40, 0.36)) !important;
}

.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button.is-active .nv-bookmark-only-icon .nv-bookmark-mark,
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button[aria-pressed="true"] .nv-bookmark-only-icon .nv-bookmark-mark,
.nv-plugin-showcase-card.is-favorite > .nv-plugin-showcase-bookmark-button .nv-bookmark-only-icon .nv-bookmark-mark {
    fill: rgba(255, 72, 38, 0.34) !important;
    stroke: #ff5a3c !important;
    filter: drop-shadow(0 0 6px rgba(255, 86, 52, 0.52)) !important;
}

/* =========================================================
   v1.1.78 - Catalog card layout aligned to final mockup.
   Full-width title/description, combined rating+price row,
   and card sizing tuned to the approved reference.
   ========================================================= */
.nv-plugin-showcase-grid {
    align-items: stretch !important;
}

.nv-plugin-showcase-card {
    display: grid !important;
    grid-template-rows: 176px minmax(0, 1fr) !important;
    min-height: 548px !important;
    height: 548px !important;
    max-height: 548px !important;
    overflow: hidden !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-media {
    height: 176px !important;
    min-height: 176px !important;
    max-height: 176px !important;
    aspect-ratio: auto !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-content {
    display: grid !important;
    grid-template-rows: auto minmax(0, 1fr) auto auto auto !important;
    row-gap: 10px !important;
    align-content: stretch !important;
    min-width: 0 !important;
    min-height: 0 !important;
    height: 100% !important;
    padding: 16px 18px 18px !important;
    box-sizing: border-box !important;
    overflow: hidden !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-top {
    min-height: 30px !important;
    height: auto !important;
    max-height: none !important;
    align-items: center !important;
    gap: 10px !important;
    overflow: hidden !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-mark {
    min-height: 30px !important;
    padding: 0 13px !important;
    font-size: 11px !important;
    letter-spacing: 0.22em !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-category {
    font-size: 11px !important;
    letter-spacing: 0.18em !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-summary {
    display: block !important;
    width: 100% !important;
    min-width: 0 !important;
    min-height: 0 !important;
    height: auto !important;
    max-height: none !important;
    overflow: hidden !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-summary-copy {
    display: flex !important;
    flex-direction: column !important;
    gap: 10px !important;
    min-width: 0 !important;
    min-height: 0 !important;
    height: 100% !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-summary-copy > h3 {
    margin: 0 !important;
    min-width: 0 !important;
    color: #f2f4f8 !important;
    font-size: 20px !important;
    line-height: 1.05 !important;
    font-weight: 800 !important;
    letter-spacing: -0.03em !important;
    white-space: normal !important;
    overflow: hidden !important;
    display: -webkit-box !important;
    -webkit-box-orient: vertical !important;
    -webkit-line-clamp: 2 !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-description,
.nv-plugin-showcase-card .nv-plugin-showcase-card-summary-copy > p {
    margin: 0 !important;
    min-width: 0 !important;
    min-height: 0 !important;
    flex: 1 1 auto !important;
    color: rgba(223, 229, 240, 0.82) !important;
    font-size: 13px !important;
    line-height: 1.6 !important;
    letter-spacing: -0.01em !important;
    white-space: normal !important;
    overflow: hidden !important;
    display: -webkit-box !important;
    -webkit-box-orient: vertical !important;
    -webkit-line-clamp: 6 !important;
    text-overflow: ellipsis !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-info-bar {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) auto !important;
    align-items: stretch !important;
    min-height: 64px !important;
    background: linear-gradient(180deg, rgba(8, 12, 20, 0.94), rgba(5, 9, 16, 0.98)) !important;
    border: 1px solid rgba(255, 72, 38, 0.28) !important;
    box-shadow: inset 0 0 0 1px rgba(255,255,255,0.03), 0 0 12px rgba(0, 0, 0, 0.18) !important;
    overflow: hidden !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating,
.nv-plugin-showcase-card .nv-plugin-showcase-card-price {
    margin: 0 !important;
    min-height: 64px !important;
    height: 64px !important;
    max-height: 64px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating {
    min-width: 0 !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-grid {
    display: block !important;
    width: 100% !important;
    height: 100% !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-metric--rating,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-rating-widget {
    display: grid !important;
    grid-template-columns: 42px minmax(0, 1fr) !important;
    align-items: center !important;
    gap: 10px !important;
    width: 100% !important;
    min-width: 0 !important;
    max-width: none !important;
    min-height: 64px !important;
    height: 64px !important;
    padding: 10px 14px !important;
    background: transparent !important;
    border: 0 !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    clip-path: none !important;
    overflow: hidden !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-metric--rating::before,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-metric--rating::after {
    content: none !important;
    display: none !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-badge {
    width: 42px !important;
    height: 42px !important;
    min-width: 42px !important;
    min-height: 42px !important;
    margin: 0 !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-ring-base,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-ring-fill {
    inset: 4px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-core {
    inset: 14px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating {
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-start !important;
    justify-content: center !important;
    gap: 4px !important;
    min-width: 0 !important;
    line-height: 1 !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-max,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating small {
    display: none !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating strong {
    display: flex !important;
    align-items: baseline !important;
    gap: 0 !important;
    margin: 0 !important;
    font-size: 18px !important;
    line-height: 1 !important;
    font-weight: 800 !important;
    letter-spacing: -0.03em !important;
    color: #f1f4fb !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating [data-nv-rating-value-text] {
    font-size: 18px !important;
    line-height: 1 !important;
    color: #f1f4fb !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em span,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em [data-nv-rating-count-text] {
    font-size: 12px !important;
    line-height: 1.1 !important;
    font-weight: 700 !important;
    color: rgba(188, 197, 214, 0.94) !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-price {
    position: relative !important;
    min-width: 108px !important;
    padding: 10px 14px 10px 12px !important;
    border-left: 1px solid rgba(255, 255, 255, 0.07) !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
    align-items: flex-end !important;
    gap: 3px !important;
    background: rgba(255,255,255,0.01) !important;
    box-sizing: border-box !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-price-discount {
    position: absolute !important;
    top: 8px !important;
    right: 10px !important;
    min-height: 18px !important;
    padding: 0 6px !important;
    border-radius: 4px !important;
    background: #97d736 !important;
    color: #12170b !important;
    font-size: 10px !important;
    font-weight: 800 !important;
    line-height: 18px !important;
    letter-spacing: 0 !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-price-current {
    margin: 0 !important;
    color: #f3f5fb !important;
    font-size: 18px !important;
    font-weight: 800 !important;
    line-height: 1 !important;
    letter-spacing: -0.03em !important;
    white-space: nowrap !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-price-original {
    margin: 0 !important;
    color: rgba(171, 179, 196, 0.72) !important;
    font-size: 12px !important;
    line-height: 1 !important;
    text-decoration: line-through !important;
    white-space: nowrap !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-metrics {
    height: 44px !important;
    min-height: 44px !important;
    max-height: 44px !important;
    margin: 0 !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-metrics .nv-asset-signal-grid {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 8px !important;
    height: 44px !important;
    min-height: 44px !important;
    max-height: 44px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-metrics .nv-asset-signal-metric {
    height: 44px !important;
    min-height: 44px !important;
    max-height: 44px !important;
    padding: 0 12px !important;
    border-radius: 0 !important;
    background: rgba(255, 255, 255, 0.015) !important;
    border: 1px solid rgba(255, 255, 255, 0.06) !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-metrics .nv-asset-signal-copy {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-metrics .nv-asset-signal-copy small {
    display: none !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-metrics .nv-asset-signal-copy strong {
    font-size: 16px !important;
    line-height: 1 !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-chips {
    min-height: 34px !important;
    max-height: 34px !important;
    height: 34px !important;
    align-self: end !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-chips .nv-plugin-showcase-chip {
    min-height: 34px !important;
    padding: 0 12px !important;
    font-size: 11px !important;
    letter-spacing: 0.06em !important;
}

.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button,
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button:hover,
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button:focus-visible,
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button:active,
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button.is-active,
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button[aria-pressed="true"],
.nv-plugin-showcase-card.is-favorite > .nv-plugin-showcase-bookmark-button {
    top: 0.7rem !important;
    right: 0.7rem !important;
    width: 34px !important;
    height: 34px !important;
    min-width: 34px !important;
    min-height: 34px !important;
    max-width: 34px !important;
    max-height: 34px !important;
}

.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button .nv-bookmark-only-icon {
    width: 34px !important;
    height: 34px !important;
}

@media (max-width: 767px) {
    .nv-plugin-showcase-card {
        grid-template-rows: 164px minmax(0, 1fr) !important;
        min-height: 520px !important;
        height: 520px !important;
        max-height: 520px !important;
    }

    .nv-plugin-showcase-card .nv-plugin-showcase-card-media {
        height: 164px !important;
        min-height: 164px !important;
        max-height: 164px !important;
    }

    .nv-plugin-showcase-card .nv-plugin-showcase-card-content {
        padding: 14px 16px 16px !important;
    }

    .nv-plugin-showcase-card .nv-plugin-showcase-card-summary-copy > h3 {
        font-size: 18px !important;
    }

    .nv-plugin-showcase-card .nv-plugin-showcase-card-info-bar {
        grid-template-columns: minmax(0, 1fr) 96px !important;
    }

    .nv-plugin-showcase-card .nv-plugin-showcase-card-price {
        min-width: 96px !important;
    }
}

/* =========================================================
   v1.1.79 - Tight match to final reference card proportions.
   Narrower/taller cards, hidden inner FAB row, always-visible price,
   smaller bookmark/badge, and typography aligned to the approved mockup.
   ========================================================= */
.nv-plugin-showcase-grid {
    gap: 18px !important;
}

.nv-plugin-showcase-card {
    justify-self: center !important;
    width: 100% !important;
    max-width: 312px !important;
    grid-template-rows: 156px minmax(0, 1fr) !important;
    min-height: 574px !important;
    height: 574px !important;
    max-height: 574px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-media {
    height: 156px !important;
    min-height: 156px !important;
    max-height: 156px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-content {
    grid-template-rows: minmax(0, 1fr) auto auto auto !important;
    row-gap: 10px !important;
    padding: 14px 14px 14px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-top {
    display: none !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-summary-copy {
    gap: 8px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-summary-copy > h3 {
    font-size: 16px !important;
    line-height: 1.08 !important;
    font-weight: 700 !important;
    letter-spacing: -0.025em !important;
    -webkit-line-clamp: 2 !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-description,
.nv-plugin-showcase-card .nv-plugin-showcase-card-summary-copy > p {
    font-size: 12px !important;
    line-height: 1.55 !important;
    color: rgba(228, 233, 244, 0.82) !important;
    -webkit-line-clamp: 6 !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-info-bar {
    min-height: 60px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating,
.nv-plugin-showcase-card .nv-plugin-showcase-card-price {
    min-height: 60px !important;
    height: 60px !important;
    max-height: 60px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-metric--rating,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-rating-widget {
    grid-template-columns: 38px minmax(0, 1fr) !important;
    gap: 10px !important;
    min-height: 60px !important;
    height: 60px !important;
    padding: 9px 12px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-badge {
    width: 38px !important;
    height: 38px !important;
    min-width: 38px !important;
    min-height: 38px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating strong,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating [data-nv-rating-value-text] {
    font-size: 16px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em span,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em [data-nv-rating-count-text] {
    font-size: 11px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-price {
    min-width: 104px !important;
    padding: 8px 12px 8px 10px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-price-current {
    font-size: 15px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-price-original {
    font-size: 11px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-price-discount {
    top: 7px !important;
    right: 8px !important;
    min-height: 16px !important;
    line-height: 16px !important;
    padding: 0 5px !important;
    font-size: 9px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-metrics {
    height: 40px !important;
    min-height: 40px !important;
    max-height: 40px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-metrics .nv-asset-signal-grid {
    gap: 8px !important;
    height: 40px !important;
    min-height: 40px !important;
    max-height: 40px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-metrics .nv-asset-signal-metric {
    height: 40px !important;
    min-height: 40px !important;
    max-height: 40px !important;
    padding: 0 10px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-metrics .nv-asset-signal-copy strong {
    font-size: 14px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-chips {
    min-height: 32px !important;
    max-height: 32px !important;
    height: 32px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-chips .nv-plugin-showcase-chip,
.nv-plugin-showcase-card .nv-plugin-showcase-chips > span {
    min-height: 32px !important;
    padding: 0 10px !important;
    font-size: 10px !important;
}

.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button,
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button:hover,
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button:focus-visible,
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button:active,
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button.is-active,
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button[aria-pressed="true"],
.nv-plugin-showcase-card.is-favorite > .nv-plugin-showcase-bookmark-button {
    top: 0.56rem !important;
    right: 0.56rem !important;
    width: 28px !important;
    height: 28px !important;
    min-width: 28px !important;
    min-height: 28px !important;
    max-width: 28px !important;
    max-height: 28px !important;
}

.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button .nv-bookmark-only-icon {
    width: 28px !important;
    height: 28px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-badge {
    left: 12px !important;
    top: 12px !important;
    padding: 5px 7px !important;
    font-size: 9px !important;
    letter-spacing: 0.12em !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-preview-label {
    top: 12px !important;
    right: 46px !important;
    padding: 4px 7px !important;
    font-size: 9px !important;
    letter-spacing: 0.14em !important;
}

@media (max-width: 767px) {
    .nv-plugin-showcase-card {
        max-width: 100% !important;
        min-height: 552px !important;
        height: 552px !important;
        max-height: 552px !important;
    }
}

/* =========================================================
   v1.1.80 - Final catalog proportion pass.
   Locks card/image/text/block sizes closer to the approved mockup.
   ========================================================= */
.nv-plugin-showcase-grid {
    --nv-catalog-card-width: 302px;
    gap: 16px !important;
    grid-template-columns: repeat(auto-fit, minmax(min(100%, var(--nv-catalog-card-width)), var(--nv-catalog-card-width))) !important;
    justify-content: center !important;
}

.nv-plugin-showcase-card {
    width: var(--nv-catalog-card-width) !important;
    max-width: var(--nv-catalog-card-width) !important;
    min-width: 0 !important;
    grid-template-rows: 150px minmax(0, 1fr) !important;
    min-height: 568px !important;
    height: 568px !important;
    max-height: 568px !important;
    border-color: rgba(255, 25, 25, 0.38) !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-media {
    height: 150px !important;
    min-height: 150px !important;
    max-height: 150px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-poster,
.nv-plugin-showcase-card .nv-plugin-showcase-preview-video,
.nv-plugin-showcase-card .nv-plugin-showcase-preview-youtube {
    object-fit: cover !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-content {
    grid-template-rows: minmax(0, 1fr) 62px 40px 32px !important;
    row-gap: 10px !important;
    padding: 14px 14px 14px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-summary-copy {
    gap: 8px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-summary-copy > h3 {
    font-size: 15px !important;
    line-height: 1.12 !important;
    font-weight: 700 !important;
    letter-spacing: -0.025em !important;
    text-shadow: none !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-description,
.nv-plugin-showcase-card .nv-plugin-showcase-card-summary-copy > p {
    font-size: 12px !important;
    line-height: 1.55 !important;
    color: rgba(224, 230, 242, 0.82) !important;
    -webkit-line-clamp: 7 !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-info-bar {
    height: 62px !important;
    min-height: 62px !important;
    max-height: 62px !important;
    grid-template-columns: minmax(0, 1fr) 108px !important;
    border-color: rgba(255, 255, 255, 0.06) !important;
    background: rgba(5, 9, 16, 0.66) !important;
    box-shadow: inset 0 0 0 1px rgba(255, 50, 28, 0.055) !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating,
.nv-plugin-showcase-card .nv-plugin-showcase-card-price {
    height: 62px !important;
    min-height: 62px !important;
    max-height: 62px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-metric--rating,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-rating-widget {
    grid-template-columns: 40px minmax(0, 1fr) !important;
    gap: 10px !important;
    height: 62px !important;
    min-height: 62px !important;
    padding: 10px 12px !important;
    overflow: hidden !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-badge {
    width: 40px !important;
    height: 40px !important;
    min-width: 40px !important;
    min-height: 40px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-ring-base,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-ring-fill {
    inset: 4px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-core {
    inset: 14px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating {
    gap: 4px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating strong,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating [data-nv-rating-value-text] {
    font-size: 16px !important;
    line-height: 1 !important;
    font-weight: 750 !important;
    color: rgba(238, 242, 250, 0.92) !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em span,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em [data-nv-rating-count-text] {
    font-size: 11px !important;
    line-height: 1 !important;
    color: rgba(170, 178, 194, 0.92) !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-price {
    min-width: 108px !important;
    width: 108px !important;
    padding: 8px 14px 8px 10px !important;
    border-left-color: rgba(255, 255, 255, 0.07) !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-price-current {
    font-size: 16px !important;
    font-weight: 700 !important;
    color: rgba(238, 242, 250, 0.92) !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-price-original {
    font-size: 11px !important;
    color: rgba(166, 174, 190, 0.72) !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-price-discount {
    top: 7px !important;
    right: 8px !important;
    min-height: 16px !important;
    line-height: 16px !important;
    padding: 0 5px !important;
    font-size: 9px !important;
    border-radius: 3px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-metrics,
.nv-plugin-showcase-card .nv-plugin-showcase-card-metrics .nv-asset-signal-grid,
.nv-plugin-showcase-card .nv-plugin-showcase-card-metrics .nv-asset-signal-metric {
    height: 40px !important;
    min-height: 40px !important;
    max-height: 40px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-metrics .nv-asset-signal-grid {
    gap: 8px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-metrics .nv-asset-signal-metric {
    padding: 0 10px !important;
    border-color: rgba(255, 255, 255, 0.055) !important;
    background: rgba(255, 255, 255, 0.012) !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-metrics .nv-asset-signal-icon,
.nv-plugin-showcase-card .nv-plugin-showcase-card-metrics .nv-ui-icon {
    width: 16px !important;
    height: 16px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-metrics .nv-asset-signal-copy {
    gap: 8px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-metrics .nv-asset-signal-copy strong {
    font-size: 14px !important;
    font-weight: 700 !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-chips,
.nv-plugin-showcase-card .nv-plugin-showcase-chips > span {
    height: 32px !important;
    min-height: 32px !important;
    max-height: 32px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-chips {
    gap: 7px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-chips > span {
    padding: 0 10px !important;
    font-size: 10px !important;
    letter-spacing: 0.055em !important;
    border-color: rgba(255, 255, 255, 0.055) !important;
    background: rgba(255, 255, 255, 0.015) !important;
}

.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button,
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button:hover,
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button:focus-visible,
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button:active,
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button.is-active,
.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button[aria-pressed="true"],
.nv-plugin-showcase-card.is-favorite > .nv-plugin-showcase-bookmark-button {
    top: 0.5rem !important;
    right: 0.5rem !important;
    width: 26px !important;
    height: 26px !important;
    min-width: 26px !important;
    min-height: 26px !important;
    max-width: 26px !important;
    max-height: 26px !important;
}

.nv-plugin-showcase-card > .nv-plugin-showcase-bookmark-button .nv-bookmark-only-icon {
    width: 26px !important;
    height: 26px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-badge {
    left: 10px !important;
    top: 10px !important;
    padding: 5px 7px !important;
    font-size: 8px !important;
    line-height: 1 !important;
    min-height: 24px !important;
    display: inline-flex !important;
    align-items: center !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-preview-label {
    top: 10px !important;
    right: 42px !important;
    padding: 4px 7px !important;
    font-size: 8px !important;
    line-height: 1 !important;
    min-height: 22px !important;
    display: inline-flex !important;
    align-items: center !important;
}

@media (max-width: 767px) {
    .nv-plugin-showcase-grid {
        grid-template-columns: minmax(0, 1fr) !important;
    }

    .nv-plugin-showcase-card {
        width: 100% !important;
        max-width: 326px !important;
        grid-template-rows: 156px minmax(0, 1fr) !important;
        min-height: 568px !important;
        height: 568px !important;
        max-height: 568px !important;
    }
}


/* =========================================================
   v1.1.81 - Card typography + rating/price alignment fix.
   Keeps the current card shell, but fixes multiline description,
   rating/count order, and price typography/alignment.
   ========================================================= */
.nv-plugin-showcase-card .nv-plugin-showcase-card-content {
    display: grid !important;
    grid-template-rows: minmax(0, 1fr) 62px 40px 32px !important;
    gap: 10px !important;
    align-content: stretch !important;
    min-height: 0 !important;
    overflow: hidden !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-summary,
.nv-plugin-showcase-card .nv-plugin-showcase-card-summary-copy {
    display: flex !important;
    flex-direction: column !important;
    min-height: 0 !important;
    height: 100% !important;
    max-height: none !important;
    overflow: hidden !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-summary-copy {
    gap: 8px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-summary-copy > h3 {
    flex: 0 0 auto !important;
    margin: 0 !important;
    font-size: 15px !important;
    line-height: 1.12 !important;
    font-weight: 700 !important;
    letter-spacing: -0.025em !important;
    color: rgba(242, 245, 250, 0.96) !important;
    white-space: normal !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    display: -webkit-box !important;
    -webkit-box-orient: vertical !important;
    -webkit-line-clamp: 2 !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-description,
.nv-plugin-showcase-card .nv-plugin-showcase-card-summary-copy > p.nv-plugin-showcase-card-description,
.nv-plugin-showcase-card .nv-plugin-showcase-card-summary-copy > .nv-plugin-showcase-subtitle.nv-plugin-showcase-card-description {
    flex: 1 1 auto !important;
    min-height: 0 !important;
    max-height: none !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    font-family: Arial, Helvetica, sans-serif !important;
    font-size: 12px !important;
    font-weight: 500 !important;
    line-height: 1.55 !important;
    letter-spacing: -0.01em !important;
    color: rgba(218, 225, 238, 0.82) !important;
    white-space: normal !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    display: -webkit-box !important;
    -webkit-box-orient: vertical !important;
    -webkit-line-clamp: 7 !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-info-bar {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) 108px !important;
    height: 62px !important;
    min-height: 62px !important;
    max-height: 62px !important;
    align-items: stretch !important;
    overflow: hidden !important;
    background: rgba(5, 9, 16, 0.72) !important;
    border: 1px solid rgba(255, 255, 255, 0.06) !important;
    box-shadow: inset 0 0 0 1px rgba(255, 50, 28, 0.05) !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-grid,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-metric--rating,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-rating-widget,
.nv-plugin-showcase-card .nv-plugin-showcase-card-price {
    height: 62px !important;
    min-height: 62px !important;
    max-height: 62px !important;
    margin: 0 !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-grid {
    min-width: 0 !important;
    width: 100% !important;
    max-width: none !important;
    overflow: hidden !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-metric--rating,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-rating-widget {
    display: grid !important;
    grid-template-columns: 42px minmax(0, 1fr) !important;
    align-items: center !important;
    justify-items: start !important;
    gap: 10px !important;
    width: 100% !important;
    min-width: 0 !important;
    max-width: none !important;
    padding: 10px 12px !important;
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    clip-path: none !important;
    overflow: hidden !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-badge {
    width: 42px !important;
    height: 42px !important;
    min-width: 42px !important;
    min-height: 42px !important;
    margin: 0 !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-ring-base,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-ring-fill {
    inset: 4px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-core {
    inset: 14px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-widget-frame,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-max,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating small {
    display: none !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating {
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
    align-items: flex-start !important;
    gap: 4px !important;
    min-width: 0 !important;
    max-width: 100% !important;
    line-height: 1 !important;
    overflow: hidden !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating strong {
    order: 1 !important;
    display: block !important;
    margin: 0 !important;
    padding: 0 !important;
    font-family: Arial, Helvetica, sans-serif !important;
    font-size: 16px !important;
    line-height: 1 !important;
    font-weight: 700 !important;
    letter-spacing: -0.025em !important;
    color: rgba(240, 244, 251, 0.95) !important;
    white-space: nowrap !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating strong [data-nv-rating-value-text] {
    display: inline !important;
    font: inherit !important;
    color: inherit !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em {
    order: 2 !important;
    display: block !important;
    position: static !important;
    margin: 0 !important;
    padding: 0 !important;
    transform: none !important;
    font-family: Arial, Helvetica, sans-serif !important;
    font-size: 11px !important;
    line-height: 1 !important;
    font-weight: 650 !important;
    font-style: normal !important;
    letter-spacing: -0.01em !important;
    color: rgba(168, 177, 194, 0.88) !important;
    white-space: nowrap !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em::before,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em::after,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em span::before,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em span::after,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em [data-nv-rating-count-text]::before,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em [data-nv-rating-count-text]::after {
    content: none !important;
    display: none !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em span,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em [data-nv-rating-count-text] {
    display: inline !important;
    margin: 0 !important;
    padding: 0 !important;
    font: inherit !important;
    color: inherit !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-price {
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-end !important;
    justify-content: center !important;
    gap: 3px !important;
    min-width: 108px !important;
    width: 108px !important;
    padding: 8px 12px 8px 10px !important;
    box-sizing: border-box !important;
    border-left: 1px solid rgba(255, 255, 255, 0.07) !important;
    background: rgba(255, 255, 255, 0.008) !important;
    overflow: hidden !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-price-current {
    margin: 0 !important;
    padding: 0 !important;
    font-family: Arial, Helvetica, sans-serif !important;
    font-size: 15px !important;
    line-height: 1 !important;
    font-weight: 700 !important;
    letter-spacing: -0.03em !important;
    color: rgba(238, 242, 250, 0.92) !important;
    white-space: nowrap !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-price-original {
    margin: 0 !important;
    padding: 0 !important;
    font-family: Arial, Helvetica, sans-serif !important;
    font-size: 11px !important;
    line-height: 1 !important;
    font-weight: 600 !important;
    color: rgba(166, 174, 190, 0.68) !important;
    text-decoration: line-through !important;
    white-space: nowrap !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-price-discount {
    position: absolute !important;
    top: 7px !important;
    right: 8px !important;
    min-height: 16px !important;
    height: 16px !important;
    padding: 0 5px !important;
    border-radius: 3px !important;
    background: #93d52d !important;
    color: #11180a !important;
    font-family: Arial, Helvetica, sans-serif !important;
    font-size: 9px !important;
    font-weight: 800 !important;
    line-height: 16px !important;
    letter-spacing: 0 !important;
}


/* =========================================================
   v1.1.82 - Centered rating/price content + responsive column sizing.
   Cards now obey the Columns setting while keeping the same card aspect ratio.
   ========================================================= */
.nv-plugin-showcase.nv-plugin-showcase-columns-1 .nv-plugin-showcase-grid,
.nv-plugin-showcase.nv-plugin-showcase-columns-2 .nv-plugin-showcase-grid,
.nv-plugin-showcase.nv-plugin-showcase-columns-3 .nv-plugin-showcase-grid,
.nv-plugin-showcase.nv-plugin-showcase-columns-4 .nv-plugin-showcase-grid {
    display: grid !important;
    align-items: stretch !important;
    justify-items: stretch !important;
    grid-auto-rows: auto !important;
}

.nv-plugin-showcase.nv-plugin-showcase-columns-1 .nv-plugin-showcase-grid {
    grid-template-columns: repeat(1, minmax(0, 1fr)) !important;
}

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

.nv-plugin-showcase.nv-plugin-showcase-columns-3 .nv-plugin-showcase-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
}

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

.nv-plugin-showcase-card {
    width: 100% !important;
    max-width: none !important;
    min-width: 0 !important;
    justify-self: stretch !important;
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    aspect-ratio: 302 / 548 !important;
    display: grid !important;
    grid-template-rows: 27.25% minmax(0, 1fr) !important;
    overflow: hidden !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-media {
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    aspect-ratio: auto !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-content {
    height: 100% !important;
    min-height: 0 !important;
    max-height: none !important;
    display: grid !important;
    grid-template-rows: minmax(0, 1fr) 62px 40px 32px !important;
    row-gap: clamp(7px, 2.4%, 10px) !important;
    align-content: stretch !important;
    overflow: hidden !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-summary,
.nv-plugin-showcase-card .nv-plugin-showcase-card-summary-copy {
    min-height: 0 !important;
    height: 100% !important;
    max-height: none !important;
    overflow: hidden !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-description,
.nv-plugin-showcase-card .nv-plugin-showcase-card-summary-copy > p.nv-plugin-showcase-card-description,
.nv-plugin-showcase-card .nv-plugin-showcase-card-summary-copy > .nv-plugin-showcase-subtitle.nv-plugin-showcase-card-description {
    min-height: 0 !important;
    max-height: none !important;
    white-space: normal !important;
    display: -webkit-box !important;
    -webkit-box-orient: vertical !important;
    -webkit-line-clamp: 7 !important;
    overflow: hidden !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-info-bar {
    grid-template-columns: minmax(0, 1fr) minmax(92px, 32%) !important;
    height: 62px !important;
    min-height: 62px !important;
    max-height: 62px !important;
    align-items: stretch !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-grid {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 100% !important;
    height: 62px !important;
    min-height: 62px !important;
    max-height: 62px !important;
    overflow: hidden !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-metric--rating,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-rating-widget {
    width: auto !important;
    min-width: 0 !important;
    max-width: 100% !important;
    height: 62px !important;
    min-height: 62px !important;
    max-height: 62px !important;
    margin: 0 auto !important;
    padding: 8px clamp(8px, 4.2%, 14px) !important;
    display: inline-grid !important;
    grid-template-columns: 42px auto !important;
    align-items: center !important;
    justify-content: center !important;
    justify-items: center !important;
    align-content: center !important;
    gap: clamp(7px, 4%, 12px) !important;
    overflow: hidden !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-badge {
    justify-self: center !important;
    align-self: center !important;
    margin: 0 !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating {
    align-self: center !important;
    justify-self: center !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    text-align: center !important;
    gap: 4px !important;
    min-width: 0 !important;
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    overflow: visible !important;
    transform: translateY(0) !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating strong,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em {
    display: block !important;
    width: auto !important;
    text-align: center !important;
    align-self: center !important;
    line-height: 1 !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating strong {
    font-size: clamp(14px, 4.8cqw, 17px) !important;
    font-weight: 700 !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em {
    font-size: clamp(10px, 3.4cqw, 11px) !important;
    font-weight: 600 !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-price {
    width: 100% !important;
    min-width: 0 !important;
    max-width: none !important;
    height: 62px !important;
    min-height: 62px !important;
    max-height: 62px !important;
    padding: 8px 8px !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    text-align: center !important;
    gap: 3px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-price-current,
.nv-plugin-showcase-card .nv-plugin-showcase-card-price-original {
    text-align: center !important;
    align-self: center !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-price-current {
    font-size: clamp(13px, 4.5cqw, 15px) !important;
    font-weight: 700 !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-price-discount {
    right: 50% !important;
    transform: translateX(50%) !important;
}

@media (max-width: 980px) {
    .nv-plugin-showcase.nv-plugin-showcase-columns-3 .nv-plugin-showcase-grid,
    .nv-plugin-showcase.nv-plugin-showcase-columns-4 .nv-plugin-showcase-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }
}

@media (max-width: 700px) {
    .nv-plugin-showcase.nv-plugin-showcase-columns-1 .nv-plugin-showcase-grid,
    .nv-plugin-showcase.nv-plugin-showcase-columns-2 .nv-plugin-showcase-grid,
    .nv-plugin-showcase.nv-plugin-showcase-columns-3 .nv-plugin-showcase-grid,
    .nv-plugin-showcase.nv-plugin-showcase-columns-4 .nv-plugin-showcase-grid {
        grid-template-columns: 1fr !important;
    }
}


/* =========================================================
   v1.1.83 - Rating clipping fix.
   The rating badge was still inheriting a larger flex-basis/box from older
   signal styles and was clipped inside the 42px grid column. Lock the badge
   to the column size and allow its glow to remain visible inside the panel.
   ========================================================= */
.nv-plugin-showcase-card .nv-plugin-showcase-card-info-bar,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-grid,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-metric--rating,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-rating-widget {
    overflow: visible !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-info-bar {
    isolation: isolate !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-grid {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-width: 0 !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-metric--rating,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-rating-widget {
    width: min(150px, 100%) !important;
    min-width: 0 !important;
    max-width: 100% !important;
    display: grid !important;
    grid-template-columns: 38px minmax(34px, auto) !important;
    align-items: center !important;
    justify-content: center !important;
    justify-items: center !important;
    align-content: center !important;
    gap: 8px !important;
    padding: 8px 10px !important;
    box-sizing: border-box !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-badge {
    position: relative !important;
    display: block !important;
    flex: 0 0 38px !important;
    width: 38px !important;
    height: 38px !important;
    min-width: 38px !important;
    min-height: 38px !important;
    max-width: 38px !important;
    max-height: 38px !important;
    justify-self: center !important;
    align-self: center !important;
    margin: 0 !important;
    transform: none !important;
    overflow: visible !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-badge-shell,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-ring-base,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-ring-fill,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-core {
    position: absolute !important;
    box-sizing: border-box !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-badge-shell,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-ring-base,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-ring-fill {
    inset: 4px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-badge-shell::before {
    inset: 2px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-badge-shell::after {
    width: 28px !important;
    height: 28px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-core {
    inset: 14px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating {
    justify-self: center !important;
    align-self: center !important;
    align-items: center !important;
    justify-content: center !important;
    text-align: center !important;
    min-width: 34px !important;
    max-width: 52px !important;
    height: auto !important;
    overflow: visible !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating strong,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em {
    width: 100% !important;
    text-align: center !important;
    overflow: visible !important;
}

@media (max-width: 900px) {
    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-metric--rating,
    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-rating-widget {
        grid-template-columns: 34px minmax(30px, auto) !important;
        gap: 7px !important;
        padding: 8px 8px !important;
    }

    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-badge {
        flex-basis: 34px !important;
        width: 34px !important;
        height: 34px !important;
        min-width: 34px !important;
        min-height: 34px !important;
        max-width: 34px !important;
        max-height: 34px !important;
    }

    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-badge-shell,
    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-ring-base,
    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-ring-fill {
        inset: 3px !important;
    }

    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-core {
        inset: 12px !important;
    }
}


/* =========================================================
   v1.1.85 - Rating number block vertical center fix.
   Keep the rating value/review count as a single centered stack next to the wheel.
   ========================================================= */
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-metric--rating,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-rating-widget {
    place-items: center !important;
    align-items: center !important;
    justify-items: center !important;
    align-content: center !important;
    justify-content: center !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-rating-badge {
    place-self: center !important;
    align-self: center !important;
    justify-self: center !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating {
    place-self: center !important;
    align-self: center !important;
    justify-self: center !important;
    display: grid !important;
    grid-template-rows: auto auto !important;
    align-content: center !important;
    justify-content: center !important;
    justify-items: center !important;
    gap: 2px !important;
    height: 38px !important;
    min-height: 38px !important;
    max-height: 38px !important;
    margin: 0 !important;
    padding: 0 !important;
    line-height: 1 !important;
    transform: translateY(1px) !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating strong,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em,
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating strong [data-nv-rating-value-text],
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em [data-nv-rating-count-text] {
    display: block !important;
    place-self: center !important;
    align-self: center !important;
    justify-self: center !important;
    margin: 0 !important;
    padding: 0 !important;
    line-height: 1 !important;
    text-align: center !important;
    vertical-align: middle !important;
    transform: none !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating strong {
    min-height: 17px !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em {
    min-height: 11px !important;
}

@media (max-width: 900px) {
    .nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating {
        height: 34px !important;
        min-height: 34px !important;
        max-height: 34px !important;
        gap: 1px !important;
        transform: translateY(1px) !important;
    }
}


/* =========================================================
   v1.1.86 - Keep rating review count on one line.
   The parentheses/count must render as a single inline unit: (10), never
   as separate wrapped characters.
   ========================================================= */
.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating em {
    display: inline-flex !important;
    flex-direction: row !important;
    align-items: center !important;
    justify-content: center !important;
    width: max-content !important;
    min-width: max-content !important;
    max-width: none !important;
    white-space: nowrap !important;
    word-break: keep-all !important;
    overflow-wrap: normal !important;
    text-wrap: nowrap !important;
    line-height: 1 !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating .nv-rating-count-line {
    display: inline-flex !important;
    flex-direction: row !important;
    align-items: baseline !important;
    justify-content: center !important;
    gap: 0 !important;
    width: max-content !important;
    min-width: max-content !important;
    max-width: none !important;
    white-space: nowrap !important;
    word-break: keep-all !important;
    overflow-wrap: normal !important;
    text-wrap: nowrap !important;
    line-height: 1 !important;
}

.nv-plugin-showcase-card .nv-plugin-showcase-card-rating .nv-asset-signal-copy--rating .nv-rating-count-line [data-nv-rating-count-text] {
    display: inline !important;
    width: auto !important;
    min-width: 0 !important;
    max-width: none !important;
    margin: 0 !important;
    padding: 0 !important;
    white-space: nowrap !important;
    word-break: keep-all !important;
    overflow-wrap: normal !important;
    text-wrap: nowrap !important;
    line-height: 1 !important;
}
