/* ═══════════════════════════════════════════════════════════════
   STEED 2026 — Midnight Gold
   Clean dark premium · Warm tones · Generous spacing
   ═══════════════════════════════════════════════════════════════ */

/* ── 1. Design Tokens — Smauke Palette ───────────────────────── */
:root {
  --bg-0: #0f1117;
  --bg-1: #151820;
  --bg-2: #1a1d27;
  --bg-3: #22263a;
  --bg-4: #2a2f4a;

  --border:   rgba(42,47,74,0.55);
  --border-h: rgba(42,47,74,0.85);
  --border-a: rgba(79,110,247,0.30);

  --text:   #e8eaf0;
  --text-2: #8b90a8;
  --text-3: #565b73;

  --accent:      #4f6ef7;
  --accent-lt:   #6b8aff;
  --accent-dim:  rgba(79,110,247,0.10);
  --accent-glow: rgba(79,110,247,0.22);

  --gold:      #f59e0b;
  --gold-lt:   #fbbf24;
  --gold-dim:  rgba(245,158,11,0.10);
  --gold-glow: rgba(245,158,11,0.20);

  --green: #22c55e;
  --red:   #ef4444;

  --r:     10px;
  --r-sm:  8px;
  --r-xs:  5px;
  --r-lg:  14px;

  --ease:    cubic-bezier(.4,0,.2,1);
  --ease-o:  cubic-bezier(0,0,.2,1);
  --spring:  cubic-bezier(.34,1.56,.64,1);
}

/* ── INTERACTIONS DYNAMIQUES ─────────────────────────────────── */

/* Scroll reveal */
.bank-card {
  opacity: 0;
  transform: translateY(18px);
  transition: opacity .45s var(--ease), transform .45s var(--ease), box-shadow .25s var(--ease);
}
.bank-card.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* Tilt 3D — transition douce au retour */
.bank-card { transition: opacity .45s var(--ease), transform .2s var(--ease), box-shadow .2s var(--ease); }

/* Glow pulse sur cartes NEW */
.bank-card.is-new::after {
  content: '';
  position: absolute; inset: 0;
  width: auto; height: auto; background: none;
  border-radius: 14px;
  box-shadow: 0 0 0 0 rgba(79,110,247,0);
  animation: glow-pulse 2.4s ease-in-out infinite;
  pointer-events: none;
}
@keyframes glow-pulse {
  0%,100% { box-shadow: 0 0 0 0 rgba(79,110,247,0); }
  50%      { box-shadow: 0 0 12px 2px rgba(79,110,247,.35); }
}

/* Ripple */
.ripple-fx {
  position: absolute; border-radius: 50%;
  width: 6px; height: 6px;
  background: rgba(255,255,255,.35);
  transform: translate(-50%,-50%) scale(0);
  animation: ripple-anim .6s var(--ease) forwards;
  pointer-events: none;
}
@keyframes ripple-anim {
  to { transform: translate(-50%,-50%) scale(28); opacity: 0; }
}
.btn-add, .chip, .btn-primary, .nav-item { position: relative; overflow: hidden; }

/* Dot volant vers le panier */
.cart-fly-dot {
  position: fixed; width: 10px; height: 10px;
  background: var(--accent); border-radius: 50%;
  z-index: 9999; pointer-events: none;
  transition: transform .5s cubic-bezier(.4,0,.2,1), opacity .5s ease;
  transform: translate(-50%,-50%) scale(1);
}

/* Bounce panier */
@keyframes cart-bounce {
  0%,100% { transform: scale(1); }
  30%     { transform: scale(1.4); }
  60%     { transform: scale(.9); }
}
.cart-bounce { animation: cart-bounce .5s var(--spring); }

/* ── CAPTCHA SLIDER ──────────────────────────────────────────── */
/* ══════════════════════════════════════════════════════════════
   CAPTCHA SCREEN — Premium Private Club
   ══════════════════════════════════════════════════════════════ */
#captcha-screen {
  position: fixed; inset: 0; z-index: 9999;
  background:
    radial-gradient(ellipse at 30% 0%, rgba(79,110,247,.14), transparent 50%),
    radial-gradient(ellipse at 70% 100%, rgba(120,90,220,.10), transparent 50%),
    #06070d;
  display: flex; align-items: center; justify-content: center;
  overflow: hidden;
  transition: opacity .7s var(--ease), transform .7s var(--ease);
}
#captcha-screen.unlocked {
  opacity: 0; transform: scale(1.06); pointer-events: none;
}

/* Animated grid background */
.captcha-grid {
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(79,110,247,.045) 1px, transparent 1px),
    linear-gradient(90deg, rgba(79,110,247,.045) 1px, transparent 1px);
  background-size: 48px 48px;
  mask-image: radial-gradient(ellipse at center, black 30%, transparent 75%);
  -webkit-mask-image: radial-gradient(ellipse at center, black 30%, transparent 75%);
  animation: grid-pan 25s linear infinite;
}
@keyframes grid-pan {
  from { background-position: 0 0, 0 0; }
  to   { background-position: 48px 48px, 48px 48px; }
}

/* Floating glow orbs */
.captcha-bg-orb {
  position: absolute; border-radius: 50%;
  filter: blur(90px); pointer-events: none;
  animation: orb-float 12s ease-in-out infinite;
}
.captcha-bg-orb.orb-a {
  width: 420px; height: 420px;
  background: rgba(79,110,247,.45);
  top: -120px; left: -120px; opacity: .35;
}
.captcha-bg-orb.orb-b {
  width: 360px; height: 360px;
  background: rgba(120,90,220,.35);
  bottom: -100px; right: -80px; opacity: .22;
  animation-delay: -4s;
}
.captcha-bg-orb.orb-c {
  width: 280px; height: 280px;
  background: rgba(107,138,255,.30);
  top: 40%; left: 50%; transform: translate(-50%,-50%); opacity: .12;
  animation-delay: -8s;
}
@keyframes orb-float {
  0%,100% { transform: translate(0,0) scale(1); }
  33%     { transform: translate(20px,-15px) scale(1.06); }
  66%     { transform: translate(-15px,20px) scale(.96); }
}

.captcha-inner {
  position: relative; z-index: 2;
  display: flex; flex-direction: column; align-items: center;
  padding: 32px 28px; width: 100%; max-width: 360px;
  animation: cap-in .9s var(--spring) both;
}
@keyframes cap-in {
  from { opacity: 0; transform: translateY(20px) scale(.98); }
  to   { opacity: 1; transform: none; }
}

/* Brand mark SVG */
.captcha-mark {
  width: 64px; height: 64px;
  color: var(--accent-lt);
  filter: drop-shadow(0 0 22px rgba(79,110,247,.55));
  margin-bottom: 18px;
  animation: mark-spin 18s linear infinite;
}
.captcha-mark svg { width: 100%; height: 100%; }
.captcha-mark .mark-shape { stroke-dasharray: 250; stroke-dashoffset: 250; animation: draw 1.4s .15s ease forwards; }
.captcha-mark .mark-inner { stroke-dasharray: 130; stroke-dashoffset: 130; animation: draw 1.1s .55s ease forwards; opacity: .7; }
.captcha-mark .mark-dot   { opacity: 0; animation: dot-in .4s 1.5s ease forwards; }
@keyframes draw   { to { stroke-dashoffset: 0; } }
@keyframes dot-in { to { opacity: 1; } }
@keyframes mark-spin { to { transform: rotate(360deg); } }

/* Titles */
.captcha-titles { text-align: center; margin-bottom: 18px; }
.captcha-logo {
  font-family: 'Syne', sans-serif;
  font-size: 44px; font-weight: 800; letter-spacing: .22em;
  line-height: 1;
  background: linear-gradient(135deg, #fff 0%, var(--accent-lt) 60%, #fff 100%);
  background-size: 200% 200%;
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text;
  animation: logo-shimmer 4s ease-in-out infinite;
}
@keyframes logo-shimmer {
  0%,100% { background-position: 0% 50%; }
  50%     { background-position: 100% 50%; }
}
.captcha-sub {
  font-family: 'Inter', sans-serif;
  font-size: 9px; font-weight: 700;
  color: var(--text-3);
  margin-top: 8px;
  letter-spacing: .12em;
}

/* Status badge */
.captcha-status {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 6px 12px; border-radius: 100px;
  background: rgba(34,197,94,.08);
  border: 1px solid rgba(34,197,94,.22);
  margin-bottom: 28px;
}
.status-pulse {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--green);
  box-shadow: 0 0 8px var(--green);
  position: relative;
}
.status-pulse::after {
  content: ''; position: absolute; inset: -3px;
  border-radius: 50%; border: 1.5px solid var(--green);
  animation: pulse-ring 1.6s ease-out infinite;
}
@keyframes pulse-ring {
  from { opacity: .8; transform: scale(.5); }
  to   { opacity: 0;  transform: scale(2.2); }
}
.status-text {
  font-size: 10px; font-weight: 700;
  color: var(--green);
  letter-spacing: .12em;
}

/* Slider */
.captcha-slider-wrap { width: 100%; margin-bottom: 24px; }
.captcha-track {
  position: relative;
  width: 100%; height: 58px;
  background:
    linear-gradient(180deg, rgba(20,24,40,.7), rgba(12,15,26,.85));
  border: 1px solid rgba(79,110,247,.20);
  border-radius: 32px;
  overflow: hidden;
  box-shadow:
    0 4px 24px rgba(0,0,0,.4),
    0 0 0 1px rgba(255,255,255,.03) inset;
  transition: border-color .3s, box-shadow .3s;
}
.captcha-track.success {
  border-color: var(--green);
  background: linear-gradient(180deg, rgba(34,197,94,.15), rgba(34,197,94,.06));
  box-shadow: 0 4px 28px rgba(34,197,94,.25), 0 0 0 1px rgba(34,197,94,.2) inset;
}
.captcha-shine {
  position: absolute; top: 0; left: -40%; width: 40%; height: 100%;
  background: linear-gradient(110deg, transparent 30%, rgba(255,255,255,.08) 50%, transparent 70%);
  animation: shine-sweep 2.4s ease-in-out infinite;
  pointer-events: none;
}
.captcha-track.success .captcha-shine { display: none; }
@keyframes shine-sweep {
  from { left: -40%; }
  to   { left: 140%; }
}
.captcha-fill {
  position: absolute; left: 0; top: 0; bottom: 0;
  background: linear-gradient(90deg, rgba(79,110,247,.18), rgba(79,110,247,.32));
  border-radius: 32px;
  pointer-events: none;
  transition: width .05s linear;
}
.captcha-label {
  position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  font-size: 13px; font-weight: 600; color: var(--text-2);
  pointer-events: none; user-select: none;
  letter-spacing: .03em;
  transition: opacity .3s;
}
.label-text { padding-left: 36px; }
.label-arrows {
  width: 14px; height: 14px;
  color: var(--accent-lt);
  margin-left: 4px;
  animation: arrow-hint 1.4s ease-in-out infinite;
}
.label-arrows-2 {
  margin-left: -10px;
  opacity: .5;
  animation-delay: .2s;
}
@keyframes arrow-hint {
  0%,100% { transform: translateX(0); opacity: 1; }
  50%     { transform: translateX(4px); opacity: .35; }
}
.captcha-track.success .captcha-label {
  color: var(--green);
}
.captcha-track.success .label-arrows { display: none; }
.captcha-handle {
  position: absolute; left: 4px; top: 4px;
  width: 50px; height: 50px;
  background: linear-gradient(135deg, var(--accent), var(--accent-lt));
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  color: #fff;
  cursor: grab; user-select: none;
  box-shadow:
    0 6px 18px rgba(79,110,247,.55),
    0 0 0 1px rgba(255,255,255,.18) inset,
    0 2px 0 rgba(255,255,255,.10) inset;
  transition: background .3s, box-shadow .3s, transform .15s;
  touch-action: none;
  will-change: transform;
}
.captcha-handle:active { cursor: grabbing; transform: scale(1.04); }
.captcha-track.success .captcha-handle {
  background: linear-gradient(135deg, var(--green), #4ade80);
  box-shadow:
    0 6px 22px rgba(34,197,94,.55),
    0 0 0 1px rgba(255,255,255,.20) inset;
}
.captcha-handle svg { pointer-events: none; }

/* Features grid */
.captcha-features {
  display: flex; justify-content: space-between; gap: 10px;
  width: 100%; margin-bottom: 20px;
}
.feature-item {
  flex: 1;
  display: flex; flex-direction: column; align-items: center; gap: 6px;
  padding: 12px 6px;
  background: rgba(255,255,255,.02);
  border: 1px solid rgba(255,255,255,.05);
  border-radius: 14px;
  transition: transform .25s, border-color .25s;
}
.feature-item:hover {
  border-color: rgba(79,110,247,.25);
  transform: translateY(-2px);
}
.feature-item svg {
  width: 18px; height: 18px;
  color: var(--accent-lt);
  opacity: .85;
}
.feature-item span {
  font-size: 10px; font-weight: 600;
  color: var(--text-2);
  letter-spacing: .04em;
}

.captcha-footer {
  font-size: 10px; color: var(--text-3);
  letter-spacing: .14em;
  font-weight: 500;
}

/* ── 2. Reset & Base ─────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Inter',system-ui,-apple-system,sans-serif;
  background:var(--bg-0);
  color:var(--text);
  min-height:100dvh;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  -webkit-tap-highlight-color:transparent;
  overscroll-behavior:none;
  cursor:none;
  font-size:15px;line-height:1.6;
}
button{cursor:none;font-family:inherit;border:none;background:none}
a{text-decoration:none;color:inherit}
::selection{background:var(--accent-dim);color:var(--accent-lt)}
@media(hover:none){body,button{cursor:auto}#cursor-dot,#cursor-ring{display:none!important}}

/* ── 3. Cursor ───────────────────────────────────────────────── */
#cursor-dot{
  position:fixed;pointer-events:none;z-index:9999;
  width:5px;height:5px;border-radius:50%;
  background:var(--accent);
  transform:translate(-50%,-50%);
  box-shadow:0 0 8px var(--accent-glow);
}
#cursor-ring{
  position:fixed;pointer-events:none;z-index:9998;
  width:28px;height:28px;border-radius:50%;
  border:1.5px solid rgba(79,110,247,.4);opacity:.6;
  transform:translate(-50%,-50%);
  transition:width .2s,height .2s,opacity .2s,border-color .2s;
}
body.cursor-hover #cursor-ring{width:44px;height:44px;opacity:.18;border-color:var(--accent)}

/* ══════════════════════════════════════════════════════════════
   LOADING SCREEN — Cinematic Reveal
   ══════════════════════════════════════════════════════════════ */
#loading-screen {
  position: fixed; inset: 0; z-index: 9000;
  background:
    radial-gradient(ellipse at center, rgba(79,110,247,.10), transparent 65%),
    #06070d;
  display: flex; align-items: center; justify-content: center;
  transition: opacity .8s ease, visibility .8s;
  overflow: hidden;
}
#loading-screen.fade-out {
  opacity: 0; visibility: hidden; pointer-events: none;
}

.loading-bg-orb {
  position: absolute; top: 50%; left: 50%;
  width: 540px; height: 540px;
  transform: translate(-50%,-50%);
  border-radius: 50%;
  background: radial-gradient(circle, rgba(79,110,247,.20) 0%, rgba(79,110,247,.05) 40%, transparent 70%);
  animation: orb-breath 3s ease-in-out infinite;
}
@keyframes orb-breath {
  0%,100% { transform: translate(-50%,-50%) scale(1); opacity: .6; }
  50%     { transform: translate(-50%,-50%) scale(1.18); opacity: 1; }
}

.loading-bg-grid {
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(79,110,247,.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(79,110,247,.05) 1px, transparent 1px);
  background-size: 60px 60px;
  mask-image: radial-gradient(ellipse at center, black 0%, transparent 60%);
  -webkit-mask-image: radial-gradient(ellipse at center, black 0%, transparent 60%);
}

.loading-content {
  position: relative; z-index: 2;
  display: flex; flex-direction: column; align-items: center;
  width: 100%; max-width: 320px;
  padding: 0 24px;
}

/* Animated mark */
.loading-mark {
  width: 80px; height: 80px;
  color: var(--accent-lt);
  filter: drop-shadow(0 0 28px rgba(79,110,247,.6));
  margin-bottom: 28px;
}
.loading-mark svg { width: 100%; height: 100%; }
.loading-mark .ld-path-1 { stroke-dasharray: 320; stroke-dashoffset: 320; animation: draw-mark 1.4s ease forwards; }
.loading-mark .ld-path-2 { stroke-dasharray: 170; stroke-dashoffset: 170; animation: draw-mark 1.2s .5s ease forwards; opacity: .75; }
.loading-mark .ld-dot    { opacity: 0; animation: dot-in 0.4s 1.6s ease forwards, dot-pulse 1.6s 1.8s ease-in-out infinite; }
@keyframes draw-mark { to { stroke-dashoffset: 0; } }
@keyframes dot-pulse {
  0%,100% { transform-origin: 40px 40px; transform: scale(1); opacity: 1; }
  50%     { transform-origin: 40px 40px; transform: scale(1.6); opacity: .5; }
}

/* Logo text */
.loading-logo {
  font-family: 'Syne', sans-serif;
  font-size: 52px; font-weight: 800; letter-spacing: .22em;
  line-height: 1;
  background: linear-gradient(135deg, #fff, var(--accent-lt), #fff);
  background-size: 200% 200%;
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text;
  animation: logo-reveal .8s .3s var(--spring) both, logo-shimmer 3.5s ease-in-out infinite;
  filter: drop-shadow(0 0 24px rgba(79,110,247,.30));
}
@keyframes logo-reveal {
  from { opacity: 0; transform: translateY(14px); filter: blur(10px); }
  to   { opacity: 1; transform: none; filter: blur(0); }
}

.loading-sub {
  font-family: 'Inter', sans-serif;
  font-size: 12px; font-weight: 700;
  color: var(--text-3);
  letter-spacing: .55em;
  margin-top: 10px;
  opacity: 0;
  animation: sub-in .6s .7s ease forwards;
}
@keyframes sub-in { to { opacity: .7; } }

/* Progress */
.loading-progress {
  display: flex; align-items: center; gap: 12px;
  margin-top: 36px;
  width: 100%;
  opacity: 0;
  animation: progress-in .5s 1s ease forwards;
}
@keyframes progress-in { to { opacity: 1; } }
.loading-bar {
  flex: 1;
  position: relative;
  height: 3px;
  background: rgba(79,110,247,.10);
  border-radius: 3px;
  overflow: hidden;
}
.loading-bar-fill {
  height: 100%; width: 0;
  background: linear-gradient(90deg, var(--accent), var(--accent-lt));
  border-radius: 3px;
  animation: load-progress 2.1s ease-out forwards;
  box-shadow: 0 0 14px rgba(79,110,247,.55);
}
.loading-bar-glow {
  position: absolute; top: 0; bottom: 0; left: 0;
  width: 60px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.4), transparent);
  animation: bar-shine 1.5s ease-in-out infinite;
}
@keyframes load-progress { to { width: 100%; } }
@keyframes bar-shine {
  from { transform: translateX(-100%); }
  to   { transform: translateX(400px); }
}
.loading-percent {
  font-family: 'Inter', sans-serif;
  font-size: 11px; font-weight: 700;
  color: var(--accent-lt);
  font-variant-numeric: tabular-nums;
  min-width: 36px; text-align: right;
  letter-spacing: .04em;
}

/* Status */
.loading-status {
  display: flex; align-items: center; gap: 7px;
  margin-top: 18px;
  font-size: 11px; font-weight: 500;
  color: var(--text-2);
  letter-spacing: .03em;
  opacity: 0;
  animation: status-in .4s 1.2s ease forwards;
  min-height: 16px;
}
@keyframes status-in { to { opacity: 1; } }
.status-icon-wrap {
  display: flex; align-items: center; justify-content: center;
  width: 14px; height: 14px;
  border-radius: 50%;
  background: var(--accent);
  color: #fff;
}
.status-check { width: 8px; height: 8px; }
.loading-status-text {
  transition: opacity .25s;
}

/* ── 5. Background ───────────────────────────────────────────── */
#hex-canvas{display:none}
#particle-canvas{position:fixed;inset:0;pointer-events:none;z-index:1;opacity:.30}

.orb{position:fixed;pointer-events:none;border-radius:50%;z-index:0;animation:orb-drift 22s ease-in-out infinite}
.orb-1{width:600px;height:600px;background:radial-gradient(circle,rgba(30,40,100,.6),transparent 70%);top:-250px;right:-160px;filter:blur(80px);animation-duration:18s}
.orb-2{width:450px;height:450px;background:radial-gradient(circle,rgba(79,110,247,.08),transparent 70%);bottom:-100px;left:-160px;filter:blur(80px);animation-duration:24s;animation-direction:reverse}
.orb-3{width:350px;height:350px;background:radial-gradient(circle,rgba(40,50,120,.4),transparent 70%);top:40%;right:-80px;filter:blur(60px);animation-duration:28s}
@keyframes orb-drift{
  0%,100%{transform:translate(0,0) scale(1)}
  33%{transform:translate(20px,-16px) scale(1.03)}
  66%{transform:translate(-14px,22px) scale(.97)}
}

/* ── 6. App Shell ────────────────────────────────────────────── */
#app{min-height:100dvh;display:flex;flex-direction:column;position:relative;z-index:2}
#app.hidden{display:none}
.app-main{flex:1;padding-bottom:76px}

.tab-section{display:none}
.tab-section.active{display:block;animation:page-in .3s var(--ease-o) both}
@keyframes page-in{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* ── 7. Header ───────────────────────────────────────────────── */
.app-header{
  position:sticky;top:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:12px 16px;
  background:rgba(8,8,13,.85);
  backdrop-filter:blur(20px) saturate(1.4);
  -webkit-backdrop-filter:blur(20px) saturate(1.4);
  border-bottom:1px solid var(--border);
  animation:header-in .45s .1s var(--ease-o) both;
}
@keyframes header-in{from{opacity:0;transform:translateY(-100%)}to{opacity:1;transform:none}}

.header-user{display:flex;align-items:center;gap:10px}
.header-avatar{
  width:32px;height:32px;border-radius:50%;flex-shrink:0;
  background:var(--bg-3);border:1px solid var(--border-h);
  overflow:hidden;display:flex;align-items:center;justify-content:center;
}
.header-avatar img{width:100%;height:100%;object-fit:cover}
.header-avatar span{font-size:12px;font-weight:600;color:var(--accent)}
.header-user-info{display:flex;flex-direction:column;gap:1px}
.header-username{font-size:13px;font-weight:500;color:var(--text)}
.header-userid{font-size:10px;color:var(--text-3)}

.header-right{display:flex;align-items:center;gap:8px}
.header-balance{
  display:flex;align-items:center;gap:5px;
  padding:6px 12px;border-radius:20px;
  background:var(--accent-dim);border:1px solid rgba(79,110,247,.22);
  font-size:12px;font-weight:600;color:var(--accent-lt);
}
.header-cart-btn{
  position:relative;padding:8px;border-radius:var(--r-sm);
  background:var(--bg-2);border:1px solid var(--border);
  color:var(--text-2);transition:all .2s var(--ease);
  display:flex;align-items:center;justify-content:center;
}
.header-cart-btn:hover{background:var(--bg-3);border-color:var(--border-h);color:var(--text)}
.cart-badge-wrap{position:relative}
.cart-count{
  position:absolute;top:-4px;right:-4px;
  min-width:16px;height:16px;border-radius:8px;padding:0 4px;
  background:var(--gold);color:var(--bg-0);font-size:9px;font-weight:700;
  display:flex;align-items:center;justify-content:center;
  border:2px solid var(--bg-0);
}
.cart-count.hidden{display:none}

/* ── 8. Hero ─────────────────────────────────────────────────── */
.hero-banner{
  position:relative;overflow:hidden;
  margin:12px 14px 0;border-radius:var(--r-lg);
  padding:28px 22px 24px;
  background:
    radial-gradient(ellipse at 80% 0%,rgba(79,110,247,.07),transparent 50%),
    radial-gradient(ellipse at 15% 100%,rgba(107,138,255,.05),transparent 50%),
    var(--bg-1);
  border:1px solid var(--border);
  box-shadow:0 4px 24px rgba(0,0,0,.25);
}
.hero-scan{
  position:absolute;top:0;left:-100%;bottom:0;width:50%;pointer-events:none;
  background:linear-gradient(90deg,transparent,rgba(79,110,247,.04),transparent);
  animation:scan 7s ease-in-out infinite;
}
@keyframes scan{0%{left:-100%}55%,100%{left:150%}}
.hero-dots{
  position:absolute;inset:0;pointer-events:none;
  background-image:radial-gradient(circle,rgba(255,255,255,.025) 1px,transparent 1px);
  background-size:20px 20px;
}
.hero-content{position:relative;z-index:1}
.hero-eyebrow{
  font-size:10px;font-weight:500;letter-spacing:.30em;
  text-transform:uppercase;color:var(--accent-lt);opacity:.75;
  margin-bottom:8px;animation:fade-up .5s .25s ease both;
}
.hero-title{
  font-family:'Syne',sans-serif;
  font-size:clamp(24px,6.5vw,36px);font-weight:700;line-height:1.15;
  color:var(--text);margin-bottom:6px;
  animation:fade-up .5s .35s ease both;
}
.hero-title .accent-text{
  background:linear-gradient(90deg,var(--accent),var(--accent-lt));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.hero-sub{font-size:13px;color:var(--text-2);animation:fade-up .5s .45s ease both}

.hero-stats{
  position:relative;z-index:1;
  display:flex;margin-top:20px;animation:fade-up .5s .55s ease both;
}
.hero-stat{flex:1;padding-right:14px;border-right:1px solid var(--border);margin-right:14px}
.hero-stat:last-child{border-right:none;margin-right:0}
.hero-stat-val{font-family:'Syne',sans-serif;font-size:20px;font-weight:700;color:var(--text)}
.hero-stat-lbl{font-size:10px;color:var(--text-3);text-transform:uppercase;letter-spacing:.06em;margin-top:4px}

/* ── 9. Search Bar ───────────────────────────────────────────── */
.search-wrap{padding:12px 14px 0;animation:fade-up .4s .15s ease both}
.search-bar{
  display:flex;align-items:center;gap:10px;
  padding:0 16px;height:48px;
  background:var(--bg-2);border:1px solid var(--border);
  border-radius:var(--r);
  transition:border-color .25s var(--ease),box-shadow .25s var(--ease);
}
.search-bar:focus-within{
  border-color:rgba(79,110,247,.35);
  box-shadow:0 0 0 3px rgba(79,110,247,.08);
}
.search-prefix{
  font-family:'Syne',sans-serif;font-size:18px;font-weight:700;
  color:var(--accent);opacity:.6;flex-shrink:0;line-height:1;
}
.search-input{
  flex:1;border:none;background:none;outline:none;
  font-family:'Outfit',sans-serif;font-size:14px;font-weight:400;
  color:var(--text);height:100%;
}
.search-input::placeholder{color:var(--text-3);font-weight:400}

/* ── 9b. Filter Chips ───────────────────────────────────────── */
.chips-scroll{
  overflow-x:auto;overflow-y:hidden;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
  padding:10px 14px 6px;
  animation:fade-up .4s .25s ease both;
}
.chips-scroll::-webkit-scrollbar{display:none}
.chips-row{display:flex;gap:8px;white-space:nowrap}
.chip{
  display:inline-flex;align-items:center;gap:5px;
  padding:7px 14px;border-radius:20px;flex-shrink:0;
  background:var(--bg-2);border:1px solid var(--border);
  font-size:12px;font-weight:500;color:var(--text-2);
  transition:all .22s var(--ease);
}
.chip:hover{background:var(--bg-3);color:var(--text);border-color:var(--border-h)}
.chip svg{width:13px;height:13px;flex-shrink:0}
.chip.is-active{
  background:rgba(59,130,246,.12);border-color:rgba(59,130,246,.30);
  color:#6db3f8;font-weight:600;
}
.chip.is-promo{
  background:rgba(217,160,64,.10);border-color:rgba(217,160,64,.25);
  color:var(--gold);font-weight:600;
}
.chip.is-filter{color:var(--text-3)}
.chip.is-filter:hover{color:var(--text)}

/* ── 10. Cards Grid ──────────────────────────────────────────── */
.cards-grid{display:flex;flex-direction:column;gap:10px;padding:6px 14px 16px}

/* ══════════════════════════════════════════════════════════════
   11. BANK CARD — Horizontal list layout
   ══════════════════════════════════════════════════════════════ */
.bank-card{
  position:relative;
  display:flex;align-items:center;gap:14px;
  padding:14px 14px 14px 16px;
  border-radius:var(--r);
  background:linear-gradient(135deg, #1a1d2a 0%, #1e2235 40%, #1a1f30 100%);
  border:1px solid rgba(79,110,247,.18);
  box-shadow:0 2px 16px rgba(0,0,0,.25), inset 0 1px 0 rgba(255,255,255,.04);
  overflow:hidden;
  animation:card-in .4s var(--ease-o) both;
  will-change:transform;
  box-shadow:0 2px 12px rgba(0,0,0,.18), inset 0 1px 0 rgba(255,255,255,.03);
  transition:
    transform .22s var(--ease),
    border-color .22s var(--ease),
    box-shadow .22s var(--ease),
    background .22s var(--ease);
}
/* Subtle top-right light reflection */
.bank-card::after{
  content:'';position:absolute;top:-40%;right:-20%;width:60%;height:80%;
  background:radial-gradient(ellipse,rgba(79,110,247,.06) 0%,transparent 70%);
  pointer-events:none;
}
@keyframes card-in{from{opacity:0;transform:translateY(14px) scale(.98)}to{opacity:1;transform:none}}

.bank-card:hover{
  transform:translateY(-2px);
  border-color:rgba(79,110,247,.25);
  background:linear-gradient(135deg, #1e2235 0%, #232842 40%, #1e2338 100%);
  box-shadow:0 8px 28px rgba(0,0,0,.28), 0 0 20px rgba(79,110,247,.06);
}

/* Card thumbnail */
.card-thumb{
  width:90px;min-width:90px;height:57px;
  border-radius:8px;overflow:hidden;flex-shrink:0;
  position:relative;background:var(--bg-4);
  border:1px solid var(--border);
  box-shadow:0 2px 8px rgba(0,0,0,.20);
  transition:transform .22s var(--ease);
}
.bank-card:hover .card-thumb{transform:scale(1.04)}
.card-thumb img{width:100%;height:100%;object-fit:cover;display:block}

/* Fallback card visual */
.card-thumb-fb{
  position:absolute;inset:0;display:none;flex-direction:column;
  justify-content:space-between;padding:6px 7px 5px;overflow:hidden;
}
/* All fallback cards = blue */
.cf-navy   {background:linear-gradient(135deg,#0f2a60,#050e22)}
.cf-blue   {background:linear-gradient(135deg,#0e3a8c,#04122e)}
.cf-gold   {background:linear-gradient(135deg,#5c3800,#201200)}
.cf-green  {background:linear-gradient(135deg,#0b3d1e,#031208)}
.cf-crimson{background:linear-gradient(135deg,#580a12,#1c0204)}
.cf-purple {background:linear-gradient(135deg,#360d5e,#110320)}
.cf-teal   {background:linear-gradient(135deg,#093540,#021015)}
.cf-shimmer{
  position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(110deg,transparent 30%,rgba(255,255,255,.06) 50%,transparent 70%);
  animation:cf-sweep 4s ease-in-out infinite;
}
@keyframes cf-sweep{0%{transform:translateX(-200%)}100%{transform:translateX(300%)}}
.cf-chip{width:14px;height:10px;border-radius:2px;background:linear-gradient(135deg,#d4a23a,#aa8030);box-shadow:0 1px 3px rgba(0,0,0,.4)}
.cf-label{font-size:7px;font-weight:800;font-style:italic;color:rgba(255,255,255,.50);letter-spacing:.03em}
.cf-row-top{display:flex;justify-content:space-between;align-items:flex-start}
.cf-row-bot{display:flex;justify-content:space-between;align-items:flex-end}
.cf-bank-name{font-size:6px;font-weight:700;color:rgba(255,255,255,.38);text-transform:uppercase;letter-spacing:.07em;max-width:38px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cf-bin-num{font-size:7px;font-weight:600;color:rgba(255,255,255,.58);letter-spacing:.05em}
.cf-flag-sm{font-size:9px;line-height:1}
.holder-name-wrap{display:flex;align-items:center;gap:5px;min-width:0;flex:1}
.card-flag-inline{font-size:12px;flex-shrink:0}
.card-thumb-col{display:flex;flex-direction:column;align-items:center;gap:5px;flex-shrink:0}
.thumb-provenance{
  display:block;max-width:90px;
  font-size:8px;font-weight:600;letter-spacing:.01em;
  color:var(--accent-lt);
  background:rgba(79,110,247,.08);
  border:1px solid rgba(79,110,247,.18);
  padding:2px 6px;border-radius:5px;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
  text-align:center;
}

/* Card content (middle) */
.card-content{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}

.card-holder-row{
  display:flex;align-items:center;gap:7px;min-width:0;
}
.card-holder{
  font-size:14px;font-weight:600;color:var(--text);line-height:1.3;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}

/* ── UA badge (iOS / Android) ────────────────────── */
.badge-ua{
  display:inline-flex;align-items:center;gap:2px;
  padding:2px 6px;border-radius:5px;
  font-size:9px;font-weight:700;letter-spacing:.04em;
  background:rgba(255,255,255,.07);
  color:var(--text-2);
  border:1px solid rgba(255,255,255,.08);
}

/* ── NEW badge (< 48h) ────────────────────────────── */
.badge-new{
  display:inline-flex;align-items:center;gap:3px;
  padding:2px 7px 2px 5px;border-radius:5px;
  font-size:9px;font-weight:800;letter-spacing:.06em;
  color:#ff6b2b;
  background:rgba(255,107,43,.10);
  border:1px solid rgba(255,107,43,.22);
  white-space:nowrap;
  animation:new-pulse 2s ease-in-out infinite;
}
.new-flame{
  font-size:11px;
  display:inline-block;
  animation:flame-dance 0.6s ease-in-out infinite alternate;
  filter:drop-shadow(0 0 3px rgba(255,107,43,.5));
}
@keyframes flame-dance{
  0%  {transform:scale(1) rotate(-6deg) translateY(0)}
  50% {transform:scale(1.15) rotate(3deg) translateY(-1px)}
  100%{transform:scale(1.05) rotate(-3deg) translateY(-2px)}
}
@keyframes new-pulse{
  0%,100%{box-shadow:0 0 0 0 rgba(255,107,43,0)}
  50%    {box-shadow:0 0 8px 0 rgba(255,107,43,.18)}
}

/* Card left border glow — all cards */
.bank-card{
  border-left:2px solid rgba(79,110,247,.35);
}
.bank-card::before{
  content:'';position:absolute;left:0;top:10%;height:80%;width:2px;
  background:linear-gradient(180deg,transparent,rgba(79,110,247,.50),transparent);
  animation:new-glow 2.5s ease-in-out infinite;
}
@keyframes new-glow{
  0%,100%{opacity:.3}
  50%{opacity:1}
}

.card-badges{display:flex;align-items:center;gap:5px;margin-top:1px}
.badge{
  display:inline-flex;align-items:center;gap:3px;
  padding:2px 7px;border-radius:4px;
  font-size:10px;font-weight:600;letter-spacing:.03em;
  line-height:1.4;
}
.badge-country{
  background:rgba(59,130,246,.10);border:1px solid rgba(59,130,246,.18);
  color:#6db3f8;
}
.badge-country .badge-flag{font-size:10px}
.badge-verified{
  width:18px;height:18px;border-radius:50%;
  background:rgba(74,222,128,.10);border:1px solid rgba(74,222,128,.18);
  display:flex;align-items:center;justify-content:center;
}
.badge-verified svg{width:10px;height:10px;color:var(--green)}

/* Card detail rows */
.card-metas{display:flex;align-items:center;gap:5px;flex-wrap:wrap}
.meta{
  display:inline-flex;align-items:center;gap:4px;
  padding:3px 8px;border-radius:5px;
  background:rgba(79,110,247,.07);
  border:1px solid rgba(79,110,247,.13);
  font-size:10px;font-weight:500;color:#6db3f8;line-height:1.3;
}
.meta svg{width:10px;height:10px;flex-shrink:0;opacity:.50;color:var(--accent)}
.meta-sep{display:none}

/* Card right side (price + action) */
.card-end{
  display:flex;flex-direction:column;align-items:flex-end;gap:4px;
  flex-shrink:0;padding-left:6px;
}
.price-old{font-size:11px;color:var(--text-3);text-decoration:line-through;line-height:1}
.price-new{
  font-family:'Inter',sans-serif;
  font-size:19px;font-weight:800;line-height:1;
  letter-spacing:-.02em;
  background:linear-gradient(135deg,#ffffff,#e8eaf0,#ffffff,#c8cdde,#ffffff);
  background-size:300% 300%;
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  animation:price-shimmer 3s ease-in-out infinite;
  filter:drop-shadow(0 0 6px rgba(245,158,11,.25));
  transition:filter .25s;
}
@keyframes price-shimmer{
  0%,100%{background-position:0% 50%}
  50%{background-position:100% 50%}
}
.bank-card:hover .price-new{
  filter:drop-shadow(0 0 10px rgba(255,255,255,.55));
}

.btn-add{
  width:34px;height:34px;border-radius:50%;flex-shrink:0;
  background:rgba(59,130,246,.12);border:1px solid rgba(59,130,246,.24);
  color:#6db3f8;font-size:20px;font-weight:300;line-height:1;
  display:flex;align-items:center;justify-content:center;
  transition:all .2s var(--spring);margin-top:2px;
}
.btn-add:hover{
  background:rgba(59,130,246,.20);border-color:rgba(59,130,246,.40);
  transform:scale(1.12);
  box-shadow:0 0 12px rgba(59,130,246,.15);
}
.btn-add:active{transform:scale(.88)}
.btn-add.is-active{
  background:rgba(74,222,128,.12);border-color:rgba(74,222,128,.28);
  color:var(--green);font-size:14px;font-weight:600;
}

/* Express & discount chips on card */
.card-chips{display:flex;align-items:center;gap:4px;margin-top:1px}
.chip-sm{
  padding:1px 6px;border-radius:4px;
  font-size:9px;font-weight:600;letter-spacing:.02em;
}
.chip-discount{
  background:rgba(217,160,64,.08);border:1px solid rgba(217,160,64,.16);color:var(--gold);
}
.chip-provenance{
  background:rgba(79,110,247,.08);border:1px solid rgba(79,110,247,.18);color:var(--accent-lt);
  max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.chip-ua{
  background:rgba(79,110,247,.08);border:1px solid rgba(79,110,247,.18);color:var(--accent-lt);
}

/* ── 12. (reserved) ─────────────────────────────────────────── */

/* ── 13. Skeleton ────────────────────────────────────────────── */
.skeleton-card{
  height:140px;border-radius:var(--r);
  background:linear-gradient(90deg,var(--bg-1) 25%,var(--bg-2) 50%,var(--bg-1) 75%);
  background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite;
  border:1px solid var(--border);
}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}

/* ── 14. Bottom Nav ──────────────────────────────────────────── */
.bottom-nav{
  position:fixed;
  bottom:max(10px, env(safe-area-inset-bottom, 0px));
  left:10px;right:10px;z-index:50;
  display:flex;align-items:stretch;gap:2px;
  padding:6px;
  border-radius:24px;
  background:linear-gradient(180deg, rgba(20,24,40,.78), rgba(12,15,26,.88));
  backdrop-filter:blur(28px) saturate(1.6);
  -webkit-backdrop-filter:blur(28px) saturate(1.6);
  border:1px solid rgba(255,255,255,.06);
  box-shadow:
    0 12px 36px rgba(0,0,0,.5),
    0 0 0 1px rgba(79,110,247,.08) inset,
    0 1px 0 rgba(255,255,255,.06) inset;
  animation:nav-up .5s .15s var(--ease-o) both;
}
@keyframes nav-up{from{transform:translateY(140%);opacity:0}to{transform:none;opacity:1}}

.nav-item{
  flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:3px;padding:9px 4px 8px;
  color:var(--text-3);font-size:10px;font-weight:600;
  position:relative;
  border-radius:18px;
  background:transparent;
  transition:all .35s cubic-bezier(.4,.0,.2,1);
  letter-spacing:.02em;
}
.nav-indicator{
  position:absolute;top:0;left:50%;transform:translateX(-50%) scaleX(0);
  width:24px;height:2px;border-radius:2px;
  background:linear-gradient(90deg, transparent, var(--accent-lt), transparent);
  box-shadow:0 0 8px var(--accent);
  transition:transform .35s cubic-bezier(.4,.0,.2,1);
}
.nav-item.active .nav-indicator{transform:translateX(-50%) scaleX(1)}

.nav-icon-wrap{
  position:relative;
  display:flex;align-items:center;justify-content:center;
  width:28px;height:28px;
  transition:transform .35s cubic-bezier(.4,.0,.2,1);
}
.nav-item svg{
  width:22px;height:22px;
  transition:all .3s var(--ease);
  stroke-width:1.8;
}
.nav-label{
  font-size:10px;font-weight:600;
  transition:all .3s var(--ease);
  opacity:.85;
}
.nav-item:active{transform:scale(.94)}

.nav-item.active{
  color:var(--accent-lt);
  background:linear-gradient(180deg, rgba(79,110,247,.20), rgba(79,110,247,.08));
  box-shadow:
    inset 0 0 0 1px rgba(79,110,247,.22),
    0 4px 14px rgba(79,110,247,.18),
    0 0 24px rgba(79,110,247,.10);
}
.nav-item.active .nav-icon-wrap{transform:translateY(-1px)}
.nav-item.active svg{
  stroke-width:2.1;
  filter:drop-shadow(0 2px 6px rgba(107,138,255,.55));
}
.nav-item.active .nav-label{opacity:1;font-weight:700}

.nav-badge{
  position:absolute;top:-3px;right:-7px;
  min-width:16px;height:16px;padding:0 4px;
  border-radius:8px;
  background:linear-gradient(135deg,#ff6b2b,#e0421a);
  color:#fff;font-size:9px;font-weight:800;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 2px 8px rgba(255,107,43,.55), 0 0 0 2px rgba(12,15,26,.9);
  letter-spacing:0;
  animation:badge-pop .3s var(--ease-o);
}
.nav-badge[hidden]{display:none}
@keyframes badge-pop{
  0%{transform:scale(0);opacity:0}
  60%{transform:scale(1.15)}
  100%{transform:scale(1);opacity:1}
}

/* Push content above the floating nav */
.tab-section{padding-bottom:90px}

/* ── 15. Page Header ─────────────────────────────────────────── */
.page-header{display:flex;align-items:center;justify-content:space-between;padding:20px 16px 12px}
.page-title{font-family:'Syne',sans-serif;font-size:20px;font-weight:700;color:var(--text)}
.clear-btn{
  padding:6px 14px;border-radius:8px;font-size:12px;font-weight:500;
  color:var(--text-3);border:1px solid var(--border);background:var(--bg-2);
  transition:all .2s var(--ease);
}
.clear-btn:hover{color:var(--red);border-color:rgba(248,113,113,.20)}

/* ── 16. Cart ────────────────────────────────────────────────── */
.cart-list{display:flex;flex-direction:column;gap:8px;padding:0 14px}
.cart-item{
  display:flex;align-items:center;gap:12px;padding:14px;
  border-radius:var(--r-sm);background:var(--bg-2);border:1px solid var(--border);
  transition:all .2s var(--ease);
}
.cart-item:hover{border-color:var(--border-h);transform:translateX(2px)}
.cart-item-icon{font-size:18px;flex-shrink:0}
.cart-item-info{flex:1;min-width:0}
.cart-item-bank{font-size:14px;font-weight:600;color:var(--text)}
.cart-item-meta{font-size:11px;color:var(--text-3);margin-top:2px}
.cart-item-price{font-size:14px;font-weight:600;color:var(--accent-lt);flex-shrink:0}
.cart-item-remove{
  padding:7px;border-radius:8px;color:var(--text-3);
  border:1px solid var(--border);background:var(--bg-2);font-size:13px;
  transition:all .2s var(--ease);
}
.cart-item-remove:hover{color:var(--red);border-color:rgba(248,113,113,.20);transform:scale(1.08)}
.cart-footer{padding:16px;border-top:1px solid var(--border);margin-top:8px}
.cart-total-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}
.cart-total-label{font-size:13px;color:var(--text-2)}
.cart-total-amount{font-family:'Syne',sans-serif;font-size:22px;font-weight:700;color:var(--accent-lt)}
.cart-empty{text-align:center;padding:60px 20px;color:var(--text-3);font-size:13px;line-height:1.8}
.cart-empty-icon{font-size:36px;margin-bottom:10px}

/* ── 17. Buttons ─────────────────────────────────────────────── */
.btn-primary{
  display:flex;align-items:center;justify-content:center;gap:8px;
  width:100%;padding:14px;border-radius:var(--r-sm);
  background:var(--accent);
  color:#fff;font-size:15px;font-weight:600;
  box-shadow:0 4px 16px var(--accent-glow);
  transition:all .22s var(--ease);
}
.btn-primary:hover{transform:translateY(-2px);background:var(--accent-lt);box-shadow:0 8px 24px rgba(79,110,247,.30)}
.btn-primary:active{transform:scale(.97)}
.btn-confirm-buy{
  display:flex;align-items:center;justify-content:center;width:100%;
  padding:14px;border-radius:var(--r-sm);margin-bottom:8px;
  background:var(--accent);
  color:#fff;font-size:15px;font-weight:600;
  box-shadow:0 4px 16px var(--accent-glow);transition:all .2s var(--ease);
}
.btn-cancel-buy{
  display:flex;align-items:center;justify-content:center;width:100%;
  padding:12px;border-radius:var(--r-sm);
  background:var(--bg-2);border:1px solid var(--border);
  color:var(--text-2);font-size:14px;font-weight:500;transition:all .2s var(--ease);
}
.btn-cancel-buy:hover{background:var(--bg-3);color:var(--text)}
.full{width:100%}

/* ── 18. Orders ──────────────────────────────────────────────── */
.orders-list{display:flex;flex-direction:column;gap:8px;padding:0 14px}
.order-item{
  padding:14px;border-radius:var(--r-sm);background:var(--bg-2);
  border:1px solid var(--border);transition:all .2s var(--ease);
}
.order-item:hover{border-color:var(--border-h);transform:translateX(2px)}
.order-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}
.order-id{font-size:11px;font-family:monospace;color:var(--text-3)}
.order-status{font-size:11px;font-weight:600;padding:3px 9px;border-radius:var(--r-xs)}
.status-delivered{background:rgba(74,222,128,.08);color:var(--green);border:1px solid rgba(74,222,128,.16)}
.status-pending{background:var(--gold-dim);color:var(--gold);border:1px solid rgba(245,158,11,.16)}
.order-bank{font-size:14px;font-weight:600;color:var(--text);margin-bottom:8px}
.order-footer{display:flex;justify-content:space-between;align-items:center}
.order-date{font-size:11px;color:var(--text-3)}
.order-price{font-size:15px;font-weight:600;color:var(--accent-lt)}
.orders-empty{text-align:center;padding:60px 20px;color:var(--text-3);font-size:13px;line-height:1.8}
.orders-empty-icon{font-size:36px;margin-bottom:10px}

/* ── 19. Balance ─────────────────────────────────────────────── */
.balance-hero{
  padding:32px 20px 28px;text-align:center;
  border-bottom:1px solid var(--border);
  background:radial-gradient(ellipse at 50% 0%,rgba(79,110,247,.06),transparent 55%);
}
.balance-label{font-size:11px;letter-spacing:.20em;text-transform:uppercase;color:var(--text-3);margin-bottom:12px}
.balance-amount{
  font-family:'Syne',sans-serif;font-size:48px;font-weight:700;line-height:1;
  background:linear-gradient(135deg,var(--accent-lt),var(--accent));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  animation:gentle-float 3.5s ease-in-out infinite;
}
@keyframes gentle-float{0%,100%{transform:translateY(0)}50%{transform:translateY(-3px)}}
.balance-currency{font-size:.45em;vertical-align:super}
.balance-actions{margin-top:20px;display:flex;justify-content:center}
.balance-actions .btn-primary{width:auto;padding:12px 28px;border-radius:22px}
.section-label{font-size:10px;font-weight:600;letter-spacing:.20em;text-transform:uppercase;color:var(--text-3);padding:16px 16px 8px}
.tx-list{display:flex;flex-direction:column;gap:2px;padding:0 14px 14px}
.tx-item{
  display:flex;align-items:center;gap:12px;padding:12px;
  border-radius:var(--r-sm);transition:background .2s var(--ease);
}
.tx-item:hover{background:var(--bg-2)}
.tx-icon{
  width:34px;height:34px;border-radius:var(--r-sm);flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  font-size:14px;font-weight:600;
}
.tx-icon.deposit{background:rgba(74,222,128,.08);color:var(--green);border:1px solid rgba(74,222,128,.14)}
.tx-icon.purchase{background:var(--accent-dim);color:var(--accent);border:1px solid rgba(79,110,247,.14)}
.tx-info{flex:1;min-width:0}
.tx-label{font-size:13px;font-weight:500;color:var(--text)}
.tx-date{font-size:11px;color:var(--text-3);margin-top:1px}
.tx-amount{font-size:14px;font-weight:600;flex-shrink:0}
.tx-amount.positive{color:var(--green)}
.tx-amount.negative{color:var(--text-2)}

/* ── 20. Support ─────────────────────────────────────────────── */
.support-hero{text-align:center;padding:32px 20px 24px;border-bottom:1px solid var(--border)}
.support-icon{font-size:36px;margin-bottom:10px}
.support-hero h2{font-family:'Syne',sans-serif;font-size:22px;font-weight:700;color:var(--text);margin-bottom:6px}
.support-hero p{font-size:13px;color:var(--text-2)}
.support-actions{display:flex;flex-direction:column;gap:8px;padding:16px 14px 8px}
.support-link-btn{
  display:flex;align-items:center;gap:12px;padding:14px;
  border-radius:var(--r-sm);background:var(--bg-2);border:1px solid var(--border);
  color:var(--text);font-size:14px;font-weight:500;transition:all .2s var(--ease);
}
.support-link-btn:hover{background:var(--bg-3);border-color:var(--border-h);transform:translateX(3px)}
.support-link-icon{font-size:20px;flex-shrink:0}
.support-link-arrow{margin-left:auto;color:var(--text-3);font-size:16px;transition:transform .2s}
.support-link-btn:hover .support-link-arrow{transform:translateX(3px);color:var(--accent)}
.faq-list{display:flex;flex-direction:column;gap:3px;padding:8px 14px 14px}
.faq-item{border-radius:var(--r-sm);overflow:hidden}
.faq-q{
  display:flex;align-items:center;justify-content:space-between;
  padding:13px 14px;font-size:14px;color:var(--text);font-weight:500;
  background:var(--bg-2);border:1px solid transparent;border-radius:var(--r-sm);
  transition:all .2s var(--ease);cursor:pointer;
}
.faq-q:hover{background:var(--bg-3);border-color:var(--border)}
.faq-item.open .faq-q{background:var(--bg-3);border-color:var(--border);border-radius:var(--r-sm) var(--r-sm) 0 0}
.faq-chevron{transition:transform .2s;flex-shrink:0;color:var(--text-3)}
.faq-item.open .faq-chevron{transform:rotate(180deg);color:var(--accent)}
.faq-a{
  max-height:0;overflow:hidden;padding:0 14px;
  font-size:13px;color:var(--text-2);line-height:1.6;
  background:var(--bg-3);border:1px solid var(--border);border-top:none;
  border-radius:0 0 var(--r-sm) var(--r-sm);
  transition:max-height .3s var(--ease),padding .3s var(--ease);
}
.faq-item.open .faq-a{max-height:300px;padding:12px 14px}

/* ── 21. Modals ──────────────────────────────────────────────── */
.modal-overlay{
  position:fixed;inset:0;z-index:500;
  background:rgba(0,0,0,.60);backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
  display:flex;align-items:flex-end;justify-content:center;
}
.modal-overlay.hidden{display:none}
.modal{
  width:100%;max-width:520px;max-height:88dvh;
  background:var(--bg-1);border:1px solid var(--border);
  border-radius:var(--r-lg) var(--r-lg) 0 0;
  overflow-y:auto;overflow-x:hidden;
  animation:modal-up .35s var(--ease) both;
}
.modal-filter-inner{max-height:80dvh}
@keyframes modal-up{from{transform:translateY(100%)}to{transform:none}}
.modal-header{
  position:sticky;top:0;z-index:1;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 18px 14px;background:var(--bg-1);border-bottom:1px solid var(--border);
}
.modal-title{font-family:'Syne',sans-serif;font-size:17px;font-weight:700;color:var(--text)}
.modal-close{
  width:30px;height:30px;border-radius:8px;
  background:var(--bg-2);border:1px solid var(--border);
  color:var(--text-2);font-size:14px;
  display:flex;align-items:center;justify-content:center;
  transition:all .2s;
}
.modal-close:hover{background:var(--bg-3);color:var(--text)}
.modal-body{padding:16px 18px 24px}

/* Crypto */
.crypto-option{
  display:flex;align-items:center;gap:12px;padding:14px;
  border-radius:var(--r-sm);background:var(--bg-2);border:1px solid var(--border);
  cursor:pointer;margin-bottom:8px;transition:all .2s;
}
.crypto-option:hover{background:var(--bg-3);border-color:var(--border-h);transform:translateX(2px)}
.crypto-icon{width:40px;height:40px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.crypto-info{flex:1}
.crypto-name{font-size:14px;font-weight:600;color:var(--text)}
.crypto-sub{font-size:11px;color:var(--text-3);margin-top:2px}
.crypto-time{font-size:11px;color:var(--text-3);flex-shrink:0}
.address-box{
  font-family:monospace;font-size:12px;word-break:break-all;
  padding:14px;border-radius:var(--r-sm);background:var(--bg-2);border:1px solid var(--border);
  color:var(--text);margin-bottom:12px;line-height:1.5;
}
.copy-btn{
  display:flex;align-items:center;justify-content:center;gap:8px;width:100%;
  padding:12px;border-radius:var(--r-sm);
  background:var(--accent-dim);border:1px solid rgba(79,110,247,.24);
  color:var(--accent-lt);font-size:13px;font-weight:600;transition:all .2s;
}
.copy-btn:hover{background:rgba(79,110,247,.16)}
.copy-btn.copied{background:rgba(74,222,128,.08);border-color:rgba(74,222,128,.20);color:var(--green)}

/* Filter */
.filter-modal-footer{
  display:flex;gap:8px;padding:12px 18px 16px;
  border-top:1px solid var(--border);position:sticky;bottom:0;background:var(--bg-1);
}
.filter-reset-btn{
  flex:1;padding:12px;border-radius:var(--r-sm);font-size:14px;font-weight:500;
  background:var(--bg-2);border:1px solid var(--border);color:var(--text-2);transition:all .2s;
}
.filter-reset-btn:hover{background:var(--bg-3);color:var(--text)}
.filter-apply-btn{
  flex:2;padding:12px;border-radius:var(--r-sm);font-size:14px;font-weight:600;
  background:var(--accent);color:#fff;transition:all .2s;
}
.filter-apply-btn:hover{transform:translateY(-1px);box-shadow:0 4px 14px var(--accent-glow)}
.fselect-row{margin-bottom:12px}
.fselect-label{font-size:11px;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:.10em;display:block;margin-bottom:6px}
.fbin-input{
  width:100%;padding:11px 14px;border-radius:var(--r-sm);
  background:var(--bg-2);border:1px solid var(--border);
  color:var(--text);font-size:14px;font-family:monospace;outline:none;transition:border-color .2s;
}
.fbin-input:focus{border-color:rgba(79,110,247,.40)}
.fbin-input::placeholder{color:var(--text-3)}
.fselect-wrap{position:relative}
.fselect{
  width:100%;padding:11px 32px 11px 14px;border-radius:var(--r-sm);
  background:var(--bg-2);border:1px solid var(--border);
  color:var(--text);font-size:14px;appearance:none;outline:none;transition:border-color .2s;
}
.fselect:focus{border-color:rgba(79,110,247,.40)}
.fselect option{background:var(--bg-3);color:var(--text)}
.fselect-arrow{position:absolute;right:12px;top:50%;transform:translateY(-50%);pointer-events:none;color:var(--text-3)}

/* Confirm */
.confirm-price-row,.confirm-balance-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0}
.confirm-label{font-size:13px;color:var(--text-2)}
.confirm-val{font-size:14px;font-weight:600;color:var(--text)}

/* ── 22. Toast ───────────────────────────────────────────────── */
#toast{
  position:fixed;bottom:90px;left:50%;transform:translateX(-50%);z-index:600;
  padding:10px 20px;border-radius:20px;font-size:13px;font-weight:500;
  background:var(--bg-3);border:1px solid var(--border);color:var(--text);
  white-space:nowrap;box-shadow:0 8px 28px rgba(0,0,0,.40);
  animation:toast-in .3s var(--spring) both;
}
@keyframes toast-in{from{opacity:0;transform:translate(-50%,14px)}to{opacity:1;transform:translateX(-50%)}}
#toast.success{background:rgba(74,222,128,.12);border-color:rgba(74,222,128,.20);color:var(--green)}
#toast.error{background:rgba(248,113,113,.12);border-color:rgba(248,113,113,.20);color:var(--red)}
#toast.hidden{display:none}


/* ─── Cart item timer ───────────────────────────────────────── */
.cart-item-timer{
  display:inline-flex;align-items:center;gap:4px;
  margin-top:4px;
  font-size:11px;font-weight:600;
  color:var(--accent-lt);
  background:rgba(79,110,247,.10);
  padding:2px 7px;border-radius:4px;
  letter-spacing:.04em;
  width:fit-content;
}
.cart-item-timer.is-urgent{
  color:#f59e0b;
  background:rgba(245,158,11,.12);
  animation:timer-pulse 1s ease-in-out infinite;
}
.cart-item-timer.is-expired{
  color:var(--red);
  background:rgba(239,68,68,.12);
}
@keyframes timer-pulse{
  0%,100%{opacity:1}
  50%{opacity:.55}
}
