/* ══════════════════════════════════════
   RIBBETSHOP — STYLES v2
   Frog-themed dark purple/pink
══════════════════════════════════════ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#0b0c1b;--bg2:#0f1126;--surface:#141630;--surface2:#1a1d3a;
  --border:rgba(192,38,211,.18);--border-glow:rgba(192,38,211,.45);
  --primary:#c026d3;--primary-dk:#a21caf;--secondary:#7c3aed;
  --gradient:linear-gradient(135deg,#c026d3 0%,#7c3aed 100%);
  --gradient-h:linear-gradient(135deg,#d946ef 0%,#8b5cf6 100%);
  --cyan:#06b6d4;--green:#10b981;--orange:#f59e0b;--red:#ef4444;
  --text:#f1f5f9;--text2:#cbd5e1;--text3:#64748b;
  --nav-h:68px;--radius:12px;--radius-lg:20px;
  --shadow:0 4px 24px rgba(0,0,0,.55);--shadow-lg:0 8px 48px rgba(0,0,0,.75);
  --glow:0 0 32px rgba(192,38,211,.3);--transition:.22s cubic-bezier(.4,0,.2,1);
}
html{scroll-behavior:smooth}
body{font-family:'Inter',sans-serif;background:var(--bg);color:var(--text);min-height:100vh;overflow-x:hidden;line-height:1.6}
.bg-texture{position:fixed;inset:0;z-index:0;pointer-events:none;background-color:var(--bg);background-image:repeating-linear-gradient(-45deg,rgba(192,38,211,.035) 0,rgba(192,38,211,.035) 1px,transparent 1px,transparent 18px),repeating-linear-gradient(45deg,rgba(124,58,237,.03) 0,rgba(124,58,237,.03) 1px,transparent 1px,transparent 18px)}
#app{position:relative;z-index:1}
a{text-decoration:none;color:inherit}button{cursor:pointer;font-family:inherit;border:none;background:none}
ul{list-style:none}img{display:block;max-width:100%}.full-width{width:100%}

/* ── BUTTONS ── */
.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 24px;background:var(--gradient);color:#fff;font-weight:600;font-size:.9rem;border-radius:8px;cursor:pointer;transition:var(--transition);white-space:nowrap;border:none}
.btn-primary:hover{background:var(--gradient-h);box-shadow:var(--glow);transform:translateY(-1px)}
.btn-outline{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:9px 22px;background:transparent;color:var(--text);font-weight:600;font-size:.9rem;border-radius:8px;border:1.5px solid rgba(192,38,211,.45);cursor:pointer;transition:var(--transition);white-space:nowrap}
.btn-outline:hover{border-color:var(--primary);color:var(--primary);background:rgba(192,38,211,.08)}
.btn-ghost{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 24px;background:rgba(255,255,255,.08);color:var(--text);font-weight:600;font-size:.9rem;border-radius:8px;border:1.5px solid rgba(255,255,255,.12);cursor:pointer;transition:var(--transition);white-space:nowrap}
.btn-ghost:hover{background:rgba(255,255,255,.14)}
.btn-lg{padding:13px 32px;font-size:1rem;border-radius:10px}

/* ── TOAST ── */
.toast{position:fixed;bottom:28px;right:28px;z-index:9999;padding:14px 22px;border-radius:10px;font-size:.9rem;font-weight:500;color:#fff;background:var(--surface2);border:1px solid var(--border);box-shadow:var(--shadow-lg);opacity:0;transform:translateY(12px);transition:opacity .3s,transform .3s;pointer-events:none;max-width:320px}
.toast.show{opacity:1;transform:translateY(0)}
.toast.success{border-color:rgba(16,185,129,.5);background:rgba(16,185,129,.15)}
.toast.error{border-color:rgba(239,68,68,.5);background:rgba(239,68,68,.15)}
.toast.info{border-color:rgba(6,182,212,.5);background:rgba(6,182,212,.12)}

/* ── NAVBAR ── */
#navbar{position:fixed;top:0;left:0;right:0;height:var(--nav-h);z-index:500;background:rgba(11,12,27,.7);border-bottom:1px solid var(--border);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);transition:background var(--transition),box-shadow var(--transition)}
#navbar.scrolled{background:rgba(11,12,27,.97);box-shadow:0 4px 32px rgba(0,0,0,.5)}
.nav-inner{max-width:1280px;margin:0 auto;height:100%;padding:0 24px;display:flex;align-items:center;gap:16px}
.nav-logo{display:flex;align-items:center;flex-shrink:0;background:none;border:none;cursor:pointer;padding:0}
.logo-img{height:44px;width:auto}
.logo-text-fallback{font-family:'Rajdhani',sans-serif;font-size:1.4rem;font-weight:700;background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.nav-links{display:flex;align-items:center;gap:4px;flex:1;margin-left:12px}
.nav-link{padding:6px 14px;font-size:.88rem;font-weight:500;color:var(--text2);border-radius:6px;transition:var(--transition);white-space:nowrap}
.nav-link:hover{color:var(--text);background:rgba(255,255,255,.06)}
.nav-link.active{color:var(--primary);background:rgba(192,38,211,.1)}
.nav-actions{display:flex;align-items:center;gap:8px;margin-left:auto}
.nav-icon-btn{display:flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:8px;color:var(--text2);transition:var(--transition);position:relative}
.nav-icon-btn:hover{color:var(--text);background:rgba(255,255,255,.08)}
.cart-badge{position:absolute;top:2px;right:2px;min-width:16px;height:16px;padding:0 4px;background:var(--primary);color:#fff;font-size:.65rem;font-weight:700;border-radius:999px;display:flex;align-items:center;justify-content:center}
.hamburger{display:none;flex-direction:column;gap:5px;width:38px;height:38px;align-items:center;justify-content:center;border-radius:8px;transition:var(--transition)}
.hamburger:hover{background:rgba(255,255,255,.08)}
.hamburger span{display:block;width:20px;height:2px;background:var(--text2);border-radius:2px;transition:var(--transition)}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ── SEARCH ── */
.search-bar{position:absolute;top:100%;left:0;right:0;background:rgba(11,12,27,.98);border-bottom:1px solid var(--border);padding:12px 24px;display:none;backdrop-filter:blur(20px)}
.search-bar.open{display:block}
.search-inner{max-width:640px;margin:0 auto;display:flex;align-items:center;gap:10px;background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:8px 14px}
.search-inner svg{color:var(--text3);flex-shrink:0}
.search-inner input{flex:1;background:none;border:none;outline:none;color:var(--text);font-size:.95rem;font-family:inherit}
.search-inner input::placeholder{color:var(--text3)}
.search-inner button{color:var(--text3);font-size:1rem;padding:0 4px;transition:var(--transition)}
.search-inner button:hover{color:var(--text)}
.search-results{max-width:640px;margin:8px auto 0;background:var(--surface);border:1px solid var(--border);border-radius:10px;overflow:hidden;display:none}
.search-results.visible{display:block}
.search-result-item{display:flex;align-items:center;gap:12px;padding:10px 14px;cursor:pointer;transition:background var(--transition);border-bottom:1px solid var(--border)}
.search-result-item:last-child{border-bottom:none}
.search-result-item:hover{background:rgba(192,38,211,.08)}
.search-result-img{width:36px;height:36px;border-radius:6px;background:var(--surface2);display:flex;align-items:center;justify-content:center;font-size:1.2rem;flex-shrink:0;overflow:hidden}
.search-result-img img{width:100%;height:100%;object-fit:cover}
.search-result-info{display:flex;flex-direction:column}
.search-result-info strong{font-size:.88rem;color:var(--text)}
.search-result-info span{font-size:.78rem;color:var(--text3)}

/* ── MOBILE DRAWER ── */
.mobile-drawer{position:fixed;top:0;right:0;width:280px;height:100vh;background:var(--surface);border-left:1px solid var(--border);z-index:600;transform:translateX(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column}
.mobile-drawer.open{transform:translateX(0)}
.drawer-inner{padding:24px 20px;display:flex;flex-direction:column;height:100%}
.drawer-close{align-self:flex-end;font-size:1.2rem;color:var(--text3);padding:4px 8px;border-radius:6px;transition:var(--transition);margin-bottom:24px}
.drawer-close:hover{color:var(--text);background:rgba(255,255,255,.08)}
.drawer-links{display:flex;flex-direction:column;gap:4px;flex:1}
.drawer-links button{text-align:left;padding:12px 16px;font-size:1rem;font-weight:500;color:var(--text2);border-radius:8px;transition:var(--transition);width:100%}
.drawer-links button:hover{color:var(--text);background:rgba(255,255,255,.07)}
.drawer-auth{display:flex;flex-direction:column;gap:10px;padding-top:20px;border-top:1px solid var(--border)}
.drawer-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:590;display:none}
.drawer-overlay.visible{display:block}

/* ── PAGE SYSTEM ── */
.page{display:none;min-height:100vh;padding-top:var(--nav-h)}
.page.active{display:block}
#page-home{padding-top:0;overflow:hidden}
.page-banner{padding:60px 24px 48px;text-align:center;background:linear-gradient(160deg,rgba(192,38,211,.1) 0%,transparent 70%);border-bottom:1px solid var(--border)}
.page-banner h1{font-family:'Rajdhani',sans-serif;font-size:clamp(2rem,5vw,3rem);font-weight:700;background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:10px}
.page-banner p{color:var(--text2);font-size:1rem;max-width:600px;margin:0 auto}
.section{max-width:1280px;margin:0 auto;padding:72px 24px}

/* ── HERO ── */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;overflow:hidden;padding-top:var(--nav-h)}
.hero-fullscreen{height:100vh;min-height:100vh;max-height:100vh;overflow:hidden;display:flex;flex-direction:column;align-items:center;justify-content:center;padding-top:0}
.hero-bg-img{position:absolute;inset:0;background-size:cover;background-position:center;background-repeat:no-repeat;z-index:0}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(160deg,rgba(11,12,27,.88) 0%,rgba(11,12,27,.7) 40%,rgba(11,12,27,.9) 100%);z-index:1}
.hero-marquee{position:absolute;top:var(--nav-h);left:0;right:0;overflow:hidden;background:rgba(192,38,211,.1);border-bottom:1px solid var(--border);padding:8px 0;z-index:3}
.marquee-track{display:flex;align-items:center;gap:24px;width:max-content;animation:marquee 30s linear infinite;white-space:nowrap}
.marquee-track span{font-size:.82rem;font-weight:600;letter-spacing:.06em;color:var(--text2);text-transform:uppercase}
.marquee-track .sep{color:var(--primary);font-size:.6rem}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.hero-content{position:relative;z-index:2;text-align:center;padding:20px 24px;max-width:760px;width:100%}
.hero-logo-wrap{margin-bottom:16px;display:flex;justify-content:center}
.hero-logo{height:160px;width:auto;max-width:400px;filter:drop-shadow(0 0 40px rgba(192,38,211,.5));animation:floatLogo 5s ease-in-out infinite}
@keyframes floatLogo{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
.hero-sub{font-size:.95rem;color:var(--text2);margin-bottom:18px;line-height:1.6}
.hero-stats{display:flex;align-items:center;justify-content:center;margin-bottom:22px;background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:14px;padding:16px 24px;width:fit-content;margin-left:auto;margin-right:auto}
.hero-stat{text-align:center;padding:0 24px}
.stat-num{display:block;font-family:'Rajdhani',sans-serif;font-size:1.7rem;font-weight:700;background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1;margin-bottom:4px}
.stat-label{font-size:.78rem;color:var(--text3);text-transform:uppercase;letter-spacing:.08em}
.hero-divider{width:1px;height:36px;background:var(--border)}
.hero-btns{display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap;margin-bottom:20px}
.hero-cats{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;max-width:700px}
.hero-cat-btn{padding:9px 18px;background:rgba(255,255,255,.06);border:1.5px solid rgba(192,38,211,.3);border-radius:999px;color:var(--text2);font-size:.83rem;font-weight:600;cursor:pointer;transition:var(--transition);white-space:nowrap}
.hero-cat-btn:hover{background:rgba(192,38,211,.15);border-color:var(--primary);color:var(--text);transform:translateY(-2px)}

/* ── CATEGORY TABS ── */
.cat-tabs-wrap{position:sticky;top:var(--nav-h);z-index:40;background:rgba(11,12,27,.9);border-bottom:1px solid var(--border);backdrop-filter:blur(16px);padding:0 24px;overflow-x:auto;scrollbar-width:none}
.cat-tabs-wrap::-webkit-scrollbar{display:none}
.cat-tabs{display:flex;align-items:center;gap:4px;max-width:1280px;margin:0 auto;padding:10px 0;width:max-content}
.cat-tab{padding:7px 18px;font-size:.85rem;font-weight:500;color:var(--text3);border-radius:999px;transition:var(--transition);white-space:nowrap;border:1.5px solid transparent}
.cat-tab:hover{color:var(--text2);background:rgba(255,255,255,.06)}
.cat-tab.active{color:#fff;background:var(--gradient);border-color:transparent}

/* ── PRODUCT GRID ── */
.product-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:20px}
.product-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;cursor:pointer;transition:transform var(--transition),box-shadow var(--transition),border-color var(--transition);display:flex;flex-direction:column}
.product-card:hover{transform:translateY(-4px);box-shadow:var(--glow),var(--shadow);border-color:var(--border-glow)}
.product-img-wrap{position:relative;width:100%;padding-top:60%;background:var(--surface2);overflow:hidden}
.product-img-wrap img,.product-emoji-img,.product-color-bg{position:absolute;inset:0;width:100%;height:100%}
.product-img-wrap img{object-fit:cover;object-position:center top}
.product-emoji-img{display:flex;align-items:center;justify-content:center;font-size:3rem}
.product-color-bg{display:flex;align-items:center;justify-content:center}
.color-card-inner{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;height:100%;width:100%}
.card-logo-text{font-family:'Rajdhani',sans-serif;font-weight:700;font-size:1.4rem;color:#fff;letter-spacing:.05em}
.card-logo-icon{font-size:2.2rem}
.xbox-card-bg{background:linear-gradient(135deg,#0d5c0d,#107C10,#1a8f1a)}
.psn-card-bg{background:linear-gradient(135deg,#001f5c,#003791,#0052cc)}
.product-badge{position:absolute;top:10px;right:10px;padding:3px 10px;font-size:.68rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;border-radius:999px;z-index:2}
.badge-hot{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}
.badge-new{background:linear-gradient(135deg,#10b981,#059669);color:#fff}
.badge-popular{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff}
.badge-best-value{background:var(--gradient);color:#fff}
.badge-rare{background:linear-gradient(135deg,#8b5cf6,#6d28d9);color:#fff}
.badge-oos{background:rgba(0,0,0,.7);color:#aaa}
.product-info{padding:16px 18px 18px;display:flex;flex-direction:column;gap:10px;flex:1}
.product-name{font-size:.95rem;font-weight:600;color:var(--text);line-height:1.3}
.product-note{font-size:.75rem;color:var(--text3);line-height:1.5}
.product-footer{display:flex;align-items:center;justify-content:space-between;margin-top:auto;padding-top:6px}
.product-price{font-family:'Rajdhani',sans-serif;font-size:1.4rem;font-weight:700;background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.product-add-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:var(--gradient);color:#fff;border-radius:8px;font-size:1.2rem;border:none;cursor:pointer;transition:var(--transition);flex-shrink:0}
.product-add-btn:hover{transform:scale(1.1);box-shadow:var(--glow)}

/* ── VOUCH SLIDESHOW ── */
.vouch-twitter-cta{text-align:center;margin-bottom:40px}
.vouch-twitter-link{display:inline-flex;align-items:center;gap:12px;padding:16px 32px;background:linear-gradient(135deg,rgba(192,38,211,.15),rgba(124,58,237,.15));border:1px solid var(--border-glow);border-radius:999px;color:var(--text);font-size:1.05rem;font-weight:700;transition:var(--transition)}
.vouch-twitter-link:hover{background:linear-gradient(135deg,rgba(192,38,211,.25),rgba(124,58,237,.25));transform:translateY(-2px);box-shadow:var(--glow)}
.vouch-count-num{font-family:'Rajdhani',sans-serif;font-size:1.3rem;background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.vouch-slideshow{position:relative;max-width:960px;margin:0 auto;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;padding-bottom:60px;user-select:none;touch-action:pan-y}
.slide-track{display:flex;will-change:transform}
.slide-img{flex-shrink:0;display:flex;align-items:center;justify-content:center;padding:20px;background:var(--surface)}
.slide-img img{max-height:480px;width:100%;object-fit:contain;border-radius:10px;pointer-events:none}
.slide-arrow{position:absolute;top:calc(50% - 30px);transform:translateY(-50%);background:rgba(10,10,20,.6);border:1px solid rgba(192,38,211,.3);backdrop-filter:blur(8px);color:#fff;width:44px;height:44px;border-radius:50%;font-size:1.6rem;line-height:1;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:5;transition:background .2s,border-color .2s,transform .2s}
.slide-arrow:hover{background:rgba(192,38,211,.35);border-color:var(--primary);transform:translateY(-50%) scale(1.08)}
.slide-prev{left:14px}
.slide-next{right:14px}
.slide-dots{position:absolute;bottom:20px;left:0;right:0;display:flex;align-items:center;justify-content:center;gap:6px;flex-wrap:wrap;padding:0 60px}
.slide-dot{width:7px;height:7px;border-radius:50%;background:rgba(255,255,255,.2);border:none;cursor:pointer;padding:0;transition:background .25s,transform .25s,width .25s,border-radius .25s}
.slide-dot.active{background:var(--primary);transform:scale(1.15);width:22px;border-radius:4px}

/* ── SUPPORT LAYOUT ── */
.support-layout{display:grid;grid-template-columns:300px 1fr;gap:40px;align-items:start}
.discord-cta{background:linear-gradient(135deg,rgba(88,101,242,.15),rgba(124,58,237,.15));border:1px solid rgba(88,101,242,.35);border-radius:var(--radius-lg);padding:32px 24px;text-align:center;position:sticky;top:calc(var(--nav-h) + 20px)}
.discord-icon{width:64px;height:64px;background:rgba(88,101,242,.2);border-radius:16px;display:flex;align-items:center;justify-content:center;margin:0 auto 16px;color:#5865F2}
.discord-cta h3{font-size:1.15rem;font-weight:700;margin-bottom:8px}
.discord-cta p{font-size:.85rem;color:var(--text2);margin-bottom:20px;line-height:1.6}
.faq-list{display:flex;flex-direction:column;gap:12px}
.faq-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:border-color var(--transition)}
.faq-item.open{border-color:var(--border-glow)}
.faq-q{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;cursor:pointer;font-size:.92rem;font-weight:600;color:var(--text);gap:12px;width:100%;text-align:left}
.faq-q:hover{color:var(--primary)}
.faq-arrow{font-size:.75rem;color:var(--text3);transition:transform var(--transition);flex-shrink:0}
.faq-item.open .faq-arrow{transform:rotate(180deg);color:var(--primary)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s cubic-bezier(.4,0,.2,1)}
.faq-item.open .faq-a{max-height:400px}
.faq-a-inner{padding:0 20px 18px;font-size:.875rem;color:var(--text2);line-height:1.7;border-top:1px solid var(--border);padding-top:14px}

/* ── TERMS ── */
.terms-content{max-width:800px;margin:0 auto;display:flex;flex-direction:column;gap:24px}
.terms-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px}
.terms-section h3{font-size:1rem;font-weight:700;color:var(--primary);margin-bottom:12px}
.terms-section p{font-size:.875rem;color:var(--text2);line-height:1.8}

/* ── CART ── */
.cart-layout{display:grid;grid-template-columns:1fr 340px;gap:32px;align-items:start}
.cart-items{display:flex;flex-direction:column;gap:14px}
.cart-empty{text-align:center;padding:80px 24px;color:var(--text3)}
.cart-empty .empty-icon{font-size:3rem;margin-bottom:16px}
.cart-empty h3{font-size:1.2rem;font-weight:600;color:var(--text2);margin-bottom:8px}
.cart-item{display:flex;align-items:center;gap:16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px}
.cart-item-img{width:70px;height:70px;border-radius:10px;overflow:hidden;flex-shrink:0;background:var(--surface2);display:flex;align-items:center;justify-content:center;font-size:1.8rem}
.cart-item-img img{width:100%;height:100%;object-fit:cover}
.cart-item-info{flex:1}
.cart-item-name{font-size:.92rem;font-weight:600;margin-bottom:4px}
.cart-item-price{font-family:'Rajdhani',sans-serif;font-size:1.1rem;font-weight:700;background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.cart-item-remove{width:32px;height:32px;border-radius:8px;background:rgba(239,68,68,.1);color:var(--red);display:flex;align-items:center;justify-content:center;font-size:.85rem;transition:var(--transition);flex-shrink:0}
.cart-item-remove:hover{background:rgba(239,68,68,.2)}
.cart-qty-controls{display:flex;align-items:center;gap:6px;flex-shrink:0}
.cart-qty-btn{width:30px;height:30px;border-radius:8px;border:1.5px solid var(--border);background:var(--surface2);color:var(--text);font-size:1.1rem;font-weight:700;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--transition);line-height:1;font-family:inherit}
.cart-qty-btn:hover{border-color:var(--primary);color:var(--primary);background:rgba(192,38,211,.1)}
.cart-qty-val{min-width:24px;text-align:center;font-weight:700;font-size:.95rem}
.cart-summary{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px;display:flex;flex-direction:column;gap:14px;position:sticky;top:calc(var(--nav-h) + 20px)}
.cart-summary h3{font-size:1.1rem;font-weight:700}
.summary-row{display:flex;align-items:center;justify-content:space-between;font-size:.9rem;color:var(--text2)}
.summary-total{font-size:1.05rem;font-weight:700;color:var(--text);border-top:1px solid var(--border);padding-top:14px}
.cart-note{font-size:.78rem;color:var(--text3);text-align:center;line-height:1.5}

/* ── ACCOUNT PAGE ── */
.account-layout{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px}
.account-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px}
.account-card h3{font-size:1rem;font-weight:700;margin-bottom:16px;color:var(--primary)}

/* ── MODALS ── */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.72);z-index:800;display:none;backdrop-filter:blur(4px)}
.modal-overlay.visible{display:block}
.modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%) scale(.95);z-index:900;background:var(--surface);border:1px solid var(--border-glow);border-radius:var(--radius-lg);padding:36px 32px;width:min(480px,calc(100vw - 32px));max-height:90vh;overflow-y:auto;opacity:0;pointer-events:none;transition:opacity .25s,transform .25s;box-shadow:var(--shadow-lg)}
.modal.open{opacity:1;transform:translate(-50%,-50%) scale(1);pointer-events:all}
.modal-close{position:absolute;top:14px;right:16px;font-size:1.1rem;color:var(--text3);padding:4px 8px;border-radius:6px;transition:var(--transition)}
.modal-close:hover{color:var(--text);background:rgba(255,255,255,.08)}
.modal-logo{display:flex;justify-content:center;margin-bottom:20px}
.modal-logo img{height:64px;width:auto}
.modal-title{font-family:'Rajdhani',sans-serif;font-size:1.6rem;font-weight:700;text-align:center;margin-bottom:6px}
.modal-sub{text-align:center;font-size:.875rem;color:var(--text2);margin-bottom:24px}
.modal-form{display:flex;flex-direction:column;gap:16px}
.modal-product{width:min(600px,calc(100vw - 32px))}
.form-group{display:flex;flex-direction:column;gap:6px}
.form-group label{font-size:.83rem;font-weight:600;color:var(--text2)}
.form-group input{padding:11px 14px;background:var(--bg2);border:1.5px solid var(--border);border-radius:8px;color:var(--text);font-size:.9rem;font-family:inherit;transition:border-color var(--transition);outline:none}
.form-group input:focus{border-color:var(--primary)}
.modal-divider{display:flex;align-items:center;gap:12px;margin:16px 0 8px;color:var(--text3);font-size:.78rem}
.modal-divider::before,.modal-divider::after{content:'';flex:1;height:1px;background:var(--border)}
.google-btn-wrap{display:flex;justify-content:center;min-height:44px}
.modal-switch{text-align:center;font-size:.83rem;color:var(--text3);margin-top:12px}
.modal-switch button{color:var(--primary);font-size:.83rem;font-weight:500}
.modal-switch button:hover{text-decoration:underline}
.product-modal-img{width:100%;height:240px;object-fit:cover;object-position:center top;border-radius:12px;margin-bottom:20px}
.product-modal-emoji{width:100%;height:160px;background:var(--surface2);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:4rem;margin-bottom:20px}
.product-modal-name{font-family:'Rajdhani',sans-serif;font-size:1.6rem;font-weight:700;margin-bottom:6px}
.product-modal-price{font-family:'Rajdhani',sans-serif;font-size:2rem;font-weight:700;background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:16px}
.product-modal-note{background:rgba(192,38,211,.08);border:1px solid var(--border);border-radius:8px;padding:12px 16px;font-size:.83rem;color:var(--text2);line-height:1.6;margin-bottom:20px}
.product-modal-actions{display:flex;gap:12px;flex-wrap:wrap}
.checkout-order-id{background:rgba(124,58,237,.12);border:1px solid rgba(124,58,237,.3);border-radius:8px;padding:10px 16px;font-size:.8rem;color:var(--text2);text-align:center;margin-bottom:8px;font-family:monospace}
.checkout-total{background:rgba(192,38,211,.08);border:1px solid var(--border);border-radius:10px;padding:16px;font-family:'Rajdhani',sans-serif;font-size:1.3rem;font-weight:700;text-align:center;color:var(--text);margin-bottom:20px}
.checkout-note{text-align:center;font-size:.8rem;color:var(--text3);margin-top:14px;line-height:1.5}

/* ── ADMIN / SUPPORT DASHBOARDS ── */
.admin-gate{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}
.admin-gate-box{background:var(--surface);border:1px solid var(--border-glow);border-radius:var(--radius-lg);padding:40px 32px;width:min(400px,100%);text-align:center}
.admin-gate-box h2{font-family:'Rajdhani',sans-serif;font-size:1.8rem;margin-bottom:8px}
.admin-gate-box p{color:var(--text2);font-size:.9rem;margin-bottom:24px}
.admin-gate-box .form-group{margin-bottom:16px;text-align:left}
.admin-panel{min-height:100vh}
.admin-layout{display:flex;min-height:100vh}
.admin-sidebar{width:220px;flex-shrink:0;background:var(--bg2);border-right:1px solid var(--border);padding:24px 16px;display:flex;flex-direction:column;gap:8px;position:sticky;top:0;height:100vh;overflow-y:auto}
.admin-brand{display:flex;flex-direction:column;align-items:center;gap:8px;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid var(--border)}
.admin-brand span{font-family:'Rajdhani',sans-serif;font-size:1.1rem;font-weight:700}
.admin-nav{display:flex;flex-direction:column;gap:4px;flex:1}
.admin-nav-btn{text-align:left;padding:10px 14px;font-size:.88rem;font-weight:500;color:var(--text2);border-radius:8px;transition:var(--transition);width:100%}
.admin-nav-btn:hover{background:rgba(255,255,255,.07);color:var(--text)}
.admin-nav-btn.active{background:rgba(192,38,211,.15);color:var(--primary)}
.admin-content{flex:1;padding:32px;overflow-y:auto;max-height:100vh}
.admin-tab-title{font-family:'Rajdhani',sans-serif;font-size:1.6rem;font-weight:700;margin-bottom:24px}
.admin-tab-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}
.admin-tab-header .admin-tab-title{margin-bottom:0}
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px}
.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;text-align:center}
.stat-card .s-num{font-family:'Rajdhani',sans-serif;font-size:2rem;font-weight:700;background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.stat-card .s-label{font-size:.8rem;color:var(--text3);margin-top:4px}
.admin-table{width:100%;border-collapse:collapse;font-size:.85rem}
.admin-table th{text-align:left;padding:10px 14px;font-size:.78rem;color:var(--text3);text-transform:uppercase;letter-spacing:.06em;border-bottom:2px solid var(--border)}
.admin-table td{padding:12px 14px;border-bottom:1px solid var(--border);color:var(--text2)}
.admin-table tr:hover td{background:rgba(255,255,255,.03)}
.admin-search-bar{margin-bottom:20px}
.admin-search-bar input{width:100%;max-width:400px;padding:10px 14px;background:var(--bg2);border:1.5px solid var(--border);border-radius:8px;color:var(--text);font-size:.9rem;font-family:inherit;outline:none;transition:border-color var(--transition)}
.admin-search-bar input:focus{border-color:var(--primary)}
.admin-textarea{width:100%;background:var(--bg2);border:1.5px solid var(--border);border-radius:8px;padding:10px;color:var(--text);font-family:inherit;font-size:.9rem;outline:none;resize:vertical;transition:border-color var(--transition)}
.admin-textarea:focus{border-color:var(--primary)}
.ticket-layout{display:grid;grid-template-columns:280px 1fr;gap:20px;min-height:500px}
.ticket-list{display:flex;flex-direction:column;gap:8px;overflow-y:auto;max-height:600px}
.ticket-item{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:14px;cursor:pointer;transition:var(--transition)}
.ticket-item:hover,.ticket-item.active{border-color:var(--border-glow);background:rgba(192,38,211,.06)}
.ticket-item-name{font-size:.88rem;font-weight:600;margin-bottom:4px}
.ticket-item-sub{font-size:.78rem;color:var(--text3)}
.ticket-item-status{display:inline-block;padding:2px 8px;border-radius:999px;font-size:.7rem;font-weight:600;margin-top:6px}
.status-open{background:rgba(16,185,129,.2);color:#10b981}
.status-pending{background:rgba(245,158,11,.2);color:#f59e0b}
.status-closed{background:rgba(100,116,139,.2);color:#64748b}
.ticket-view{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;display:flex;flex-direction:column;gap:16px}
.empty-hint{color:var(--text3);font-size:.9rem;text-align:center;margin:auto}
.chat-messages-view{display:flex;flex-direction:column;gap:12px;max-height:400px;overflow-y:auto;padding:4px}
.chat-msg{max-width:80%;padding:10px 14px;border-radius:10px;font-size:.88rem;line-height:1.5}
.chat-msg.agent{background:rgba(192,38,211,.15);border:1px solid var(--border);align-self:flex-start}
.chat-msg.customer{background:var(--surface2);border:1px solid var(--border);align-self:flex-end}
.chat-msg-meta{font-size:.72rem;color:var(--text3);margin-top:4px}
.reply-form{display:flex;gap:10px;margin-top:8px}
.reply-form input{flex:1;padding:10px 14px;background:var(--bg2);border:1.5px solid var(--border);border-radius:8px;color:var(--text);font-family:inherit;font-size:.9rem;outline:none}
.reply-form input:focus{border-color:var(--primary)}
.settings-grid{display:flex;flex-direction:column;gap:20px}
.settings-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px}
.settings-card h3{font-size:1rem;font-weight:700;margin-bottom:8px}
.settings-card p{font-size:.85rem;color:var(--text2);margin-bottom:16px}
.toggle-row{display:flex;align-items:center;justify-content:space-between;gap:16px}

/* ── LIVE CHAT WIDGET ── */
@keyframes chatBubbleVibrate{0%,100%{transform:scale(1) rotate(0)}15%{transform:scale(1.12) rotate(-6deg)}30%{transform:scale(1.12) rotate(6deg)}45%{transform:scale(1.08) rotate(-4deg)}60%{transform:scale(1.08) rotate(4deg)}75%{transform:scale(1.04) rotate(-2deg)}}
.chat-trigger-btn{position:fixed;bottom:24px;right:24px;z-index:700;width:54px;height:54px;border-radius:50%;background:var(--gradient);color:#fff;font-size:1.4rem;display:flex;align-items:center;justify-content:center;box-shadow:var(--glow),var(--shadow);transition:background .3s,box-shadow .3s,transform .2s}
.chat-trigger-btn:hover{transform:scale(1.08)}
.chat-trigger-btn.has-reply{background:linear-gradient(135deg,#16a34a,#15803d);box-shadow:0 0 18px rgba(22,163,74,.6),var(--shadow);animation:chatBubbleVibrate .6s ease-in-out}
.chat-unread{position:absolute;top:-2px;right:-2px;width:16px;height:16px;background:var(--red);border-radius:50%;font-size:.6rem;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700}
.live-chat-widget{position:fixed;bottom:90px;right:24px;z-index:700;width:340px;background:var(--surface);border:1px solid var(--border-glow);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);overflow:hidden;display:flex;flex-direction:column}
.chat-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;background:var(--gradient);color:#fff}
.chat-messages{flex:1;padding:16px;display:flex;flex-direction:column;gap:10px;max-height:320px;overflow-y:auto;min-height:120px}
.chat-input-row{display:flex;gap:8px;padding:12px;border-top:1px solid var(--border)}
.chat-input-row input{flex:1;padding:8px 12px;background:var(--bg2);border:1.5px solid var(--border);border-radius:8px;color:var(--text);font-family:inherit;font-size:.85rem;outline:none}
.chat-input-row input:focus{border-color:var(--primary)}
.chat-pre-form{padding:28px 20px 20px;display:flex;flex-direction:column;align-items:center;gap:8px;text-align:center}
.chat-pre-icon{font-size:2.4rem;line-height:1}
.chat-pre-title{font-weight:700;font-size:1rem;color:var(--text);margin:0}
.chat-pre-sub{font-size:.8rem;color:var(--text3);margin:0 0 4px}
.chat-pre-fields{display:flex;flex-direction:column;gap:8px;width:100%}
.chat-pre-fields input{width:100%;padding:10px 12px;background:var(--bg2);border:1.5px solid var(--border);border-radius:8px;color:var(--text);font-family:inherit;font-size:.85rem;outline:none;box-sizing:border-box}
.chat-pre-fields input:focus{border-color:var(--primary)}

/* ── SHIEDA ANALYTICS ── */
.shieda-controls{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;margin-bottom:20px}
.shieda-select{background:var(--bg2);border:1.5px solid var(--border);border-radius:8px;padding:8px 12px;color:var(--text);font-family:inherit;font-size:.88rem;outline:none;cursor:pointer}
.shieda-kpi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:14px;margin-bottom:20px}
.shieda-kpi{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:18px 20px}
.shieda-kpi-val{font-size:1.6rem;font-weight:800;color:var(--primary);line-height:1}
.shieda-kpi-label{font-size:.75rem;color:var(--text3);text-transform:uppercase;letter-spacing:.06em;margin-top:6px}
.shieda-kpi-sub{font-size:.78rem;color:var(--text2);margin-top:4px}
.shieda-chart{display:flex;align-items:flex-end;gap:4px;height:140px;padding:0 4px}
.shieda-bar-wrap{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;min-width:0}
.shieda-bar{width:100%;border-radius:4px 4px 0 0;background:var(--gradient);min-height:2px;transition:height .4s;position:relative}
.shieda-bar:hover::after{content:attr(data-tip);position:absolute;top:-28px;left:50%;transform:translateX(-50%);background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:2px 8px;font-size:.72rem;white-space:nowrap;pointer-events:none;z-index:10}
.shieda-bar-label{font-size:.62rem;color:var(--text3);text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
.shieda-table{width:100%;border-collapse:collapse;font-size:.85rem}
.shieda-table th{text-align:left;padding:8px 12px;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text3);border-bottom:1px solid var(--border)}
.shieda-table td{padding:10px 12px;border-bottom:1px solid rgba(255,255,255,.04)}
.shieda-table tr:last-child td{border-bottom:none}
.shieda-table tr:hover td{background:rgba(192,38,211,.06)}
.shieda-rank{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;background:var(--gradient);color:#fff;font-size:.7rem;font-weight:700}

/* ── FOOTER ── */
.footer{background:var(--bg2);border-top:1px solid var(--border)}
.footer-bottom{border-top:1px solid var(--border);padding:20px 24px;text-align:center;font-size:.78rem;color:var(--text3)}

/* ══════════════ RESPONSIVE ══════════════ */
@media(max-width:960px){
  .nav-links{display:none}
  .hamburger{display:flex}
  #navLoginBtn,#navRegisterBtn{display:none!important}
  #navAccountBtn{display:none!important}
  .support-layout{grid-template-columns:1fr}
  .discord-cta{position:static}
  .cart-layout{grid-template-columns:1fr}
  .cart-summary{position:static}
  .ticket-layout{grid-template-columns:1fr}
  .admin-layout{flex-direction:column}
  .admin-sidebar{width:100%;height:auto;position:static;flex-direction:row;flex-wrap:wrap;gap:4px}
  .admin-content{max-height:none}
}
@media(max-width:640px){
  .section{padding:48px 16px}
  .page-banner{padding:40px 16px 32px}
  .hero-logo{height:120px;max-width:280px}
  .hero-stats{padding:12px 16px}
  .hero-stat{padding:0 12px}
  .stat-num{font-size:1.3rem}
  .hero-btns{flex-direction:column;width:100%}
  .hero-btns .btn-primary,.hero-btns .btn-ghost{width:100%}
  .product-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}
  .modal{padding:28px 20px}
  .live-chat-widget{width:calc(100vw - 48px)}
  .cat-tabs-wrap{padding:0 16px}
  .admin-nav{flex-direction:row;flex-wrap:wrap}
  .admin-nav-btn{font-size:.78rem;padding:7px 10px}
}

/* ══════════════ EXTENDED STYLES ══════════════ */

/* Wishlist button on product cards */
.wishlist-btn{position:absolute;top:10px;left:10px;z-index:3;background:rgba(0,0,0,.5);border:none;color:var(--text3);width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.9rem;cursor:pointer;transition:var(--transition)}
.wishlist-btn:hover,.wishlist-btn.active{color:#ef4444;background:rgba(239,68,68,.2)}

/* Status badges */
.status-badge{display:inline-block;padding:3px 10px;border-radius:999px;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}
.status-completed{background:rgba(16,185,129,.18);color:#10b981}
.status-processing{background:rgba(6,182,212,.18);color:#06b6d4}
.status-failed{background:rgba(239,68,68,.18);color:#ef4444}
.status-refunded{background:rgba(245,158,11,.18);color:#f59e0b}

/* Admin table wrapper */
.admin-table-wrap{overflow-x:auto;border-radius:var(--radius);margin-bottom:8px}

/* Ticket list items */
.ticket-id{font-family:monospace;font-size:.82rem;color:var(--primary);font-weight:700;margin-bottom:3px}
.ticket-sub{font-size:.88rem;font-weight:600;color:var(--text);margin-bottom:3px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:220px}
.ticket-meta{font-size:.74rem;color:var(--text3);margin-bottom:6px}
.ticket-open{border-color:rgba(16,185,129,.4)!important;background:rgba(16,185,129,.04)!important}

/* Ticket detail view */
.ticket-detail{display:flex;flex-direction:column;gap:16px;height:100%}
.ticket-detail-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.ticket-detail-header h3{font-size:1.05rem;font-weight:700;flex:1}
.ticket-info-row{display:flex;flex-wrap:wrap;gap:12px;font-size:.78rem;color:var(--text3)}
.ticket-message{background:var(--bg2);border:1px solid var(--border);border-radius:8px;padding:14px 16px;font-size:.875rem;color:var(--text2);line-height:1.7;white-space:pre-wrap;max-height:300px;overflow-y:auto}
.ticket-reply{background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:12px 16px}
.reply-staff{background:rgba(192,38,211,.08);border-color:rgba(192,38,211,.25)}
.reply-customer{background:var(--bg2)}
.reply-from{font-size:.73rem;color:var(--text3);margin-bottom:6px;font-weight:600}
.ticket-reply-form{margin-top:4px}

/* Account page */
.account-info-row{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--border);font-size:.9rem}
.account-info-row:last-of-type{border-bottom:none}
.account-info-row span{color:var(--text3)}

/* Order history */
.order-history-item{display:flex;flex-wrap:wrap;align-items:center;gap:10px;padding:12px 14px;background:var(--bg2);border:1px solid var(--border);border-radius:8px;margin-bottom:8px;font-size:.83rem}
.order-history-item code{font-size:.75rem;color:var(--primary);font-family:monospace;font-weight:700;flex-shrink:0}
.order-items-label{flex:1;color:var(--text2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}
.order-total-label{font-weight:700;color:var(--text);flex-shrink:0}
.order-date{color:var(--text3);font-size:.75rem;margin-left:auto}

/* Wishlist items */
.wishlist-item{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--bg2);border:1px solid var(--border);border-radius:8px;margin-bottom:8px;font-size:.85rem}
.wishlist-item span:first-child{flex:1;font-weight:500}

/* V-Bucks modal */
.vb-notice{background:rgba(245,158,11,.1);border:1px solid rgba(245,158,11,.35);border-radius:10px;padding:14px 16px;font-size:.83rem;color:#fbbf24;line-height:1.7;margin-bottom:18px}
.vb-order-meta{background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:12px 16px;margin-bottom:4px}
.vb-order-row{font-size:.87rem;color:var(--text2);padding:4px 0}

/* Crypto payment modal */
.crypto-picker{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:4px 0 16px}
.crypto-option{background:var(--surface2);border:1.5px solid var(--border);border-radius:10px;padding:14px 8px;text-align:center;cursor:pointer;transition:var(--transition)}
.crypto-option:hover,.crypto-option.selected{border-color:var(--primary);background:rgba(192,38,211,.12)}
.crypto-icon{font-size:1.6rem;margin-bottom:4px;font-weight:700;color:var(--text2)}
.crypto-name{font-size:.75rem;font-weight:600;color:var(--text3)}
.crypto-option.selected .crypto-name{color:var(--primary)}
.crypto-address-box{background:var(--bg2);border:1px solid var(--border-glow);border-radius:10px;padding:16px;text-align:center;margin:4px 0 12px}
.crypto-address{font-family:monospace;font-size:.78rem;word-break:break-all;color:var(--primary);margin:8px 0;line-height:1.6}
.crypto-status{text-align:center;padding:12px;font-size:.88rem;color:var(--text2)}
.crypto-status-pending{color:var(--orange)}
.crypto-status-paid{color:var(--green)}
.crypto-status-failed{color:var(--red)}

/* ── HERO TITLE ── */
.hero-title{font-family:'Rajdhani',sans-serif;font-size:clamp(2.2rem,6vw,4rem);font-weight:700;color:#fff;margin-bottom:10px;letter-spacing:.02em;line-height:1.1}

/* ── HOME SECTIONS ── */
.home-section{padding:96px 24px;background:var(--bg)}
.home-section-alt{background:var(--bg2)}
.home-section-inner{max-width:1140px;margin:0 auto}
.section-label{display:inline-block;font-size:.72rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--primary);background:rgba(192,38,211,.1);border:1px solid rgba(192,38,211,.25);border-radius:999px;padding:4px 14px;margin-bottom:18px}
.section-title{font-family:'Rajdhani',sans-serif;font-size:clamp(1.8rem,4vw,2.6rem);font-weight:700;color:var(--text);margin-bottom:48px;line-height:1.15}

/* ── STEPS (HOW IT WORKS) ── */
.steps-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.step-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:32px 28px;position:relative;transition:border-color var(--transition),transform var(--transition)}
.step-card:hover{border-color:var(--border-glow);transform:translateY(-3px)}
.step-num{font-family:'Rajdhani',sans-serif;font-size:3rem;font-weight:700;line-height:1;background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:16px;opacity:.7}
.step-card h3{font-size:1rem;font-weight:700;color:var(--text);margin-bottom:10px}
.step-card p{font-size:.875rem;color:var(--text2);line-height:1.7}

/* ── FEATURES (WHY US) ── */
.features-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.feature-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px 24px;transition:border-color var(--transition),transform var(--transition)}
.feature-card:hover{border-color:var(--border-glow);transform:translateY(-3px)}
.feature-icon{font-size:2rem;margin-bottom:14px}
.feature-card h3{font-size:.95rem;font-weight:700;color:var(--text);margin-bottom:8px}
.feature-card p{font-size:.84rem;color:var(--text2);line-height:1.7}

/* ── FOOTER ── */
.footer-inner{max-width:1140px;margin:0 auto;padding:64px 24px 40px;display:grid;grid-template-columns:260px 1fr;gap:60px;border-bottom:1px solid var(--border)}
.footer-brand{display:flex;flex-direction:column;gap:14px}
.footer-brand p{font-size:.85rem;color:var(--text3);line-height:1.7;max-width:220px}
.footer-links{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.footer-col{display:flex;flex-direction:column;gap:10px}
.footer-col h4{font-size:.78rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text3);margin-bottom:4px}
.footer-col button,.footer-col a{font-size:.88rem;color:var(--text2);text-align:left;background:none;border:none;cursor:pointer;transition:color var(--transition);font-family:inherit;text-decoration:none;padding:0}
.footer-col button:hover,.footer-col a:hover{color:var(--primary)}
.footer-bottom{max-width:1140px;margin:0 auto;padding:20px 24px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}
.footer-bottom p{font-size:.78rem;color:var(--text3)}
.footer-staff{display:flex;align-items:center;gap:8px;font-size:.72rem;color:var(--text3)}
.footer-staff span{color:var(--text3)}
.staff-link{font-size:.72rem;color:var(--text3);background:none;border:1px solid rgba(255,255,255,.12);border-radius:4px;cursor:pointer;font-family:inherit;transition:color var(--transition),border-color var(--transition);padding:2px 8px}
.staff-link:hover{color:var(--primary);border-color:var(--primary)}

/* ── RESPONSIVE: HOME SECTIONS ── */
@media(max-width:900px){
  .steps-grid{grid-template-columns:1fr}
  .features-grid{grid-template-columns:repeat(2,1fr)}
  .footer-inner{grid-template-columns:1fr;gap:32px}
  .footer-links{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:640px){
  .home-section{padding:64px 16px}
  .features-grid{grid-template-columns:1fr}
  .footer-links{grid-template-columns:repeat(2,1fr)}
  .footer-bottom{flex-direction:column;align-items:flex-start;gap:8px}
}

/* ── CHARACTER BREATHING ── */
@keyframes charBreathe {
  0%    { transform: scale(1.000) translateY(0.0px) }
  5%    { transform: scale(1.001) translateY(-0.4px) }
  10%   { transform: scale(1.002) translateY(-0.9px) }
  15%   { transform: scale(1.003) translateY(-1.5px) }
  20%   { transform: scale(1.005) translateY(-2.2px) }
  25%   { transform: scale(1.007) translateY(-3.0px) }
  30%   { transform: scale(1.009) translateY(-3.7px) }
  35%   { transform: scale(1.010) translateY(-4.3px) }
  40%   { transform: scale(1.011) translateY(-4.7px) }
  45%   { transform: scale(1.012) translateY(-4.9px) }
  50%   { transform: scale(1.012) translateY(-5.0px) }
  55%   { transform: scale(1.011) translateY(-4.8px) }
  60%   { transform: scale(1.010) translateY(-4.4px) }
  65%   { transform: scale(1.008) translateY(-3.8px) }
  70%   { transform: scale(1.006) translateY(-3.1px) }
  75%   { transform: scale(1.004) translateY(-2.3px) }
  80%   { transform: scale(1.002) translateY(-1.5px) }
  85%   { transform: scale(1.001) translateY(-0.9px) }
  90%   { transform: scale(1.000) translateY(-0.4px) }
  95%   { transform: scale(1.000) translateY(-0.1px) }
  100%  { transform: scale(1.000) translateY(0.0px) }
}

@keyframes charLightPulse {
  0%    { filter: brightness(1.000) }
  5%    { filter: brightness(1.002) }
  10%   { filter: brightness(1.005) }
  20%   { filter: brightness(1.010) }
  35%   { filter: brightness(1.016) }
  50%   { filter: brightness(1.020) }
  65%   { filter: brightness(1.014) }
  80%   { filter: brightness(1.007) }
  90%   { filter: brightness(1.002) }
  100%  { filter: brightness(1.000) }
}

.hero-bg-img {
  transform-origin: center bottom;
  animation:
    charBreathe    7s    ease-in-out infinite,
    charLightPulse 7s    ease-in-out infinite;
  will-change: transform, filter;
}


/* ── INTERACTIVITY: CARD HOVER LIFT ── */
.product-card {
  transition:transform .22s cubic-bezier(.34,1.56,.64,1), box-shadow .22s ease, border-color .22s ease;
}
.product-card:hover {
  transform:translateY(-6px) scale(1.015);
  box-shadow:0 16px 40px rgba(192,38,211,.2);
  border-color:var(--primary);
}

/* Step & feature card animations */
.step-card, .feature-card {
  transition:transform .22s cubic-bezier(.34,1.56,.64,1), box-shadow .22s ease, border-color .22s ease;
}
.step-card:hover {
  transform:translateY(-5px);
  box-shadow:0 12px 32px rgba(192,38,211,.18);
  border-color:var(--primary);
}
.feature-card:hover {
  transform:translateY(-5px) scale(1.02);
  box-shadow:0 12px 32px rgba(192,38,211,.18);
}
.feature-icon {
  transition:transform .22s cubic-bezier(.34,1.56,.64,1);
  display:inline-block;
}
.feature-card:hover .feature-icon {
  transform:scale(1.25) rotate(-5deg);
}

/* Button ripple */
.btn-primary, .btn-outline, .btn-ghost {
  position:relative;
  overflow:hidden;
}
.btn-primary::after, .btn-outline::after {
  content:'';
  position:absolute;
  border-radius:50%;
  width:0;height:0;
  background:rgba(255,255,255,.25);
  transform:translate(-50%,-50%);
  transition:width .5s ease, height .5s ease, opacity .5s ease;
  opacity:0;
  top:50%;left:50%;
  pointer-events:none;
}
.btn-primary:active::after, .btn-outline:active::after {
  width:200px;height:200px;
  opacity:0;
  transition:0s;
}

/* Nav link underline slide */
.nav-link {
  position:relative;
}
.nav-link::after {
  content:'';
  position:absolute;
  bottom:-2px;left:50%;right:50%;
  height:2px;
  background:var(--primary);
  transition:left .2s ease, right .2s ease;
  border-radius:2px;
}
.nav-link:hover::after, .nav-link.active::after {
  left:0;right:0;
}

/* Stat counter pulse */
.stat-num {
  display:inline-block;
  transition:transform .15s ease;
}
.hero-stat:hover .stat-num {
  transform:scale(1.1);
  color:var(--primary);
}

/* Admin table row hover */
.admin-table tbody tr {
  transition:background .15s ease;
}
.admin-table tbody tr:hover {
  background:rgba(192,38,211,.07);
}

/* Page transitions */
.page.active {
  animation:pageFadeIn .25s ease;
}
@keyframes pageFadeIn {
  from { opacity:0; transform:translateY(8px) }
  to   { opacity:1; transform:translateY(0) }
}

/* Ticket / order item hover */
.ticket-open, .order-history-item {
  transition:border-color .15s ease, background .15s ease;
}
.ticket-open:hover, .order-history-item:hover {
  border-color:var(--primary);
  background:rgba(192,38,211,.06);
}

/* Step number glow on hover */
.step-num {
  transition:color .2s, text-shadow .2s;
}
.step-card:hover .step-num {
  color:var(--primary);
  text-shadow:0 0 20px rgba(192,38,211,.5);
}

/* Modal slide-in */
.modal {
  animation:modalIn .22s cubic-bezier(.34,1.4,.64,1);
}

/* ── SPLIT MODAL (login / register / forgot) ── */
.modal-split {
  width: min(820px, calc(100vw - 24px));
  padding: 0;
  display: flex;
  overflow: hidden;
}
.modal-split-img {
  flex: 0 0 300px;
  position: relative;
  overflow: hidden;
  border-radius: var(--radius-lg) 0 0 var(--radius-lg);
}
.modal-split-img > img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.modal-split-img-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, rgba(11,12,27,.15) 0%, rgba(11,12,27,.85) 100%);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-end;
  padding: 28px 20px;
  text-align: center;
}
.modal-split-logo { height: 44px; object-fit: contain; margin-bottom: 10px; }
.modal-split-tagline {
  font-size: .82rem;
  color: rgba(255,255,255,.75);
  line-height: 1.55;
}
.modal-split-form {
  flex: 1;
  min-width: 0;
  padding: 40px 32px 32px;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
}
.modal-split .modal-title { text-align: left; margin-bottom: 4px; }
.modal-split .modal-sub   { text-align: left; margin-bottom: 20px; }
.modal-split .modal-close { top: 12px; right: 12px; }
.modal-split .modal-switch { margin-top: 16px; }
@media (max-width: 600px) {
  .modal-split { flex-direction: column; }
  .modal-split-img { display: none; }
  .modal-split-form { padding: 28px 20px 24px; }
}
@keyframes modalIn {
  from { opacity:0; transform:scale(.94) translateY(12px) }
  to   { opacity:1; transform:scale(1) translateY(0) }
}

/* Scrollbar styling */
::-webkit-scrollbar { width:6px }
::-webkit-scrollbar-track { background:var(--bg) }
::-webkit-scrollbar-thumb { background:rgba(192,38,211,.4); border-radius:3px }
::-webkit-scrollbar-thumb:hover { background:var(--primary) }

/* ── GIFT CARD PAYMENT ── */
.gc-warning{background:rgba(245,158,11,.1);border:1px solid rgba(245,158,11,.4);border-radius:10px;padding:14px 16px;font-size:.82rem;color:#fbbf24;margin-bottom:20px;line-height:1.5}
.gc-order-summary{display:flex;justify-content:space-between;align-items:center;background:var(--surface2);border:1px solid var(--border);border-radius:10px;padding:12px 18px;margin-bottom:16px;font-size:.9rem;gap:16px;flex-wrap:wrap}
.gc-order-meta{margin-bottom:4px}
.gc-consent{margin-top:8px}
.gc-verify-notice{font-size:.8rem;color:#f59e0b;margin-top:10px;padding:8px 12px;background:rgba(245,158,11,.08);border-radius:8px;border-left:3px solid #f59e0b}

/* ── ORDER HISTORY — CODE REVEAL ── */
.order-history-item{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:16px 20px;margin-bottom:12px}
.order-history-top{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:8px}
.order-id-code{font-family:monospace;font-size:.85rem;color:var(--primary);background:var(--surface2);padding:3px 8px;border-radius:6px}
.order-history-mid{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px;font-size:.88rem;color:var(--text2);margin-bottom:10px}
.order-total-label{font-weight:600;color:var(--text)}
.order-code-section{border-top:1px solid var(--border);padding-top:12px;margin-top:4px}
.order-code-hidden{display:flex;align-items:center;gap:8px}
.order-code-revealed{display:flex;flex-direction:column;gap:8px}
.code-label{font-size:.78rem;color:var(--text3)}
.delivered-code{font-family:monospace;font-size:1.1rem;letter-spacing:.08em;background:rgba(192,38,211,.12);border:1px solid rgba(192,38,211,.35);padding:8px 16px;border-radius:8px;color:var(--primary);word-break:break-all}
.warranty-void-notice{font-size:.75rem;color:#f87171;padding:6px 10px;background:rgba(239,68,68,.08);border-radius:6px;border-left:3px solid #dc2626;margin:0}

/* ── STATUS BADGE: PENDING VERIFICATION ── */
.status-pending-verification{background:rgba(245,158,11,.15);color:#f59e0b;border:1px solid rgba(245,158,11,.3)}

/* ══════════════════════════════════════
   SHOP SECTION NAVIGATOR
══════════════════════════════════════ */
.shop-nav-bar {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 20px 24px 0;
  max-width: 1280px;
  margin: 0 auto;
}
.shop-arrow {
  flex-shrink: 0;
  width: 44px; height: 44px;
  border-radius: 50%;
  border: 1px solid var(--border);
  background: var(--surface);
  color: var(--text);
  font-size: 1.6rem;
  line-height: 1;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: background .2s, border-color .2s, transform .15s;
}
.shop-arrow:hover {
  background: rgba(192,38,211,.15);
  border-color: var(--primary);
  transform: scale(1.08);
}
.shop-sec-pills {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  flex: 1;
}
.shop-sec-pill {
  padding: 8px 18px;
  border-radius: 50px;
  border: 1px solid rgba(255,255,255,.12);
  background: var(--surface);
  color: var(--text2);
  font-size: .85rem;
  font-weight: 500;
  cursor: pointer;
  font-family: inherit;
  transition: all .2s ease;
  white-space: nowrap;
}
.shop-sec-pill:hover {
  border-color: var(--pill-color, var(--primary));
  color: var(--pill-color, var(--primary));
}
.shop-sec-pill.active {
  background: var(--pill-color, var(--primary));
  border-color: var(--pill-color, var(--primary));
  color: #fff;
  font-weight: 600;
  box-shadow: 0 0 20px color-mix(in srgb, var(--pill-color, var(--primary)) 40%, transparent);
}

/* ── ACTIVE SECTION HEADER BANNER ── */
.shop-section-header {
  margin: 20px 24px 0;
  max-width: calc(1280px - 48px);
  margin-left: auto;
  margin-right: auto;
  border-radius: 20px;
  border: 1px solid rgba(255,255,255,.08);
  padding: 36px 40px;
  display: flex;
  align-items: center;
  gap: 32px;
  overflow: hidden;
  position: relative;
  min-height: 140px;
  transition: background .4s ease, border-color .4s ease;
}
.shop-section-header::before {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.35);
  backdrop-filter: blur(0px);
  z-index: 0;
}
.ssh-img-wrap {
  position: relative;
  z-index: 1;
  flex-shrink: 0;
  width: 100px; height: 100px;
  border-radius: 16px;
  overflow: hidden;
  background: rgba(255,255,255,.06);
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 8px 32px rgba(0,0,0,.4);
}
.ssh-img {
  width: 100%; height: 100%;
  object-fit: cover;
}
.ssh-emoji {
  font-size: 3rem;
}
.ssh-text {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.ssh-label {
  font-family: 'Rajdhani', sans-serif;
  font-size: clamp(1.8rem, 4vw, 2.8rem);
  font-weight: 700;
  line-height: 1;
  letter-spacing: .01em;
}
.ssh-sub {
  font-size: .92rem;
  color: rgba(255,255,255,.65);
}
.ssh-count {
  font-size: .78rem;
  color: rgba(255,255,255,.4);
  margin-top: 4px;
}

/* ── RESPONSIVE ── */
@media(max-width: 640px) {
  .shop-section-header { padding: 24px 20px; gap: 20px; }
  .ssh-img-wrap { width: 70px; height: 70px; }
  .shop-nav-bar { padding: 16px 16px 0; gap: 8px; }
  .shop-arrow { width: 36px; height: 36px; font-size: 1.3rem; }
  .shop-sec-pill { padding: 6px 12px; font-size: .78rem; }
}

/* ══════════════════════════════════════
   PRODUCT RARITY SYSTEM
══════════════════════════════════════ */

/* Rarity border glow on card */
.product-card[class*="rarity-"] {
  border-bottom: 3px solid var(--rc, var(--primary));
  box-shadow: 0 4px 24px rgba(0,0,0,.55), 0 0 18px color-mix(in srgb, var(--rc, var(--primary)) 22%, transparent);
  position: relative;
}
.product-card[class*="rarity-"]:hover {
  box-shadow: 0 8px 36px rgba(0,0,0,.65), 0 0 32px color-mix(in srgb, var(--rc, var(--primary)) 40%, transparent);
  transform: translateY(-4px);
}

/* Rarity strip row inside product-info */
.rarity-strip {
  display: flex;
  align-items: center;
  gap: 6px;
  margin: 4px 0 2px;
}
.rarity-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--rc, var(--primary));
  box-shadow: 0 0 6px var(--rc, var(--primary));
  flex-shrink: 0;
}
.rarity-label {
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--rc, var(--primary));
}

/* Per-rarity accent colors (fallback if CSS color-mix unsupported) */
.rarity-common    { --rc: #3fc45f; }
.rarity-rare      { --rc: #4f9cf7; }
.rarity-epic      { --rc: #b94fff; }
.rarity-legendary { --rc: #f5a623; }

/* Shimmer on legendary */
@keyframes legendaryShimmer {
  0%   { box-shadow: 0 4px 24px rgba(0,0,0,.55), 0 0 18px rgba(245,166,35,.22); }
  50%  { box-shadow: 0 4px 24px rgba(0,0,0,.55), 0 0 32px rgba(245,166,35,.45); }
  100% { box-shadow: 0 4px 24px rgba(0,0,0,.55), 0 0 18px rgba(245,166,35,.22); }
}
.rarity-legendary {
  animation: legendaryShimmer 2.8s ease-in-out infinite;
}
.rarity-legendary:hover {
  animation: none;
  box-shadow: 0 8px 36px rgba(0,0,0,.65), 0 0 48px rgba(245,166,35,.55) !important;
}

/* ══════════════════════════════════════
   LIVE CHAT — Customer widget
══════════════════════════════════════ */
.chat-msg { display:flex; flex-direction:column; gap:2px; max-width:82%; padding:10px 14px; border-radius:14px; font-size:.88rem; line-height:1.5; word-break:break-word; }
.chat-msg.customer { align-self:flex-end; background:var(--gradient); color:#fff; border-bottom-right-radius:4px; }
.chat-msg.agent    { align-self:flex-start; background:var(--surface2); border:1px solid var(--border); color:var(--text); border-bottom-left-radius:4px; }
.chat-msg-time     { font-size:.68rem; opacity:.55; align-self:flex-end; margin-top:2px; }
#chatMessages      { display:flex; flex-direction:column; gap:10px; }

/* ══════════════════════════════════════
   LIVE CHAT — Support dashboard view
══════════════════════════════════════ */
.support-msg-box {
  flex: 1;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 16px;
  background: var(--bg2);
  border-radius: 12px;
  border: 1px solid var(--border);
  min-height: 320px;
  max-height: 540px;
  scroll-behavior: smooth;
}
.support-reply-bar {
  display: flex;
  gap: 10px;
  align-items: flex-end;
  padding-top: 12px;
  flex-shrink: 0;
}
.support-reply-bar input[type="text"] {
  min-height: 80px;
  resize: vertical;
  padding: 10px 14px;
  align-self: stretch;
}
.support-chat-msg {
  display: flex;
  flex-direction: column;
  gap: 3px;
  max-width: 80%;
  padding: 10px 14px;
  border-radius: 14px;
  font-size: .88rem;
  line-height: 1.5;
  word-break: break-word;
}
.support-chat-msg.sc-customer {
  align-self: flex-start;
  background: var(--surface2);
  border: 1px solid var(--border);
  border-bottom-left-radius: 4px;
}
.support-chat-msg.sc-agent {
  align-self: flex-end;
  background: var(--gradient);
  color: #fff;
  border-bottom-right-radius: 4px;
}
.sc-from {
  font-size: .72rem;
  font-weight: 600;
  opacity: .7;
  text-transform: uppercase;
  letter-spacing: .04em;
}
.sc-text { font-size: .9rem; }
.sc-time { font-size: .68rem; opacity: .5; align-self: flex-end; margin-top: 2px; }

/* Active chat highlight in list */
.ticket-active {
  background: rgba(192,38,211,.12) !important;
  border-color: rgba(192,38,211,.45) !important;
}
#supportChatView { min-height: 340px; }

/* ══════════════════════════════════════
   CRYPTOMUS — Crypto payment modal
══════════════════════════════════════ */
.crypto-picker {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin: 16px 0;
  justify-content: center;
}
.crypto-option {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 5px;
  padding: 12px 16px;
  border-radius: 12px;
  border: 1.5px solid var(--border);
  background: var(--surface);
  cursor: pointer;
  transition: all .2s;
  font-family: inherit;
  min-width: 88px;
}
.crypto-option:hover  { border-color:var(--primary); background:rgba(192,38,211,.08); }
.crypto-option.selected { border-color:var(--primary); background:rgba(192,38,211,.18); box-shadow:0 0 18px rgba(192,38,211,.3); }
.crypto-icon { font-size:1.7rem; line-height:1; }
.crypto-name { font-size:.75rem; font-weight:600; color:var(--text2); text-align:center; }
.crypto-option.selected .crypto-name { color:var(--text); }

.crypto-status          { font-size:.88rem; color:var(--text2); padding:10px 0; text-align:center; }
.crypto-status-pending  { color:var(--orange); }
.crypto-status-paid     { color:var(--green); font-weight:600; }
.crypto-status-failed   { color:var(--red); }

.crypto-address-box {
  background: var(--bg2);
  border: 1.5px solid var(--border);
  border-radius: 12px;
  padding: 16px;
  margin-top: 12px;
}
.crypto-address {
  font-family: monospace;
  font-size: .8rem;
  color: var(--text2);
  word-break: break-all;
  background: var(--surface);
  padding: 10px 14px;
  border-radius: 8px;
  border: 1px solid var(--border);
  margin-top: 6px;
  line-height: 1.6;
  user-select: all;
}
/* Decorative coin badges on fiat checkout modal */
.crypto-coin-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 5px 12px;
  border-radius: 50px;
  background: var(--surface2);
  border: 1px solid var(--border);
  font-size: .78rem;
  font-weight: 600;
  color: var(--text2);
  font-family: monospace;
}

/* ── CARD PAYMENT BUTTON ── */
.btn-card {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 11px 24px;
  background: linear-gradient(135deg, #1a56db 0%, #0e9f6e 100%);
  color: #fff;
  font-weight: 700;
  font-size: .92rem;
  border-radius: 8px;
  cursor: pointer;
  transition: var(--transition);
  white-space: nowrap;
  border: none;
  font-family: inherit;
  box-shadow: 0 4px 18px rgba(26,86,219,.35);
}
.btn-card:hover {
  filter: brightness(1.1);
  transform: translateY(-1px);
  box-shadow: 0 6px 24px rgba(26,86,219,.5);
}

/* Cart divider between Discord and direct pay */
.cart-pay-divider {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 14px 0 4px;
  color: var(--text3);
  font-size: .78rem;
}
.cart-pay-divider::before,
.cart-pay-divider::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--border);
}

/* Card brand badges */
.card-brand-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 5px 12px;
  border-radius: 50px;
  background: var(--surface2);
  border: 1px solid rgba(26,86,219,.3);
  font-size: .78rem;
  font-weight: 600;
  color: var(--text2);
}

/* ══════════════════════════════════════════
   GIFTING PAGE
══════════════════════════════════════════ */

/* Utility bar (credits + friend checker) */
.gifting-utility-bar {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
  padding: 24px 32px 0;
  max-width: 1200px;
  margin: 0 auto;
}
.gifting-credit-box,
.gifting-friend-box {
  flex: 1 1 300px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 18px 20px;
}
.gifting-credit-label {
  font-size: .78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--text3);
  margin-bottom: 10px;
  display: flex;
  align-items: center;
  gap: 6px;
}
.gifting-discord-info{cursor:pointer;color:var(--primary);font-size:.9rem;font-style:normal;opacity:.8;transition:opacity .2s}
.gifting-discord-info:hover{opacity:1}
.gifting-discord-infobox{background:var(--bg2);border:1px solid var(--border);border-radius:10px;padding:12px 14px;font-size:.8rem;color:var(--text2);line-height:1.6;margin-bottom:10px}
.gifting-discord-infobox code{background:rgba(192,38,211,.15);color:var(--primary);padding:1px 6px;border-radius:4px;font-size:.78rem}
.gifting-credit-row {
  display: flex;
  gap: 8px;
}
.gifting-credit-row input {
  flex: 1;
  background: var(--bg2);
  border: 1.5px solid var(--border);
  border-radius: 8px;
  padding: 9px 12px;
  color: var(--text);
  font-family: inherit;
  font-size: .9rem;
  outline: none;
  transition: border-color .2s;
}
.gifting-credit-row input:focus { border-color: var(--primary); }
.gifting-credit-result,
.gifting-friend-result {
  margin-top: 12px;
}
.gifting-credit-display {
  display: flex;
  align-items: baseline;
  gap: 6px;
}
.gifting-credit-amount {
  font-family: 'Rajdhani', sans-serif;
  font-size: 1.8rem;
  font-weight: 700;
  color: var(--primary);
}
.gifting-credit-unit {
  font-size: .85rem;
  color: var(--text3);
}

/* Section titles */
.gifting-section-title {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  margin-bottom: 20px;
}
.gifting-section-title h2 {
  font-size: 1.4rem;
  font-weight: 700;
  margin: 0;
}
.gifting-section-title p {
  color: var(--text3);
  font-size: .85rem;
  margin: 4px 0 0;
}

/* Accounts toggle */
.gifting-accounts-toggle{width:100%;display:flex;align-items:center;justify-content:space-between;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:14px 20px;font-size:.95rem;font-weight:600;color:var(--text);cursor:pointer;transition:border-color .2s,background .2s}
.gifting-accounts-toggle:hover{border-color:var(--primary);background:var(--bg2)}
.gifting-toggle-arrow{transition:transform .25s;font-size:.75rem;opacity:.6}
.gifting-accounts-toggle[aria-expanded="true"] .gifting-toggle-arrow{transform:rotate(180deg)}
.gifting-accounts-panel{margin-top:12px;padding:18px;background:var(--surface);border:1px solid var(--border);border-radius:12px}

/* Accounts to add */
.gifting-accounts-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.gifting-account-card {
  display: flex;
  align-items: center;
  gap: 14px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 14px 18px;
  transition: border-color .2s;
}
.gifting-account-card:hover { border-color: var(--primary); }
.gifting-account-avatar {
  font-size: 2rem;
  width: 46px;
  height: 46px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--bg2);
  border-radius: 10px;
  flex-shrink: 0;
}
.gifting-account-info { flex: 1; min-width: 0; }
.gifting-account-name { font-weight: 700; font-size: .95rem; }
.gifting-account-vb   { font-size: .82rem; color: var(--text2); margin-top: 2px; }
.gifting-account-slots { font-size: .78rem; color: var(--text3); margin-top: 2px; }
.gifting-account-admin .gifting-account-status { font-size: .75rem; color: var(--text3); }

/* Friend status rows */
.gifting-friend-rows { display: flex; flex-direction: column; gap: 8px; margin-top: 8px; }
.gifting-friend-row  { display: flex; justify-content: space-between; align-items: center; gap: 8px; flex-wrap: wrap; }

/* Status badges */
.gifting-status-badge {
  display: inline-block;
  padding: 3px 10px;
  border-radius: 20px;
  font-size: .75rem;
  font-weight: 600;
  white-space: nowrap;
}
.gifting-status-eligible  { background: rgba(63,196,95,.15);  color: #3fc45f; border: 1px solid rgba(63,196,95,.3); }
.gifting-status-pending   { background: rgba(245,166,35,.15); color: #f5a623; border: 1px solid rgba(245,166,35,.3); }
.gifting-status-notadded  { background: rgba(239,68,68,.12);  color: #ef4444; border: 1px solid rgba(239,68,68,.3); }
.gifting-status-ready     { background: rgba(79,156,247,.15); color: #4f9cf7; border: 1px solid rgba(79,156,247,.3); }

/* Pricing grid */
.gifting-pricing-section { background: var(--surface); border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); padding: 40px 32px; }
.gifting-pricing-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 16px;
}
.gifting-price-card {
  background: var(--bg);
  border: 2px solid var(--border);
  border-radius: 16px;
  padding: 20px 16px;
  text-align: center;
  position: relative;
  overflow: hidden;
  transition: transform .2s, border-color .2s, box-shadow .2s;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
}
.gifting-price-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: var(--rc, var(--primary));
}
.gifting-price-card:hover { transform: translateY(-4px); border-color: var(--rc, var(--primary)); box-shadow: 0 8px 28px rgba(0,0,0,.35); }
.gifting-price-img {
  width: 90px;
  height: 90px;
  object-fit: contain;
  margin-bottom: 4px;
}
.gifting-price-vb {
  font-family: 'Rajdhani', sans-serif;
  font-size: 1.4rem;
  font-weight: 700;
  color: var(--text);
  line-height: 1.1;
}
.gifting-price-vb span { font-size: .72rem; font-weight: 500; color: var(--text3); }
.gifting-price-credits {
  font-size: .88rem;
  font-weight: 700;
  color: var(--rc, var(--primary));
}
.gifting-price-usd {
  font-size: 1.5rem;
  font-weight: 800;
  color: var(--text);
  font-family: 'Rajdhani', sans-serif;
  margin: 4px 0;
}
.gifting-buy-btn {
  display: block;
  width: 100%;
  margin-top: 6px;
  padding: 9px 12px;
  border-radius: 10px;
  border: none;
  background: linear-gradient(135deg, var(--rc, var(--primary)), color-mix(in srgb, var(--rc, var(--primary)) 60%, #000));
  color: #fff;
  font-size: .85rem;
  font-weight: 700;
  cursor: pointer;
  transition: opacity .2s, transform .15s;
}
.gifting-buy-btn:hover { opacity: .88; transform: translateY(-1px); }

/* Shop layout: sidebar + grid */
.gifting-shop-layout {
  display: flex;
  gap: 20px;
  align-items: flex-start;
}

/* Category sidebar */
.gifting-category-sidebar {
  flex-shrink: 0;
  width: 160px;
  display: flex;
  flex-direction: column;
  gap: 4px;
  position: sticky;
  top: 80px;
}
.gifting-cat-loading {
  color: var(--text3);
  font-size: .82rem;
  padding: 8px;
}
.gifting-cat-btn {
  display: flex;
  align-items: center;
  gap: 8px;
  width: 100%;
  padding: 9px 12px;
  border-radius: 10px;
  border: 1.5px solid transparent;
  background: var(--surface);
  color: var(--text2);
  font-size: .83rem;
  font-weight: 600;
  cursor: pointer;
  text-align: left;
  transition: background .15s, border-color .15s, color .15s;
}
.gifting-cat-btn:hover { background: var(--surface2); color: var(--text); }
.gifting-cat-btn.active {
  background: rgba(var(--primary-rgb), .12);
  border-color: var(--primary);
  color: var(--primary);
}
.gifting-cat-icon { font-size: 1rem; flex-shrink: 0; }
.gifting-cat-label { flex: 1; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.gifting-cat-count {
  font-size: .72rem;
  background: var(--bg2);
  border-radius: 10px;
  padding: 1px 6px;
  color: var(--text3);
  flex-shrink: 0;
}
.gifting-cat-btn.active .gifting-cat-count { background: rgba(var(--primary-rgb),.2); color: var(--primary); }

/* Item shop grid */
.gifting-shop-grid {
  flex: 1;
  min-width: 0;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: 14px;
}
.gifting-shop-card {
  background: var(--surface);
  border: 1.5px solid var(--border);
  border-radius: 14px;
  overflow: hidden;
  transition: transform .2s, border-color .2s, box-shadow .2s;
  position: relative;
}
.gifting-shop-card:hover {
  transform: translateY(-4px);
  border-color: var(--rc, var(--primary));
  box-shadow: 0 8px 24px rgba(0,0,0,.3);
}
.gifting-shop-card::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 2px;
  background: var(--rc, var(--primary));
  opacity: 0;
  transition: opacity .2s;
}
.gifting-shop-card:hover::after { opacity: 1; }
.gifting-shop-img {
  position: relative;
  aspect-ratio: 1;
  background: var(--bg2);
  overflow: hidden;
}
.gifting-shop-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.gifting-shop-no-img {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
  font-size: 2.5rem;
}
.gifting-shop-banner {
  position: absolute;
  top: 8px; right: 8px;
  background: var(--primary);
  color: #fff;
  font-size: .65rem;
  font-weight: 700;
  padding: 2px 7px;
  border-radius: 20px;
  text-transform: uppercase;
}
.gifting-shop-info { padding: 10px 12px 12px; }
.gifting-shop-name {
  font-size: .88rem;
  font-weight: 700;
  line-height: 1.2;
  margin-bottom: 4px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.gifting-shop-type   { font-size: .72rem; color: var(--text3); margin-bottom: 2px; }
.gifting-shop-rarity { font-size: .72rem; font-weight: 700; text-transform: uppercase; letter-spacing: .05em; margin-bottom: 6px; }
.gifting-shop-price  { display: flex; align-items: baseline; gap: 6px; flex-wrap: wrap; }
.gifting-vbucks      { font-size: .82rem; font-weight: 700; color: #4f9cf7; }
.gifting-old-price   { font-size: .72rem; color: var(--text3); text-decoration: line-through; }
.gifting-bundle-tag  { font-size: .65rem; background: rgba(var(--primary-rgb),.15); color: var(--primary); padding: 1px 5px; border-radius: 4px; vertical-align: middle; margin-left: 4px; }

/* Gift button on shop cards */
.gifting-gift-btn {
  display: block;
  width: 100%;
  margin-top: 10px;
  padding: 7px 10px;
  border-radius: 8px;
  border: none;
  background: linear-gradient(135deg, #7c3aed, #4f9cf7);
  color: #fff;
  font-size: .78rem;
  font-weight: 700;
  cursor: pointer;
  transition: opacity .2s, transform .15s;
}
.gifting-gift-btn:hover { opacity: .88; transform: translateY(-1px); }
.gifting-gift-btn--disabled {
  background: var(--surface2);
  color: var(--text3);
  cursor: not-allowed;
  border: 1px solid var(--border);
}
.gifting-gift-btn--disabled:hover { opacity: 1; transform: none; }

/* How it works section */
.gifting-how-section {
  background: var(--surface);
  border-bottom: 1px solid var(--border);
}
.gifting-how-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 16px;
  margin-bottom: 24px;
}
.gifting-how-card {
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 22px 18px;
  text-align: center;
  transition: border-color .2s, transform .2s;
}
.gifting-how-card:hover {
  border-color: var(--primary);
  transform: translateY(-3px);
}
.gifting-how-icon {
  font-size: 2rem;
  margin-bottom: 12px;
}
.gifting-how-card h3 {
  font-size: 1rem;
  font-weight: 700;
  margin-bottom: 8px;
}
.gifting-how-card p {
  font-size: .83rem;
  color: var(--text2);
  line-height: 1.55;
}
.gifting-how-notice {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  background: rgba(245,166,35,.08);
  border: 1px solid rgba(245,166,35,.25);
  border-radius: 10px;
  padding: 14px 16px;
  font-size: .82rem;
  color: var(--text2);
  line-height: 1.5;
}
.gifting-how-notice span:first-child { flex-shrink: 0; font-size: 1rem; }

/* Loading state */
.gifting-loading {
  text-align: center;
  padding: 40px;
  color: var(--text3);
  font-size: .9rem;
}

/* Admin sub-tabs */
.admin-sub-tabs {
  display: flex;
  gap: 8px;
  margin-bottom: 24px;
  flex-wrap: wrap;
}
.admin-sub-tab {
  background: var(--surface);
  border: 1.5px solid var(--border);
  border-radius: 8px;
  padding: 7px 16px;
  font-size: .85rem;
  font-weight: 600;
  color: var(--text2);
  cursor: pointer;
  transition: border-color .2s, color .2s, background .2s;
}
.admin-sub-tab:hover { border-color: var(--primary); color: var(--primary); }
.admin-sub-tab.active { background: var(--primary); border-color: var(--primary); color: #fff; }

.gifting-admin-section { display: block; }
.gifting-admin-accounts-grid { display: flex; flex-direction: column; gap: 10px; }

/* Credits table */
.gifting-credits-table {
  width: 100%;
  border-collapse: collapse;
  font-size: .88rem;
}
.gifting-credits-table th {
  text-align: left;
  padding: 10px 14px;
  background: var(--surface);
  border-bottom: 1px solid var(--border);
  color: var(--text3);
  font-size: .75rem;
  text-transform: uppercase;
  letter-spacing: .06em;
}
.gifting-credits-table td {
  padding: 10px 14px;
  border-bottom: 1px solid rgba(255,255,255,.04);
  color: var(--text);
}
.gifting-credits-table tr:hover td { background: var(--surface); }

@media (max-width: 768px) {
  .gifting-shop-layout { flex-direction: column; }
  .gifting-category-sidebar {
    width: 100%;
    flex-direction: row;
    flex-wrap: nowrap;
    overflow-x: auto;
    position: static;
    padding-bottom: 4px;
    gap: 6px;
  }
  .gifting-cat-btn { flex-shrink: 0; width: auto; }
}
@media (max-width: 640px) {
  .gifting-utility-bar  { padding: 16px 16px 0; }
  .gifting-pricing-section { padding: 32px 16px; }
  .gifting-shop-grid { grid-template-columns: repeat(auto-fill, minmax(130px, 1fr)); }
}

/* ══ GIFTING HERO ══ */
.gifting-hero {
  background: linear-gradient(135deg, #0a0416 0%, #130a2e 40%, #0d1a2e 100%);
  border-bottom: 1px solid var(--border);
  padding: 80px 0 60px;
  overflow: hidden;
  position: relative;
}
.gifting-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 60% 60% at 30% 50%, rgba(192,38,211,.12) 0%, transparent 70%),
              radial-gradient(ellipse 40% 40% at 70% 60%, rgba(124,58,237,.1) 0%, transparent 70%);
  pointer-events: none;
}
.gifting-hero-inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 24px;
  display: flex;
  align-items: center;
  gap: 48px;
  position: relative;
  z-index: 1;
}
.gifting-hero-text { flex: 1; min-width: 0; }
.gifting-hero-tag {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: .78rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--cyan);
  background: rgba(6,182,212,.1);
  border: 1px solid rgba(6,182,212,.25);
  border-radius: 999px;
  padding: 5px 14px;
  margin-bottom: 20px;
}
.gifting-hero-h1 {
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: 800;
  line-height: 1.15;
  margin-bottom: 16px;
  color: var(--text);
}
.gifting-hero-gradient {
  background: linear-gradient(135deg, #c026d3, #06b6d4);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.gifting-hero-sub {
  font-size: 1.05rem;
  color: var(--text2);
  line-height: 1.7;
  margin-bottom: 24px;
  max-width: 480px;
}
.gifting-trust-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 8px;
}
.gifting-trust-chip {
  font-size: .78rem;
  font-weight: 600;
  color: var(--text2);
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 999px;
  padding: 4px 12px;
}
/* Hero preview card */
.gifting-hero-card {
  flex-shrink: 0;
  width: 280px;
}
@media (max-width: 768px) { .gifting-hero-card { display: none; } .gifting-hero-inner { flex-direction: column; text-align: center; } .gifting-trust-row { justify-content: center; } .gifting-hero-sub { max-width: 100%; } }
.gifting-preview-card {
  background: var(--surface);
  border: 1px solid var(--border-glow);
  border-radius: 16px;
  padding: 20px;
  box-shadow: 0 8px 40px rgba(192,38,211,.15);
}
.gifting-preview-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: .85rem;
  font-weight: 600;
  margin-bottom: 16px;
  color: var(--text);
}
.gifting-preview-live {
  font-size: .72rem;
  color: #3fc45f;
  font-weight: 700;
  animation: blink 1.4s ease-in-out infinite;
}
@keyframes blink { 0%,100% { opacity: 1; } 50% { opacity: .4; } }
.gifting-preview-steps {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 16px;
}
.gifting-preview-step {
  font-size: .82rem;
  color: var(--text3);
  padding: 6px 10px;
  border-radius: 6px;
}
.gifting-preview-step.done { color: #3fc45f; }
.gifting-preview-step.active { color: var(--cyan); background: rgba(6,182,212,.08); font-weight: 600; }
.gifting-preview-bar-wrap {
  height: 6px;
  background: var(--bg2);
  border-radius: 3px;
  overflow: hidden;
  margin-bottom: 8px;
}
.gifting-preview-bar-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--primary), var(--cyan));
  border-radius: 3px;
  transition: width .6s ease;
}
.gifting-preview-pct { font-size: .75rem; color: var(--text3); text-align: right; }

/* ══ HOW IT WORKS — updated ══ */
.gifting-how-num {
  font-family: 'Rajdhani', sans-serif;
  font-size: 2.5rem;
  font-weight: 700;
  color: rgba(192,38,211,.2);
  line-height: 1;
  margin-bottom: 8px;
}

/* ══ ACCOUNTS SECTION ══ */
.gifting-accounts-section { padding-top: 60px; }
.gifting-accounts-login-gate {
  text-align: center;
  padding: 48px 24px;
  background: var(--surface);
  border: 1px dashed var(--border);
  border-radius: 16px;
  max-width: 420px;
  margin: 0 auto;
}

/* ══ SHOP — USD price badge ══ */
.gifting-shop-usd-tag {
  position: absolute;
  top: 8px;
  right: 8px;
  background: rgba(0,0,0,.75);
  backdrop-filter: blur(6px);
  color: #fff;
  font-size: .72rem;
  font-weight: 700;
  padding: 3px 8px;
  border-radius: 6px;
  border: 1px solid rgba(255,255,255,.15);
}
.gifting-shop-img { position: relative; }

/* ══ GIFT MODAL — payment options ══ */
.gd-pay-options { display: flex; flex-direction: column; gap: 0; }
.gd-pay-option { padding: 16px; background: var(--surface2); border: 1px solid var(--border); border-radius: 12px; }
.gd-pay-option-label { font-weight: 700; font-size: .92rem; margin-bottom: 4px; }
.gd-pay-option-sub { font-size: .8rem; color: var(--text3); min-height: 18px; }
.gd-pay-divider { display: flex; align-items: center; gap: 12px; padding: 10px 0; }
.gd-pay-divider::before,.gd-pay-divider::after { content:''; flex:1; height:1px; background:var(--border); }
.gd-pay-divider span { font-size:.78rem; color:var(--text3); flex-shrink:0; }

/* ══ ORDER HISTORY — DISCORD NOTICE + FULFILLED ══ */
.order-discord-notice {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  flex-wrap: wrap;
  background: rgba(88,101,242,.08);
  border: 1px solid rgba(88,101,242,.25);
  border-radius: 8px;
  padding: 8px 12px;
  margin-top: 8px;
  font-size: .8rem;
  color: var(--text2);
}
.order-fulfilled {
  border-color: rgba(16,185,129,.3) !important;
  background: rgba(16,185,129,.03);
}
.status-completed { background: rgba(16,185,129,.15); color: #10b981; border: 1px solid rgba(16,185,129,.3); }

/* ══ CREDIT PACKAGES SECTION ══ */
.gift-credits-section {
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  background: linear-gradient(180deg, rgba(192,38,211,.04) 0%, transparent 100%);
}
.gift-credit-packages {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 16px;
  max-width: 900px;
  margin: 0 auto;
}
.gift-credit-pkg {
  background: var(--surface);
  border: 2px solid var(--border);
  border-radius: 16px;
  padding: 22px 18px 18px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  position: relative;
  overflow: hidden;
  transition: transform .3s ease, box-shadow .3s ease, border-color .3s ease;
}
.gift-credit-pkg::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: var(--pkg-color, var(--primary));
}
.gift-credit-pkg:hover {
  transform: translateY(-6px);
  border-color: var(--pkg-color, var(--primary));
  box-shadow: 0 12px 36px rgba(0,0,0,.35);
}
.gift-credit-pkg-top {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
}
.gift-credit-pkg-img {
  width: 80px;
  height: 80px;
  object-fit: contain;
}
.gift-credit-pkg-rarity {
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.gift-credit-pkg-vb {
  font-family: 'Rajdhani', sans-serif;
  font-size: 1.6rem;
  font-weight: 800;
  color: var(--text);
  line-height: 1;
  margin-top: 4px;
}
.gift-credit-pkg-label {
  font-size: .78rem;
  color: var(--text3);
  margin-bottom: 4px;
}
.gift-credit-pkg-owned {
  font-size: .75rem;
  color: #3fc45f;
  font-weight: 600;
}
.gift-credit-pkg-price {
  font-size: 1.3rem;
  font-weight: 800;
  color: var(--text);
  margin: 4px 0 8px;
}
.gift-credit-pkg-btn {
  font-size: .82rem;
  padding: 9px 14px;
  border-radius: 8px;
  width: 100%;
}
.gift-credit-pkg-btn:disabled {
  opacity: .45;
  cursor: not-allowed;
  transform: none !important;
}
@media (max-width: 640px) {
  .gift-credit-packages { grid-template-columns: repeat(2, 1fr); }
}

/* ══ CURRENCY PICKER ══ */
.currency-picker-btn {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 5px 10px;
  background: rgba(255,255,255,.06);
  border: 1.5px solid rgba(192,38,211,.3);
  border-radius: 8px;
  color: var(--text2);
  font-size: .78rem;
  font-weight: 700;
  cursor: pointer;
  transition: var(--transition);
  white-space: nowrap;
}
.currency-picker-btn:hover {
  border-color: var(--primary);
  color: var(--text);
  background: rgba(192,38,211,.1);
}
#currencyIndicator { color: var(--primary); }

.currency-picker-panel {
  display: none;
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  width: 320px;
  background: var(--surface);
  border: 1px solid var(--border-glow);
  border-radius: 14px;
  padding: 16px;
  box-shadow: 0 12px 40px rgba(0,0,0,.6);
  z-index: 600;
}
.currency-picker-panel.open { display: block; }
.currency-picker-title {
  font-size: .78rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--text3);
  margin-bottom: 12px;
}
.currency-picker-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 6px;
}
.currency-opt {
  padding: 6px 4px;
  border-radius: 6px;
  font-size: .72rem;
  font-weight: 700;
  background: var(--surface2);
  border: 1px solid var(--border);
  color: var(--text2);
  cursor: pointer;
  transition: background .15s, border-color .15s, color .15s;
  text-align: center;
}
.currency-opt:hover { background: rgba(192,38,211,.15); border-color: var(--primary); color: var(--text); }
.currency-opt.active { background: rgba(192,38,211,.2); border-color: var(--primary); color: var(--primary); }

@media (max-width: 768px) {
  .currency-picker-btn { display: none; }
}

/* ══ SHOP HEADER ══ */
.gifting-shop-header { display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; margin-bottom: 28px; flex-wrap: wrap; }

/* ══════════════════════════════════════════
   GIFTING ANIMATIONS
══════════════════════════════════════════ */

/* ── Scroll-reveal ── */
@keyframes gRevealUp {
  from { opacity: 0; transform: translateY(36px); }
  to   { opacity: 1; transform: translateY(0); }
}
.g-reveal {
  opacity: 0;
  transform: translateY(36px);
  transition: opacity .65s cubic-bezier(.4,0,.2,1), transform .65s cubic-bezier(.4,0,.2,1);
}
.g-reveal.g-visible { opacity: 1; transform: translateY(0); }
.g-reveal-d1 { transition-delay: .08s; }
.g-reveal-d2 { transition-delay: .17s; }
.g-reveal-d3 { transition-delay: .26s; }
.g-reveal-d4 { transition-delay: .35s; }

/* ── Rotating word in hero ── */
.gifting-word-wrap {
  display: inline-block;
  overflow: hidden;
  vertical-align: bottom;
  height: 1.15em;
  position: relative;
}
.gifting-rotating-word {
  display: block;
  background: linear-gradient(135deg, #c026d3, #06b6d4);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  transition: transform .48s cubic-bezier(.4,0,.2,1), opacity .48s;
  transform: translateY(0);
  opacity: 1;
}
.gifting-rotating-word.slide-out {
  transform: translateY(-110%);
  opacity: 0;
}
.gifting-rotating-word.slide-in-prep {
  transform: translateY(110%);
  opacity: 0;
  transition: none;
}

/* ── Floating hero orbs ── */
@keyframes gFloatOrb {
  0%,100% { transform: translate(0,0) scale(1); }
  33%     { transform: translate(18px,-28px) scale(1.06); }
  66%     { transform: translate(-14px,16px) scale(.94); }
}
.gifting-hero-orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(55px);
  pointer-events: none;
  animation: gFloatOrb var(--orb-dur, 9s) ease-in-out infinite var(--orb-delay, 0s);
}
.gifting-hero-orb-1 { width: 320px; height: 320px; background: rgba(192,38,211,.18); top: -60px; left: 8%; --orb-dur:10s; --orb-delay:0s; }
.gifting-hero-orb-2 { width: 220px; height: 220px; background: rgba(6,182,212,.14); bottom: -40px; right: 12%; --orb-dur:12s; --orb-delay:-4s; }
.gifting-hero-orb-3 { width: 160px; height: 160px; background: rgba(124,58,237,.12); top: 45%; right: 28%; --orb-dur:8s; --orb-delay:-6s; }

/* ── How-it-works card hover lift ── */
.gifting-how-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 28px 24px;
  transition: transform .3s ease, box-shadow .3s ease, border-color .3s ease;
}
.gifting-how-card:hover {
  transform: translateY(-8px);
  box-shadow: 0 20px 50px rgba(192,38,211,.22);
  border-color: rgba(192,38,211,.45);
}
.gifting-how-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 20px;
}
.gifting-how-icon {
  font-size: 2rem;
  margin-bottom: 12px;
}
.gifting-how-section {
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}

/* ── Animated progress bar in preview card ── */
@keyframes gBarPulse {
  0%,100% { box-shadow: 0 0 8px rgba(192,38,211,.4); }
  50%     { box-shadow: 0 0 20px rgba(6,182,212,.6); }
}
.gifting-preview-bar-fill {
  animation: gBarPulse 2s ease-in-out infinite;
}

/* ── FAQ section ── */
.gifting-faq-section {
  padding: 72px 0;
  border-top: 1px solid var(--border);
}
.gifting-faq-inner {
  max-width: 780px;
  margin: 0 auto;
  padding: 0 24px;
}
.gifting-faq-title {
  text-align: center;
  font-size: 1.8rem;
  font-weight: 800;
  margin-bottom: 8px;
}
.gifting-faq-sub {
  text-align: center;
  color: var(--text2);
  margin-bottom: 40px;
  font-size: .95rem;
}
.gifting-faq-item {
  border: 1px solid var(--border);
  border-radius: 12px;
  margin-bottom: 10px;
  overflow: hidden;
  transition: border-color .25s;
}
.gifting-faq-item.open { border-color: rgba(192,38,211,.5); }
.gifting-faq-q {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px 20px;
  font-size: .95rem;
  font-weight: 600;
  color: var(--text);
  background: var(--surface);
  text-align: left;
  gap: 12px;
  transition: background .2s;
}
.gifting-faq-q:hover { background: var(--surface2); }
.gifting-faq-chevron {
  flex-shrink: 0;
  font-size: .75rem;
  transition: transform .3s cubic-bezier(.4,0,.2,1);
  opacity: .6;
}
.gifting-faq-item.open .gifting-faq-chevron { transform: rotate(180deg); }
.gifting-faq-a {
  max-height: 0;
  overflow: hidden;
  transition: max-height .35s cubic-bezier(.4,0,.2,1), padding .35s;
  background: var(--surface2);
  font-size: .88rem;
  color: var(--text2);
  line-height: 1.7;
  padding: 0 20px;
}
.gifting-faq-item.open .gifting-faq-a {
  max-height: 300px;
  padding: 16px 20px;
}

/* ── Shimmer glow on preview card ── */
@keyframes gCardShimmer {
  0%   { box-shadow: 0 8px 40px rgba(192,38,211,.15), 0 0 0 0 rgba(192,38,211,.0); }
  50%  { box-shadow: 0 8px 40px rgba(192,38,211,.25), 0 0 24px 2px rgba(6,182,212,.15); }
  100% { box-shadow: 0 8px 40px rgba(192,38,211,.15), 0 0 0 0 rgba(192,38,211,.0); }
}
.gifting-preview-card {
  animation: gCardShimmer 3s ease-in-out infinite;
}
