:root{--color-bg: #0b0820;--color-bg-2: #120e2b;--color-surface: #1a143a;--color-surface-2: #22194d;--color-border: #3a2e6a;--color-divider: #2a2152;--color-text: #f1ecff;--color-text-muted: #a79ed0;--color-text-faint: #6f678f;--color-primary: #8b5cf6;--color-primary-hover: #a078ff;--color-primary-active: #7a4be0;--color-accent-blue: #5b8cff;--color-gradient: linear-gradient(135deg, #5b2cff 0%, #8b5cf6 55%, #5b8cff 100%);--color-gradient-soft: linear-gradient(135deg, #2a1b66 0%, #3a2a88 100%);--color-success: #3dd68c;--color-warning: #ffb84d;--color-error: #ff6b8e;--font-body: "Inter", "Helvetica Neue", system-ui, sans-serif;--font-display: "Inter", "Helvetica Neue", system-ui, sans-serif;--radius-sm: 10px;--radius-md: 14px;--radius-lg: 20px;--radius-full: 9999px;--shadow-card: 0 6px 24px rgba(0, 0, 0, .35);--shadow-glow: 0 0 24px rgba(139, 92, 246, .35)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{min-height:100dvh}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;scroll-behavior:smooth}body{font-family:var(--font-body);font-size:15px;line-height:1.55;color:var(--color-text);background:radial-gradient(1100px 600px at 85% -10%,rgba(91,140,255,.18),transparent 60%),radial-gradient(800px 500px at 0% 20%,rgba(139,92,246,.2),transparent 60%),var(--color-bg);min-height:100dvh}img{display:block;max-width:100%;height:auto}button{font:inherit;color:inherit;border:none;background:none;cursor:pointer}input,textarea{font:inherit;color:inherit}a{color:var(--color-primary-hover);text-decoration:none}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px;border-radius:var(--radius-sm)}.app{display:flex;flex-direction:column;min-height:100dvh;max-width:640px;margin:0 auto;padding:56px 16px 96px;position:relative}.topbar{position:fixed;top:0;left:50%;transform:translateX(-50%);width:100%;max-width:640px;z-index:20;display:flex;align-items:center;justify-content:space-between;background:linear-gradient(to bottom,rgba(11,8,32,.95),rgba(11,8,32,.8) 70%,transparent);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);margin:0;padding:14px 16px;box-sizing:border-box}.topbar h1{font-size:17px;font-weight:700;letter-spacing:-.01em}.topbar .back{display:inline-flex;align-items:center;gap:6px;padding:6px 10px 6px 6px;font-size:14px;color:var(--color-text-muted);border-radius:var(--radius-sm)}.topbar .back:hover{color:var(--color-text)}.brand{display:inline-flex;align-items:center;gap:10px;font-weight:700}.brand .logo{width:28px;height:28px;border-radius:8px;background:var(--color-gradient);box-shadow:var(--shadow-glow)}.tabbar{position:fixed;left:50%;transform:translate(-50%);bottom:0;width:100%;max-width:640px;display:grid;grid-template-columns:repeat(4,1fr);gap:0;padding:8px 8px calc(env(safe-area-inset-bottom,0px) + 10px);background:#120e2beb;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-top:1px solid var(--color-border);z-index:30}.tab{display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 4px;border-radius:var(--radius-md);color:var(--color-text-muted);font-size:11px;line-height:1.1;font-weight:500;transition:color .15s ease,background .15s ease}.tab.active{color:#c4b5fd;font-weight:700;background:#1a143a}.tab.active svg{stroke:#a78bfa;filter:drop-shadow(0 0 6px rgba(139,92,246,.55))}.tab svg{width:22px;height:22px}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:16px;box-shadow:var(--shadow-card)}.card+.card{margin-top:12px}.card-grad{background:var(--color-gradient);color:#fff;position:relative;overflow:hidden}.card-grad:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(600px 300px at 110% -20%,rgba(255,255,255,.2),transparent 60%);pointer-events:none}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 18px;font-size:15px;font-weight:600;border-radius:var(--radius-md);background:var(--color-surface-2);color:var(--color-text);border:1px solid var(--color-border);transition:background .16s ease,transform .12s ease,box-shadow .16s ease;width:100%}.btn:hover{background:#2b2162}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--color-gradient);border:none;box-shadow:var(--shadow-glow)}.btn-primary:hover{filter:brightness(1.08);background:var(--color-gradient)}.btn-ghost{background:transparent;border:1px solid var(--color-border)}.btn-row{display:flex;gap:8px}.input,.textarea{width:100%;padding:12px 14px;font-size:15px;background:var(--color-bg-2);color:var(--color-text);border:1px solid var(--color-border);border-radius:var(--radius-md);outline:none;transition:border-color .16s ease,box-shadow .16s ease}.input::placeholder,.textarea::placeholder{color:var(--color-text-faint)}.input:focus,.textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #8b5cf62e}.textarea{resize:vertical;min-height:88px;line-height:1.5}.field{display:block;margin-bottom:12px}.field-label{display:block;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted);margin-bottom:6px}.field-error{color:var(--color-error);font-size:12px;margin-top:4px}.grid-cats{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:8px}.cat-tile{display:flex;align-items:flex-end;min-height:110px;padding:14px;border-radius:var(--radius-lg);background:var(--color-gradient-soft);color:#fff;font-weight:600;font-size:14px;line-height:1.2;border:1px solid var(--color-border);position:relative;overflow:hidden;text-align:left;transition:transform .15s ease}.cat-tile:active{transform:scale(.97)}.cat-tile-img{min-height:120px;background-size:cover;background-position:center;background-repeat:no-repeat;padding:0;border-color:#8b5cf659}.cat-tile-img .cat-tile-grad{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to top,#0a0814d9,#0a08148c 35%,#0a081426 65%,#0a081400);pointer-events:none}.cat-tile-img .cat-tile-title{position:relative;z-index:1;padding:14px;font-size:15px;font-weight:700;color:#fff;text-shadow:0 1px 6px rgba(0,0,0,.6);align-self:flex-end;width:100%}.list-products{display:grid;grid-template-columns:1fr 1fr;gap:12px}.prod-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;display:flex;flex-direction:column;text-align:left;padding:0}.prod-card:hover{border-color:var(--color-primary)}.prod-thumb{aspect-ratio:1 / 1;background:var(--color-gradient-soft);display:flex;align-items:center;justify-content:center;overflow:hidden}.prod-thumb img{width:100%;height:100%;object-fit:cover}.prod-body{padding:12px}.prod-title{font-size:13px;font-weight:600;line-height:1.25;margin-bottom:6px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.prod-price{font-size:14px;font-weight:700;color:var(--color-primary-hover);display:flex;align-items:baseline;gap:6px;flex-wrap:wrap}.prod-price-old{color:var(--color-text-muted);font-weight:500;text-decoration:line-through;font-size:12px}.prod-price-cur{color:var(--color-primary-hover)}.hero-img{width:100%;aspect-ratio:4 / 3;border-radius:var(--radius-lg);background:var(--color-gradient-soft);overflow:hidden;margin-bottom:14px;border:1px solid var(--color-border)}.hero-img img{width:100%;height:100%;object-fit:cover}.hero-title{font-size:22px;font-weight:700;letter-spacing:-.01em;margin-bottom:8px}.hero-price-row{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap;margin-bottom:12px}.hero-price-old{font-size:16px;font-weight:500;color:var(--color-text-muted);text-decoration:line-through}.hero-price{font-size:26px;font-weight:800;background:var(--color-gradient);-webkit-background-clip:text;background-clip:text;color:transparent}.prod-desc{color:var(--color-text-muted);white-space:pre-wrap;margin-bottom:14px}.bonus-balance{font-size:44px;font-weight:800;letter-spacing:-.02em}.bonus-hint{color:#fffc;font-size:13px;margin-top:2px}.tx-list{margin-top:6px}.tx-row{display:flex;justify-content:space-between;gap:10px;padding:10px 0;border-bottom:1px solid var(--color-divider);align-items:flex-start}.tx-row:last-child{border-bottom:none}.tx-amount-pos{color:var(--color-success);font-weight:700}.tx-amount-neg{color:var(--color-error);font-weight:700}.tx-meta{font-size:12px;color:var(--color-text-muted)}.chip{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;border-radius:var(--radius-full);border:1px solid transparent}.chip-pending{background:#ffb84d26;color:var(--color-warning);border-color:#ffb84d59}.chip-paid{background:#3dd68c26;color:var(--color-success);border-color:#3dd68c59}.chip-shipped{background:#5b8cff33;color:#9fb8ff;border-color:#5b8cff66}.chip-failed,.chip-expired{background:#ff6b8e26;color:var(--color-error);border-color:#ff6b8e59}.center-stack{display:flex;flex-direction:column;align-items:center;gap:12px;padding:48px 20px;text-align:center;color:var(--color-text-muted)}.skeleton{background:linear-gradient(90deg,var(--color-surface) 0%,var(--color-surface-2) 50%,var(--color-surface) 100%);background-size:200% 100%;animation:sk 1.4s linear infinite;border-radius:var(--radius-md)}@keyframes sk{0%{background-position:200% 0}to{background-position:-200% 0}}.muted{color:var(--color-text-muted)}.small{font-size:12px}.row-between{display:flex;justify-content:space-between;align-items:center;gap:10px}.stack-sm>*+*{margin-top:6px}.stack-md>*+*{margin-top:12px}.mt-2{margin-top:8px}.mt-3{margin-top:12px}.mt-4{margin-top:16px}.section-title{font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-muted);margin:16px 4px 10px}.alert{border-radius:var(--radius-md);padding:12px 14px;font-size:14px;line-height:1.5}.alert-warn{background:#ffb84d1a;border:1px solid rgba(255,184,77,.35);color:#ffd9a0}.alert-err{background:#ff6b8e1f;border:1px solid rgba(255,107,142,.35);color:#ffd2dc}.alert-ok{background:#3dd68c1f;border:1px solid rgba(61,214,140,.35);color:#c2f3dd}.range-wrap{display:flex;align-items:center;gap:12px}.range-wrap input[type=range]{flex:1;accent-color:var(--color-primary)}.info-list{padding:0;overflow:hidden}.info-row{display:flex;align-items:center;justify-content:space-between;width:100%;padding:14px 16px;background:transparent;border:0;color:var(--color-text);font-size:15px;font-weight:500;text-align:left;cursor:pointer;transition:background .12s ease}.info-row+.info-row{border-top:1px solid var(--color-border)}.info-row:active{background:#8b5cf61a}.info-arrow{color:var(--color-text-muted);font-size:22px;line-height:1}.link{color:#c4b5fd;text-decoration:underline;text-underline-offset:2px}.link:active{color:#a78bfa}

/* cart/balance miniapp polish */

.tab{border:0;border-radius:16px;padding:10px 4px;background:transparent;color:rgba(255,255,255,.72);font-size:11px;font-weight:700}
.tab.active{color:#c4b5fd;font-weight:700;background:#1a143a}.tab.active svg{stroke:#a78bfa;filter:drop-shadow(0 0 6px rgba(139,92,246,.55))}

.brand{display:flex;gap:8px;align-items:center;font-weight:900}.logo{width:10px;height:10px;border-radius:99px;background:#ec4899;box-shadow:0 0 20px #ec4899}.back{border:0;background:rgba(255,255,255,.08);color:white;border-radius:14px;padding:10px 12px;font-weight:800}
.btn-row .btn{flex:1}.prod-card,.cat-tile,.btn{cursor:pointer;touch-action:manipulation}.field{display:block;margin-top:12px}.field-label{display:block;margin-bottom:6px;font-size:12px;color:rgba(255,255,255,.72);font-weight:700}.input,.textarea{width:100%;box-sizing:border-box;border:1px solid rgba(255,255,255,.14);border-radius:16px;background:rgba(255,255,255,.07);color:white;padding:13px 14px;font-size:16px}.textarea{min-height:92px;resize:vertical}.alert-warn{background:rgba(245,158,11,.12);border-color:rgba(245,158,11,.35);color:#fde68a}.mt-2{margin-top:8px}.mt-3{margin-top:12px}.mt-4{margin-top:16px}

/* v10: keep original tabbar colors exactly; only layout + wallet fixes */
html,body,#root{max-width:100%;overflow-x:hidden!important}
.app{width:100%;max-width:640px;margin:0 auto;overflow-x:hidden;box-sizing:border-box}
.app main{max-width:100%;overflow-x:hidden}
.grid-cats{grid-template-columns:minmax(0,1fr) minmax(0,1fr)}
.cat-tile,.prod-card,.card,.hero-img,.list-products{min-width:0;max-width:100%;box-sizing:border-box}
.tabbar{overflow:hidden}
.top-wallet{display:flex;align-items:center;gap:8px;margin-left:auto;background:transparent;border:0;padding:0;box-shadow:none;max-width:190px}
.top-wallet-balance{display:flex;flex-direction:column;align-items:flex-end;min-width:0}
.top-wallet-balance span{font-size:10px;line-height:1;color:var(--color-text-muted)}
.top-wallet-balance b{font-size:12px;line-height:1.15;white-space:nowrap;color:var(--color-text)}
.top-wallet-btn{display:inline-flex!important;align-items:center!important;justify-content:center!important;width:auto!important;height:30px!important;min-width:78px!important;padding:0 11px!important;border-radius:12px!important;background:var(--color-gradient)!important;color:#fff!important;border:0!important;font-size:11px!important;font-weight:800!important;line-height:1!important;box-shadow:var(--shadow-glow)!important;white-space:nowrap!important}
.top-wallet-btn:active{transform:scale(.97)}
.cart-line{padding:12px 0;border-bottom:1px solid var(--color-border)}
.cart-line:last-child{border-bottom:0}
.btn-mini{max-width:58px;padding-left:0!important;padding-right:0!important}
.alert-warn{background:rgba(245,158,11,.12);border:1px solid rgba(245,158,11,.35);color:#fde68a}
.mt-2{margin-top:8px}.mt-3{margin-top:12px}.mt-4{margin-top:16px}
@media(max-width:370px){.top-wallet{gap:6px;max-width:165px}.top-wallet-balance span{display:none}.top-wallet-balance b{font-size:11px}.top-wallet-btn{min-width:72px!important;padding:0 9px!important;font-size:10px!important}}
