:root{
    --cyan:#22d3ee;
    --violet:#8b5cf6;
    --pink:#ec4899;
    --red:#ef4444;
    --bg:#050505;
    --surface:#0f0f0f;
    --surface2:#121212;
    --border:#1a1a1a;
}

/* ── Base ─────────────────────────────────────────────────────────────── */

*{box-sizing:border-box}

body{
    margin:0;
    background:var(--bg);
    color:#fff;
    font-family:Inter,sans-serif;
    overflow-x:hidden;
    -webkit-font-smoothing:antialiased;
}

body::before{
    content:'';
    position:fixed;
    inset:0;
    pointer-events:none;
    opacity:.35;
    z-index:0;
    background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
}

/* ── Blobs ────────────────────────────────────────────────────────────── */

.glow-blob{
    position:fixed;
    border-radius:50%;
    filter:blur(140px);
    pointer-events:none;
    z-index:0;
    will-change:transform;
}
.blob-1{ width:500px; height:500px; background:var(--cyan);   top:-8%;  left:-6%;  opacity:.07; }
.blob-2{ width:480px; height:480px; background:var(--violet); bottom:8%; right:-6%; opacity:.07; }
.blob-3{ width:300px; height:300px; background:var(--pink);   top:40%; left:50%; opacity:.04; }

/* ── Layout ───────────────────────────────────────────────────────────── */

.store-wrap{ display:flex; justify-content:center; }

.store-center{
    width:100%;
    max-width:1400px;
    padding:0 32px 120px;
    position:relative;
    z-index:1;
}

/* ── Hero ─────────────────────────────────────────────────────────────── */

.hero{
    text-align:center;
    padding:80px 20px 110px;
    position:relative;
    z-index:1;
    overflow:hidden;
    min-height:460px;
}

.hero::before{
    content:'';
    position:absolute;
    inset:0;
    background-image:
        linear-gradient(rgba(255,255,255,.022) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,.022) 1px, transparent 1px);
    background-size:60px 60px;
    mask-image:radial-gradient(ellipse 80% 70% at 50% 50%, black 30%, transparent 100%);
    pointer-events:none;
}

.hero-content{
    position:relative;
    z-index:1;
    will-change:transform;
}


.hero-tag{
    font:.58rem 'JetBrains Mono';
    letter-spacing:.28em;
    text-transform:uppercase;
    color:var(--cyan);
    border:1px solid rgba(34,211,238,.45);
    background:rgba(0,0,0,.8);
    padding:.32rem 1rem;
    display:inline-block;
    margin-bottom:22px;
    border-radius:4px;
    animation:heroIn .5s cubic-bezier(.16,1,.3,1) .05s both;
    backdrop-filter:blur(8px);
    -webkit-backdrop-filter:blur(8px);
}

.hero-title{
    font-size:clamp(2.6rem,7vw,5.5rem);
    font-weight:900;
    letter-spacing:-.04em;
    font-style:italic;
    text-transform:uppercase;
    line-height:.95;
    margin:0 0 16px;
    animation:heroIn .6s cubic-bezier(.16,1,.3,1) .18s both;
    text-shadow:-3px -3px 0 #000,3px -3px 0 #000,-3px 3px 0 #000,3px 3px 0 #000,0 -3px 0 #000,0 3px 0 #000,-3px 0 0 #000,3px 0 0 #000;
    background:linear-gradient(135deg,#fff 40%,rgba(255,255,255,.6));
    -webkit-background-clip:text;
    -webkit-text-fill-color:transparent;
    background-clip:text;
}

.hero-title .accent{ color:var(--cyan); }

.brand-desc{
    color:rgba(255,255,255,.8);
    margin:0 0 28px;
    font-size:1rem;
    font-weight:500;
    letter-spacing:.03em;
    animation:heroIn .55s cubic-bezier(.16,1,.3,1) .32s both;
    text-shadow:-1px -1px 0 #000,1px -1px 0 #000,-1px 1px 0 #000,1px 1px 0 #000;
}

.hero-scroll-hint{
    display:inline-flex;
    align-items:center;
    gap:7px;
    font-family:'JetBrains Mono',monospace;
    font-size:.55rem;
    letter-spacing:.22em;
    text-transform:uppercase;
    color:rgba(255,255,255,.35);
    animation:heroIn .5s cubic-bezier(.16,1,.3,1) .5s both;
}

.hero-scroll-hint svg{
    animation:scrollBounce 2s ease-in-out infinite;
    opacity:.5;
}

@keyframes scrollBounce{
    0%,100%{ transform:translateY(0); }
    50%{ transform:translateY(4px); }
}


/* ── Hero stats ───────────────────────────────────────────────────────── */

.hero-stats{
    display:inline-flex;
    gap:0;
    margin-top:32px;
    border:1px solid rgba(255,255,255,.12);
    border-radius:10px;
    background:rgba(0,0,0,.82);
    backdrop-filter:blur(12px);
    -webkit-backdrop-filter:blur(12px);
    overflow:hidden;
}

.hero-stat{
    font-family:'JetBrains Mono',monospace;
    font-size:.6rem;
    letter-spacing:.2em;
    text-transform:uppercase;
    color:rgba(255,255,255,.5);
    padding:14px 28px;
    border-right:1px solid rgba(255,255,255,.08);
}

.hero-stat:last-child{ border-right:none; }

.hero-stat span{
    display:block;
    font-size:1.25rem;
    font-weight:700;
    color:#fff;
    margin-bottom:5px;
    letter-spacing:-.03em;
    text-shadow:-2px -2px 0 #000,2px -2px 0 #000,-2px 2px 0 #000,2px 2px 0 #000,0 -2px 0 #000,0 2px 0 #000,-2px 0 0 #000,2px 0 0 #000;
}

/* ── Category quick-nav cards ─────────────────────────────────────────── */

.cat-cards-row{
    display:grid;
    grid-template-columns:repeat(auto-fill, minmax(170px, 1fr));
    gap:10px;
    margin-bottom:36px;
    width:100%;
}

.cat-card{
    display:flex;
    align-items:center;
    gap:12px;
    padding:16px 18px;
    background:linear-gradient(135deg, #111 0%, #0d0d0d 100%);
    border:1px solid #252525;
    border-left:3px solid var(--c, #22d3ee);
    border-radius:10px;
    text-decoration:none;
    transition:border-color .2s, background .2s, transform .2s, box-shadow .2s;
}

.cat-card:hover{
    background:linear-gradient(135deg, #161616 0%, #111 100%);
    border-color:#333;
    border-left-color:var(--c, #22d3ee);
    transform:translateY(-2px);
    box-shadow:0 8px 28px rgba(0,0,0,.45);
}

.cat-card-dot{
    width:8px;
    height:8px;
    border-radius:50%;
    flex-shrink:0;
}

.cat-card-info{ flex:1; min-width:0; }

.cat-card-label{
    font-weight:700;
    font-size:.82rem;
    color:#d0d0d0;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
}

.cat-card-count{
    font-family:'JetBrains Mono',monospace;
    font-size:.58rem;
    color:#555;
    letter-spacing:.06em;
    margin-top:3px;
}

.cat-card-arrow{
    margin-left:auto;
    color:#383838;
    flex-shrink:0;
    transition:color .2s, transform .2s;
}

.cat-card:hover .cat-card-arrow{
    color:var(--c, #22d3ee);
    transform:translateX(3px);
}

/* skeleton cat card */
.skeleton-cat-card{
    height:54px;
    background:linear-gradient(90deg,#111,#1a1a1a,#111);
    background-size:200% 100%;
    animation:shimmer 1.2s infinite;
    border-radius:10px;
    border:1px solid #1e1e1e;
}

/* ── Trending scroll row ──────────────────────────────────────────────── */

.trending-section{
    margin-bottom:36px;
}

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

.section-row-title{
    font-size:.88rem;
    font-weight:800;
    letter-spacing:.06em;
    text-transform:uppercase;
    color:#fff;
    display:flex;
    align-items:center;
    gap:7px;
    font-family:'JetBrains Mono',monospace;
    text-shadow:-2px -2px 0 #000,2px -2px 0 #000,-2px 2px 0 #000,2px 2px 0 #000,0 -2px 0 #000,0 2px 0 #000,-2px 0 0 #000,2px 0 0 #000;
}

.fire-badge{ font-size:.85rem; }

.trending-scroll{
    display:flex;
    gap:11px;
    overflow-x:auto;
    padding-bottom:6px;
    scroll-snap-type:x mandatory;
    -webkit-overflow-scrolling:touch;
}

.trending-scroll::-webkit-scrollbar{ height:3px; }
.trending-scroll::-webkit-scrollbar-track{ background:transparent; }
.trending-scroll::-webkit-scrollbar-thumb{ background:#1a1a1a; border-radius:3px; }

.trend-card{
    flex-shrink:0;
    width:175px;
    background:#111;
    border:1px solid #252525;
    border-radius:10px;
    overflow:hidden;
    text-decoration:none;
    scroll-snap-align:start;
    transition:border-color .2s, transform .2s, box-shadow .2s;
}

.trend-card:hover{
    border-color:#383838;
    transform:translateY(-3px);
    box-shadow:0 10px 30px rgba(0,0,0,.5);
}

.trend-card-img{
    position:relative;
    aspect-ratio:16/10;
    overflow:hidden;
    background:#111;
}

.trend-card-img img{
    width:100%;
    height:100%;
    object-fit:cover;
    transition:transform .4s ease, opacity .3s ease;
}

.trend-card:hover .trend-card-img img{ transform:scale(1.07); }

.trend-card-cat{
    position:absolute;
    bottom:7px;
    left:7px;
    font-family:'JetBrains Mono',monospace;
    font-size:.48rem;
    letter-spacing:.12em;
    text-transform:uppercase;
    padding:2px 7px;
    border-radius:3px;
    backdrop-filter:blur(6px);
}

.trend-card-body{ padding:9px 11px 10px; }

.trend-card-title{
    font-size:.75rem;
    font-weight:700;
    color:#bbb;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
    margin-bottom:3px;
}

.trend-card-price{
    font-family:'JetBrains Mono',monospace;
    font-size:.6rem;
    font-weight:700;
}

/* ── Store controls (filter pills + sort) ─────────────────────────────── */

.store-controls{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:12px;
    flex-wrap:wrap;
    padding:14px 0;
    margin-bottom:32px;
}

.filter-pills{
    display:flex;
    gap:7px;
    flex-wrap:wrap;
}

.filter-pill{
    font-family:'JetBrains Mono',monospace;
    font-size:.58rem;
    letter-spacing:.14em;
    text-transform:uppercase;
    padding:.4rem .85rem;
    border-radius:7px;
    border:1px solid rgba(255,255,255,.18);
    background:#111;
    color:rgba(255,255,255,.8);
    cursor:pointer;
    transition:all .18s ease;
    font-weight:600;
}

/* ── Per-category colours: solid black bg, coloured border + text ─────────── */
.filter-pill[data-filter="all"]             { border-color:rgba(255,255,255,.4);  color:#e2e2e2; }
.filter-pill[data-filter="dashboards"]      { border-color:rgba(34,211,238,.6);  color:#22d3ee; }
.filter-pill[data-filter="suspension"]      { border-color:rgba(139,92,246,.6);  color:#a78bfa; }
.filter-pill[data-filter="interior-lights"] { border-color:rgba(239,68,68,.6);   color:#f87171; }
.filter-pill[data-filter="packs"]           { border-color:rgba(245,158,11,.6);  color:#fbbf24; }
.filter-pill[data-filter="skins"]           { border-color:rgba(236,72,153,.6);  color:#f472b6; }
.filter-pill[data-filter="engines"]         { border-color:rgba(249,115,22,.6);  color:#fb923c; }
.filter-pill[data-filter="free"]            { border-color:rgba(34,197,94,.6);   color:#4ade80; }

/* ── Hover ────────────────────────────────────────────────────────────────── */
.filter-pill[data-filter="all"]:hover             { background:#1a1a1a; border-color:rgba(255,255,255,.75); }
.filter-pill[data-filter="dashboards"]:hover      { background:#1a1a1a; border-color:#22d3ee; }
.filter-pill[data-filter="suspension"]:hover      { background:#1a1a1a; border-color:#8b5cf6; }
.filter-pill[data-filter="interior-lights"]:hover { background:#1a1a1a; border-color:#ef4444; }
.filter-pill[data-filter="packs"]:hover           { background:#1a1a1a; border-color:#f59e0b; }
.filter-pill[data-filter="skins"]:hover           { background:#1a1a1a; border-color:#ec4899; }
.filter-pill[data-filter="engines"]:hover         { background:#1a1a1a; border-color:#f97316; }
.filter-pill[data-filter="free"]:hover            { background:#1a1a1a; border-color:#22c55e; }

/* ── Active: full solid colour ────────────────────────────────────────────── */
.filter-pill.active{ font-weight:700; }
.filter-pill[data-filter="all"].active             { background:#e2e2e2; border-color:#e2e2e2; color:#000; box-shadow:0 0 18px rgba(255,255,255,.3); }
.filter-pill[data-filter="dashboards"].active      { background:#22d3ee; border-color:#22d3ee; color:#000; box-shadow:0 0 18px rgba(34,211,238,.5); }
.filter-pill[data-filter="suspension"].active      { background:#8b5cf6; border-color:#8b5cf6; color:#fff; box-shadow:0 0 18px rgba(139,92,246,.5); }
.filter-pill[data-filter="interior-lights"].active { background:#ef4444; border-color:#ef4444; color:#fff; box-shadow:0 0 18px rgba(239,68,68,.5);  }
.filter-pill[data-filter="packs"].active           { background:#f59e0b; border-color:#f59e0b; color:#000; box-shadow:0 0 18px rgba(245,158,11,.5); }
.filter-pill[data-filter="skins"].active           { background:#ec4899; border-color:#ec4899; color:#fff; box-shadow:0 0 18px rgba(236,72,153,.5); }
.filter-pill[data-filter="engines"].active         { background:#f97316; border-color:#f97316; color:#000; box-shadow:0 0 18px rgba(249,115,22,.5); }
.filter-pill[data-filter="free"].active            { background:#22c55e; border-color:#22c55e; color:#000; box-shadow:0 0 18px rgba(34,197,94,.5);  }

.controls-right{
    display:flex;
    align-items:center;
    gap:10px;
    flex-shrink:0;
}

.sort-select{
    padding:.4rem .85rem;
    padding-right:1.6rem;
    background:rgba(0,0,0,.9);
    border:1px solid rgba(255,255,255,.15);
    border-radius:7px;
    color:#fff;
    font-family:'JetBrains Mono',monospace;
    font-size:.58rem;
    letter-spacing:.1em;
    outline:none;
    cursor:pointer;
    transition:border-color .2s;
    appearance:none;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%23888'/%3E%3C/svg%3E");
    background-repeat:no-repeat;
    background-position:right 8px center;
}

.sort-select:focus{ border-color:rgba(255,255,255,.3); }

.filter-count{
    font-family:'JetBrains Mono',monospace;
    font-size:.58rem;
    color:rgba(255,255,255,.75);
    letter-spacing:.1em;
    white-space:nowrap;
}

/* ── Search mode header ───────────────────────────────────────────────── */

.search-mode-bar{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:12px;
    padding:18px 0 22px;
    border-bottom:1px solid var(--border);
    margin-bottom:30px;
}

.search-mode-label{
    font-family:'JetBrains Mono',monospace;
    font-size:.68rem;
    color:#555;
    letter-spacing:.06em;
}

.search-mode-label strong{ color:#ccc; font-weight:700; }

.search-mode-right{
    display:flex;
    align-items:center;
    gap:10px;
    flex-shrink:0;
}

.search-clear-btn{
    display:flex;
    align-items:center;
    gap:6px;
    font-family:'JetBrains Mono',monospace;
    font-size:.58rem;
    letter-spacing:.12em;
    text-transform:uppercase;
    background:none;
    border:1px solid #1e1e1e;
    color:#444;
    padding:.38rem .85rem;
    border-radius:7px;
    cursor:pointer;
    transition:border-color .15s, color .15s;
    white-space:nowrap;
}

.search-clear-btn:hover{ border-color:#333; color:#ccc; }

/* ── No results ───────────────────────────────────────────────────────── */

.no-results{
    text-align:center;
    padding:48px 40px;
    margin:40px auto;
    font-family:'JetBrains Mono',monospace;
    font-size:.65rem;
    letter-spacing:.2em;
    text-transform:uppercase;
    color:rgba(255,255,255,.7);
    display:flex;
    flex-direction:column;
    align-items:center;
    gap:16px;
    background:#0d0d0d;
    border:1px solid rgba(255,255,255,.1);
    border-radius:14px;
    max-width:320px;
    text-shadow:-1px -1px 0 #000,1px -1px 0 #000,-1px 1px 0 #000,1px 1px 0 #000;
}

/* ── Category sections ────────────────────────────────────────────────── */

.empty-cat{
    grid-column:1/-1;
    font-family:'JetBrains Mono',monospace;
    font-size:.7rem;
    letter-spacing:.2em;
    text-transform:uppercase;
    color:#222;
    text-align:center;
    padding:60px 0;
}

.cat-section{
    margin-bottom:80px;
    opacity:0;
    transform:translateY(24px);
    transition:opacity .55s cubic-bezier(.16,1,.3,1), transform .55s cubic-bezier(.16,1,.3,1);
}

.cat-section.revealed{ opacity:1; transform:translateY(0); }

.cat-header{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:16px;
    margin-bottom:18px;
    padding:12px 16px 12px 20px;
    background:#0d0d0d;
    border:1px solid rgba(255,255,255,.07);
    border-left:3px solid var(--cat-accent, var(--cyan));
    border-radius:0 8px 8px 0;
    width:100%;
    box-sizing:border-box;
}

.cat-title{
    font-size:1.5rem;
    font-weight:900;
    letter-spacing:-.03em;
    font-style:italic;
    text-transform:uppercase;
    line-height:1;
    margin-bottom:4px;
    text-shadow:-2px -2px 0 #000,2px -2px 0 #000,-2px 2px 0 #000,2px 2px 0 #000,0 -2px 0 #000,0 2px 0 #000,-2px 0 0 #000,2px 0 0 #000;
    color:var(--cat-accent, #fff);
}

.cat-sub{
    font:.6rem 'JetBrains Mono';
    color:rgba(255,255,255,.5);
    letter-spacing:.15em;
    text-transform:uppercase;
}

.cat-view-all{
    font:.58rem 'JetBrains Mono',monospace;
    letter-spacing:.15em;
    text-transform:uppercase;
    text-decoration:none;
    padding:.38rem .8rem;
    border-radius:6px;
    border:1px solid rgba(255,255,255,.25);
    background:#111;
    color:rgba(255,255,255,.85);
    opacity:1;
    transition:background .2s, border-color .2s;
    white-space:nowrap;
    flex-shrink:0;
}

.cat-view-all:hover{ background:#1e1e1e; border-color:rgba(255,255,255,.45); color:#fff; }

/* ── Grid ─────────────────────────────────────────────────────────────── */

.grid{
    display:grid;
    grid-template-columns:repeat(auto-fill,minmax(255px,1fr));
    gap:18px;
}

/* ── Product card ─────────────────────────────────────────────────────── */

.product-card{
    background:linear-gradient(180deg,var(--surface),var(--surface2));
    border:1px solid var(--card-border, var(--border));
    border-radius:14px;
    overflow:hidden;
    display:flex;
    flex-direction:column;
    opacity:0;
    transform:translateY(24px) scale(.96);
    transition:opacity .55s cubic-bezier(.16,1,.3,1), transform .55s cubic-bezier(.16,1,.3,1), border-color .3s ease, box-shadow .38s ease;
    position:relative;
}

.product-card.revealed{
    opacity:1;
    transform:translateY(0) scale(1);
}

.product-card.revealed:hover{
    transform:translateY(-8px) scale(1.015);
    border-color:var(--card-color, rgba(34,211,238,.8));
    box-shadow:
        0 30px 70px var(--card-shadow-color, rgba(0,0,0,.55)),
        0 0 0 1px var(--card-color, rgba(34,211,238,.15)),
        inset 0 1px 0 rgba(255,255,255,.04);
}

.card-img-wrap{
    position:relative;
    aspect-ratio:16/9;
    overflow:hidden;
    background:#070707;
    flex-shrink:0;
}

/* Shimmer sweep */
.card-img-wrap::before{
    content:'';
    display:block;
    position:absolute;
    top:0;
    left:-80%;
    width:55%;
    height:100%;
    background:linear-gradient(105deg,transparent,rgba(255,255,255,.07),transparent);
    transform:skewX(-20deg);
    z-index:2;
    pointer-events:none;
}

.product-card.revealed:hover .card-img-wrap::before{
    animation:cardShimmer .8s cubic-bezier(.4,0,.2,1) forwards;
}

@keyframes cardShimmer{
    0%  { left:-80%; }
    100%{ left:150%; }
}

.card-img-wrap::after{
    content:'';
    position:absolute;
    inset:0;
    background:linear-gradient(to bottom,transparent 45%,rgba(5,5,5,.55) 100%);
    pointer-events:none;
}

.card-img-wrap img{
    width:100%;
    height:100%;
    object-fit:cover;
    transition:transform .7s cubic-bezier(.16,1,.3,1);
}

.product-card.revealed:hover img{ transform:scale(1.07); }


.card-badge-trending{
    position:absolute;
    bottom:10px;
    right:10px;
    font:.5rem 'JetBrains Mono';
    padding:.22rem .6rem;
    border-radius:4px;
    letter-spacing:.11em;
    text-transform:uppercase;
    color:#f97316;
    border:1px solid rgba(249,115,22,.35);
    background:rgba(249,115,22,.09);
    backdrop-filter:blur(8px);
    animation:_trendPulse 2.4s ease-in-out infinite;
    z-index:1;
}

@keyframes _trendPulse{ 0%,100%{opacity:1;} 50%{opacity:.55;} }

.card-body{
    padding:14px 15px 15px;
    display:flex;
    flex-direction:column;
    flex:1;
}

.card-title{
    font-weight:800;
    text-transform:uppercase;
    font-size:.9rem;
    line-height:1.25;
    letter-spacing:-.01em;
    display:-webkit-box;
    -webkit-line-clamp:2;
    -webkit-box-orient:vertical;
    overflow:hidden;
}

.card-meta{
    display:flex;
    align-items:center;
    gap:5px;
    margin-top:8px;
    margin-bottom:8px;
    flex-wrap:wrap;
}

.card-chip{
    display:inline-flex;
    align-items:center;
    gap:4px;
    font:.52rem 'JetBrains Mono',monospace;
    color:#555;
    letter-spacing:.06em;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
    background:rgba(255,255,255,.02);
    border:1px solid #1e1e1e;
    border-radius:4px;
    padding:2px 7px 2px 5px;
}

.card-footer{
    display:flex;
    justify-content:space-between;
    align-items:center;
    border-top:1px solid var(--border);
    padding-top:11px;
    margin-top:auto;
}

.card-price{
    font:.83rem 'JetBrains Mono';
    font-weight:700;
    transition:color .2s ease;
}

.price-free{ color:#22c55e; }

/* ── Buttons ──────────────────────────────────────────────────────────── */

.btn-view{
    font:.58rem 'JetBrains Mono';
    letter-spacing:.15em;
    text-transform:uppercase;
    padding:.5rem .88rem;
    border-radius:5px;
    border:1px solid var(--card-color, var(--cyan));
    color:var(--card-color, var(--cyan));
    background:transparent;
    text-decoration:none;
    transition:transform .25s cubic-bezier(.16,1,.3,1), box-shadow .25s ease;
    white-space:nowrap;
    position:relative;
    overflow:hidden;
}

.btn-view::before{
    content:'';
    position:absolute;
    inset:0;
    background:var(--card-color, var(--cyan));
    opacity:.1;
    transform:scaleX(0);
    transform-origin:left;
    transition:transform .3s cubic-bezier(.16,1,.3,1);
}

.btn-view:hover::before{ transform:scaleX(1); }

.btn-view:hover{
    transform:translateY(-2px);
    box-shadow:0 8px 24px var(--card-shadow-color, rgba(34,211,238,.15));
}

/* ── Skeleton ─────────────────────────────────────────────────────────── */

.skeleton-title,
.skeleton-sub,
.sk-img,
.sk-line{
    background:linear-gradient(90deg,#111,#1c1c1c,#111);
    background-size:200% 100%;
    animation:shimmer 1.2s infinite;
    border-radius:6px;
}

.skeleton-title{ width:160px; height:16px; margin-bottom:8px; }
.skeleton-sub  { width:100px; height:11px; opacity:.6; }

.skeleton-card{
    background:var(--surface);
    border:1px solid var(--border);
    border-radius:14px;
    padding:12px;
}

.sk-img{ height:130px; margin-bottom:10px; }
.sk-line{ height:9px; margin-bottom:7px; }
.sk-line.short{ width:60%; }

/* ── Animations ───────────────────────────────────────────────────────── */

@keyframes heroIn{
    from{opacity:0;transform:translateY(22px)}
    to  {opacity:1;transform:translateY(0)}
}

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

/* ── Scrollbar ────────────────────────────────────────────────────────── */

::-webkit-scrollbar{ width:6px; }
::-webkit-scrollbar-thumb{ background:#1a1a1a; border-radius:10px; }

/* ── Responsive ───────────────────────────────────────────────────────── */

@media(max-width:900px){
    .cat-cards-row{ gap:8px; grid-template-columns:repeat(auto-fill, minmax(140px, 1fr)); }
    .cat-card{ padding:12px 14px; }
}

@media(max-width:768px){

    .hero{ padding:40px 20px 60px; }

    .hero-search-wrap{ padding:11px 14px; }

    #heroSearchInput{ font-size:.9rem; }

    .hero-stats{
        flex-direction:column;
        width:100%;
        border-radius:10px;
    }

    .hero-stat{
        border-right:none;
        border-bottom:1px solid var(--border);
        padding:11px 18px;
        display:flex;
        align-items:center;
        gap:12px;
        text-align:left;
    }

    .hero-stat:last-child{ border-bottom:none; }

    .hero-stat span{
        display:inline;
        font-size:1.05rem;
        margin-bottom:0;
    }

    .store-center{ padding:0 14px 60px; }

    .cat-cards-row{
        grid-template-columns:repeat(auto-fill, minmax(150px, 1fr));
        margin-bottom:28px;
    }

    .store-controls{
        gap:10px;
        padding-top:16px;
        margin-bottom:24px;
    }

    .cat-section{ margin-bottom:50px; }

    .cat-title{ font-size:1.35rem; }

    .cat-header{ flex-wrap:wrap; gap:8px; }

    .cat-view-all{ font-size:.5rem; padding:.28rem .6rem; }

    .grid{
        grid-template-columns:repeat(auto-fill,minmax(200px,1fr));
        gap:13px;
    }

    .card-body{ padding:11px 12px 12px; }
}

@media(max-width:480px){

    .hero-title{ font-size:clamp(2.2rem,12vw,3.5rem); }

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

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

    .filter-pill{ font-size:.54rem; padding:.36rem .68rem; }

    .search-mode-bar{ flex-direction:column; align-items:flex-start; gap:10px; }
}

.hero-title{ text-shadow:0 0 90px rgba(34,211,238,.06); }
