*{box-sizing:border-box;margin:0;padding:0}:root{--purple-50:#faf5ff;--purple-100:#f3e8ff;--purple-200:#e9d5ff;--purple-300:#d8b4fe;--purple-400:#c084fc;--purple-500:#a855f7;--purple-600:#9333ea;--purple-700:#7c3aed;--purple-800:#6d28d9;--purple-900:#581c87;--cyan-400:#22d3ee;--cyan-500:#06b6d4;--green-400:#4ade80;--green-500:#22c55e;--red-400:#f87171;--red-500:#ef4444;--amber-400:#fbbf24;--primary:#a855f7;--primary-hover:#9333ea;--primary-glow:#a855f759;--accent:linear-gradient(135deg, #a855f7, #6d28d9);--accent-warm:linear-gradient(135deg, #d946ef, #7c3aed);--accent-cool:linear-gradient(135deg, #a855f7, #06b6d4);--success:#22c55e;--danger:#ef4444;--info:#3b82f6;--warning:#f59e0b;--bg-base:#0a0a12;--bg-surface:#120c1ce6;--bg-elevated:#181026f2;--bg-card:linear-gradient(135deg, #140c24eb, #0a0a12eb);--bg-input:#0d0d14;--bg-glass:#0a0a0fb8;--border-subtle:#a855f726;--border-default:#a855f740;--border-strong:#a855f773;--border-muted:#ffffff0f;--text:#f5f5f7;--text-secondary:#d4d4d8;--text-muted:#a1a1aa;--text-faint:#6b7280;--text-purple:#e9d5ff;--text-lavender:#c4b5fd;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-7:32px;--space-8:40px;--space-9:48px;--space-10:64px;--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--radius-xl:18px;--radius-2xl:24px;--radius-full:999px;--shadow-sm:0 2px 8px #0003;--shadow-md:0 8px 24px #0000004d;--shadow-lg:0 16px 40px #0006;--shadow-glow-purple:0 0 30px #a855f733;--shadow-glow-strong:0 12px 32px #6d28d959;--ease-smooth:cubic-bezier(.4, 0, .2, 1);--ease-bounce:cubic-bezier(.34, 1.56, .64, 1);--ease-spring:cubic-bezier(.22, 1, .36, 1);--duration-fast:.15s;--duration-normal:.25s;--duration-slow:.4s;color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,system-ui,-apple-system,sans-serif;font-size:16px;line-height:1.6}html{scroll-behavior:smooth}body{background:var(--bg-base);min-height:100vh;overflow-x:hidden}#root{min-height:100vh}a{color:var(--primary);transition:color var(--duration-fast) var(--ease-smooth);text-decoration:none}button{cursor:pointer;font-family:inherit}input,textarea,select{font-family:inherit}img{max-width:100%;display:block}h1,h2,h3{font-family:Outfit,Inter,system-ui,sans-serif}@keyframes ui-spin{to{transform:rotate(360deg)}}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes fade-up{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes fade-up-sm{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes slide-in-right{0%{opacity:0;transform:translate(40px)}to{opacity:1;transform:translate(0)}}@keyframes slide-in-bottom{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}@keyframes scale-in{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}@keyframes shimmer{0%{background-position:-200%}to{background-position:200%}}@keyframes pulse-glow{0%,to{box-shadow:0 0 20px #a855f726}50%{box-shadow:0 0 40px #a855f759}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes orbit{0%{transform:rotate(0)translate(120px)rotate(0)}to{transform:rotate(360deg)translate(120px)rotate(-360deg)}}@keyframes gradient-shift{0%,to{background-position:0%}50%{background-position:100%}}@keyframes dual-ring{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes toast-enter{0%{opacity:0;transform:translate(40px)scale(.95)}to{opacity:1;transform:translate(0)scale(1)}}@keyframes toast-exit{0%{opacity:1;transform:translate(0)scale(1)}to{opacity:0;transform:translate(40px)scale(.95)}}.anim-fade-up{animation:fade-up .6s var(--ease-spring) both}.anim-fade-up-sm{animation:fade-up-sm .4s var(--ease-spring) both}.anim-scale-in{animation:scale-in .5s var(--ease-spring) both}.anim-fade-in{animation:fade-in .5s var(--ease-smooth) both}.loading-overlay{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:1000;animation:fade-in .3s var(--ease-smooth);background:#080810cc;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.loading-card{border-radius:var(--radius-xl);background:var(--bg-card);border:1px solid var(--border-default);box-shadow:var(--shadow-glow-purple);animation:scale-in .4s var(--ease-spring);flex-direction:column;align-items:center;gap:16px;padding:32px 40px;display:flex}.loading-spinner{border:3px solid var(--border-subtle);border-top-color:var(--purple-400);border-right-color:var(--purple-600);filter:drop-shadow(0 0 6px #a855f766);border-radius:50%;width:40px;height:40px;animation:.8s linear infinite dual-ring}.loading-text{color:var(--text-secondary);letter-spacing:.02em;box-shadow:none;background:0 0;font-size:.9rem;font-weight:600;animation:2s ease-in-out infinite pulse-glow}.toast-region{z-index:1001;flex-direction:column;gap:10px;max-width:360px;display:flex;position:fixed;bottom:20px;right:20px}.toast{border-radius:var(--radius-lg);border:1px solid var(--border-default);background:var(--bg-card);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);box-shadow:var(--shadow-lg);animation:toast-enter .4s var(--ease-spring) both;padding:14px 18px;position:relative;overflow:hidden}.toast:before{content:"";border-radius:4px 0 0 4px;width:4px;position:absolute;top:0;bottom:0;left:0}.toast__title{margin-bottom:4px;padding-left:8px;font-size:.9rem;font-weight:700}.toast__message{color:var(--text-secondary);padding-left:8px;font-size:.82rem;line-height:1.4}.toast--success{color:#bbf7d0;background:linear-gradient(135deg,#052e16e6,#0a0a12f2);border-color:#22c55e4d}.toast--success:before{background:var(--success)}.toast--error{color:#fecaca;background:linear-gradient(135deg,#3f0d0de6,#0a0a12f2);border-color:#ef44444d}.toast--error:before{background:var(--danger)}.toast--info{color:#bfdbfe;background:linear-gradient(135deg,#0b1b3ae6,#0a0a12f2);border-color:#3b82f64d}.toast--info:before{background:var(--info)}.shop-nav{z-index:100;transition:background var(--duration-normal) var(--ease-smooth);padding:12px 16px 8px;position:sticky;top:0}.shop-nav--scrolled{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#0a0a12eb}.shop-nav__inner{background:var(--bg-glass);border:1px solid var(--border-strong);border-radius:var(--radius-full);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);max-width:1100px;transition:all var(--duration-normal) var(--ease-smooth);justify-content:space-between;align-items:center;gap:16px;margin:0 auto;padding:10px 22px;display:flex;box-shadow:0 8px 32px #0006,inset 0 1px #ffffff0a}.shop-nav__logo{align-items:center;gap:10px;text-decoration:none;display:flex}.shop-nav__logo-icon{border-radius:var(--radius-md);background:var(--accent);color:#fff;width:36px;height:36px;transition:transform var(--duration-fast) var(--ease-bounce);justify-content:center;align-items:center;font-family:Outfit,sans-serif;font-size:18px;font-weight:900;display:flex;box-shadow:0 4px 16px #6d28d966}.shop-nav__logo-icon:hover{transform:scale(1.08)rotate(-4deg)}.shop-nav__logo-text{color:#fff;letter-spacing:-.01em;font-family:Outfit,sans-serif;font-size:1.05rem;font-weight:800}.shop-nav__links{gap:6px;display:flex}.shop-nav__link{color:var(--text-muted);transition:all var(--duration-fast) var(--ease-smooth);border-radius:var(--radius-md);align-items:center;gap:8px;padding:8px 14px;font-size:.88rem;font-weight:500;text-decoration:none;display:inline-flex;position:relative}.shop-nav__link:hover,.shop-nav__link:focus-visible{color:var(--text-purple);background:#a855f714}.shop-nav__link--active{color:var(--text-purple);background:#a855f71f}.shop-nav__link--active:after{content:"";background:var(--primary);border-radius:2px;width:16px;height:2px;position:absolute;bottom:2px;left:50%;transform:translate(-50%);box-shadow:0 0 8px #a855f799}.shop-nav__right{align-items:center;display:flex}.shop-nav__login{background:var(--accent);color:#fff;border-radius:var(--radius-md);transition:all var(--duration-fast) var(--ease-smooth);border:none;align-items:center;gap:8px;padding:8px 20px;font-size:.85rem;font-weight:600;text-decoration:none;display:inline-flex;box-shadow:0 8px 20px #6d28d959}.shop-nav__login:hover{transform:translateY(-1px);box-shadow:0 12px 28px #6d28d973}.shop-nav__icon{color:inherit;flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.shop-nav__label{display:inline-flex}.shop-nav__user{align-items:center;gap:10px;display:flex}.shop-nav__avatar{width:30px;height:30px;transition:border-color var(--duration-fast) var(--ease-smooth);border:2px solid #a855f766;border-radius:50%}.shop-nav__avatar:hover{border-color:var(--purple-400)}.shop-nav__name{color:#fff;font-size:.85rem;font-weight:600}.shop-nav__role{text-transform:uppercase;letter-spacing:.05em;color:var(--text-purple);border-radius:var(--radius-full);background:#a855f726;border:1px solid #a855f74d;padding:3px 8px;font-size:.68rem;font-weight:700}.shop-nav__logout{color:var(--text-muted);border-radius:var(--radius-sm);transition:all var(--duration-fast) var(--ease-smooth);background:0 0;border:1px solid #a855f74d;align-items:center;gap:6px;padding:6px 14px;font-size:.8rem;font-weight:500;display:inline-flex}.shop-nav__logout:hover{border-color:var(--danger);color:var(--red-400);background:#ef444414}.shop-page{background:var(--bg-base);min-height:100vh;padding-bottom:0}.shop-hero{text-align:left;padding:48px 20px 20px}.shop-hero__panel{border-radius:var(--radius-2xl);border:1px solid var(--border-strong);max-width:1100px;animation:fade-up .8s var(--ease-spring) both;background:radial-gradient(at 20%,#a855f733,#0000 60%),radial-gradient(at 80% 20%,#06b6d414,#0000 50%),linear-gradient(135deg,#20123bf2,#0e0a18f2);grid-template-columns:1fr 1fr;gap:32px;margin:0 auto;padding:48px;display:grid;position:relative;overflow:hidden;box-shadow:0 20px 60px #00000080,inset 0 1px #ffffff0a}.shop-hero__panel:before{content:"";pointer-events:none;background-image:linear-gradient(#ffffff05 1px,#0000 1px),linear-gradient(90deg,#ffffff05 1px,#0000 1px);background-size:60px 60px;position:absolute;inset:0}.shop-hero__panel:after{content:"";pointer-events:none;background:radial-gradient(circle,#a855f726,#0000 70%);border-radius:50%;width:300px;height:300px;animation:6s ease-in-out infinite float;position:absolute;top:-80px;right:-60px}.shop-hero__content{z-index:1;flex-direction:column;justify-content:center;display:flex;position:relative}.shop-hero__eyebrow{letter-spacing:.28em;text-transform:uppercase;color:var(--text-lavender);animation:fade-up-sm .5s var(--ease-spring) .1s both;margin-bottom:14px;font-size:.72rem;font-weight:600}.shop-hero__title{color:#fff;letter-spacing:-1.5px;animation:fade-up .6s var(--ease-spring) .15s both;margin-bottom:14px;font-size:clamp(2.2rem,4vw,3.4rem);font-weight:900;line-height:1.1}.shop-hero__accent{background:var(--accent-warm);-webkit-text-fill-color:transparent;background-size:200%;-webkit-background-clip:text;background-clip:text;animation:4s infinite gradient-shift}.shop-hero__subtitle{color:var(--text-secondary);max-width:480px;animation:fade-up .6s var(--ease-spring) .25s both;margin-bottom:24px;font-size:1.05rem;line-height:1.6}.shop-hero__actions{animation:fade-up .6s var(--ease-spring) .35s both;flex-wrap:wrap;gap:12px;margin-bottom:0;display:flex}.shop-hero__cta{border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.08em;transition:all var(--duration-fast) var(--ease-smooth);cursor:pointer;border:none;align-items:center;gap:8px;padding:12px 28px;font-size:.82rem;font-weight:700;text-decoration:none;display:inline-flex}.shop-hero__cta--primary{background:var(--accent);color:#fff;box-shadow:0 8px 24px #6d28d966}.shop-hero__cta--primary:hover{transform:translateY(-2px);box-shadow:0 14px 36px #6d28d98c}.shop-hero__cta--ghost{color:var(--text-purple);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#140a2480;border:1px solid #c4b5fd66}.shop-hero__cta--ghost:hover{background:#1e0f32b3;border-color:#c4b5fdb3;transform:translateY(-2px)}.shop-hero__tagline{color:var(--purple-400);font-size:.95rem}.shop-hero__image{z-index:1;animation:fade-up .7s var(--ease-spring) .3s both;flex-direction:column;justify-content:center;gap:16px;display:flex;position:relative}.shop-hero__userCountCard{background:var(--bg-card);border:1px solid var(--border-default);border-radius:var(--radius-xl);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);transition:all var(--duration-normal) var(--ease-smooth);flex-direction:row;align-items:center;gap:18px;padding:20px 22px;display:flex;position:relative;overflow:hidden;box-shadow:0 4px 20px #0000004d,inset 0 1px #ffffff0a}.shop-hero__userCountCard:before{content:"";border-radius:inherit;opacity:0;transition:opacity var(--duration-normal) var(--ease-smooth);background:linear-gradient(135deg,#a855f70d,#0000);position:absolute;inset:0}.shop-hero__userCountCard:hover{border-color:var(--border-strong);transform:translateY(-3px);box-shadow:0 8px 32px #6d28d940,0 0 0 1px #a855f71a}.shop-hero__userCountCard:hover:before{opacity:1}.shop-hero__userCard-header{flex-shrink:0}.shop-hero__userCard-icon{border-radius:var(--radius-lg);width:52px;height:52px;color:var(--purple-400);border:1px solid var(--border-default);transition:all var(--duration-normal) var(--ease-smooth);background:radial-gradient(circle at 0 0,#a855f74d,#a855f714);justify-content:center;align-items:center;display:flex;box-shadow:0 0 20px #a855f726}.shop-hero__userCountCard:hover .shop-hero__userCard-icon{transform:scale(1.05);box-shadow:0 0 28px #a855f74d}.shop-hero__userCard-body{flex-direction:column;justify-content:center;display:flex}.shop-hero__userCount{color:var(--green-500);text-shadow:0 0 16px #22c55e4d;letter-spacing:-.5px;margin:0;font-family:Outfit,sans-serif;font-size:1.8rem;font-weight:900;line-height:1}.shop-hero__userLabel{color:var(--text-secondary);margin-top:6px;font-size:.88rem;font-weight:500}.quick-actions{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;max-width:1100px;margin:28px auto 0;padding:0 20px;display:grid}.action-card{border-radius:var(--radius-xl);background:var(--bg-card);border:1px solid var(--border-default);color:var(--text);box-shadow:var(--shadow-md);transition:all var(--duration-normal) var(--ease-smooth);animation:fade-up .5s var(--ease-spring) both;align-items:center;gap:14px;padding:18px 20px;text-decoration:none;display:flex;position:relative;overflow:hidden}.action-card:before{content:"";opacity:0;transition:opacity var(--duration-normal) var(--ease-smooth);background:linear-gradient(135deg,#a855f70f,#0000);position:absolute;inset:0}.action-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow-glow-strong);transform:translateY(-4px)}.action-card:hover:before{opacity:1}.action-card__icon{border-radius:var(--radius-lg);border:1px solid var(--border-default);width:48px;height:48px;color:var(--purple-300);transition:all var(--duration-normal) var(--ease-smooth);background:radial-gradient(circle at 0 0,#a855f740,#a855f70f);flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.action-card:hover .action-card__icon{transform:scale(1.06);box-shadow:0 0 20px #a855f740}.action-card__text{flex-direction:column;gap:3px;display:flex}.action-card__title{color:var(--text);font-size:.95rem;font-weight:700}.action-card__subtitle{color:var(--text-lavender);font-size:.82rem}.action-card__cta{border-radius:var(--radius-full);border:1px solid var(--border-default);text-transform:uppercase;letter-spacing:.05em;color:var(--text-lavender);transition:all var(--duration-fast) var(--ease-smooth);background:#a855f71f;margin-left:auto;padding:6px 12px;font-size:.72rem;font-weight:600}.action-card:hover .action-card__cta{border-color:var(--border-strong);background:#a855f740}.shop-footer{border-top:1px solid var(--border-subtle);text-align:center;background:linear-gradient(#0000,#a855f708);padding:40px 24px}.shop-footer__inner{flex-direction:column;align-items:center;gap:20px;max-width:1100px;margin:0 auto;display:flex}.shop-footer__brand{align-items:center;gap:10px;margin-bottom:4px;display:flex}.shop-footer__logo{border-radius:var(--radius-sm);background:var(--accent);color:#fff;justify-content:center;align-items:center;width:32px;height:32px;font-family:Outfit,sans-serif;font-size:14px;font-weight:900;display:flex}.shop-footer__brand-name{color:var(--text);font-family:Outfit,sans-serif;font-size:1rem;font-weight:700}.shop-footer__links{flex-wrap:wrap;justify-content:center;gap:24px;display:flex}.shop-footer__link{color:var(--text-muted);transition:color var(--duration-fast) var(--ease-smooth);font-size:.85rem;font-weight:500;text-decoration:none}.shop-footer__link:hover{color:var(--text-purple)}.shop-footer__divider{background:linear-gradient(90deg, transparent, var(--border-subtle), transparent);width:100%;max-width:400px;height:1px}.shop-footer__text{color:var(--text-faint);font-size:.78rem}.product-grid{max-width:1200px;margin:0 auto;padding:40px 24px 80px}.product-grid__title{color:#fff;letter-spacing:-.5px;margin-bottom:24px;font-size:1.6rem;font-weight:800}.product-grid__error{color:var(--danger)}.product-grid__list{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px;display:grid}.product-card{background:var(--bg-surface);border-radius:var(--radius-xl);border:1px solid var(--border-default);transition:all var(--duration-normal) var(--ease-smooth);animation:fade-up .5s var(--ease-spring) both;position:relative;overflow:hidden}.product-card--out-of-stock{cursor:default;pointer-events:none}.product-card--out-of-stock:after{content:"";border-radius:inherit;z-index:5;pointer-events:none;background:#0000008c;position:absolute;inset:0}.product-card__oos-badge{z-index:10;border:2px solid var(--danger);text-align:center;width:96px;height:96px;color:var(--red-400);text-transform:uppercase;letter-spacing:.08em;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);pointer-events:none;background:#0a0a12d1;border-radius:50%;justify-content:center;align-items:center;font-size:.72rem;font-weight:800;line-height:1.3;display:flex;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 0 0 3px #ef444440,0 4px 20px #00000080}.product-card:hover{box-shadow:var(--shadow-glow-strong);border-color:var(--border-strong);transform:translateY(-6px)}.product-card__badge{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:var(--text-purple);border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.06em;border:1px solid var(--border-default);z-index:2;background:#0a0a12b3;padding:4px 12px;font-size:.68rem;font-weight:700;position:absolute;top:14px;right:14px}.product-card__image{border-bottom:1px solid var(--border-subtle);background:radial-gradient(at top,#a855f733,#0000 70%);width:100%;height:200px;position:relative}.product-card__image--script{background:linear-gradient(135deg,#38bdf833,#0f172ae6)}.product-card__image--item{background:linear-gradient(135deg,#f8717133,#0f172ae6)}.product-card__body{padding:18px}.product-card__title{color:#fff;letter-spacing:-.01em;margin-bottom:10px;font-size:1.02rem;font-weight:700}.product-card__price-row{justify-content:space-between;align-items:center;gap:8px;margin-bottom:16px;display:flex}.product-card__price{color:var(--green-500);font-family:Outfit,sans-serif;font-size:1.15rem;font-weight:800}.product-card__stock{color:var(--text-faint);font-size:.82rem;font-weight:500}.product-card__link{background:var(--accent);color:#fff;border-radius:var(--radius-md);width:100%;transition:all var(--duration-fast) var(--ease-smooth);text-align:center;letter-spacing:.02em;border:none;padding:11px;font-size:.85rem;font-weight:700;text-decoration:none;display:inline-block}.product-card__link--disabled{opacity:.45;cursor:not-allowed;pointer-events:none;background:var(--bg-elevated);color:var(--text-muted)}.product-card__stock--out{color:var(--red-400);font-weight:600}.product-card__link:hover{transform:translateY(-1px);box-shadow:0 8px 24px #6d28d966}.category-container{border:1px solid var(--border-default);background:var(--bg-card);border-radius:var(--radius-2xl);color:var(--text-secondary);max-width:1100px;animation:fade-up .6s var(--ease-spring) .2s both;margin:32px auto 60px;padding:28px;position:relative;overflow:hidden}.category-container:before{content:"";pointer-events:none;background:radial-gradient(circle,#a855f70f,#0000 70%);border-radius:50%;width:400px;height:400px;position:absolute;top:-50%;right:-30%}.category-container__header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.category-container__title{color:var(--text);letter-spacing:-.5px;margin:0;font-size:1.5rem;font-weight:800}.categories-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:18px;min-height:120px;display:grid}.categories-container{border:1px dashed var(--border-default);border-radius:var(--radius-xl);width:100%;color:var(--text-lavender);background:#0f0a1a80;justify-content:center;align-items:center;padding:32px;display:flex}.category-card{background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-xl);transition:all var(--duration-normal) var(--ease-smooth);animation:fade-up .5s var(--ease-spring) both;overflow:hidden}.category-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow-glow-strong);transform:translateY(-6px)}.category-card__link{color:inherit;text-decoration:none;display:block}.category-card__image{object-fit:cover;width:100%;height:160px;transition:transform var(--duration-slow) var(--ease-smooth);display:block}.category-card:hover .category-card__image{transform:scale(1.05)}.category-card__name{color:var(--text);margin:16px 18px 8px;font-size:1.1rem;font-weight:700}.category-card__details{color:var(--text-lavender);margin:0 18px 18px;font-size:.88rem;line-height:1.5}.category-container__footer{justify-content:flex-end;margin-top:24px;display:flex}.recent-buy{border-radius:var(--radius-2xl);max-width:1100px;animation:fade-up .6s var(--ease-spring) .25s both;background:radial-gradient(circle at 0 0,#a855f71f,#0000 38%),linear-gradient(#120c20f5,#0a0a12fa);border:1px solid #a855f72e;margin:0 auto 60px;padding:28px;position:relative;overflow:hidden;box-shadow:0 18px 55px #00000059,inset 0 1px #ffffff08}.recent-buy:before,.recent-buy:after{content:"";pointer-events:none;z-index:2;width:88px;position:absolute;top:0;bottom:0}.recent-buy:before{background:linear-gradient(90deg,#0a0a12,#0a0a1200);left:0}.recent-buy:after{background:linear-gradient(270deg,#0a0a12,#0a0a1200);right:0}.recent-buy__header{justify-content:space-between;align-items:end;gap:16px;margin-bottom:22px;display:flex}.recent-buy__eyebrow{color:var(--text-lavender);text-transform:uppercase;letter-spacing:.22em;margin:0 0 6px;font-size:.7rem;font-weight:700}.recent-buy__title{color:#fff;letter-spacing:-.04em;margin:0;font-size:1.45rem;font-weight:800}.recent-buy__subtitle{color:var(--text-secondary);margin:0;font-size:.92rem}.recent-buy__empty{border-radius:var(--radius-xl);color:var(--text-lavender);background:#0a0a1273;border:1px dashed #a855f740;padding:28px}.recent-buy__marquee{overflow:hidden;-webkit-mask-image:linear-gradient(90deg,#0000 0,#000 8% 92%,#0000 100%);mask-image:linear-gradient(90deg,#0000 0,#000 8% 92%,#0000 100%)}.recent-buy__track{gap:14px;width:max-content;animation:28s linear infinite recent-buy-marquee;display:flex}.recent-buy__track:hover{animation-play-state:paused}.recent-buy__card{border-radius:var(--radius-xl);background:linear-gradient(135deg,#1f1236eb,#0c0c14eb);border:1px solid #a855f724;flex-shrink:0;align-items:center;gap:14px;width:300px;padding:14px;display:flex;box-shadow:0 10px 30px #00000038}.recent-buy__image-wrap{background:#ffffff05;border:1px solid #ffffff14;border-radius:18px;flex-shrink:0;width:64px;height:64px;overflow:hidden}.recent-buy__image{object-fit:cover;width:100%;height:100%;display:block}.recent-buy__body{flex-direction:column;gap:4px;min-width:0;display:flex}.recent-buy__product{color:#fff;margin:0;font-size:.98rem;font-weight:700;line-height:1.25}.recent-buy__user{color:var(--text-secondary);margin:0;font-size:.84rem}.recent-buy__time{border-radius:var(--radius-full);letter-spacing:.02em;color:var(--text-purple);background:#a855f71f;border:1px solid #a855f72e;align-self:flex-start;margin-top:4px;padding:4px 8px;font-size:.72rem;font-weight:700;display:inline-flex}@keyframes recent-buy-marquee{0%{transform:translate(0)}to{transform:translate(-50%)}}.button{border-radius:var(--radius-md);border:1px solid var(--border-strong);background:var(--accent);color:#fff;cursor:pointer;transition:all var(--duration-fast) var(--ease-smooth);padding:10px 20px;font-size:.9rem;font-weight:700}.button:hover{box-shadow:var(--shadow-glow-strong);transform:translateY(-1px)}.category-page{background:var(--bg-base);color:#fff;min-height:100vh;padding:32px 24px 80px}.category-page__empty{border-radius:var(--radius-2xl);background:var(--bg-card);border:1px solid var(--border-default);text-align:center;max-width:720px;animation:scale-in .5s var(--ease-spring) both;margin:80px auto 0;padding:48px}.category-page__empty h2{color:#fff;margin-bottom:10px;font-weight:800}.category-page__empty p{color:var(--text-muted)}.products-page{background:var(--bg-base);color:#fff;min-height:100vh;padding:32px}.products-page__header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin-bottom:28px;display:flex}.products-page__title{letter-spacing:-.5px;margin:0;font-size:2rem;font-weight:800}.products-page__subtitle{color:var(--text-muted);margin:6px 0 0}.products-page__actions{align-items:center;gap:12px;display:flex}.products-page__button{border-radius:var(--radius-md);border:1px solid var(--border-default);background:var(--bg-elevated);color:var(--text-secondary);cursor:pointer;transition:all var(--duration-fast) var(--ease-smooth);padding:10px 18px;font-weight:600}.products-page__button:hover{border-color:var(--border-strong);background:#a855f71a}.products-page__link{border-radius:var(--radius-md);background:var(--accent);color:#fff;transition:all var(--duration-fast) var(--ease-smooth);border:none;padding:10px 18px;font-weight:700;text-decoration:none}.products-page__link:hover{box-shadow:var(--shadow-glow-strong);transform:translateY(-1px)}.products-page__error{color:var(--red-400)}.products-page__grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:18px;display:grid}.products-page__card{background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-xl);transition:all var(--duration-normal) var(--ease-smooth);flex-direction:column;gap:14px;padding:18px;display:flex}.products-page__card:hover{border-color:var(--border-strong);box-shadow:var(--shadow-glow-purple);transform:translateY(-3px)}.products-page__card-header{justify-content:space-between;align-items:center;gap:8px;display:flex}.products-page__card-title{margin:0;font-size:1.1rem;font-weight:700}.products-page__badge{color:var(--text-purple);border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.05em;border:1px solid var(--border-subtle);background:#a855f71f;padding:4px 10px;font-size:.72rem;font-weight:700}.products-page__card-body{color:var(--text-secondary);justify-content:space-between;align-items:center;display:flex}.products-page__price{color:var(--green-500);margin:0;font-family:Outfit,sans-serif;font-size:1.15rem;font-weight:800}.products-page__stock{color:var(--text-muted);margin:0}.products-page__card-footer{justify-content:space-between;align-items:center;gap:12px;display:flex}.products-page__hint{color:var(--text-muted);font-size:.8rem}.products-page__image{border-radius:var(--radius-lg) var(--radius-lg) 0 0;border-bottom:1px solid var(--border-subtle);background-position:50%;background-size:cover;height:160px}.product-detail{background:var(--bg-base);color:#fff;justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex;position:relative}.product-detail:before{content:"";pointer-events:none;background:radial-gradient(circle,#a855f70f,#0000 70%);border-radius:50%;width:500px;height:500px;position:absolute;top:10%;left:20%}.product-detail__card{background:var(--bg-card);border:1px solid var(--border-default);border-radius:var(--radius-2xl);width:100%;max-width:540px;animation:scale-in .5s var(--ease-spring) both;box-shadow:var(--shadow-lg);flex-direction:column;gap:18px;padding:28px;display:flex;position:relative}.product-detail__back{color:var(--text-muted);transition:color var(--duration-fast) var(--ease-smooth);align-items:center;gap:6px;font-size:.88rem;font-weight:500;text-decoration:none;display:inline-flex}.product-detail__back:hover{color:var(--text-purple)}.product-detail__image{border-radius:var(--radius-lg);border:1px solid var(--border-subtle);background-position:50%;background-size:cover;width:100%;height:220px;margin-bottom:4px;position:relative;overflow:hidden}.product-detail__header{justify-content:space-between;align-items:center;gap:12px;display:flex}.product-detail__title{letter-spacing:-.5px;margin:0;font-size:1.7rem;font-weight:800}.product-detail__badge{color:var(--text-purple);border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.05em;border:1px solid var(--border-subtle);background:#a855f71f;padding:5px 12px;font-size:.72rem;font-weight:700}.product-detail__details{color:var(--text-muted);margin:0;font-size:.95rem;line-height:1.6}.product-detail__meta{border-radius:var(--radius-lg);border:1px solid var(--border-subtle);background:#0a0a1280;justify-content:space-between;align-items:center;padding:14px 18px;display:flex}.product-detail__price{color:var(--green-500);font-family:Outfit,sans-serif;font-size:1.3rem;font-weight:800}.product-detail__stock{color:var(--text-muted);font-weight:500}.product-detail__button{border-radius:var(--radius-lg);background:var(--accent);color:#fff;cursor:pointer;transition:all var(--duration-fast) var(--ease-smooth);letter-spacing:.02em;border:none;padding:14px;font-size:1rem;font-weight:700}.product-detail__button:hover:not(:disabled){box-shadow:var(--shadow-glow-strong);transform:translateY(-2px)}.product-detail__button:disabled{opacity:.6;cursor:not-allowed}.product-detail__info{color:var(--text-muted)}.product-detail__error{color:var(--red-400)}.product-detail__message{color:var(--text-secondary);border-radius:var(--radius-md);border:1px solid var(--border-subtle);word-break:break-all;background:#0a0a1280;margin:0;padding:12px 16px;font-size:.9rem}.history-page{background:var(--bg-base);color:#fff;justify-content:center;min-height:100vh;padding:32px;display:flex}.history-page__card{background:var(--bg-card);border:1px solid var(--border-default);border-radius:var(--radius-2xl);width:100%;max-width:720px;animation:fade-up .6s var(--ease-spring) both;box-shadow:var(--shadow-lg);flex-direction:column;gap:18px;padding:28px;display:flex}.history-page__title{letter-spacing:-.5px;margin:0;font-size:1.8rem;font-weight:800}.history-page__subtitle{color:var(--text-muted);margin:0;font-size:.9rem}.history-page__info{color:var(--text-muted);text-align:center;padding:32px}.history-page__error{color:var(--red-400)}.history-page__list{flex-direction:column;gap:10px;display:flex}.history-page__row{border-radius:var(--radius-lg);border:1px solid var(--border-subtle);transition:all var(--duration-fast) var(--ease-smooth);animation:fade-up-sm .4s var(--ease-spring) both;background:#120c1c99;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:16px 18px;display:flex}.history-page__row:hover{border-color:var(--border-default);background:#181026b3}.history-page__row-title{text-transform:uppercase;letter-spacing:.06em;color:var(--text-lavender);margin:0;font-size:.75rem;font-weight:700}.history-page__row-text{color:var(--text-secondary);margin:4px 0 0;font-size:.88rem}.history-page__amount-box{flex-direction:column;align-items:flex-end;gap:4px;display:flex}.history-page__amount{color:var(--green-500);font-family:Outfit,sans-serif;font-size:1.05rem;font-weight:800}.history-page__date{color:var(--text-faint);font-size:.78rem}.dashboard-page{background:var(--bg-base);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex;position:relative}.dashboard-page:before{content:"";pointer-events:none;background:radial-gradient(circle,#a855f70f,#0000 70%);border-radius:50%;width:400px;height:400px;position:absolute;top:20%;right:30%}.dashboard-card{background:var(--bg-card);border:1px solid var(--border-default);border-radius:var(--radius-2xl);text-align:center;box-shadow:var(--shadow-lg);width:100%;max-width:440px;animation:scale-in .5s var(--ease-spring) both;padding:40px;position:relative}.dashboard-meta{flex-direction:column;gap:8px;width:100%;margin-top:12px;display:flex}.dashboard-meta-row{color:#ffffffb3;border-radius:var(--radius-md);transition:background var(--duration-fast) var(--ease-smooth);background:#0a0a1266;justify-content:space-between;align-items:center;margin:0;padding:8px 14px;font-size:.88rem;display:flex}.dashboard-meta-row:hover{background:#0f0c1c99}.dashboard-meta-label{color:var(--text-muted);font-weight:500}.dashboard-meta-value{color:#ffffffe6;font-weight:700}.dashboard-user-id{color:var(--text-faint);margin-top:8px;margin-bottom:24px;font-size:.78rem}.dashboard-logout{color:#fff;border-radius:var(--radius-lg);cursor:pointer;transition:all var(--duration-fast) var(--ease-smooth);background:linear-gradient(135deg,#ef4444,#dc2626);border:none;padding:13px 36px;font-size:.95rem;font-weight:700}.dashboard-logout:hover{transform:translateY(-2px);box-shadow:0 8px 24px #ef444459}.topup-page{background:var(--bg-base);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex;position:relative}.topup-page:before{content:"";pointer-events:none;background:radial-gradient(circle,#22c55e0a,#0000 70%);border-radius:50%;width:500px;height:500px;position:absolute;bottom:20%;left:15%}.topup-card{background:var(--bg-card);border:1px solid var(--border-default);border-radius:var(--radius-2xl);box-shadow:var(--shadow-lg);width:100%;max-width:480px;animation:scale-in .5s var(--ease-spring) both;padding:36px;position:relative}.topup-back{color:var(--text-muted);transition:color var(--duration-fast) var(--ease-smooth);align-items:center;gap:6px;margin-bottom:18px;font-size:.85rem;font-weight:500;text-decoration:none;display:inline-flex}.topup-back:hover{color:var(--text-purple)}.topup-title{color:#fff;letter-spacing:-.5px;margin-bottom:22px;font-size:1.6rem;font-weight:800}.topup-credit{border-radius:var(--radius-lg);border:1px solid var(--border-subtle);background:#0a0a1280;justify-content:space-between;align-items:center;margin-bottom:26px;padding:18px 22px;display:flex}.topup-credit-label{color:var(--text-muted);font-size:.9rem;font-weight:500}.topup-credit-value{color:var(--green-500);font-family:Outfit,sans-serif;font-size:1.2rem;font-weight:800}.topup-form{flex-direction:column;gap:14px;display:flex}.topup-label{color:var(--text-secondary);font-size:.9rem;font-weight:600}.topup-input{border-radius:var(--radius-lg);border:1px solid var(--border-subtle);background:var(--bg-input);color:#fff;transition:all var(--duration-fast) var(--ease-smooth);outline:none;padding:14px 18px;font-size:.95rem}.topup-input--error{box-shadow:0 0 0 3px #ef444426;border-color:var(--danger)!important}.topup-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #a855f726}.topup-input::placeholder{color:var(--text-faint)}.topup-error{color:var(--danger);margin:0;font-size:.85rem;font-weight:500}.topup-success{color:var(--success);margin:0;font-size:.85rem;font-weight:500}.topup-submit{background:var(--accent);color:#fff;border-radius:var(--radius-lg);cursor:pointer;transition:all var(--duration-fast) var(--ease-smooth);letter-spacing:.02em;border:none;margin-top:6px;padding:14px;font-size:1rem;font-weight:700}.topup-submit:hover:not(:disabled){box-shadow:var(--shadow-glow-strong);transform:translateY(-2px)}.topup-submit:disabled{opacity:.6;cursor:not-allowed}.login-page{background:var(--bg-base);justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative;overflow:hidden}.login-page:before{content:"";pointer-events:none;background:radial-gradient(circle,#a855f714,#0000 70%);border-radius:50%;width:500px;height:500px;animation:8s ease-in-out infinite float;position:absolute;top:-20%;left:-10%}.login-page:after{content:"";pointer-events:none;background:radial-gradient(circle,#06b6d40f,#0000 70%);border-radius:50%;width:400px;height:400px;animation:10s ease-in-out infinite reverse float;position:absolute;bottom:-15%;right:-5%}.login-card{background:var(--bg-card);border:1px solid var(--border-default);border-radius:var(--radius-2xl);text-align:center;box-shadow:var(--shadow-lg);width:100%;max-width:420px;animation:scale-in .5s var(--ease-spring) both;z-index:1;padding:48px;position:relative}.login-title{color:#fff;letter-spacing:-1px;margin-bottom:10px;font-size:2.2rem;font-weight:900}.login-subtitle{color:var(--text-muted);margin-bottom:36px;font-size:1rem;line-height:1.5}.login-discord-btn{color:#fff;border-radius:var(--radius-lg);transition:all var(--duration-fast) var(--ease-smooth);cursor:pointer;letter-spacing:.01em;background:linear-gradient(135deg,#5865f2,#4752c4);border:none;align-items:center;gap:12px;padding:15px 32px;font-size:1rem;font-weight:700;text-decoration:none;display:inline-flex;box-shadow:0 8px 24px #5865f24d}.login-discord-btn:hover{transform:translateY(-2px);box-shadow:0 14px 36px #5865f273}.auth-callback{background:var(--bg-base);color:#fff;justify-content:center;align-items:center;min-height:100vh;display:flex}.profile-header{border-radius:var(--radius-lg);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:16px 20px;display:flex}.profile-header--solid{border:1px solid var(--border-subtle);background:#0f172acc}.profile-header--glass{border:1px solid var(--border-muted);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff0a}.profile-header--light{color:#0f172a;background:#f8fafc;border:1px solid #e2e8f0}.profile-header__left{align-items:center;gap:14px;display:flex}.profile-header__avatar{object-fit:cover;width:44px;height:44px;transition:border-color var(--duration-fast) var(--ease-smooth);border:2px solid #a855f780;border-radius:50%}.profile-header__avatar:hover{border-color:var(--purple-400)}.profile-header__avatar--lg{width:64px;height:64px}.profile-header__label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin:0;font-size:.78rem;font-weight:500}.profile-header__value{color:#fff;margin:4px 0 0;font-size:1.05rem;font-weight:800}.profile-header--light .profile-header__label{color:#64748b}.profile-header--light .profile-header__value{color:#0f172a}.profile-header__meta{flex-direction:column;align-items:flex-end;gap:6px;display:flex}.profile-header__meta-item{color:var(--text-secondary);font-size:.85rem}.profile-header--light .profile-header__meta-item{color:#475569}.profile-header__badge-row{flex-wrap:wrap;justify-content:flex-end;gap:6px;display:flex}.profile-header__badge{border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.05em;padding:4px 10px;font-size:.7rem;font-weight:700}.profile-header__badge--neutral.profile-header__badge--solid{color:#e5e7eb;background:#1f2937;border:1px solid #374151}.profile-header__badge--success.profile-header__badge--solid{color:#bbf7d0;background:#052e16;border:1px solid #14532d}.profile-header__badge--info.profile-header__badge--solid{color:#bfdbfe;background:#0b1b3a;border:1px solid #1e3a8a}.profile-header__badge--warning.profile-header__badge--solid{color:#fde68a;background:#3f2d0d;border:1px solid #92400e}.profile-header__badge--neutral.profile-header__badge--light{color:#0f172a;background:#e2e8f0;border:1px solid #cbd5e1}.profile-header__badge--success.profile-header__badge--light{color:#14532d;background:#dcfce7;border:1px solid #86efac}.profile-header__badge--info.profile-header__badge--light{color:#1e3a8a;background:#dbeafe;border:1px solid #93c5fd}.profile-header__badge--warning.profile-header__badge--light{color:#854d0e;background:#fef9c3;border:1px solid #fde68a}.profile-header__badge--neutral.profile-header__badge--glass{color:#e5e7eb;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#0f172a99;border:1px solid #94a3b84d}.profile-header__badge--success.profile-header__badge--glass{color:#bbf7d0;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#052e1699;border:1px solid #22c55e4d}.profile-header__badge--info.profile-header__badge--glass{color:#bfdbfe;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#02061799;border:1px solid #3b82f64d}.profile-header__badge--warning.profile-header__badge--glass{color:#fde68a;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#3f2d0d99;border:1px solid #f59e0b4d}.profile-header__syncing{border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.05em;color:#7dd3fc;box-shadow:none;background:#38bdf81a;border:1px solid #38bdf84d;padding:4px 12px;font-size:.68rem;font-weight:700;animation:2s ease-in-out infinite pulse-glow}.admin-page{background:var(--bg-base);color:#fff;max-width:1200px;min-height:100vh;margin:0 auto;padding:40px 24px 80px}.admin-page__title{letter-spacing:-.5px;margin-bottom:12px;font-size:2.2rem;font-weight:900}.admin-page__subtitle{color:var(--text-muted);max-width:640px;margin-bottom:24px}.admin-page__actions{gap:12px;margin-bottom:32px;display:flex}.admin-page__btn{border-radius:var(--radius-md);background:var(--accent);color:#fff;cursor:pointer;transition:all var(--duration-fast) var(--ease-smooth);border:none;padding:11px 22px;font-weight:700}.admin-page__btn:hover{box-shadow:var(--shadow-glow-strong);transform:translateY(-1px)}.admin-page__grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px;display:grid}.admin-page__cat-card{background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-xl);transition:all var(--duration-normal) var(--ease-smooth);flex-direction:column;display:flex;overflow:hidden}.admin-page__cat-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow-glow-purple);transform:translateY(-3px)}.admin-page__cat-img{object-fit:cover;border-bottom:1px solid var(--border-subtle);width:100%;height:140px;display:block}.admin-page__cat-body{flex-direction:column;flex:1;gap:4px;padding:14px 16px 10px;display:flex}.admin-page__cat-name{color:var(--text);font-size:1rem;font-weight:700}.admin-page__cat-details{color:var(--text-lavender);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:.82rem;display:-webkit-box;overflow:hidden}.admin-page__cat-actions{border-top:1px solid var(--border-subtle);gap:8px;padding:10px 16px 14px;display:flex}.admin-page__cat-btn{border-radius:var(--radius-md);border:1px solid var(--border-default);background:var(--bg-elevated);color:var(--text-secondary);text-align:center;cursor:pointer;transition:all var(--duration-fast) var(--ease-smooth);flex:1;padding:8px 12px;font-size:.82rem;font-weight:600;text-decoration:none}.admin-page__cat-btn:hover{border-color:var(--border-strong);color:var(--text-purple);background:#a855f71a}.admin-page__cat-btn--edit{color:var(--text-purple);background:#a855f71a;border-color:#a855f759}.admin-page__cat-btn--edit:hover{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:var(--shadow-glow-strong)}.admin-edit__back-btn{border-radius:var(--radius-md);border:1px solid var(--border-default);background:var(--bg-elevated);color:var(--text-secondary);transition:all var(--duration-fast) var(--ease-smooth);padding:9px 18px;font-size:.88rem;font-weight:600;text-decoration:none}.admin-edit__back-btn:hover{border-color:var(--border-strong);background:#a855f714}.admin-edit__input--error{box-shadow:0 0 0 3px #ef444426;border-color:var(--danger)!important}.admin-edit__field-error{color:var(--red-400);margin-top:2px;font-size:.8rem;font-weight:500}.admin-categories{background:var(--bg-base);color:#fff;min-height:100vh}.admin-categories__hero{text-align:center;background:linear-gradient(#a855f70f 0%,#0000 100%);padding:72px 24px 48px}.admin-categories__title{letter-spacing:-1px;margin-bottom:12px;font-size:2.6rem;font-weight:900}.admin-categories__accent{background:var(--accent-warm);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.admin-categories__subtitle{color:var(--text-muted);max-width:520px;margin:0 auto;font-size:1rem}.admin-categories__content{max-width:960px;margin:0 auto;padding:0 24px 80px}.admin-categories__form{background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-xl);gap:20px;padding:32px;display:grid}.admin-categories__form-title{margin-bottom:4px;font-size:1.3rem;font-weight:800}.admin-categories__field{gap:8px;display:grid}.admin-categories__label{color:var(--text-secondary);font-size:.88rem;font-weight:600}.admin-categories__input{border-radius:var(--radius-md);border:1px solid var(--border-subtle);background:var(--bg-input);color:#fff;width:100%;transition:all var(--duration-fast) var(--ease-smooth);padding:12px 16px}.admin-categories__input--error{box-shadow:0 0 0 3px #ef444426;border-color:var(--danger)!important}.admin-categories__field-error{color:var(--red-400);margin-top:2px;font-size:.8rem;font-weight:500}.admin-categories__input:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #a855f726}.admin-categories__input::placeholder{color:var(--text-faint)}.admin-categories__actions{justify-content:flex-end;display:flex}.admin-categories__button{border-radius:var(--radius-md);background:var(--accent);color:#fff;cursor:pointer;transition:all var(--duration-fast) var(--ease-smooth);border:none;padding:11px 22px;font-weight:700}.admin-categories__button:hover{box-shadow:var(--shadow-glow-strong);transform:translateY(-1px)}.admin-products{background:var(--bg-base);color:#fff;justify-content:center;min-height:100vh;padding:32px;display:flex}.admin-products__card{background:var(--bg-card);border:1px solid var(--border-default);border-radius:var(--radius-2xl);width:100%;max-width:620px;animation:fade-up .5s var(--ease-spring) both;flex-direction:column;gap:20px;padding:28px;display:flex}.admin-products__title{letter-spacing:-.5px;margin:0;font-size:1.8rem;font-weight:800}.admin-products__subtitle{color:var(--text-muted);margin:0}.admin-products__link{border-radius:var(--radius-md);background:var(--accent);color:#fff;transition:all var(--duration-fast) var(--ease-smooth);border:none;padding:10px 18px;font-weight:700;text-decoration:none;display:inline-block}.admin-products__link:hover{box-shadow:var(--shadow-glow-strong);transform:translateY(-1px)}.admin-products__section-title{color:var(--text-secondary);margin:0;font-size:1.1rem;font-weight:700}.admin-products__form{border-radius:var(--radius-lg);border:1px solid var(--border-subtle);background:#120c1c99;flex-direction:column;gap:12px;padding:18px;display:flex}.admin-products__label{color:var(--text-secondary);font-size:.88rem;font-weight:600}.admin-products__input{border-radius:var(--radius-md);border:1px solid var(--border-subtle);background:var(--bg-input);color:var(--text-secondary);transition:all var(--duration-fast) var(--ease-smooth);padding:11px 14px}.admin-products__input:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #a855f726}.admin-products__textarea{border-radius:var(--radius-md);border:1px solid var(--border-subtle);background:var(--bg-input);color:var(--text-secondary);resize:vertical;transition:all var(--duration-fast) var(--ease-smooth);padding:11px 14px}.admin-products__textarea:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #a855f726}.admin-products__button{border-radius:var(--radius-md);border:1px solid var(--border-default);background:var(--bg-elevated);color:var(--text-secondary);cursor:pointer;transition:all var(--duration-fast) var(--ease-smooth);padding:11px 14px;font-weight:700}.admin-products__button:hover{border-color:var(--border-strong);background:#a855f71a}.admin-products__message{color:#93c5fd;margin:0;font-weight:500}.admin-products__error{color:var(--red-400);margin:0}.admin-custom{background:var(--bg-base);color:#fff;flex-direction:column;justify-content:center;align-items:center;gap:10px;min-height:100vh;padding:32px;display:flex}.admin-custom__title{margin:0;font-size:2rem;font-weight:800}.admin-custom__subtitle{color:var(--text-muted);margin:0}.create-category{flex-direction:column;gap:16px;max-width:400px;margin:40px auto;display:flex}.create-category__title{color:var(--text-secondary);margin:0;font-weight:800}.create-category__form{flex-direction:column;gap:12px;display:flex}.create-category__input{border-radius:var(--radius-md);border:1px solid var(--border-subtle);background:var(--bg-input);color:var(--text-secondary);transition:all var(--duration-fast) var(--ease-smooth);padding:12px 14px}.create-category__input:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #a855f726}.create-category__button{border-radius:var(--radius-md);background:var(--accent);color:#fff;cursor:pointer;transition:all var(--duration-fast) var(--ease-smooth);border:none;padding:11px 14px;font-weight:700}.create-category__button:hover{box-shadow:var(--shadow-glow-strong);transform:translateY(-1px)}.create-category__error{color:var(--red-400);margin:0}.legacy-loading{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0009;justify-content:center;align-items:center;min-height:100vh;display:flex}.legacy-loading__card{border-radius:var(--radius-2xl);background:var(--bg-card);border:1px solid var(--border-default);box-shadow:var(--shadow-lg);flex-direction:column;align-items:center;gap:16px;padding:32px 48px;display:flex}.legacy-loading__spinner{border:3px solid var(--border-subtle);border-top:3px solid var(--purple-400);border-radius:50%;width:48px;height:48px;animation:.8s linear infinite dual-ring}.legacy-loading__subtitle{color:#fff;margin:0;font-size:1rem;font-weight:600}@media (width<=900px){.shop-hero__panel{grid-template-columns:1fr;padding:32px}.shop-hero__image{flex-direction:row;order:-1;gap:12px}.shop-hero__userCountCard{flex:1}}@media (width<=768px){.shop-nav{width:100%;padding:4px 8px calc(4px + env(safe-area-inset-bottom));-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-top:1px solid var(--border-subtle);background:#0a0a12f7;position:fixed;top:auto;bottom:0}.shop-nav__inner{box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none;background:0 0;border:none;border-radius:0;flex-direction:row;justify-content:space-around;align-items:stretch;gap:0;padding:4px 0;display:flex}.shop-nav__logo{display:none}.shop-nav__links{flex:1;justify-content:space-around;gap:0;display:flex}.shop-nav__right{align-items:stretch;display:flex}.shop-nav__avatar,.shop-nav__name,.shop-nav__role{display:none}.shop-nav__user{flex-direction:row;align-items:stretch;gap:0;display:flex}.shop-nav__link,.shop-nav__login,.shop-nav__logout{border-radius:var(--radius-md);min-width:52px;box-shadow:none;color:var(--text-muted);cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;flex-direction:column;justify-content:center;align-items:center;gap:3px;padding:6px 8px;font-size:.75rem;text-decoration:none;display:inline-flex}.shop-nav__link:hover,.shop-nav__login:hover,.shop-nav__logout:hover{color:var(--text-purple);background:#a855f714}.shop-nav__label{color:inherit;font-size:.6rem;font-weight:500;line-height:1}.shop-nav__icon svg{width:18px;height:18px}.shop-nav__link--active{color:var(--text-purple);background:#a855f71a}.shop-nav__link--active:after{display:none}.shop-page,.products-page,.product-detail,.history-page,.dashboard-page,.topup-page,.login-page,.auth-callback,.admin-products,.admin-custom,.admin-page,.admin-categories,.category-page{padding-bottom:96px}}@media (width<=600px){.shop-hero__panel{padding:24px}.shop-hero__image{flex-direction:column}.shop-hero__actions{width:100%}.shop-hero__cta{text-align:center;justify-content:center;width:100%}.quick-actions{grid-template-columns:repeat(2,1fr);gap:10px;margin-top:16px;padding:0 14px}.action-card{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:10px;padding:20px 12px}.action-card__text{align-items:center}.action-card__cta{display:none}.product-grid__list,.categories-grid{grid-template-columns:1fr}.shop-footer__links{gap:16px}.recent-buy{border-radius:var(--radius-xl);margin-bottom:32px;padding:20px 16px}.recent-buy:before,.recent-buy:after{width:24px}.recent-buy__header{flex-direction:column;align-items:flex-start;gap:6px;margin-bottom:16px}.recent-buy__title{font-size:1.15rem}.recent-buy__subtitle{font-size:.82rem}.recent-buy__card{gap:10px;width:240px;padding:12px}.recent-buy__image-wrap{border-radius:12px;flex-shrink:0;width:52px;height:52px}.recent-buy__product{font-size:.88rem}.recent-buy__user{font-size:.78rem}.toast-region{max-width:none;left:16px;right:16px}.history-page__card,.topup-card,.login-card,.dashboard-card,.product-detail__card{padding:20px}}
