/* ══════════════════════════════════════════
   MEGA ARENA GAMER – STYLESHEET
   ══════════════════════════════════════════ */

:root {
  --bg-dark:      #060610;
  --bg-card:      #0d0d22;
  --bg-card2:     #12122a;
  --neon-purple:  #9d4edd;
  --neon-blue:    #00c8ff;
  --neon-green:   #39ff14;
  --neon-pink:    #ff006e;
  --neon-orange:  #ff7b00;
  --text-main:    #e8e8ff;
  --text-muted:   #8888bb;
  --border:       rgba(157,78,221,.25);
  --glow-purple:  0 0 20px rgba(157,78,221,.6), 0 0 40px rgba(157,78,221,.3);
  --glow-blue:    0 0 20px rgba(0,200,255,.6), 0 0 40px rgba(0,200,255,.3);
  --glow-pink:    0 0 20px rgba(255,0,110,.6), 0 0 40px rgba(255,0,110,.3);
  --glow-green:   0 0 20px rgba(57,255,20,.6);
}

/* ─── RESET ─────────────────────────────── */
*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }
/* Garante que o atributo HTML hidden sempre esconda o elemento */
[hidden] { display: none !important; }
body {
  font-family: 'Rajdhani', sans-serif;
  background: var(--bg-dark);
  color: var(--text-main);
  overflow-x: hidden;
}
a { text-decoration: none; color: inherit; }
ul { list-style: none; }
img { max-width: 100%; }

/* ─── SCROLLBAR ──────────────────────────── */
::-webkit-scrollbar { width: 6px; }
::-webkit-scrollbar-track { background: var(--bg-dark); }
::-webkit-scrollbar-thumb { background: var(--neon-purple); border-radius: 3px; }

/* ─── PARTÍCULAS ─────────────────────────── */
.particles {
  position: fixed; inset: 0; pointer-events: none; z-index: 0; overflow: hidden;
}
.particle {
  position: absolute; border-radius: 50%;
  animation: float linear infinite;
  opacity: 0;
}
@keyframes float {
  0%   { transform: translateY(100vh) scale(0); opacity: 0; }
  10%  { opacity: .7; }
  90%  { opacity: .4; }
  100% { transform: translateY(-10vh) scale(1); opacity: 0; }
}

/* ─── NAVBAR ─────────────────────────────── */
.navbar {
  position: fixed; top: 0; left: 0; right: 0; z-index: 1000;
  background: rgba(6,6,16,.85);
  backdrop-filter: blur(16px);
  border-bottom: 1px solid var(--border);
  transition: all .3s;
}
.navbar.scrolled {
  background: rgba(6,6,16,.98);
  box-shadow: 0 4px 30px rgba(157,78,221,.2);
}
.nav-container {
  max-width: 1280px; margin: 0 auto; padding: 0 24px;
  display: flex; align-items: center; justify-content: space-between;
  height: 70px;
}
.logo { display: flex; align-items: center; gap: 10px; }
.logo-icon {
  width: 40px; height: 40px;
  background: linear-gradient(135deg, var(--neon-purple), var(--neon-blue));
  border-radius: 10px;
  display: grid; place-items: center;
  font-size: 18px;
  box-shadow: var(--glow-purple);
}
.logo-text {
  font-family: 'Orbitron', sans-serif;
  font-weight: 900; font-size: 16px;
  letter-spacing: 2px;
}
.logo-highlight { color: var(--neon-purple); }
.nav-links {
  display: flex; gap: 32px;
}
.nav-links a {
  font-size: 15px; font-weight: 600; letter-spacing: 1px;
  color: var(--text-muted);
  transition: color .3s;
  position: relative;
}
.nav-links a::after {
  content: ''; position: absolute; bottom: -4px; left: 0; right: 0;
  height: 2px; background: var(--neon-purple);
  transform: scaleX(0); transition: transform .3s;
}
.nav-links a:hover { color: var(--text-main); }
.nav-links a:hover::after { transform: scaleX(1); }

.nav-actions { display: flex; align-items: center; gap: 12px; }
.btn-cart {
  position: relative; background: transparent; border: 1px solid var(--border);
  color: var(--text-main); padding: 8px 14px; border-radius: 8px;
  font-size: 18px; cursor: pointer; transition: all .3s;
}
.btn-cart:hover { border-color: var(--neon-purple); box-shadow: var(--glow-purple); }
.cart-count {
  position: absolute; top: -6px; right: -6px;
  background: var(--neon-pink); color: #fff;
  font-size: 11px; font-weight: 700;
  width: 18px; height: 18px; border-radius: 50%;
  display: grid; place-items: center;
}
.btn-menu {
  display: none; background: none; border: none;
  color: var(--text-main); font-size: 22px; cursor: pointer;
}

/* ─── BOTÕES GERAIS ──────────────────────── */
.btn-primary {
  display: inline-flex; align-items: center; gap: 8px;
  background: linear-gradient(135deg, var(--neon-purple), #6a1fd0);
  color: #fff; border: none;
  padding: 13px 28px; border-radius: 10px;
  font-family: 'Rajdhani', sans-serif;
  font-size: 15px; font-weight: 700; letter-spacing: 1px;
  cursor: pointer; transition: all .3s;
  box-shadow: var(--glow-purple);
}
.btn-primary:hover {
  transform: translateY(-2px);
  box-shadow: 0 0 30px rgba(157,78,221,.8), 0 0 60px rgba(157,78,221,.4);
}
.btn-secondary {
  display: inline-flex; align-items: center; gap: 8px;
  background: transparent; color: var(--neon-blue);
  border: 2px solid var(--neon-blue);
  padding: 11px 26px; border-radius: 10px;
  font-family: 'Rajdhani', sans-serif;
  font-size: 15px; font-weight: 700; letter-spacing: 1px;
  cursor: pointer; transition: all .3s;
}
.btn-secondary:hover {
  background: rgba(0,200,255,.1);
  box-shadow: var(--glow-blue); transform: translateY(-2px);
}

/* ─── HERO ───────────────────────────────── */
.hero {
  min-height: 42vh; position: relative;
  display: flex; align-items: center;
  padding: 134px 24px 10px;
  overflow: hidden;
}
.hero-bg-video {
  position: absolute; inset: 0; z-index: 0;
}
.hero-grid {
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(157,78,221,.08) 1px, transparent 1px),
    linear-gradient(90deg, rgba(157,78,221,.08) 1px, transparent 1px);
  background-size: 50px 50px;
  animation: gridMove 20s linear infinite;
}
@keyframes gridMove { from { transform: translateY(0); } to { transform: translateY(50px); } }

.hero::before {
  content: '';
  position: absolute; inset: 0; z-index: 1;
  background:
    radial-gradient(ellipse 60% 60% at 30% 50%, rgba(157,78,221,.15) 0%, transparent 70%),
    radial-gradient(ellipse 40% 40% at 70% 30%, rgba(0,200,255,.1) 0%, transparent 60%);
}
.hero-content {
  position: relative; z-index: 2;
  max-width: 1280px; margin: 0 auto; flex: 1;
}
.hero-badge {
  display: inline-flex; align-items: center; gap: 6px;
  background: rgba(157,78,221,.15);
  border: 1px solid rgba(157,78,221,.4);
  color: var(--neon-purple);
  padding: 8px 16px 7px; border-radius: 100px;
  font-size: 13px; font-weight: 700; letter-spacing: 2px;
  margin-bottom: 24px;
  line-height: 1.2;
  animation: fadeDown .8s ease both;
}
.hero-title {
  font-family: 'Orbitron', sans-serif;
  font-weight: 900; line-height: 1.06;
  margin-bottom: 20px;
}
.hero-title .line1 { display: block; font-size: clamp(52px,8vw,96px); color: var(--text-main); animation: fadeLeft .8s .1s ease both; }
.hero-title .line2 { display: block; font-size: clamp(52px,8vw,96px); color: var(--neon-purple); text-shadow: var(--glow-purple); animation: fadeLeft .8s .2s ease both; }
.hero-title .line3 { display: block; font-size: clamp(52px,8vw,96px);
  background: linear-gradient(90deg, var(--neon-blue), var(--neon-green));
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  animation: fadeLeft .8s .3s ease both;
}
.hero-sub {
  font-size: 18px; font-weight: 600; color: var(--text-muted);
  letter-spacing: 2px; margin-bottom: 16px;
  animation: fadeLeft .8s .4s ease both;
}
.hero-desc {
  font-size: 17px; color: var(--text-muted); max-width: 520px;
  line-height: 1.6; margin-bottom: 32px;
  animation: fadeLeft .8s .5s ease both;
}
.hero-btns {
  display: flex; gap: 16px; flex-wrap: wrap; margin-bottom: 48px;
  animation: fadeLeft .8s .6s ease both;
}
.hero-stats {
  display: flex; gap: 40px; flex-wrap: wrap;
  animation: fadeLeft .8s .7s ease both;
}
.stat { text-align: left; }
.stat-num {
  display: block;
  font-family: 'Orbitron', sans-serif;
  font-size: 32px; font-weight: 900;
  color: var(--neon-purple); text-shadow: var(--glow-purple);
}
.stat-label { font-size: 13px; color: var(--text-muted); letter-spacing: 1px; }

/* Hero image */
.hero-image {
  position: absolute; right: 5%; top: 50%; transform: translateY(-50%);
  z-index: 2; display: flex; align-items: center; justify-content: center;
}
.controller-wrap {
  position: relative; width: 320px; height: 320px;
  display: grid; place-items: center;
}
.controller-icon {
  font-size: 100px; color: var(--neon-purple); z-index: 2;
  text-shadow: var(--glow-purple);
  animation: pulse 3s ease-in-out infinite;
}
.glow-ring {
  position: absolute; inset: 20px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(157,78,221,.2), transparent 70%);
  animation: pulse 3s ease-in-out infinite;
}
@keyframes pulse {
  0%, 100% { transform: scale(1); }
  50% { transform: scale(1.08); }
}
.orbit {
  position: absolute; border-radius: 50%; border: 1px solid;
  display: grid; place-items: start;
}
.orbit1 { width: 200px; height: 200px; border-color: rgba(157,78,221,.4); animation: spin1 6s linear infinite; }
.orbit2 { width: 270px; height: 270px; border-color: rgba(0,200,255,.3); animation: spin1 10s linear infinite reverse; }
.orbit3 { width: 310px; height: 310px; border-color: rgba(57,255,20,.2); animation: spin1 14s linear infinite; }
@keyframes spin1 { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }
.orbit-dot {
  width: 10px; height: 10px; border-radius: 50%;
  background: var(--neon-purple);
  box-shadow: var(--glow-purple);
  margin: -5px;
}
.orbit2 .orbit-dot { background: var(--neon-blue); box-shadow: var(--glow-blue); }
.orbit3 .orbit-dot { background: var(--neon-green); box-shadow: var(--glow-green); }

.scroll-indicator {
  position: absolute; bottom: 30px; left: 50%; transform: translateX(-50%);
  z-index: 3;
}
.scroll-arrow {
  width: 24px; height: 24px;
  border-right: 2px solid var(--neon-purple);
  border-bottom: 2px solid var(--neon-purple);
  transform: rotate(45deg);
  animation: scrollBounce 1.5s ease-in-out infinite;
}
@keyframes scrollBounce { 0%,100%{transform:rotate(45deg) translateY(0);} 50%{transform:rotate(45deg) translateY(6px);} }

/* ─── SECTION COMMON ─────────────────────── */
section {
  position: relative; z-index: 1;
  padding: 80px 24px;
}
.section-header { text-align: center; margin-bottom: 56px; }
.section-tag {
  display: inline-flex; align-items: center; gap: 6px;
  background: rgba(157,78,221,.12);
  border: 1px solid rgba(157,78,221,.3);
  color: var(--neon-purple);
  padding: 5px 16px; border-radius: 100px;
  font-size: 12px; font-weight: 700; letter-spacing: 2px;
  margin-bottom: 16px;
}
.section-header h2 {
  font-family: 'Orbitron', sans-serif;
  font-size: clamp(28px,5vw,48px); font-weight: 900;
  margin-bottom: 12px;
}
.highlight { color: var(--neon-purple); text-shadow: var(--glow-purple); }
.section-header p { font-size: 17px; color: var(--text-muted); }

/* ─── PLATAFORMAS ────────────────────────── */
.plataformas { background: linear-gradient(180deg, var(--bg-dark), #0a0a1a); }
.plataformas-grid {
  max-width: 1280px; margin: 0 auto;
  display: grid; grid-template-columns: repeat(auto-fit, minmax(250px,1fr)); gap: 24px;
}
.plat-card {
  position: relative; overflow: hidden;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 20px;
  padding: 32px 24px; text-align: center;
  cursor: pointer;
  transition: transform .35s, box-shadow .35s, border-color .35s;
}
.plat-card:hover { transform: translateY(-8px); }
.plat-glow {
  position: absolute; inset: 0; border-radius: 20px;
  opacity: 0; transition: opacity .35s;
}
.plat-card.pc:hover { border-color: var(--neon-blue); box-shadow: 0 20px 50px rgba(0,200,255,.25); }
.plat-card.pc .plat-glow { background: radial-gradient(circle at top, rgba(0,200,255,.1), transparent 70%); }
.plat-card.pc:hover .plat-glow { opacity: 1; }
.plat-card.ps5:hover { border-color: #003791; box-shadow: 0 20px 50px rgba(0,55,145,.4); }
.plat-card.ps5 .plat-glow { background: radial-gradient(circle at top, rgba(0,55,145,.2), transparent 70%); }
.plat-card.ps5:hover .plat-glow { opacity: 1; }
.plat-card.xbox:hover { border-color: #107c10; box-shadow: 0 20px 50px rgba(16,124,16,.35); }
.plat-card.xbox .plat-glow { background: radial-gradient(circle at top, rgba(16,124,16,.15), transparent 70%); }
.plat-card.xbox:hover .plat-glow { opacity: 1; }
.plat-card.nintendo:hover { border-color: var(--neon-pink); box-shadow: 0 20px 50px rgba(255,0,110,.25); }
.plat-card.nintendo .plat-glow { background: radial-gradient(circle at top, rgba(255,0,110,.1), transparent 70%); }
.plat-card.nintendo:hover .plat-glow { opacity: 1; }
.plat-card.iphone:hover { border-color: #c0c0c0; box-shadow: 0 20px 50px rgba(192,192,192,.2); }
.plat-card.iphone .plat-glow { background: radial-gradient(circle at top, rgba(200,200,200,.08), transparent 70%); }
.plat-card.iphone:hover .plat-glow { opacity: 1; }

.plat-icon {
  width: 72px; height: 72px; border-radius: 20px;
  display: grid; place-items: center;
  font-size: 32px; margin: 0 auto 20px;
}
.plat-icon svg {
  width: 38px;
  height: 38px;
  display: block;
}
.plat-card.pc .plat-icon    { background: rgba(0,200,255,.15); color: var(--neon-blue); }
.plat-card.ps5 .plat-icon   { background: rgba(0,55,145,.2);   color: #4e8fff; }
.plat-card.xbox .plat-icon  { background: rgba(16,124,16,.2);  color: #5dc55d; }
.plat-card.nintendo .plat-icon { background: rgba(255,0,110,.1); color: var(--neon-pink); }
.plat-card.iphone .plat-icon  { background: rgba(200,200,200,.1); color: #d0d0d0; }

.plat-card h3 {
  font-family: 'Orbitron', sans-serif;
  font-size: 20px; font-weight: 700; margin-bottom: 12px;
}
.plat-card p { font-size: 14px; color: var(--text-muted); line-height: 1.6; margin-bottom: 16px; }
.plat-tags { display: flex; flex-wrap: wrap; gap: 6px; justify-content: center; margin-bottom: 16px; }
.plat-tags span {
  background: rgba(157,78,221,.1); border: 1px solid rgba(157,78,221,.2);
  color: var(--neon-purple); padding: 3px 10px;
  border-radius: 100px; font-size: 11px; font-weight: 600; letter-spacing: 1px;
}
.plat-count {
  color: var(--text-muted); font-size: 14px; margin-bottom: 20px;
}
.plat-btn {
  background: transparent; border: 1px solid var(--border);
  color: var(--text-main); padding: 10px 20px; border-radius: 8px;
  font-family: 'Rajdhani', sans-serif; font-size: 14px; font-weight: 600;
  cursor: pointer; transition: all .3s;
  display: inline-flex; align-items: center; gap: 6px;
}
.plat-btn:hover { border-color: var(--neon-purple); color: var(--neon-purple); }

/* ─── FILTROS ────────────────────────────── */
.filtros {
  display: flex; flex-wrap: wrap; gap: 10px; justify-content: center;
  max-width: 1280px; margin: 0 auto 40px;
}
.filtro-btn {
  background: var(--bg-card); border: 1px solid var(--border);
  color: var(--text-muted); padding: 9px 22px; border-radius: 8px;
  font-family: 'Rajdhani', sans-serif; font-size: 14px; font-weight: 600;
  cursor: pointer; transition: all .3s;
}
.filtro-btn.active, .filtro-btn:hover {
  border-color: var(--neon-purple); color: var(--neon-purple);
  background: rgba(157,78,221,.08);
}

/* ─── BILHETES GRID ──────────────────────── */
.bilhetes-section { background: #08080f; }
.bilhetes-grid {
  max-width: 1440px; margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 28px;
}
.bilhete-card {
  position: relative; overflow: hidden;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 16px;
  min-width: 0;
  transition: transform .35s, box-shadow .35s, border-color .35s;
}
.bilhete-card:hover { transform: translateY(-6px); }
.bilhete-card[data-platform="pc"]:hover     { border-color: var(--neon-blue);  box-shadow: 0 16px 40px rgba(0,200,255,.2); }
.bilhete-card[data-platform="ps5"]:hover    { border-color: #4e8fff;            box-shadow: 0 16px 40px rgba(0,55,145,.3); }
.bilhete-card[data-platform="xbox"]:hover   { border-color: #5dc55d;            box-shadow: 0 16px 40px rgba(16,124,16,.3); }
.bilhete-card[data-platform="nintendo"]:hover { border-color: var(--neon-pink); box-shadow: 0 16px 40px rgba(255,0,110,.2); }
.bilhete-card[data-platform="iphone"]:hover  { border-color: #c0c0c0;            box-shadow: 0 16px 40px rgba(192,192,192,.15); }

.bilhete-card.hidden { display: none; }

/* Loading state do grid dinâmico */
.bilhetes-loading {
  grid-column: 1 / -1;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 14px; padding: 60px 20px;
  color: var(--text-muted); font-size: 15px;
}
.bilhetes-loading i { font-size: 40px; color: var(--neon-purple); opacity: .6; }

.card-badge {
  position: absolute; top: 14px; right: 14px;
  padding: 4px 12px; border-radius: 100px;
  font-size: 11px; font-weight: 700; letter-spacing: 1px; z-index: 2;
}
.card-badge.hot  { background: rgba(255,123,0,.2); color: var(--neon-orange); border: 1px solid rgba(255,123,0,.4); }
.card-badge.new  { background: rgba(0,200,255,.15); color: var(--neon-blue);  border: 1px solid rgba(0,200,255,.3); }
.card-badge.sale { background: rgba(57,255,20,.12); color: var(--neon-green); border: 1px solid rgba(57,255,20,.3); }

.card-platform {
  display: inline-flex; align-items: center; gap: 6px;
  margin: 14px 14px 0;
  padding: 4px 12px; border-radius: 100px;
  font-size: 12px; font-weight: 700; letter-spacing: 1px;
}
.pc-tag      { background: rgba(0,200,255,.1);   color: var(--neon-blue);  border: 1px solid rgba(0,200,255,.25); }
.ps5-tag     { background: rgba(0,55,145,.15);   color: #4e8fff;           border: 1px solid rgba(0,55,145,.3); }
.xbox-tag    { background: rgba(16,124,16,.12);  color: #5dc55d;           border: 1px solid rgba(16,124,16,.3); }
.nintendo-tag{ background: rgba(255,0,110,.1);   color: var(--neon-pink);  border: 1px solid rgba(255,0,110,.25); }
.iphone-tag  { background: rgba(210,210,210,.08); color: #c0c0c0;            border: 1px solid rgba(200,200,200,.25); }

.card-img {
  display: flex; align-items: center; justify-content: center;
  height: 260px; font-size: 64px;
  background:
    radial-gradient(circle at top, rgba(157,78,221,.18), transparent 60%),
    linear-gradient(135deg, rgba(157,78,221,.08), rgba(0,200,255,.08));
  color: var(--neon-purple); opacity: .8;
  margin: 12px;
  border-radius: 12px;
  overflow: hidden;
  padding: 0;
  transition: all .35s;
}
.bilhete-card:hover .card-img { opacity: 1; transform: scale(1.03); }
.card-img img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
  display: block;
  background: rgba(6,6,16,.18);
}
.card-body { padding: 14px 18px 18px; }
.card-body h4 {
  font-family: 'Orbitron', sans-serif;
  font-size: 17px; font-weight: 700; margin-bottom: 10px; line-height: 1.35;
}
.card-body p { font-size: 15px; color: var(--text-muted); line-height: 1.55; margin-bottom: 14px; }
.card-meta { display: flex; gap: 14px; flex-wrap: wrap; margin-bottom: 16px; }
.card-meta span { font-size: 13px; color: var(--text-muted); display: flex; align-items: center; gap: 5px; }
.card-meta i { color: var(--neon-purple); }
.card-footer { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.card-price {
  font-family: 'Orbitron', sans-serif;
  font-size: 24px; font-weight: 900; color: var(--neon-green);
  line-height: 1;
  margin-right: auto;
}
.card-price-total {
  display: block;
}
.card-price-hint {
  display: block;
  margin-top: 6px;
  font-family: 'Rajdhani', sans-serif;
  font-size: 13px;
  font-weight: 600;
  color: var(--text-muted);
}
.old-price {
  font-size: 14px; color: var(--text-muted);
  text-decoration: line-through; display: block;
  font-family: 'Rajdhani', sans-serif; font-weight: 500;
  margin-bottom: 2px;
}
.btn-comprar {
  background: linear-gradient(135deg, var(--neon-purple), #6a1fd0);
  color: #fff; border: none;
  padding: 12px 18px; border-radius: 8px;
  font-family: 'Rajdhani', sans-serif;
  font-size: 15px; font-weight: 700; letter-spacing: .5px;
  cursor: pointer; transition: all .3s;
  display: inline-flex; align-items: center; gap: 6px;
  white-space: nowrap;
  flex: 1 1 150px;
  justify-content: center;
}
.btn-comprar:hover { transform: translateY(-2px); box-shadow: var(--glow-purple); }

.qty-control {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 7px 9px;
  background: rgba(6,6,16,.35);
  flex: 0 0 auto;
}
.qty-btn {
  width: 32px;
  height: 32px;
  border-radius: 7px;
  border: 1px solid var(--border);
  background: transparent;
  color: var(--text-main);
  cursor: pointer;
  font-weight: 900;
  transition: all .2s;
}
.qty-btn:hover { border-color: var(--neon-purple); box-shadow: var(--glow-purple); }
.qty-input {
  width: 52px;
  height: 32px;
  border-radius: 7px;
  border: 1px solid var(--border);
  background: transparent;
  color: var(--text-main);
  text-align: center;
  font-weight: 700;
  outline: none;
}
.qty-input:focus { border-color: var(--neon-blue); box-shadow: var(--glow-blue); }

/* ─── RANKING ────────────────────────────── */
.ranking-section {
  background: linear-gradient(180deg, #08080f, var(--bg-dark));
  overflow: hidden;
}

/* ─── Carrossel ────────────────────────── */
.ranking-carousel-wrap {
  max-width: 1280px;
  margin: 0 auto;
  overflow: hidden;
  padding: 8px 0 24px;
  position: relative;
  /* fade nas bordas */
  -webkit-mask-image: linear-gradient(to right, transparent 0%, #000 6%, #000 94%, transparent 100%);
  mask-image: linear-gradient(to right, transparent 0%, #000 6%, #000 94%, transparent 100%);
}
.ranking-track {
  display: flex;
  gap: 20px;
  width: max-content;
  animation: rankingScroll 28s linear infinite;
  cursor: default;
}
.ranking-track:hover { animation-play-state: paused; }
@keyframes rankingScroll {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

/* ─── Cards ─────────────────────────────── */
.rank-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 24px 20px;
  text-align: center;
  width: 200px;
  flex-shrink: 0;
  transition: transform .3s, box-shadow .3s;
  position: relative;
}
.rank-card:hover { transform: translateY(-6px); box-shadow: 0 16px 40px rgba(157,78,221,.25); }
.rank-card.rank-1 { border-color: #ffd700; box-shadow: 0 0 20px rgba(255,215,0,.25); }
.rank-card.rank-2 { border-color: #c0c0c0; box-shadow: 0 0 20px rgba(192,192,192,.2); }
.rank-card.rank-3 { border-color: #cd7f32; box-shadow: 0 0 20px rgba(205,127,50,.2); }
.rank-medal { font-size: 32px; margin-bottom: 12px; line-height: 1; }
.rank-medal-num {
  font-family: 'Orbitron', sans-serif;
  font-size: 22px; font-weight: 900;
  color: var(--text-muted);
  margin-bottom: 12px;
}
.rank-avatar {
  width: 64px; height: 64px; border-radius: 50%;
  background: rgba(157,78,221,.15); border: 2px solid var(--border);
  display: grid; place-items: center; font-size: 28px;
  margin: 0 auto 14px; color: var(--neon-purple);
}
.rank-info h4 {
  font-family: 'Orbitron', sans-serif; font-size: 12px; font-weight: 700;
  margin-bottom: 8px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.rank-info p {
  font-family: 'Orbitron', sans-serif; font-size: 15px;
  color: var(--neon-green); font-weight: 900; line-height: 1.3;
}
.rank-compras-label {
  font-size: 11px; color: var(--text-muted); margin-top: 3px;
}
.rank-empty {
  color: var(--text-muted); font-size: 14px;
  padding: 40px 24px; text-align: center;
}

/* ─── PROMO BANNER ───────────────────────── */
.promo-banner {
  background: linear-gradient(135deg, rgba(157,78,221,.2), rgba(0,200,255,.1));
  border: 1px solid rgba(157,78,221,.3);
  margin: 0 24px;
  border-radius: 24px; padding: 60px 40px;
  display: flex; align-items: center; justify-content: space-between;
  gap: 32px; flex-wrap: wrap;
  position: relative; overflow: hidden;
}
.promo-banner::before {
  content: '';
  position: absolute; inset: 0;
  background: radial-gradient(circle at 80% 50%, rgba(157,78,221,.15), transparent 60%);
}
.promo-content { position: relative; z-index: 1; max-width: 600px; }
.promo-tag {
  display: inline-flex; align-items: center; gap: 6px;
  background: rgba(255,123,0,.15); border: 1px solid rgba(255,123,0,.4);
  color: var(--neon-orange); padding: 5px 16px;
  border-radius: 100px; font-size: 13px; font-weight: 700; letter-spacing: 2px;
  margin-bottom: 16px;
}
.promo-content h2 {
  font-family: 'Orbitron', sans-serif; font-size: clamp(22px,4vw,36px);
  font-weight: 900; margin-bottom: 12px; line-height: 1.2;
}
.promo-content h2 span { color: var(--neon-purple); }
.promo-content p { font-size: 16px; color: var(--text-muted); margin-bottom: 24px; }
.promo-btn { font-size: 16px; padding: 15px 32px; }
.promo-img {
  font-size: 100px; color: var(--neon-purple);
  opacity: .3; position: relative; z-index: 1;
  animation: pulse 3s ease-in-out infinite;
}

/* ─── MINHA CONTA ───────────────────────── */
.account-section {
  background:
    radial-gradient(circle at top left, rgba(0,200,255,.08), transparent 35%),
    radial-gradient(circle at bottom right, rgba(157,78,221,.12), transparent 40%),
    #06060f;
}
.account-section-page {
  min-height: calc(100vh - 160px);
}
.account-page-hero {
  position: relative;
  padding: 140px 24px 46px;
  background:
    radial-gradient(circle at 20% 30%, rgba(157,78,221,.14), transparent 32%),
    radial-gradient(circle at 85% 20%, rgba(0,200,255,.12), transparent 26%),
    linear-gradient(180deg, #060610, #0a0a1a);
}
.account-page-hero-inner {
  max-width: 980px;
  margin: 0 auto;
  text-align: center;
}
.account-page-hero h1 {
  font-family: 'Orbitron', sans-serif;
  font-size: clamp(36px, 6vw, 64px);
  line-height: 1.1;
  margin-bottom: 16px;
}
.account-page-hero p {
  max-width: 760px;
  margin: 0 auto 28px;
  color: var(--text-muted);
  font-size: 18px;
  line-height: 1.7;
}
.nav-account-link {
  padding: 9px 16px;
  font-size: 14px;
}
.account-grid {
  max-width: 1440px; margin: 0 auto;
  display: grid; grid-template-columns: minmax(320px, 420px) minmax(0, 1fr);
  gap: 28px;
  align-items: start;
}
.account-grid.account-grid-authenticated {
  grid-template-columns: minmax(0, 1fr);
}
.account-login-card,
.account-panel-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 22px;
  box-shadow: 0 24px 60px rgba(0,0,0,.18);
}
.account-login-card {
  padding: 30px;
  position: sticky;
  top: 92px;
}
.account-login-card h3,
.account-panel-header h3 {
  font-family: 'Orbitron', sans-serif;
  font-size: 22px;
  display: flex; align-items: center; gap: 10px;
  margin-bottom: 10px;
}
.account-login-card p {
  color: var(--text-muted);
  font-size: 15px;
  line-height: 1.6;
  margin-bottom: 22px;
}
.account-login-form {
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.account-panel-card {
  padding: 28px;
  min-height: 520px;
}
.account-grid.account-grid-authenticated .account-panel-card {
  max-width: 100%;
  min-height: 620px;
}
.account-empty {
  min-height: 460px;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  text-align: center;
  gap: 14px;
  color: var(--text-muted);
}
.account-empty i {
  font-size: 58px;
  color: var(--neon-purple);
  text-shadow: var(--glow-purple);
}
.account-empty h3 {
  font-family: 'Orbitron', sans-serif;
  font-size: 22px;
  color: var(--text-main);
}
.account-panel {
  display: flex;
  flex-direction: column;
  gap: 22px;
}
.account-panel-header {
  display: flex; justify-content: space-between; align-items: flex-start;
  gap: 16px; flex-wrap: wrap;
}
.account-chip {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 6px 12px;
  border-radius: 999px;
  background: rgba(57,255,20,.08);
  border: 1px solid rgba(57,255,20,.22);
  color: var(--neon-green);
  font-size: 12px; font-weight: 700; letter-spacing: 1px;
  margin-bottom: 12px;
}
.account-panel-header p {
  color: var(--text-muted);
  line-height: 1.6;
}
.account-logout-btn {
  padding-inline: 18px;
}
.account-stats {
  display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 14px;
}
.account-stat-card {
  background: rgba(255,255,255,.03);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 16px 18px;
}
.account-stat-card strong {
  display: block;
  font-family: 'Orbitron', sans-serif;
  font-size: 24px;
  color: var(--neon-green);
  margin-bottom: 6px;
}
.account-stat-card span {
  color: var(--text-muted);
  font-size: 13px;
  letter-spacing: 1px;
}
.account-ticket-list {
  display: grid;
  gap: 14px;
}
.account-order-list {
  display: grid;
  gap: 18px;
}
.account-section-block {
  display: grid;
  gap: 14px;
}
.account-section-heading {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}
.account-section-heading h4 {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: 'Orbitron', sans-serif;
  font-size: 16px;
}
.account-section-heading span {
  color: var(--text-muted);
  font-size: 13px;
}
.account-ticket-card {
  background: linear-gradient(135deg, rgba(157,78,221,.08), rgba(0,200,255,.05));
  border: 1px solid var(--border);
  border-radius: 18px;
  padding: 18px;
}
.account-order-card {
  background: linear-gradient(135deg, rgba(255,123,0,.08), rgba(0,200,255,.04));
}
.account-ticket-top {
  display: flex; justify-content: space-between; align-items: flex-start; gap: 14px; flex-wrap: wrap;
  margin-bottom: 12px;
}
.account-ticket-top h4 {
  font-family: 'Orbitron', sans-serif;
  font-size: 16px;
  line-height: 1.4;
  margin-bottom: 6px;
}
.account-ticket-platform {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 4px 10px;
  border-radius: 999px;
  font-size: 12px; font-weight: 700;
  background: rgba(0,200,255,.09);
  border: 1px solid rgba(0,200,255,.2);
  color: var(--neon-blue);
}
.account-ticket-code {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 10px 14px;
  border-radius: 12px;
  background: rgba(6,6,16,.5);
  border: 1px dashed rgba(157,78,221,.45);
  font-family: 'Orbitron', sans-serif;
  font-size: 14px;
}
.account-order-status {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 40px;
  padding: 10px 14px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 700;
  border: 1px solid rgba(255,255,255,.12);
}
.account-order-status.pending {
  color: var(--orange);
  background: rgba(255,123,0,.08);
  border-color: rgba(255,123,0,.25);
}
.account-order-status.paid {
  color: var(--neon-green);
  background: rgba(57,255,20,.08);
  border-color: rgba(57,255,20,.22);
}
.account-ticket-meta {
  display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 10px;
}
.account-ticket-meta div {
  background: rgba(255,255,255,.03);
  border-radius: 12px;
  padding: 10px 12px;
}
.account-ticket-meta strong {
  display: block; color: var(--text-muted); font-size: 12px; margin-bottom: 4px;
}
.account-ticket-meta span {
  display: block; font-size: 14px; line-height: 1.4;
}
.account-order-actions {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 14px;
}
.account-ticket-empty {
  border: 1px dashed var(--border);
  border-radius: 18px;
  padding: 24px;
  text-align: center;
  color: var(--text-muted);
}

/* ─── CONTATO ────────────────────────────── */
.contato-section { background: #08080f; }
.contato-grid {
  max-width: 1000px; margin: 0 auto;
  display: grid; grid-template-columns: 1fr 1fr; gap: 48px;
}
.contato-form-wrap {
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: 20px; padding: 36px;
}
.form-group { position: relative; margin-bottom: 20px; }
.form-group input,
.form-group select,
.form-group textarea {
  width: 100%; padding: 14px 16px;
  background: rgba(255,255,255,.04);
  border: 1px solid var(--border);
  border-radius: 10px; color: var(--text-main);
  font-family: 'Rajdhani', sans-serif; font-size: 15px;
  transition: border-color .3s;
  outline: none;
}
.form-group select { appearance: none; }
.form-group select option { background: var(--bg-card); }
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus { border-color: var(--neon-purple); }
.form-group textarea { resize: vertical; min-height: 100px; }
.full-btn { width: 100%; justify-content: center; }

.contato-info { display: flex; flex-direction: column; gap: 16px; }
.info-card {
  display: flex; align-items: center; gap: 16px;
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: 14px; padding: 20px;
  transition: border-color .3s;
}
.info-card:hover { border-color: var(--neon-purple); }
.info-card > i {
  font-size: 28px; color: var(--neon-purple); min-width: 36px;
}
.info-card h4 { font-size: 14px; font-weight: 700; margin-bottom: 4px; }
.info-card p { font-size: 14px; color: var(--text-muted); }

.social-links { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 8px; }
.social-btn {
  width: 46px; height: 46px; border-radius: 12px;
  background: var(--bg-card); border: 1px solid var(--border);
  display: grid; place-items: center; font-size: 20px;
  color: var(--text-muted); transition: all .3s;
}
.social-btn:hover { border-color: var(--neon-purple); color: var(--neon-purple); transform: translateY(-3px); box-shadow: var(--glow-purple); }

/* ─── FOOTER ─────────────────────────────── */
.footer {
  background: #040408;
  border-top: 1px solid var(--border);
  padding: 60px 24px 24px;
}
.footer-top {
  max-width: 1280px; margin: 0 auto;
  display: grid; grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 40px; margin-bottom: 48px;
}
.footer-brand .logo { margin-bottom: 16px; }
.footer-brand p { font-size: 14px; color: var(--text-muted); line-height: 1.6; }
.footer-links h5 {
  font-family: 'Orbitron', sans-serif;
  font-size: 13px; font-weight: 700; letter-spacing: 2px;
  color: var(--neon-purple); margin-bottom: 16px;
}
.footer-links ul li { margin-bottom: 10px; }
.footer-links ul a {
  font-size: 14px; color: var(--text-muted); transition: color .3s;
}
.footer-links ul a:hover { color: var(--text-main); }
.payment-icons {
  display: flex; gap: 12px; font-size: 28px;
  color: var(--text-muted); flex-wrap: wrap; margin-bottom: 12px;
}
.secure-badge {
  font-size: 13px; color: var(--neon-green);
  display: flex; align-items: center; gap: 6px;
}
.footer-bottom {
  max-width: 1280px; margin: 0 auto;
  border-top: 1px solid var(--border);
  padding-top: 24px;
  display: flex; justify-content: space-between; flex-wrap: wrap; gap: 12px;
  font-size: 13px; color: var(--text-muted);
}

/* ─── CARRINHO LATERAL ───────────────────── */
.cart-overlay {
  position: fixed; inset: 0; background: rgba(0,0,0,.7);
  z-index: 1999; opacity: 0; pointer-events: none; transition: opacity .3s;
}
.cart-overlay.open { opacity: 1; pointer-events: all; }
.cart-sidebar {
  position: fixed; top: 0; right: -420px; width: 420px; max-width: 100vw;
  height: 100vh; background: var(--bg-card2);
  border-left: 1px solid var(--border);
  z-index: 2000; display: flex; flex-direction: column;
  transition: right .35s cubic-bezier(.25,.8,.25,1);
}
.cart-sidebar.open { right: 0; }
.cart-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 20px 24px;
  border-bottom: 1px solid var(--border);
}
.cart-header h3 {
  font-family: 'Orbitron', sans-serif; font-size: 16px;
  display: flex; align-items: center; gap: 10px;
}
.cart-header button {
  background: none; border: none; color: var(--text-muted);
  font-size: 22px; cursor: pointer; transition: color .3s;
}
.cart-header button:hover { color: var(--neon-pink); }
.cart-items { flex: 1; overflow-y: auto; padding: 20px 24px; }
.cart-empty {
  display: flex; flex-direction: column; align-items: center;
  justify-content: center; height: 100%;
  color: var(--text-muted); gap: 12px;
}
.cart-empty i { font-size: 48px; }
.cart-item {
  display: flex; align-items: flex-start; gap: 14px;
  padding: 14px 0; border-bottom: 1px solid var(--border);
}
.cart-item-info { flex: 1; }
.cart-item-info h5 { font-size: 13px; font-weight: 700; margin-bottom: 6px; line-height: 1.4; }
.cart-item-info span { font-size: 12px; color: var(--text-muted); }
.cart-qty-control {
  display: inline-flex; align-items: center; gap: 10px;
  margin-top: 10px;
  padding: 6px 10px;
  border: 1px solid var(--border);
  border-radius: 999px;
  background: rgba(255,255,255,.03);
}
.cart-qty-btn {
  width: 24px; height: 24px;
  display: grid; place-items: center;
  border-radius: 50%; border: 1px solid var(--border);
  background: rgba(255,255,255,.04);
  color: var(--text-main); cursor: pointer;
  font-size: 14px; font-weight: 700;
  transition: all .3s;
}
.cart-qty-btn:hover {
  border-color: var(--neon-purple);
  box-shadow: var(--glow-purple);
}
.cart-qty-value {
  min-width: 18px;
  text-align: center;
  font-size: 13px;
  font-weight: 700;
  color: var(--text-main);
}
.cart-item-price {
  font-family: 'Orbitron', sans-serif;
  font-weight: 900; color: var(--neon-green); font-size: 15px;
}
.cart-item-del {
  background: none; border: none; color: var(--text-muted);
  cursor: pointer; font-size: 16px; transition: color .3s;
  padding: 4px;
}
.cart-item-del:hover { color: var(--neon-pink); }
.cart-total-wrap {
  padding: 20px 24px;
  border-top: 1px solid var(--border);
}
.cart-total {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 16px;
  font-size: 16px; font-weight: 700;
}
.total-value {
  font-family: 'Orbitron', sans-serif;
  font-size: 22px; color: var(--neon-green);
}

/* ─── MODAL ──────────────────────────────── */
.modal-overlay {
  position: fixed; inset: 0;
  background: rgba(0,0,0,.8); backdrop-filter: blur(6px);
  z-index: 3000;
  display: grid; place-items: center;
  opacity: 0; pointer-events: none; transition: opacity .3s;
}
.modal-overlay.open { opacity: 1; pointer-events: all; }
.checkout-shell {
  position: relative;
  background: linear-gradient(180deg, rgba(21,20,48,.98), rgba(10,10,26,.98));
  border: 1px solid var(--border);
  border-radius: 24px;
  width: min(1080px, calc(100vw - 32px));
  max-height: calc(100vh - 32px);
  overflow: auto;
  box-shadow: 0 24px 70px rgba(0,0,0,.45);
  transform: translateY(20px);
  transition: transform .35s;
}
.modal-overlay.open .checkout-shell { transform: translateY(0); }
.checkout-close {
  position: sticky; top: 16px; margin-left: auto; margin-right: 16px; margin-top: 16px;
  width: 42px; height: 42px; border-radius: 12px;
  border: 1px solid var(--border); background: rgba(255,255,255,.04);
  color: var(--text-muted); cursor: pointer; z-index: 2;
  display: grid; place-items: center; transition: all .3s;
}
.checkout-close:hover { color: var(--text-main); border-color: var(--neon-pink); }

/* ─── MODAL LOGIN ──────────────────────────── */
.login-shell {
  position: relative;
  background: linear-gradient(180deg, rgba(21,20,48,.98), rgba(10,10,26,.98));
  border: 1px solid var(--border);
  border-radius: 24px;
  width: min(420px, calc(100vw - 32px));
  box-shadow: 0 24px 70px rgba(0,0,0,.45);
  transform: translateY(20px);
  transition: transform .35s;
}
.modal-overlay.open .login-shell { transform: translateY(0); }
.login-modal-inner { padding: 8px 28px 28px; }
.login-modal-header {
  text-align: center;
  margin-bottom: 24px;
}
.login-modal-header > i {
  font-size: 40px;
  color: var(--neon-purple);
  text-shadow: var(--glow-purple);
  display: block;
  margin-bottom: 12px;
}
.login-modal-header h3 {
  font-family: 'Orbitron', sans-serif;
  font-size: 19px;
  margin-bottom: 8px;
}
.login-modal-header p {
  color: var(--text-muted);
  font-size: 14px;
  line-height: 1.6;
}
.login-modal-error {
  background: rgba(255,0,110,.1);
  border: 1px solid rgba(255,0,110,.3);
  border-radius: 10px;
  color: #ff5c8a;
  font-size: 14px;
  padding: 10px 14px;
  text-align: center;
}
.login-modal-footer {
  text-align: center;
  margin-top: 18px;
  font-size: 14px;
  color: var(--text-muted);
}
.login-modal-footer a {
  color: var(--neon-cyan);
  text-decoration: none;
}
.login-modal-footer a:hover { text-decoration: underline; }

/* ─── MODAL DADOS CADASTRADOS ────────────── */
.dados-shell { width: min(480px, calc(100vw - 32px)); }
.dados-grid {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-top: 4px;
}
.dados-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  padding: 11px 16px;
  background: rgba(255,255,255,.03);
  border: 1px solid var(--border);
  border-radius: 12px;
  flex-wrap: wrap;
}
.dados-label {
  display: flex;
  align-items: center;
  gap: 8px;
  color: var(--text-muted);
  font-size: 13px;
  font-weight: 600;
  white-space: nowrap;
}
.dados-label i { color: var(--neon-purple); width: 16px; text-align: center; }
.dados-val {
  font-size: 14px;
  font-weight: 600;
  color: var(--text-main);
  text-align: right;
  word-break: break-all;
}

.dados-pedidos {
  margin-top: 18px;
}
.dados-pedidos-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 10px;
}
.dados-pedidos-head h4 {
  margin: 0;
  font-family: 'Orbitron', sans-serif;
  font-size: 14px;
  display: flex;
  align-items: center;
  gap: 10px;
}
.dados-pedidos-head span {
  color: var(--text-muted);
  font-size: 13px;
  font-weight: 700;
}
.dados-pedidos-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
  max-height: 240px;
  overflow: auto;
  padding-right: 4px;
}
.dados-pedido-item {
  background: rgba(255,255,255,.03);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 12px 14px;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 14px;
}
.dados-pedido-main {
  min-width: 0;
}
.dados-pedido-title {
  font-weight: 700;
  font-size: 14px;
  color: var(--text-main);
  margin-bottom: 4px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  max-width: 260px;
}
.dados-pedido-meta {
  color: var(--text-muted);
  font-size: 12px;
  line-height: 1.5;
}
.dados-pedido-right {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 8px;
  flex: 0 0 auto;
}
.dados-status {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 10px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .6px;
}
.dados-status.pago {
  background: rgba(57,255,20,.08);
  border: 1px solid rgba(57,255,20,.22);
  color: var(--neon-green);
}
.dados-status.pendente {
  background: rgba(255,193,7,.08);
  border: 1px solid rgba(255,193,7,.22);
  color: #ffd266;
}
.dados-pedido-valor {
  font-weight: 800;
  color: var(--neon-cyan);
  font-size: 13px;
}
.dados-pedidos-empty {
  background: rgba(255,255,255,.02);
  border: 1px dashed var(--border);
  border-radius: 12px;
  padding: 12px 14px;
  color: var(--text-muted);
  font-size: 13px;
}

/* ─── APELIDO EDITÁVEL ─────────────────── */
.dados-row-apelido { flex-wrap: nowrap; }
.dados-apelido-wrap {
  display: flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
}
.dados-apelido-btn {
  background: none;
  border: 1px solid rgba(157,78,221,.3);
  border-radius: 7px;
  color: var(--neon-purple);
  width: 28px; height: 28px;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  font-size: .72rem;
  flex-shrink: 0;
  transition: background .2s, border-color .2s;
}
.dados-apelido-btn:hover {
  background: rgba(157,78,221,.12);
  border-color: var(--neon-purple);
}
.dados-apelido-edit {
  display: flex;
  align-items: center;
  gap: 6px;
}
.dados-apelido-edit input {
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(157,78,221,.4);
  border-radius: 8px;
  padding: 5px 10px;
  color: var(--text-main);
  font-family: 'Rajdhani', sans-serif;
  font-size: .88rem;
  font-weight: 600;
  outline: none;
  width: 160px;
}
.dados-apelido-edit input:focus { border-color: var(--neon-purple); }
.dados-apelido-save,
.dados-apelido-cancel {
  width: 28px; height: 28px;
  border-radius: 7px;
  border: none;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  font-size: .75rem;
  flex-shrink: 0;
  transition: background .2s;
}
.dados-apelido-save {
  background: rgba(57,255,20,.15);
  color: var(--neon-green);
  border: 1px solid rgba(57,255,20,.3);
}
.dados-apelido-save:hover { background: rgba(57,255,20,.25); }
.dados-apelido-cancel {
  background: rgba(255,0,80,.1);
  color: #ff7ca0;
  border: 1px solid rgba(255,0,80,.25);
}
.dados-apelido-cancel:hover { background: rgba(255,0,80,.2); }
.dados-apelido-rank-badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  background: rgba(157,78,221,.12);
  border: 1px solid rgba(157,78,221,.25);
  border-radius: 999px;
  padding: 2px 10px;
  font-size: .8rem;
  font-weight: 700;
  color: var(--neon-purple);
  letter-spacing: .3px;
}

/* ─── DROPDOWN USUÁRIO NAVBAR ───────────── */
.user-btn-wrap {
  position: relative;
}
.user-dropdown {
  position: absolute;
  top: calc(100% + 10px);
  right: 0;
  min-width: 190px;
  background: linear-gradient(180deg, rgba(21,20,48,.98), rgba(10,10,26,.98));
  border: 1px solid var(--border);
  border-radius: 14px;
  box-shadow: 0 16px 40px rgba(0,0,0,.5);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  opacity: 0;
  pointer-events: none;
  transform: translateY(8px);
  transition: opacity .2s, transform .2s;
  z-index: 2000;
}
.user-dropdown.open {
  opacity: 1;
  pointer-events: all;
  transform: translateY(0);
}
.user-dropdown-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 18px;
  font-family: 'Rajdhani', sans-serif;
  font-size: 15px;
  font-weight: 600;
  color: var(--text-main);
  text-decoration: none;
  background: none;
  border: none;
  cursor: pointer;
  width: 100%;
  text-align: left;
  transition: background .2s;
}
.user-dropdown-item:hover {
  background: rgba(157,78,221,.15);
  color: var(--neon-purple);
}
.user-dropdown-logout { color: var(--text-muted); }
.user-dropdown-logout:hover { color: #ff5c8a; background: rgba(255,0,110,.08); }

/* ─── BOTÃO USUÁRIO NAVBAR ──────────────── */
.btn-user-login {
  display: flex; align-items: center; gap: 7px;
  background: rgba(157,78,221,.12);
  border: 1px solid rgba(157,78,221,.35);
  border-radius: 12px;
  color: var(--text-main);
  padding: 0 14px;
  height: 40px;
  font-family: 'Rajdhani', sans-serif;
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  transition: all .3s;
  white-space: nowrap;
  max-width: 160px;
  overflow: hidden;
  text-overflow: ellipsis;
}
.btn-user-login:hover {
  background: rgba(157,78,221,.25);
  border-color: var(--neon-purple);
  box-shadow: 0 0 12px rgba(157,78,221,.3);
}
.btn-user-login.logged-in {
  background: rgba(57,255,20,.08);
  border-color: rgba(57,255,20,.3);
  color: var(--neon-green);
}
.btn-user-login.logged-in:hover {
  background: rgba(57,255,20,.15);
  border-color: var(--neon-green);
  box-shadow: 0 0 12px rgba(57,255,20,.3);
}
@media (max-width: 480px) {
  .btn-user-login { max-width: 110px; font-size: 12px; }
}
.checkout-layout {
  display: grid; grid-template-columns: minmax(0, 1.25fr) minmax(320px, .75fr);
  gap: 24px; padding: 10px 28px 28px;
}
.checkout-main,
.checkout-summary {
  background: rgba(255,255,255,.03);
  border: 1px solid var(--border);
  border-radius: 20px;
}
.checkout-main { padding: 28px; }
.checkout-summary { padding: 24px; height: fit-content; }
.checkout-tag { margin-bottom: 16px; }
.checkout-title {
  font-family: 'Orbitron', sans-serif;
  font-size: clamp(24px, 4vw, 34px);
  margin-bottom: 10px;
}
.checkout-subtitle {
  color: var(--text-muted); font-size: 15px;
  line-height: 1.6; margin-bottom: 24px;
}
.checkout-form { display: flex; flex-direction: column; gap: 18px; }

/* ── Cliente já logado no checkout ── */
.checkout-logged-banner {
  display: flex; align-items: center; justify-content: space-between;
  background: rgba(57,255,20,.08); border: 1px solid rgba(57,255,20,.3);
  border-radius: 10px; padding: 12px 16px; margin-bottom: 6px; gap: 12px;
}
.checkout-logged-info { display: flex; align-items: center; gap: 12px; color: var(--text); }
.checkout-logged-info i { font-size: 22px; color: #39ff14; flex-shrink: 0; }
.checkout-logged-info strong { display: block; font-size: 14px; font-weight: 700; }
.checkout-logged-info span { font-size: 12px; color: var(--muted); }
.checkout-logged-out {
  background: transparent; border: 1px solid rgba(255,255,255,.15);
  color: var(--muted); border-radius: 7px; padding: 6px 12px;
  font-size: 12px; cursor: pointer; white-space: nowrap;
  transition: all .2s; display: flex; align-items: center; gap: 6px;
}
.checkout-logged-out:hover { border-color: #ff006e; color: #ff006e; }
.checkout-row {
  display: grid; grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}
.checkout-row-sm {
  grid-template-columns: 1fr 140px;
}
.checkout-methods {
  display: grid; grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}
.checkout-method {
  border: 1px solid var(--border);
  background: rgba(255,255,255,.03);
  color: var(--text-main);
  border-radius: 16px;
  min-height: 62px;
  display: flex; align-items: center; justify-content: center; gap: 10px;
  font-family: 'Rajdhani', sans-serif; font-size: 16px; font-weight: 700;
  cursor: pointer; transition: all .3s;
}
.checkout-method.active {
  border-color: var(--neon-purple);
  box-shadow: var(--glow-purple);
  background: rgba(157,78,221,.12);
}
.payment-pane {
  display: none;
  border: 1px solid var(--border);
  border-radius: 18px;
  padding: 18px;
  background: rgba(255,255,255,.025);
}
.payment-pane.active { display: block; }
.payment-note {
  display: flex; gap: 14px; align-items: flex-start;
}
.payment-note i {
  color: var(--neon-green); font-size: 20px; margin-top: 2px;
}
.payment-note strong { display: block; margin-bottom: 6px; }
.payment-note p { color: var(--text-muted); font-size: 14px; line-height: 1.5; }
.checkout-summary h4 {
  font-family: 'Orbitron', sans-serif;
  font-size: 16px; margin-bottom: 18px;
}
.checkout-items {
  display: flex; flex-direction: column; gap: 12px; margin-bottom: 20px;
}
.checkout-item {
  display: flex; justify-content: space-between; gap: 14px;
  padding: 12px 0; border-bottom: 1px solid var(--border);
}
.checkout-item:last-child { border-bottom: none; }
.checkout-item-name {
  font-size: 14px; font-weight: 700; line-height: 1.4;
}
.checkout-item-meta {
  display: block; margin-top: 4px; color: var(--text-muted); font-size: 12px;
}
.checkout-item-price {
  font-family: 'Orbitron', sans-serif; color: var(--neon-green); font-size: 14px;
  white-space: nowrap;
}
.checkout-totals {
  border-top: 1px solid var(--border);
  padding-top: 16px;
  display: flex; flex-direction: column; gap: 10px;
}
.checkout-line {
  display: flex; justify-content: space-between; gap: 12px; color: var(--text-muted);
}
.checkout-line.total {
  color: var(--text-main); font-weight: 700; font-size: 17px;
}
.checkout-line.total span:last-child {
  font-family: 'Orbitron', sans-serif; color: var(--neon-green);
}
.checkout-success:not([hidden]) {
  display: grid; place-items: center; text-align: center;
  padding: 36px 28px 34px;
}
.checkout-success-icon {
  font-size: 54px; color: var(--neon-green); margin-bottom: 14px;
}
.checkout-success h3 {
  font-family: 'Orbitron', sans-serif; font-size: 24px; margin-bottom: 10px;
}
.checkout-success p {
  max-width: 560px; color: var(--text-muted); line-height: 1.6; margin-bottom: 20px;
}
.checkout-success-meta {
  width: min(100%, 620px);
  margin-bottom: 22px;
  display: grid; gap: 12px;
}
.checkout-meta-card {
  text-align: left;
  background: rgba(255,255,255,.03);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 14px 16px;
}
.checkout-meta-card strong {
  display: block; font-size: 12px; color: var(--text-muted); margin-bottom: 6px;
}
.checkout-meta-card span {
  display: block; font-size: 15px; line-height: 1.5; word-break: break-word;
}
.checkout-meta-list {
  display: flex; flex-direction: column; gap: 10px;
}
.checkout-meta-line {
  display: flex; justify-content: space-between; gap: 14px;
  align-items: flex-start;
  color: var(--text-main);
}
.checkout-meta-line strong {
  margin-bottom: 0;
  color: var(--text-main);
  font-size: 14px;
}
.checkout-meta-total {
  margin-top: 14px; padding-top: 12px;
  border-top: 1px solid var(--border);
}
.checkout-qr-card {
  display: grid; justify-items: center;
}
.checkout-qr-image {
  width: min(100%, 260px); height: auto;
  border-radius: 18px; padding: 10px;
  background: #fff;
  border: 1px solid var(--border);
}
.checkout-copy-wrap {
  display: grid; gap: 12px;
}
.checkout-copy-code {
  display: block;
  padding: 12px 14px;
  border: 1px solid var(--border);
  border-radius: 14px;
  background: rgba(255,255,255,.025);
  font-size: 14px;
  line-height: 1.6;
  word-break: break-all;
}
.checkout-copy-btn {
  justify-self: start;
}

/* ─── PÁGINA PIX ────────────────────────── */
.pix-page {
  min-height: 100vh;
  padding: 32px 20px 48px;
  background:
    radial-gradient(circle at top left, rgba(0,200,255,.14), transparent 28%),
    radial-gradient(circle at top right, rgba(157,78,221,.16), transparent 26%),
    linear-gradient(180deg, #060611 0%, #080814 46%, #05050d 100%);
}
.pix-shell {
  width: min(1180px, 100%);
  margin: 0 auto;
}
.pix-topbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 20px;
}
.pix-brand {
  display: inline-flex;
  align-items: center;
  gap: 14px;
}
.pix-brand-mark {
  width: 56px;
  height: 56px;
  border-radius: 18px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 56px;
  background: linear-gradient(180deg, rgba(157,78,221,.18), rgba(0,200,255,.12));
  border: 1px solid rgba(0,200,255,.22);
  box-shadow: 0 16px 40px rgba(0,200,255,.12);
}
.pix-brand-symbol {
  display: block;
  width: 44px;
  height: 44px;
  margin: 0 auto;
  transform: translate(0, 1px);
  transform-origin: center;
  filter: drop-shadow(0 8px 18px rgba(126,231,255,.16));
}
.pix-brand strong {
  display: block;
  font-family: 'Orbitron', sans-serif;
  font-size: 13px;
}
.pix-brand span {
  display: block;
  color: var(--text-muted);
  font-size: 13px;
  margin-top: 4px;
}
.pix-topbar-actions {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}
.pix-back-link {
  min-height: 46px;
}
.pix-client-badge {
  display: flex;
  align-items: center;
  gap: 8px;
  background: linear-gradient(135deg, rgba(57,255,20,.15), rgba(57,255,20,.06));
  border: 1px solid rgba(57,255,20,.35);
  border-radius: 40px;
  padding: 8px 16px;
  color: #39ff14;
  font-weight: 600;
  font-size: 14px;
}
.pix-client-badge i { font-size: 18px; }

/* ─── Seção de bilhetes ─── */
.pix-bilhetes-section {
  margin-top: 28px;
  padding: 28px;
  background: linear-gradient(135deg, rgba(57,255,20,.06), rgba(57,255,20,.02));
  border: 1px solid rgba(57,255,20,.25);
  border-radius: 24px;
}
.pix-bilhetes-header {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-bottom: 20px;
}
.pix-bilhetes-header i {
  font-size: 36px;
  color: #39ff14;
  filter: drop-shadow(0 0 8px #39ff14aa);
}
.pix-bilhetes-header h2 {
  font-family: 'Orbitron', sans-serif;
  font-size: 22px;
  color: #39ff14;
  margin: 0 0 4px;
}
.pix-bilhetes-header p {
  margin: 0;
  color: rgba(255,255,255,.6);
  font-size: 14px;
}
.pix-bilhetes-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 14px;
}
.pix-bilhete-card {
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(57,255,20,.2);
  border-radius: 16px;
  padding: 18px;
}
.pix-bilhete-card .bilhete-titulo {
  font-weight: 700;
  font-size: 14px;
  color: #fff;
  margin-bottom: 4px;
}
.pix-bilhete-card .bilhete-plat {
  font-size: 12px;
  color: rgba(255,255,255,.5);
  margin-bottom: 12px;
}
.pix-bilhete-card .bilhete-codigo {
  font-family: 'Courier New', monospace;
  font-size: 15px;
  font-weight: 700;
  color: #39ff14;
  background: rgba(57,255,20,.1);
  border: 1px dashed rgba(57,255,20,.4);
  border-radius: 8px;
  padding: 8px 12px;
  word-break: break-all;
  letter-spacing: 1px;
}
.pix-bilhete-copy {
  margin-top: 10px;
  display: flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  color: rgba(255,255,255,.5);
  font-size: 12px;
  background: none;
  border: none;
  padding: 0;
}
.pix-bilhete-copy:hover { color: #39ff14; }
.pix-hero {
  display: grid;
  grid-template-columns: minmax(0, 1.25fr) minmax(260px, .75fr);
  gap: 24px;
  padding: 30px;
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 28px;
  margin-bottom: 24px;
  box-shadow: 0 24px 60px rgba(0,0,0,.28);
}
.pix-hero-copy {
  text-align: left;
}
.pix-hero h1 {
  font-family: 'Orbitron', sans-serif;
  font-size: clamp(28px, 4vw, 44px);
  line-height: 1.1;
  margin: 14px 0 12px;
}
.pix-hero p {
  color: var(--text-muted);
  max-width: 680px;
  margin: 0;
  line-height: 1.7;
}
.pix-highlight-list {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 20px;
}
.pix-highlight-item {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  border-radius: 999px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.07);
  color: var(--text-main);
  font-size: 13px;
}
.pix-highlight-item i {
  color: var(--neon-green);
}
.pix-hero-badge {
  align-self: stretch;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 10px;
  padding: 24px;
  border-radius: 24px;
  background: radial-gradient(circle at top, rgba(0,200,255,.14), rgba(255,255,255,.03));
  border: 1px solid rgba(0,200,255,.18);
  text-align: left;
}
.pix-hero-badge-icon {
  width: 56px;
  height: 56px;
  border-radius: 18px;
  display: grid;
  place-items: center;
  background: rgba(255,255,255,.08);
  color: var(--blue);
  font-size: 22px;
}
.pix-hero-badge strong {
  font-family: 'Orbitron', sans-serif;
  font-size: 14px;
}
.pix-hero-badge span {
  color: var(--text-muted);
  line-height: 1.6;
}
.pix-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(320px, .9fr);
  gap: 24px;
}
.pix-card {
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.025));
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 28px;
  padding: 24px;
  box-shadow: 0 20px 50px rgba(0,0,0,.22);
}
.pix-card h2 {
  font-family: 'Orbitron', sans-serif;
  font-size: 18px;
  margin-bottom: 0;
}
.pix-card-main {
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.pix-card-side {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.pix-card-header {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: flex-start;
}
.pix-kicker {
  display: inline-block;
  margin-bottom: 8px;
  color: var(--blue);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .12em;
  font-weight: 700;
}
.pix-status-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 38px;
  padding: 8px 14px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 700;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.05);
  color: var(--text-muted);
  white-space: nowrap;
}
.pix-status-pill.pending {
  color: #ffdc7b;
  border-color: rgba(255,220,123,.25);
  background: rgba(255,220,123,.08);
}
.pix-status-pill.paid {
  color: var(--green);
  border-color: rgba(57,255,20,.25);
  background: rgba(57,255,20,.08);
}
.pix-qr-wrap {
  display: grid;
  place-items: center;
  min-height: 420px;
  padding: 28px;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 24px;
  background:
    radial-gradient(circle at top, rgba(0,200,255,.08), transparent 35%),
    rgba(255,255,255,.02);
}
.pix-copy-card {
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
}
.pix-summary-card {
  padding: 18px;
}
.pix-info-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}
.pix-info-card {
  min-height: 112px;
  background: rgba(255,255,255,.035);
}
.pix-tip-card {
  background: linear-gradient(180deg, rgba(0,200,255,.06), rgba(255,255,255,.02));
}
.pix-tip-list {
  display: grid;
  gap: 12px;
}
.pix-tip-item {
  display: grid;
  grid-template-columns: 28px 1fr;
  gap: 12px;
  align-items: start;
}
.pix-tip-item span {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  background: rgba(57,255,20,.12);
  color: var(--green);
  font-size: 12px;
  font-weight: 700;
}
.pix-tip-item p {
  color: var(--text-muted);
  line-height: 1.5;
  margin: 0;
}
.pix-empty-state {
  text-align: center;
  padding: 42px 24px;
  background: rgba(255,255,255,.03);
  border: 1px solid var(--border);
  border-radius: 24px;
}
.pix-empty-state h2 {
  font-family: 'Orbitron', sans-serif;
  font-size: 24px;
  margin-bottom: 12px;
}
.pix-empty-state p {
  color: var(--text-muted);
  margin-bottom: 20px;
}

/* ─── TOAST ──────────────────────────────── */
.toast {
  position: fixed; bottom: 24px; left: 50%; transform: translateX(-50%) translateY(80px);
  background: rgba(13,13,34,.95); border: 1px solid var(--neon-purple);
  color: var(--text-main);
  padding: 12px 24px; border-radius: 12px;
  display: flex; align-items: center; gap: 10px;
  font-size: 15px; font-weight: 600;
  box-shadow: var(--glow-purple);
  transition: transform .4s cubic-bezier(.25,.8,.25,1);
  z-index: 4000;
}
.toast i { color: var(--neon-green); font-size: 18px; }
.toast.show { transform: translateX(-50%) translateY(0); }

/* ─── ANIMAÇÕES ──────────────────────────── */
@keyframes fadeDown  { from { opacity:0; transform:translateY(-20px);} to{opacity:1;transform:translateY(0);} }
@keyframes fadeLeft  { from { opacity:0; transform:translateX(-30px);} to{opacity:1;transform:translateX(0);} }
@keyframes fadeIn    { from { opacity:0; } to { opacity:1; } }

/* ─── RESPONSIVO ─────────────────────────── */
@media (max-width: 1080px) {
  .bilhetes-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .hero-image { position: static; transform: none; width: 200px; height: 200px; }
  .hero {
    min-height: auto;
    flex-direction: column;
    align-items: center;
  .account-grid { gap: 18px; }
    text-align: center;
    gap: 28px;
    padding: 140px 24px 36px;
  }
  .hero-desc { max-width: 100%; }
  .hero-btns { justify-content: center; }
  .hero-stats { justify-content: center; }
  .controller-wrap { width: 200px; height: 200px; }
  .controller-icon { font-size: 70px; }
  .footer-top { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 768px) {
  .bilhetes-grid { grid-template-columns: 1fr; gap: 22px; }
  .card-img { height: 220px; }
  .card-body h4 { font-size: 15px; }
  .card-body p { font-size: 14px; }
  .card-price { font-size: 22px; }
  .hero { padding: 150px 16px 28px; gap: 24px; }
  .hero-badge { padding-top: 11px; margin-top: 0; }
  .hero-title { padding-top: 6px; }
  .checkout-layout { grid-template-columns: 1fr; padding: 8px 16px 16px; }
  .checkout-main, .checkout-summary { padding: 20px; }
  .checkout-row, .checkout-row-sm, .checkout-methods, .pix-grid, .pix-info-grid, .pix-hero { grid-template-columns: 1fr; }
  .nav-links { display: none; position: fixed; top: 70px; left: 0; right: 0;
    background: rgba(6,6,16,.98); border-bottom: 1px solid var(--border);
    flex-direction: column; padding: 24px;
    text-align: center; gap: 20px; z-index: 999; }
  .nav-links.open { display: flex; }
  .btn-menu { display: block; }
  .account-grid { grid-template-columns: 1fr; }
  .account-login-card { position: static; }
  .account-stats, .account-ticket-meta { grid-template-columns: 1fr; }
  .contato-grid { grid-template-columns: 1fr; }
  .footer-top { grid-template-columns: 1fr; }
  .promo-banner { margin: 0 12px; padding: 40px 24px; }
  .cart-sidebar { width: 100%; }
  .hero-title .line1, .hero-title .line2, .hero-title .line3 { font-size: clamp(40px,12vw,72px); }
  .pix-card-header, .pix-topbar { align-items: stretch; }
  .pix-status-pill { justify-content: flex-start; }
}
@media (max-width: 480px) {
  .card-img { height: 210px; }
  .card-footer { align-items: stretch; }
  .qty-control { width: 100%; justify-content: center; }
  .btn-comprar { width: 100%; }
  .ranking-carousel-wrap { padding: 8px 0 16px; }
  section { padding: 60px 16px; }
  .hero { padding-top: 156px; }
  .account-panel-card, .account-login-card { padding: 22px 18px; }
  .checkout-shell { width: calc(100vw - 16px); max-height: calc(100vh - 16px); }
  .checkout-title { font-size: 22px; }
  .checkout-close { top: 8px; margin-right: 8px; margin-top: 8px; }
  .pix-page { padding: 18px 12px 36px; }
  .pix-card { padding: 18px; }
  .pix-highlight-item { width: 100%; justify-content: flex-start; border-radius: 16px; }
  .pix-qr-wrap { min-height: auto; padding: 18px; }
}
