/* ============================================================
   RODONATE STORE
   Item-shop tiles + marketplace sidebar filters + premium
   supporter section. Built on the global tokens in style.css.
============================================================ */

.store-body {
    --store-accent: #62dfa9;
    --store-surface: rgba(20, 20, 28, 0.84);
    --store-surface-2: rgba(26, 26, 36, 0.9);
    --store-surface-soft: rgba(255, 255, 255, 0.045);
    --store-line: rgba(255, 255, 255, 0.09);
    --store-line-strong: rgba(255, 255, 255, 0.18);

    /* Filter panel palette (matches the avatar page) */
    --flt-bg: rgba(13, 16, 27, 0.94);
    --flt-soft: rgba(255, 255, 255, 0.045);
    --flt-line: rgba(255, 255, 255, 0.085);
    --flt-cyan: #65d8ff;
    --flt-cyan-line: rgba(101, 216, 255, 0.3);
    --flt-active: linear-gradient(135deg, rgba(79, 124, 255, 0.18), rgba(70, 198, 255, 0.08));

    /* Category accent palette (item-shop frames) */
    --c-support: #ffc457;
    --c-stands: #4f9bff;
    --c-avatar: #b478ff;
    --c-profile: #62dfa9;
    --c-boosts: #ff5f9e;

    /* Supporter gold (premium CTA) */
    --gold: #ffd27a;
    --gold-deep: #f5b84a;
}

.store-shell {
    width: 100%;
    overflow-x: clip;
    overflow-y: visible;
}

.store-body .container {
    padding-inline: max(var(--space-lg), 18px);
}

.store-body h2 {
    display: block;
}

.store-body h2::after {
    display: none;
}

.store-kicker {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    margin-bottom: var(--space-sm);
    color: var(--store-accent);
    font-size: var(--fs-body-sm);
    font-weight: var(--fw-bold);
    letter-spacing: 0.5px;
    line-height: 1;
    text-transform: uppercase;
}

.store-kicker::before {
    content: "";
    width: 16px;
    height: 2px;
    border-radius: 2px;
    background: var(--store-accent);
}

.store-card {
    position: relative;
    border: 1px solid var(--store-line);
    border-radius: var(--radius-md);
    background: var(--store-surface);
    box-shadow: var(--shadow-soft);
}

.store-card,
.store-hero-banner,
.tier-card,
.store-filters,
.store-tile {
    border-color: transparent;
    background-clip: padding-box;
}

.store-card::before,
.store-hero-banner::before,
.tier-card::before,
.store-filters::before,
.store-tile::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 4;
    border: 1px solid var(--store-frame-color, var(--store-line));
    border-radius: inherit;
    pointer-events: none;
}

/* ------------------------------------------------------------
   BUTTONS
------------------------------------------------------------ */

.store-btn {
    min-height: 46px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 9px;
    padding: 0 22px;
    border-radius: var(--radius-md);
    font-size: var(--fs-body-md);
    font-weight: var(--fw-bold);
    line-height: 1;
    text-align: center;
    white-space: nowrap;
    transition:
        transform var(--motion-sm) var(--ease-standard),
        background var(--motion-sm) var(--ease-standard),
        border-color var(--motion-sm) var(--ease-standard),
        box-shadow var(--motion-sm) var(--ease-standard);
}

.store-btn i {
    width: 17px;
    height: 17px;
}

.store-btn-primary {
    background: var(--primary);
    border: 1px solid var(--primary);
    color: var(--text-dark);
}

.store-btn-primary:hover {
    background: var(--primary-dark);
    border-color: var(--primary-dark);
    box-shadow: 0 8px 22px rgba(79, 124, 255, 0.32);
    opacity: 1;
    transform: translateY(-1px);
}

.store-btn-ghost {
    background: rgba(255, 255, 255, 0.06);
    border: 1px solid var(--store-line-strong);
    color: var(--bright-snow);
}

.store-btn-ghost:hover {
    background: rgba(255, 255, 255, 0.1);
    border-color: rgba(255, 255, 255, 0.28);
    opacity: 1;
    transform: translateY(-1px);
}

.store-btn-gold {
    background: linear-gradient(135deg, var(--gold), var(--gold-deep));
    border: 1px solid var(--gold-deep);
    color: #2a1c05;
}

.store-btn-gold:hover {
    background: linear-gradient(135deg, #ffdc92, #f0ac38);
    border-color: #f0ac38;
    box-shadow: 0 8px 22px rgba(245, 184, 74, 0.3);
    opacity: 1;
    transform: translateY(-1px);
}

/* ------------------------------------------------------------
   HERO (image banner)
------------------------------------------------------------ */

.store-hero {
    padding: clamp(20px, 3vw, 32px) 0 0;
}

.store-hero-banner {
    --store-frame-color: var(--store-line);
    position: relative;
    display: flex;
    align-items: flex-end;
    min-height: clamp(300px, 42vw, 460px);
    padding: clamp(24px, 4vw, 52px);
    overflow: hidden;
    border: 1px solid var(--store-line);
    border-radius: 18px;
    box-shadow: 0 24px 60px rgba(0, 0, 0, 0.4);
    /* Fallback art shown until a real hero image loads */
    background:
        radial-gradient(circle at 82% 22%, rgba(255, 196, 87, 0.28), transparent 46%),
        radial-gradient(circle at 18% 12%, rgba(180, 120, 255, 0.32), transparent 50%),
        linear-gradient(125deg, #1b2350, #2a1840 46%, #101524);
}

.store-hero-img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    z-index: 1;
}

.store-hero-banner::after {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 2;
    background:
        linear-gradient(90deg, rgba(8, 10, 18, 0.9) 0%, rgba(8, 10, 18, 0.62) 42%, rgba(8, 10, 18, 0.15) 100%),
        linear-gradient(0deg, rgba(8, 10, 18, 0.78), transparent 60%);
}

.store-hero-content {
    position: relative;
    z-index: 3;
    max-width: 600px;
}

.store-hero-content h1 {
    margin: 0;
    color: var(--bright-snow);
    font-size: clamp(32px, 5.4vw, 60px);
    line-height: 1.02;
    letter-spacing: -0.6px;
    text-shadow: 0 4px 24px rgba(0, 0, 0, 0.5);
}

.store-hero-content h1 span {
    color: #ffd27a;
}

.store-hero-content p {
    max-width: 480px;
    margin-top: var(--space-md);
    color: rgba(242, 242, 247, 0.86);
    font-size: clamp(15px, 1.4vw, 18px);
    text-shadow: 0 2px 14px rgba(0, 0, 0, 0.5);
}

.store-hero-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: var(--space-lg);
}

/* ------------------------------------------------------------
   SECTION HEADS
------------------------------------------------------------ */

.store-supporter-section,
.store-catalog-section,
.store-fair-section,
.store-cta-section {
    padding: clamp(40px, 6vw, 64px) 0;
}

.store-section-head {
    max-width: 660px;
    margin-bottom: var(--space-lg);
}

.store-section-head h2 {
    margin: 0;
    color: var(--bright-snow);
    font-size: clamp(26px, 4vw, 40px);
    letter-spacing: -0.4px;
}

.store-section-head p {
    margin-top: 10px;
    color: rgba(242, 242, 247, 0.66);
    font-size: var(--fs-body-md);
}

/* ------------------------------------------------------------
   SUPPORTER (Nitro-style tiers)
------------------------------------------------------------ */

.store-supporter-tiers {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: var(--space-lg);
    align-items: stretch;
}

.tier-card {
    --store-frame-color: var(--store-line);
    position: relative;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    border: 1px solid var(--store-line);
    border-radius: 16px;
    background: var(--store-surface-2);
    box-shadow: var(--shadow-soft);
    transition:
        transform var(--motion-sm) var(--ease-standard),
        border-color var(--motion-sm) var(--ease-standard),
        box-shadow var(--motion-sm) var(--ease-standard);
}

.tier-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 18px 42px rgba(0, 0, 0, 0.4);
}

.tier-banner {
    position: relative;
    padding: clamp(20px, 3vw, 26px);
    overflow: hidden;
    color: #fff;
}

.tier-card-supporter .tier-banner {
    background:
        radial-gradient(circle at 110% -20%, rgba(255, 255, 255, 0.25), transparent 50%),
        linear-gradient(120deg, #5865f2, #9b6bff 55%, #ff77c8);
}

.tier-card-onetime .tier-banner {
    background:
        radial-gradient(circle at 110% -20%, rgba(255, 255, 255, 0.22), transparent 50%),
        linear-gradient(120deg, #1f9d7a, #38c98f 60%, #79e0b6);
}

.tier-banner-icon {
    width: 48px;
    height: 48px;
    display: grid;
    place-items: center;
    margin-bottom: 14px;
    border-radius: 14px;
    background: rgba(255, 255, 255, 0.18);
    -webkit-backdrop-filter: blur(4px);
    backdrop-filter: blur(4px);
}

.tier-banner-icon i,
.tier-banner-icon svg {
    width: 26px;
    height: 26px;
}

.tier-banner h3 {
    margin: 0;
    font-size: clamp(20px, 2.6vw, 26px);
    letter-spacing: -0.3px;
    color: #fff;
}

.tier-banner p {
    margin-top: 4px;
    color: rgba(255, 255, 255, 0.86);
    font-size: var(--fs-body-sm);
}

.tier-body {
    display: flex;
    flex-direction: column;
    flex: 1;
    gap: var(--space-md);
    padding: clamp(20px, 3vw, 26px);
}

.tier-price {
    display: flex;
    align-items: baseline;
    gap: 8px;
}

.tier-price .amount {
    color: var(--bright-snow);
    font-family: var(--ff-display);
    font-size: clamp(30px, 4vw, 42px);
    font-weight: var(--fw-bold);
    line-height: 1;
}

.tier-price .period {
    color: rgba(242, 242, 247, 0.6);
    font-size: var(--fs-body-md);
    font-weight: var(--fw-semibold);
}

.tier-perks {
    display: grid;
    gap: 11px;
    list-style: none;
}

.tier-perks li {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    color: rgba(242, 242, 247, 0.84);
    font-size: var(--fs-body-md);
    line-height: 1.4;
}

.tier-perks i {
    flex: 0 0 auto;
    width: 18px;
    height: 18px;
    margin-top: 1px;
    color: var(--store-accent);
}

.tier-body .store-btn {
    width: 100%;
    margin-top: auto;
}

/* ------------------------------------------------------------
   CATALOG: sidebar filters + tile grid
------------------------------------------------------------ */

.store-catalog-section {
    border-top: 1px solid rgba(255, 255, 255, 0.07);
}

.store-catalog-layout {
    display: grid;
    grid-template-columns: 252px minmax(0, 1fr);
    gap: var(--space-lg);
    align-items: start;
    margin-top: var(--space-md);
}

/* Filters sidebar */
.store-filters {
    --store-frame-color: var(--flt-line);
    position: sticky;
    top: 96px;
    display: flex;
    flex-direction: column;
    gap: var(--space-lg);
    padding: var(--space-lg);
    border: 1px solid var(--flt-line);
    border-radius: 14px;
    background: var(--flt-bg);
    box-shadow: 0 0 0 1px rgba(101, 216, 255, 0.06), 0 18px 40px rgba(0, 0, 0, 0.3);
    -webkit-backdrop-filter: blur(16px);
    backdrop-filter: blur(16px);
}

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

.store-filter-label {
    color: rgba(238, 244, 255, 0.48);
    font-size: 11px;
    font-weight: var(--fw-bold);
    letter-spacing: 0.6px;
    text-transform: uppercase;
}

/* Search field (inline icon + input, like the avatar page) */
.store-search {
    display: flex;
    align-items: center;
    gap: 8px;
    min-height: 42px;
    padding: 0 12px;
    border: 1px solid var(--flt-line);
    border-radius: 10px;
    background: var(--flt-soft);
    transition:
        border-color var(--motion-sm) var(--ease-standard),
        background var(--motion-sm) var(--ease-standard),
        box-shadow var(--motion-sm) var(--ease-standard);
}

.store-search:focus-within {
    border-color: rgba(101, 216, 255, 0.58);
    background: rgba(255, 255, 255, 0.055);
    box-shadow: inset 0 0 0 1px rgba(101, 216, 255, 0.28), 0 0 0 1px rgba(101, 216, 255, 0.18);
}

.store-search i,
.store-search svg {
    width: 16px;
    height: 16px;
    flex: 0 0 auto;
    color: var(--flt-cyan);
    opacity: 0.85;
}

.store-search input {
    min-width: 0;
    width: 100%;
    height: 40px;
    border: 0;
    outline: none;
    background: transparent;
    color: var(--bright-snow);
    font-family: var(--ff-body);
    font-size: var(--fs-body-md);
    font-weight: var(--fw-semibold);
}

.store-search input::placeholder {
    color: rgba(238, 244, 255, 0.42);
}

.store-filter-row {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(132px, 100%), 1fr));
    gap: 8px;
    align-items: center;
    min-width: 0;
    max-width: 100%;
    overflow: visible;
}

.store-cats {
    display: grid;
    gap: 4px;
    list-style: none;
}

.store-cat {
    width: 100%;
    min-height: 40px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    padding: 0 12px;
    border: 1px solid transparent;
    border-radius: var(--radius-md);
    background: transparent;
    color: rgba(242, 242, 247, 0.74);
    font-size: var(--fs-body-md);
    font-weight: var(--fw-bold);
    text-align: left;
    transition:
        background var(--motion-sm) var(--ease-standard),
        color var(--motion-sm) var(--ease-standard);
}

.store-cat:hover {
    background: rgba(255, 255, 255, 0.045);
    color: var(--bright-snow);
}

.store-cat.is-active {
    color: var(--bright-snow);
    background: var(--flt-active);
    border-color: transparent;
    box-shadow: inset 0 -2px 0 rgba(101, 216, 255, 0.58);
}

.store-cat-count {
    min-width: 24px;
    height: 20px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0 6px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.08);
    color: rgba(242, 242, 247, 0.66);
    font-size: 11px;
    font-weight: var(--fw-bold);
}

.store-cat.is-active .store-cat-count {
    background: rgba(101, 216, 255, 0.22);
    color: #d6f4ff;
}

.store-select {
    width: 100%;
    min-width: 0;
    min-height: 36px;
    padding: 0 34px 0 12px;
    border: 1px solid var(--flt-line);
    border-radius: 8px;
    background:
        url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%2365d8ff' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E")
        no-repeat right 12px center,
        var(--flt-soft);
    color: var(--bright-snow);
    font-family: var(--ff-body);
    font-size: var(--fs-body-md);
    font-weight: var(--fw-bold);
    outline: none;
    cursor: pointer;
    -webkit-appearance: none;
    appearance: none;
    transition:
        border-color var(--motion-sm) var(--ease-standard),
        background-color var(--motion-sm) var(--ease-standard),
        color var(--motion-sm) var(--ease-standard);
}

.store-select-native {
    position: absolute;
    width: 1px;
    height: 1px;
    opacity: 0;
    pointer-events: none;
}

.store-select:hover {
    border-color: rgba(101, 216, 255, 0.32);
    background-color: rgba(79, 124, 255, 0.14);
}

.store-select:focus {
    border-color: rgba(101, 216, 255, 0.58);
    box-shadow: 0 0 0 3px rgba(101, 216, 255, 0.14);
}

.store-filter-select {
    position: relative;
    min-width: 0;
    z-index: 2;
}

.store-filter-select.is-open {
    z-index: 40;
}

.store-filter-select-button,
.store-filter-chip {
    width: 100%;
    min-width: 0;
    min-height: 36px;
    border: 1px solid rgba(255, 255, 255, 0.075);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.045);
    color: rgba(238, 244, 255, 0.68);
    font: inherit;
    font-size: 12px;
    font-weight: 800;
}

.store-filter-select-button {
    display: inline-flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    padding: 0 9px 0 11px;
    text-align: left;
    transition:
        transform var(--motion-sm) var(--ease-standard),
        background var(--motion-sm) var(--ease-standard),
        border-color var(--motion-sm) var(--ease-standard),
        color var(--motion-sm) var(--ease-standard);
}

.store-filter-select-button span {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.store-filter-select-button svg {
    width: 16px;
    height: 16px;
    flex: 0 0 auto;
    fill: currentColor;
    opacity: 0.78;
    transition: transform var(--motion-sm) var(--ease-standard);
}

.store-filter-select.is-open .store-filter-select-button,
.store-filter-select-button:hover,
.store-filter-select-button:focus-visible {
    color: var(--bright-snow);
    border-color: rgba(101, 216, 255, 0.32);
    background: rgba(79, 124, 255, 0.14);
}

.store-filter-select-button:focus-visible,
.store-filter-chip:focus-visible,
.store-search:focus-within,
.store-filter-reset:focus-visible,
.store-filters-toggle:focus-visible {
    outline: 2px solid rgba(101, 216, 255, 0.82);
    outline-offset: 3px;
}

.store-filter-select.is-open .store-filter-select-button svg {
    transform: rotate(180deg);
}

.store-filter-select-menu {
    position: absolute;
    top: calc(100% + 7px);
    left: 0;
    width: 100%;
    min-width: 0;
    display: grid;
    gap: 3px;
    padding: 5px;
    border: 1px solid rgba(101, 216, 255, 0.18);
    border-radius: 8px;
    background: rgba(12, 15, 25, 0.98);
    box-shadow:
        0 14px 28px rgba(0, 0, 0, 0.32),
        inset 0 1px 0 rgba(255, 255, 255, 0.05);
    opacity: 0;
    pointer-events: none;
    transform: translateY(-4px) scale(0.98);
    transform-origin: 50% 0;
    transition:
        opacity var(--motion-sm) var(--ease-standard),
        transform var(--motion-sm) var(--ease-standard);
}

.store-filter-select.is-open .store-filter-select-menu {
    opacity: 1;
    pointer-events: auto;
    transform: translateY(0) scale(1);
}

.store-filter-select-option {
    min-height: 31px;
    padding: 0 9px;
    border: 0;
    border-radius: 6px;
    background: transparent;
    color: rgba(238, 244, 255, 0.68);
    font: inherit;
    font-size: 12px;
    font-weight: 800;
    text-align: left;
    transition:
        background var(--motion-sm) var(--ease-standard),
        color var(--motion-sm) var(--ease-standard);
}

.store-filter-select-option:hover,
.store-filter-select-option:focus-visible,
.store-filter-select-option.is-selected {
    color: var(--bright-snow);
    background: rgba(101, 216, 255, 0.12);
    outline: 0;
}

.store-filter-select-option.is-selected {
    background: rgba(79, 124, 255, 0.2);
}

.store-filter-chip {
    padding: 0 11px;
    transition:
        transform var(--motion-sm) var(--ease-standard),
        background var(--motion-sm) var(--ease-standard),
        border-color var(--motion-sm) var(--ease-standard),
        color var(--motion-sm) var(--ease-standard);
}

.store-filter-chip:hover,
.store-filter-chip.is-active,
.store-filter-chip[aria-pressed="true"] {
    opacity: 1;
    color: var(--bright-snow);
    background: rgba(79, 124, 255, 0.16);
    border-color: rgba(101, 216, 255, 0.28);
}

.store-filter-chip:active,
.store-filter-select-button:active {
    transform: translateY(1px) scale(0.99);
}

.store-filter-reset {
    min-height: 40px;
    border: 1px solid var(--flt-line);
    border-radius: 8px;
    background: var(--flt-soft);
    color: rgba(238, 244, 255, 0.78);
    font-size: var(--fs-body-sm);
    font-weight: var(--fw-bold);
    transition:
        background var(--motion-sm) var(--ease-standard),
        border-color var(--motion-sm) var(--ease-standard),
        color var(--motion-sm) var(--ease-standard);
}

.store-filter-reset:hover {
    color: var(--bright-snow);
    background: rgba(79, 124, 255, 0.16);
    border-color: rgba(101, 216, 255, 0.28);
}

/* Catalog main */
.store-catalog-main {
    min-width: 0;
}

.store-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-md);
    margin-bottom: var(--space-md);
}

.store-result-count {
    color: rgba(242, 242, 247, 0.66);
    font-size: var(--fs-body-md);
    font-weight: var(--fw-semibold);
}

.store-result-count strong {
    color: var(--bright-snow);
}

.store-filters-toggle {
    display: none;
    align-items: center;
    gap: 8px;
    min-height: 42px;
    padding: 0 16px;
    border: 1px solid var(--flt-line);
    border-radius: 10px;
    background: var(--flt-soft);
    color: var(--bright-snow);
    font-size: var(--fs-body-sm);
    font-weight: var(--fw-bold);
    transition:
        background var(--motion-sm) var(--ease-standard),
        border-color var(--motion-sm) var(--ease-standard);
}

.store-filters-toggle:hover,
.store-filters-toggle[aria-expanded="true"] {
    background: rgba(79, 124, 255, 0.16);
    border-color: rgba(101, 216, 255, 0.28);
}

.store-filters-toggle i,
.store-filters-toggle svg {
    width: 16px;
    height: 16px;
    color: var(--flt-cyan);
}

/* Tile grid */
.store-tiles {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: var(--space-md);
}

.store-tile {
    --tile-accent: var(--store-line);
    --store-frame-color: color-mix(in srgb, var(--tile-accent) 22%, var(--store-line));
    position: relative;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    border: 1px solid color-mix(in srgb, var(--tile-accent) 22%, var(--store-line));
    border-radius: 14px;
    background: var(--store-surface-2);
    box-shadow: var(--shadow-soft);
    transition:
        transform var(--motion-sm) var(--ease-standard),
        border-color var(--motion-sm) var(--ease-standard),
        box-shadow var(--motion-sm) var(--ease-standard);
}

.store-tile:hover {
    --store-frame-color: color-mix(in srgb, var(--tile-accent) 55%, transparent);
    transform: translateY(-4px);
    box-shadow: 0 16px 36px rgba(0, 0, 0, 0.4);
}

.store-tile.is-hidden {
    display: none;
}

.store-tile-art {
    position: relative;
    display: grid;
    place-items: center;
    aspect-ratio: 16 / 11;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.035), transparent 55%),
        #14141d;
    border-bottom: 1px solid var(--store-line);
}

.store-tile-art .store-tile-icon {
    width: 56px;
    height: 56px;
    display: grid;
    place-items: center;
    border-radius: 16px;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid var(--store-line);
    color: color-mix(in srgb, var(--tile-accent) 72%, #ffffff);
}

.store-tile-art .store-tile-icon i,
.store-tile-art .store-tile-icon svg {
    width: 28px;
    height: 28px;
}

.store-tile-tag {
    position: absolute;
    top: 10px;
    left: 10px;
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 4px 9px;
    border-radius: 999px;
    background: rgba(8, 10, 18, 0.7);
    border: 1px solid color-mix(in srgb, var(--tile-accent) 45%, transparent);
    color: color-mix(in srgb, var(--tile-accent) 72%, #ffffff);
    font-size: 10px;
    font-weight: var(--fw-bold);
    letter-spacing: 0.5px;
    text-transform: uppercase;
}

.store-tile-tag::before {
    content: "";
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: var(--tile-accent);
}

.store-tile-feature {
    position: absolute;
    top: 10px;
    right: 10px;
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 4px 9px;
    border-radius: 999px;
    background: rgba(255, 196, 87, 0.16);
    border: 1px solid rgba(255, 196, 87, 0.5);
    color: #ffe2a0;
    font-size: 10px;
    font-weight: var(--fw-bold);
    letter-spacing: 0.4px;
    text-transform: uppercase;
}

.store-tile-feature i {
    width: 12px;
    height: 12px;
}

.store-tile-body {
    display: flex;
    flex-direction: column;
    flex: 1;
    gap: 6px;
    padding: 14px 14px 16px;
}

.store-tile-body h3 {
    margin: 0;
    color: var(--bright-snow);
    font-size: 16px;
    letter-spacing: -0.2px;
}

.store-tile-body p {
    flex: 1;
    margin: 0;
    color: rgba(242, 242, 247, 0.6);
    font-size: var(--fs-body-sm);
    line-height: 1.45;
}

.store-tile-foot {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    margin-top: 8px;
}

.store-tile-price {
    display: inline-flex;
    align-items: baseline;
    gap: 4px;
    color: var(--bright-snow);
    font-size: var(--fs-body-md);
    font-weight: var(--fw-bold);
    white-space: nowrap;
}

.store-tile-price small {
    color: rgba(242, 242, 247, 0.55);
    font-size: 11px;
    font-weight: var(--fw-semibold);
}

.store-tile-btn {
    min-height: 36px;
    padding: 0 16px;
    border-radius: var(--radius-md);
    border: 1px solid color-mix(in srgb, var(--tile-accent) 45%, transparent);
    background: color-mix(in srgb, var(--tile-accent) 14%, transparent);
    color: var(--bright-snow);
    font-size: var(--fs-body-sm);
    font-weight: var(--fw-bold);
    transition:
        background var(--motion-sm) var(--ease-standard),
        border-color var(--motion-sm) var(--ease-standard),
        transform var(--motion-sm) var(--ease-standard);
}

.store-tile-btn:hover {
    background: color-mix(in srgb, var(--tile-accent) 26%, transparent);
    border-color: color-mix(in srgb, var(--tile-accent) 70%, transparent);
    transform: translateY(-1px);
}

/* Category accent assignments */
.store-tile[data-store-category="support"] { --tile-accent: var(--c-support); }
.store-tile[data-store-category="stands"] { --tile-accent: var(--c-stands); }
.store-tile[data-store-category="avatar"] { --tile-accent: var(--c-avatar); }
.store-tile[data-store-category="profile"] { --tile-accent: var(--c-profile); }
.store-tile[data-store-category="boosts"] { --tile-accent: var(--c-boosts); }

/* Empty state */
.store-empty {
    position: relative;
    display: none;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 8px;
    padding: clamp(40px, 7vw, 72px) var(--space-lg);
    border: 1px dashed var(--store-line-strong);
    border-radius: var(--radius-md);
    background: rgba(255, 255, 255, 0.02);
}

.store-empty.is-visible {
    display: flex;
}

.store-empty i,
.store-empty svg {
    width: 32px;
    height: 32px;
    color: rgba(242, 242, 247, 0.5);
}

.store-empty h3 {
    margin: 0;
    color: var(--bright-snow);
}

.store-empty p {
    margin: 0;
    color: rgba(242, 242, 247, 0.6);
    font-size: var(--fs-body-md);
}

/* ------------------------------------------------------------
   FAIR / WHAT YOU GET
------------------------------------------------------------ */

.store-fair-section {
    border-top: 1px solid rgba(255, 255, 255, 0.07);
    background: rgba(255, 255, 255, 0.02);
}

.store-fair-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: var(--space-md);
    margin-top: var(--space-md);
}

.store-fair-card {
    display: flex;
    flex-direction: column;
    gap: 10px;
    padding: clamp(20px, 3vw, 26px);
}

.store-fair-icon {
    width: 46px;
    height: 46px;
    display: grid;
    place-items: center;
    margin-bottom: 4px;
    border-radius: var(--radius-md);
}

.store-fair-icon i,
.store-fair-icon svg { width: 22px; height: 22px; }
.store-fair-icon.is-purple { background: rgba(174, 115, 255, 0.18); color: #cdb0ff; }
.store-fair-icon.is-green { background: rgba(98, 223, 169, 0.16); color: #8ff0c6; }
.store-fair-icon.is-pink { background: rgba(255, 88, 144, 0.18); color: #ff9abd; }

.store-fair-card h3 {
    margin: 0;
    color: var(--bright-snow);
    font-size: var(--fs-display-md);
}

.store-fair-card p {
    margin: 0;
    color: rgba(242, 242, 247, 0.66);
    font-size: var(--fs-body-md);
    line-height: 1.5;
}

/* ------------------------------------------------------------
   CLOSING CTA
------------------------------------------------------------ */

.store-cta-section {
    border-top: 1px solid rgba(255, 255, 255, 0.07);
}

.store-cta-band {
    --store-frame-color: rgba(79, 124, 255, 0.24);
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: var(--space-lg);
    padding: clamp(26px, 4vw, 40px);
    overflow: hidden;
    border-color: rgba(79, 124, 255, 0.24);
    background:
        radial-gradient(circle at 0% 0%, rgba(79, 124, 255, 0.12), transparent 55%),
        rgba(20, 20, 28, 0.92);
}

.store-cta-copy {
    max-width: 560px;
}

.store-cta-copy h2 {
    margin: 0;
    color: var(--bright-snow);
    font-size: clamp(24px, 3.4vw, 36px);
    letter-spacing: -0.4px;
}

.store-cta-copy p {
    margin-top: 10px;
    color: rgba(242, 242, 247, 0.72);
    font-size: var(--fs-body-md);
}

.store-cta-band .store-btn {
    flex: 0 0 auto;
}

/* ------------------------------------------------------------
   RESPONSIVE
------------------------------------------------------------ */

/* Laptops: shrink the sidebar, keep 3 columns */
@media (max-width: 1100px) {
    .store-catalog-layout {
        grid-template-columns: 210px minmax(0, 1fr);
        gap: var(--space-md);
    }

}

/* Tablets: sidebar collapses into a toggle, full-width grid */
@media (max-width: 900px) {
    .store-supporter-tiers {
        grid-template-columns: 1fr;
    }

    .store-catalog-layout {
        grid-template-columns: 1fr;
    }

    .store-filters {
        position: static;
        display: none;
    }

    .store-filters.is-open {
        display: flex;
    }

    .store-filters-toggle {
        display: inline-flex;
    }

    .store-fair-grid {
        grid-template-columns: 1fr;
    }
}

/* Large phones and below: 2 cards per row */
@media (max-width: 680px) {
    .store-tiles {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 12px;
    }
}

@media (max-width: 620px) {
    .store-hero-actions {
        flex-direction: column;
        align-items: stretch;
    }

    .store-hero-actions .store-btn {
        width: 100%;
    }

    .store-cta-band {
        flex-direction: column;
        align-items: flex-start;
    }

    .store-cta-band .store-btn {
        width: 100%;
    }
}

/* Narrow phones: stack each tile's price over a full-width button */
@media (max-width: 520px) {
    .store-tile-body {
        padding: 12px 12px 14px;
    }

    .store-tile-foot {
        flex-direction: column;
        align-items: stretch;
        gap: 8px;
    }

    .store-tile-btn {
        width: 100%;
    }
}

/* Narrow tiles: drop the decorative Featured flag so it can't
   collide with the rarity tag */
@media (max-width: 400px) {
    .store-tile-feature {
        display: none;
    }
}

@media (max-width: 360px) {
    .store-tiles {
        gap: 10px;
    }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
    .store-btn,
    .store-tile,
    .tier-card,
    .store-cat,
    .store-tile-btn,
    .store-filter-chip,
    .store-filter-select-button,
    .store-filter-select-menu {
        transition: none;
    }
}
