/* ═══════════════════════════════════════════════════════════════
   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; border-radius: inherit;
  box-shadow: 0 0 0 0 rgba(79,110,247,.5);
  animation: glow-pulse 2.4s ease-in-out infinite;
  pointer-events: none; border-radius: 14px;
}
@keyframes glow-pulse {
  0%,100% { box-shadow: 0 0 0 0 rgba(79,110,247,.4); }
  50%      { box-shadow: 0 0 0 8px rgba(79,110,247,0); }
}

/* 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 {
  position: fixed; inset: 0; z-index: 9999;
  background: var(--bg-0);
  display: flex; align-items: center; justify-content: center;
  overflow: hidden;
  transition: opacity .6s var(--ease), transform .6s var(--ease);
}
#captcha-screen.unlocked {
  opacity: 0; transform: scale(1.04); pointer-events: none;
}
.captcha-bg-orb {
  position: absolute; border-radius: 50%;
  filter: blur(80px); opacity: .18; pointer-events: none;
}
.captcha-bg-orb.orb-a {
  width: 420px; height: 420px;
  background: var(--accent);
  top: -100px; left: -100px;
}
.captcha-bg-orb.orb-b {
  width: 360px; height: 360px;
  background: var(--gold);
  bottom: -80px; right: -60px;
}
.captcha-inner {
  display: flex; flex-direction: column; align-items: center;
  gap: 12px; padding: 40px 24px; width: 100%; max-width: 360px;
}
.captcha-logo {
  font-family: 'Syne', sans-serif;
  font-size: 42px; font-weight: 800; letter-spacing: .18em;
  background: linear-gradient(135deg, var(--accent-lt), var(--gold-lt));
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text;
}
.captcha-sub {
  font-family: 'Syne', sans-serif;
  font-size: 13px; font-weight: 600; letter-spacing: .5em;
  color: var(--text-3); margin-top: -10px;
}
.captcha-hint {
  font-size: 13px; color: var(--text-2); margin-top: 8px;
  letter-spacing: .03em;
}
.captcha-slider-wrap {
  width: 100%; margin-top: 16px;
}
.captcha-track {
  position: relative;
  width: 100%; height: 56px;
  background: var(--bg-2);
  border: 1px solid var(--border);
  border-radius: 28px;
  overflow: hidden;
  transition: border-color .3s;
}
.captcha-track.success {
  border-color: var(--green);
  background: rgba(34,197,94,.08);
}
.captcha-fill {
  position: absolute; left: 0; top: 0; bottom: 0;
  background: linear-gradient(90deg, rgba(79,110,247,.15), rgba(79,110,247,.25));
  border-radius: 28px;
  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: 500; color: var(--text-3);
  pointer-events: none; user-select: none;
  letter-spacing: .04em;
  transition: opacity .3s;
}
.captcha-track.success .captcha-label {
  color: var(--green); opacity: 1;
}
.captcha-handle {
  position: absolute; left: 4px; top: 4px;
  width: 48px; height: 48px;
  background: linear-gradient(135deg, var(--accent), var(--accent-lt));
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  cursor: grab; user-select: none;
  box-shadow: 0 4px 16px rgba(79,110,247,.4);
  transition: background .3s, box-shadow .3s;
  touch-action: none;
}
.captcha-handle:active { cursor: grabbing; }
.captcha-track.success .captcha-handle {
  background: linear-gradient(135deg, var(--green), #4ade80);
  box-shadow: 0 4px 20px rgba(34,197,94,.5);
}
.captcha-handle svg { pointer-events: none; }
.captcha-footer {
  font-size: 11px; color: var(--text-3); margin-top: 12px;
  letter-spacing: .06em;
}

/* ── 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)}

/* ── 4. Loading — Premium ────────────────────────────────────── */
#loading-screen{
  position:fixed;inset:0;z-index:9000;
  background:var(--bg-0);
  display:flex;align-items:center;justify-content:center;
  transition:opacity .7s ease,visibility .7s;
  overflow:hidden;
}
#loading-screen.fade-out{opacity:0;visibility:hidden;pointer-events:none}
/* Pulsing orb glow behind logo */
.loader-orb{
  position:absolute;top:50%;left:50%;
  width:320px;height:320px;
  transform:translate(-50%,-50%);
  border-radius:50%;
  background:radial-gradient(circle,rgba(79,110,247,.14) 0%,rgba(79,110,247,.04) 40%,transparent 70%);
  animation:orb-pulse 2.5s ease-in-out infinite;
  z-index:1;
}
@keyframes orb-pulse{
  0%,100%{transform:translate(-50%,-50%) scale(1);opacity:.7}
  50%{transform:translate(-50%,-50%) scale(1.25);opacity:1}
}

/* Rotating rings */
.loading-content{position:relative;z-index:2;text-align:center}
.loader-rings{
  position:absolute;top:50%;left:50%;
  transform:translate(-50%,-55%);
  width:200px;height:200px;
  pointer-events:none;
}
.loader-ring{
  position:absolute;inset:0;border-radius:50%;
  border:1px solid transparent;
}
.lr-1{
  border-top-color:rgba(79,110,247,.35);
  border-right-color:rgba(79,110,247,.10);
  animation:ring-spin 3s linear infinite;
}
.lr-2{
  inset:14px;
  border-bottom-color:rgba(107,138,255,.25);
  border-left-color:rgba(107,138,255,.08);
  animation:ring-spin 4.5s linear infinite reverse;
}
@keyframes ring-spin{to{transform:rotate(360deg)}}

/* Logo */
.loading-logo{
  font-family:'Syne',sans-serif;
  font-size:clamp(52px,14vw,88px);font-weight:800;
  letter-spacing:.22em;line-height:1;
  background:linear-gradient(135deg,#8ba4ff,var(--accent),#8ba4ff);
  background-size:200% 200%;
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  animation:logo-reveal 1s var(--spring) both, logo-gradient 4s ease-in-out infinite;
  filter:drop-shadow(0 0 40px rgba(79,110,247,.35));
  position:relative;
}
@keyframes logo-reveal{
  from{opacity:0;transform:scale(.5) translateY(20px);filter:blur(12px) drop-shadow(0 0 40px rgba(79,110,247,.35))}
  to{opacity:1;transform:none;filter:blur(0) drop-shadow(0 0 40px rgba(79,110,247,.35))}
}
@keyframes logo-gradient{
  0%,100%{background-position:0% 50%}
  50%{background-position:100% 50%}
}

/* Sub-title "SHOP" */
.loading-sub{
  font-family:'Inter',sans-serif;
  font-size:14px;font-weight:600;
  letter-spacing:.6em;
  color:var(--accent-lt);opacity:0;
  margin-top:6px;
  animation:sub-in .6s .5s var(--ease-o) forwards;
}
@keyframes sub-in{
  from{opacity:0;letter-spacing:1.2em;filter:blur(4px)}
  to{opacity:.6;letter-spacing:.6em;filter:blur(0)}
}

/* Progress bar */
.loader-bar-wrap{
  position:relative;
  margin:28px auto 16px;width:140px;height:2px;
  background:rgba(79,110,247,.10);border-radius:2px;overflow:visible;
}
.loader-bar{
  height:100%;width:0;border-radius:2px;
  background:linear-gradient(90deg,var(--accent),var(--accent-lt));
  box-shadow:0 0 12px var(--accent-glow),0 0 4px var(--accent);
  animation:load-fill 2s var(--ease) forwards;
}
.loader-dot{
  position:absolute;top:50%;
  width:6px;height:6px;border-radius:50%;
  background:var(--accent-lt);
  box-shadow:0 0 10px var(--accent),0 0 20px var(--accent-glow);
  transform:translateY(-50%);
  animation:dot-slide 2s var(--ease) forwards;
}
@keyframes load-fill{to{width:100%}}
@keyframes dot-slide{from{left:0}to{left:140px}}

/* Tagline */
.loading-tagline{
  color:var(--text-3);font-size:10px;font-weight:500;
  letter-spacing:.28em;text-transform:uppercase;
  opacity:0;
  animation:fade-up .6s .7s ease forwards;
}
@keyframes fade-up{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* ── 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:6px;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,.12);
  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:76px;min-width:76px;height:50px;
  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,.cf-blue,.cf-gold,.cf-green,.cf-crimson,.cf-purple{
  background:linear-gradient(135deg,#0a3a6e,#041a32);
}
.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:12px;height:9px;border-radius:2px;background:linear-gradient(135deg,#d4a23a,#aa8030)}
.cf-label{font-size:7px;font-weight:700;font-style:italic;color:rgba(255,255,255,.30);text-align:right}

/* 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:var(--text-2);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;
}

/* ── 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:0;left:0;right:0;z-index:50;
  display:flex;align-items:stretch;
  background:rgba(8,8,13,.92);backdrop-filter:blur(20px) saturate(1.4);
  -webkit-backdrop-filter:blur(20px) saturate(1.4);
  border-top:1px solid var(--border);
  padding-bottom:env(safe-area-inset-bottom,0);
  animation:nav-up .45s .15s var(--ease-o) both;
}
@keyframes nav-up{from{transform:translateY(100%)}to{transform:none}}
.nav-item{
  flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:3px;padding:10px 4px 8px;
  color:var(--text-3);font-size:10px;font-weight:500;
  position:relative;transition:color .2s var(--ease);
}
.nav-item svg{width:20px;height:20px;transition:transform .2s var(--ease)}
.nav-item:hover{color:var(--text-2)}
.nav-item:hover svg{transform:translateY(-1px)}
.nav-item.active{color:var(--accent-lt)}
.nav-dot{
  position:absolute;top:5px;left:50%;transform:translateX(-50%);
  width:3px;height:3px;border-radius:50%;background:var(--accent);
  opacity:0;transition:opacity .2s;
}
.nav-item.active .nav-dot{opacity:1}

/* ── 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}
