/* Base Reset & Variables */
*,
*::before,
*::after {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

:root {
    --bg: #0f1115;
    --bg-card: #1a1d24;
    --bg-card-hover: #22262f;
    --text: #e8eaed;
    --text-muted: #8b919a;
    --text-dim: #5f646d;
    --border: #2a2f38;
    --online: #4ade80;
    --offline: #f87171;
    --slow: #fbbf24;
    --radius: 12px;
    --radius-sm: 8px;
    --radius-pill: 20px;
}

html {
    font-size: 14px;
    scroll-behavior: smooth;
}

body {
    font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif;
    background: var(--bg);
    color: var(--text);
    line-height: 1.5;
    min-height: 100vh;
    -webkit-font-smoothing: antialiased;
}

/* Container */
.container {
    max-width: 540px;
    margin: 0 auto;
    padding: 12px;
    min-height: 100vh;
    display: flex;
    flex-direction: column;
}

/* Header */
.header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    padding: 8px 0;
    margin-bottom: 16px;
    position: relative;
}

.header-right {
    display: flex;
    align-items: center;
    gap: 8px;
}

/* Nav Toggle (mobile) */
.nav-toggle {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    background: var(--bg-card);
    border: none;
    border-radius: var(--radius-sm);
    color: var(--text-muted);
    cursor: pointer;
    transition: all 0.15s ease;
}

.nav-toggle:hover {
    background: var(--bg-card-hover);
    color: var(--text);
}

.nav-toggle-line {
    transition: all 0.25s ease;
    transform-origin: center;
}

.nav-toggle--active .nav-toggle-line--top {
    transform: translateY(6px) rotate(45deg);
}

.nav-toggle--active .nav-toggle-line--mid {
    opacity: 0;
}

.nav-toggle--active .nav-toggle-line--bot {
    transform: translateY(-6px) rotate(-45deg);
}

/* Navigation */
.nav {
    display: none;
    flex-direction: column;
    gap: 2px;
    width: 100%;
    padding-top: 10px;
    order: 10;
}

.nav--open {
    display: flex;
}

.nav-item {
    position: relative;
}

.nav-link {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 8px 12px;
    font-size: 0.813rem;
    font-weight: 500;
    color: var(--text-muted);
    text-decoration: none;
    border-radius: var(--radius-sm);
    transition: all 0.15s ease;
}

.nav-link:hover {
    color: var(--text);
    background: var(--bg-card);
}

.nav-dropdown {
    display: flex;
    flex-direction: column;
    gap: 1px;
    padding-left: 16px;
}

.nav-dropdown-link {
    display: block;
    padding: 6px 12px;
    font-size: 0.75rem;
    color: var(--text-dim);
    text-decoration: none;
    border-radius: var(--radius-sm);
    transition: all 0.15s ease;
}

.nav-dropdown-link:hover {
    color: var(--text);
    background: var(--bg-card);
}

/* Desktop Navigation */
@media (min-width: 640px) {
    .nav-toggle {
        display: none;
    }

    .nav {
        display: flex;
        flex-direction: row;
        align-items: center;
        gap: 2px;
        width: auto;
        padding-top: 0;
        order: 0;
        margin-left: auto;
    }

    .nav-item {
        position: relative;
    }

    .nav-link {
        padding: 6px 10px;
    }

    .nav-dropdown {
        display: none;
        position: absolute;
        top: 100%;
        left: 0;
        padding: 10px 6px 6px;
        padding-left: 0;
        background: var(--bg-card);
        border: 1px solid var(--border);
        border-radius: var(--radius);
        min-width: 200px;
        z-index: 100;
        flex-direction: column;
        gap: 2px;
        margin-top: 0;
        box-shadow: 0 8px 24px rgba(0, 0, 0, 0.4);
    }

    .nav-item::after {
        content: '';
        position: absolute;
        top: 100%;
        left: 0;
        width: 100%;
        height: 8px;
    }

    .nav-item:hover .nav-dropdown {
        display: flex;
    }

    .nav-dropdown-link {
        padding: 8px 14px;
        font-size: 0.75rem;
        white-space: nowrap;
    }

    .nav-dropdown-link:hover {
        background: var(--bg-card-hover);
    }
}

.logo {
    margin: 0;
    font-size: inherit;
    font-weight: inherit;
}

.logo-link {
    display: flex;
    align-items: baseline;
    gap: 0;
    text-decoration: none;
    letter-spacing: -0.02em;
}

.logo-text {
    font-size: 1.125rem;
    font-weight: 500;
    color: var(--text-muted);
}

.logo-accent {
    font-size: 1.125rem;
    font-weight: 700;
    color: var(--text);
}

.header-status {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    background: var(--bg-card);
    border-radius: var(--radius-pill);
}

.header-status-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--text-dim);
    transition: background 0.2s ease;
}

.header-status-dot[data-status="online"] {
    background: var(--online);
}

.header-status-dot[data-status="offline"] {
    background: var(--offline);
}

.header-status-dot[data-status="slow"] {
    background: var(--slow);
}

.header-status-text {
    font-size: 0.75rem;
    font-weight: 500;
    color: var(--text-muted);
}


/* Main Content */
.main {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 20px;
}

/* Sections */
.section {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.section-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
}

.section-title {
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--text);
    letter-spacing: -0.01em;
}

.section-link {
    font-size: 0.688rem;
    color: var(--text-muted);
    text-decoration: none;
    transition: color 0.15s;
    white-space: nowrap;
}

.section-link:hover {
    color: var(--text);
}

.status-meta {
    display: flex;
    align-items: center;
    gap: 6px;
}

.last-update {
    font-size: 0.688rem;
    color: var(--text-dim);
}

.status-link {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 20px;
    height: 20px;
    text-decoration: none;
}

.status-link-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--text-dim);
    transition: background 0.3s;
}

.status-link-dot[data-status="online"] {
    background: var(--online);
}

.status-link-dot[data-status="slow"] {
    background: var(--degraded);
}

.status-link-dot[data-status="offline"] {
    background: var(--offline);
}

.badge {
    font-size: 0.625rem;
    font-weight: 500;
    padding: 3px 8px;
    background: var(--bg-card);
    color: var(--text-muted);
    border-radius: var(--radius-pill);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

/* Bento Grid */
.bento-grid {
    display: grid;
    gap: 8px;
}

.status-grid {
    grid-template-columns: repeat(2, 1fr);
}

.tools-grid {
    grid-template-columns: repeat(2, 1fr);
}

.content-grid {
    grid-template-columns: repeat(2, 1fr);
}

/* Cards */
.card {
    background: var(--bg-card);
    border-radius: var(--radius);
    padding: 12px;
    display: flex;
    align-items: flex-start;
    gap: 10px;
    transition: background 0.15s ease;
}

.card-main {
    grid-column: span 2;
    padding: 14px;
}

.card-wide {
    grid-column: span 2;
}

.card-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    background: var(--bg);
    border-radius: var(--radius-sm);
    color: var(--text-muted);
    flex-shrink: 0;
}

.card-main .card-icon {
    width: 40px;
    height: 40px;
}

/* Status Icon States */
.status-icon[data-status="online"] {
    background: rgba(74, 222, 128, 0.12);
    color: var(--online);
}

.status-icon[data-status="offline"] {
    background: rgba(248, 113, 113, 0.12);
    color: var(--offline);
}

.status-icon[data-status="slow"] {
    background: rgba(251, 191, 36, 0.12);
    color: var(--slow);
}

.status-icon[data-status="loading"] {
    animation: pulse 1.5s ease-in-out infinite;
}

@keyframes pulse {
    0%, 100% { opacity: 0.5; }
    50% { opacity: 1; }
}

.card-content {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.card-title {
    font-size: 0.938rem;
    font-weight: 600;
    color: var(--text);
}

.card-status {
    font-size: 0.75rem;
    color: var(--text-muted);
}

.card-label {
    font-size: 0.688rem;
    color: var(--text-dim);
    text-transform: uppercase;
    letter-spacing: 0.03em;
}

.card-value {
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--text);
}

.card-value-large {
    font-size: 1.125rem;
    font-weight: 600;
}

/* Tool Cards */
.card-tool {
    text-decoration: none;
    position: relative;
    cursor: pointer;
}

.card-tool:hover {
    background: var(--bg-card-hover);
}

.tool-icon {
    background: var(--bg);
    color: var(--text-dim);
}

.card-tool:hover .tool-icon {
    color: var(--text-muted);
}

.tool-title {
    font-size: 0.813rem;
    font-weight: 500;
    color: var(--text);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.tool-desc {
    font-size: 0.688rem;
    color: var(--text-dim);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* CS2 Skins Cards */
.skins-grid {
    grid-template-columns: repeat(2, 1fr);
}

.skins-grid .card-skin-link:first-child {
    grid-column: span 2;
}

.skin-thumb {
    width: 32px;
    height: 32px;
    object-fit: contain;
    flex-shrink: 0;
}

.tool-badge {
    position: absolute;
    top: 8px;
    right: 8px;
    font-size: 0.563rem;
    font-weight: 500;
    padding: 2px 6px;
    background: var(--bg);
    color: var(--text-dim);
    border-radius: var(--radius-sm);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

/* Content Sections */
.section-content {
    padding: 16px 0;
}

.section-content .section-title {
    margin-bottom: 10px;
}

.content-text {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.content-text p {
    font-size: 0.813rem;
    color: var(--text-muted);
    line-height: 1.6;
}

.content-text strong {
    color: var(--text);
}

/* Page Content (legal pages) */
.page-content {
    padding: 8px 0;
}

.page-title {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--text);
    margin-bottom: 8px;
    letter-spacing: -0.02em;
}

.page-meta {
    font-size: 0.75rem;
    color: var(--text-dim);
    margin-bottom: 20px;
}

.tool-last-updated {
    font-size: 0.688rem;
    color: var(--text-dim);
    margin-top: 24px;
}

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

.page-title-row .page-title {
    margin-bottom: 0;
}

.tool-share-actions {
    display: flex;
    align-items: center;
    gap: 2px;
    flex-shrink: 0;
}

.tool-share-btn {
    appearance: none;
    border: none;
    background: transparent;
    color: var(--text-muted);
    padding: 5px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    border-radius: 4px;
    transition: color 0.15s ease;
}

.tool-share-btn:hover {
    color: var(--text);
}

.tool-share-btn:active {
    opacity: 0.7;
}

.tool-share-btn [data-icon="check"] { display: none; }

.tool-share-btn.is-copied { color: #22c55e; }
.tool-share-btn.is-copied [data-icon="copy"]  { display: none; }
.tool-share-btn.is-copied [data-icon="check"] { display: block; }

.tool-focus-target {
    position: relative;
    border-color: rgba(255,255,255,0.18) !important;
    box-shadow: 0 0 0 1px rgba(255,255,255,0.12), 0 12px 28px rgba(0,0,0,0.18);
}

.tool-focus-target::after {
    content: '';
    position: absolute;
    inset: 0;
    border: 1px solid rgba(255,255,255,0.12);
    border-radius: inherit;
    pointer-events: none;
}

.content-section {
    margin-bottom: 24px;
}

.content-section h2 {
    font-size: 1rem;
    font-weight: 600;
    color: var(--text);
    margin-bottom: 10px;
}

.content-section h3 {
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--text);
    margin: 16px 0 8px;
}

.content-section p {
    font-size: 0.813rem;
    color: var(--text-muted);
    line-height: 1.7;
    margin-bottom: 10px;
}

.content-section a {
    color: var(--text);
    text-decoration: underline;
    text-underline-offset: 2px;
}

.content-section a:hover {
    color: var(--text-muted);
}

/* Markdown body from Content Collections — same styles as .content-section */
.article-body { margin-bottom: 24px; }
.article-body h2 { font-size: 1rem; font-weight: 600; color: var(--text); margin: 24px 0 10px; }
.article-body h3 { font-size: 0.875rem; font-weight: 600; color: var(--text); margin: 16px 0 8px; }
.article-body p { font-size: 0.813rem; color: var(--text-muted); line-height: 1.7; margin-bottom: 10px; }
.article-body a { color: var(--text); text-decoration: underline; text-underline-offset: 2px; }
.article-body a:hover { color: var(--text-muted); }
.article-body ul, .article-body ol { font-size: 0.813rem; color: var(--text-muted); line-height: 1.7; margin: 10px 0; padding-left: 20px; }

.content-list {
    list-style: none;
    margin: 10px 0;
    padding-left: 0;
}

.content-list li {
    font-size: 0.813rem;
    color: var(--text-muted);
    line-height: 1.7;
    padding-left: 16px;
    position: relative;
    margin-bottom: 6px;
}

.content-list li::before {
    content: '•';
    position: absolute;
    left: 0;
    color: var(--text-dim);
}

.content-list strong {
    color: var(--text);
}


.contact-email {
    margin: 8px 0;
}

.contact-email a {
    font-size: 0.938rem;
    font-weight: 500;
    color: var(--text);
    text-decoration: none;
    padding: 10px 16px;
    background: var(--bg-card);
    border-radius: var(--radius-sm);
    display: inline-block;
    transition: background 0.15s;
}

.contact-email a:hover {
    background: var(--bg-card-hover);
}

/* Tool Placeholder */
.tool-placeholder {
    background: var(--bg-card);
    border-radius: var(--radius);
    padding: 32px 20px;
    text-align: center;
    margin-bottom: 24px;
}

.placeholder-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 72px;
    height: 72px;
    background: var(--bg);
    border-radius: 50%;
    color: var(--text-dim);
    margin-bottom: 16px;
}

.placeholder-title {
    font-size: 1.125rem;
    font-weight: 600;
    color: var(--text);
    margin-bottom: 8px;
}

.placeholder-text {
    font-size: 0.813rem;
    color: var(--text-muted);
    max-width: 320px;
    margin: 0 auto 16px;
    line-height: 1.6;
}

.placeholder-link {
    display: inline-block;
    font-size: 0.813rem;
    font-weight: 500;
    color: var(--text);
    text-decoration: none;
    padding: 8px 16px;
    background: var(--bg);
    border-radius: var(--radius-sm);
    transition: background 0.15s;
}

.placeholder-link:hover {
    background: var(--bg-card-hover);
}

/* Steam ID Finder Tool */
.sid-tool {
    display: flex;
    gap: 8px;
    margin-bottom: 12px;
}

.sid-input-wrap {
    flex: 1;
    position: relative;
    display: flex;
    align-items: center;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    transition: border-color 0.15s;
}

.sid-input-wrap:focus-within {
    border-color: var(--text-dim);
}

.sid-input {
    flex: 1;
    background: transparent;
    border: none;
    outline: none;
    color: var(--text);
    font-size: 0.875rem;
    padding: 10px 12px;
    font-family: inherit;
    min-width: 0;
}

.sid-input::placeholder {
    color: var(--text-dim);
}

.sid-input-actions {
    display: flex;
    align-items: center;
    gap: 2px;
    padding-right: 6px;
    flex-shrink: 0;
}

.sid-btn-icon {
    background: none;
    border: none;
    color: var(--text-dim);
    cursor: pointer;
    padding: 6px;
    border-radius: 4px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: color 0.15s, background 0.15s;
}

.sid-btn-icon:hover {
    color: var(--text-muted);
    background: var(--bg);
}

.sid-btn-convert {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 10px 18px;
    background: var(--text);
    color: var(--bg);
    border: none;
    border-radius: var(--radius-sm);
    font-size: 0.813rem;
    font-weight: 600;
    cursor: pointer;
    font-family: inherit;
    transition: opacity 0.15s;
    white-space: nowrap;
    flex-shrink: 0;
}

.sid-btn-convert:hover {
    opacity: 0.85;
}

.sid-btn-convert:disabled {
    opacity: 0.6;
    cursor: default;
}

.sid-spinner {
    animation: sid-spin 0.8s linear infinite;
}

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

.sid-examples {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 6px;
    margin-bottom: 16px;
}

.sid-examples-label {
    font-size: 0.75rem;
    color: var(--text-dim);
}

.sid-example {
    font-size: 0.75rem;
    color: var(--text-muted);
    text-decoration: none;
    padding: 3px 10px;
    background: var(--bg-card);
    border-radius: var(--radius-pill);
    transition: background 0.15s, color 0.15s;
}

.sid-example:hover {
    background: var(--bg-card-hover);
    color: var(--text);
}

.sid-error {
    background: rgba(248, 113, 113, 0.08);
    border: 1px solid rgba(248, 113, 113, 0.2);
    border-radius: var(--radius-sm);
    padding: 10px 14px;
    font-size: 0.813rem;
    color: var(--offline);
    margin-bottom: 16px;
    line-height: 1.5;
}

.sid-detected {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 0.75rem;
    color: var(--online);
    margin-bottom: 12px;
    padding: 6px 0;
}

.sid-detected strong {
    color: var(--online);
}

.sid-results {
    display: flex;
    flex-direction: column;
    gap: 1px;
    background: var(--border);
    border-radius: var(--radius);
    overflow: hidden;
    margin-bottom: 24px;
}

.sid-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 10px 14px;
    background: var(--bg-card);
}

.sid-row-header {
    display: flex;
    flex-direction: column;
    gap: 1px;
    min-width: 0;
    flex-shrink: 0;
}

.sid-label {
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--text);
}

.sid-desc {
    font-size: 0.688rem;
    color: var(--text-dim);
}

.sid-row-value {
    display: flex;
    align-items: center;
    gap: 8px;
    min-width: 0;
}

.sid-value {
    font-size: 0.813rem;
    color: var(--text-muted);
    font-family: 'SF Mono', 'Cascadia Code', 'Consolas', monospace;
    word-break: break-all;
    text-align: right;
}

.sid-copy {
    background: none;
    border: none;
    color: var(--text-dim);
    cursor: pointer;
    padding: 4px;
    border-radius: 4px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: color 0.15s;
    flex-shrink: 0;
}

.sid-copy:hover {
    color: var(--text);
}

.sid-copy .check-icon {
    color: var(--online);
}

@media (max-width: 600px) {
    .sid-tool {
        flex-direction: column;
    }

    .sid-btn-convert {
        justify-content: center;
    }

    .sid-row {
        flex-direction: column;
        align-items: flex-start;
        gap: 4px;
    }

    .sid-row-value {
        width: 100%;
        justify-content: space-between;
    }

    .sid-value {
        text-align: left;
    }
}

/* Steam Player Count Tool */
.spc-tool {
    display: flex;
    gap: 8px;
    margin-bottom: 12px;
}

.spc-input-wrap {
    flex: 1;
    position: relative;
    display: flex;
    align-items: center;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    transition: border-color 0.15s;
}

.spc-input-wrap:focus-within {
    border-color: var(--text-dim);
}

.spc-input {
    flex: 1;
    background: transparent;
    border: none;
    outline: none;
    color: var(--text);
    font-size: 0.875rem;
    padding: 10px 12px;
    font-family: inherit;
    min-width: 0;
}

.spc-input::placeholder {
    color: var(--text-dim);
}

.spc-input-actions {
    display: flex;
    align-items: center;
    gap: 2px;
    padding-right: 6px;
    flex-shrink: 0;
}

.spc-btn-icon {
    background: none;
    border: none;
    color: var(--text-dim);
    cursor: pointer;
    padding: 6px;
    border-radius: 4px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: color 0.15s, background 0.15s;
}

.spc-btn-icon:hover {
    color: var(--text-muted);
    background: var(--bg);
}

.spc-btn-search {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 10px 18px;
    background: var(--text);
    color: var(--bg);
    border: none;
    border-radius: var(--radius-sm);
    font-size: 0.813rem;
    font-weight: 600;
    cursor: pointer;
    font-family: inherit;
    transition: opacity 0.15s;
    white-space: nowrap;
    flex-shrink: 0;
}

.spc-btn-search:hover {
    opacity: 0.85;
}

.spc-quick-links {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 6px;
    margin-bottom: 20px;
}

.spc-quick-label {
    font-size: 0.75rem;
    color: var(--text-dim);
}

.spc-quick {
    font-size: 0.75rem;
    color: var(--text-muted);
    text-decoration: none;
    padding: 3px 10px;
    background: var(--bg-card);
    border-radius: var(--radius-pill);
    transition: background 0.15s, color 0.15s;
    cursor: pointer;
}

.spc-quick:hover {
    background: var(--bg-card-hover);
    color: var(--text);
}

/* Leaderboard table */
.spc-section-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 10px;
}

.spc-section-title {
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--text);
    display: flex;
    align-items: center;
    gap: 6px;
}

.spc-meta {
    font-size: 0.688rem;
    color: var(--text-dim);
    display: flex;
    align-items: center;
    gap: 4px;
}

.spc-table-wrap {
    border-radius: var(--radius);
    overflow: hidden;
    border: 1px solid var(--border);
    margin-bottom: 12px;
}

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

.spc-table th {
    text-align: left;
    font-size: 0.688rem;
    font-weight: 600;
    color: var(--text-dim);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    padding: 8px 12px;
    background: var(--bg-card);
    border-bottom: 1px solid var(--border);
}

.spc-table th:last-child {
    text-align: right;
}

.spc-row td {
    padding: 8px 12px;
    border-bottom: 1px solid var(--border);
    background: var(--bg-card);
    transition: background 0.1s;
}

.spc-row:last-child td {
    border-bottom: none;
}

.spc-row:hover td {
    background: var(--bg-card-hover);
}

.spc-rank {
    width: 32px;
    font-size: 0.75rem;
    color: var(--text-dim);
    font-weight: 600;
    text-align: center !important;
}

.spc-game-name {
    font-size: 0.813rem;
    display: flex;
    align-items: center;
    gap: 8px;
}

.spc-game-icon {
    width: 32px;
    height: 12px;
    object-fit: cover;
    border-radius: 2px;
    flex-shrink: 0;
}

.spc-game-name a {
    color: var(--text);
    text-decoration: none;
    transition: color 0.15s;
}

.spc-game-name a:hover {
    color: var(--text-muted);
}

.spc-count {
    text-align: right;
    font-size: 0.813rem;
    font-weight: 600;
    color: var(--online);
    font-variant-numeric: tabular-nums;
    white-space: nowrap;
}

.spc-shimmer {
    display: inline-block;
    width: 52px;
    height: 12px;
    background: var(--bg-card-hover);
    border-radius: 4px;
    animation: spcPulse 1.2s ease-in-out infinite;
}

@keyframes spcPulse {
    0%, 100% { opacity: 0.35; }
    50% { opacity: 0.9; }
}

/* Search results */
.spc-search-wrap {
    margin-bottom: 20px;
}

.spc-search-title {
    font-size: 0.813rem;
    font-weight: 600;
    color: var(--text);
    margin-bottom: 8px;
    display: flex;
    align-items: center;
    gap: 6px;
}

.spc-thumb-cell {
    width: 52px;
    padding-right: 0 !important;
}

.spc-thumb {
    width: 48px;
    height: 18px;
    object-fit: cover;
    border-radius: 3px;
    display: block;
}

.spc-status {
    text-align: center;
    font-size: 0.75rem;
    color: var(--text-dim);
    padding: 20px 12px !important;
    background: var(--bg-card);
}

/* Footer meta */
.spc-footer-meta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    font-size: 0.688rem;
    color: var(--text-dim);
    margin-bottom: 24px;
    padding: 0 2px;
}

.spc-live {
    display: flex;
    align-items: center;
    gap: 4px;
}

.spc-dot {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--online);
    animation: spcBlink 2s ease-in-out infinite;
}

@keyframes spcBlink {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.3; }
}

@media (max-width: 600px) {
    .spc-tool {
        flex-direction: column;
    }

    .spc-btn-search {
        justify-content: center;
    }

    .spc-section-header {
        flex-direction: column;
        align-items: flex-start;
        gap: 4px;
    }

    .spc-rank {
        width: 24px;
        font-size: 0.688rem;
    }

    .spc-row td {
        padding: 7px 8px;
    }

    .spc-thumb {
        width: 36px;
        height: 14px;
    }

    .spc-thumb-cell {
        width: 42px;
    }

    .spc-footer-meta {
        flex-direction: column;
        gap: 4px;
        align-items: flex-start;
    }

    .spc-game-name {
        font-size: 0.75rem;
        gap: 6px;
    }

    .spc-game-icon {
        width: 26px;
        height: 10px;
    }

    .spc-count {
        font-size: 0.75rem;
    }
}

/* ═══════════════════════════════════════════════════════
   STEAM CALCULATOR TOOL
   ═══════════════════════════════════════════════════════ */

.scalc-tool {
    display: flex;
    gap: 8px;
    margin-bottom: 12px;
}

.scalc-input-wrap {
    flex: 1;
    position: relative;
    display: flex;
    align-items: center;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    transition: border-color 0.15s;
}

.scalc-input-wrap:focus-within {
    border-color: var(--text-dim);
}

.scalc-input {
    flex: 1;
    background: transparent;
    border: none;
    outline: none;
    color: var(--text);
    font-size: 0.875rem;
    padding: 10px 12px;
    font-family: inherit;
    min-width: 0;
}

.scalc-input::placeholder {
    color: var(--text-dim);
}

.scalc-input-actions {
    display: flex;
    align-items: center;
    gap: 2px;
    padding-right: 6px;
    flex-shrink: 0;
}

.scalc-btn-icon {
    background: none;
    border: none;
    color: var(--text-dim);
    cursor: pointer;
    padding: 6px;
    border-radius: 4px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: color 0.15s, background 0.15s;
}

.scalc-btn-icon:hover {
    color: var(--text-muted);
    background: var(--bg);
}

.scalc-btn-calc {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 10px 18px;
    background: var(--text);
    color: var(--bg);
    border: none;
    border-radius: var(--radius-sm);
    font-size: 0.813rem;
    font-weight: 600;
    cursor: pointer;
    font-family: inherit;
    transition: opacity 0.15s;
    white-space: nowrap;
    flex-shrink: 0;
}

.scalc-btn-calc:hover {
    opacity: 0.85;
}

.scalc-examples {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 6px;
    margin-bottom: 16px;
}

.scalc-examples-label {
    font-size: 0.75rem;
    color: var(--text-dim);
}

.scalc-example {
    font-size: 0.75rem;
    color: var(--text-muted);
    text-decoration: none;
    padding: 3px 10px;
    background: var(--bg-card);
    border-radius: var(--radius-pill);
    transition: background 0.15s, color 0.15s;
}

.scalc-example:hover {
    background: var(--bg-card-hover);
    color: var(--text);
}

.scalc-error {
    background: rgba(248, 113, 113, 0.08);
    border: 1px solid rgba(248, 113, 113, 0.2);
    border-radius: var(--radius-sm);
    padding: 10px 14px;
    font-size: 0.813rem;
    color: var(--offline);
    margin-bottom: 16px;
    line-height: 1.5;
}

.scalc-loading {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 24px;
    justify-content: center;
    font-size: 0.813rem;
    color: var(--text-muted);
    background: var(--bg-card);
    border-radius: var(--radius);
    margin-bottom: 16px;
}

.scalc-spinner {
    width: 18px;
    height: 18px;
    border: 2px solid var(--border);
    border-top-color: var(--text-muted);
    border-radius: 50%;
    animation: scalcSpin 0.7s linear infinite;
}

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

/* Profile card */
.scalc-profile {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 16px;
    background: var(--bg-card);
    border-radius: var(--radius);
    margin-bottom: 12px;
}

.scalc-avatar-wrap {
    position: relative;
    flex-shrink: 0;
}

.scalc-avatar {
    width: 56px;
    height: 56px;
    border-radius: var(--radius-sm);
    display: block;
}

.scalc-status-dot {
    position: absolute;
    bottom: -2px;
    right: -2px;
    width: 14px;
    height: 14px;
    border-radius: 50%;
    background: var(--text-dim);
    border: 2.5px solid var(--bg-card);
}

.scalc-status-dot.scalc-online {
    background: var(--online);
}

.scalc-profile-info {
    flex: 1;
    min-width: 0;
}

.scalc-name-row {
    display: flex;
    align-items: center;
    gap: 8px;
}

.scalc-name {
    font-size: 1rem;
    font-weight: 600;
    color: var(--text);
    line-height: 1.3;
    word-break: break-word;
}

.scalc-level-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 24px;
    height: 20px;
    padding: 0 5px;
    font-size: 0.625rem;
    font-weight: 700;
    color: var(--text);
    background: var(--bg);
    border: 1px solid var(--border);
    border-radius: 10px;
    font-variant-numeric: tabular-nums;
    flex-shrink: 0;
}

.scalc-member {
    font-size: 0.75rem;
    color: var(--text-muted);
    margin-top: 2px;
}

.scalc-status-text {
    font-size: 0.688rem;
    color: var(--text-dim);
    margin-top: 2px;
}

.scalc-badges {
    display: flex;
    gap: 4px;
    margin-top: 6px;
    flex-wrap: wrap;
}

.scalc-badge {
    font-size: 0.625rem;
    font-weight: 600;
    padding: 2px 6px;
    border-radius: 3px;
    text-transform: uppercase;
    letter-spacing: 0.03em;
}

.scalc-badge-vac {
    background: rgba(248, 113, 113, 0.15);
    color: var(--offline);
}

.scalc-badge-trade {
    background: rgba(251, 191, 36, 0.15);
    color: var(--slow);
}

.scalc-badge-limited {
    background: rgba(139, 145, 154, 0.15);
    color: var(--text-dim);
}

.scalc-profile-link {
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    color: var(--text-dim);
    border-radius: var(--radius-sm);
    transition: color 0.15s, background 0.15s;
}

.scalc-profile-link:hover {
    color: var(--text-muted);
    background: var(--bg);
}

/* Stats grid */
.scalc-stats {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 6px;
    margin-bottom: 16px;
}

.scalc-stat {
    padding: 14px;
    background: var(--bg-card);
    border-radius: var(--radius-sm);
}

.scalc-stat-label {
    font-size: 0.688rem;
    color: var(--text-dim);
    text-transform: uppercase;
    letter-spacing: 0.03em;
    font-weight: 500;
    margin-bottom: 4px;
}

.scalc-stat-value {
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--text);
    line-height: 1.2;
    font-variant-numeric: tabular-nums;
}

.scalc-stat-value::selection {
    background: var(--text-dim);
}

.scalc-stat-sub {
    font-size: 0.688rem;
    color: var(--text-dim);
    margin-top: 3px;
}

.scalc-stat-value {
    color: var(--text);
}

.scalc-stat-spent .scalc-stat-value {
    color: var(--slow);
}

/* Section header */
.scalc-section-header {
    margin-bottom: 10px;
    margin-top: 4px;
}

.scalc-section-title {
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--text);
    display: flex;
    align-items: center;
    gap: 6px;
}

/* Games table */
.scalc-table-wrap {
    border-radius: var(--radius);
    overflow: hidden;
    border: 1px solid var(--border);
    margin-bottom: 12px;
}

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

.scalc-table th {
    text-align: left;
    font-size: 0.688rem;
    font-weight: 600;
    color: var(--text-dim);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    padding: 8px 12px;
    background: var(--bg-card);
    border-bottom: 1px solid var(--border);
}

.scalc-table th:last-child {
    text-align: right;
}

.scalc-game-row td {
    padding: 8px 12px;
    border-bottom: 1px solid var(--border);
    background: var(--bg-card);
    transition: background 0.1s;
}

.scalc-game-row:last-child td {
    border-bottom: none;
}

.scalc-game-row:hover td {
    background: var(--bg-card-hover);
}

.scalc-game-rank {
    width: 32px;
    font-size: 0.75rem;
    color: var(--text-dim);
    font-weight: 600;
    text-align: center !important;
}

.scalc-game-name {
    font-size: 0.813rem;
}

.scalc-game-name a {
    color: var(--text);
    text-decoration: none;
    transition: color 0.15s;
}

.scalc-game-name a:hover {
    color: var(--text-muted);
}

.scalc-game-hours {
    text-align: right;
    font-size: 0.813rem;
    font-weight: 600;
    color: var(--text-muted);
    font-variant-numeric: tabular-nums;
    white-space: nowrap;
}

.scalc-inv-thumb-cell {
    width: 52px;
    padding-right: 0 !important;
}

.scalc-inv-thumb {
    width: 48px;
    height: 36px;
    object-fit: contain;
    border-radius: 3px;
    display: block;
    background: var(--bg);
}

/* Notices */
.scalc-notice {
    display: flex;
    gap: 12px;
    padding: 14px;
    background: rgba(139, 145, 154, 0.08);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    margin-bottom: 16px;
    align-items: flex-start;
}

.scalc-notice svg {
    flex-shrink: 0;
    color: var(--text-dim);
    margin-top: 1px;
}

.scalc-notice strong {
    display: block;
    font-size: 0.813rem;
    color: var(--text);
    margin-bottom: 4px;
}

.scalc-notice p {
    font-size: 0.75rem;
    color: var(--text-muted);
    line-height: 1.5;
    margin: 0;
}

.scalc-notice-warn {
    background: rgba(251, 191, 36, 0.06);
    border-color: rgba(251, 191, 36, 0.15);
}

.scalc-notice-warn svg {
    color: var(--slow);
}

/* Disclaimer */
.scalc-disclaimer {
    font-size: 0.688rem;
    color: var(--text-dim);
    line-height: 1.5;
    display: flex;
    align-items: flex-start;
    gap: 6px;
    padding: 10px 0 0;
    margin-bottom: 20px;
}

.scalc-disclaimer svg {
    flex-shrink: 0;
    margin-top: 1px;
}

/* Mobile */
@media (max-width: 600px) {
    .scalc-tool {
        flex-direction: column;
    }

    .scalc-btn-calc {
        justify-content: center;
    }

    .scalc-profile {
        padding: 12px;
        gap: 10px;
    }

    .scalc-avatar {
        width: 44px;
        height: 44px;
    }

    .scalc-status-dot {
        width: 12px;
        height: 12px;
    }

    .scalc-name {
        font-size: 0.875rem;
    }

    .scalc-stats {
        grid-template-columns: repeat(2, 1fr);
        gap: 4px;
    }

    .scalc-stat {
        padding: 10px;
    }

    .scalc-stat-value {
        font-size: 1.05rem;
    }

    .scalc-game-row td {
        padding: 7px 8px;
    }

    .scalc-game-rank {
        width: 24px;
        font-size: 0.688rem;
    }

    .scalc-game-name {
        font-size: 0.75rem;
    }

    .scalc-game-hours {
        font-size: 0.75rem;
    }
}

/* Desktop 3-col stats */
@media (min-width: 480px) {
    .scalc-stats {
        grid-template-columns: repeat(3, 1fr);
    }
}

/* Is Steam Down Tool */
.isd-banner {
    background: var(--bg-card);
    border-radius: var(--radius);
    padding: 16px;
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 10px;
    transition: background 0.3s;
}

.isd-banner[data-status="online"] {
    background: rgba(74, 222, 128, 0.08);
    border: 1px solid rgba(74, 222, 128, 0.15);
}

.isd-banner[data-status="offline"] {
    background: rgba(248, 113, 113, 0.08);
    border: 1px solid rgba(248, 113, 113, 0.15);
}

.isd-banner[data-status="slow"] {
    background: rgba(251, 191, 36, 0.08);
    border: 1px solid rgba(251, 191, 36, 0.15);
}

.isd-banner-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    border-radius: var(--radius-sm);
    background: var(--bg);
    color: var(--text-muted);
    flex-shrink: 0;
    transition: all 0.3s;
}

.isd-banner-icon[data-status="online"] {
    background: rgba(74, 222, 128, 0.12);
    color: var(--online);
}

.isd-banner-icon[data-status="offline"] {
    background: rgba(248, 113, 113, 0.12);
    color: var(--offline);
}

.isd-banner-icon[data-status="slow"] {
    background: rgba(251, 191, 36, 0.12);
    color: var(--slow);
}

.isd-banner-content {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.isd-banner-title {
    font-size: 1.125rem;
    font-weight: 700;
    color: var(--text);
    letter-spacing: -0.01em;
}

.isd-banner[data-status="online"] .isd-banner-title {
    color: var(--online);
}

.isd-banner[data-status="offline"] .isd-banner-title {
    color: var(--offline);
}

.isd-banner[data-status="slow"] .isd-banner-title {
    color: var(--slow);
}

.isd-banner-sub {
    font-size: 0.75rem;
    color: var(--text-muted);
}

.isd-banner-meta {
    display: flex;
    align-items: center;
    gap: 6px;
    flex-shrink: 0;
}

.isd-last-check {
    font-size: 0.688rem;
    color: var(--text-dim);
    white-space: nowrap;
}

.isd-refresh-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    background: var(--bg-card);
    border: none;
    border-radius: var(--radius-sm);
    color: var(--text-muted);
    cursor: pointer;
    transition: all 0.15s;
}

.isd-banner[data-status] .isd-refresh-btn {
    background: rgba(255, 255, 255, 0.06);
}

.isd-refresh-btn:hover {
    background: var(--bg-card-hover);
    color: var(--text);
}

.isd-refresh-btn.loading svg {
    animation: spin 1s linear infinite;
}

/* Services grid */
.isd-services {
    display: flex;
    flex-direction: column;
    gap: 4px;
    margin-bottom: 10px;
}

.isd-service {
    background: var(--bg-card);
    border-radius: var(--radius-sm);
    padding: 10px 12px;
    display: flex;
    align-items: center;
    gap: 10px;
    transition: background 0.15s;
}

.isd-service-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    border-radius: 6px;
    flex-shrink: 0;
    transition: all 0.3s;
    background: var(--bg);
    color: var(--text-muted);
}

.isd-service-icon[data-status="online"] {
    background: rgba(74, 222, 128, 0.12);
    color: var(--online);
}

.isd-service-icon[data-status="offline"] {
    background: rgba(248, 113, 113, 0.12);
    color: var(--offline);
}

.isd-service-icon[data-status="slow"] {
    background: rgba(251, 191, 36, 0.12);
    color: var(--slow);
}

.isd-service-icon[data-status="loading"] {
    animation: pulse 1.5s ease-in-out infinite;
}

.isd-service-info {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 1px;
}

.isd-service-name {
    font-size: 0.813rem;
    font-weight: 600;
    color: var(--text);
}

.isd-service-status {
    font-size: 0.688rem;
    color: var(--text-dim);
    transition: color 0.3s;
}

.isd-service-status[data-status="online"] {
    color: var(--online);
}

.isd-service-status[data-status="offline"] {
    color: var(--offline);
}

.isd-service-status[data-status="slow"] {
    color: var(--slow);
}

.isd-service-latency {
    font-size: 0.688rem;
    font-weight: 500;
    color: var(--text-dim);
    font-variant-numeric: tabular-nums;
    min-width: 40px;
    text-align: right;
    flex-shrink: 0;
}

.isd-service-latency[data-status="online"] {
    color: var(--online);
}

.isd-service-latency[data-status="slow"] {
    color: var(--slow);
}

.isd-service-latency[data-status="offline"] {
    color: var(--offline);
}

/* Players online */
.isd-players {
    background: var(--bg-card);
    border-radius: var(--radius-sm);
    padding: 10px 12px;
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 20px;
}

.isd-players-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    border-radius: 6px;
    background: var(--bg);
    color: var(--text-muted);
    flex-shrink: 0;
}

.isd-players-info {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
}

.isd-players-label {
    font-size: 0.688rem;
    color: var(--text-dim);
    text-transform: uppercase;
    letter-spacing: 0.03em;
}

.isd-players-count {
    font-size: 1rem;
    font-weight: 700;
    color: var(--text);
    font-variant-numeric: tabular-nums;
}

/* Maintenance notice */
.isd-notice {
    background: rgba(251, 191, 36, 0.08);
    border: 1px solid rgba(251, 191, 36, 0.15);
    border-radius: var(--radius-sm);
    padding: 10px 12px;
    display: flex;
    align-items: flex-start;
    gap: 8px;
    margin-bottom: 20px;
    font-size: 0.75rem;
    color: var(--slow);
    line-height: 1.5;
}

.isd-notice svg {
    flex-shrink: 0;
    margin-top: 1px;
}

@media (max-width: 600px) {
    .isd-banner {
        flex-wrap: wrap;
        gap: 10px;
    }

    .isd-banner-icon {
        width: 36px;
        height: 36px;
    }

    .isd-banner-icon svg {
        width: 20px;
        height: 20px;
    }

    .isd-banner-title {
        font-size: 1rem;
    }

    .isd-banner-meta {
        width: 100%;
        justify-content: space-between;
        padding-top: 4px;
        border-top: 1px solid rgba(255, 255, 255, 0.05);
    }

    .isd-service {
        padding: 8px 10px;
    }

    .isd-service-icon {
        width: 28px;
        height: 28px;
    }

    .isd-service-icon svg {
        width: 14px;
        height: 14px;
    }
}

/* ===== Steam Server Status (sss-) ===== */

.sss-banner {
    background: var(--bg-card);
    border-radius: var(--radius);
    padding: 16px;
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 10px;
    transition: background 0.3s;
}

.sss-banner[data-status="online"] {
    background: rgba(74, 222, 128, 0.08);
    border: 1px solid rgba(74, 222, 128, 0.15);
}

.sss-banner[data-status="offline"] {
    background: rgba(248, 113, 113, 0.08);
    border: 1px solid rgba(248, 113, 113, 0.15);
}

.sss-banner[data-status="slow"] {
    background: rgba(251, 191, 36, 0.08);
    border: 1px solid rgba(251, 191, 36, 0.15);
}

.sss-banner-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    border-radius: var(--radius-sm);
    background: var(--bg);
    color: var(--text-muted);
    flex-shrink: 0;
    transition: all 0.3s;
}

.sss-banner-icon[data-status="online"] {
    background: rgba(74, 222, 128, 0.12);
    color: var(--online);
}

.sss-banner-icon[data-status="offline"] {
    background: rgba(248, 113, 113, 0.12);
    color: var(--offline);
}

.sss-banner-icon[data-status="slow"] {
    background: rgba(251, 191, 36, 0.12);
    color: var(--slow);
}

.sss-banner-content {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.sss-banner-title {
    font-size: 1.125rem;
    font-weight: 700;
    color: var(--text);
    letter-spacing: -0.01em;
}

.sss-banner[data-status="online"] .sss-banner-title { color: var(--online); }
.sss-banner[data-status="offline"] .sss-banner-title { color: var(--offline); }
.sss-banner[data-status="slow"] .sss-banner-title { color: var(--slow); }

.sss-banner-sub {
    font-size: 0.75rem;
    color: var(--text-muted);
}

.sss-banner-meta {
    display: flex;
    align-items: center;
    gap: 6px;
    flex-shrink: 0;
}

.sss-last-check {
    font-size: 0.688rem;
    color: var(--text-dim);
    white-space: nowrap;
}

.sss-refresh-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    background: var(--bg-card);
    border: none;
    border-radius: var(--radius-sm);
    color: var(--text-muted);
    cursor: pointer;
    transition: all 0.15s;
}

.sss-banner[data-status] .sss-refresh-btn {
    background: rgba(255, 255, 255, 0.06);
}

.sss-refresh-btn:hover {
    background: var(--bg-card-hover);
    color: var(--text);
}

.sss-refresh-btn.loading svg {
    animation: spin 1s linear infinite;
}

/* Summary stats row */
.sss-stats {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 4px;
    margin-bottom: 10px;
}

.sss-stat {
    background: var(--bg-card);
    border-radius: var(--radius-sm);
    padding: 12px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 2px;
    text-align: center;
}

.sss-stat-value {
    font-size: 1.125rem;
    font-weight: 700;
    color: var(--text);
    font-variant-numeric: tabular-nums;
}

.sss-stat-label {
    font-size: 0.625rem;
    color: var(--text-dim);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

/* Maintenance notice */
.sss-notice {
    background: rgba(251, 191, 36, 0.08);
    border: 1px solid rgba(251, 191, 36, 0.15);
    border-radius: var(--radius-sm);
    padding: 10px 12px;
    display: flex;
    align-items: flex-start;
    gap: 8px;
    margin-bottom: 10px;
    font-size: 0.75rem;
    color: var(--slow);
    line-height: 1.5;
}

.sss-notice svg {
    flex-shrink: 0;
    margin-top: 1px;
}

/* Sections */
.sss-section {
    margin-bottom: 20px;
}

.sss-section-title {
    font-size: 0.813rem;
    font-weight: 600;
    color: var(--text);
    margin: 0 0 8px;
    display: flex;
    align-items: center;
    gap: 6px;
}

.sss-section-title svg {
    color: var(--text-muted);
    flex-shrink: 0;
}

.sss-section-desc {
    font-size: 0.688rem;
    color: var(--text-dim);
    margin: -4px 0 8px;
}

/* Platform & Game card grid */
.sss-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 4px;
}

.sss-grid-3 {
    grid-template-columns: repeat(3, 1fr);
}

.sss-card {
    background: var(--bg-card);
    border-radius: var(--radius-sm);
    padding: 12px;
    display: flex;
    flex-direction: column;
    gap: 6px;
    transition: background 0.15s;
}

.sss-card-header {
    display: flex;
    align-items: center;
    gap: 6px;
}

.sss-card-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    flex-shrink: 0;
    background: var(--text-dim);
    transition: background 0.3s;
}

.sss-card-dot[data-status="online"] { background: var(--online); box-shadow: 0 0 6px rgba(74, 222, 128, 0.4); }
.sss-card-dot[data-status="offline"] { background: var(--offline); box-shadow: 0 0 6px rgba(248, 113, 113, 0.4); }
.sss-card-dot[data-status="slow"] { background: var(--slow); box-shadow: 0 0 6px rgba(251, 191, 36, 0.4); }
.sss-card-dot[data-status="loading"] { animation: pulse 1.5s ease-in-out infinite; }

.sss-card-name {
    font-size: 0.813rem;
    font-weight: 600;
    color: var(--text);
    flex: 1;
}

.sss-card-latency {
    font-size: 0.688rem;
    font-weight: 500;
    color: var(--text-dim);
    font-variant-numeric: tabular-nums;
    flex-shrink: 0;
}

.sss-card-latency[data-status="online"] { color: var(--online); }
.sss-card-latency[data-status="slow"] { color: var(--slow); }
.sss-card-latency[data-status="offline"] { color: var(--offline); }

.sss-card-status {
    font-size: 0.688rem;
    color: var(--text-dim);
    transition: color 0.3s;
}

.sss-card-status[data-status="online"] { color: var(--online); }
.sss-card-status[data-status="offline"] { color: var(--offline); }
.sss-card-status[data-status="slow"] { color: var(--slow); }

/* Game card detail (player count) */
.sss-card-detail {
    font-size: 0.625rem;
    color: var(--text-dim);
    font-variant-numeric: tabular-nums;
}

.sss-card-detail[data-status="active"] {
    color: var(--text-muted);
}

.sss-card-detail[data-status="offline"] {
    color: var(--offline);
}

/* Region rows */
.sss-regions {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 4px;
}

.sss-region {
    background: var(--bg-card);
    border-radius: var(--radius-sm);
    padding: 10px 12px;
    display: flex;
    align-items: center;
    gap: 10px;
    transition: background 0.15s;
}

.sss-region-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    flex-shrink: 0;
    background: var(--text-dim);
    transition: background 0.3s;
}

.sss-region-dot[data-status="online"] { background: var(--online); box-shadow: 0 0 6px rgba(74, 222, 128, 0.4); }
.sss-region-dot[data-status="offline"] { background: var(--offline); box-shadow: 0 0 6px rgba(248, 113, 113, 0.4); }
.sss-region-dot[data-status="slow"] { background: var(--slow); box-shadow: 0 0 6px rgba(251, 191, 36, 0.4); }
.sss-region-dot[data-status="loading"] { animation: pulse 1.5s ease-in-out infinite; }

.sss-region-info {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 1px;
}

.sss-region-name {
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--text);
}

.sss-region-status {
    font-size: 0.625rem;
    color: var(--text-dim);
    transition: color 0.3s;
}

.sss-region-status[data-status="online"] { color: var(--online); }
.sss-region-status[data-status="offline"] { color: var(--offline); }
.sss-region-status[data-status="slow"] { color: var(--slow); }

.sss-region-latency {
    font-size: 0.688rem;
    font-weight: 500;
    color: var(--text-dim);
    font-variant-numeric: tabular-nums;
    min-width: 36px;
    text-align: right;
    flex-shrink: 0;
}

.sss-region-latency[data-status="online"] { color: var(--online); }
.sss-region-latency[data-status="slow"] { color: var(--slow); }
.sss-region-latency[data-status="offline"] { color: var(--offline); }

/* Mobile responsive */
@media (max-width: 600px) {
    .sss-banner {
        flex-wrap: wrap;
        gap: 10px;
    }

    .sss-banner-icon {
        width: 36px;
        height: 36px;
    }

    .sss-banner-icon svg {
        width: 20px;
        height: 20px;
    }

    .sss-banner-title {
        font-size: 1rem;
    }

    .sss-banner-meta {
        width: 100%;
        justify-content: space-between;
        padding-top: 4px;
        border-top: 1px solid rgba(255, 255, 255, 0.05);
    }

    .sss-stats {
        grid-template-columns: repeat(3, 1fr);
    }

    .sss-stat {
        padding: 10px 6px;
    }

    .sss-stat-value {
        font-size: 0.938rem;
    }

    .sss-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .sss-grid-3 {
        grid-template-columns: repeat(3, 1fr);
    }

    .sss-regions {
        grid-template-columns: 1fr;
    }

    .sss-card {
        padding: 10px;
    }

    .sss-region {
        padding: 8px 10px;
    }
}

@media (max-width: 400px) {
    .sss-grid-3 {
        grid-template-columns: 1fr 1fr;
    }
}

/* ===== End Steam Server Status ===== */

/* FAQ */
.faq-list {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.faq-item {
    background: var(--bg-card);
    border-radius: var(--radius-sm);
    overflow: hidden;
}

.faq-question {
    padding: 12px 14px;
    font-size: 0.813rem;
    font-weight: 500;
    color: var(--text);
    cursor: pointer;
    list-style: none;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.faq-question::-webkit-details-marker {
    display: none;
}

.faq-question::after {
    content: '+';
    font-size: 1rem;
    color: var(--text-dim);
    transition: transform 0.2s;
}

.faq-item[open] .faq-question::after {
    content: '−';
}

.faq-answer {
    padding: 0 14px 12px;
    font-size: 0.75rem;
    color: var(--text-muted);
    line-height: 1.6;
}

/* 404 Error Page */
.error-page {
    display: flex;
    align-items: center;
    justify-content: center;
    flex: 1;
    min-height: 50vh;
}

.error-container {
    text-align: center;
}

.error-code {
    font-size: 5rem;
    font-weight: 700;
    color: var(--text-dim);
    line-height: 1;
    letter-spacing: -0.04em;
}

.error-title {
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--text);
    margin: 12px 0 8px;
}

.error-text {
    font-size: 0.813rem;
    color: var(--text-muted);
    margin-bottom: 20px;
}

.error-link {
    display: inline-block;
    font-size: 0.813rem;
    font-weight: 500;
    color: var(--text);
    text-decoration: none;
    padding: 10px 20px;
    background: var(--bg-card);
    border-radius: var(--radius-sm);
    transition: background 0.15s;
}

.error-link:hover {
    background: var(--bg-card-hover);
}

/* Footer */
.footer {
    margin-top: 24px;
    padding: 20px 0 12px;
    border-top: 1px solid var(--border);
}

.footer-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px 16px;
    margin-bottom: 20px;
}

.footer-brand {
    grid-column: span 2;
}

.footer-logo {
    font-size: 1rem;
    color: var(--text-muted);
}

.footer-logo strong {
    color: var(--text);
}

.footer-tagline {
    font-size: 0.688rem;
    color: var(--text-dim);
    margin-top: 4px;
}

.footer-section {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.footer-heading {
    font-size: 0.688rem;
    font-weight: 600;
    color: var(--text);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.footer-links {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.footer-links a {
    font-size: 0.75rem;
    color: var(--text-muted);
    text-decoration: none;
    transition: color 0.15s;
}

.footer-links a:hover {
    color: var(--text);
}

.footer-lang {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 12px 0;
    border-top: 1px solid var(--border);
    margin-top: 4px;
    color: var(--text-dim);
}

.footer-lang svg {
    flex-shrink: 0;
}

.footer-lang-current {
    font-size: 0.688rem;
    font-weight: 600;
    color: var(--text);
    text-transform: uppercase;
}

.footer-lang-sep {
    font-size: 0.688rem;
    color: var(--text-dim);
}

.footer-lang-link {
    font-size: 0.688rem;
    font-weight: 500;
    color: var(--text-muted);
    text-decoration: none;
    transition: color 0.15s;
}

.footer-lang-link:hover {
    color: var(--text);
}

.footer-bottom {
    padding-top: 12px;
    border-top: 1px solid var(--border);
}

.footer-disclaimer {
    font-size: 0.625rem;
    color: var(--text-dim);
    line-height: 1.5;
    margin-bottom: 8px;
}

.footer-copyright {
    font-size: 0.625rem;
    color: var(--text-dim);
}

/* Desktop footer */
@media (min-width: 640px) {
    .footer-grid {
        grid-template-columns: 2fr 1fr 1fr 1fr;
        gap: 24px;
    }
    
    .footer-brand {
        grid-column: span 1;
    }
}

/* Tablet & Desktop */
@media (min-width: 640px) {
    html {
        font-size: 15px;
    }

    .container {
        max-width: 680px;
        padding: 20px;
    }

    .header {
        margin-bottom: 24px;
    }

    .bento-grid {
        gap: 10px;
    }

    .status-grid {
        grid-template-columns: repeat(4, 1fr);
    }

    .card-main {
        grid-column: span 2;
        grid-row: span 2;
        flex-direction: column;
        justify-content: center;
        align-items: center;
        text-align: center;
        padding: 20px;
    }

    .card-main .card-icon {
        width: 48px;
        height: 48px;
    }

    .card-main .card-content {
        align-items: center;
    }

    .card-wide {
        grid-column: span 2;
    }

    .tools-grid {
        grid-template-columns: repeat(3, 1fr);
    }

    .skins-grid {
        grid-template-columns: repeat(5, 1fr);
    }

    .skins-grid .card-skin-link:first-child {
        grid-column: span 1;
    }

    .card {
        padding: 14px;
    }
}

@media (min-width: 900px) {
    .container {
        max-width: 800px;
        padding: 24px;
    }

    .main {
        gap: 28px;
    }

    .section {
        gap: 12px;
    }

    .status-grid {
        grid-template-columns: repeat(4, 1fr);
    }

    .tools-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

/* Smooth loading states */
.card-value[data-loading="true"] {
    background: linear-gradient(90deg, var(--bg) 25%, var(--bg-card-hover) 50%, var(--bg) 75%);
    background-size: 200% 100%;
    animation: shimmer 1.5s infinite;
    border-radius: 4px;
    color: transparent;
    min-width: 40px;
}

@keyframes shimmer {
    0% { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

/* Status text colors */
.card-value[data-status="online"] {
    color: var(--online);
}

.card-value[data-status="offline"] {
    color: var(--offline);
}

.card-value[data-status="slow"] {
    color: var(--slow);
}

/* ═══════════════════════════════════════════════════════
   TOOLS LISTING
   ═══════════════════════════════════════════════════════ */

.tools-listing {
    display: flex;
    flex-direction: column;
    gap: 6px;
    margin-bottom: 24px;
}

.tool-listing-card {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 14px;
    background: var(--bg-card);
    border-radius: var(--radius);
    text-decoration: none;
    transition: background 0.15s ease;
}

.tool-listing-card:hover {
    background: var(--bg-card-hover);
}

.tool-listing-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    background: var(--bg);
    border-radius: var(--radius-sm);
    color: var(--text-dim);
    flex-shrink: 0;
    transition: color 0.15s ease;
}

.tool-listing-card:hover .tool-listing-icon {
    color: var(--text-muted);
}

.tool-listing-content {
    flex: 1;
    min-width: 0;
}

.tool-listing-name {
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--text);
    margin: 0;
}

.tool-listing-desc {
    font-size: 0.75rem;
    color: var(--text-dim);
    margin: 2px 0 0;
    line-height: 1.4;
}

.tool-listing-arrow {
    color: var(--text-dim);
    flex-shrink: 0;
    opacity: 0;
    transform: translateX(-4px);
    transition: all 0.15s ease;
}

.tool-listing-card:hover .tool-listing-arrow {
    opacity: 1;
    transform: translateX(0);
}

/* ═══════════════════════════════════════════════════════
   RELATED TOOLS (cross-linking between tool pages)
   ═══════════════════════════════════════════════════════ */

.related-tools {
    margin-top: 32px;
    margin-bottom: 8px;
    padding-top: 24px;
    border-top: 1px solid var(--border);
}

.related-tools-title {
    font-size: 0.813rem;
    font-weight: 600;
    color: var(--text-muted);
    margin: 0 0 12px;
    display: flex;
    align-items: center;
    gap: 6px;
}

.related-tools-title svg {
    color: var(--text-dim);
}

.related-tools-grid {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.related-tool-card {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 12px;
    background: var(--bg-card);
    border-radius: var(--radius);
    text-decoration: none;
    transition: background 0.15s ease;
}

.related-tool-card:hover {
    background: var(--bg-card-hover);
}

.related-tool-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    background: var(--bg);
    border-radius: var(--radius-sm);
    color: var(--text-dim);
    flex-shrink: 0;
    transition: color 0.15s ease;
}

.related-tool-card:hover .related-tool-icon {
    color: var(--text-muted);
}

.related-tool-info {
    flex: 1;
    min-width: 0;
}

.related-tool-name {
    display: block;
    font-size: 0.813rem;
    font-weight: 500;
    color: var(--text);
    line-height: 1.3;
}

.related-tool-desc {
    display: block;
    font-size: 0.688rem;
    color: var(--text-dim);
    line-height: 1.3;
    margin-top: 1px;
}

.related-tool-arrow {
    color: var(--text-dim);
    flex-shrink: 0;
    opacity: 0;
    transform: translateX(-4px);
    transition: all 0.15s ease;
}

.related-tool-card:hover .related-tool-arrow {
    opacity: 1;
    transform: translateX(0);
}

@media (min-width: 640px) {
    .related-tools-grid {
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
        gap: 6px;
    }
}

/* ═══════════════════════════════════════════════════════
   CONTENT FEED (Articles & News)
   ═══════════════════════════════════════════════════════ */

.content-tags {
    display: flex;
    gap: 6px;
    margin-bottom: 16px;
    flex-wrap: wrap;
}

.content-tag {
    display: inline-flex;
    align-items: center;
    padding: 6px 12px;
    font-size: 0.75rem;
    font-weight: 500;
    color: var(--text-muted);
    background: var(--bg-card);
    border-radius: var(--radius-pill);
    text-decoration: none;
    transition: all 0.15s ease;
}

.content-tag:hover {
    background: var(--bg-card-hover);
    color: var(--text);
}

.content-tag--active {
    background: var(--text);
    color: var(--bg);
}

.content-tag--active:hover {
    background: var(--text-muted);
    color: var(--bg);
}

.content-feed {
    display: flex;
    flex-direction: column;
    gap: 6px;
    margin-bottom: 24px;
}

.feed-card {
    display: block;
    padding: 16px;
    background: var(--bg-card);
    border-radius: var(--radius);
    text-decoration: none;
    transition: background 0.15s ease;
}

.feed-card:hover {
    background: var(--bg-card-hover);
}

.feed-card-body {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.feed-card-meta {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 0.688rem;
    color: var(--text-dim);
}

.feed-card-sep {
    color: var(--text-dim);
}

.feed-card-title {
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--text);
    margin: 0;
    line-height: 1.4;
}

.feed-card-desc {
    font-size: 0.75rem;
    color: var(--text-muted);
    margin: 0;
    line-height: 1.5;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.feed-card-tags {
    display: flex;
    gap: 4px;
    flex-wrap: wrap;
    margin-top: 2px;
}

.feed-tag {
    font-size: 0.625rem;
    font-weight: 500;
    padding: 2px 8px;
    background: var(--bg);
    color: var(--text-dim);
    border-radius: var(--radius-pill);
    text-transform: uppercase;
    letter-spacing: 0.03em;
}

/* ═══════════════════════════════════════════════════════
   ARTICLE / NEWS DETAIL
   ═══════════════════════════════════════════════════════ */

.article-detail .page-title {
    line-height: 1.3;
}

.article-header {
    margin-bottom: 20px;
}

.article-breadcrumb {
    display: flex;
    align-items: center;
    gap: 6px;
    margin-bottom: 12px;
    font-size: 0.75rem;
}

.article-breadcrumb a {
    color: var(--text-dim);
    text-decoration: none;
    transition: color 0.15s ease;
}

.article-breadcrumb a:hover {
    color: var(--text);
}

.article-breadcrumb-sep {
    color: var(--text-dim);
}

.article-meta {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 0.75rem;
    color: var(--text-dim);
    margin-bottom: 10px;
}

.article-meta-sep {
    color: var(--text-dim);
}

.article-tags {
    display: flex;
    gap: 4px;
    flex-wrap: wrap;
}

.article-lead {
    padding: 16px;
    background: var(--bg-card);
    border-radius: var(--radius);
    margin-bottom: 24px;
}

.article-lead p {
    font-size: 0.875rem;
    color: var(--text-muted);
    line-height: 1.7;
    margin: 0;
}

.article-footer {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    padding-top: 20px;
    border-top: 1px solid var(--border);
    margin-top: 8px;
}

.article-back {
    display: inline-block;
    font-size: 0.813rem;
    font-weight: 500;
    color: var(--text);
    text-decoration: none;
    padding: 8px 16px;
    background: var(--bg-card);
    border-radius: var(--radius-sm);
    transition: background 0.15s;
}

.article-back:hover {
    background: var(--bg-card-hover);
}

/* ═══════════════════════════════════════════════════════
   SKINS SECTION
   ═══════════════════════════════════════════════════════ */

/* Rarity Colors */
:root {
    --rarity-consumer: #b0c3d9;
    --rarity-industrial: #5e98d9;
    --rarity-milspec: #4b69ff;
    --rarity-restricted: #8847ff;
    --rarity-classified: #d32ce6;
    --rarity-covert: #eb4b4b;
    --rarity-extraordinary: #e4ae39;
    --rarity-contraband: #e4ae39;
}

/* Wide Container */
.container--wide {
    max-width: 540px;
}

/* Skins Layout */
.skins-layout {
    display: flex;
    flex-direction: column;
    gap: 0;
}

.skins-content {
    flex: 1;
    min-width: 0;
}

/* ─── Breadcrumbs ─── */
.breadcrumbs {
    margin-bottom: 16px;
}

.breadcrumbs-list {
    list-style: none;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0;
}

.breadcrumbs-item {
    display: flex;
    align-items: center;
    font-size: 0.688rem;
}

.breadcrumbs-sep {
    margin: 0 6px;
    color: var(--text-dim);
}

.breadcrumbs-link {
    color: var(--text-muted);
    text-decoration: none;
    transition: color 0.15s;
}

.breadcrumbs-link:hover {
    color: var(--text);
}

.breadcrumbs-current {
    color: var(--text-dim);
}

/* ─── Sidebar ─── */
.sidebar-toggle {
    display: flex;
    align-items: center;
    gap: 6px;
    position: fixed;
    bottom: 16px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 200;
    padding: 10px 18px;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius-pill);
    color: var(--text);
    font-size: 0.813rem;
    font-weight: 500;
    font-family: inherit;
    cursor: pointer;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.5);
    transition: all 0.15s ease;
}

.sidebar-toggle:hover {
    background: var(--bg-card-hover);
}

.sidebar-backdrop {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.6);
    z-index: 299;
}

.sidebar-backdrop.active {
    display: block;
}

.sidebar {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    bottom: 0;
    width: 280px;
    max-width: 85vw;
    background: var(--bg);
    border-right: 1px solid var(--border);
    z-index: 300;
    flex-direction: column;
    overflow: hidden;
    transform: translateX(-100%);
    transition: transform 0.25s ease;
}

.sidebar.open {
    display: flex;
    transform: translateX(0);
}

.sidebar-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 14px 16px;
    border-bottom: 1px solid var(--border);
}

.sidebar-title {
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--text);
}

.sidebar-close {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    background: var(--bg-card);
    border: none;
    border-radius: var(--radius-sm);
    color: var(--text-muted);
    cursor: pointer;
    transition: all 0.15s ease;
}

.sidebar-close:hover {
    background: var(--bg-card-hover);
    color: var(--text);
}

.sidebar-search {
    padding: 10px 12px;
    border-bottom: 1px solid var(--border);
}

.sidebar-search-input {
    width: 100%;
    padding: 8px 10px;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    color: var(--text);
    font-size: 0.75rem;
    font-family: inherit;
    outline: none;
    transition: border-color 0.15s;
}

.sidebar-search-input::placeholder {
    color: var(--text-dim);
}

.sidebar-search-input:focus {
    border-color: var(--text-dim);
}

.sidebar-nav {
    flex: 1;
    overflow-y: auto;
    padding: 8px 0;
}

.sidebar-nav::-webkit-scrollbar {
    width: 4px;
}

.sidebar-nav::-webkit-scrollbar-track {
    background: transparent;
}

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

.sidebar-group {
    margin-bottom: 2px;
}

.sidebar-group.hidden {
    display: none;
}

.sidebar-group-toggle {
    display: flex;
    align-items: center;
    width: 100%;
    padding: 8px 14px;
    background: none;
    border: none;
    color: var(--text);
    font-size: 0.75rem;
    font-weight: 600;
    font-family: inherit;
    cursor: pointer;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    gap: 6px;
    transition: background 0.15s;
}

.sidebar-group-toggle:hover {
    background: var(--bg-card);
}

.sidebar-group-count {
    font-size: 0.625rem;
    color: var(--text-dim);
    font-weight: 400;
    margin-right: auto;
}

.sidebar-chevron {
    transition: transform 0.2s ease;
    color: var(--text-dim);
    flex-shrink: 0;
}

.sidebar-group-toggle.expanded .sidebar-chevron {
    transform: rotate(180deg);
}

.sidebar-group-items {
    display: none;
    flex-direction: column;
    gap: 1px;
    padding-bottom: 4px;
}

.sidebar-group-items.expanded {
    display: flex;
}

.sidebar-link {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 6px 14px 6px 24px;
    font-size: 0.75rem;
    color: var(--text-muted);
    text-decoration: none;
    transition: all 0.15s;
    border-radius: 0;
}

.sidebar-link:hover {
    color: var(--text);
    background: var(--bg-card);
}

.sidebar-link.active {
    color: var(--text);
    background: var(--bg-card);
    font-weight: 500;
}

.sidebar-link.hidden {
    display: none;
}

.sidebar-link-count {
    font-size: 0.625rem;
    color: var(--text-dim);
}

.sidebar-models {
    display: flex;
    flex-direction: column;
    gap: 1px;
    padding-left: 12px;
    border-left: 1px solid var(--border);
    margin-left: 10px;
    margin-bottom: 4px;
}

.sidebar-link--model {
    font-size: 0.688rem;
    padding: 4px 10px;
}

/* ─── Game Hub ─── */
.game-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
}

.game-card {
    background: var(--bg-card);
    border-radius: var(--radius);
    padding: 24px 16px;
    text-align: center;
    text-decoration: none;
    transition: background 0.15s ease;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
}

.game-card:hover {
    background: var(--bg-card-hover);
}

.game-card--disabled {
    opacity: 0.4;
    pointer-events: none;
}

.game-card-icon {
    width: 56px;
    height: 56px;
    background: var(--bg);
    border-radius: var(--radius);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--text-dim);
}

.game-card-name {
    font-size: 0.938rem;
    font-weight: 600;
    color: var(--text);
}

.game-card-badge {
    font-size: 0.625rem;
    padding: 2px 8px;
    background: var(--bg);
    color: var(--text-dim);
    border-radius: var(--radius-pill);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

/* ─── Category Cards (Hub) ─── */
.hub-section {
    margin-bottom: 24px;
}

.hub-section-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 10px;
}

.hub-section-title {
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--text);
    letter-spacing: -0.01em;
}

.hub-section-count {
    font-size: 0.688rem;
    color: var(--text-dim);
}

.hub-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 8px;
}

.hub-grid--hero {
    gap: 10px;
}

.hub-grid--compact {
    grid-template-columns: repeat(2, 1fr);
    gap: 6px;
}

.hub-grid--compact .cat-card {
    min-width: 0;
}

.hub-grid--compact .cat-card-name {
    font-size: 0.75rem;
}

.cat-card {
    background: var(--bg-card);
    border-radius: var(--radius);
    padding: 12px;
    text-decoration: none;
    display: flex;
    align-items: center;
    gap: 10px;
    transition: background 0.15s ease;
}

.cat-card:hover {
    background: var(--bg-card-hover);
}

.cat-card--hero {
    flex-direction: column;
    align-items: center;
    text-align: center;
    padding: 20px 12px;
    gap: 10px;
}

.cat-card-img {
    width: 36px;
    height: 36px;
    background: var(--bg);
    border-radius: var(--radius-sm);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--text-dim);
    flex-shrink: 0;
    overflow: hidden;
}

.cat-card-img img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    opacity: 0;
    transition: opacity 0.2s ease;
}

.cat-card-img img.loaded {
    opacity: 1;
}

.cat-card-img--hero {
    width: 56px;
    height: 56px;
    border-radius: var(--radius);
}

.cat-card-info {
    display: flex;
    flex-direction: column;
    gap: 2px;
    min-width: 0;
}

.cat-card-name {
    font-size: 0.813rem;
    font-weight: 500;
    color: var(--text);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.cat-card--hero .cat-card-name {
    font-size: 0.938rem;
    font-weight: 600;
    white-space: normal;
}

.cat-card-count {
    font-size: 0.625rem;
    color: var(--text-dim);
}

/* Weapon class subsection */
.weapon-class {
    margin-bottom: 14px;
}

.weapon-class-title {
    font-size: 0.75rem;
    font-weight: 500;
    color: var(--text-muted);
    margin-bottom: 6px;
    padding-left: 2px;
}

/* ─── Hub Search ─── */
.hub-search {
    margin-bottom: 20px;
}

.hub-search-input {
    width: 100%;
    padding: 10px 14px;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    color: var(--text);
    font-size: 0.875rem;
    font-family: inherit;
    outline: none;
    transition: border-color 0.15s;
}

.hub-search-input::placeholder {
    color: var(--text-dim);
}

.hub-search-input:focus {
    border-color: var(--text-muted);
}

.hub-no-results {
    display: none;
    text-align: center;
    padding: 32px 16px;
    color: var(--text-muted);
    font-size: 0.813rem;
}

.hub-no-results.visible {
    display: block;
}

/* ─── Category Page ─── */
.category-tabs {
    display: flex;
    gap: 6px;
    margin-bottom: 16px;
    flex-wrap: wrap;
}

.category-tab {
    display: inline-flex;
    align-items: center;
    padding: 6px 14px;
    font-size: 0.75rem;
    font-weight: 500;
    color: var(--text-muted);
    background: var(--bg-card);
    border-radius: var(--radius-pill);
    text-decoration: none;
    transition: background 0.15s ease, color 0.15s ease;
}

.category-tab:hover {
    background: var(--bg-card-hover);
    color: var(--text);
}

.category-tab.active {
    background: var(--text);
    color: var(--bg);
}

.category-tab.active:hover {
    background: var(--text-muted);
    color: var(--bg);
}

.category-header {
    display: flex;
    align-items: baseline;
    gap: 10px;
    margin-bottom: 8px;
}

.category-title {
    font-size: 1.375rem;
    font-weight: 700;
    color: var(--text);
    letter-spacing: -0.02em;
}

.category-count {
    font-size: 0.75rem;
    color: var(--text-dim);
}

.category-badge {
    font-size: 0.625rem;
    font-weight: 500;
    padding: 3px 8px;
    background: var(--bg-card);
    color: var(--text-muted);
    border-radius: var(--radius-pill);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.category-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
}

.category-filter-input {
    width: 100%;
    padding: 8px 12px;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    color: var(--text);
    font-size: 0.813rem;
    font-family: inherit;
    outline: none;
    transition: border-color 0.15s;
}

.category-filter-input::placeholder {
    color: var(--text-dim);
}

.category-filter-input:focus {
    border-color: var(--text-muted);
}

.items-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 8px;
    margin-bottom: 24px;
}

.items-no-results {
    display: none;
    grid-column: 1 / -1;
    text-align: center;
    padding: 24px;
    color: var(--text-muted);
    font-size: 0.813rem;
}

.items-no-results.visible {
    display: block;
}

/* ─── Skin Card ─── */
.skin-card {
    background: var(--bg-card);
    border-radius: var(--radius);
    text-decoration: none;
    display: flex;
    flex-direction: column;
    transition: all 0.2s ease;
    border: 1px solid transparent;
    overflow: hidden;
}

.skin-card:hover {
    background: var(--bg-card-hover);
    border-color: var(--border);
}

.skin-card-visual {
    position: relative;
    width: 100%;
    aspect-ratio: 4/3;
    background: linear-gradient(135deg, var(--bg) 0%, rgba(26, 29, 36, 0.6) 100%);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--text-dim);
    overflow: hidden;
    border-bottom: 2px solid var(--rarity-color, var(--border));
}

@keyframes img-shimmer {
    0% { transform: translateX(-100%); }
    100% { transform: translateX(100%); }
}

.skin-card-visual::before,
.item-image::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(90deg, transparent 0%, rgba(255, 255, 255, 0.04) 50%, transparent 100%);
    animation: img-shimmer 1.6s ease-in-out infinite;
    z-index: 0;
    pointer-events: none;
}

.skin-card-visual.img-loaded::before,
.item-image.img-loaded::before {
    display: none;
}

.skin-card-featured {
    position: absolute;
    top: 6px;
    left: 6px;
    z-index: 1;
    display: inline-flex;
    align-items: center;
    padding: 3px 7px;
    border-radius: var(--radius-pill);
    background: rgba(255, 215, 0, 0.12);
    border: 1px solid rgba(255, 215, 0, 0.26);
    color: #d4a72c;
    font-size: 0.563rem;
    font-weight: 700;
    line-height: 1;
    letter-spacing: 0.02em;
    backdrop-filter: blur(8px);
}

.skin-card-badges {
    position: absolute;
    top: 6px;
    right: 6px;
    display: flex;
    gap: 3px;
    z-index: 1;
}

.skin-card-badge {
    padding: 2px 5px;
    border-radius: 4px;
    font-size: 0.563rem;
    font-weight: 700;
    line-height: 1;
    letter-spacing: 0.04em;
    backdrop-filter: blur(8px);
}

.skin-card-badge--st {
    background: rgba(207, 106, 50, 0.18);
    border: 1px solid rgba(207, 106, 50, 0.3);
    color: #cf6a32;
}

.skin-card-badge--sv {
    background: rgba(255, 215, 0, 0.12);
    border: 1px solid rgba(255, 215, 0, 0.26);
    color: #d4a72c;
}

.skin-card-img {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
}

.skin-card-img img {
    width: 85%;
    height: 85%;
    object-fit: contain;
    opacity: 0;
    transition: opacity 0.2s ease;
}

.skin-card-img img.loaded {
    opacity: 1;
}

.skin-card-body {
    display: flex;
    flex-direction: column;
    gap: 3px;
    padding: 10px;
}

.skin-card-name {
    font-size: 0.813rem;
    font-weight: 600;
    color: var(--text);
    line-height: 1.3;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.skin-card-rarity {
    font-size: 0.625rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    font-weight: 500;
}

.skin-card-pricing {
    display: flex;
    align-items: baseline;
    gap: 6px;
    margin-top: 4px;
    padding-top: 6px;
    border-top: 1px solid var(--border);
}

.skin-card-price {
    font-size: 0.938rem;
    font-weight: 700;
    color: var(--text);
    font-variant-numeric: tabular-nums;
    letter-spacing: -0.01em;
}

.skin-card-mp-count {
    font-size: 0.563rem;
    color: var(--text-dim);
    white-space: nowrap;
}

/* ─── Finish Card Phase Tag ─── */
.finish-card-phase {
    font-size: 0.688rem;
    color: var(--text-muted);
}

/* ─── Item Detail Page ─── */
.item-hero {
    display: flex;
    flex-direction: column;
    gap: 16px;
    margin-bottom: 20px;
}

.item-image {
    width: 100%;
    aspect-ratio: 16/10;
    background: linear-gradient(135deg, var(--bg-card) 0%, rgba(26, 29, 36, 0.5) 100%);
    border-radius: var(--radius);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--text-dim);
    border-bottom: 3px solid var(--rarity-color, var(--border));
    overflow: hidden;
    position: relative;
    cursor: zoom-in;
}

.item-image img {
    width: 80%;
    height: 80%;
    object-fit: contain;
    opacity: 0;
    transition: opacity 0.3s ease;
}

.item-image img.loaded {
    opacity: 1;
}

/* ─── Inspect in Game ─── */
.inspect-btn {
    position: absolute;
    bottom: 10px;
    right: 10px;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    background: rgba(0, 0, 0, 0.6);
    color: #fff;
    border-radius: 6px;
    font-size: 0.78rem;
    text-decoration: none;
    transition: background 0.15s;
    z-index: 2;
    cursor: pointer;
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
}
.inspect-btn:hover {
    background: rgba(0, 0, 0, 0.85);
    color: #fff;
}
.inspect-btn svg {
    flex-shrink: 0;
    opacity: 0.85;
}

/* ─── Lightbox ─── */
.lightbox-overlay {
    position: fixed;
    inset: 0;
    z-index: 9999;
    background: rgba(0, 0, 0, 0.85);
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: zoom-out;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.2s ease, visibility 0.2s ease;
    -webkit-backdrop-filter: blur(8px);
    backdrop-filter: blur(8px);
}

.lightbox-overlay.active {
    opacity: 1;
    visibility: visible;
}

.lightbox-overlay img {
    max-width: 90vw;
    max-height: 90vh;
    object-fit: contain;
    border-radius: 6px;
    transform: scale(0.92);
    transition: transform 0.2s ease;
    user-select: none;
    -webkit-user-select: none;
}

.lightbox-overlay.active img {
    transform: scale(1);
}

.lightbox-close {
    position: absolute;
    top: 16px;
    right: 16px;
    width: 40px;
    height: 40px;
    border: none;
    background: rgba(255, 255, 255, 0.1);
    color: #fff;
    border-radius: 50%;
    font-size: 20px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background 0.15s ease;
    line-height: 1;
}

.lightbox-close:hover {
    background: rgba(255, 255, 255, 0.2);
}

.item-info {
    display: flex;
    flex-direction: column;
    gap: 10px;
    min-width: 0;
    flex: 1;
}

.item-name-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
}

.item-name {
    font-size: 1.375rem;
    font-weight: 700;
    color: var(--text);
    letter-spacing: -0.02em;
}

.item-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    align-items: center;
    align-self: stretch;
}

.item-badges .locale-toggles {
    margin-left: auto;
}

.item-rarity-badge {
    font-size: 0.625rem;
    font-weight: 600;
    padding: 4px 10px;
    border-radius: var(--radius-pill);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.item-badge-pill {
    font-size: 0.625rem;
    font-weight: 500;
    padding: 4px 10px;
    background: var(--bg-card);
    color: var(--text-muted);
    border-radius: var(--radius-pill);
    border: 1px solid var(--border);
}

.item-badge-pill--st {
    background: rgba(207, 106, 50, 0.1);
    border-color: rgba(207, 106, 50, 0.25);
    color: #cf6a32;
}

/* ─── Item Price Hero (inline marketplace offers) ─── */
.item-price-hero {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.hero-offer {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 10px;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
}

.hero-offer--best {
    border-color: rgba(74, 222, 128, 0.25);
    background: rgba(74, 222, 128, 0.04);
}

.hero-offer-mp {
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--text);
    min-width: 0;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.hero-offer-price {
    font-size: 0.938rem;
    font-weight: 700;
    color: var(--text);
    font-variant-numeric: tabular-nums;
    white-space: nowrap;
    margin-left: auto;
}

.hero-offer--best .hero-offer-price {
    color: var(--online);
}

.hero-offer-save {
    font-size: 0.563rem;
    font-weight: 700;
    padding: 2px 5px;
    background: rgba(74, 222, 128, 0.12);
    color: var(--online);
    border-radius: var(--radius-pill);
    white-space: nowrap;
}

.hero-offer-link {
    font-size: 0.688rem;
    font-weight: 600;
    color: var(--text-muted);
    padding: 4px 8px;
    background: var(--bg-card-hover);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    cursor: pointer;
    transition: all 0.15s;
    white-space: nowrap;
    flex-shrink: 0;
}

.hero-offer-link:hover {
    color: var(--text);
    border-color: var(--text-muted);
}

.hero-offer--best .hero-offer-link {
    background: rgba(74, 222, 128, 0.1);
    border-color: rgba(74, 222, 128, 0.25);
    color: var(--online);
}

.hero-offer--best .hero-offer-link:hover {
    background: var(--online);
    color: var(--bg);
}

.hero-offer-more {
    font-size: 0.688rem;
    font-weight: 500;
    color: var(--text-dim);
    text-decoration: none;
    text-align: center;
    padding: 4px;
    transition: color 0.15s;
}

.hero-offer-more:hover {
    color: var(--text-muted);
}

/* Float Range */
.float-range {
    margin-top: 2px;
}

.float-range-label {
    font-size: 0.688rem;
    color: var(--text-dim);
    margin-bottom: 4px;
}

.float-range-bar {
    height: 4px;
    background: var(--bg-card);
    border-radius: 2px;
    position: relative;
    overflow: hidden;
}

.float-range-fill {
    position: absolute;
    top: 0;
    height: 100%;
    background: var(--text-muted);
    border-radius: 2px;
}

.float-range-values {
    display: flex;
    justify-content: space-between;
    margin-top: 2px;
    font-size: 0.625rem;
    color: var(--text-dim);
}

/* ─── Filter Bar ─── */
.filter-bar {
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin-bottom: 14px;
}

.filter-group {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.filter-group-label {
    font-size: 0.625rem;
    font-weight: 600;
    color: var(--text-dim);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    flex-shrink: 0;
}

.filter-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
}

.filter-chip {
    padding: 5px 10px;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius-pill);
    color: var(--text-muted);
    font-size: 0.688rem;
    font-weight: 500;
    font-family: inherit;
    cursor: pointer;
    transition: all 0.15s ease;
    white-space: nowrap;
    text-decoration: none;
    flex-shrink: 0;
}

.filter-chip:hover {
    background: var(--bg-card-hover);
    color: var(--text);
}

.filter-chip.active {
    background: var(--bg-card-hover);
    border-color: var(--text-muted);
    color: var(--text);
}


/* Filter chip: full name on desktop, short on mobile */
.filter-short { display: none; }

/* Mobile: horizontal scroll for filter chips */
@media (max-width: 640px) {
    .filter-full { display: none; }
    .filter-short { display: inline; }

    .filter-group {
        flex-direction: row;
        align-items: center;
        gap: 8px;
    }

    .filter-chips {
        flex-wrap: nowrap;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: none;
        padding-bottom: 2px;
    }

    .filter-chips::-webkit-scrollbar {
        display: none;
    }
}

/* ─── Category Toolbar ─── */
.category-toolbar {
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin-bottom: 12px;
}

.category-count {
    font-size: 0.75rem;
    color: var(--text-dim);
}

.category-filter {
    position: relative;
    display: flex;
    align-items: center;
}

.category-filter-icon {
    position: absolute;
    left: 10px;
    color: var(--text-dim);
    pointer-events: none;
}

.category-filter-input {
    padding-left: 30px;
}

/* ─── Toolbar Row (sort left, locale right) ─── */
.toolbar-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
}

/* ─── Sort Controls ─── */
.sort-controls {
    display: flex;
    gap: 4px;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
}

.sort-controls::-webkit-scrollbar {
    display: none;
}

.sort-btn {
    padding: 5px 10px;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius-pill);
    color: var(--text-dim);
    font-size: 0.688rem;
    font-weight: 500;
    font-family: inherit;
    cursor: pointer;
    transition: all 0.15s ease;
    white-space: nowrap;
    flex-shrink: 0;
    touch-action: manipulation;
    -webkit-tap-highlight-color: transparent;
}

.sort-btn:hover {
    color: var(--text-muted);
    background: var(--bg-card-hover);
}

.sort-btn.active {
    background: var(--bg-card-hover);
    border-color: var(--text-muted);
    color: var(--text);
}

/* ─── Finish Gallery (Model Page) ─── */
.finish-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 8px;
    margin-bottom: 24px;
}

/* finish-card now reuses skin-card classes for consistency */
.finish-card {
    background: var(--bg-card);
    border-radius: var(--radius);
    text-decoration: none;
    display: flex;
    flex-direction: column;
    transition: all 0.2s ease;
    border: 1px solid transparent;
    overflow: hidden;
}

.finish-card:hover {
    background: var(--bg-card-hover);
    border-color: var(--border);
}

/* ─── Finish Selector (Finish Page) ─── */
.finish-selector {
    margin-bottom: 14px;
}

.finish-selector-label {
    display: block;
    font-size: 0.688rem;
    font-weight: 600;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    margin-bottom: 6px;
}

.finish-selector-list {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
}

@media (max-width: 640px) {
    .finish-selector-list {
        flex-wrap: nowrap;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: none;
        padding-bottom: 2px;
    }

    .finish-selector-list::-webkit-scrollbar {
        display: none;
    }
}

.finish-selector-pill {
    padding: 5px 10px;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    color: var(--text-muted);
    font-size: 0.688rem;
    font-weight: 500;
    text-decoration: none;
    white-space: nowrap;
    transition: all 0.15s ease;
}

.finish-selector-pill:hover {
    background: var(--bg-card-hover);
    color: var(--text);
}

.finish-selector-pill.active {
    background: var(--bg-card-hover);
    border-color: var(--text-muted);
    color: var(--text);
}

.finish-selector--phases {
    margin-top: -6px;
    padding-left: 12px;
    border-left: 2px solid var(--border);
}

.finish-selector-pill--phase {
    font-size: 0.625rem;
    padding: 4px 8px;
}

/* ─── Wear Selector ─── */
.wear-selector,
.stattrak-selector,
.color-selector {
    margin-bottom: 14px;
}

.color-pills {
    display: flex;
    gap: 4px;
    flex-wrap: wrap;
    margin-top: 6px;
}

@media (max-width: 640px) {
    .color-pills,
    .wear-pills {
        flex-wrap: nowrap;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: none;
        padding-bottom: 2px;
    }

    .color-pills::-webkit-scrollbar,
    .wear-pills::-webkit-scrollbar {
        display: none;
    }
}

.wear-selector-label {
    display: block;
    font-size: 0.688rem;
    font-weight: 600;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    margin-bottom: 6px;
}

.wear-pills {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
}

.wear-pill {
    padding: 6px 10px;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--text-muted);
    font-size: 0.75rem;
    font-weight: 500;
    font-family: inherit;
    cursor: pointer;
    transition: all 0.15s ease;
    white-space: nowrap;
    text-decoration: none;
}

.wear-pill:hover {
    background: var(--bg-card-hover);
    color: var(--text);
}

.wear-pill.active {
    background: var(--bg-card-hover);
    border-color: var(--text-muted);
    color: var(--text);
}

.wear-pill-abbr {
    display: inline;
}

.wear-pill-full {
    display: none;
}

.wear-pill-price {
    font-size: 0.625rem;
    font-weight: 500;
    color: var(--text-dim);
    font-variant-numeric: tabular-nums;
    margin-left: 2px;
}

.wear-pill-price::before {
    content: '\00b7';
    margin-right: 2px;
}

.wear-pill.active .wear-pill-price {
    color: var(--text-muted);
}

.st-badge {
    font-size: 0.625rem;
    font-weight: 600;
    color: #cf6a32;
}

.wear-pill--st.active .st-badge {
    color: #e4853f;
}

.sv-badge {
    font-size: 0.625rem;
    font-weight: 600;
    color: #ffd700;
}

.wear-pill--sv.active .sv-badge {
    color: #ffe44d;
}

/* ─── Price Table ─── */
.price-section {
    margin-bottom: 24px;
}

.price-section-header {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    margin-bottom: 12px;
    gap: 8px;
}

.price-section-title {
    font-size: 1rem;
    font-weight: 700;
    color: var(--text);
}

.price-section-updated {
    font-size: 0.625rem;
    color: var(--text-dim);
    flex-shrink: 0;
}

.price-variant.hidden {
    display: none;
}

.price-list {
    display: flex;
    flex-direction: column;
    gap: 4px;
    margin-bottom: 8px;
}

.price-row {
    display: grid;
    grid-template-columns: auto 1fr auto auto;
    align-items: center;
    gap: 10px;
    padding: 10px 12px;
    background: var(--bg-card);
    border-radius: var(--radius-sm);
    border: 1px solid transparent;
    transition: all 0.15s ease;
}

.price-row:hover {
    border-color: var(--border);
    background: var(--bg-card-hover);
}

.price-row--best {
    border-color: rgba(74, 222, 128, 0.2);
    background: rgba(74, 222, 128, 0.04);
}

.price-row--best:hover {
    border-color: rgba(74, 222, 128, 0.35);
}

.price-row-rank {
    min-width: 52px;
}

.price-rank-num {
    font-size: 0.688rem;
    color: var(--text-dim);
    font-weight: 500;
}

.price-best-badge {
    font-size: 0.563rem;
    font-weight: 700;
    padding: 3px 8px;
    background: rgba(74, 222, 128, 0.15);
    color: var(--online);
    border-radius: var(--radius-pill);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    white-space: nowrap;
}

.price-row-info {
    display: flex;
    flex-direction: column;
    gap: 1px;
    min-width: 0;
}

.price-mp-name-row {
    display: flex;
    align-items: center;
}

.price-mp-name {
    font-size: 0.813rem;
    font-weight: 600;
    color: var(--text);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.price-mp-review {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 22px;
    height: 22px;
    margin-left: 2px;
    border-radius: 50%;
    color: var(--text-dim);
    opacity: 0.45;
    transition: opacity 0.15s, color 0.15s;
    text-decoration: none;
}

.price-mp-review:hover {
    opacity: 1;
    color: var(--accent, rgba(96,165,250,0.9));
}

.price-offers {
    font-size: 0.563rem;
    color: var(--text-dim);
}

.price-pinned-badge {
    font-size: 0.5rem;
    font-weight: 700;
    padding: 3px 8px;
    background: rgba(96, 165, 250, 0.12);
    color: rgba(96, 165, 250, 0.85);
    border-radius: var(--radius-pill);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    white-space: nowrap;
}

.price-steam-ref {
    margin-bottom: 12px;
}

.price-row--steam {
    border-color: rgba(96, 165, 250, 0.15);
    background: rgba(96, 165, 250, 0.03);
}

.price-row--steam:hover {
    border-color: rgba(96, 165, 250, 0.3);
}

.price-steam-markup {
    font-size: 0.5rem;
    font-weight: 700;
    color: #ef4444;
    white-space: nowrap;
}

.price-row-value {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 2px;
}

.price-amount {
    font-size: 0.875rem;
    font-weight: 700;
    color: var(--text);
    font-variant-numeric: tabular-nums;
    white-space: nowrap;
}

.price-row--best .price-amount {
    color: var(--online);
}

.price-save-tag {
    font-size: 0.5rem;
    font-weight: 700;
    color: var(--online);
    white-space: nowrap;
}

.price-save-tag--negative {
    color: var(--text-dim);
}

.price-row-action {
    flex-shrink: 0;
}

.price-cta {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 0.688rem;
    font-weight: 600;
    color: var(--text);
    text-decoration: none;
    padding: 6px 12px;
    background: var(--bg-card-hover);
    border-radius: var(--radius-sm);
    border: 1px solid var(--border);
    transition: all 0.15s;
    white-space: nowrap;
    cursor: pointer;
}

.price-cta:hover {
    background: var(--text);
    color: var(--bg);
    border-color: var(--text);
}

.price-row--best .price-cta {
    background: rgba(74, 222, 128, 0.15);
    border-color: rgba(74, 222, 128, 0.3);
    color: var(--online);
}

.price-row--best .price-cta:hover {
    background: var(--online);
    color: var(--bg);
    border-color: var(--online);
}

.price-cta--dim {
    color: var(--text-muted);
}

.price-cta--disabled,
.price-cta--disabled:hover {
    background: transparent;
    border-color: transparent;
    color: var(--text-dim);
    cursor: default;
}

.price-disclaimer {
    font-size: 0.625rem;
    color: var(--text-dim);
    margin-top: 8px;
}

.price-table-intro {
    font-size: 0.75rem;
    line-height: 1.5;
    color: var(--text-muted);
    margin: 4px 0 12px;
}

#allPrices .sort-controls {
    margin-bottom: 12px;
}

/* Mobile: compact price rows */
@media (max-width: 640px) {
    .price-row {
        grid-template-columns: 1fr auto auto;
        gap: 8px;
        padding: 8px 10px;
    }

    .price-row-rank {
        display: none;
    }

    .price-cta {
        padding: 5px 8px;
        font-size: 0.625rem;
    }
}

/* ─── Related Items ─── */
.related-section {
    margin-bottom: 24px;
}

.related-title {
    font-size: 1rem;
    font-weight: 600;
    color: var(--text);
    margin-bottom: 10px;
}

.related-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 8px;
}

/* ─── Locale Toggles ─── */
.locale-toggles {
    display: flex;
    gap: 4px;
    align-items: center;
}

.locale-toggle {
    display: inline-flex;
    align-items: center;
    gap: 2px;
    padding: 4px 8px;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius-pill);
    color: var(--text);
    font-size: 0.688rem;
    font-weight: 600;
    font-family: inherit;
    cursor: pointer;
    transition: all 0.15s ease;
    user-select: none;
}

.locale-toggle:hover {
    border-color: var(--text-muted);
    background: var(--bg-card-hover);
}

.locale-toggle-sep {
    color: var(--text-dim);
    font-weight: 400;
}

.locale-toggle-opt {
    transition: color 0.15s ease;
}

.locale-toggle-opt--dim {
    color: var(--text-dim);
}

/* ─── SEO Content Section (skins pages) ─── */
.skins-about {
    margin-top: 24px;
    padding-top: 20px;
    border-top: 1px solid var(--border);
}

.skins-about h2 {
    font-size: 1rem;
    font-weight: 600;
    color: var(--text);
    margin-bottom: 8px;
}

.skins-about p {
    font-size: 0.813rem;
    color: var(--text-muted);
    line-height: 1.6;
    margin-bottom: 10px;
}

/* ─── Skins Responsive: Tablet ─── */
@media (min-width: 640px) {
    .container--wide {
        max-width: 960px;
    }

    .hub-grid {
        grid-template-columns: repeat(4, 1fr);
    }

    .hub-grid--compact {
        grid-template-columns: repeat(3, 1fr);
    }

    .hub-grid--compact .cat-card-name {
        font-size: 0.813rem;
    }

    .finish-grid {
        grid-template-columns: repeat(3, 1fr);
    }

    .items-grid {
        grid-template-columns: repeat(3, 1fr);
    }

    .related-grid {
        grid-template-columns: repeat(4, 1fr);
    }

    .item-hero {
        flex-direction: row;
        gap: 24px;
    }

    .item-image {
        width: 55%;
        flex-shrink: 0;
    }

    .item-info {
        flex: 1;
    }

    .wear-pill-abbr {
        display: none;
    }

    .wear-pill-full {
        display: inline;
    }

    .game-grid {
        grid-template-columns: repeat(4, 1fr);
    }
}

/* ─── Skins Responsive: Desktop (sidebar visible) ─── */
@media (min-width: 1100px) {
    .container--wide {
        max-width: 1200px;
    }

    .sidebar-toggle {
        display: none;
    }

    .skins-layout--with-sidebar {
        flex-direction: row;
        gap: 20px;
    }

    .skins-layout--with-sidebar .sidebar {
        display: flex;
        position: sticky;
        top: 12px;
        width: 240px;
        flex-shrink: 0;
        max-width: none;
        height: calc(100vh - 24px);
        background: var(--bg);
        border-right: none;
        border: 1px solid var(--border);
        border-radius: var(--radius);
        z-index: 1;
        transform: none;
        transition: none;
    }

    .skins-layout--with-sidebar .sidebar .sidebar-header {
        display: none;
    }

    .finish-grid {
        grid-template-columns: repeat(4, 1fr);
    }

    .items-grid {
        grid-template-columns: repeat(3, 1fr);
    }

    .hub-grid--compact {
        grid-template-columns: repeat(5, 1fr);
    }
}

/* ─── Pagination ─── */
.pagination {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 4px;
    margin: 20px 0 8px;
}

.pagination-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 32px;
    height: 32px;
    padding: 0 8px;
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--text-muted);
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    text-decoration: none;
    transition: all 0.15s;
}

.pagination-btn:hover {
    color: var(--text);
    background: var(--bg-card-hover);
    border-color: var(--text-dim);
}

.pagination-current {
    color: var(--text);
    background: var(--bg-card-hover);
    border-color: var(--text-muted);
    cursor: default;
}

.pagination-dots {
    font-size: 0.75rem;
    color: var(--text-dim);
    padding: 0 4px;
}

/* ─── Scroll to top button ─── */
.scroll-top {
    position: fixed;
    bottom: 20px;
    right: 20px;
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: 50%;
    color: var(--text-muted);
    cursor: pointer;
    opacity: 0;
    visibility: hidden;
    transition: all 0.2s;
    z-index: 50;
}

.scroll-top.visible {
    opacity: 1;
    visibility: visible;
}

.scroll-top:hover {
    color: var(--text);
    background: var(--bg-card-hover);
    border-color: var(--text-dim);
}

/* Steam Workshop Downloader Tool */
.swd-tool {
    display: flex;
    gap: 8px;
    margin-bottom: 12px;
}

.swd-input-wrap {
    flex: 1;
    position: relative;
    display: flex;
    align-items: center;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    transition: border-color 0.15s;
}

.swd-input-wrap:focus-within {
    border-color: var(--text-dim);
}

.swd-input {
    flex: 1;
    background: transparent;
    border: none;
    outline: none;
    color: var(--text);
    font-size: 0.875rem;
    padding: 10px 12px;
    font-family: inherit;
    min-width: 0;
}

.swd-input::placeholder {
    color: var(--text-dim);
}

.swd-input-actions {
    display: flex;
    align-items: center;
    gap: 2px;
    padding-right: 6px;
    flex-shrink: 0;
}

.swd-btn-icon {
    background: none;
    border: none;
    color: var(--text-dim);
    cursor: pointer;
    padding: 6px;
    border-radius: 4px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: color 0.15s, background 0.15s;
}

.swd-btn-icon:hover {
    color: var(--text-muted);
    background: var(--bg);
}

.swd-btn-search {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 10px 18px;
    background: var(--text);
    color: var(--bg);
    border: none;
    border-radius: var(--radius-sm);
    font-size: 0.813rem;
    font-weight: 600;
    cursor: pointer;
    font-family: inherit;
    transition: opacity 0.15s;
    white-space: nowrap;
    flex-shrink: 0;
}

.swd-btn-search:hover {
    opacity: 0.85;
}

.swd-examples {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 6px;
    margin-bottom: 16px;
}

.swd-examples-label {
    font-size: 0.75rem;
    color: var(--text-dim);
}

.swd-example {
    font-size: 0.75rem;
    color: var(--text-muted);
    text-decoration: none;
    padding: 3px 10px;
    background: var(--bg-card);
    border-radius: var(--radius-pill);
    transition: background 0.15s, color 0.15s;
}

.swd-example:hover {
    background: var(--bg-card-hover);
    color: var(--text);
}

.swd-error {
    background: rgba(248, 113, 113, 0.08);
    border: 1px solid rgba(248, 113, 113, 0.2);
    border-radius: var(--radius-sm);
    padding: 10px 14px;
    font-size: 0.813rem;
    color: var(--offline);
    margin-bottom: 16px;
    line-height: 1.5;
}

.swd-loading {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 20px;
    font-size: 0.813rem;
    color: var(--text-dim);
    justify-content: center;
}

.swd-spinner {
    width: 18px;
    height: 18px;
    border: 2px solid var(--border);
    border-top-color: var(--text-muted);
    border-radius: 50%;
    animation: swd-spin 0.7s linear infinite;
}

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

/* Results container */
.swd-results {
    margin-bottom: 24px;
}

/* Item card */
.swd-card {
    display: flex;
    gap: 16px;
    background: var(--bg-card);
    border-radius: var(--radius);
    overflow: hidden;
    margin-bottom: 12px;
}

.swd-card-preview {
    flex-shrink: 0;
    width: 200px;
    min-height: 120px;
    background: var(--bg);
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}

.swd-card-preview img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.swd-card-body {
    flex: 1;
    padding: 14px 16px 14px 0;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.swd-card-title {
    font-size: 1rem;
    font-weight: 600;
    color: var(--text);
    margin: 0;
    line-height: 1.3;
}

.swd-card-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
}

.swd-tag {
    font-size: 0.688rem;
    color: var(--text-dim);
    background: var(--bg);
    padding: 2px 8px;
    border-radius: var(--radius-pill);
}

.swd-card-desc {
    font-size: 0.75rem;
    color: var(--text-muted);
    line-height: 1.5;
    margin: 0;
}

/* Stats grid */
.swd-stats {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1px;
    background: var(--border);
    border-radius: var(--radius);
    overflow: hidden;
    margin-bottom: 12px;
}

.swd-stat {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    padding: 12px 8px;
    background: var(--bg-card);
}

.swd-stat svg {
    color: var(--text-dim);
}

.swd-stat-val {
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--text);
}

.swd-stat-label {
    font-size: 0.688rem;
    color: var(--text-dim);
}

/* Download section */
.swd-download-section {
    background: var(--bg-card);
    border-radius: var(--radius);
    padding: 16px;
}

.swd-section-title {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--text);
    margin: 0 0 14px;
}

.swd-section-title svg {
    color: var(--text-dim);
}

.swd-option {
    margin-bottom: 14px;
}

.swd-option:last-child {
    margin-bottom: 0;
}

.swd-option-header {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 8px;
}

.swd-option-badge {
    font-size: 0.688rem;
    font-weight: 600;
    color: var(--text);
    background: var(--bg);
    padding: 2px 8px;
    border-radius: var(--radius-pill);
    flex-shrink: 0;
}

.swd-badge-green {
    color: var(--online);
    background: rgba(52, 211, 153, 0.1);
}

.swd-badge-dim {
    color: var(--text-dim);
}

.swd-option-desc {
    font-size: 0.75rem;
    color: var(--text-dim);
}

/* Command block */
.swd-cmd-block {
    display: flex;
    align-items: center;
    gap: 8px;
    background: var(--bg);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: 8px 10px;
}

.swd-cmd-text {
    flex: 1;
    font-size: 0.75rem;
    font-family: 'SF Mono', 'Cascadia Code', 'Consolas', monospace;
    color: var(--text-muted);
    word-break: break-all;
    line-height: 1.5;
}

.swd-copy {
    background: none;
    border: none;
    color: var(--text-dim);
    cursor: pointer;
    padding: 4px;
    border-radius: 4px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: color 0.15s;
    flex-shrink: 0;
}

.swd-copy:hover {
    color: var(--text);
}

.swd-copy .check-icon {
    color: var(--online);
}

/* Action buttons */
.swd-btn-download,
.swd-btn-steam,
.swd-btn-link {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 16px;
    border-radius: var(--radius-sm);
    font-size: 0.813rem;
    font-weight: 500;
    text-decoration: none;
    transition: opacity 0.15s;
    font-family: inherit;
}

.swd-btn-download {
    background: var(--online);
    color: #000;
}

.swd-btn-steam {
    background: var(--text);
    color: var(--bg);
}

.swd-btn-link {
    background: var(--bg);
    color: var(--text-muted);
    border: 1px solid var(--border);
}

.swd-btn-download:hover,
.swd-btn-steam:hover,
.swd-btn-link:hover {
    opacity: 0.85;
}

.swd-option-direct {
    background: rgba(52, 211, 153, 0.04);
    border: 1px solid rgba(52, 211, 153, 0.15);
    border-radius: var(--radius-sm);
    padding: 12px;
    margin-bottom: 14px;
}

@media (max-width: 600px) {
    .swd-tool {
        flex-direction: column;
    }

    .swd-btn-search {
        justify-content: center;
    }

    .swd-card {
        flex-direction: column;
    }

    .swd-card-preview {
        width: 100%;
        height: 180px;
    }

    .swd-card-body {
        padding: 12px 14px;
    }

    .swd-stats {
        grid-template-columns: repeat(2, 1fr);
    }

    .swd-option-header {
        flex-direction: column;
        align-items: flex-start;
        gap: 4px;
    }

    .swd-cmd-text {
        font-size: 0.688rem;
    }
}

/* ═══════════════════════════════════════════════════════
   STEAM CHARTS TOOL
   ═══════════════════════════════════════════════════════ */

/* Overview stat cards */
.sc-overview {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 10px;
    margin-bottom: 16px;
}

.sc-stat-card {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: 14px 16px;
    text-align: center;
}

.sc-stat-value {
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--text);
    font-variant-numeric: tabular-nums;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
}

.sc-stat-label {
    font-size: 0.688rem;
    color: var(--text-dim);
    margin-top: 2px;
}

.sc-stat-live .sc-stat-value {
    color: var(--online);
    font-size: 0.875rem;
    font-weight: 600;
}

/* Search bar */
.sc-tool {
    display: flex;
    gap: 8px;
    margin-bottom: 12px;
}

.sc-input-wrap {
    flex: 1;
    position: relative;
    display: flex;
    align-items: center;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    transition: border-color 0.15s;
}

.sc-input-wrap:focus-within {
    border-color: var(--text-dim);
}

.sc-input {
    flex: 1;
    background: transparent;
    border: none;
    outline: none;
    color: var(--text);
    font-size: 0.875rem;
    padding: 10px 12px;
    font-family: inherit;
    min-width: 0;
}

.sc-input::placeholder {
    color: var(--text-dim);
}

.sc-input-actions {
    display: flex;
    align-items: center;
    gap: 2px;
    padding-right: 6px;
    flex-shrink: 0;
}

.sc-btn-icon {
    background: none;
    border: none;
    color: var(--text-dim);
    cursor: pointer;
    padding: 6px;
    border-radius: 4px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: color 0.15s, background 0.15s;
}

.sc-btn-icon:hover {
    color: var(--text-muted);
    background: var(--bg);
}

.sc-btn-search {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 10px 18px;
    background: var(--text);
    color: var(--bg);
    border: none;
    border-radius: var(--radius-sm);
    font-size: 0.813rem;
    font-weight: 600;
    cursor: pointer;
    font-family: inherit;
    transition: opacity 0.15s;
    white-space: nowrap;
    flex-shrink: 0;
}

.sc-btn-search:hover {
    opacity: 0.85;
}

/* Quick search chips */
.sc-quick-links {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 6px;
    margin-bottom: 20px;
}

.sc-quick-label {
    font-size: 0.75rem;
    color: var(--text-dim);
}

.sc-quick {
    font-size: 0.75rem;
    color: var(--text-muted);
    text-decoration: none;
    padding: 3px 10px;
    background: var(--bg-card);
    border-radius: var(--radius-pill);
    transition: background 0.15s, color 0.15s;
    cursor: pointer;
}

.sc-quick:hover {
    background: var(--bg-card-hover);
    color: var(--text);
}

/* Section header */
.sc-section-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 10px;
}

.sc-section-title {
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--text);
    display: flex;
    align-items: center;
    gap: 6px;
}

.sc-meta {
    font-size: 0.688rem;
    color: var(--text-dim);
    display: flex;
    align-items: center;
    gap: 4px;
}

/* Chart table */
.sc-table-wrap {
    border-radius: var(--radius);
    overflow: hidden;
    border: 1px solid var(--border);
    margin-bottom: 12px;
}

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

.sc-table th {
    text-align: left;
    font-size: 0.688rem;
    font-weight: 600;
    color: var(--text-dim);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    padding: 8px 12px;
    background: var(--bg-card);
    border-bottom: 1px solid var(--border);
}

.sc-table th:last-child {
    text-align: right;
}

.sc-row td {
    padding: 8px 12px;
    border-bottom: 1px solid var(--border);
    background: var(--bg-card);
    transition: background 0.1s;
}

.sc-row:last-child td {
    border-bottom: none;
}

.sc-row:hover td {
    background: var(--bg-card-hover);
}

.sc-rank {
    width: 32px;
    font-size: 0.75rem;
    color: var(--text-dim);
    font-weight: 600;
    text-align: center !important;
}

.sc-game-name {
    font-size: 0.813rem;
    display: flex;
    align-items: center;
    gap: 8px;
}

.sc-game-icon {
    width: 32px;
    height: 12px;
    object-fit: cover;
    border-radius: 2px;
    flex-shrink: 0;
}

.sc-game-name a {
    color: var(--text);
    text-decoration: none;
    transition: color 0.15s;
}

.sc-game-name a:hover {
    color: var(--text-muted);
}

.sc-count {
    text-align: right;
    font-size: 0.813rem;
    font-weight: 600;
    color: var(--online);
    font-variant-numeric: tabular-nums;
    white-space: nowrap;
}

.sc-shimmer {
    display: inline-block;
    width: 52px;
    height: 12px;
    background: var(--bg-card-hover);
    border-radius: 4px;
    animation: scPulse 1.2s ease-in-out infinite;
}

@keyframes scPulse {
    0%, 100% { opacity: 0.35; }
    50% { opacity: 0.9; }
}

/* Search results */
.sc-search-wrap {
    margin-bottom: 20px;
}

.sc-search-title {
    font-size: 0.813rem;
    font-weight: 600;
    color: var(--text);
    margin-bottom: 8px;
    display: flex;
    align-items: center;
    gap: 6px;
}

.sc-thumb-cell {
    width: 52px;
    padding-right: 0 !important;
}

.sc-thumb {
    width: 48px;
    height: 18px;
    object-fit: cover;
    border-radius: 3px;
    display: block;
}

.sc-status {
    text-align: center;
    font-size: 0.75rem;
    color: var(--text-dim);
    padding: 20px 12px !important;
    background: var(--bg-card);
}

/* Footer meta */
.sc-footer-meta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    font-size: 0.688rem;
    color: var(--text-dim);
    margin-bottom: 24px;
    padding: 0 2px;
}

.sc-live {
    display: flex;
    align-items: center;
    gap: 4px;
}

.sc-dot {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--online);
    animation: scBlink 2s ease-in-out infinite;
}

@keyframes scBlink {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.3; }
}

/* Mobile */
@media (max-width: 600px) {
    .sc-overview {
        grid-template-columns: 1fr 1fr;
        gap: 8px;
    }

    .sc-stat-card:last-child {
        grid-column: 1 / -1;
    }

    .sc-stat-value {
        font-size: 1rem;
    }

    .sc-stat-card {
        padding: 10px 12px;
    }

    .sc-tool {
        flex-direction: column;
    }

    .sc-btn-search {
        justify-content: center;
    }

    .sc-section-header {
        flex-direction: column;
        align-items: flex-start;
        gap: 4px;
    }

    .sc-rank {
        width: 24px;
        font-size: 0.688rem;
    }

    .sc-row td {
        padding: 7px 8px;
    }

    .sc-thumb {
        width: 36px;
        height: 14px;
    }

    .sc-thumb-cell {
        width: 42px;
    }

    .sc-footer-meta {
        flex-direction: column;
        gap: 4px;
        align-items: flex-start;
    }

    .sc-game-name {
        font-size: 0.75rem;
        gap: 6px;
    }

    .sc-game-icon {
        width: 26px;
        height: 10px;
    }

    .sc-count {
        font-size: 0.75rem;
    }
}

/* ═══════════════════════════════════════════════
   Steam Sales Tool
   ═══════════════════════════════════════════════ */

/* Hero block: countdown */
.ss-hero {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 24px 20px;
    text-align: center;
    margin-bottom: 16px;
}

.ss-hero--active {
    border-color: var(--online);
    box-shadow: 0 0 0 1px var(--online), 0 0 20px rgba(74, 222, 128, 0.08);
}

.ss-hero-status {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    font-size: 0.75rem;
    color: var(--text-dim);
    margin-bottom: 8px;
}

.ss-hero--active .ss-hero-status {
    color: var(--online);
    font-weight: 600;
}

.ss-status-dot {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--text-dim);
}

.ss-hero--active .ss-status-dot {
    background: var(--online);
    animation: scBlink 2s ease-in-out infinite;
}

.ss-hero-name {
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--text);
    margin-bottom: 16px;
}

/* Countdown digits */
.ss-countdown {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    margin-bottom: 14px;
}

.ss-countdown-unit {
    display: flex;
    flex-direction: column;
    align-items: center;
    min-width: 48px;
}

.ss-countdown-val {
    font-size: 1.75rem;
    font-weight: 700;
    color: var(--text);
    font-variant-numeric: tabular-nums;
    line-height: 1;
}

.ss-hero--active .ss-countdown-val {
    color: var(--online);
}

.ss-countdown-label {
    font-size: 0.625rem;
    color: var(--text-dim);
    margin-top: 4px;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.ss-countdown-sep {
    font-size: 1.25rem;
    color: var(--text-dim);
    font-weight: 700;
    align-self: flex-start;
    margin-top: 4px;
}

.ss-hero-dates {
    font-size: 0.75rem;
    color: var(--text-muted);
}

/* Quick stats */
.ss-stats {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 10px;
    margin-bottom: 20px;
}

.ss-stat-card {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: 12px 14px;
    text-align: center;
}

.ss-stat-val {
    font-size: 1.125rem;
    font-weight: 700;
    color: var(--text);
    font-variant-numeric: tabular-nums;
}

.ss-stat-lbl {
    font-size: 0.625rem;
    color: var(--text-dim);
    margin-top: 2px;
}

/* Year toggle */
.ss-year-toggle {
    display: flex;
    gap: 6px;
    margin-bottom: 14px;
}

.ss-year-btn {
    padding: 6px 16px;
    font-size: 0.813rem;
    font-weight: 600;
    font-family: inherit;
    background: var(--bg-card);
    color: var(--text-muted);
    border: 1px solid var(--border);
    border-radius: var(--radius-pill);
    cursor: pointer;
    transition: all 0.15s;
}

.ss-year-btn:hover {
    background: var(--bg-card-hover);
    color: var(--text);
}

.ss-year-btn--active {
    background: var(--text);
    color: var(--bg);
    border-color: var(--text);
}

.ss-year-btn--active:hover {
    opacity: 0.85;
    background: var(--text);
    color: var(--bg);
}

/* Sale calendar cards */
.ss-calendar {
    display: flex;
    flex-direction: column;
    gap: 8px;
    margin-bottom: 28px;
}

.ss-sale-card {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: 14px 16px;
    transition: background 0.1s;
}

.ss-sale-card:hover {
    background: var(--bg-card-hover);
}

.ss-sale-card--active {
    border-color: var(--online);
}

.ss-sale-card--past {
    opacity: 0.55;
}

.ss-sale-icon {
    flex-shrink: 0;
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--bg);
    border-radius: var(--radius-sm);
    color: var(--text-muted);
}

.ss-sale-card--active .ss-sale-icon {
    color: var(--online);
}

.ss-sale-body {
    flex: 1;
    min-width: 0;
}

.ss-sale-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    margin-bottom: 4px;
    flex-wrap: wrap;
}

.ss-sale-name {
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--text);
    display: flex;
    align-items: center;
    gap: 6px;
}

.ss-major-tag {
    font-size: 0.563rem;
    font-weight: 700;
    color: var(--slow);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    padding: 1px 5px;
    background: rgba(251, 191, 36, 0.1);
    border-radius: 3px;
}

.ss-badge {
    font-size: 0.625rem;
    font-weight: 600;
    padding: 2px 8px;
    border-radius: var(--radius-pill);
    white-space: nowrap;
    flex-shrink: 0;
}

.ss-badge--active {
    color: var(--online);
    background: rgba(74, 222, 128, 0.1);
}

.ss-badge--upcoming {
    color: var(--text-muted);
    background: var(--bg);
}

.ss-badge--past {
    color: var(--text-dim);
    background: var(--bg);
}

.ss-sale-desc {
    font-size: 0.75rem;
    color: var(--text-dim);
    margin-bottom: 6px;
}

.ss-sale-meta {
    display: flex;
    align-items: center;
    gap: 12px;
    font-size: 0.688rem;
    color: var(--text-muted);
}

.ss-sale-dates {
    font-weight: 600;
}

.ss-sale-dur {
    color: var(--text-dim);
}

/* Mobile: steam sales */
@media (max-width: 600px) {
    .ss-hero {
        padding: 20px 16px;
    }

    .ss-hero-name {
        font-size: 1.05rem;
    }

    .ss-countdown-val {
        font-size: 1.35rem;
    }

    .ss-countdown-unit {
        min-width: 40px;
    }

    .ss-countdown-sep {
        font-size: 1rem;
    }

    .ss-stats {
        grid-template-columns: 1fr 1fr;
        gap: 8px;
    }

    .ss-stat-card:last-child {
        grid-column: 1 / -1;
    }

    .ss-stat-val {
        font-size: 0.938rem;
    }

    .ss-stat-card {
        padding: 10px 10px;
    }

    .ss-sale-card {
        padding: 12px 12px;
        gap: 10px;
    }

    .ss-sale-icon {
        width: 32px;
        height: 32px;
    }

    .ss-sale-icon svg {
        width: 16px;
        height: 16px;
    }

    .ss-sale-name {
        font-size: 0.813rem;
    }

    .ss-sale-top {
        gap: 4px;
    }

    .ss-sale-meta {
        flex-wrap: wrap;
        gap: 6px;
    }
}

/* ═══════════════════════════════════════════════════════
   Steam Price History Tool
   ═══════════════════════════════════════════════════════ */

/* Search bar */
.sph-tool {
    display: flex;
    gap: 8px;
    margin-bottom: 12px;
}

.sph-input-wrap {
    flex: 1;
    position: relative;
    display: flex;
    align-items: center;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    transition: border-color 0.15s;
}

.sph-input-wrap:focus-within {
    border-color: var(--text-dim);
}

.sph-input {
    flex: 1;
    background: transparent;
    border: none;
    outline: none;
    color: var(--text);
    font-size: 0.875rem;
    padding: 10px 12px;
    font-family: inherit;
    min-width: 0;
}

.sph-input::placeholder {
    color: var(--text-dim);
}

.sph-input-actions {
    display: flex;
    align-items: center;
    gap: 2px;
    padding-right: 6px;
    flex-shrink: 0;
}

.sph-btn-icon {
    background: none;
    border: none;
    color: var(--text-dim);
    cursor: pointer;
    padding: 6px;
    border-radius: 4px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: color 0.15s, background 0.15s;
}

.sph-btn-icon:hover {
    color: var(--text-muted);
    background: var(--bg);
}

.sph-btn-search {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 10px 18px;
    background: var(--text);
    color: var(--bg);
    border: none;
    border-radius: var(--radius-sm);
    font-size: 0.813rem;
    font-weight: 600;
    cursor: pointer;
    font-family: inherit;
    transition: opacity 0.15s;
    white-space: nowrap;
    flex-shrink: 0;
}

.sph-btn-search:hover {
    opacity: 0.85;
}

/* Dropdown */
.sph-dropdown {
    position: absolute;
    top: calc(100% + 4px);
    left: 0;
    right: 0;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    max-height: 320px;
    overflow-y: auto;
    z-index: 50;
    box-shadow: 0 8px 24px rgba(0,0,0,0.4);
}

.sph-dd-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 12px;
    cursor: pointer;
    transition: background 0.1s;
}

.sph-dd-item:hover {
    background: var(--bg-card-hover);
}

.sph-dd-img {
    width: 80px;
    height: 30px;
    object-fit: cover;
    border-radius: 4px;
    flex-shrink: 0;
}

.sph-dd-img-placeholder {
    width: 80px;
    height: 30px;
    background: var(--border);
    border-radius: 4px;
    flex-shrink: 0;
}

.sph-dd-name {
    font-size: 0.813rem;
    color: var(--text);
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.sph-dd-empty {
    padding: 16px 12px;
    text-align: center;
    font-size: 0.813rem;
    color: var(--text-dim);
}

/* Quick links */
.sph-quick-links {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 6px;
    margin-bottom: 20px;
}

.sph-quick-label {
    font-size: 0.75rem;
    color: var(--text-dim);
}

.sph-quick {
    font-size: 0.75rem;
    color: var(--text-muted);
    text-decoration: none;
    padding: 3px 10px;
    background: var(--bg-card);
    border-radius: var(--radius-pill);
    transition: background 0.15s, color 0.15s;
    cursor: pointer;
}

.sph-quick:hover {
    background: var(--bg-card-hover);
    color: var(--text);
}

/* Error & loading */
.sph-error {
    background: rgba(248,113,113,0.08);
    border: 1px solid rgba(248,113,113,0.2);
    border-radius: var(--radius-sm);
    padding: 12px 16px;
    color: #f87171;
    font-size: 0.813rem;
    margin-bottom: 16px;
}

.sph-loading {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    padding: 32px 16px;
    color: var(--text-dim);
    font-size: 0.813rem;
}

.sph-spinner {
    width: 20px;
    height: 20px;
    border: 2px solid var(--border);
    border-top-color: var(--text);
    border-radius: 50%;
    animation: sph-spin 0.6s linear infinite;
}

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

/* ── Game card ── */
.sph-game-card {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    overflow: hidden;
    margin-bottom: 12px;
}

.sph-game-header {
    width: 100%;
    aspect-ratio: 460 / 215;
    overflow: hidden;
    background: var(--border);
}

.sph-game-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.sph-game-info {
    padding: 14px 16px;
}

.sph-game-title-row {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    margin-bottom: 6px;
}

.sph-game-name {
    font-size: 1.125rem;
    font-weight: 700;
    color: var(--text);
    flex: 1;
    min-width: 0;
    margin: 0;
}

.sph-store-link {
    color: var(--text-dim);
    padding: 4px;
    border-radius: 4px;
    flex-shrink: 0;
    transition: color 0.15s;
    margin-top: 3px;
}

.sph-store-link:hover {
    color: var(--text);
}

.sph-game-desc {
    font-size: 0.813rem;
    color: var(--text-muted);
    line-height: 1.5;
    margin-bottom: 10px;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.sph-game-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-bottom: 8px;
    font-size: 0.75rem;
    color: var(--text-dim);
}

.sph-game-meta span {
    display: flex;
    align-items: center;
    gap: 3px;
}

.sph-mc {
    font-weight: 700;
    padding: 1px 6px;
    border-radius: 4px;
    font-size: 0.75rem;
}

.sph-mc-good {
    background: rgba(74,222,128,0.15);
    color: #4ade80;
}

.sph-mc-mixed {
    background: rgba(251,191,36,0.15);
    color: #fbbf24;
}

.sph-mc-bad {
    background: rgba(248,113,113,0.15);
    color: #f87171;
}

.sph-players {
    color: var(--online);
}

.sph-game-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
    margin-bottom: 4px;
}

.sph-tag {
    font-size: 0.688rem;
    color: var(--text-dim);
    padding: 2px 8px;
    background: var(--bg);
    border-radius: var(--radius-pill);
}

.sph-game-platforms {
    display: flex;
    gap: 6px;
    font-size: 0.75rem;
    margin-top: 4px;
}

/* ── Price hero ── */
.sph-price-hero {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 16px 20px;
    margin-bottom: 12px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}

.sph-price-hero--sale {
    border-color: rgba(74,222,128,0.25);
    background: linear-gradient(135deg, var(--bg-card) 0%, rgba(74,222,128,0.04) 100%);
}

.sph-price-main {
    display: flex;
    align-items: center;
    gap: 12px;
}

.sph-discount-badge {
    background: #4ade80;
    color: #0f1115;
    font-size: 1.125rem;
    font-weight: 800;
    padding: 6px 12px;
    border-radius: 6px;
    white-space: nowrap;
}

.sph-price-nums {
    display: flex;
    flex-direction: column;
}

.sph-price-old {
    font-size: 0.75rem;
    color: var(--text-dim);
    text-decoration: line-through;
}

.sph-price-current {
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--text);
}

.sph-price-badge {
    text-align: center;
}

.sph-price-label {
    display: block;
    font-size: 0.688rem;
    color: var(--text-dim);
    margin-bottom: 4px;
}

.sph-price-value {
    font-size: 1.125rem;
    font-weight: 700;
    color: var(--text);
}

.sph-free .sph-price-value {
    color: var(--online);
}

.sph-deal-badge {
    font-size: 0.813rem;
    font-weight: 600;
    display: flex;
    align-items: center;
    gap: 4px;
    white-space: nowrap;
}

/* ── Regional prices table ── */
.sph-section {
    margin-bottom: 12px;
}

.sph-section-header {
    margin-bottom: 8px;
}

.sph-section-title {
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--text);
    display: flex;
    align-items: center;
    gap: 6px;
    margin: 0;
}

.sph-table-wrap {
    border-radius: var(--radius);
    overflow: hidden;
    border: 1px solid var(--border);
}

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

.sph-table th {
    text-align: left;
    font-size: 0.688rem;
    font-weight: 600;
    color: var(--text-dim);
    text-transform: uppercase;
    padding: 8px 12px;
    background: var(--bg-card);
    border-bottom: 1px solid var(--border);
}

.sph-table th:last-child {
    text-align: right;
}

.sph-tbl-row {
    border-bottom: 1px solid var(--border);
    transition: background 0.1s;
}

.sph-tbl-row:last-child {
    border-bottom: none;
}

.sph-tbl-row:hover {
    background: var(--bg-card);
}

.sph-tbl-region {
    padding: 9px 12px;
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 0.813rem;
}

.sph-tbl-flag {
    font-size: 1rem;
    flex-shrink: 0;
}

.sph-tbl-name {
    color: var(--text);
}

.sph-tbl-price {
    padding: 9px 12px;
    font-size: 0.813rem;
    color: var(--text);
    font-weight: 600;
    font-variant-numeric: tabular-nums;
    white-space: nowrap;
}

.sph-tbl-sale {
    color: var(--online);
}

.sph-tbl-old {
    font-size: 0.688rem;
    color: var(--text-dim);
    text-decoration: line-through;
    font-weight: 400;
}

.sph-tbl-disc {
    padding: 9px 12px;
    text-align: right;
    font-size: 0.813rem;
}

.sph-tbl-discount {
    background: rgba(74,222,128,0.12);
    color: #4ade80;
    padding: 2px 8px;
    border-radius: var(--radius-pill);
    font-weight: 600;
    font-size: 0.75rem;
}

.sph-tbl-no-disc {
    color: var(--text-dim);
}

.sph-tbl-usd {
    padding: 9px 12px;
    font-size: 0.813rem;
    color: var(--text-muted);
    font-variant-numeric: tabular-nums;
    white-space: nowrap;
    text-align: right;
}

.sph-tbl-cheapest {
    background: rgba(74,222,128,0.06);
}

.sph-tbl-cheapest .sph-tbl-usd {
    color: var(--online);
    font-weight: 600;
}

.sph-disclaimer {
    font-size: 0.688rem;
    color: var(--text-dim);
    margin-top: 8px;
    display: flex;
    align-items: flex-start;
    gap: 4px;
    line-height: 1.4;
}

.sph-disclaimer svg {
    margin-top: 1px;
    flex-shrink: 0;
}

/* ── Sale card ── */
.sph-sale-card {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 14px 16px;
    display: flex;
    gap: 12px;
    align-items: flex-start;
    margin-bottom: 12px;
}

.sph-sale-card--active {
    border-color: rgba(248,113,113,0.3);
    background: linear-gradient(135deg, var(--bg-card) 0%, rgba(248,113,113,0.04) 100%);
}

.sph-sale-icon {
    color: var(--text-dim);
    flex-shrink: 0;
    margin-top: 2px;
}

.sph-sale-body {
    flex: 1;
    min-width: 0;
}

.sph-sale-name {
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--text);
    margin-bottom: 2px;
}

.sph-sale-major {
    font-size: 0.625rem;
    background: rgba(251,191,36,0.15);
    color: #fbbf24;
    padding: 1px 6px;
    border-radius: var(--radius-pill);
    font-weight: 600;
    vertical-align: middle;
}

.sph-sale-status {
    font-size: 0.813rem;
    color: var(--text-muted);
    margin-bottom: 2px;
}

.sph-sale-live {
    color: #f87171;
    font-weight: 600;
}

.sph-sale-tip {
    font-size: 0.75rem;
    color: var(--text-dim);
}

/* ── Buy advice ── */
.sph-advice {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 14px 16px;
    display: flex;
    gap: 12px;
    align-items: flex-start;
    margin-bottom: 12px;
}

.sph-advice-icon {
    font-size: 1.25rem;
    flex-shrink: 0;
    line-height: 1;
}

.sph-advice-body {
    flex: 1;
    min-width: 0;
}

.sph-advice-body strong {
    font-size: 0.875rem;
    display: block;
    margin-bottom: 2px;
}

.sph-advice-body p {
    font-size: 0.813rem;
    color: var(--text-muted);
    margin: 0;
    line-height: 1.5;
}

/* ── Mobile responsive ── */
@media (max-width: 600px) {
    .sph-tool {
        flex-direction: column;
    }

    .sph-btn-search {
        justify-content: center;
        padding: 12px 18px;
    }

    .sph-price-hero {
        flex-direction: column;
        align-items: flex-start;
        gap: 8px;
        padding: 14px 16px;
    }

    .sph-discount-badge {
        font-size: 1rem;
        padding: 4px 10px;
    }

    .sph-price-current {
        font-size: 1.125rem;
    }

    .sph-game-name {
        font-size: 1rem;
    }

    .sph-game-desc {
        -webkit-line-clamp: 2;
    }

    .sph-tbl-region {
        padding: 8px 10px;
    }

    .sph-tbl-price {
        padding: 8px 10px;
    }

    .sph-tbl-disc {
        padding: 8px 10px;
    }

    .sph-tbl-usd {
        padding: 8px 8px;
        font-size: 0.75rem;
    }

    .sph-tbl-name {
        max-width: 80px;
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
    }
}

/* ═══════════════════════════════════════════════════════════════
   Deadlock section
   Reuses the site tokens only (no accent colour). Mirrors cat-card,
   filter-chip, skin-card and skins-about so it reads as native.
   ═══════════════════════════════════════════════════════════════ */
.dl-lede {
    font-size: 0.813rem;
    color: var(--text-muted);
    line-height: 1.6;
    max-width: 68ch;
    margin-top: 6px;
}
.dl-toolbar {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 10px;
    margin-bottom: 14px;
}
.dl-toolbar .hub-search-input { flex: 1 1 200px; }
.dl-result-count { font-size: 0.75rem; color: var(--text-dim); white-space: nowrap; }

/* tiles */
.dl-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(116px, 1fr));
    gap: 8px;
}
.dl-grid--items { grid-template-columns: repeat(auto-fill, minmax(132px, 1fr)); }
.dl-grid--skins { grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); }
@media (max-width: 520px) {
    .dl-grid { grid-template-columns: repeat(3, 1fr); }
    .dl-grid--skins { grid-template-columns: repeat(2, 1fr); }
}

.dl-tile {
    background: var(--bg-card);
    border-radius: var(--radius);
    padding: 10px;
    text-decoration: none;
    display: flex;
    flex-direction: column;
    gap: 8px;
    border: 1px solid transparent;
    transition: background 0.15s ease, border-color 0.15s ease;
}
.dl-tile:hover { background: var(--bg-card-hover); border-color: var(--border); }
.dl-tile-img {
    width: 100%;
    aspect-ratio: 1 / 1;
    background: var(--bg);
    border-radius: var(--radius-sm);
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    color: var(--text-dim);
    font-size: 1.5rem;
    font-weight: 700;
}
.dl-tile--item .dl-tile-img { aspect-ratio: 1 / 1; padding: 8px; }
.dl-tile-img img { width: 100%; height: 100%; object-fit: cover; opacity: 0; transition: opacity 0.2s ease; }
.dl-tile--item .dl-tile-img img { object-fit: contain; }
.dl-tile-img img.loaded { opacity: 1; }
.dl-tile-body { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.dl-tile-name { font-size: 0.813rem; font-weight: 600; color: var(--text); line-height: 1.25; }
.dl-tile-sub { font-size: 0.688rem; color: var(--text-dim); }
.dl-tile-tags { display: flex; flex-wrap: wrap; gap: 3px; margin-top: 2px; }
.dl-chip-tag {
    font-size: 0.625rem;
    padding: 2px 6px;
    background: var(--bg);
    color: var(--text-muted);
    border-radius: var(--radius-pill);
}

/* detail header */
.dl-detail { display: flex; gap: 18px; flex-wrap: wrap; align-items: flex-start; margin-bottom: 18px; }
.dl-detail-art {
    flex: 0 0 200px;
    max-width: 200px;
    aspect-ratio: 3 / 4;
    background: var(--bg-card);
    border-radius: var(--radius);
    overflow: hidden;
}
.dl-detail-art--item { flex-basis: 120px; max-width: 120px; aspect-ratio: 1 / 1; padding: 14px; }
.dl-detail-art img { width: 100%; height: 100%; object-fit: cover; }
.dl-detail-art--item img { object-fit: contain; }
.dl-detail-main { flex: 1 1 300px; min-width: 0; }
.dl-detail-main .page-title { margin-bottom: 8px; }
.dl-detail-tags { display: flex; flex-wrap: wrap; gap: 6px; margin: 10px 0; }

/* stat cards */
.dl-section { margin-top: 24px; }
.dl-section-title { font-size: 1rem; font-weight: 600; color: var(--text); margin-bottom: 10px; }
.dl-stats {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(124px, 1fr));
    gap: 6px;
}
.dl-stat { background: var(--bg-card); border-radius: var(--radius-sm); padding: 10px 12px; }
.dl-stat-label { font-size: 0.625rem; color: var(--text-dim); text-transform: uppercase; letter-spacing: 0.04em; }
.dl-stat-value { font-size: 1.0625rem; font-weight: 700; color: var(--text); margin-top: 2px; }

/* abilities */
.dl-ability { display: flex; gap: 12px; padding: 12px 0; border-top: 1px solid var(--border); }
.dl-ability:first-child { border-top: none; padding-top: 4px; }
.dl-ability-icon {
    flex: 0 0 44px; width: 44px; height: 44px;
    background: var(--bg-card); border-radius: var(--radius-sm);
    display: flex; align-items: center; justify-content: center; overflow: hidden;
}
.dl-ability-icon img { width: 100%; height: 100%; object-fit: contain; }
.dl-ability-name { font-size: 0.875rem; font-weight: 600; color: var(--text); margin-bottom: 3px; }
.dl-ability-desc { font-size: 0.813rem; color: var(--text-muted); line-height: 1.6; white-space: pre-line; }

/* prose + FAQ */
.dl-prose p { font-size: 0.813rem; color: var(--text-muted); line-height: 1.7; margin-bottom: 12px; white-space: pre-line; }
.dl-prose h3 { font-size: 0.875rem; font-weight: 600; color: var(--text); margin: 18px 0 8px; }
.dl-faq { display: flex; flex-direction: column; gap: 8px; }
.dl-faq-item { background: var(--bg-card); border-radius: var(--radius-sm); padding: 12px 14px; }
.dl-faq-q { font-size: 0.813rem; font-weight: 600; color: var(--text); margin-bottom: 4px; }
.dl-faq-a { font-size: 0.813rem; color: var(--text-muted); line-height: 1.6; }

/* related links row */
.dl-related { display: flex; flex-wrap: wrap; gap: 6px; }

/* hub cards */
.dl-hub-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 10px; }
.dl-hub-card {
    background: var(--bg-card); border-radius: var(--radius); padding: 16px;
    text-decoration: none; display: flex; flex-direction: column; gap: 4px;
    border: 1px solid transparent; transition: background 0.15s ease, border-color 0.15s ease;
}
.dl-hub-card:hover { background: var(--bg-card-hover); border-color: var(--border); }
.dl-hub-card-count { font-size: 0.688rem; color: var(--text-dim); }
.dl-hub-card-title { font-size: 1rem; font-weight: 600; color: var(--text); }
.dl-hub-card-desc { font-size: 0.75rem; color: var(--text-muted); line-height: 1.5; }

/* source line */
.dl-source { margin-top: 28px; padding-top: 16px; border-top: 1px solid var(--border); }
.dl-source p { font-size: 0.75rem; color: var(--text-dim); line-height: 1.6; }
.dl-source a { color: var(--text-muted); text-decoration: underline; text-underline-offset: 2px; }
.dl-source a:hover { color: var(--text); }

/* skins */
.dl-skin-author { font-size: 0.688rem; color: var(--text-dim); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.dl-skin-stats { display: flex; gap: 10px; font-size: 0.688rem; color: var(--text-dim); }
.dl-skin-card--mature .skin-card-img img { filter: blur(18px); }
.dl-skin-card--mature.revealed .skin-card-img img { filter: none; }
.dl-mature-tag {
    position: absolute; inset: 0; display: flex; align-items: center; justify-content: center;
    z-index: 1; font-size: 0.625rem; font-weight: 700; color: var(--text-muted);
    text-transform: uppercase; letter-spacing: 0.06em; pointer-events: none;
}
.dl-skin-card--mature.revealed .dl-mature-tag { display: none; }

/* age gate modal (mirrors lightbox-overlay) */
.dl-agegate {
    position: fixed; inset: 0; z-index: 9999;
    background: rgba(0, 0, 0, 0.85);
    -webkit-backdrop-filter: blur(8px); backdrop-filter: blur(8px);
    display: flex; align-items: center; justify-content: center; padding: 20px;
    opacity: 0; visibility: hidden; transition: opacity 0.2s ease, visibility 0.2s ease;
}
.dl-agegate.active { opacity: 1; visibility: visible; }
.dl-agegate-box {
    background: var(--bg-card); border: 1px solid var(--border); border-radius: var(--radius);
    padding: 24px; max-width: 380px; text-align: center;
}
.dl-agegate-box h2 { font-size: 1rem; font-weight: 600; color: var(--text); margin-bottom: 8px; }
.dl-agegate-box p { font-size: 0.813rem; color: var(--text-muted); line-height: 1.6; margin-bottom: 16px; }
.dl-agegate-actions { display: flex; gap: 8px; justify-content: center; }
.dl-btn {
    padding: 8px 16px; border-radius: var(--radius-pill); font-size: 0.75rem; font-weight: 600;
    font-family: inherit; cursor: pointer; border: 1px solid var(--border);
    background: var(--bg-card); color: var(--text-muted); transition: all 0.15s ease;
}
.dl-btn:hover { background: var(--bg-card-hover); color: var(--text); }
.dl-btn--primary { background: var(--text); color: var(--bg); border-color: var(--text); }
.dl-btn--primary:hover { background: var(--text-muted); color: var(--bg); }

/* ── Deadlock: view switch / table / compare ── */
.dl-views { display: inline-flex; gap: 4px; background: var(--bg-card); border-radius: var(--radius-pill); padding: 3px; }
.dl-views button {
    padding: 5px 12px; border: none; background: transparent; color: var(--text-muted);
    font-size: 0.688rem; font-weight: 600; font-family: inherit; cursor: pointer; border-radius: var(--radius-pill);
}
.dl-views button.active { background: var(--text); color: var(--bg); }
.dl-table { width: 100%; border-collapse: collapse; font-size: 0.75rem; }
.dl-table th, .dl-table td { padding: 8px 10px; text-align: left; border-bottom: 1px solid var(--border); white-space: nowrap; }
.dl-table th { color: var(--text-dim); font-weight: 600; font-size: 0.625rem; text-transform: uppercase; letter-spacing: 0.04em; }
.dl-table td { color: var(--text-muted); }
.dl-table tr:hover td { background: var(--bg-card); }
.dl-table .dl-table-name { color: var(--text); font-weight: 600; }
.dl-table a.dl-table-name { text-decoration: none; }
.dl-table a.dl-table-name:hover { text-decoration: underline; }
.dl-table-row[data-status-tag="dev"] .dl-table-name::after,
.dl-tile[data-released="0"] .dl-tile-name::after {
    content: attr(data-dev-label); margin-left: 6px; font-size: 0.563rem; font-weight: 700;
    color: var(--slow); border: 1px solid var(--slow); border-radius: 4px; padding: 0 4px; vertical-align: middle; text-transform: uppercase;
}
.dl-table-img { width: 28px; height: 28px; border-radius: var(--radius-sm); object-fit: cover; vertical-align: middle; background: var(--bg); }
.dl-compare-hint { padding: 24px 16px; text-align: center; color: var(--text-muted); font-size: 0.813rem; }
.dl-table td:first-child, .dl-table th:first-child { position: sticky; left: 0; background: var(--bg); }
.dl-compare-pick { width: 15px; height: 15px; accent-color: var(--text); }
.dl-dev-badge { margin-left: 6px; font-size: 0.563rem; font-weight: 700; color: var(--slow); border: 1px solid var(--slow); border-radius: 4px; padding: 0 4px; vertical-align: middle; text-transform: uppercase; white-space: nowrap; }
.dl-toggle { display: inline-flex; align-items: center; gap: 6px; font-size: 0.75rem; color: var(--text-muted); cursor: pointer; user-select: none; }
.dl-toggle input { accent-color: var(--text); width: 14px; height: 14px; }
.dl-toggle:hover { color: var(--text); }

/* ── Deadlock fixes: hidden must win over card display; FAQ spacing; empty ── */
.dl-tile[hidden], .skin-card[hidden], .dl-table-row[hidden], [data-dl-card][hidden] { display: none !important; }
.dl-faq { display: flex; flex-direction: column; }
.dl-faq-item { margin-bottom: 8px; }
.dl-faq-item:last-child { margin-bottom: 0; }
.skins-about .dl-faq-item { margin-bottom: 8px; }
.dl-empty { padding: 28px 16px; text-align: center; color: var(--text-muted); font-size: 0.813rem; }

/* ── Deadlock hub: logo header + featured heroes strip ── */
.dl-hub-hero { display: flex; align-items: center; gap: 14px; margin-bottom: 6px; }
.dl-hub-logo { width: 64px; height: 64px; object-fit: contain; flex-shrink: 0; }
@media (max-width: 520px) { .dl-hub-logo { width: 44px; height: 44px; } }
.dl-hero-strip { display: flex; flex-wrap: wrap; gap: 6px; align-items: center; }
.dl-hero-chip { width: 52px; height: 52px; border-radius: var(--radius-sm); background: var(--bg-card); overflow: hidden; display: block; transition: background 0.15s ease; }
.dl-hero-chip:hover { background: var(--bg-card-hover); }
.dl-hero-chip img { width: 100%; height: 100%; object-fit: cover; opacity: 0; transition: opacity 0.2s ease; }
.dl-hero-chip img.loaded { opacity: 1; }
