.upsell-overlay{position:fixed;inset:0;z-index:9999;background:#000000c7;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;animation:upsell-fade-in .25s ease-out}.upsell-modal{width:90%;max-width:780px;max-height:92vh;background:linear-gradient(160deg,#1a1a2e,#0f3460);border-radius:20px;border:1px solid rgba(168,85,247,.2);box-shadow:0 24px 60px #0009,0 0 40px #a855f714;display:flex;flex-direction:column;overflow:hidden;animation:upsell-slide-up .3s ease-out}.upsell-header{display:flex;align-items:center;justify-content:space-between;padding:.875rem 1.25rem;flex-shrink:0;border-bottom:1px solid rgba(255,255,255,.06)}.upsell-header-spacer{width:36px;display:block}.upsell-nav-btn{width:36px;height:36px;border-radius:50%;background:#ffffff14;border:1px solid rgba(255,255,255,.12);color:#bbb;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s,color .2s;flex-shrink:0}.upsell-nav-btn:hover{background:#ffffff26;color:#fff}.upsell-progress{display:flex;gap:8px;align-items:center}.progress-dot{width:8px;height:8px;border-radius:50%;background:#ffffff2e;transition:all .3s ease;flex-shrink:0}.progress-dot.active{width:22px;border-radius:4px;background:#ff4682;box-shadow:0 0 10px #ff46828c}.progress-dot.done{background:#a855f7}.choice-step{display:flex;flex-direction:column;align-items:center;text-align:center;padding:2.25rem 2rem 2.5rem;overflow-y:auto}.upsell-icon-circle{width:80px;height:80px;background:linear-gradient(135deg,#ff4682,#a855f7);border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:1.5rem;box-shadow:0 8px 24px #a855f759;flex-shrink:0}.upsell-title{font-size:1.75rem;font-weight:700;color:#fff;margin:0 0 .5rem;line-height:1.2}.upsell-subtitle{font-size:.95rem;color:#a0a0c0;margin:0 0 2rem;line-height:1.5}.choice-cards{display:grid;grid-template-columns:1fr 1fr;gap:1rem;width:100%;max-width:460px;margin-bottom:1.75rem}.choice-card{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:2rem 1rem;display:flex;flex-direction:column;align-items:center;text-align:center;cursor:pointer;transition:transform .2s ease,background .2s ease,border-color .2s ease,box-shadow .2s ease;color:inherit}.choice-card:hover{transform:translateY(-4px);background:#ffffff14;border-color:#ff4682;box-shadow:0 8px 24px #ff46822e}.choice-card-icon{margin-bottom:1rem}.choice-card-name{font-size:1.05rem;font-weight:600;color:#fff;margin-bottom:.4rem;display:block}.choice-card-desc{font-size:.8rem;color:#888;line-height:1.4;display:block}.upsell-skip-link{background:none;border:none;color:#666;font-size:.875rem;cursor:pointer;padding:.4rem .75rem;transition:color .2s;text-decoration:underline;text-underline-offset:3px;white-space:nowrap}.upsell-skip-link:hover{color:#aaa}.content-step{display:flex;flex-direction:column;flex:1;overflow:hidden;min-height:0}.step-title{font-size:1.4rem;font-weight:700;color:#fff;margin:0;padding:1.25rem 1.5rem .25rem;flex-shrink:0}.step-subtitle{font-size:.875rem;color:#a0a0c0;margin:0;padding:0 1.5rem .875rem;flex-shrink:0}.step-scroll-body{flex:1;overflow-y:auto;padding:0 1.25rem .75rem;scrollbar-width:thin;scrollbar-color:rgba(168,85,247,.4) transparent}.step-scroll-body::-webkit-scrollbar{width:4px}.step-scroll-body::-webkit-scrollbar-track{background:transparent}.step-scroll-body::-webkit-scrollbar-thumb{background:#a855f766;border-radius:2px}.upsell-loading{display:flex;justify-content:center;align-items:center;min-height:220px}.upsell-spinner{width:40px;height:40px;border:3px solid rgba(255,255,255,.1);border-top-color:#ff4682;border-radius:50%;animation:upsell-spin .8s linear infinite}.upsell-empty{text-align:center;color:#777;padding:3rem 1rem;font-size:.9rem}.games-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem}.game-card{background:#ffffff0a;border:2px solid transparent;border-radius:12px;overflow:hidden;cursor:pointer;position:relative;display:flex;flex-direction:column;text-align:left;color:inherit;padding:0;transition:background .2s ease,border-color .2s ease,box-shadow .2s ease}.game-card:hover{background:#ffffff12;border-color:#ff468273}.game-card.selected{border-color:#ff4682;box-shadow:0 0 16px #ff468247}.game-card-check{position:absolute;top:8px;right:8px;width:22px;height:22px;background:#ff4682;border-radius:50%;display:flex;align-items:center;justify-content:center;z-index:2;color:#fff}.game-card-badge{position:absolute;top:8px;left:8px;background:#000000a6;backdrop-filter:blur(4px);color:#fff;font-size:.62rem;font-weight:700;padding:.18rem .45rem;border-radius:20px;z-index:2;text-transform:uppercase;letter-spacing:.05em}.game-card-img-wrap{width:100%;aspect-ratio:3 / 4;background:#0000004d;overflow:hidden;flex-shrink:0}.game-card-img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease;display:block}.game-card:hover .game-card-img{transform:scale(1.05)}.game-card-img-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.game-card-info{padding:.6rem .7rem .75rem;display:flex;flex-direction:column;gap:.18rem}.game-card-name{font-size:.78rem;font-weight:600;color:#e0e0f0;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.game-card-desc{font-size:.68rem;color:#777;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}.game-card-price{font-size:.72rem;color:#a855f7;font-weight:600;margin-top:.15rem}.addons-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.addon-card{background:#ffffff0a;border:2px solid transparent;border-radius:12px;padding:.875rem;display:flex;gap:.875rem;transition:border-color .2s ease,background .2s ease}.addon-card.added{border-color:#a855f7;background:#a855f712}.addon-card-img{width:68px;height:68px;border-radius:8px;object-fit:cover;flex-shrink:0}.addon-card-img-placeholder{width:68px;height:68px;border-radius:8px;background:#ffffff0f;display:flex;align-items:center;justify-content:center;flex-shrink:0}.addon-card-info{flex:1;display:flex;flex-direction:column;gap:.2rem;min-width:0}.addon-card-name{font-size:.85rem;font-weight:600;color:#e0e0f0;line-height:1.3}.addon-card-desc{font-size:.73rem;color:#777;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.addon-card-footer{display:flex;align-items:center;justify-content:space-between;margin-top:auto;padding-top:.5rem;gap:.5rem}.addon-card-price{font-size:.78rem;color:#a855f7;font-weight:600}.addon-toggle-btn{background:#a855f724;border:1px solid rgba(168,85,247,.4);color:#c084fc;font-size:.73rem;font-weight:700;padding:.28rem .65rem;border-radius:20px;cursor:pointer;transition:background .2s,border-color .2s,color .2s;white-space:nowrap;flex-shrink:0}.addon-toggle-btn:hover{background:#a855f740}.addon-toggle-btn.added{background:#a855f7;border-color:#a855f7;color:#fff}.upsell-footer{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem 1.5rem;background:#080818eb;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-top:1px solid rgba(255,255,255,.08);flex-shrink:0}.footer-summary{font-size:.875rem;color:#b0b0cc;font-weight:500;white-space:nowrap}.footer-actions{display:flex;align-items:center;gap:.875rem;flex-shrink:0}.upsell-cta-btn{background:linear-gradient(90deg,#ff4682,#a855f7);border:none;border-radius:50px;color:#fff;font-size:.9rem;font-weight:700;padding:.7rem 1.5rem;cursor:pointer;transition:opacity .2s,transform .2s,box-shadow .2s;white-space:nowrap}.upsell-cta-btn:hover{opacity:.9;transform:translateY(-1px);box-shadow:0 6px 20px #ff468259}.upsell-cta-btn:active{transform:translateY(0);opacity:1}@keyframes upsell-fade-in{0%{opacity:0}to{opacity:1}}@keyframes upsell-slide-up{0%{transform:translateY(22px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes upsell-spin{to{transform:rotate(360deg)}}@media(max-width:600px){.choice-cards{grid-template-columns:1fr;max-width:100%}.games-grid{grid-template-columns:repeat(2,1fr)}.addons-grid{grid-template-columns:1fr}.upsell-footer{flex-direction:column;align-items:stretch;text-align:center}.footer-actions{justify-content:center;flex-wrap:wrap}.upsell-title{font-size:1.4rem}.step-title{font-size:1.2rem}.upsell-cta-btn{width:100%;justify-content:center}}
