html,body,#app{min-height:100%}body{margin:0}:root{--bg-dark: #0a0e27;--bg-card: #1a1a2e;--bg-hover: #16213e;--accent-blue: #00d4ff;--accent-purple: #a855f7;--accent-pink: #f72585;--text-primary: #ffffff;--text-secondary: #b4b4c8;--border-subtle: rgba(255, 255, 255, .08);--danger: #ff6b6b;--ok: #16a34a}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,PingFang SC,Microsoft YaHei,Noto Sans SC,Helvetica Neue,Arial,sans-serif;background:linear-gradient(180deg,#050812,#0b1120,#060912);color:var(--text-primary);min-height:100vh;overflow-x:hidden;position:relative}code{background:rgba(255,255,255,.08);border-radius:6px;padding:1px 6px}.cyber-bg,.cyber-grid,.cyber-scanlines,.cyber-particles{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none}.cyber-bg{z-index:-4;background:radial-gradient(circle at 15% 20%,rgba(0,212,255,.14),transparent 28%),radial-gradient(circle at 82% 18%,rgba(168,85,247,.14),transparent 26%),radial-gradient(circle at 68% 78%,rgba(247,37,133,.11),transparent 24%),linear-gradient(180deg,#050812,#0b1120 48%,#060912);filter:saturate(1.08)}.cyber-grid{z-index:-3;background-image:linear-gradient(rgba(0,212,255,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(0,212,255,.06) 1px,transparent 1px);background-size:44px 44px;-webkit-mask-image:radial-gradient(circle at center,rgba(0,0,0,.9),rgba(0,0,0,.35) 70%,transparent 100%);mask-image:radial-gradient(circle at center,rgba(0,0,0,.9),rgba(0,0,0,.35) 70%,transparent 100%);opacity:.38;transform:perspective(1200px) rotateX(78deg) scale(1.8) translateY(-10%);transform-origin:center top}.cyber-scanlines{z-index:-2;background:repeating-linear-gradient(to bottom,rgba(255,255,255,.02) 0,rgba(255,255,255,.02) 1px,transparent 1px,transparent 4px);opacity:.16}.cyber-scanlines:before{content:"";position:absolute;left:0;right:0;height:180px;background:linear-gradient(180deg,transparent,rgba(0,212,255,.12),rgba(168,85,247,.08),transparent);filter:blur(14px);animation:scanline-sweep 9s linear infinite}.cyber-particles{z-index:-1;overflow:hidden}.cyber-particle{position:absolute;width:3px;height:3px;border-radius:50%;background:rgba(0,212,255,.8);box-shadow:0 0 10px #00d4ffb3,0 0 22px #a855f740;opacity:0;animation:particle-drift linear infinite}.navbar{background:rgba(10,14,39,.95);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--border-subtle)}.navbar-inner{max-width:1400px;margin:0 auto;padding:14px 24px;display:flex;justify-content:center;align-items:center;gap:16px}.nav-logo{font-size:20px;font-weight:900;background:linear-gradient(135deg,var(--accent-blue),var(--accent-purple),var(--accent-pink));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.container{max-width:1400px;margin:0 auto;padding:24px}.panel{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:14px;padding:18px;margin-bottom:16px}.panel-title{font-size:16px;font-weight:800;margin-bottom:12px}.btn{width:100%;border-radius:10px;border:1px solid var(--border-subtle);background:rgba(255,255,255,.03);color:#fff;min-height:42px;padding:0 12px;outline:none}.btn{cursor:pointer;font-weight:700;background:linear-gradient(135deg,var(--accent-blue),var(--accent-purple));border:none}.btn:disabled{opacity:.6;cursor:not-allowed}.btn.secondary{width:auto;padding:0 16px;background:rgba(255,255,255,.08);border:1px solid var(--border-subtle)}.ghost-btn{min-height:36px}.status{margin-top:10px;font-size:13px;color:var(--text-secondary)}.status.error{color:var(--danger)}.status.ok{color:#86efac}.category-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;gap:10px;flex-wrap:wrap}.header-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.badge{font-size:12px;padding:2px 10px;border-radius:999px;background:rgba(255,255,255,.08);color:var(--text-secondary)}.vendor-group{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:14px}.vendor-btn{width:100%;min-height:58px;padding:12px 14px;background:rgba(255,255,255,.06);border:1px solid var(--border-subtle);border-radius:14px;color:var(--text-primary);cursor:pointer;transition:transform .2s ease,border-color .2s ease,box-shadow .2s ease,background .2s ease;display:flex;align-items:center;justify-content:center;text-align:center}.vendor-btn:hover{transform:translateY(-2px);border-color:#00d4ff66;background:rgba(255,255,255,.09)}.vendor-btn.active{background:rgba(0,212,255,.14);border-color:#00d4ffbf;color:#dffbff;box-shadow:0 0 0 1px #00d4ff2e inset,0 8px 24px #00d4ff2e}.vendor-btn-title{font-size:14px;font-weight:700;line-height:1.35;white-space:normal;word-break:break-word}.vendor-loading{min-height:180px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;border-radius:14px;border:1px solid rgba(0,212,255,.14);background:rgba(255,255,255,.03)}.vendor-loading-ring{width:54px;height:54px;border-radius:50%;border:3px solid rgba(255,255,255,.1);border-top-color:var(--accent-blue);border-right-color:var(--accent-purple);box-shadow:0 0 18px #00d4ff38;animation:loading-spin .9s linear infinite}.vendor-loading-text{font-size:14px;color:#d8f7ff;letter-spacing:.4px}.game-grid{display:grid;grid-template-columns:repeat(8,minmax(0,1fr));gap:12px}.game-item{border-radius:12px;border:1px solid var(--border-subtle);overflow:hidden;background:var(--bg-card);cursor:pointer;transition:transform .2s ease,box-shadow .2s ease;position:relative;isolation:isolate}.game-item:before{content:"";position:absolute;top:-1px;right:-1px;bottom:-1px;left:-1px;border-radius:12px;background:linear-gradient(120deg,rgba(0,212,255,.1) 0%,rgba(0,212,255,.85) 24%,rgba(168,85,247,.82) 50%,rgba(247,37,133,.85) 76%,rgba(0,212,255,.12) 100%);background-size:220% 220%;opacity:0;z-index:-2;filter:blur(10px);transition:opacity .25s ease}.game-item:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:12px;background:linear-gradient(120deg,transparent 15%,rgba(0,212,255,.16) 45%,rgba(255,255,255,.22) 50%,rgba(247,37,133,.18) 60%,transparent 85%);transform:translate(-120%) skew(-18deg);opacity:0;z-index:1;pointer-events:none}.game-item:hover{transform:translateY(-4px);box-shadow:0 18px 36px #00000073,0 0 18px #00d4ff33,0 0 36px #a855f71f}.game-item:hover:before{opacity:1;animation:game-border-breathe 2.2s ease-in-out infinite,game-border-flow 4.4s linear infinite}.game-item:hover:after{opacity:1;animation:game-sheen 1.6s ease-in-out infinite}.game-item.disabled{cursor:not-allowed;opacity:.55;filter:grayscale(.2)}.game-item.disabled:hover{transform:none;box-shadow:none}.game-item.disabled:before,.game-item.disabled:after{display:none}.game-image{width:100%;aspect-ratio:1 / 1;object-fit:cover;display:block;background:var(--bg-hover);opacity:0;transition:opacity .28s ease}.game-image.loaded{opacity:1}.game-image-wrap{position:relative;aspect-ratio:1 / 1;background:linear-gradient(135deg,rgba(0,212,255,.08),rgba(168,85,247,.08)),var(--bg-hover);overflow:hidden}.game-image-loading{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,rgba(255,255,255,.03),rgba(255,255,255,.06)),var(--bg-hover);z-index:1;transition:opacity .28s ease,visibility .28s ease}.game-image-loading.hidden{opacity:0;visibility:hidden}.game-image-loading:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.08),transparent);transform:translate(-100%);animation:image-skeleton-sweep 1.4s ease-in-out infinite}.game-image-loading-ring{width:34px;height:34px;border-radius:50%;border:2px solid rgba(255,255,255,.14);border-top-color:var(--accent-blue);border-right-color:var(--accent-purple);box-shadow:0 0 16px #00d4ff33;animation:loading-spin .9s linear infinite}.game-name{padding:10px 10px 12px;font-size:12px;font-weight:600;text-align:center;line-height:1.45;min-height:54px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.game-tag{position:absolute;top:8px;right:8px;z-index:2;padding:3px 8px;border-radius:999px;font-size:11px;font-weight:700;color:#fff;background:rgba(0,0,0,.6);border:1px solid rgba(255,255,255,.12)}.game-tag.maintenance{background:rgba(220,68,70,.92);border-color:#ff6b6b66}.launch-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(0,0,0,.86);display:none;align-items:center;justify-content:center;padding:0;z-index:9999}.launch-overlay.show{display:flex}.launch-modal{width:100vw;height:100vh;background:#0b1120;border:none;border-radius:0;overflow:hidden;box-shadow:none;display:flex;flex-direction:column}.launch-head{background:rgba(5,8,18,.92);padding:12px 16px;font-size:13px;color:var(--text-secondary);display:flex;align-items:center;justify-content:space-between;gap:12px}.launch-title{min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.launch-close{width:auto;min-height:40px;padding:0 14px;border-radius:999px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.08);color:#fff;cursor:pointer}.launch-frame{width:100%;height:100%;border:none;background:#000;flex:1}.launch-frame-wrap{position:relative;flex:1;min-height:0;background:radial-gradient(circle at top,rgba(0,212,255,.12),transparent 35%),radial-gradient(circle at bottom right,rgba(168,85,247,.12),transparent 35%),#050812}.launch-loading{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(180deg,rgba(5,8,18,.92),rgba(7,12,24,.96)),radial-gradient(circle at center,rgba(0,212,255,.08),transparent 45%);z-index:2;transition:opacity .35s ease,visibility .35s ease}.launch-loading.hidden{opacity:0;visibility:hidden;pointer-events:none}.launch-loading-panel{position:relative;min-width:min(420px,82vw);padding:28px 26px;border-radius:20px;border:1px solid rgba(0,212,255,.26);background:linear-gradient(135deg,rgba(0,212,255,.08),rgba(168,85,247,.08),rgba(247,37,133,.08)),rgba(8,14,28,.9);box-shadow:inset 0 0 0 1px #ffffff0a,0 0 24px #00d4ff2e,0 0 50px #a855f729;overflow:hidden}.launch-loading-panel:after{content:"";position:absolute;top:-22%;right:-22%;bottom:-22%;left:-22%;background:radial-gradient(circle,rgba(0,212,255,.18),transparent 40%),radial-gradient(circle,rgba(168,85,247,.14),transparent 48%);animation:loading-pulse-glow 2.4s ease-in-out infinite}.launch-loading-panel:before{content:"";position:absolute;top:-40%;right:-40%;bottom:-40%;left:-40%;background:linear-gradient(90deg,transparent,rgba(0,212,255,.18),transparent);transform:rotate(18deg);animation:loading-scan 2.8s linear infinite}.launch-loading-inner{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;text-align:center;gap:12px}.launch-loading-ring{width:86px;height:86px;border-radius:50%;position:relative;background:radial-gradient(circle,rgba(255,255,255,.04) 0 45%,transparent 46%),conic-gradient(from 0deg,rgba(0,212,255,.08),rgba(0,212,255,.95),rgba(168,85,247,.95),rgba(247,37,133,.95),rgba(0,212,255,.08));animation:loading-spin 1.25s linear infinite;box-shadow:0 0 18px #00d4ff59,0 0 36px #a855f733}.launch-loading-ring:before{content:"";position:absolute;top:-14px;right:-14px;bottom:-14px;left:-14px;border-radius:50%;border:1px solid rgba(0,212,255,.2);box-shadow:0 0 28px #00d4ff33;animation:loading-halo-pulse 1.8s ease-in-out infinite}.launch-loading-ring:after{content:"";position:absolute;top:10px;right:10px;bottom:10px;left:10px;border-radius:50%;background:#08101d;box-shadow:inset 0 0 14px #00d4ff1f}.launch-loading-title{font-size:20px;font-weight:900;letter-spacing:1.5px;color:#fff;text-shadow:0 0 12px rgba(0,212,255,.85),0 0 28px rgba(168,85,247,.45)}.launch-loading-subtitle{font-size:13px;color:#d8f7ff;line-height:1.7;text-shadow:0 0 12px rgba(0,212,255,.18)}.launch-loading-bars{width:min(280px,76vw);display:flex;align-items:flex-end;justify-content:center;gap:8px;height:34px;margin-top:2px}.launch-loading-bars span{width:8px;border-radius:999px;background:linear-gradient(180deg,var(--accent-blue),var(--accent-purple),var(--accent-pink));box-shadow:0 0 14px #00d4ff61;animation:loading-bar 1.1s ease-in-out infinite}.launch-loading-bars span:nth-child(2){animation-delay:.1s}.launch-loading-bars span:nth-child(3){animation-delay:.2s}.launch-loading-bars span:nth-child(4){animation-delay:.3s}.launch-loading-bars span:nth-child(5){animation-delay:.4s}.launch-loading-bars span:nth-child(6){animation-delay:.5s}.launch-loading-bars span:nth-child(7){animation-delay:.6s}.launch-loading-error .launch-loading-ring{background:radial-gradient(circle,rgba(255,255,255,.04) 0 45%,transparent 46%),conic-gradient(from 0deg,rgba(255,107,107,.15),rgba(255,107,107,.95),rgba(247,37,133,.88),rgba(255,107,107,.15));animation-duration:2.4s}.launch-loading-error .launch-loading-title{text-shadow:0 0 12px rgba(255,107,107,.85),0 0 28px rgba(247,37,133,.4)}.tips{color:var(--text-secondary);font-size:12px;margin-top:10px;line-height:1.6}@keyframes cyber-border-flow{0%{background-position:0% 50%;filter:blur(14px) brightness(1)}50%{background-position:100% 50%;filter:blur(16px) brightness(1.15)}to{background-position:0% 50%;filter:blur(14px) brightness(1)}}@keyframes scanline-sweep{0%{transform:translateY(-120%);opacity:0}10%{opacity:1}50%{opacity:.85}to{transform:translateY(120vh);opacity:0}}@keyframes particle-drift{0%{transform:translateZ(0) scale(.5);opacity:0}10%{opacity:.8}90%{opacity:.55}to{transform:translate3d(var(--particle-x, 0),var(--particle-y, -160px),0) scale(1.3);opacity:0}}@keyframes game-border-flow{0%{background-position:0% 50%}to{background-position:200% 50%}}@keyframes game-border-breathe{0%,to{filter:blur(10px) brightness(1);opacity:.7}50%{filter:blur(14px) brightness(1.25);opacity:1}}@keyframes game-sheen{0%{transform:translate(-120%) skew(-18deg);opacity:0}18%{opacity:.9}50%{opacity:.55}to{transform:translate(140%) skew(-18deg);opacity:0}}@keyframes loading-spin{to{transform:rotate(360deg)}}@keyframes loading-scan{0%{transform:translate(-55%) rotate(18deg);opacity:0}12%{opacity:1}50%{opacity:1}to{transform:translate(55%) rotate(18deg);opacity:0}}@keyframes loading-bar{0%,to{height:10px;opacity:.5}50%{height:32px;opacity:1}}@keyframes loading-pulse-glow{0%,to{transform:scale(.92);opacity:.5}50%{transform:scale(1.08);opacity:1}}@keyframes loading-halo-pulse{0%,to{transform:scale(.94);opacity:.45}50%{transform:scale(1.08);opacity:1}}@keyframes image-skeleton-sweep{0%{transform:translate(-100%)}to{transform:translate(100%)}}@media (max-width: 1100px){.game-grid{grid-template-columns:repeat(5,minmax(0,1fr))}}@media (max-width: 768px){.container{padding:16px}.game-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.header-actions{width:100%;justify-content:space-between}.navbar-inner{padding:14px 16px}}
