/* ============================================================================
   assets/shop.css — TCGZen Shop (TCGplayer-powered sealed storefront)
   Dark TCGZen base + electric violet/blue glow accents. GOLD stays the Buy CTA
   (parity with card-page affiliate buttons). COLOR & LIFE come from three PHP-fed
   per-element hooks — do NOT remove/rename them:
     --ga  game accent   (on .sp-card, .sp-gbadge, .sp-cta-game, .sp-fchip)
     --tc  type accent   (on .sp-card, .sp-typechip, .sp-type)
     --rc  rail accent   (on .sp-rail / .sp-rail-title i)
   Loaded by shop.php, shop-category.php, shop-product.php, shop-watchlist.php.
   ============================================================================ */
.shop2{
  --sp-glow1:#7c5cff;        /* violet  */
  --sp-glow2:#2f7bff;        /* blue    */
  --sp-ink:#ece9ff;
  --sp-card:var(--bg-panel,#1a150e);
  --sp-line:var(--border,#2e2418);
  --sp-radius:16px;
  /* fallbacks so generic surfaces still get color even before a hook is set */
  --ga:var(--sp-glow1);
  --tc:var(--sp-glow2);
  --rc:var(--sp-glow1);
}
.shop2-wrap{max-width:1320px;margin:0 auto;padding:18px 20px 40px}
.shop2 .breadcrumb{margin-bottom:14px;font-size:12.5px}

/* ───── HERO ───── */
.sp-hero{position:relative;border:1px solid var(--sp-line);border-radius:22px;overflow:hidden;
  background:linear-gradient(180deg,#15131f,#0d0b14 60%,var(--bg,#0a0806));margin-bottom:22px}
.sp-hero-glow{position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(60% 90% at 8% -20%, rgba(124,92,255,.34), transparent 60%),
    radial-gradient(55% 90% at 95% 0%, rgba(47,123,255,.26), transparent 60%),
    radial-gradient(40% 80% at 60% 120%, rgba(218,165,32,.12), transparent 60%);
  filter:saturate(1.1)}
/* faint animated aurora drift so the hero breathes (paused when motion-reduced) */
.sp-hero::before{content:'';position:absolute;inset:-40%;pointer-events:none;z-index:0;opacity:.5;
  background:
    radial-gradient(38% 50% at 30% 40%, rgba(124,92,255,.20), transparent 60%),
    radial-gradient(34% 46% at 72% 60%, rgba(47,123,255,.16), transparent 60%);
  animation:spAurora 18s ease-in-out infinite alternate}
@keyframes spAurora{0%{transform:translate3d(-3%,-2%,0) rotate(0deg)}100%{transform:translate3d(4%,3%,0) rotate(8deg)}}
.sp-hero-inner{position:relative;z-index:1;padding:38px 32px 30px}
.sp-eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:11px;font-weight:800;letter-spacing:.12em;
  text-transform:uppercase;color:#cdbcff;margin-bottom:14px}
.sp-live-dot{width:8px;height:8px;border-radius:50%;background:#3ad28a;box-shadow:0 0 0 0 rgba(58,210,138,.7);animation:spPulse 2s infinite}
@keyframes spPulse{0%{box-shadow:0 0 0 0 rgba(58,210,138,.55)}70%{box-shadow:0 0 0 7px rgba(58,210,138,0)}100%{box-shadow:0 0 0 0 rgba(58,210,138,0)}}
.sp-hero h1{font-size:clamp(28px,4.4vw,46px);font-weight:900;line-height:1.04;letter-spacing:-.02em;margin:0 0 12px;
  background:linear-gradient(120deg,#fff 30%,#c9bbff 75%);-webkit-background-clip:text;background-clip:text;color:transparent}
.sp-hero p{color:var(--text-mid,#a08e70);font-size:15px;line-height:1.55;max-width:680px;margin:0 0 22px}
.sp-hero-search{display:flex;align-items:center;gap:10px;background:rgba(255,255,255,.04);border:1px solid rgba(124,92,255,.4);
  border-radius:14px;padding:7px 8px 7px 16px;max-width:680px;margin-bottom:20px;backdrop-filter:blur(6px)}
.sp-hero-search:focus-within{border-color:var(--sp-glow1);box-shadow:0 0 0 4px rgba(124,92,255,.16)}
.sp-hero-search i{width:20px;height:20px;color:#b9a9ff;flex-shrink:0}
.sp-hero-search input{flex:1;background:transparent;border:none;color:var(--text,#e8dcc0);font-size:15px;padding:9px 0}
.sp-hero-search input:focus{outline:none}
.sp-hero-search .btn{flex-shrink:0;border:none;cursor:pointer}
.sp-hero-ctas{display:flex;gap:9px;flex-wrap:wrap;margin-bottom:20px}
.sp-cta{display:inline-flex;align-items:center;gap:7px;padding:9px 15px;border-radius:11px;background:rgba(255,255,255,.05);
  border:1px solid var(--sp-line);color:var(--text,#e8dcc0);font-size:13px;font-weight:700;text-decoration:none;transition:.16s}
.sp-cta i{width:15px;height:15px}
.sp-cta:hover{transform:translateY(-2px);border-color:var(--sp-glow1);background:rgba(124,92,255,.14);color:#fff}
.sp-cta-primary{background:linear-gradient(120deg,var(--sp-glow1),var(--sp-glow2));border-color:transparent;color:#fff;
  box-shadow:0 8px 24px -10px rgba(124,92,255,.7)}
.sp-cta-primary:hover{filter:brightness(1.08);color:#fff}
/* per-game quick-pick chips: each wears its own game color, not one shared violet */
.sp-cta-game{border-color:color-mix(in srgb,var(--ga,#7c5cff) 32%,var(--sp-line))}
.sp-cta-game .dot{width:9px;height:9px;border-radius:50%;background:var(--ga,#a08e70);
  box-shadow:0 0 8px color-mix(in srgb,var(--ga,#7c5cff) 75%,transparent)}
.sp-cta-game:hover{transform:translateY(-2px);border-color:var(--ga,var(--sp-glow1));color:#fff;
  background:color-mix(in srgb,var(--ga,#7c5cff) 18%,transparent);
  box-shadow:0 8px 22px -12px color-mix(in srgb,var(--ga,#7c5cff) 85%,transparent)}
.sp-trust{display:flex;gap:20px;flex-wrap:wrap;font-size:12.5px;color:var(--text-mid,#a08e70)}
.sp-trust span{display:inline-flex;align-items:center;gap:7px}
.sp-trust i{width:15px;height:15px;color:#8fd6a8}

/* ───── TYPE NAV ───── */
/* each product-type chip carries its own --tc, so the row reads as a spectrum */
.sp-typenav{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:26px}
.sp-typechip{position:relative;display:inline-flex;align-items:center;gap:8px;padding:10px 15px;border-radius:12px;
  background:linear-gradient(150deg,color-mix(in srgb,var(--tc,#7c5cff) 10%,var(--sp-card)),var(--sp-card) 70%);
  border:1px solid color-mix(in srgb,var(--tc,#7c5cff) 26%,var(--sp-line));
  color:var(--text,#e8dcc0);font-size:13px;font-weight:700;text-decoration:none;overflow:hidden;
  transition:transform .16s,border-color .16s,box-shadow .16s,background .16s}
.sp-typechip i{width:17px;height:17px;color:var(--tc,#b9a9ff);
  filter:drop-shadow(0 0 5px color-mix(in srgb,var(--tc,#7c5cff) 60%,transparent))}
.sp-typechip:hover{transform:translateY(-3px);border-color:var(--tc,var(--sp-glow2));color:#fff;
  background:color-mix(in srgb,var(--tc,#7c5cff) 16%,var(--sp-card));
  box-shadow:0 10px 26px -14px color-mix(in srgb,var(--tc,#2f7bff) 95%,transparent)}
.sp-typechip-alt{border-style:dashed;background:var(--sp-card)}

/* ───── RAILS ───── */
/* the rail accent (--rc) now tints the header, leading bar AND scrollbar so each
   rail is recognizably its own color instead of an undifferentiated stack */
.sp-rail{position:relative;margin:0 0 32px;padding-left:14px}
.sp-rail::before{content:'';position:absolute;left:0;top:2px;bottom:18px;width:3px;border-radius:3px;
  background:linear-gradient(180deg,var(--rc,var(--sp-glow1)),color-mix(in srgb,var(--rc,#7c5cff) 8%,transparent));
  box-shadow:0 0 12px -2px color-mix(in srgb,var(--rc,#7c5cff) 70%,transparent)}
.sp-rail-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:13px}
.sp-rail-title{display:flex;align-items:center;gap:10px;min-width:0}
.sp-rail-title i{width:22px;height:22px;color:var(--rc,var(--sp-glow1));flex-shrink:0;
  filter:drop-shadow(0 0 8px color-mix(in srgb,var(--rc,#7c5cff) 62%,transparent))}
.sp-rail-title h2{font-size:clamp(17px,2.2vw,21px);font-weight:900;margin:0;letter-spacing:-.01em;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  background:linear-gradient(100deg,#fff 35%,color-mix(in srgb,var(--rc,#cdbcff) 75%,#fff) 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent}
.sp-rail-sub{font-size:12px;color:var(--text-mid,#a08e70);font-weight:600;white-space:nowrap;
  padding:3px 9px;border-radius:999px;border:1px solid color-mix(in srgb,var(--rc,#7c5cff) 24%,var(--sp-line));
  background:color-mix(in srgb,var(--rc,#7c5cff) 8%,transparent)}
.sp-rail-more{display:inline-flex;align-items:center;gap:3px;font-size:13px;font-weight:700;
  color:color-mix(in srgb,var(--rc,#b9a9ff) 80%,#fff);text-decoration:none;white-space:nowrap;flex-shrink:0;transition:.15s}
.sp-rail-more i{width:15px;height:15px;transition:transform .15s}
.sp-rail-more:hover{color:#fff}
.sp-rail-more:hover i{transform:translateX(3px)}
.sp-rail-track{display:flex;gap:14px;overflow-x:auto;scroll-snap-type:x proximity;padding:4px 2px 14px;
  scrollbar-width:thin;scrollbar-color:var(--rc,var(--sp-glow1)) transparent}
.sp-rail-track::-webkit-scrollbar{height:8px}
.sp-rail-track::-webkit-scrollbar-thumb{background:color-mix(in srgb,var(--rc,#7c5cff) 60%,transparent);border-radius:8px}
.sp-rail-track::-webkit-scrollbar-thumb:hover{background:var(--rc,var(--sp-glow1))}
.sp-rail-track>div{scroll-snap-align:start;flex:0 0 auto;width:200px}

/* ───── PRODUCT CARD ───── */
/* the card now wears both its game (--ga) and type (--tc) colors at rest, not only
   on hover: a soft top glow tinted by game + a type-tinted panel gradient */
.sp-card{display:flex;flex-direction:column;height:100%;
  background:
    linear-gradient(180deg,color-mix(in srgb,var(--tc,#7c5cff) 6%,transparent),transparent 30%),
    var(--sp-card);
  border:1px solid var(--sp-line);
  border-radius:var(--sp-radius);overflow:hidden;transition:transform .18s,border-color .18s,box-shadow .18s;position:relative}
.sp-card:hover{transform:translateY(-4px);border-color:color-mix(in srgb,var(--ga,#7c5cff) 60%,transparent);
  box-shadow:0 18px 40px -18px color-mix(in srgb,var(--ga,#7c5cff) 75%,transparent),
             0 0 0 1px color-mix(in srgb,var(--ga,#7c5cff) 32%,transparent)}
.sp-card::after{content:'';position:absolute;left:0;right:0;top:0;height:3px;border-radius:var(--sp-radius) var(--sp-radius) 0 0;
  background:linear-gradient(90deg,var(--ga,#7c5cff),color-mix(in srgb,var(--tc,#2f7bff) 80%,transparent) 55%,transparent 95%);
  opacity:.35;transition:opacity .18s;z-index:2}
.sp-card:hover::after{opacity:1}
.sp-imgwrap{position:relative;aspect-ratio:1/1;
  background:radial-gradient(circle at 50% 28%,color-mix(in srgb,var(--ga,#7c5cff) 16%,#1c1830),#0e0c16 78%);
  display:flex;align-items:center;justify-content:center;overflow:hidden}
.sp-imgwrap img{width:100%;height:100%;object-fit:contain;padding:10px;display:block;transition:transform .25s}
.sp-card:hover .sp-imgwrap img{transform:scale(1.06)}
.sp-ph{display:flex;align-items:center;justify-content:center;color:color-mix(in srgb,var(--tc,#b9a9ff) 55%,#5a4f6e)}
.sp-ph i{width:54px;height:54px}
.sp-ph-lg i{width:120px;height:120px}
.sp-gbadge{position:absolute;top:8px;left:8px;font-size:9.5px;font-weight:800;text-transform:uppercase;letter-spacing:.04em;
  color:#fff;background:linear-gradient(120deg,color-mix(in srgb,var(--ga,#7c5cff) 92%,#000),color-mix(in srgb,var(--ga,#7c5cff) 62%,#000));
  padding:3px 8px;border-radius:6px;z-index:2;box-shadow:0 3px 10px -4px color-mix(in srgb,var(--ga,#7c5cff) 80%,transparent)}
.sp-prebadge{position:absolute;top:8px;right:8px;font-size:9.5px;font-weight:800;text-transform:uppercase;color:#0d0b14;
  background:linear-gradient(120deg,#ffd97a,#e6b422);padding:3px 8px;border-radius:6px;z-index:2;
  box-shadow:0 3px 10px -4px rgba(218,165,32,.7)}
.sp-move{position:absolute;top:8px;right:8px;font-size:10px;font-weight:800;padding:3px 7px;border-radius:6px;z-index:2;
  box-shadow:0 2px 8px -3px rgba(0,0,0,.6)}
.sp-move.up{color:#ffb4a0;background:rgba(196,64,64,.88)}
.sp-move.down{color:#bff5cf;background:rgba(46,140,72,.88)}
.sp-body{display:flex;flex-direction:column;gap:5px;padding:11px 12px 12px;flex:1}
/* type label as a tinted pill — the strongest at-a-glance category signal */
.sp-type{display:inline-flex;align-items:center;gap:5px;align-self:flex-start;
  font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.05em;
  color:color-mix(in srgb,var(--tc,#b9a9ff) 78%,#fff);
  padding:3px 8px;border-radius:7px;border:1px solid color-mix(in srgb,var(--tc,#7c5cff) 30%,transparent);
  background:color-mix(in srgb,var(--tc,#7c5cff) 13%,transparent)}
.sp-type i{width:12px;height:12px}
.sp-name{font-size:13.5px;font-weight:800;line-height:1.25;color:var(--text,#e8dcc0);text-decoration:none;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:2.5em}
.sp-name:hover{color:#fff}
.sp-set{font-size:11px;color:var(--text-mid,#a08e70);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sp-etag{font-size:10.5px;font-weight:800;padding:3px 8px;border-radius:7px;align-self:flex-start}
.tag-hot{color:#ffd2c2;background:rgba(196,64,64,.22)}
.tag-collector{color:#ffe6a8;background:rgba(218,165,32,.2)}
.tag-starter{color:#bff5cf;background:rgba(46,140,72,.22)}
.tag-premium{color:#d8c9ff;background:rgba(124,92,255,.24)}
.tag-staff{color:#ffe6a8;background:rgba(218,165,32,.24)}
.tag-preorder{color:#cfe0ff;background:rgba(47,123,255,.22)}
.sp-price-row{display:flex;align-items:baseline;gap:8px;margin-top:auto;padding-top:4px}
.sp-price{font-family:'JetBrains Mono',monospace;font-weight:900;font-size:16px;color:#fff}
.sp-price.sp-na{font-size:12px;color:var(--text-mid,#a08e70);font-family:inherit}
.sp-low{font-size:11px;color:var(--text-mid,#a08e70)}
.sp-buy{display:flex;align-items:center;justify-content:center;gap:6px;margin-top:10px;padding:9px 10px;border-radius:10px;
  background:linear-gradient(120deg,var(--gold,#daa520),#e6b422);color:#1a150e;font-size:12.5px;font-weight:800;
  text-decoration:none;transition:.15s}
.sp-buy i{width:15px;height:15px}
.sp-buy:hover{filter:brightness(1.07);transform:translateY(-1px);box-shadow:0 8px 20px -10px rgba(218,165,32,.8)}
.sp-buy-alt{background:rgba(255,255,255,.06);color:var(--text,#e8dcc0);border:1px solid var(--sp-line)}
.sp-buy-alt:hover{border-color:var(--sp-glow1)}

/* watchlist heart */
.sp-watch{position:absolute;top:8px;right:8px;z-index:3;display:inline-flex;align-items:center;justify-content:center;
  width:30px;height:30px;border-radius:9px;border:1px solid var(--sp-line);background:rgba(13,11,20,.72);
  color:#cdbcff;cursor:pointer;backdrop-filter:blur(4px);transition:.15s;padding:0}
.sp-watch i{width:15px;height:15px;fill:none}
.sp-watch:hover{border-color:var(--sp-glow1);color:#fff;transform:scale(1.08)}
.sp-watch.on{color:#ff5c8a;border-color:#ff5c8a;background:rgba(255,92,138,.16)}
.sp-watch.on i{fill:#ff5c8a}
.sp-watch-lg{position:static;width:auto;height:auto;gap:7px;padding:15px 18px;border-radius:13px;font-size:14px;font-weight:700;background:rgba(255,255,255,.05);color:var(--text,#e8dcc0)}
.sp-watch-lg i{width:17px;height:17px}
.sp-watch-lg.on{color:#ff5c8a}

/* ───── SKELETONS ───── */
.sp-rail-skel{margin-bottom:30px}
.sp-skel-head{height:22px;width:240px;border-radius:7px;margin-bottom:14px;background:linear-gradient(90deg,#1a1726,#241f33,#1a1726);
  background-size:200% 100%;animation:spShimmer 1.4s infinite}
.sp-skel-track{display:flex;gap:14px;overflow:hidden}
.sp-skel-card{flex:0 0 auto;width:200px;height:300px;border-radius:var(--sp-radius);
  background:linear-gradient(90deg,#15131f,#211d30,#15131f);background-size:200% 100%;animation:spShimmer 1.4s infinite}
@keyframes spShimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}

/* ───── SINGLES CTA + DISCLOSURE ───── */
.sp-singles-cta{display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap;
  border:1px solid var(--sp-line);border-radius:18px;padding:22px 24px;margin:8px 0 26px;
  background:
    radial-gradient(120% 140% at 100% 0%,rgba(47,123,255,.12),transparent 55%),
    radial-gradient(90% 130% at 0% 100%,rgba(124,92,255,.10),transparent 55%),
    var(--sp-card)}
.sp-singles-cta h2{font-size:19px;font-weight:900;margin:0 0 4px}
.sp-singles-cta p{font-size:13.5px;color:var(--text-mid,#a08e70);margin:0;max-width:520px}
.sp-singles-cta .btn{flex-shrink:0}
.sp-disclosure{font-size:11.5px;line-height:1.6;color:var(--text-mid,#a08e70);text-align:center;max-width:820px;margin:18px auto 0}
.sp-disclosure a{color:var(--gold,#daa520);text-decoration:underline}

/* ───── CATEGORY ───── */
.sp-cat-head{display:flex;align-items:baseline;gap:14px;flex-wrap:wrap;margin:6px 0 16px}
.sp-cat-head h1{font-size:clamp(22px,3vw,30px);font-weight:900;margin:0;letter-spacing:-.01em;
  background:linear-gradient(100deg,#fff 40%,#c9bbff 100%);-webkit-background-clip:text;background-clip:text;color:transparent}
.sp-cat-count{font-size:13px;color:var(--text-mid,#a08e70)}
.sp-cat-search{display:flex;align-items:center;gap:10px;background:rgba(255,255,255,.04);border:1px solid rgba(124,92,255,.4);
  border-radius:13px;padding:6px 8px 6px 14px;margin-bottom:14px;max-width:640px}
.sp-cat-search:focus-within{border-color:var(--sp-glow1);box-shadow:0 0 0 3px rgba(124,92,255,.15)}
.sp-cat-search i{width:18px;height:18px;color:#b9a9ff}
.sp-cat-search input{flex:1;background:transparent;border:none;color:var(--text,#e8dcc0);font-size:14px;padding:8px 0}
.sp-cat-search input:focus{outline:none}
.sp-cat-search .btn{border:none;cursor:pointer}
.sp-intent{font-size:13px;color:var(--text-mid,#a08e70);margin-bottom:14px}
.sp-intent strong{color:#cdbcff}
.sp-filters{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;margin-bottom:18px}
.sp-filter-chips{display:flex;gap:7px;flex-wrap:wrap}
/* game filter chips ride their own --ga, so the filter row is multicolor too */
.sp-fchip{display:inline-flex;align-items:center;gap:6px;padding:7px 13px;border-radius:999px;background:var(--sp-card);
  border:1px solid var(--sp-line);color:var(--text-mid,#a08e70);font-size:12.5px;font-weight:700;text-decoration:none;transition:.15s}
.sp-fchip:hover{transform:translateY(-1px);color:var(--text,#e8dcc0);
  border-color:color-mix(in srgb,var(--ga,#7c5cff) 55%,transparent);
  background:color-mix(in srgb,var(--ga,#7c5cff) 9%,var(--sp-card))}
.sp-fchip.on{background:color-mix(in srgb,var(--ga,#7c5cff) 20%,transparent);border-color:var(--ga,var(--sp-glow1));color:#fff;
  box-shadow:0 6px 18px -10px color-mix(in srgb,var(--ga,#7c5cff) 85%,transparent)}
.sp-fchip .dot{width:8px;height:8px;border-radius:50%;background:var(--ga,#a08e70);
  box-shadow:0 0 7px color-mix(in srgb,var(--ga,#7c5cff) 70%,transparent)}
.sp-chip-sep{width:1px;height:20px;background:var(--sp-line);margin:0 4px;align-self:center}
.sp-filter-right{display:flex;gap:9px;flex-wrap:wrap}
.sp-select{background:var(--sp-card);border:1px solid var(--sp-line);border-radius:10px;color:var(--text,#e8dcc0);
  padding:8px 12px;font-size:13px;font-weight:600;cursor:pointer;color-scheme:dark;transition:border-color .15s}
.sp-select:hover{border-color:color-mix(in srgb,var(--sp-glow1) 50%,var(--sp-line))}
.sp-select option{background:var(--bg-panel,#1a150e);color:var(--text,#e8dcc0)}
.sp-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(185px,1fr));gap:16px}
.sp-empty{text-align:center;padding:64px 20px;color:var(--text-mid,#a08e70)}
.sp-empty-ico i{width:54px;height:54px;opacity:.5;color:#6b5f80}
.sp-empty p{margin:12px 0 18px}

/* ───── PRODUCT DETAIL ───── */
.sp-detail{display:grid;grid-template-columns:minmax(280px,440px) 1fr;gap:34px;margin:8px 0 30px;align-items:start}
.sp-detail-media{position:sticky;top:90px}
.sp-detail-imgwrap{position:relative;border:1px solid color-mix(in srgb,var(--ga,#7c5cff) 26%,var(--sp-line));border-radius:20px;overflow:hidden;
  background:radial-gradient(circle at 50% 22%,color-mix(in srgb,var(--ga,#7c5cff) 18%,#1c1830),#0d0b14 80%);
  aspect-ratio:1/1;display:flex;align-items:center;justify-content:center;
  box-shadow:0 24px 60px -34px color-mix(in srgb,var(--ga,#7c5cff) 70%,transparent)}
.sp-detail-imgwrap img{width:100%;height:100%;object-fit:contain;padding:22px;display:block}
.sp-detail-info{min-width:0}
.sp-detail-type{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:800;text-transform:uppercase;
  letter-spacing:.06em;color:color-mix(in srgb,var(--tc,#b9a9ff) 78%,#fff);margin-bottom:8px;
  padding:4px 10px;border-radius:8px;border:1px solid color-mix(in srgb,var(--tc,#7c5cff) 30%,transparent);
  background:color-mix(in srgb,var(--tc,#7c5cff) 12%,transparent)}
.sp-detail-type i{width:15px;height:15px}
.sp-detail-name{font-size:clamp(22px,3.2vw,32px);font-weight:900;line-height:1.12;letter-spacing:-.01em;margin:0 0 8px}
.sp-detail-set{display:inline-block;font-size:14px;color:#cdbcff;text-decoration:none;font-weight:600;margin-bottom:6px}
.sp-detail-set:hover{text-decoration:underline}
.sp-price-panel{position:relative;border:1px solid color-mix(in srgb,var(--ga,#7c5cff) 22%,var(--sp-line));border-radius:16px;
  padding:18px 20px;margin:18px 0;overflow:hidden;
  background:
    radial-gradient(120% 120% at 0% 0%,color-mix(in srgb,var(--ga,#7c5cff) 16%,transparent),transparent 55%),
    var(--sp-card)}
.sp-pp-market{display:flex;align-items:baseline;gap:12px;flex-wrap:wrap}
.sp-pp-label{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-mid,#a08e70)}
.sp-pp-value{font-family:'JetBrains Mono',monospace;font-size:34px;font-weight:900;color:#fff;line-height:1}
.sp-pp-value.sp-na{font-size:18px;font-family:inherit;color:var(--text-mid,#a08e70)}
.sp-pp-grid{display:flex;gap:22px;margin-top:14px;padding-top:14px;border-top:1px solid var(--sp-line)}
.sp-pp-grid>div{display:flex;flex-direction:column;gap:2px}
.sp-pp-grid span{font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--text-mid,#a08e70)}
.sp-pp-grid strong{font-family:'JetBrains Mono',monospace;font-size:16px;color:var(--text,#e8dcc0)}
.sp-pp-fresh{display:flex;align-items:center;gap:7px;flex-wrap:wrap;font-size:11.5px;color:var(--text-mid,#a08e70);margin-top:14px}
.sp-pp-fresh i{width:14px;height:14px}
.sp-detail-cta{display:flex;gap:12px;flex-wrap:wrap;align-items:center;margin-bottom:10px}
.sp-buy-lg{margin-top:0;padding:15px 26px;font-size:15.5px;border-radius:13px;flex:1;min-width:240px}
.sp-buy-lg i{width:19px;height:19px}
.sp-share{display:inline-flex;align-items:center;gap:7px;padding:15px 18px;border-radius:13px;background:rgba(255,255,255,.05);
  border:1px solid var(--sp-line);color:var(--text,#e8dcc0);font-size:14px;font-weight:700;cursor:pointer;transition:.15s}
.sp-share:hover{border-color:var(--sp-glow1);color:#fff}
.sp-share i{width:17px;height:17px}
.sp-detail-note{font-size:12px;color:var(--text-mid,#a08e70);line-height:1.5;margin:6px 0 16px}
.sp-detail-note a{color:var(--gold,#daa520);text-decoration:underline}
.sp-tiein{display:flex;gap:10px;flex-wrap:wrap}
.sp-tiein a{display:inline-flex;align-items:center;gap:7px;font-size:13px;font-weight:700;color:#cdbcff;text-decoration:none;
  padding:9px 14px;border-radius:10px;border:1px solid var(--sp-line);background:var(--sp-card);transition:.15s}
.sp-tiein a:hover{transform:translateY(-2px);border-color:var(--sp-glow2);color:#fff;
  background:color-mix(in srgb,var(--sp-glow2) 10%,var(--sp-card))}
.sp-tiein i{width:15px;height:15px}

/* ───── RESPONSIVE ───── */
@media(max-width:860px){
  .sp-detail{grid-template-columns:1fr;gap:22px}
  .sp-detail-media{position:static;max-width:380px;margin:0 auto}
}
@media(max-width:600px){
  .sp-hero-inner{padding:26px 18px 22px}
  .sp-rail{padding-left:11px;margin-bottom:26px}
  .sp-rail::before{bottom:16px}
  .sp-rail-track>div{width:158px}
  .sp-skel-card{width:158px;height:250px}
  .sp-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}
  .sp-trust{gap:12px;font-size:11.5px}
  .sp-buy-lg{min-width:0;width:100%}
  .sp-detail-cta{gap:10px}
  .sp-rail-sub{display:none}            /* keep the mobile rail header clean */
}

/* ───── MOTION SAFETY ───── */
@media(prefers-reduced-motion:reduce){
  .sp-hero::before{animation:none}
  .sp-live-dot{animation:none}
  .sp-skel-head,.sp-skel-card{animation:none}
  .sp-card,.sp-typechip,.sp-cta,.sp-cta-game,.sp-fchip,.sp-tiein a,.sp-rail-more i,
  .sp-card .sp-imgwrap img,.sp-buy,.sp-watch{transition:none}
  .sp-card:hover,.sp-typechip:hover,.sp-cta-game:hover,.sp-fchip:hover,.sp-tiein a:hover{transform:none}
  .sp-card:hover .sp-imgwrap img{transform:none}
}
