

:root {

  --red:         #C8102E;
  --red-deep:    #8B0000;
  --red-bright:  #E1252E;
  --red-glow:    rgba(200, 16, 46, 0.32);

  --gold:        #FFC72C;
  --gold-bright: #FFD75A;
  --gold-deep:   #C9930A;
  --gold-glow:   rgba(255, 199, 44, 0.30);

  --cream:       #FFF8E7;
  --cream-dim:   #EBE0BD;

  --green:       #2BA862;
  --orange:      #FF8A1F;

  --bg:          #100506;
  --bg-card:     #1B0A0C;
  --bg-raised:   #260F12;
  --bg-input:    #160708;
  --bg-nav:      #150607;
  --bg-overlay:  rgba(20, 6, 8, 0.92);

  --white:       #FFF8E7;
  --grey:        #B69097;
  --grey-dim:    #79545B;

  --line:        rgba(255, 248, 231, 0.06);
  --line-light:  rgba(255, 199, 44, 0.16);
  --line-red:    rgba(200, 16, 46, 0.28);

  --r:    14px;
  --r-sm: 10px;
  --r-lg: 22px;
  --r-xl: 30px;

  --nav-h:  72px;
  --head-h: 64px;
  --safe-b: env(safe-area-inset-bottom, 0px);
}

*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; -webkit-tap-highlight-color: transparent; }

html, body {
  height: 100%;
  overflow: hidden;
  font-family: 'Inter', system-ui, -apple-system, sans-serif;
  background: var(--bg);
  color: var(--white);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

body::before {
  content: '';
  position: fixed; inset: 0;
  background:
    radial-gradient(ellipse 700px 480px at 90% -10%, rgba(255,199,44,0.08) 0%, transparent 60%),
    radial-gradient(ellipse 800px 600px at -10% 110%, rgba(200,16,46,0.16) 0%, transparent 60%),
    radial-gradient(ellipse 500px 400px at 50% 50%, rgba(200,16,46,0.04) 0%, transparent 70%);
  pointer-events: none;
  z-index: 0;
}

#app { display: flex; flex-direction: column; height: 100%; position: relative; z-index: 1; }
.app-hidden { display: none !important; }

.tg-gate {
  position: fixed; inset: 0; z-index: 9999;
  display: flex; align-items: center; justify-content: center;
  background:
    radial-gradient(ellipse 700px 500px at 50% 30%, rgba(255,199,44,0.10) 0%, transparent 70%),
    radial-gradient(ellipse 600px 500px at 50% 90%, rgba(200,16,46,0.22) 0%, transparent 70%),
    var(--bg);
  overflow: hidden;
  transition: opacity .55s cubic-bezier(.4,0,.2,1), transform .55s cubic-bezier(.4,0,.2,1);
}
.tg-gate::after {
  content: '';
  position: absolute; inset: 0;
  background:
    repeating-linear-gradient(135deg, transparent 0 28px, rgba(255,199,44,0.018) 28px 29px),
    repeating-linear-gradient(45deg,  transparent 0 60px, rgba(200,16,46,0.04) 60px 61px);
  pointer-events: none;
}
.tg-gate.tg-gate-pass { opacity: 0; transform: scale(1.04); pointer-events: none; }
.tg-gate-inner {
  text-align: center; position: relative; z-index: 1;
  animation: gateIn .65s cubic-bezier(.16,1,.3,1) both;
}
@keyframes gateIn {
  from { opacity: 0; transform: translateY(28px) scale(.94); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}

.tg-gate-logo {
  width: 110px; height: 110px; margin: 0 auto 26px;
  border-radius: 32px;
  display: flex; align-items: center; justify-content: center;
  background: linear-gradient(135deg, var(--red), var(--red-deep));
  border: 2px solid var(--gold);
  position: relative;
  animation: gatePulse 2.4s ease-in-out infinite;
  box-shadow:
    0 0 0 4px rgba(200,16,46,0.18),
    0 22px 50px rgba(200,16,46,0.40),
    inset 0 1px 0 rgba(255,255,255,0.2);
}
.tg-gate-logo::before {
  content: '';
  position: absolute; inset: -8px;
  border-radius: inherit;
  background: conic-gradient(from 0deg, transparent 0deg, var(--gold) 80deg, transparent 160deg, var(--red-bright) 240deg, transparent 360deg);
  filter: blur(10px); opacity: .55;
  animation: gateRing 4.5s linear infinite;
  z-index: -1;
}
@keyframes gateRing { to { transform: rotate(360deg); } }
.tg-gate-logo-img { width: 70px; height: 70px; object-fit: contain; filter: drop-shadow(0 0 22px rgba(255,199,44,0.55)); }
@keyframes gatePulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(255,199,44,0.30), 0 22px 50px rgba(200,16,46,0.40); }
  50%      { box-shadow: 0 0 42px 10px rgba(255,199,44,0.20), 0 22px 50px rgba(200,16,46,0.45); }
}

.tg-gate-brand {
  font-family: 'Anton', 'Inter', sans-serif;
  font-size: 34px; font-weight: 400; letter-spacing: 2px;
  text-transform: uppercase;
  background: linear-gradient(180deg, var(--gold-bright), var(--gold) 50%, var(--gold-deep));
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  margin-bottom: 4px;
  filter: drop-shadow(0 4px 16px rgba(255,199,44,0.30));
}
.tg-gate-text {
  font-size: 12px; font-weight: 700; color: var(--cream-dim);
  letter-spacing: 4px; text-transform: uppercase;
  margin-bottom: 30px;
}
.tg-gate-bar { width: 220px; height: 4px; margin: 0 auto; border-radius: 4px; background: rgba(255,248,231,0.06); overflow: hidden; }
.tg-gate-bar span {
  display: block; width: 40%; height: 100%; border-radius: 4px;
  background: linear-gradient(90deg, var(--red), var(--gold), var(--red-bright));
  background-size: 200% 100%;
  box-shadow: 0 0 14px rgba(255,199,44,0.6);
  animation: gateBar 1.2s ease-in-out infinite, shimmer 2s linear infinite;
}
@keyframes gateBar {
  0%   { transform: translateX(-100%); }
  100% { transform: translateX(350%); }
}

.tg-gate-success .tg-gate-logo {
  background: linear-gradient(135deg, var(--green), #1f7a48);
  border-color: var(--gold);
  animation: gateSuccessPop .55s cubic-bezier(.16,1,.3,1);
}
@keyframes gateSuccessPop {
  0% { transform: scale(.8); }
  50%{ transform: scale(1.1); }
  100%{ transform: scale(1); }
}
.tg-gate-success .tg-gate-text { color: var(--green); }
.tg-gate-success .tg-gate-bar span { width: 100%; background: var(--green); animation: none; }

.tg-gate-blocked .tg-gate-logo {
  background: linear-gradient(135deg, var(--red-deep), #4a0000);
  border-color: var(--red);
  animation: gateShake .55s ease;
}
@keyframes gateShake {
  0%, 100% { transform: translateX(0); }
  20%, 60% { transform: translateX(-9px); }
  40%, 80% { transform: translateX(9px); }
}
.tg-gate-blocked .tg-gate-brand {
  background: linear-gradient(135deg, var(--red-bright), #FF6B6B);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
}
.tg-gate-blocked .tg-gate-text { color: var(--grey); margin-bottom: 12px; }
.tg-gate-blocked .tg-gate-bar { display: none; }
.tg-gate-sub { font-size: 13px; color: var(--grey); line-height: 1.6; max-width: 280px; margin: 0 auto; }
.tg-gate-sub a { color: var(--gold); text-decoration: none; font-weight: 700; }
.tg-gate-badge {
  display: inline-flex; align-items: center; gap: 6px;
  margin-top: 22px; padding: 8px 16px;
  background: var(--bg-card); border: 1px solid var(--line);
  border-radius: 100px; font-size: 11px; font-weight: 700; color: var(--grey);
  letter-spacing: .5px; text-transform: uppercase;
}
.tg-gate-badge .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--red); animation: dotBlink 1.5s ease infinite; }
@keyframes dotBlink {
  0%, 100% { opacity: 1; }
  50%      { opacity: .3; }
}

.ico { width: 20px; height: 20px; flex-shrink: 0; display: inline-block; vertical-align: middle; }
.ico-nav {
  width: 24px; height: 24px;
  stroke: var(--grey-dim); fill: none; stroke-width: 1.85;
  stroke-linecap: round; stroke-linejoin: round;
  transition: stroke 0.18s, transform .25s cubic-bezier(.22,1,.36,1);
}
.ico-24 { width: 20px; height: 20px; stroke: currentColor; fill: none; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; display: inline-block; vertical-align: middle; }
.ico-sm { width: 16px; height: 16px; }

#app-header {
  flex-shrink: 0;
  height: var(--head-h);
  padding: 0 16px;
  display: flex; align-items: center; justify-content: space-between;
  background: linear-gradient(180deg, rgba(21,7,8,0.96) 0%, rgba(16,5,6,0.78) 100%);
  border-bottom: 1px solid var(--line);
  z-index: 20;
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  position: relative;
}

#app-header::after {
  content: '';
  position: absolute; left: 0; right: 0; bottom: -2px;
  height: 3px;
  background: linear-gradient(90deg, var(--red) 0%, var(--gold) 50%, var(--red) 100%);
  background-size: 200% 100%;
  animation: shimmer 4s linear infinite;
  box-shadow: 0 2px 14px rgba(200,16,46,0.4);
}

.h-left { display: flex; align-items: center; gap: 13px; }

.h-avatar-wrap {
  position: relative;
  width: 42px; height: 42px;
  flex-shrink: 0;
}
.h-avatar-wrap::before {
  content: '';
  position: absolute; inset: -3px;
  border-radius: 50%;
  background: conic-gradient(from 0deg, var(--gold) 0deg, transparent 90deg, var(--red-bright) 180deg, transparent 270deg, var(--gold) 360deg);
  animation: avRingSpin 4.5s linear infinite;
  z-index: 0;
}
.h-avatar-wrap::after {
  content: '';
  position: absolute; inset: 0;
  border-radius: 50%;
  box-shadow: 0 0 0 2px var(--bg);
  z-index: 1;
}
.h-avatar {
  position: relative; z-index: 2;
  width: 42px; height: 42px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--red), var(--red-deep));
  display: flex; align-items: center; justify-content: center;
  font-weight: 900; font-size: 15px; color: var(--cream);
  overflow: hidden;
  box-shadow: 0 4px 14px rgba(200,16,46,0.35);
}
@keyframes avRingSpin { to { transform: rotate(360deg); } }

.avatar-img { width: 100%; height: 100%; object-fit: cover; border-radius: 50%; display: block; }

.h-name {
  font-family: 'Anton', 'Inter', sans-serif;
  font-weight: 400; font-size: 17px; letter-spacing: 0.6px;
  text-transform: uppercase;
  line-height: 1.05;
  color: var(--cream);
}
.h-sub {
  font-size: 9px; font-weight: 800; margin-top: 3px;
  letter-spacing: 2.4px; text-transform: uppercase;
  color: var(--gold);
  display: inline-flex; align-items: center; gap: 6px;
}
.h-sub::before {
  content: '';
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--gold);
  box-shadow: 0 0 10px var(--gold);
  animation: dotBlink 1.6s ease infinite;
}

.h-bal {
  display: flex; align-items: center; gap: 6px;
  padding: 8px 16px;
  background: linear-gradient(135deg, var(--gold), var(--gold-deep));
  border: 2px solid var(--cream);
  border-radius: 8px;
  font-family: 'Anton', 'Inter', sans-serif;
  font-size: 14px; font-weight: 400; color: var(--red-deep);
  letter-spacing: .8px; text-transform: uppercase;
  position: relative; overflow: hidden;
  box-shadow:
    0 4px 14px rgba(255,199,44,0.35),
    inset 0 1px 0 rgba(255,255,255,0.4);
  transform: rotate(-2deg);
  transition: transform 0.2s;
}
.h-bal:active { transform: rotate(-2deg) scale(0.94); }
.h-bal::before {
  content: '';
  position: absolute; top: 0; left: -60%;
  width: 50%; height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.45), transparent);
  animation: balShimmer 3.6s ease-in-out infinite;
}
@keyframes balShimmer {
  0%, 70% { left: -60%; }
  100%    { left: 110%; }
}

#app-content {
  flex: 1;
  overflow-y: auto;
  overflow-x: hidden;
  padding-bottom: calc(var(--nav-h) + var(--safe-b));
  -webkit-overflow-scrolling: touch;
}
#app-content::-webkit-scrollbar { display: none; }
.page-pad { padding: 16px; }

#app-navbar {
  flex-shrink: 0;
  height: calc(var(--nav-h) + var(--safe-b));
  padding: 6px 8px var(--safe-b);
  display: flex; align-items: stretch; justify-content: space-around;
  background: linear-gradient(0deg, rgba(21,7,8,0.99) 0%, rgba(21,7,8,0.88) 100%);
  border-top: 1px solid var(--line-red);
  z-index: 20;
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  position: relative;
}
#app-navbar::before {
  content: '';
  position: absolute; top: -1px; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--red) 30%, var(--gold) 50%, var(--red) 70%, transparent);
  box-shadow: 0 -2px 14px rgba(200,16,46,0.35);
}

.nav-item {
  flex: 1;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 5px;
  padding: 6px 4px;
  cursor: pointer; user-select: none;
  position: relative; min-width: 0;
  transition: transform 0.18s cubic-bezier(.22,1,.36,1);
}
.nav-item .ico-nav { width: 23px; height: 23px; }
.nav-item span {
  font-size: 9px; font-weight: 900; color: var(--grey-dim);
  letter-spacing: 1px; text-transform: uppercase;
  transition: color 0.18s;
}
.nav-item.active .ico-nav {
  stroke: var(--gold);
  filter: drop-shadow(0 0 10px var(--gold-glow));
  transform: translateY(-2px) scale(1.08);
}
.nav-item.active span { color: var(--gold); }
.nav-item.active::before {
  content: '';
  position: absolute; bottom: 4px; left: 50%; transform: translateX(-50%);
  width: 28px; height: 4px;
  background: linear-gradient(90deg, var(--red), var(--gold), var(--red));
  border-radius: 4px;
  box-shadow: 0 0 12px rgba(255,199,44,0.55);
  animation: navIndicatorIn 0.32s cubic-bezier(.22,1,.36,1);
}
@keyframes navIndicatorIn {
  from { width: 0; opacity: 0; }
  to   { width: 28px; opacity: 1; }
}
.nav-item:active { transform: scale(0.88); }

.hero {
  position: relative;
  margin: 14px 14px 18px;
  height: 220px;
  border-radius: var(--r-lg);
  overflow: hidden;
  animation: heroIn 0.65s cubic-bezier(.22,1,.36,1);
  box-shadow:
    0 16px 42px rgba(0,0,0,0.55),
    0 0 0 2px var(--gold),
    0 0 0 4px var(--bg);
}
.hero img {
  width: 100%; height: 100%; object-fit: cover; display: block;
  animation: kenBurns 22s ease-in-out infinite alternate;
}
@keyframes kenBurns {
  0%   { transform: scale(1.05) translate(0, 0); }
  100% { transform: scale(1.16) translate(-2%, -2%); }
}
.hero-fade {
  position: absolute; inset: 0;
  background:
    linear-gradient(180deg, rgba(16,5,6,0.05) 25%, rgba(16,5,6,0.55) 65%, rgba(16,5,6,0.96) 100%),
    linear-gradient(90deg, rgba(200,16,46,0.45) 0%, transparent 60%);
}
.hero-content { position: absolute; bottom: 0; left: 0; right: 0; padding: 0 22px 22px; }
.hero-pill {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 6px 14px;
  background: var(--gold);
  color: var(--red-deep);
  border: 2px solid var(--cream);
  border-radius: 6px;
  font-family: 'Anton', sans-serif;
  font-size: 11px; font-weight: 400;
  letter-spacing: 1.4px; text-transform: uppercase;
  margin-bottom: 12px;
  box-shadow: 0 6px 16px rgba(255,199,44,0.4);
  animation: slideLeft 0.55s cubic-bezier(0.22,1,0.36,1) 0.3s backwards;
  transform: rotate(-1.5deg);
}
.hero-pill::before {
  content: '';
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--red); box-shadow: 0 0 8px var(--red);
  animation: dotBlink 1.4s ease infinite;
}
.hero-title {
  font-family: 'Anton', sans-serif;
  font-weight: 400;
  font-size: 36px;
  letter-spacing: 0.5px; line-height: 1; text-transform: uppercase;
  text-shadow: 0 3px 22px rgba(0,0,0,0.65), 0 0 14px rgba(200,16,46,0.4);
  animation: slideUp 0.6s cubic-bezier(0.22,1,0.36,1) 0.4s backwards;
  color: var(--cream);
}
.hero-title em {
  font-style: normal;
  background: linear-gradient(180deg, var(--gold-bright), var(--gold), var(--gold-deep));
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  filter: drop-shadow(0 2px 12px rgba(255,199,44,0.4));
}
.hero-desc {
  font-size: 12px;
  color: rgba(255,248,231,0.78);
  margin-top: 8px;
  font-weight: 600;
  letter-spacing: 0.3px;
}

@keyframes heroIn {
  from { opacity: 0; transform: scale(1.06); }
  to   { opacity: 1; transform: scale(1); }
}

.fidelity-banner {
  display: flex; align-items: center;
  margin: 0 16px 22px;
  padding: 16px 18px;
  background: linear-gradient(135deg, var(--red), var(--red-deep));
  border: 2px solid var(--gold);
  border-radius: var(--r);
  cursor: pointer;
  position: relative; overflow: hidden;
  transition: all 0.25s cubic-bezier(.22,1,.36,1);
  animation: slideUp 0.5s cubic-bezier(.22,1,.36,1) 0.2s backwards;
  box-shadow: 0 10px 28px rgba(200,16,46,0.30);
}

.fidelity-banner::before, .fidelity-banner::after {
  content: '';
  position: absolute; top: 50%; transform: translateY(-50%);
  width: 16px; height: 16px;
  background: var(--bg);
  border-radius: 50%;
}
.fidelity-banner::before { left: -10px; box-shadow: 1px 0 0 var(--gold); }
.fidelity-banner::after  { right: -10px; box-shadow: -1px 0 0 var(--gold); }
.fidelity-banner:active { transform: scale(0.97); }

.fid-left { flex: 1; position: relative; z-index: 1; }
.fid-badge {
  display: inline-block; padding: 4px 10px;
  background: var(--gold);
  color: var(--red-deep);
  border-radius: 4px;
  font-family: 'Anton', sans-serif;
  font-size: 11px; font-weight: 400;
  letter-spacing: 1.4px; text-transform: uppercase;
  margin-bottom: 6px;
  box-shadow: 0 2px 10px rgba(255,199,44,0.35);
}
.fid-title {
  font-family: 'Anton', sans-serif;
  font-size: 18px; font-weight: 400; letter-spacing: 0.6px;
  text-transform: uppercase;
  color: var(--cream);
}
.fid-desc { font-size: 11px; color: rgba(255,248,231,0.72); margin-top: 2px; font-weight: 600; }
.fid-arrow {
  font-size: 28px; color: var(--gold); margin-left: 12px; font-weight: 900;
  position: relative; z-index: 1;
  animation: arrowNudge 1.6s ease-in-out infinite;
}
@keyframes arrowNudge {
  0%, 100% { transform: translateX(0); }
  50%      { transform: translateX(5px); }
}

.sec-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 16px; margin-bottom: 14px;
}
.sec-title {
  font-family: 'Anton', sans-serif;
  font-size: 22px; font-weight: 400;
  letter-spacing: 0.8px; text-transform: uppercase;
  color: var(--cream);
  display: inline-flex; align-items: center; gap: 12px;
  position: relative;
}
.sec-title::before {
  content: '';
  width: 6px; height: 24px; border-radius: 3px;
  background: linear-gradient(180deg, var(--gold), var(--red));
  box-shadow: 0 0 12px rgba(255,199,44,0.35);
}
.sec-count {
  font-family: 'Anton', sans-serif;
  font-size: 13px; font-weight: 400; color: var(--red-deep);
  padding: 4px 12px;
  background: var(--gold);
  border: 1px solid var(--cream);
  border-radius: 6px;
  letter-spacing: 1px;
  transform: rotate(-2deg);
  box-shadow: 0 3px 10px rgba(255,199,44,0.35);
}

.sort-toggle {
  display: flex; align-items: center; gap: 6px;
  padding: 7px 14px;
  background: var(--bg-raised); border: 1px solid var(--line-red);
  border-radius: 8px; cursor: pointer;
  transition: all 0.2s cubic-bezier(.22,1,.36,1);
}
.sort-toggle:active { background: var(--bg-card); transform: scale(0.94); }
.sort-toggle span {
  font-size: 10px; font-weight: 900; color: var(--gold);
  letter-spacing: 0.8px; text-transform: uppercase;
}
.sort-ico {
  width: 14px; height: 14px;
  stroke: var(--gold); fill: none; stroke-width: 2.2;
  transition: transform 0.3s cubic-bezier(.22,1,.36,1);
}
.sort-ico.sort-desc { transform: rotate(180deg); }

.tranche {
  margin-bottom: 22px;
  animation: slideUp 0.45s cubic-bezier(.22,1,.36,1) backwards;
}
.tranche-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 13px 18px;
  background: linear-gradient(135deg, var(--red), var(--red-deep));
  border: 2px solid var(--gold);
  border-bottom: none;
  border-radius: var(--r) var(--r) 0 0;
  position: relative;
  box-shadow: 0 4px 16px rgba(200,16,46,0.25);
}
.tranche-head::before {
  content: '';
  position: absolute; left: 16px; top: -8px;
  width: 30px; height: 14px;
  background: var(--gold);
  clip-path: polygon(0 0, 100% 0, 80% 100%, 20% 100%);
  filter: drop-shadow(0 2px 4px rgba(0,0,0,0.35));
}
.tranche-pts {
  font-family: 'Anton', sans-serif;
  font-size: 24px; font-weight: 400; letter-spacing: 1px;
  text-transform: uppercase;
  color: var(--gold);
  filter: drop-shadow(0 2px 10px rgba(255,199,44,0.25));
}
.tranche-pts span {
  font-size: 11px; font-weight: 800; color: var(--cream-dim);
  text-transform: uppercase; letter-spacing: 1px;
  margin-left: 4px;
  font-family: 'Inter', sans-serif;
}
.tranche-stock {
  font-size: 10px; font-weight: 900; padding: 5px 11px;
  border-radius: 6px; letter-spacing: 0.6px; text-transform: uppercase;
  border: 1px solid;
}
.tranche-list {
  border: 2px solid var(--gold);
  border-top: none;
  border-radius: 0 0 var(--r) var(--r);
  overflow: hidden;
  background: var(--bg-card);
}
.tranche-list .p-card {
  margin-bottom: 0;
  border-radius: 0; border: none;
  border-bottom: 1px dashed var(--line-light);
}
.tranche-list .p-card:last-child { border-bottom: none; }

.product-list { padding: 0 16px; }

.p-card {
  display: flex; align-items: center; gap: 14px;
  padding: 14px 16px;
  background: var(--bg-card);
  border: 1px solid var(--line);
  border-radius: var(--r);
  margin-bottom: 8px;
  cursor: pointer;
  transition: transform 0.18s cubic-bezier(.22,1,.36,1), background 0.18s, box-shadow 0.2s;
  animation: slideUp 0.4s cubic-bezier(.22,1,.36,1) backwards;
  position: relative;
}
.p-card:active {
  transform: scale(0.97);
  background: var(--bg-raised);
  box-shadow: 0 0 22px rgba(255,199,44,0.16);
}

.p-thumb {
  width: 62px; height: 62px;
  border-radius: 12px;
  background: linear-gradient(135deg, var(--gold), var(--gold-deep));
  overflow: hidden; flex-shrink: 0;
  border: 2px solid var(--cream);
  position: relative;
  box-shadow: 0 4px 12px rgba(255,199,44,0.18);
  transform: rotate(-2deg);
  transition: transform 0.22s cubic-bezier(.22,1,.36,1);
}
.p-card:active .p-thumb { transform: rotate(0deg) scale(1.04); }
.p-thumb::after {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(135deg, transparent 55%, rgba(255,255,255,0.18));
  pointer-events: none;
}
.p-thumb img { width: 100%; height: 100%; object-fit: cover; }

.p-info { flex: 1; min-width: 0; }
.p-name {
  font-family: 'Anton', sans-serif;
  font-size: 16px; font-weight: 400; letter-spacing: 0.4px;
  text-transform: uppercase;
  color: var(--cream);
}
.p-cat {
  font-size: 9px; color: var(--red-bright); font-weight: 900;
  text-transform: uppercase; letter-spacing: 1px; margin-top: 3px;
  display: inline-flex; align-items: center; gap: 4px;
}
.p-cat::before {
  content: '';
  width: 4px; height: 4px; border-radius: 50%;
  background: var(--red-bright);
  box-shadow: 0 0 6px var(--red-bright);
}
.p-cat-white { color: var(--cream); }
.p-cat-white::before { background: var(--cream); box-shadow: 0 0 6px rgba(255,248,231,0.55); }

.p-right { text-align: right; flex-shrink: 0; }
.p-price {
  font-family: 'Anton', sans-serif;
  font-size: 19px; font-weight: 400; letter-spacing: 0.4px;
  color: var(--gold);
  filter: drop-shadow(0 1px 6px rgba(255,199,44,0.28));
}

.p-stock {
  display: inline-block; margin-top: 5px;
  font-size: 9px; font-weight: 900; padding: 3px 9px;
  border-radius: 4px; letter-spacing: 0.4px; text-transform: uppercase;
  border: 1px solid;
}
.stk-ok  { background: rgba(43,168,98,0.14);  color: var(--green);    border-color: rgba(43,168,98,0.28); }
.stk-low { background: rgba(255,138,31,0.14); color: var(--orange);   border-color: rgba(255,138,31,0.28); }
.stk-out { background: rgba(200,16,46,0.14);  color: var(--red-bright); border-color: rgba(200,16,46,0.32); }

.p-price-wrap {
  display: flex; flex-direction: column; align-items: flex-end; gap: 0;
  line-height: 1.05;
}
.p-price-old {
  font-size: 11px; font-weight: 800;
  color: var(--cream-dim);
  text-decoration: line-through;
  opacity: .65;
  letter-spacing: 0.2px;
}
.p-price-wrap .p-price {
  color: var(--green);
  filter: drop-shadow(0 0 4px rgba(43,168,98,0.4));
}

.det { animation: fadeIn 0.25s ease; }

.det-img {
  width: 100%; height: 240px;
  overflow: hidden; position: relative;
  animation: heroIn 0.5s cubic-bezier(0.22,1,0.36,1);
  background: linear-gradient(135deg, var(--red), var(--red-deep));
  border-bottom: 4px solid var(--gold);
}
.det-img img {
  width: 100%; height: 100%; object-fit: cover; display: block;
  transition: transform 0.5s ease;
  animation: kenBurns 18s ease-in-out infinite alternate;
}
.det-img:active img { transform: scale(1.05); }
.det-img::after {
  content: ''; position: absolute; bottom: 0; left: 0; right: 0;
  height: 60%; background: linear-gradient(transparent, var(--bg));
}

.det-body { padding: 22px 18px 16px; }
.det-name {
  font-family: 'Anton', sans-serif;
  font-size: 30px; font-weight: 400; letter-spacing: 1px;
  text-transform: uppercase;
  color: var(--cream);
  animation: slideUp 0.45s cubic-bezier(0.22,1,0.36,1) 0.15s backwards;
}
.det-desc {
  font-size: 13px; color: var(--grey); line-height: 1.55; margin: 8px 0 22px;
  animation: slideUp 0.45s cubic-bezier(0.22,1,0.36,1) 0.2s backwards;
}
.det-price {
  font-family: 'Anton', sans-serif;
  font-size: 46px; font-weight: 400; letter-spacing: 1px;
  background: linear-gradient(180deg, var(--gold-bright), var(--gold) 50%, var(--gold-deep));
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  margin-bottom: 24px;
  animation: countUp 0.5s cubic-bezier(0.22,1,0.36,1) 0.25s backwards;
  filter: drop-shadow(0 4px 14px rgba(255,199,44,0.25));
}
.det-unit {
  font-family: 'Inter', sans-serif;
  font-size: 13px; color: var(--grey); font-weight: 700;
  letter-spacing: 0.5px;
  -webkit-text-fill-color: var(--grey);
}

.qty-row {
  display: flex; align-items: center; justify-content: space-between; gap: 10px;
  padding: 14px 18px;
  background: linear-gradient(135deg, var(--red), var(--red-deep));
  border: 2px solid var(--gold);
  border-radius: var(--r);
  margin-bottom: 22px;
  box-shadow: 0 6px 20px rgba(200,16,46,0.22);
}
.qty-btn {
  width: 44px; height: 44px; border-radius: 10px;
  border: 2px solid var(--cream);
  background: var(--gold);
  color: var(--red-deep);
  font-family: 'Anton', sans-serif;
  font-size: 22px; font-weight: 400;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; transition: all 0.15s cubic-bezier(.22,1,.36,1);
  box-shadow: 0 3px 10px rgba(0,0,0,0.25);
}
.qty-btn:active {
  background: var(--cream); transform: scale(0.85);
  box-shadow: 0 0 18px rgba(255,199,44,0.5);
}
.qty-val {
  font-family: 'Anton', sans-serif;
  font-size: 30px; font-weight: 400;
  flex: 1; text-align: center;
  letter-spacing: 1.5px;
  color: var(--cream);
  transition: transform 0.15s cubic-bezier(0.22,1,0.36,1);
  text-shadow: 0 2px 8px rgba(0,0,0,0.3);
}
.qty-val.bump { animation: popIn 0.3s cubic-bezier(0.22,1,0.36,1); }

.info-card {
  background: var(--bg-card); border: 1px solid var(--line-light);
  border-radius: var(--r); overflow: hidden; margin-bottom: 10px;
  animation: slideUp 0.4s cubic-bezier(0.22,1,0.36,1) 0.1s backwards;
}
.info-row { display: flex; align-items: center; justify-content: space-between; padding: 13px 16px; }
.info-row + .info-row { border-top: 1px dashed var(--line-light); }
.info-label {
  font-size: 11px; color: var(--grey); font-weight: 700;
  letter-spacing: 0.5px; text-transform: uppercase;
}
.info-val { font-size: 13px; font-weight: 800; color: var(--cream); }
.info-val-gold {
  color: var(--gold);
  font-family: 'Anton', sans-serif;
  font-size: 17px; letter-spacing: 0.5px;
}

.btn {
  width: 100%; padding: 16px; border: none;
  border-radius: var(--r);
  font-family: 'Anton', sans-serif;
  font-size: 15px; font-weight: 400;
  letter-spacing: 1.4px; text-transform: uppercase;
  cursor: pointer;
  transition: all 0.22s cubic-bezier(0.22,1,0.36,1);
  position: relative; overflow: hidden;
  display: inline-flex; align-items: center; justify-content: center; gap: 10px;
}
.btn::after {
  content: ''; position: absolute; inset: 0;
  background: radial-gradient(circle at var(--x, 50%) var(--y, 50%), rgba(255,255,255,0.28) 0%, transparent 60%);
  opacity: 0; transition: opacity 0.3s;
}
.btn:active::after { opacity: 1; }
.btn:active { transform: scale(0.96); }
.btn:disabled { opacity: 0.32; cursor: not-allowed; transform: none; box-shadow: none; }

.btn-gold {
  background: linear-gradient(180deg, var(--gold-bright), var(--gold) 50%, var(--gold-deep));
  color: var(--red-deep);
  border: 2px solid var(--cream);
  box-shadow:
    0 8px 22px rgba(255,199,44,0.32),
    inset 0 1px 0 rgba(255,255,255,0.45);
  text-shadow: 0 1px 0 rgba(255,255,255,0.25);
}
.btn-gold:active {
  box-shadow: 0 0 28px rgba(255,199,44,0.55);
}

.btn-red {
  background: linear-gradient(180deg, var(--red-bright), var(--red) 50%, var(--red-deep));
  color: var(--cream);
  border: 2px solid var(--gold);
  box-shadow:
    0 8px 22px rgba(200,16,46,0.40),
    inset 0 1px 0 rgba(255,255,255,0.20);
}
.btn-red:active { box-shadow: 0 0 28px rgba(200,16,46,0.6); }

.btn-green {
  background: linear-gradient(135deg, var(--green), #1f7a48);
  color: var(--cream);
  border: 2px solid var(--gold);
  box-shadow: 0 6px 22px rgba(43,168,98,0.32), inset 0 1px 0 rgba(255,255,255,0.18);
}

.btn-ghost {
  background: var(--bg-raised); color: var(--cream);
  border: 1px solid var(--line-light);
}
.btn-ghost:active { background: var(--bg-card); border-color: var(--gold); }

.btn-back {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 9px 14px; background: var(--bg-raised); border: 1px solid var(--line);
  border-radius: 100px;
  color: var(--cream-dim); font-family: 'Inter', sans-serif;
  font-size: 11px; font-weight: 800; cursor: pointer;
  letter-spacing: 0.6px; text-transform: uppercase;
  transition: all .15s;
  margin-bottom: 16px;
}
.btn-back:active { color: var(--gold); border-color: var(--gold); transform: translateX(-3px); }
.btn-back .ico-24 { width: 16px; height: 16px; stroke: currentColor; }

.btn-disabled { opacity: .42; pointer-events: none; }

.bal-card {
  text-align: center;
  padding: 32px 22px;
  background:
    repeating-linear-gradient(45deg, rgba(255,248,231,0.025) 0 18px, transparent 18px 19px),
    linear-gradient(135deg, var(--red), var(--red-deep) 60%, #4a0000);
  border: 3px solid var(--gold);
  border-radius: var(--r-lg);
  margin-bottom: 18px;
  position: relative; overflow: hidden;
  animation: slideUp 0.55s cubic-bezier(.22,1,.36,1);
  box-shadow:
    0 14px 40px rgba(200,16,46,0.30),
    inset 0 0 0 1px var(--cream);
}
.bal-card::before {
  content: ''; position: absolute;
  top: 0; left: 0; right: 0; height: 6px;
  background: linear-gradient(90deg, var(--gold-bright), var(--gold), var(--cream), var(--gold), var(--gold-bright));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
@keyframes shimmer {
  0% { background-position: -200% 0; }
  100% { background-position: 200% 0; }
}
.bal-card::after {
  content: 'M';
  position: absolute;
  bottom: -40px; right: -10px;
  font-family: 'Anton', sans-serif;
  font-size: 220px; font-weight: 400;
  color: rgba(255,199,44,0.06);
  line-height: 1;
  pointer-events: none;
  animation: floatBg 12s ease-in-out infinite alternate;
}
@keyframes floatBg {
  from { transform: translate(0, 0) rotate(0deg); }
  to   { transform: translate(-6%, -8%) rotate(8deg); }
}

.bal-label {
  font-size: 10px; font-weight: 900; color: var(--gold);
  text-transform: uppercase; letter-spacing: 3.5px; margin-bottom: 10px;
  animation: fadeIn 0.5s ease 0.1s backwards;
  position: relative; z-index: 1;
}
.bal-amount {
  font-family: 'Anton', sans-serif;
  font-size: 56px; font-weight: 400; letter-spacing: 1px;
  background: linear-gradient(180deg, var(--cream), var(--gold-bright) 50%, var(--gold));
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  animation: countUp 0.6s cubic-bezier(0.22,1,0.36,1) 0.2s backwards;
  filter: drop-shadow(0 4px 14px rgba(255,199,44,0.32));
  position: relative; z-index: 1;
}
.bal-cur {
  font-size: 11px; color: var(--cream-dim); font-weight: 800;
  margin-top: 6px; letter-spacing: 2px; text-transform: uppercase;
  position: relative; z-index: 1;
}

.o-card {
  display: flex; align-items: center; gap: 13px;
  padding: 14px 16px;
  background: var(--bg-card); border: 1px solid var(--line);
  border-radius: var(--r); margin-bottom: 8px;
  cursor: pointer; transition: all 0.2s cubic-bezier(.22,1,.36,1);
  animation: slideUp 0.35s cubic-bezier(.22,1,.36,1) backwards;
  position: relative; overflow: hidden;
}
.o-card::before {
  content: '';
  position: absolute; left: 0; top: 0; bottom: 0;
  width: 4px;
  background: var(--gold);
  opacity: .35;
}
.o-card:nth-child(1) { animation-delay: 0.04s; }
.o-card:nth-child(2) { animation-delay: 0.08s; }
.o-card:nth-child(3) { animation-delay: 0.12s; }
.o-card:nth-child(4) { animation-delay: 0.16s; }
.o-card:nth-child(5) { animation-delay: 0.20s; }
.o-card:nth-child(6) { animation-delay: 0.24s; }
.o-card:active { transform: scale(0.97) translateX(3px); background: var(--bg-raised); }

.o-ico {
  width: 42px; height: 42px; border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  font-size: 16px; flex-shrink: 0;
  border: 1px solid var(--line);
}
.o-ico.pending   { background: rgba(255,138,31,0.10); border-color: rgba(255,138,31,0.22); }
.o-ico.completed { background: rgba(43,168,98,0.10);  border-color: rgba(43,168,98,0.24); }
.o-ico.failed    { background: rgba(200,16,46,0.10);  border-color: rgba(200,16,46,0.24); }
.o-ico .ico-24 { width: 19px; height: 19px; }
.o-ico.pending   .ico-24 { stroke: var(--orange); }
.o-ico.completed .ico-24 { stroke: var(--green); }
.o-ico.failed    .ico-24 { stroke: var(--red-bright); }
.o-ico.completed { animation: subtleGlow 2.4s ease infinite; }
@keyframes subtleGlow {
  0%, 100% { box-shadow: 0 0 0 0 rgba(43,168,98,0); }
  50%      { box-shadow: 0 0 12px 2px rgba(43,168,98,0.22); }
}

.o-info { flex: 1; min-width: 0; }
.o-name {
  font-family: 'Anton', sans-serif;
  font-size: 15px; font-weight: 400; letter-spacing: 0.3px;
  text-transform: uppercase;
  color: var(--cream);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.o-date { font-size: 10px; color: var(--grey-dim); margin-top: 3px; font-weight: 700; letter-spacing: 0.2px; }

.o-status {
  font-size: 9px; font-weight: 900; padding: 4px 10px;
  border-radius: 4px; letter-spacing: 0.6px; text-transform: uppercase; flex-shrink: 0;
  border: 1px solid transparent;
}
.o-status.pending   { background: rgba(255,138,31,0.10); color: var(--orange);     border-color: rgba(255,138,31,0.24); }
.o-status.completed { background: rgba(43,168,98,0.10);  color: var(--green);      border-color: rgba(43,168,98,0.26); }
.o-status.failed    { background: rgba(200,16,46,0.10);  color: var(--red-bright); border-color: rgba(200,16,46,0.26); }

.prof-head { text-align: center; margin: 8px 0 26px; animation: slideUp 0.55s cubic-bezier(.22,1,.36,1); }

.prof-av-wrap {
  width: 130px; height: 130px;
  margin: 0 auto 18px;
  position: relative;
}
.prof-av-wrap::before {
  content: '';
  position: absolute; inset: -7px;
  border-radius: 50%;
  background: conic-gradient(from 0deg,
    var(--gold) 0deg,
    var(--gold-bright) 60deg,
    transparent 120deg,
    var(--red-bright) 180deg,
    transparent 240deg,
    var(--red) 300deg,
    var(--gold) 360deg);
  animation: avRingSpin 5.5s linear infinite;
  filter: blur(1.5px);
  z-index: 0;
}
.prof-av-wrap::after {
  content: '';
  position: absolute; inset: -22px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(200,16,46,0.30), transparent 65%);
  animation: avHalo 3s ease-in-out infinite;
  pointer-events: none; z-index: -1;
}
@keyframes avHalo {
  0%, 100% { opacity: .5; transform: scale(0.95); }
  50%      { opacity: 1;  transform: scale(1.06); }
}

.prof-av {
  position: relative; z-index: 2;
  width: 130px; height: 130px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--red), var(--red-deep));
  display: flex; align-items: center; justify-content: center;
  font-family: 'Anton', sans-serif;
  font-size: 50px; font-weight: 400; color: var(--cream);
  overflow: hidden;
  box-shadow:
    0 0 0 5px var(--bg),
    0 18px 45px rgba(200,16,46,0.35),
    inset 0 0 0 2px rgba(255,255,255,0.10);
  animation: popIn 0.55s cubic-bezier(0.22,1,0.36,1);
  transition: transform 0.3s cubic-bezier(0.22,1,0.36,1);
}
.prof-av:active { transform: scale(0.94); }
.prof-av .avatar-img { width: 100%; height: 100%; object-fit: cover; border-radius: 50%; }
.prof-av-shine {
  position: absolute; top: 0; left: -100%;
  width: 100%; height: 100%;
  background: linear-gradient(110deg, transparent 30%, rgba(255,255,255,0.32) 50%, transparent 70%);
  animation: avShine 4.5s ease-in-out infinite;
  pointer-events: none; z-index: 3;
}
@keyframes avShine {
  0%, 60%  { left: -100%; }
  100%     { left: 110%; }
}

.prof-name {
  font-family: 'Anton', sans-serif;
  font-size: 26px; font-weight: 400; letter-spacing: 1px;
  text-transform: uppercase;
  color: var(--cream);
  display: inline-flex; align-items: center; gap: 8px;
}
.prof-name::after {
  content: '';
  width: 18px; height: 18px;
  background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23FFC72C'><path d='M12 2l2.39 2.39 3.39-.39.61 3.39 3.22 1.34-.96 3.27.96 3.27-3.22 1.34-.61 3.39-3.39-.39L12 22l-2.39-2.39-3.39.39-.61-3.39L2.39 15.27 3.35 12l-.96-3.27 3.22-1.34.61-3.39 3.39.39L12 2zm-1 14l6-6-1.41-1.41L11 13.17l-2.59-2.58L7 12l4 4z'/></svg>") no-repeat center / contain;
  animation: badgeBounce 1.6s ease-in-out infinite;
  filter: drop-shadow(0 0 8px rgba(255,199,44,0.5));
}
@keyframes badgeBounce {
  0%, 100% { transform: translateY(0) rotate(0deg); }
  50%      { transform: translateY(-3px) rotate(8deg); }
}
.prof-tag {
  font-size: 11px; color: var(--cream-dim); margin-top: 5px;
  font-weight: 800; letter-spacing: 1.2px; text-transform: uppercase;
}

.prof-stats {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 9px; margin-bottom: 22px;
  animation: slideUp 0.45s cubic-bezier(.22,1,.36,1) 0.15s backwards;
}
.prof-stat {
  background: var(--bg-card); border: 1px solid var(--line-light);
  border-radius: 12px; padding: 14px 8px;
  text-align: center;
  position: relative; overflow: hidden;
}
.prof-stat::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--red), var(--gold), var(--red));
}
.prof-stat-val {
  font-family: 'Anton', sans-serif;
  font-size: 22px; font-weight: 400; letter-spacing: 0.5px;
  background: linear-gradient(180deg, var(--gold-bright), var(--gold-deep));
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
}
.prof-stat-lbl {
  font-size: 9px; font-weight: 900; color: var(--cream-dim);
  text-transform: uppercase; letter-spacing: 0.8px; margin-top: 3px;
}

.set-row {
  display: flex; align-items: center; gap: 14px;
  padding: 14px 16px;
  background: var(--bg-card); border: 1px solid var(--line);
  border-radius: var(--r); margin-bottom: 8px;
  cursor: pointer; transition: all 0.22s cubic-bezier(.22,1,.36,1);
  animation: slideUp 0.32s cubic-bezier(.22,1,.36,1) backwards;
  position: relative;
}
.set-row::before {
  content: '';
  position: absolute; left: 0; top: 50%; transform: translateY(-50%);
  width: 3px; height: 0; border-radius: 3px;
  background: var(--gold);
  transition: height 0.25s cubic-bezier(.22,1,.36,1);
}
.set-row:active::before { height: 80%; }
.set-row:nth-child(1) { animation-delay: 0.06s; }
.set-row:nth-child(2) { animation-delay: 0.10s; }
.set-row:nth-child(3) { animation-delay: 0.14s; }
.set-row:nth-child(4) { animation-delay: 0.18s; }
.set-row:nth-child(5) { animation-delay: 0.22s; }
.set-row:nth-child(6) { animation-delay: 0.26s; }
.set-row:nth-child(7) { animation-delay: 0.30s; }
.set-row:active { background: var(--bg-raised); transform: scale(0.97) translateX(3px); border-color: var(--line-light); }
.set-row:active .set-ico { background: var(--gold); border-color: var(--gold); }
.set-row:active .set-ico .ico-24 { stroke: var(--red-deep); }

.set-ico {
  width: 38px; height: 38px; border-radius: 10px;
  background: var(--bg-raised); border: 1px solid var(--line-light);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; color: var(--gold);
  transition: all .22s;
}
.set-ico .ico-24 { width: 18px; height: 18px; stroke: var(--gold); transition: stroke .22s; }
.set-label {
  flex: 1;
  font-family: 'Inter', sans-serif;
  font-size: 13px; font-weight: 800; color: var(--cream);
  letter-spacing: 0.2px;
}
.set-chev { color: var(--gold); font-size: 22px; font-weight: 700; }

.empty { text-align: center; padding: 56px 24px; animation: slideUp 0.45s cubic-bezier(.22,1,.36,1); }
.empty-ico {
  width: 76px; height: 76px; margin: 0 auto 16px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--red), var(--red-deep));
  border: 2px solid var(--gold);
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 8px 24px rgba(200,16,46,0.32);
}
.empty-ico .ico-24 { width: 36px; height: 36px; stroke: var(--gold); }
.empty-title {
  font-family: 'Anton', sans-serif;
  font-size: 20px; font-weight: 400; letter-spacing: 0.7px;
  text-transform: uppercase;
  margin-bottom: 8px;
  color: var(--cream);
}
.empty-desc { font-size: 12px; color: var(--grey); line-height: 1.5; max-width: 280px; margin: 0 auto; font-weight: 600; }

#toast-container {
  position: fixed; top: 14px; left: 14px; right: 14px;
  z-index: 9999; display: flex; flex-direction: column; gap: 8px;
  pointer-events: none;
}
.toast {
  padding: 13px 18px; border-radius: var(--r);
  font-size: 12px; font-weight: 800; letter-spacing: .3px;
  animation: toastIn 0.28s cubic-bezier(.22,1,.36,1); pointer-events: auto;
  box-shadow: 0 14px 36px rgba(0,0,0,0.45);
  border: 2px solid transparent;
}
.toast-success {
  background: linear-gradient(135deg, var(--green), #1f7a48);
  color: var(--cream); border-color: var(--gold);
}
.toast-error {
  background: linear-gradient(135deg, var(--red-bright), var(--red-deep));
  color: var(--cream); border-color: var(--gold);
}
.toast-info {
  background: var(--bg-raised); color: var(--gold);
  border-color: var(--gold);
}
@keyframes toastIn {
  from { opacity: 0; transform: translateY(-12px) scale(0.94); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}
.toast-out { animation: toastOut 0.22s ease forwards; }
@keyframes toastOut { to { opacity: 0; transform: translateY(-10px) scale(0.96); } }

.loader {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  height: 50vh; gap: 22px;
  animation: fadeIn 0.3s ease;
}

.ld-arch {
  display: flex; gap: 6px; align-items: flex-end;
  height: 50px;
}
.ld-arch span {
  display: block;
  width: 16px; height: 40px;
  border-radius: 16px 16px 4px 4px;
  background: linear-gradient(180deg, var(--gold-bright), var(--gold), var(--gold-deep));
  box-shadow: 0 0 16px rgba(255,199,44,0.55), inset 0 -3px 6px rgba(0,0,0,0.18);
  animation: archBounce 1.1s ease-in-out infinite;
}
.ld-arch span:nth-child(2) { animation-delay: 0.18s; }
@keyframes archBounce {
  0%, 100% { transform: scaleY(1); opacity: .85; }
  50%      { transform: scaleY(1.5); opacity: 1; }
}

.ld-text {
  font-family: 'Anton', sans-serif;
  font-size: 18px; font-weight: 400; letter-spacing: 6px; text-transform: uppercase;
  background: linear-gradient(90deg, var(--gold), var(--red-bright), var(--gold));
  background-size: 200% 100%;
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  animation: shimmer 2.5s linear infinite;
}

.spin {
  width: 16px; height: 16px;
  border: 2px solid rgba(255,248,231,0.18);
  border-top-color: var(--cream);
  border-radius: 50%;
  animation: spin 0.55s linear infinite;
  display: inline-block; vertical-align: middle;
}
@keyframes spin { to { transform: rotate(360deg); } }

.modal-overlay {
  position: fixed; inset: 0; z-index: 9000;
  background: rgba(0,0,0,0);
  display: flex; flex-direction: column;
  transition: background 0.3s ease;
}
.modal-overlay.modal-visible {
  background: var(--bg-overlay);
  backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px);
}
.modal-content {
  flex: 1; display: flex; flex-direction: column;
  opacity: 0; transform: translateY(20px);
  transition: all 0.28s cubic-bezier(.22,1,.36,1);
}
.modal-visible .modal-content { opacity: 1; transform: translateY(0); }
.modal-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 18px 16px; flex-shrink: 0;
}
.modal-title {
  font-family: 'Anton', sans-serif;
  font-size: 20px; font-weight: 400; letter-spacing: 0.8px;
  text-transform: uppercase;
  color: var(--cream);
}
.modal-close {
  width: 36px; height: 36px; border-radius: 50%;
  border: 2px solid var(--gold); background: var(--bg-card);
  color: var(--gold); font-size: 14px; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: all 0.18s;
}
.modal-close:active { transform: scale(0.85) rotate(90deg); background: var(--gold); color: var(--red-deep); }
.modal-body { flex: 1; overflow-y: auto; padding: 0 14px 28px; -webkit-overflow-scrolling: touch; }
.fidelity-img {
  width: 100%; border-radius: var(--r-lg); display: block;
  box-shadow: 0 14px 36px rgba(0,0,0,0.45);
  border: 2px solid var(--gold);
}

@keyframes slideUp   { from { opacity: 0; transform: translateY(20px); } to { opacity: 1; transform: translateY(0); } }
@keyframes slideDown { from { opacity: 0; transform: translateY(-20px); } to { opacity: 1; transform: translateY(0); } }
@keyframes slideLeft { from { opacity: 0; transform: translateX(26px); } to { opacity: 1; transform: translateX(0); } }
@keyframes slideRight{ from { opacity: 0; transform: translateX(-26px); } to { opacity: 1; transform: translateX(0); } }
@keyframes scaleIn   { from { opacity: 0; transform: scale(0.86); } to { opacity: 1; transform: scale(1); } }
@keyframes popIn     { 0% { opacity: 0; transform: scale(0.6); } 70% { transform: scale(1.06); } 100% { opacity: 1; transform: scale(1); } }
@keyframes fadeIn    { from { opacity: 0; } to { opacity: 1; } }
@keyframes goldPulse { 0%, 100% { box-shadow: 0 0 0 0 rgba(255,199,44,0.32); } 50% { box-shadow: 0 0 22px 5px rgba(255,199,44,0.20); } }
@keyframes float     { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(-6px); } }
@keyframes countUp   { from { opacity: 0; transform: translateY(12px) scale(0.84); } to { opacity: 1; transform: translateY(0) scale(1); } }
@keyframes skeletonLoad { 0% { background-position: -200% 0; } 100% { background-position: 200% 0; } }

.fade-in { animation: slideUp 0.45s cubic-bezier(0.22,1,0.36,1); }
.fade-left { animation: slideLeft 0.45s cubic-bezier(0.22,1,0.36,1); }
.fade-right { animation: slideRight 0.45s cubic-bezier(0.22,1,0.36,1); }
.pop-in { animation: popIn 0.5s cubic-bezier(0.22,1,0.36,1); }
.anim-float { animation: float 3s ease-in-out infinite; }

.admin-nav {
  display: flex; gap: 6px;
  overflow-x: auto;
  padding: 0 0 4px;
  scroll-snap-type: x mandatory;
}
.admin-nav::-webkit-scrollbar { display: none; }
.admin-nav-btn {
  flex-shrink: 0;
  padding: 10px 18px; border: 1px solid var(--line); border-radius: 8px;
  background: var(--bg-card); color: var(--cream-dim);
  font-family: 'Anton', sans-serif; font-size: 12px; font-weight: 400;
  text-transform: uppercase; letter-spacing: 1px; cursor: pointer;
  transition: all 0.22s cubic-bezier(.22,1,.36,1); white-space: nowrap;
  scroll-snap-align: start;
}
.admin-nav-btn:active { transform: scale(0.92); }
.admin-nav-btn.active {
  background: linear-gradient(135deg, var(--red-bright), var(--red-deep));
  color: var(--cream); border-color: var(--gold);
  box-shadow: 0 0 18px rgba(200,16,46,0.42);
}

.admin-tabs {
  display: flex; gap: 4px;
  background: var(--bg-card); border: 1px solid var(--line-light);
  border-radius: var(--r); padding: 4px;
}
.admin-tab {
  flex: 1; padding: 11px; border: none; border-radius: 10px;
  background: transparent; color: var(--cream-dim);
  font-family: 'Anton', sans-serif; font-size: 12px; font-weight: 400;
  text-transform: uppercase; letter-spacing: 0.8px; cursor: pointer; transition: all 0.18s;
}
.admin-tab.active {
  background: linear-gradient(135deg, var(--red-bright), var(--red-deep));
  color: var(--cream);
}

.admin-form {
  background: var(--bg-card); border: 1px solid var(--line-light);
  border-radius: var(--r); padding: 16px;
  animation: slideUp 0.4s cubic-bezier(.22,1,.36,1);
}
.input-group { margin-bottom: 10px; }
.input-label {
  font-size: 10px; font-weight: 900; color: var(--gold);
  text-transform: uppercase; letter-spacing: 1.2px;
  margin-bottom: 6px; display: block;
}

.input-field {
  width: 100%; padding: 12px 14px;
  background: var(--bg-input); border: 1px solid var(--line-light);
  border-radius: 10px; color: var(--cream);
  font-family: 'Inter', sans-serif; font-size: 13px; outline: none;
  transition: border-color 0.18s, box-shadow .18s;
}
.input-field:focus {
  border-color: var(--gold);
  box-shadow: 0 0 0 3px rgba(255,199,44,0.14);
}

.input-textarea {
  width: 100%; padding: 12px 14px;
  background: var(--bg-input); border: 1px solid var(--line-light);
  border-radius: 10px; color: var(--cream);
  font-family: 'Inter', sans-serif; font-size: 13px; outline: none;
  resize: vertical; min-height: 88px; transition: border-color 0.18s, box-shadow .18s;
}
.input-textarea:focus { border-color: var(--gold); box-shadow: 0 0 0 3px rgba(255,199,44,0.14); }

.input-row { display: flex; gap: 6px; }
.admin-separator { height: 1px; background: var(--line-light); margin: 14px 0; }

.file-zone { position: relative; margin-bottom: 10px; }
.file-input { position: absolute; inset: 0; opacity: 0; cursor: pointer; z-index: -1; }
.file-zone-inner {
  display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 8px;
  padding: 26px; border: 2px dashed var(--line-light);
  border-radius: var(--r); cursor: pointer; transition: all 0.2s;
  background: rgba(255,199,44,0.025);
}
.file-zone-inner:active { border-color: var(--gold); background: rgba(255,199,44,0.06); }
.file-zone-icon { display: flex; align-items: center; justify-content: center; }
.file-zone-icon .ico-24 { width: 30px; height: 30px; stroke: var(--gold); }
.file-zone-text { font-size: 11px; color: var(--cream-dim); font-weight: 800; letter-spacing: 0.4px; }

.file-preview {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 12px; background: var(--bg-input);
  border-radius: 10px; border: 1px solid var(--line-light);
}
.file-preview-img { width: 48px; height: 48px; border-radius: 8px; object-fit: cover; border: 1px solid var(--gold); }
.file-preview-name { flex: 1; font-size: 11px; font-weight: 800; color: var(--cream-dim); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.file-remove {
  width: 30px; height: 30px; border-radius: 50%; border: 1px solid var(--red-bright);
  background: rgba(200,16,46,0.16); color: var(--red-bright);
  font-size: 13px; cursor: pointer; display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}

.bc-result { margin-top: 12px; padding: 11px 14px; border-radius: 10px; font-size: 11px; font-weight: 900; text-align: center; animation: slideUp 0.25s ease; letter-spacing: 0.3px; }
.bc-result-success { background: rgba(43,168,98,0.10); color: var(--green);      border: 1px solid rgba(43,168,98,0.26); }
.bc-result-error   { background: rgba(200,16,46,0.10); color: var(--red-bright); border: 1px solid rgba(200,16,46,0.26); }

.admin-stats-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 9px;
}
.admin-stats-grid .stat-card { animation: popIn 0.45s cubic-bezier(0.22,1,0.36,1) backwards; }
.admin-stats-grid .stat-card:nth-child(1) { animation-delay: 0.00s; }
.admin-stats-grid .stat-card:nth-child(2) { animation-delay: 0.06s; }
.admin-stats-grid .stat-card:nth-child(3) { animation-delay: 0.12s; }
.admin-stats-grid .stat-card:nth-child(4) { animation-delay: 0.18s; }
.admin-stats-grid .stat-card:nth-child(5) { animation-delay: 0.24s; }
.admin-stats-grid .stat-card:nth-child(6) { animation-delay: 0.30s; }
.admin-stats-grid .stat-card:nth-child(7) { animation-delay: 0.36s; }
.admin-stats-grid .stat-card:nth-child(8) { animation-delay: 0.42s; }
.admin-stats-grid .stat-card:nth-child(9) { animation-delay: 0.48s; }

.stat-card {
  background:
    linear-gradient(135deg, rgba(255,199,44,0.05), transparent 50%),
    var(--bg-card);
  border: 1px solid var(--line-light);
  border-radius: var(--r); padding: 16px; text-align: center;
  transition: transform 0.22s, box-shadow 0.22s;
  position: relative; overflow: hidden;
}
.stat-card::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--red), var(--gold));
}
.stat-card:active { transform: scale(0.96); box-shadow: 0 0 20px rgba(255,199,44,0.16); }
.stat-val {
  font-family: 'Anton', sans-serif;
  font-size: 30px; font-weight: 400; letter-spacing: 0.5px;
  background: linear-gradient(180deg, var(--gold-bright), var(--gold-deep));
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  animation: countUp 0.55s cubic-bezier(0.22,1,0.36,1) backwards;
}
.stat-lbl { font-size: 9px; font-weight: 900; color: var(--cream-dim); text-transform: uppercase; letter-spacing: 1px; margin-top: 4px; }
.stat-card-wide { grid-column: span 2; }

.adm-user-row {
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 14px;
  background: var(--bg-card); border: 1px solid var(--line);
  border-radius: 10px; margin-bottom: 6px;
  animation: slideUp 0.25s cubic-bezier(.22,1,.36,1) backwards;
}
.adm-user-info { flex: 1; min-width: 0; }
.adm-user-name { font-size: 12px; font-weight: 800; color: var(--cream); }
.adm-user-meta { font-size: 9px; color: var(--grey-dim); margin-top: 3px; font-weight: 700; letter-spacing: 0.3px; }
.adm-user-actions { display: flex; gap: 5px; flex-shrink: 0; }
.adm-btn-sm {
  width: 32px; height: 32px; border-radius: 9px;
  border: 1px solid var(--line); background: var(--bg-raised);
  color: var(--cream-dim); cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: all 0.15s cubic-bezier(.22,1,.36,1);
}
.adm-btn-sm .ico-24 { width: 14px; height: 14px; }
.adm-btn-sm:active { transform: scale(0.85); }
.adm-btn-del { border-color: rgba(200,16,46,0.22); color: var(--red-bright); }
.adm-btn-del .ico-24 { stroke: var(--red-bright); }
.adm-btn-del:active { background: rgba(200,16,46,0.14); }
.adm-btn-dm { color: var(--gold); border-color: var(--line-light); }
.adm-btn-dm .ico-24 { stroke: var(--gold); }

.crypto-tabs { display: flex; gap: 6px; overflow-x: auto; padding: 2px 0; }
.crypto-tabs::-webkit-scrollbar { display: none; }
.crypto-tab {
  display: flex; align-items: center; gap: 6px;
  padding: 10px 14px;
  background: var(--bg-card); border: 1px solid var(--line);
  border-radius: 10px;
  font-family: 'Inter', sans-serif; font-size: 11px; font-weight: 900;
  color: var(--cream-dim); cursor: pointer;
  transition: all 0.22s cubic-bezier(.22,1,.36,1); white-space: nowrap;
  letter-spacing: 0.5px;
}
.crypto-tab .ico { width: 18px; height: 18px; }
.crypto-tab:active { transform: scale(0.93); }
.crypto-tab.active {
  background: linear-gradient(135deg, var(--gold-bright), var(--gold-deep));
  color: var(--red-deep); border-color: var(--cream);
  box-shadow: 0 0 20px rgba(255,199,44,0.25);
}

.pay-info-card {
  background: var(--bg-card); border: 1px solid var(--line-light);
  border-radius: var(--r); padding: 16px;
  animation: slideUp 0.4s cubic-bezier(.22,1,.36,1);
}
.pay-info-title {
  font-family: 'Anton', sans-serif;
  font-size: 15px; font-weight: 400; letter-spacing: 0.7px;
  text-transform: uppercase;
  color: var(--gold); margin-bottom: 12px;
}
.pay-info-row {
  display: flex; align-items: center; justify-content: space-between;
  padding: 10px 0; border-bottom: 1px dashed var(--line-light);
  font-size: 12px; color: var(--cream-dim); font-weight: 700;
}
.pay-info-amount { font-weight: 900; color: var(--gold); font-size: 14px; font-family: 'Anton', sans-serif; letter-spacing: 0.5px; }
.pay-info-addr {
  font-size: 10px; font-weight: 700; color: var(--cream);
  font-family: ui-monospace, monospace;
  max-width: 170px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.pay-info-note { font-size: 10px; color: var(--grey-dim); margin-top: 12px; line-height: 1.5; font-weight: 700; }

.pay-methods { display: flex; gap: 6px; }
.pay-method-btn {
  flex: 1; display: flex; align-items: center; justify-content: center; gap: 8px;
  padding: 14px;
  background: var(--bg-card); border: 1px solid var(--line);
  border-radius: var(--r);
  font-family: 'Anton', sans-serif; font-size: 13px; font-weight: 400;
  color: var(--cream-dim); cursor: pointer;
  transition: all 0.22s cubic-bezier(.22,1,.36,1); text-transform: uppercase; letter-spacing: 1px;
}
.pay-method-btn .ico { width: 22px; height: 22px; }
.pay-method-btn.active {
  background: linear-gradient(135deg, var(--gold-bright), var(--gold-deep));
  color: var(--red-deep); border-color: var(--cream);
  box-shadow: 0 0 20px rgba(255,199,44,0.25);
}
.pay-method-btn:active { transform: scale(0.97); }

.pay-steps { margin-bottom: 18px; }
.pay-step {
  display: flex; align-items: center; gap: 13px;
  padding: 12px 0;
  animation: slideLeft 0.4s cubic-bezier(0.22,1,0.36,1) backwards;
}
.pay-step:nth-child(1) { animation-delay: 0.05s; }
.pay-step:nth-child(2) { animation-delay: 0.12s; }
.pay-step:nth-child(3) { animation-delay: 0.19s; }
.pay-step + .pay-step { border-top: 1px dashed var(--line-light); }
.pay-step-num {
  width: 34px; height: 34px; border-radius: 50%;
  background: linear-gradient(135deg, var(--gold), var(--gold-deep));
  border: 2px solid var(--cream);
  display: flex; align-items: center; justify-content: center;
  font-family: 'Anton', sans-serif;
  font-size: 14px; font-weight: 400; color: var(--red-deep);
  flex-shrink: 0;
  box-shadow: 0 3px 10px rgba(255,199,44,0.28);
}
.pay-step-text {
  font-size: 12px; font-weight: 700; color: var(--cream-dim);
  letter-spacing: 0.2px;
}

.btn-paypal {
  display: flex; align-items: center; justify-content: center; gap: 10px;
  width: 100%; padding: 16px; border: 2px solid var(--gold);
  border-radius: var(--r);
  background: linear-gradient(135deg, #0070BA, #003087); color: var(--cream);
  font-family: 'Anton', sans-serif; font-size: 14px; font-weight: 400;
  letter-spacing: 1.2px; text-transform: uppercase;
  text-decoration: none; cursor: pointer;
  transition: all 0.18s;
  box-shadow: 0 8px 22px rgba(0,112,186,0.32);
}
.btn-paypal .ico { width: 20px; height: 20px; }
.btn-paypal:active { transform: scale(0.97); box-shadow: 0 0 24px rgba(0,112,186,0.45); }

.ticket-head { display: flex; align-items: center; gap: 14px; margin-bottom: 22px; }
.ticket-head-ico {
  width: 54px; height: 54px; border-radius: 50%;
  background: linear-gradient(135deg, var(--red), var(--red-deep));
  border: 2px solid var(--gold);
  display: flex; align-items: center; justify-content: center;
  animation: popIn 0.5s cubic-bezier(0.22,1,0.36,1) 0.1s backwards, gatePulse 3s ease infinite;
  box-shadow: 0 6px 18px rgba(200,16,46,0.32);
}
.ticket-head-ico .ico-24 { width: 26px; height: 26px; stroke: var(--gold); }
.ticket-head-text { flex: 1; }
.ticket-head-title {
  font-family: 'Anton', sans-serif;
  font-size: 22px; font-weight: 400; letter-spacing: 0.8px;
  text-transform: uppercase;
  color: var(--cream);
}
.ticket-head-desc { font-size: 11px; color: var(--cream-dim); margin-top: 4px; font-weight: 700; letter-spacing: 0.3px; }

.ticket-form {
  background: var(--bg-card); border: 1px solid var(--line-light);
  border-radius: var(--r); padding: 18px;
  animation: slideUp 0.4s cubic-bezier(.22,1,.36,1);
}
.ticket-subjects { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 14px; }
.ticket-subj {
  padding: 9px 14px;
  background: var(--bg-raised); border: 1px solid var(--line-light);
  border-radius: 8px;
  font-family: 'Inter', sans-serif; font-size: 11px; font-weight: 900;
  color: var(--cream-dim); cursor: pointer;
  transition: all 0.22s cubic-bezier(.22,1,.36,1);
  letter-spacing: 0.3px;
}
.ticket-subj:active { transform: scale(0.92); }
.ticket-subj.active {
  background: linear-gradient(135deg, var(--gold-bright), var(--gold-deep));
  color: var(--red-deep); border-color: var(--cream);
  box-shadow: 0 0 14px rgba(255,199,44,0.25);
}

.ticket-history { margin-top: 24px; }
.ticket-item {
  padding: 14px;
  background: var(--bg-card); border: 1px solid var(--line);
  border-radius: var(--r); margin-bottom: 8px;
  animation: slideLeft 0.4s cubic-bezier(0.22,1,0.36,1) backwards;
  position: relative;
}
.ticket-item::before {
  content: ''; position: absolute; left: 0; top: 0; bottom: 0;
  width: 3px; background: var(--gold); opacity: .5;
  border-radius: 3px 0 0 3px;
}
.ticket-item:nth-child(1) { animation-delay: 0.04s; }
.ticket-item:nth-child(2) { animation-delay: 0.08s; }
.ticket-item:nth-child(3) { animation-delay: 0.12s; }
.ticket-item:nth-child(4) { animation-delay: 0.16s; }
.ticket-item-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 6px; }
.ticket-item-subj {
  font-family: 'Anton', sans-serif;
  font-size: 14px; font-weight: 400; letter-spacing: 0.4px;
  text-transform: uppercase;
  color: var(--cream);
}
.ticket-item-date { font-size: 9px; color: var(--grey-dim); font-weight: 800; letter-spacing: 0.3px; }
.ticket-item-msg { font-size: 11px; color: var(--cream-dim); line-height: 1.5; font-weight: 600; }
.ticket-item-status {
  display: inline-block; margin-top: 8px;
  font-size: 9px; font-weight: 900; padding: 3px 9px;
  border-radius: 4px; letter-spacing: 0.5px; text-transform: uppercase;
}
.ticket-item-status.sent { background: rgba(43,168,98,0.10); color: var(--green); border: 1px solid rgba(43,168,98,0.26); }

.skeleton {
  background: linear-gradient(90deg, var(--bg-card) 25%, var(--bg-raised) 50%, var(--bg-card) 75%);
  background-size: 200% 100%;
  animation: skeletonLoad 1.5s ease-in-out infinite;
  border-radius: var(--r);
}
.skel-card  { height: 80px;  margin-bottom: 8px; border-radius: var(--r); }
.skel-stat  { height: 88px;  border-radius: var(--r); }
.skel-hero  { height: 220px; border-radius: var(--r-lg); margin: 14px 14px 18px; }
.skel-block { height: 48px;  border-radius: 10px; margin-bottom: 6px; }

.page-enter { animation: pageSlideIn 0.42s cubic-bezier(0.22,1,0.36,1); }
@keyframes pageSlideIn {
  from { opacity: 0; transform: translateY(16px); }
  to   { opacity: 1; transform: translateY(0); }
}

.stagger-1 { animation-delay: 0.04s !important; }
.stagger-2 { animation-delay: 0.08s !important; }
.stagger-3 { animation-delay: 0.12s !important; }
.stagger-4 { animation-delay: 0.16s !important; }
.stagger-5 { animation-delay: 0.20s !important; }
.stagger-6 { animation-delay: 0.24s !important; }
.stagger-7 { animation-delay: 0.28s !important; }
.stagger-8 { animation-delay: 0.32s !important; }

.glow-gold  { box-shadow: 0 0 16px rgba(255,199,44,0.20); }
.glow-red   { box-shadow: 0 0 16px rgba(200,16,46,0.20); }
.glow-green { box-shadow: 0 0 16px rgba(43,168,98,0.20); }
.pulse-gold  { animation: goldPulse 2s ease infinite; }

.pay-poll-status { padding: 14px; border-radius: var(--r); background: var(--bg-card); border: 1px solid var(--line-light); }
.poll-row { display: flex; align-items: center; gap: 10px; }
.poll-dot { width: 10px; height: 10px; border-radius: 50%; flex-shrink: 0; }
.poll-dot.waiting    { background: var(--orange);     animation: dotBlink 1.5s ease infinite; }
.poll-dot.confirming { background: var(--gold);       animation: dotBlink 0.8s ease infinite; }
.poll-dot.success    { background: var(--green);      animation: none; }
.poll-dot.error      { background: var(--red-bright); animation: none; }
.poll-label { font-size: 13px; font-weight: 800; color: var(--cream); }
.poll-timer { margin-top: 8px; font-size: 12px; font-weight: 800; color: var(--cream-dim); font-variant-numeric: tabular-nums; letter-spacing: .05em; }

.hidden { display: none !important; }

.divider { height: 1px; background: linear-gradient(90deg, transparent, var(--line-light), transparent); margin: 18px 0; }
.mt-10 { margin-top: 10px; }
.mt-16 { margin-top: 16px; }
.mt-20 { margin-top: 20px; }
.mb-10 { margin-bottom: 10px; }
.mb-16 { margin-bottom: 16px; }
.mb-20 { margin-bottom: 20px; }
.gap-8 { gap: 8px; }

#app-header.h2 {
  height: 78px;
  padding: 8px 14px;
  display: grid;
  grid-template-columns: auto 1fr auto auto;
  grid-template-rows: 1fr 1fr;
  align-items: center;
  column-gap: 12px;
  row-gap: 0;
}
.h2-av { grid-row: 1 / span 2; align-self: center; }
.h2-loc {
  grid-column: 2; grid-row: 1;
  display: flex; align-items: center; gap: 5px;
  font-size: 9px; font-weight: 800;
  color: var(--cream-dim);
  letter-spacing: 1.5px; text-transform: uppercase;
}
.h2-loc .ico-24 { width: 11px; height: 11px; stroke: var(--gold); }
.h2-name {
  grid-column: 2; grid-row: 2;
  font-family: 'Anton', sans-serif;
  font-size: 17px; font-weight: 400; letter-spacing: 0.7px;
  text-transform: uppercase;
  color: var(--cream);
  line-height: 1;
}
.h2-bell, .h2-bal-mini {
  grid-row: 1 / span 2;
  align-self: center;
}
.h2-bell {
  width: 40px; height: 40px;
  border-radius: 12px;
  background: var(--bg-raised);
  border: 1px solid var(--line-light);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  transition: all .18s;
  position: relative;
}
.h2-bell .ico-24 { width: 18px; height: 18px; stroke: var(--gold); }
.h2-bell:active { transform: scale(0.9); background: var(--gold); }
.h2-bell:active .ico-24 { stroke: var(--red-deep); }
.h2-bell-dot {
  position: absolute; top: 6px; right: 6px;
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--red-bright);
  border: 2px solid var(--bg);
  animation: dotBlink 1.4s ease infinite;
}
.h2-bal-mini {
  display: flex; flex-direction: column; align-items: flex-end;
  padding: 6px 12px;
  background: linear-gradient(135deg, var(--gold), var(--gold-deep));
  border: 2px solid var(--cream);
  border-radius: 10px;
  box-shadow: 0 4px 12px rgba(255,199,44,0.32);
  transform: rotate(-2deg);
  cursor: pointer;
  transition: all .18s;
  min-width: 70px;
}
.h2-bal-mini:active { transform: rotate(-2deg) scale(.93); }
.h2-bal-mini-lbl {
  font-size: 7px; font-weight: 900; color: var(--red-deep);
  letter-spacing: 1.5px; text-transform: uppercase;
  line-height: 1;
}
.h2-bal-mini-val {
  font-family: 'Anton', sans-serif;
  font-size: 16px; font-weight: 400; color: var(--red-deep);
  letter-spacing: 0.4px;
  line-height: 1.1; margin-top: 2px;
}

.quick-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
  padding: 0 16px;
  margin-bottom: 20px;
  animation: slideUp .5s cubic-bezier(.22,1,.36,1) .15s backwards;
}
.quick-card {
  display: flex; flex-direction: column; align-items: center; gap: 6px;
  padding: 12px 6px;
  background: var(--bg-card);
  border: 1px solid var(--line);
  border-radius: 14px;
  cursor: pointer;
  position: relative; overflow: hidden;
  transition: all .22s cubic-bezier(.22,1,.36,1);
}
.quick-card::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 2px;
  background: linear-gradient(90deg, var(--red), var(--gold), var(--red));
  opacity: 0;
  transition: opacity .22s;
}
.quick-card:active {
  transform: scale(0.93);
  background: var(--bg-raised);
  border-color: var(--gold);
}
.quick-card:active::before { opacity: 1; }
.quick-ico {
  width: 38px; height: 38px;
  border-radius: 12px;
  background: linear-gradient(135deg, var(--red), var(--red-deep));
  border: 2px solid var(--gold);
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 4px 12px rgba(200,16,46,0.32);
}
.quick-ico .ico-24 { width: 18px; height: 18px; stroke: var(--gold); }
.quick-card:nth-child(2) .quick-ico { background: linear-gradient(135deg, var(--gold-bright), var(--gold-deep)); border-color: var(--cream); box-shadow: 0 4px 12px rgba(255,199,44,0.32); }
.quick-card:nth-child(2) .quick-ico .ico-24 { stroke: var(--red-deep); }
.quick-card:nth-child(3) .quick-ico { background: linear-gradient(135deg, var(--green), #1f7a48); border-color: var(--gold); }
.quick-card:nth-child(3) .quick-ico .ico-24 { stroke: var(--cream); }
.quick-card:nth-child(4) .quick-ico { background: linear-gradient(135deg, var(--orange), #c95e00); border-color: var(--gold); }
.quick-card:nth-child(4) .quick-ico .ico-24 { stroke: var(--cream); }
.quick-lbl {
  font-size: 9px; font-weight: 900; color: var(--cream);
  letter-spacing: 0.5px; text-transform: uppercase;
  text-align: center; line-height: 1.1;
}

.promo-card {
  display: flex; align-items: stretch; gap: 0;
  margin: 18px 16px 22px;
  border-radius: var(--r-lg);
  overflow: hidden;
  background: linear-gradient(135deg, var(--gold-bright), var(--gold) 50%, var(--gold-deep));
  border: 2px solid var(--cream);
  box-shadow: 0 14px 36px rgba(255,199,44,0.30);
  cursor: pointer;
  position: relative;
  animation: slideUp .55s cubic-bezier(.22,1,.36,1) .25s backwards;
  min-height: 110px;
}
.promo-card::after {
  content: '';
  position: absolute; bottom: -30px; right: -30px;
  width: 140px; height: 140px;
  background: radial-gradient(circle, rgba(255,255,255,0.25), transparent 65%);
  pointer-events: none;
}
.promo-card:active { transform: scale(0.98); }
.promo-left {
  flex: 1;
  padding: 16px 18px;
  display: flex; flex-direction: column; justify-content: center;
  position: relative; z-index: 1;
}
.promo-tag {
  display: inline-block; align-self: flex-start;
  padding: 3px 9px;
  background: var(--red-deep);
  color: var(--gold);
  border-radius: 4px;
  font-family: 'Anton', sans-serif;
  font-size: 10px; font-weight: 400; letter-spacing: 1.4px;
  text-transform: uppercase;
  margin-bottom: 6px;
}
.promo-title {
  font-family: 'Anton', sans-serif;
  font-size: 22px; font-weight: 400; line-height: 1;
  letter-spacing: 0.4px; text-transform: uppercase;
  color: var(--red-deep);
  text-shadow: 0 1px 0 rgba(255,255,255,0.25);
}
.promo-desc {
  font-size: 11px; font-weight: 700; color: var(--red-deep);
  margin-top: 4px; opacity: .8; letter-spacing: 0.2px;
}
.promo-right {
  width: 110px;
  background: linear-gradient(135deg, var(--red), var(--red-deep));
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  border-left: 2px dashed var(--cream);
  position: relative; z-index: 1;
}
.promo-right::before, .promo-right::after {
  content: '';
  position: absolute; left: -10px;
  width: 18px; height: 18px;
  background: var(--bg);
  border-radius: 50%;
}
.promo-right::before { top: -10px; }
.promo-right::after  { bottom: -10px; }
.promo-big {
  font-family: 'Anton', sans-serif;
  font-size: 36px; font-weight: 400; letter-spacing: 1px;
  color: var(--gold);
  filter: drop-shadow(0 2px 8px rgba(255,199,44,0.4));
}
.promo-small { font-size: 9px; font-weight: 900; color: var(--cream); letter-spacing: 1.4px; text-transform: uppercase; }

.chips-row {
  display: flex; gap: 7px;
  overflow-x: auto;
  padding: 0 16px 14px;
  scrollbar-width: none;
}
.chips-row::-webkit-scrollbar { display: none; }
.chip {
  flex-shrink: 0;
  padding: 8px 16px;
  background: var(--bg-card);
  border: 1px solid var(--line);
  border-radius: 100px;
  font-family: 'Anton', sans-serif;
  font-size: 12px; font-weight: 400; letter-spacing: 0.8px;
  text-transform: uppercase;
  color: var(--cream-dim);
  cursor: pointer;
  transition: all .22s cubic-bezier(.22,1,.36,1);
  white-space: nowrap;
}
.chip:active { transform: scale(.92); }
.chip.active {
  background: linear-gradient(135deg, var(--red-bright), var(--red-deep));
  color: var(--cream);
  border-color: var(--gold);
  box-shadow: 0 0 18px rgba(200,16,46,0.42);
}
.chip-all { background: var(--bg-raised); border-color: var(--line-light); color: var(--gold); }

.sec-h2 {
  display: flex; align-items: baseline; justify-content: space-between;
  padding: 0 16px; margin-bottom: 12px;
}
.sec-h2-title {
  font-family: 'Anton', sans-serif;
  font-size: 20px; font-weight: 400;
  letter-spacing: 0.7px; text-transform: uppercase;
  color: var(--cream);
}
.sec-h2-title em {
  font-style: normal;
  background: linear-gradient(180deg, var(--gold-bright), var(--gold-deep));
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
}
.sec-h2-link {
  font-size: 10px; font-weight: 900; color: var(--gold);
  letter-spacing: 1px; text-transform: uppercase;
  cursor: pointer;
  display: inline-flex; align-items: center; gap: 2px;
}
.sec-h2-link:active { color: var(--gold-bright); }

.grid-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  padding: 0 16px;
}
.menu-card {
  display: flex; flex-direction: column;
  background: var(--bg-card);
  border: 1px solid var(--line-light);
  border-radius: var(--r);
  overflow: hidden;
  cursor: pointer;
  transition: all .22s cubic-bezier(.22,1,.36,1);
  animation: slideUp .42s cubic-bezier(.22,1,.36,1) backwards;
  position: relative;
}
.menu-card:active {
  transform: scale(0.95);
  border-color: var(--gold);
  box-shadow: 0 0 22px rgba(255,199,44,0.18);
}
.menu-thumb {
  height: 110px;
  background: linear-gradient(135deg, var(--red), var(--red-deep));
  position: relative;
  overflow: hidden;
  border-bottom: 2px solid var(--gold);
}
.menu-thumb img {
  width: 100%; height: 100%; object-fit: cover; display: block;
  transition: transform .35s cubic-bezier(.22,1,.36,1);
}
.menu-card:active .menu-thumb img { transform: scale(1.08); }
.menu-thumb::after {
  content: '';
  position: absolute; bottom: 0; left: 0; right: 0;
  height: 50%;
  background: linear-gradient(transparent, rgba(16,5,6,0.65));
}
.menu-pts-tag {
  position: absolute; top: 8px; left: 8px;
  padding: 4px 9px;
  background: var(--gold);
  color: var(--red-deep);
  border-radius: 5px;
  border: 1px solid var(--cream);
  font-family: 'Anton', sans-serif;
  font-size: 11px; font-weight: 400; letter-spacing: 0.6px;
  text-transform: uppercase;
  box-shadow: 0 2px 8px rgba(0,0,0,0.35);
  z-index: 2;
}
.menu-stk {
  position: absolute; top: 8px; right: 8px;
  width: 8px; height: 8px;
  border-radius: 50%;
  border: 2px solid var(--cream);
  z-index: 2;
}
.menu-stk.ok  { background: var(--green); box-shadow: 0 0 10px var(--green); }
.menu-stk.low { background: var(--orange); }
.menu-stk.out { background: var(--red-bright); }
.menu-body {
  padding: 11px 12px 13px;
  display: flex; flex-direction: column; gap: 4px;
}
.menu-name {
  font-family: 'Anton', sans-serif;
  font-size: 13px; font-weight: 400; letter-spacing: 0.4px;
  text-transform: uppercase;
  color: var(--cream);
  line-height: 1.15;
  height: 30px;
  overflow: hidden;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}
.menu-row {
  display: flex; align-items: center; justify-content: space-between;
  margin-top: 4px;
}
.menu-price {
  font-family: 'Anton', sans-serif;
  font-size: 17px; font-weight: 400; letter-spacing: 0.3px;
  color: var(--gold);
}
.menu-add {
  width: 28px; height: 28px;
  border-radius: 8px;
  background: linear-gradient(135deg, var(--gold-bright), var(--gold-deep));
  border: 1px solid var(--cream);
  display: flex; align-items: center; justify-content: center;
}
.menu-add .ico-24 { width: 14px; height: 14px; stroke: var(--red-deep); stroke-width: 3; }

#app-navbar.nav2 {
  padding: 0 4px var(--safe-b);
  height: calc(var(--nav-h) + var(--safe-b));
  display: grid;
  grid-template-columns: 1fr 1fr 88px 1fr 1fr;
  align-items: stretch;
  position: relative;
  overflow: hidden;
}
#app-navbar.nav2.nav2-admin {
  grid-template-columns: 1fr 1fr 80px 1fr 1fr 1fr;
}

.nav2-fab-cell {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 3px;
  height: 100%;
  cursor: pointer;
  position: relative;
  padding: 0 2px;
  transition: transform .14s;
}
.nav2-fab-cell:active { transform: scale(0.92); }
.nav2-fab-cell::before { display: none; }

.nav2-fab {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--red-bright), var(--red-deep));
  border: 2px solid var(--gold);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  box-shadow:
    0 4px 14px rgba(200,16,46,0.45),
    inset 0 1px 0 rgba(255,255,255,0.20);
  transition: transform .18s;
  position: relative;
}
.nav2-fab .ico-24,
.nav2-fab .ico-nav,
.nav2-fab svg {
  stroke: var(--gold);
  fill: var(--gold);
  width: 20px;
  height: 20px;
  filter: drop-shadow(0 0 6px rgba(255,199,44,0.45));
}

.nav2-fab::after {
  content: '';
  position: absolute;
  inset: -3px;
  border-radius: 50%;
  border: 1px solid rgba(255,199,44,0.35);
  animation: navFabPulse 2.4s ease-in-out infinite;
  pointer-events: none;
}
@keyframes navFabPulse {
  0%, 100% { opacity: 0.35; transform: scale(1); }
  50%      { opacity: 0;    transform: scale(1.18); }
}

.nav-item.nav2-fab-cell .nav2-fab-lbl {
  font-family: 'Anton', sans-serif;
  font-size: 9px;
  font-weight: 400;
  color: var(--gold);
  letter-spacing: 1px;
  text-transform: uppercase;
  white-space: nowrap;
  line-height: 1;
  text-align: center;
  padding: 0;
}

#app-navbar.nav2.nav2-admin .nav-item span,
#app-navbar.nav2.nav2-admin .nav-item.nav2-fab-cell .nav2-fab-lbl {
  font-size: 8.5px;
  letter-spacing: 0.5px;
}
#app-navbar.nav2.nav2-admin .nav2-fab {
  width: 40px;
  height: 40px;
}
#app-navbar.nav2.nav2-admin .nav2-fab .ico-24,
#app-navbar.nav2.nav2-admin .nav2-fab svg {
  width: 18px;
  height: 18px;
}

#app-navbar.nav2 .nav-item {
  padding: 4px 2px;
  gap: 4px;
  min-width: 0;
}
#app-navbar.nav2 .nav-item span {
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  padding: 0;
}

#app-navbar.nav2 .nav-item.active::before {
  bottom: 2px;
  width: 22px;
  height: 3px;
}

.amounts-row {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 8px;
  margin-bottom: 12px;
}
.amount-chip {
  padding: 11px 4px;
  background: var(--bg-card);
  border: 1px solid var(--line-light);
  border-radius: 10px;
  font-family: 'Anton', sans-serif;
  font-size: 16px; font-weight: 400;
  color: var(--cream);
  text-align: center;
  cursor: pointer;
  transition: all .2s;
}
.amount-chip:active {
  background: linear-gradient(135deg, var(--gold), var(--gold-deep));
  color: var(--red-deep);
  border-color: var(--cream);
  transform: scale(.94);
}

.timeline {
  position: relative;
  padding-left: 32px;
  margin: 0 16px;
}
.timeline::before {
  content: '';
  position: absolute; left: 12px; top: 8px; bottom: 8px;
  width: 2px;
  background: linear-gradient(180deg, var(--gold), var(--red), var(--gold));
  border-radius: 2px;
}
.tl-item {
  position: relative;
  padding: 14px 16px;
  background: var(--bg-card);
  border: 1px solid var(--line-light);
  border-radius: var(--r);
  margin-bottom: 12px;
  cursor: pointer;
  transition: all .2s cubic-bezier(.22,1,.36,1);
  animation: slideLeft .4s cubic-bezier(.22,1,.36,1) backwards;
}
.tl-item:active { transform: scale(.97) translateX(3px); border-color: var(--gold); }
.tl-item::before {
  content: '';
  position: absolute;
  left: -27px; top: 18px;
  width: 14px; height: 14px;
  border-radius: 50%;
  background: var(--bg);
  border: 3px solid var(--gold);
  box-shadow: 0 0 14px var(--gold-glow);
  z-index: 1;
}
.tl-item.tl-done::before    { border-color: var(--green); box-shadow: 0 0 12px rgba(43,168,98,0.45); }
.tl-item.tl-fail::before    { border-color: var(--red-bright); box-shadow: 0 0 12px rgba(200,16,46,0.45); }
.tl-item.tl-pending::before { border-color: var(--orange); animation: dotBlink 1.4s ease infinite; }

.tl-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 6px; gap: 10px; }
.tl-name {
  font-family: 'Anton', sans-serif;
  font-size: 14px; font-weight: 400; letter-spacing: 0.4px;
  text-transform: uppercase;
  color: var(--cream);
  flex: 1; min-width: 0;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.tl-status {
  font-size: 9px; font-weight: 900; padding: 3px 9px;
  border-radius: 4px; letter-spacing: 0.5px; text-transform: uppercase;
  border: 1px solid transparent;
  flex-shrink: 0;
}
.tl-status.done { background: rgba(43,168,98,0.10); color: var(--green); border-color: rgba(43,168,98,0.26); }
.tl-status.fail { background: rgba(200,16,46,0.10); color: var(--red-bright); border-color: rgba(200,16,46,0.26); }
.tl-status.pending { background: rgba(255,138,31,0.10); color: var(--orange); border-color: rgba(255,138,31,0.24); }
.tl-meta { font-size: 10px; font-weight: 700; color: var(--cream-dim); letter-spacing: 0.3px; }

.prof-hero {
  display: flex; align-items: center; gap: 16px;
  padding: 14px 18px;
  margin: 0 16px 22px;
  background: linear-gradient(135deg, var(--red), var(--red-deep));
  border: 2px solid var(--gold);
  border-radius: var(--r-lg);
  box-shadow: 0 10px 28px rgba(200,16,46,0.30);
  position: relative;
  overflow: hidden;
  animation: slideUp .5s cubic-bezier(.22,1,.36,1);
}
.prof-hero::after {
  content: 'M';
  position: absolute;
  bottom: -50px; right: -10px;
  font-family: 'Anton', sans-serif;
  font-size: 180px; font-weight: 400;
  color: rgba(255,199,44,0.07);
  line-height: 1; pointer-events: none;
}
.prof-hero-av {
  width: 78px; height: 78px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--gold), var(--gold-deep));
  border: 3px solid var(--cream);
  display: flex; align-items: center; justify-content: center;
  font-family: 'Anton', sans-serif;
  font-size: 32px; color: var(--red-deep);
  overflow: hidden;
  flex-shrink: 0;
  box-shadow: 0 6px 18px rgba(255,199,44,0.32);
  position: relative; z-index: 1;
}
.prof-hero-av .avatar-img { width: 100%; height: 100%; object-fit: cover; border-radius: 50%; }
.prof-hero-info { flex: 1; min-width: 0; position: relative; z-index: 1; }
.prof-hero-name {
  font-family: 'Anton', sans-serif;
  font-size: 22px; font-weight: 400; letter-spacing: 0.6px;
  text-transform: uppercase;
  color: var(--cream);
  line-height: 1.05;
}
.prof-hero-tag {
  font-size: 10px; font-weight: 800; color: var(--gold);
  letter-spacing: 1.5px; text-transform: uppercase;
  margin-top: 4px;
}
.prof-hero-bal {
  margin-top: 8px;
  display: inline-flex; align-items: baseline; gap: 4px;
  padding: 5px 10px;
  background: var(--gold);
  color: var(--red-deep);
  border-radius: 6px;
  border: 1px solid var(--cream);
  font-family: 'Anton', sans-serif;
  font-size: 14px; letter-spacing: 0.4px;
  box-shadow: 0 3px 10px rgba(255,199,44,0.25);
}

.svc-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  padding: 0 16px;
  margin-bottom: 18px;
}
.svc-card {
  display: flex; flex-direction: column; gap: 8px;
  padding: 16px;
  background: var(--bg-card);
  border: 1px solid var(--line);
  border-radius: var(--r);
  cursor: pointer;
  position: relative; overflow: hidden;
  transition: all .22s cubic-bezier(.22,1,.36,1);
  animation: popIn .4s cubic-bezier(.22,1,.36,1) backwards;
  min-height: 96px;
}
.svc-card:nth-child(1) { animation-delay: .04s; }
.svc-card:nth-child(2) { animation-delay: .08s; }
.svc-card:nth-child(3) { animation-delay: .12s; }
.svc-card:nth-child(4) { animation-delay: .16s; }
.svc-card:active {
  transform: scale(.96);
  background: var(--bg-raised);
  border-color: var(--gold);
}
.svc-card::before {
  content: '';
  position: absolute; top: 0; left: 0; bottom: 0;
  width: 3px;
  background: linear-gradient(180deg, var(--gold), var(--red));
  opacity: 0;
  transition: opacity .22s;
}
.svc-card:active::before { opacity: 1; }
.svc-card-ico {
  width: 36px; height: 36px;
  border-radius: 10px;
  background: var(--bg-raised);
  border: 1px solid var(--line-light);
  display: flex; align-items: center; justify-content: center;
}
.svc-card-ico .ico-24 { width: 18px; height: 18px; stroke: var(--gold); }
.svc-card-name {
  font-family: 'Anton', sans-serif;
  font-size: 13px; font-weight: 400; letter-spacing: 0.4px;
  text-transform: uppercase;
  color: var(--cream); line-height: 1.1;
}
.svc-card-desc {
  font-size: 10px; font-weight: 700; color: var(--cream-dim);
  letter-spacing: 0.2px;
  margin-top: -2px;
}
.svc-card-danger { border-color: rgba(200,16,46,0.22); }
.svc-card-danger .svc-card-ico { background: rgba(200,16,46,0.10); border-color: rgba(200,16,46,0.26); }
.svc-card-danger .svc-card-ico .ico-24 { stroke: var(--red-bright); }
.svc-card-danger .svc-card-name { color: var(--red-bright); }

.gift-banner {
  display: flex; align-items: center; gap: 14px;
  margin: 8px 16px 18px;
  padding: 12px 16px;
  background: linear-gradient(135deg, var(--green) 0%, #1f7a48 100%);
  border: 2px solid var(--gold);
  border-radius: var(--r-lg);
  box-shadow: 0 8px 22px rgba(43,168,98,0.30);
  cursor: pointer;
  transition: transform .18s;
  position: relative; overflow: hidden;
  animation: slideUp .45s cubic-bezier(.22,1,.36,1);
}
.gift-banner::after {
  content: '';
  position: absolute; inset: 0;
  background: repeating-linear-gradient(135deg, transparent, transparent 18px, rgba(255,255,255,0.04) 18px, rgba(255,255,255,0.04) 22px);
  pointer-events: none;
}
.gift-banner:active { transform: scale(.98); }
.gift-banner-pct {
  font-family: 'Anton', sans-serif;
  font-size: 32px; font-weight: 400;
  color: var(--gold);
  line-height: 1;
  text-shadow: 0 2px 8px rgba(0,0,0,0.4);
  flex-shrink: 0;
}
.gift-banner-text { flex: 1; min-width: 0; position: relative; z-index: 1; }
.gift-banner-title {
  font-family: 'Anton', sans-serif;
  font-size: 14px; font-weight: 400; letter-spacing: 0.5px;
  text-transform: uppercase;
  color: var(--cream);
}
.gift-banner-title span {
  background: var(--gold);
  color: var(--red-deep);
  padding: 1px 6px;
  border-radius: 4px;
  margin-left: 4px;
  font-family: 'Anton', sans-serif;
  letter-spacing: 1px;
}
.gift-banner-sub {
  font-size: 10px; font-weight: 700;
  color: var(--cream); opacity: .85;
  margin-top: 3px;
}

.menu-disc-tag {
  position: absolute; top: 8px; right: 24px;
  padding: 3px 8px;
  background: linear-gradient(135deg, var(--green), #1f7a48);
  color: var(--cream);
  border: 1px solid var(--gold);
  border-radius: 5px;
  font-family: 'Anton', sans-serif;
  font-size: 10px; font-weight: 400; letter-spacing: 0.5px;
  text-transform: uppercase;
  box-shadow: 0 2px 8px rgba(43,168,98,0.32);
  z-index: 2;
}

.menu-price-wrap {
  display: flex; flex-direction: column; align-items: flex-start; gap: 0;
  line-height: 1;
}
.menu-price-old {
  font-size: 10px; font-weight: 800;
  color: var(--cream-dim);
  text-decoration: line-through;
  opacity: .65;
  letter-spacing: 0.2px;
}
.menu-price-new {
  color: var(--green) !important;
  font-size: 17px;
  filter: drop-shadow(0 0 4px rgba(43,168,98,0.4));
}

.det-price-old {
  display: inline-block;
  font-size: 18px; font-weight: 700;
  color: var(--cream-dim);
  text-decoration: line-through;
  margin-right: 8px;
  opacity: .55;
  letter-spacing: 0.2px;
}
.det-disc-tag {
  display: inline-block;
  padding: 3px 9px;
  background: linear-gradient(135deg, var(--green), #1f7a48);
  color: var(--cream);
  border: 1px solid var(--gold);
  border-radius: 5px;
  font-family: 'Anton', sans-serif;
  font-size: 11px; font-weight: 400; letter-spacing: 0.5px;
  text-transform: uppercase;
  margin-left: 10px;
  vertical-align: middle;
  box-shadow: 0 2px 8px rgba(43,168,98,0.30);
}

.gift-form {
  padding: 16px;
  background: var(--bg-card);
  border: 1px solid var(--line-light);
  border-radius: var(--r);
  margin-bottom: 4px;
}
.gift-form-head {
  display: flex; align-items: center; gap: 12px;
  margin-bottom: 14px;
}
.gift-form-text { flex: 1; min-width: 0; }
.gift-input-group { margin: 0 0 10px; }
.gift-input {
  text-transform: uppercase;
  letter-spacing: 1px;
  font-weight: 700;
}
.gift-redeem-btn {
  width: 100%;
  padding: 14px;
  font-size: 14px;
  letter-spacing: 1.4px;
}
.gift-result-zone { margin-top: 10px; }
.gift-form-ico {
  width: 40px; height: 40px;
  border-radius: 12px;
  background: linear-gradient(135deg, var(--gold), var(--gold-deep));
  border: 2px solid var(--cream);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  box-shadow: 0 4px 12px rgba(255,199,44,0.30);
}
.gift-form-ico .ico-24 { width: 18px; height: 18px; stroke: var(--red-deep); fill: var(--red-deep); }
.gift-form-title {
  font-family: 'Anton', sans-serif;
  font-size: 14px; font-weight: 400; letter-spacing: 0.4px;
  text-transform: uppercase;
  color: var(--cream);
  line-height: 1.1;
}
.gift-form-sub {
  font-size: 10px; font-weight: 700;
  color: var(--cream-dim);
  margin-top: 2px;
}

.gift-active {
  display: flex; align-items: center; gap: 14px;
  padding: 14px 16px;
  background: linear-gradient(135deg, rgba(43,168,98,0.12), rgba(31,122,72,0.08));
  border: 2px solid var(--green);
  border-radius: var(--r);
  position: relative;
  overflow: hidden;
  animation: popIn .45s cubic-bezier(.22,1,.36,1);
}
.gift-active::before {
  content: '';
  position: absolute; top: 0; left: 0; bottom: 0;
  width: 4px;
  background: linear-gradient(180deg, var(--green), var(--gold));
}
.gift-active-pct {
  font-family: 'Anton', sans-serif;
  font-size: 32px; font-weight: 400;
  color: var(--green);
  line-height: 1;
  filter: drop-shadow(0 0 8px rgba(43,168,98,0.42));
  flex-shrink: 0;
}
.gift-active-info { flex: 1; min-width: 0; }
.gift-active-title {
  font-family: 'Anton', sans-serif;
  font-size: 13px; font-weight: 400;
  color: var(--green);
  letter-spacing: 0.5px; text-transform: uppercase;
}
.gift-active-code {
  font-family: 'Anton', sans-serif;
  font-size: 18px; font-weight: 400;
  color: var(--cream);
  letter-spacing: 1.4px;
  margin: 2px 0 4px;
  word-break: break-all;
}
.gift-active-desc {
  font-size: 10px; font-weight: 700;
  color: var(--cream-dim);
  letter-spacing: 0.1px;
}
.gift-active-x {
  width: 28px; height: 28px;
  border-radius: 50%;
  background: rgba(200,16,46,0.16);
  border: 1px solid rgba(200,16,46,0.32);
  color: var(--red-bright);
  font-size: 14px; font-weight: 900;
  cursor: pointer;
  flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  padding: 0;
  transition: all .18s;
}
.gift-active-x:active { transform: scale(.85); background: var(--red-bright); color: var(--cream); }

.promo-list {
  display: flex; flex-direction: column; gap: 8px;
}
.promo-row {
  padding: 12px 14px;
  background: var(--bg-card);
  border: 1px solid var(--line-light);
  border-radius: var(--r);
  display: flex; flex-direction: column; gap: 6px;
}
.promo-row-main {
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
}
.promo-row-code {
  font-family: 'Anton', sans-serif;
  font-size: 16px; font-weight: 400; letter-spacing: 1.6px;
  color: var(--gold);
  cursor: pointer;
  text-transform: uppercase;
  user-select: all;
}
.promo-row-code:active { color: var(--gold-bright); }
.promo-row-pct {
  font-family: 'Anton', sans-serif;
  font-size: 18px; font-weight: 400; letter-spacing: 0.5px;
  color: var(--green);
}
.promo-row-meta {
  display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
  font-size: 10px; color: var(--cream-dim);
}
.promo-saved {
  font-size: 11px; color: var(--green); font-weight: 800;
  letter-spacing: 0.1px;
}
.promo-owner {
  font-size: 10px; font-weight: 700; color: var(--cream);
}
.promo-row-revoke {
  align-self: flex-end;
  padding: 5px 12px;
  background: transparent;
  border: 1px solid rgba(200,16,46,0.32);
  border-radius: 6px;
  color: var(--red-bright);
  font-size: 10px; font-weight: 800;
  letter-spacing: 0.5px; text-transform: uppercase;
  cursor: pointer;
  transition: all .18s;
}
.promo-row-revoke:active {
  background: var(--red-bright);
  color: var(--cream);
  transform: scale(.93);
}

.promo-badge {
  padding: 2px 7px;
  border-radius: 4px;
  font-size: 9px; font-weight: 900;
  letter-spacing: 0.5px; text-transform: uppercase;
  border: 1px solid transparent;
}
.promo-badge-free     { background: rgba(255,199,44,0.10); color: var(--gold); border-color: rgba(255,199,44,0.30); }
.promo-badge-used     { background: rgba(255,138,31,0.10); color: var(--orange); border-color: rgba(255,138,31,0.26); }
.promo-badge-consumed { background: rgba(43,168,98,0.10); color: var(--green); border-color: rgba(43,168,98,0.30); }
.promo-badge-revoked  { background: rgba(200,16,46,0.10); color: var(--red-bright); border-color: rgba(200,16,46,0.30); }

.promo-result-code {
  display: inline-block;
  margin: 4px 4px 0 0;
  padding: 3px 8px;
  background: var(--bg-raised);
  border: 1px solid var(--gold);
  border-radius: 4px;
  font-family: 'Anton', sans-serif;
  font-size: 12px; letter-spacing: 1px;
  color: var(--gold);
  cursor: pointer;
  user-select: all;
}
.promo-result-code:active { background: var(--gold); color: var(--red-deep); }

.wel-overlay {
  position: fixed; inset: 0;
  background: rgba(0, 0, 0, 0.78);
  backdrop-filter: blur(8px) saturate(140%);
  -webkit-backdrop-filter: blur(8px) saturate(140%);
  z-index: 9999;
  display: flex; align-items: flex-end; justify-content: center;
  opacity: 0;
  transition: opacity .3s cubic-bezier(.22,1,.36,1);
  padding: 0;
}
.wel-overlay.wel-visible { opacity: 1; }
.wel-overlay.wel-leaving { opacity: 0; }

.wel-card {
  width: 100%; max-width: 540px;
  max-height: 92vh;
  overflow-y: auto;
  background: linear-gradient(180deg, #1A0809 0%, var(--bg) 100%);
  border-top: 3px solid var(--gold);
  border-radius: 24px 24px 0 0;
  padding: 28px 22px 22px;
  position: relative;
  transform: translateY(100%);
  transition: transform .42s cubic-bezier(.22,1,.36,1);
  box-shadow: 0 -20px 60px rgba(0,0,0,0.5);
}
.wel-overlay.wel-visible .wel-card { transform: translateY(0); }
.wel-overlay.wel-leaving .wel-card { transform: translateY(40%); }

.wel-card::-webkit-scrollbar { width: 0; }
.wel-card { scrollbar-width: none; }

.wel-card::before {
  content: '';
  position: absolute;
  top: 8px; left: 50%; transform: translateX(-50%);
  width: 38px; height: 4px;
  border-radius: 4px;
  background: rgba(255, 199, 44, 0.35);
}

.wel-arches {
  display: flex; justify-content: center;
  margin: 4px 0 14px;
}
.wel-arches img {
  width: 92px; height: 78px;
  object-fit: contain;
  filter: drop-shadow(0 6px 22px rgba(255, 199, 44, 0.45));
  animation: welBounce 1.1s cubic-bezier(.22,1,.36,1) backwards;
}
@keyframes welBounce {
  0%   { transform: translateY(-30px) scale(0.6); opacity: 0; }
  60%  { transform: translateY(8px) scale(1.08); opacity: 1; }
  100% { transform: translateY(0) scale(1); opacity: 1; }
}

.wel-title {
  font-family: 'Anton', sans-serif;
  font-size: 22px; font-weight: 400; letter-spacing: 0.5px;
  text-transform: uppercase;
  color: var(--cream);
  text-align: center;
  line-height: 1.1;
  margin-bottom: 6px;
}
.wel-sub {
  font-size: 12px; font-weight: 700;
  color: var(--cream-dim);
  text-align: center;
  letter-spacing: 0.2px;
  margin-bottom: 22px;
  padding: 0 4px;
}

.wel-list {
  list-style: none;
  padding: 0; margin: 0 0 22px;
  display: flex; flex-direction: column; gap: 10px;
}
.wel-item {
  display: flex; align-items: flex-start; gap: 12px;
  padding: 13px 14px;
  background: var(--bg-card);
  border: 1px solid var(--line-light);
  border-radius: 14px;
  animation: welItemIn .42s cubic-bezier(.22,1,.36,1) backwards;
}
.wel-item:nth-child(1) { animation-delay: .12s; }
.wel-item:nth-child(2) { animation-delay: .20s; }
.wel-item:nth-child(3) { animation-delay: .28s; }
.wel-item:nth-child(4) { animation-delay: .36s; }
@keyframes welItemIn {
  from { opacity: 0; transform: translateY(14px); }
  to   { opacity: 1; transform: translateY(0); }
}

.wel-ico {
  width: 38px; height: 38px;
  border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  border: 1px solid transparent;
}
.wel-ico svg { width: 18px; height: 18px; }
.wel-ico-orange { background: rgba(255,138,31,0.12); border-color: rgba(255,138,31,0.32); color: var(--orange); }
.wel-ico-gold   { background: rgba(255,199,44,0.12); border-color: rgba(255,199,44,0.32); color: var(--gold); }
.wel-ico-red    { background: rgba(200,16,46,0.14);  border-color: rgba(200,16,46,0.34);  color: var(--red-bright); }
.wel-ico-green  { background: rgba(43,168,98,0.14);  border-color: rgba(43,168,98,0.32);  color: var(--green); }

.wel-text { flex: 1; min-width: 0; }
.wel-txt-title {
  font-family: 'Anton', sans-serif;
  font-size: 13px; font-weight: 400; letter-spacing: 0.4px;
  text-transform: uppercase;
  color: var(--cream);
  margin-bottom: 3px;
  line-height: 1.15;
}
.wel-txt-desc {
  font-size: 12px; font-weight: 600; line-height: 1.45;
  color: var(--cream-dim);
}
.wel-txt-desc b {
  color: var(--cream); font-weight: 800;
}

.wel-cta {
  display: block;
  width: 100%;
  padding: 16px 18px;
  background: linear-gradient(135deg, var(--gold-bright), var(--gold) 50%, var(--gold-deep));
  border: 2px solid var(--cream);
  border-radius: 14px;
  color: var(--red-deep);
  font-family: 'Anton', sans-serif;
  font-size: 16px; font-weight: 400; letter-spacing: 1px;
  text-transform: uppercase;
  cursor: pointer;
  box-shadow: 0 8px 24px rgba(255, 199, 44, 0.36);
  transition: all .18s cubic-bezier(.22,1,.36,1);
  animation: welItemIn .45s cubic-bezier(.22,1,.36,1) .44s backwards;
}
.wel-cta:active {
  transform: scale(0.97);
  box-shadow: 0 4px 14px rgba(255, 199, 44, 0.30);
}

.wel-foot {
  text-align: center;
  margin-top: 12px;
  font-size: 9px; font-weight: 800;
  color: var(--cream-dim);
  letter-spacing: 1.4px; text-transform: uppercase;
  opacity: .55;
}

@supports (padding-bottom: env(safe-area-inset-bottom)) {
  .wel-card { padding-bottom: calc(22px + env(safe-area-inset-bottom)); }
}
