:root{
  --bg:#030c2a;
  --bg2:#041c55;
  --text:#eefbff;
  --muted:rgba(238,251,255,.72);
  --line:rgba(101,242,255,.28);
  --brand:#65f2ff;
  --brand2:#0a7bff;
  --shadow:0 34px 110px rgba(0,0,0,.42),0 0 58px rgba(0,154,255,.13);
  --font:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
}

*{box-sizing:border-box}
html,body{margin:0;min-height:100%;width:100%;max-width:100%;background:var(--bg);color:var(--text);font-family:var(--font);overflow-x:hidden;overscroll-behavior-x:none}
html{touch-action:pan-y}
body{
  position:relative;
  background:
    radial-gradient(circle at 12% 0,rgba(101,242,255,.19),transparent 34rem),
    radial-gradient(circle at 94% 20%,rgba(10,123,255,.22),transparent 30rem),
    linear-gradient(180deg,#030c2a 0%,#061133 56%,#020716 100%);
}
button{font:inherit}

.page{
  min-height:100vh;
  min-height:100dvh;
  width:100%;
  max-width:100%;
  overflow-x:hidden;
  display:grid;
  place-items:center;
  padding:clamp(16px,4vw,42px);
}

.roleta-card{
  position:relative;
  width:min(1180px,100%);
  max-width:100%;
  padding:clamp(18px,4vw,42px);
  border:1px solid rgba(101,242,255,.34);
  border-radius:34px;
  background:
    radial-gradient(circle at 50% 0,rgba(101,242,255,.14),transparent 34%),
    linear-gradient(135deg,rgba(3,12,42,.94),rgba(4,28,85,.70));
  box-shadow:var(--shadow);
  isolation:isolate;
  overflow:hidden;
}

.roleta-stage{
  position:relative;
  z-index:2;
  display:grid;
  gap:clamp(18px,3vw,30px);
  justify-items:center;
}

.reward-wheel-wrap{
  position:relative;
  max-width:100%;
  overflow:hidden;
  display:grid;
  place-items:center;
  width:100%;
  min-height:clamp(255px,32vw,340px);
  user-select:none;
  touch-action:manipulation;
  border-radius:34px;
  cursor:pointer;
}

.reward-wheel-wrap[aria-disabled="true"]{pointer-events:none}

.reward-wheel-shell{
  position:relative;
  display:grid;
  place-items:center;
  width:min(1060px,100%);
  max-width:100%;
  padding:clamp(28px,3vw,42px) 0;
  border-radius:36px;
  background:
    radial-gradient(circle at 50% 0,rgba(101,242,255,.24),transparent 34%),
    linear-gradient(180deg,rgba(3,12,42,.86),rgba(4,28,85,.58));
  filter:drop-shadow(0 30px 48px rgba(0,0,0,.42)) drop-shadow(0 0 24px rgba(0,200,255,.18));
}

.reward-wheel-shell::before{
  content:"";
  position:absolute;
  inset:-10px;
  border-radius:40px;
  border:1px solid rgba(101,242,255,.32);
  background:
    linear-gradient(90deg,rgba(0,200,255,.16),transparent 28%,transparent 72%,rgba(0,200,255,.16)),
    linear-gradient(135deg,rgba(101,242,255,.14),rgba(7,62,168,.08));
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.06),0 0 28px rgba(0,200,255,.16);
}

.reward-wheel-viewport{
  position:relative;
  width:min(990px,100%);
  max-width:100%;
  min-height:clamp(230px,24vw,300px);
  overflow:hidden;
  padding:clamp(30px,3vw,44px) 0;
  border:1px solid rgba(101,242,255,.22);
  border-radius:30px;
  background:
    linear-gradient(90deg,rgba(1,16,56,.94),rgba(5,42,120,.36) 50%,rgba(1,16,56,.94)),
    rgba(0,0,0,.18);
  box-shadow:inset 0 0 32px rgba(0,0,0,.30);
}

.reward-wheel-viewport::before,
.reward-wheel-viewport::after{
  content:"";
  position:absolute;
  top:0;
  bottom:0;
  z-index:4;
  pointer-events:none;
}
.reward-wheel-viewport::before{left:0;width:20%;background:linear-gradient(90deg,rgba(1,16,56,.98),transparent)}
.reward-wheel-viewport::after{right:0;width:20%;background:linear-gradient(270deg,rgba(1,16,56,.98),transparent)}

.reward-pointer{
  position:absolute;
  top:4px;
  left:50%;
  width:58px;
  height:68px;
  transform:translateX(-50%);
  background:transparent;
  filter:drop-shadow(0 8px 16px rgba(0,0,0,.54)) drop-shadow(0 0 16px rgba(101,242,255,.56));
  z-index:8;
  pointer-events:none;
}
.reward-pointer::before{
  content:"";
  position:absolute;
  left:50%;
  top:0;
  width:42px;
  height:42px;
  border-radius:14px 14px 14px 4px;
  transform:translateX(-50%) rotate(45deg);
  background:linear-gradient(135deg,#eaffff,#65f2ff 42%,#0a7bff 100%);
  box-shadow:0 0 24px rgba(101,242,255,.58);
}
.reward-pointer::after{
  content:"";
  position:absolute;
  left:50%;
  top:18px;
  width:6px;
  height:190px;
  border-radius:999px;
  transform:translateX(-50%);
  background:linear-gradient(180deg,#fff,rgba(101,242,255,.92),rgba(101,242,255,.04));
  box-shadow:0 0 18px rgba(101,242,255,.58);
}

.reward-wheel{
  position:relative;
  z-index:2;
  width:max-content;
  background:transparent!important;
  transition:transform 4.9s cubic-bezier(.08,.76,.13,1);
  will-change:transform;
}
.reward-wheel--no-transition{transition:none!important}

.reward-wheel-labels{
  display:flex;
  align-items:stretch;
  gap:clamp(10px,1.45vw,18px);
  padding:0 clamp(32px,4vw,58px);
  transform:translateZ(0);
}

.reward-prize-card{
  position:relative;
  flex:0 0 clamp(122px,15.4vw,176px);
  width:clamp(122px,15.4vw,176px);
  min-height:clamp(155px,18vw,214px);
  display:grid;
  place-items:center;
  gap:10px;
  padding:clamp(12px,1.5vw,18px);
  border:1px solid rgba(101,242,255,.28);
  border-radius:26px;
  background:
    radial-gradient(circle at 50% 0,rgba(101,242,255,.24),transparent 48%),
    linear-gradient(180deg,rgba(255,255,255,.10),rgba(255,255,255,.03));
  box-shadow:0 18px 38px rgba(0,0,0,.30),inset 0 1px 0 rgba(255,255,255,.08);
  overflow:hidden;
}
.reward-prize-card::before{
  content:"";
  position:absolute;
  inset:1px;
  border-radius:24px;
  background:linear-gradient(135deg,rgba(255,255,255,.12),transparent 44%,rgba(101,242,255,.10));
  pointer-events:none;
}
.reward-prize-card.is-special{
  border-color:rgba(255,255,255,.48);
  box-shadow:0 20px 45px rgba(0,0,0,.34),0 0 28px rgba(101,242,255,.24),inset 0 1px 0 rgba(255,255,255,.14);
}
.reward-prize-card.is-selected{
  border-color:rgba(255,255,255,.80);
  box-shadow:0 26px 60px rgba(0,0,0,.42),0 0 36px rgba(101,242,255,.46),inset 0 0 0 1px rgba(255,255,255,.16);
}
.reward-prize-card img{
  position:relative;
  z-index:2;
  width:100%;
  max-width:128px;
  height:clamp(72px,8.2vw,110px);
  object-fit:contain;
  filter:drop-shadow(0 14px 16px rgba(0,0,0,.30));
}
.reward-prize-name{
  position:relative;
  z-index:2;
  min-height:36px;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  color:#fff;
  font-size:clamp(.78rem,1.1vw,.98rem);
  font-weight:1000;
  line-height:1.06;
  letter-spacing:-.02em;
  text-shadow:0 0 14px rgba(101,242,255,.18);
}

.btn{
  min-height:52px;
  padding:0 28px;
  border:1px solid rgba(101,242,255,.36);
  border-radius:999px;
  background:rgba(255,255,255,.06);
  color:var(--text);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-weight:950;
  cursor:pointer;
  transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease,opacity .18s ease;
}
.btn:hover{transform:translateY(-1px);border-color:rgba(101,242,255,.70);box-shadow:0 16px 34px rgba(0,0,0,.24)}
.btn:disabled{opacity:.72;cursor:not-allowed;transform:none;box-shadow:none}
.btn-primary{
  border-color:rgba(101,242,255,.45);
  background:linear-gradient(135deg,#00c8ff,#0a7bff 62%,#073ea8);
  box-shadow:0 20px 54px rgba(0,123,255,.36);
}

@keyframes selectedPulse{
  0%,100%{transform:translateY(0) scale(1)}
  50%{transform:translateY(-5px) scale(1.035)}
}
.reward-wheel.is-celebrating .reward-prize-card.is-selected{animation:selectedPulse .72s ease-in-out 2}

@media (max-width:720px){
  .page{padding:12px}
  .roleta-card{padding:14px;border-radius:26px}
  .reward-wheel-wrap{min-height:225px}
  .reward-wheel-shell{padding:20px 0;border-radius:28px}
  .reward-wheel-viewport{min-height:178px;padding:22px 0;border-radius:24px}
  .reward-prize-card{flex-basis:106px;width:106px;min-height:144px;border-radius:22px;padding:10px}
  .reward-prize-card img{height:64px}
  .reward-prize-name{font-size:.74rem}
  .reward-pointer{top:2px;width:48px;height:58px}
  .reward-pointer::before{width:34px;height:34px;border-radius:11px 11px 11px 3px}
  .reward-pointer::after{top:15px;height:146px}
  .btn{width:min(100%,320px)}
}

@media (max-width:420px){
  .reward-wheel-viewport{min-height:162px;padding:20px 0}
  .reward-prize-card{flex-basis:96px;width:96px;min-height:132px}
  .reward-prize-card img{height:56px}
  .reward-pointer::after{height:126px}
}

@media (prefers-reduced-motion:reduce){
  .reward-wheel,.reward-wheel.is-celebrating .reward-prize-card.is-selected,.redeem-bg::before,.redeem-bg::after{animation:none!important;transition:none!important}
}


.redeem-overlay{
  position:fixed;
  inset:0;
  width:100dvw;
  max-width:100dvw;
  min-height:100dvh;
  overflow:hidden;
  overscroll-behavior:contain;
  touch-action:pan-y;
  z-index:99;
  display:grid;
  place-items:center;
  padding:clamp(18px,4vw,44px);
  opacity:0;
  visibility:hidden;
  pointer-events:none;
  transition:opacity .35s ease,visibility .35s ease;
}
.redeem-overlay.is-visible{
  opacity:1;
  visibility:visible;
  pointer-events:auto;
}
.redeem-bg{
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 50% 35%,rgba(101,242,255,.24),transparent 18rem),
    radial-gradient(circle at 18% 20%,rgba(10,123,255,.32),transparent 24rem),
    radial-gradient(circle at 86% 70%,rgba(101,242,255,.18),transparent 22rem),
    rgba(1,6,23,.94);
  backdrop-filter:blur(14px);
}
.redeem-bg::before,
.redeem-bg::after{
  content:"";
  position:absolute;
  inset:-20%;
  background:
    repeating-conic-gradient(from 0deg,rgba(101,242,255,.16) 0deg,transparent 7deg,transparent 18deg);
  animation:redeemSpin 12s linear infinite;
  opacity:.35;
}
.redeem-bg::after{
  animation-duration:18s;
  animation-direction:reverse;
  opacity:.18;
}
.redeem-modal{
  position:relative;
  max-width:100%;
  z-index:2;
  width:min(720px,100%);
  min-height:min(640px,82vh);
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:clamp(14px,2vw,22px);
  padding:clamp(24px,5vw,56px);
  border:1px solid rgba(101,242,255,.50);
  border-radius:34px;
  text-align:center;
  background:
    radial-gradient(circle at 50% 0,rgba(101,242,255,.24),transparent 38%),
    linear-gradient(145deg,rgba(3,12,42,.95),rgba(4,28,85,.88));
  box-shadow:0 34px 110px rgba(0,0,0,.62),0 0 58px rgba(0,200,255,.22),inset 0 1px 0 rgba(255,255,255,.10);
  transform:translateY(20px) scale(.96);
  transition:transform .35s ease;
  overflow:hidden;
}
.redeem-overlay.is-visible .redeem-modal{
  transform:translateY(0) scale(1);
}
.redeem-modal::before{
  content:"";
  position:absolute;
  inset:1px;
  border-radius:32px;
  background:linear-gradient(135deg,rgba(255,255,255,.12),transparent 42%,rgba(101,242,255,.14));
  pointer-events:none;
}
.redeem-badge{
  position:relative;
  z-index:2;
  display:inline-flex;
  align-items:center;
  min-height:34px;
  padding:0 16px;
  border:1px solid rgba(101,242,255,.44);
  border-radius:999px;
  color:#eaffff;
  background:rgba(101,242,255,.10);
  font-size:.78rem;
  font-weight:1000;
  letter-spacing:.12em;
}
.redeem-modal h2{
  position:relative;
  z-index:2;
  margin:0;
  color:#fff;
  font-size:clamp(2.3rem,8vw,5.8rem);
  font-weight:1000;
  line-height:.92;
  text-shadow:0 0 22px rgba(101,242,255,.36),0 18px 42px rgba(0,0,0,.44);
}
.redeem-prize-image-wrap{
  position:relative;
  z-index:2;
  width:min(270px,64vw);
  aspect-ratio:1/1;
  display:grid;
  place-items:center;
  border-radius:34px;
  border:1px solid rgba(101,242,255,.28);
  background:linear-gradient(180deg,rgba(255,255,255,.11),rgba(255,255,255,.03));
  box-shadow:0 22px 58px rgba(0,0,0,.34),0 0 26px rgba(101,242,255,.20);
}
.redeem-prize-image-wrap img{
  width:88%;
  height:88%;
  object-fit:contain;
  filter:drop-shadow(0 18px 20px rgba(0,0,0,.30));
}
.redeem-prize-name{
  position:relative;
  z-index:2;
  margin:0;
  color:#fff;
  font-size:clamp(1.35rem,4.6vw,3rem);
  font-weight:1000;
  line-height:1.02;
  text-shadow:0 0 18px rgba(101,242,255,.28);
}
.redeem-button{
  position:relative;
  z-index:2;
  min-height:60px;
  padding:0 clamp(28px,6vw,54px);
  font-size:clamp(1rem,2vw,1.2rem);
  text-transform:uppercase;
}
.redeem-help{
  position:relative;
  z-index:2;
  margin:0;
  color:var(--muted);
  font-size:.95rem;
}

@keyframes redeemSpin{
  to{transform:rotate(360deg)}
}

/* Arte acima da roleta configurável pelo .env */
.top-art-slot{
  position:relative;
  width:min(1100px,100%);
  display:none;
  place-items:center;
  overflow:hidden;
  border:0;
  border-radius:30px;
  background:transparent;
  box-shadow:0 22px 54px rgba(0,0,0,.24);
}
.top-art-slot.has-image{
  display:grid;
}
.top-art-slot[hidden]{
  display:none!important;
}
.top-art-slot img{
  display:block;
  width:100%;
  max-width:100%;
  height:auto;
  max-height:clamp(230px,42vw,560px);
  object-fit:contain;
  padding:0;
  border-radius:30px;
  filter:drop-shadow(0 22px 26px rgba(0,0,0,.28));
}

/* Pop-up de resgate com tutorial lateral */
.redeem-shell{
  position:relative;
  max-width:100%;
  min-width:0;
  z-index:2;
  width:min(1180px,100%);
  max-height:calc(100dvh - 44px);
  display:grid;
  grid-template-columns:1fr;
  gap:clamp(14px,2vw,22px);
  align-items:stretch;
  overflow:auto;
  overflow-x:hidden;
  scrollbar-width:thin;
}
.redeem-shell.has-tutorial{
  grid-template-columns:minmax(320px,1fr) minmax(290px,.72fr);
}
.redeem-shell .redeem-modal{
  width:100%;
  min-height:min(620px,calc(100dvh - 48px));
}
.redeem-shell.has-tutorial .redeem-modal{
  min-height:0;
}
.redeem-tutorial-card{
  position:relative;
  z-index:2;
  min-width:0;
  display:flex;
  flex-direction:column;
  gap:14px;
  padding:clamp(22px,3.8vw,34px);
  border:1px solid rgba(101,242,255,.40);
  border-radius:34px;
  background:
    radial-gradient(circle at 50% 0,rgba(101,242,255,.22),transparent 36%),
    linear-gradient(145deg,rgba(3,12,42,.96),rgba(4,28,85,.90));
  box-shadow:0 34px 110px rgba(0,0,0,.50),0 0 42px rgba(0,200,255,.16),inset 0 1px 0 rgba(255,255,255,.10);
  overflow:hidden;
}
.redeem-tutorial-card[hidden]{display:none!important}
.redeem-tutorial-card::before{
  content:"";
  position:absolute;
  inset:1px;
  border-radius:32px;
  pointer-events:none;
  background:linear-gradient(135deg,rgba(255,255,255,.10),transparent 42%,rgba(101,242,255,.12));
}
.redeem-tutorial-card > *{position:relative;z-index:2}
.redeem-tutorial-card h3{
  margin:0;
  color:#fff;
  font-size:clamp(1.45rem,3.4vw,2.45rem);
  line-height:.98;
  font-weight:1000;
  letter-spacing:-.045em;
  text-shadow:0 0 18px rgba(101,242,255,.24);
}
.redeem-tutorial-card p{
  margin:0;
  color:rgba(238,251,255,.76);
  line-height:1.42;
  font-weight:750;
}
.reward-tutorial-gallery{
  display:grid;
  grid-template-columns:1fr;
  gap:12px;
}
.reward-tutorial-shot{
  appearance:none;
  width:100%;
  padding:8px;
  border:1px solid rgba(101,242,255,.28);
  border-radius:22px;
  background:linear-gradient(180deg,rgba(255,255,255,.08),rgba(255,255,255,.025));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.06),0 12px 26px rgba(0,0,0,.22);
  color:#fff;
  cursor:pointer;
  text-align:left;
  transition:transform .2s ease,border-color .2s ease,box-shadow .2s ease;
}
.reward-tutorial-shot:hover,
.reward-tutorial-shot:focus-visible{
  transform:translateY(-2px);
  border-color:rgba(101,242,255,.72);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08),0 16px 38px rgba(0,0,0,.28),0 0 24px rgba(101,242,255,.18);
  outline:none;
}
.reward-tutorial-shot img{
  display:block;
  width:100%;
  max-height:260px;
  object-fit:contain;
  border-radius:16px;
  background:rgba(0,0,0,.22);
}
.reward-tutorial-shot span{
  display:block;
  padding:9px 8px 4px;
  color:#eaffff;
  font-size:.88rem;
  font-weight:950;
  line-height:1.15;
}
.reward-tutorial-shot span::after{
  content:" · toque para ampliar";
  color:rgba(238,251,255,.62);
  font-weight:850;
}

/* Tutorial em tela cheia */
.reward-tutorial-lightbox{
  position:fixed;
  inset:0;
  z-index:180;
  display:grid;
  place-items:center;
  padding:clamp(12px,2vw,24px);
  background:rgba(0,0,0,.86);
  backdrop-filter:blur(14px);
  overflow:auto;
}
.reward-tutorial-lightbox[hidden]{display:none!important}
.reward-tutorial-lightbox-card{
  width:min(960px,100%);
  min-height:min(760px,calc(100dvh - 48px));
  display:grid;
  grid-template-rows:auto auto minmax(0,1fr) auto;
  gap:12px;
  padding:clamp(16px,2.8vw,28px);
  border:1px solid rgba(101,242,255,.34);
  border-radius:32px;
  background:radial-gradient(circle at 50% 0,rgba(101,242,255,.18),transparent 36%),linear-gradient(180deg,rgba(3,31,82,.98),rgba(3,12,42,.99));
  box-shadow:0 34px 110px rgba(0,0,0,.58),0 0 42px rgba(0,200,255,.14);
  text-align:center;
}
.reward-tutorial-lightbox-card h2{
  margin:0;
  color:#fff;
  font-size:clamp(1.35rem,4vw,2.5rem);
  line-height:1;
  letter-spacing:-.045em;
}
.reward-tutorial-lightbox-figure{
  min-height:0;
  margin:0;
  padding:10px;
  border:1px solid rgba(101,242,255,.22);
  border-radius:24px;
  background:rgba(0,0,0,.24);
  display:grid;
  place-items:center;
}
.reward-tutorial-lightbox-figure img{
  display:block;
  max-width:100%;
  max-height:calc(100dvh - 230px);
  width:auto;
  height:auto;
  object-fit:contain;
  border-radius:16px;
}
.reward-tutorial-lightbox-close{
  position:fixed;
  top:clamp(12px,2vw,22px);
  right:clamp(12px,2vw,22px);
  z-index:181;
  width:46px;
  height:46px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.22);
  background:rgba(3,12,42,.78);
  color:#fff;
  font-size:1.7rem;
  box-shadow:0 14px 34px rgba(0,0,0,.34);
  cursor:pointer;
}
.reward-tutorial-lightbox-controls{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:10px;
}
.reward-tutorial-lightbox-controls .btn{min-width:118px;justify-content:center}

@media (max-width:980px){
  .redeem-overlay{align-items:start;overflow:auto}
  .redeem-shell,
  .redeem-shell.has-tutorial{grid-template-columns:1fr;width:min(720px,100%);max-height:none}
  .redeem-shell .redeem-modal{min-height:0}
  .redeem-tutorial-card{text-align:center}
  .reward-tutorial-gallery{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width:620px){
  .top-art-slot{border-radius:22px}
  .top-art-slot img{max-height:320px;border-radius:22px}
  .reward-tutorial-gallery{grid-template-columns:1fr}
  .reward-tutorial-shot span::after{content:""}
  .reward-tutorial-lightbox{padding:10px}
  .reward-tutorial-lightbox-card{min-height:calc(100dvh - 20px);border-radius:24px;padding:16px 12px}
  .reward-tutorial-lightbox-figure img{max-height:calc(100dvh - 215px)}
  .reward-tutorial-lightbox-controls{display:grid;grid-template-columns:1fr 1fr;width:100%}
  .reward-tutorial-lightbox-controls .btn{min-width:0;width:100%}
}

@media (prefers-reduced-motion:reduce){
  .reward-tutorial-shot{transition:none!important}
}


/* Correções finais: fluxo sem telefone e sem vazamento lateral no mobile */
body.redeem-open,
body.tutorial-lightbox-open{
  overflow:hidden!important;
  width:100%!important;
  max-width:100%!important;
  touch-action:pan-y;
}
body.redeem-open .page{
  pointer-events:none;
  user-select:none;
}
.redeem-overlay.is-visible,
.reward-tutorial-lightbox:not([hidden]){
  overflow-x:hidden!important;
}
.redeem-shell,
.redeem-modal,
.redeem-tutorial-card,
.reward-tutorial-lightbox-card{
  box-sizing:border-box;
  max-width:100%;
}
img,canvas,svg,video{
  max-width:100%;
}
@media (max-width:620px){
  html,body{overflow-x:hidden!important}
  .page{padding:10px;place-items:start center}
  .redeem-overlay{align-items:start;justify-items:center;padding:10px;width:100vw;max-width:100vw}
  .redeem-shell{width:100%;max-width:100%;max-height:calc(100dvh - 20px);padding:0;overflow-y:auto;overflow-x:hidden}
  .redeem-shell.has-tutorial{grid-template-columns:1fr}
  .redeem-modal{width:100%;min-height:auto;border-radius:26px;padding:22px 14px}
  .redeem-prize-image-wrap{width:min(220px,58vw);border-radius:26px}
  .redeem-tutorial-card{width:100%;border-radius:26px;padding:18px 14px}
}



/* Ajuste mobile v15: telas mais compactas, sem vazamento lateral e com melhor encaixe no celular */
html,
body{
  width:100%;
  max-width:100%;
  overflow-x:hidden!important;
}

.page,
.roleta-card,
.roleta-stage,
.reward-wheel-wrap,
.reward-wheel-shell,
.reward-wheel-viewport,
.redeem-overlay,
.redeem-shell,
.redeem-modal,
.redeem-tutorial-card,
.reward-tutorial-lightbox,
.reward-tutorial-lightbox-card{
  max-width:100%;
  box-sizing:border-box;
}

@media (max-width:768px){
  .page{
    min-height:100dvh;
    padding:10px;
    place-items:start center;
  }

  .roleta-card{
    width:100%;
    padding:12px;
    border-radius:24px;
  }

  .roleta-stage{
    gap:14px;
  }

  .top-art-slot{
    width:100%;
    border-radius:20px;
  }

  .top-art-slot img{
    width:100%;
    max-height:230px;
    object-fit:contain;
    border-radius:20px;
  }

  .reward-wheel-wrap{
    width:100%;
    min-height:clamp(170px,54vw,235px);
    border-radius:24px;
    overflow:hidden;
  }

  .reward-wheel-shell{
    width:100%;
    padding:14px 0;
    border-radius:24px;
  }

  .reward-wheel-shell::before{
    inset:-5px;
    border-radius:28px;
  }

  .reward-wheel-viewport{
    width:100%;
    min-height:clamp(142px,44vw,185px);
    padding:16px 0;
    border-radius:22px;
  }

  .reward-wheel-viewport::before,
  .reward-wheel-viewport::after{
    width:13%;
  }

  .reward-wheel-labels{
    gap:8px;
    padding:0 22px;
  }

  .reward-prize-card{
    flex:0 0 clamp(82px,25vw,108px);
    width:clamp(82px,25vw,108px);
    min-height:clamp(112px,34vw,142px);
    padding:8px;
    border-radius:18px;
    gap:6px;
  }

  .reward-prize-card::before{
    border-radius:16px;
  }

  .reward-prize-card img{
    max-width:72px;
    height:clamp(44px,14vw,62px);
  }

  .reward-prize-name{
    font-size:clamp(.60rem,2.65vw,.74rem);
    line-height:1.12;
    overflow-wrap:anywhere;
  }

  .reward-pointer{
    top:0;
    width:42px;
    height:48px;
  }

  .reward-pointer::before{
    width:30px;
    height:30px;
    border-radius:10px 10px 10px 3px;
  }

  .reward-pointer::after{
    top:13px;
    width:4px;
    height:clamp(108px,36vw,150px);
  }

  .btn{
    width:100%;
    max-width:330px;
    min-height:52px;
    padding:0 18px;
    border-radius:16px;
    font-size:.96rem;
  }
}

@media (max-width:430px){
  .page{
    padding:8px;
  }

  .roleta-card{
    padding:10px;
    border-radius:22px;
  }

  .roleta-stage{
    gap:12px;
  }

  .reward-wheel-wrap{
    min-height:clamp(158px,58vw,214px);
  }

  .reward-wheel-shell{
    padding:12px 0;
    border-radius:22px;
  }

  .reward-wheel-viewport{
    min-height:clamp(132px,48vw,168px);
    padding:14px 0;
    border-radius:20px;
  }

  .reward-wheel-labels{
    gap:7px;
    padding:0 18px;
  }

  .reward-prize-card{
    flex-basis:clamp(76px,24vw,94px);
    width:clamp(76px,24vw,94px);
    min-height:clamp(104px,32vw,124px);
    border-radius:16px;
    padding:7px;
  }

  .reward-prize-card img{
    height:clamp(40px,13vw,52px);
  }

  .reward-prize-name{
    font-size:clamp(.56rem,2.75vw,.68rem);
  }

  .reward-pointer::after{
    height:clamp(96px,34vw,126px);
  }
}

@media (max-width:620px){
  .redeem-overlay{
    align-items:start;
    justify-items:center;
    width:100vw;
    max-width:100vw;
    min-height:100dvh;
    padding:8px;
    overflow-y:auto!important;
    overflow-x:hidden!important;
  }

  .redeem-shell,
  .redeem-shell.has-tutorial{
    width:100%;
    max-width:100%;
    max-height:none;
    grid-template-columns:1fr;
    gap:10px;
    padding:0;
    overflow:visible;
  }

  .redeem-modal{
    width:100%;
    min-height:auto;
    max-height:none;
    border-radius:22px;
    padding:16px 12px;
    gap:10px;
  }

  .redeem-modal::before{
    border-radius:20px;
  }

  .redeem-badge{
    min-height:28px;
    padding:0 10px;
    font-size:.58rem;
    letter-spacing:.08em;
    white-space:normal;
    justify-content:center;
    text-align:center;
  }

  .redeem-modal h2{
    font-size:clamp(1.65rem,8.6vw,2.45rem);
    line-height:1.02;
    max-width:100%;
  }

  .redeem-prize-image-wrap{
    width:min(156px,44vw);
    border-radius:20px;
  }

  .redeem-prize-name{
    font-size:clamp(1rem,5.2vw,1.45rem);
    line-height:1.08;
    max-width:100%;
    overflow-wrap:anywhere;
  }

  .redeem-button{
    width:100%;
    max-width:320px;
    min-height:50px;
    padding:0 14px;
    font-size:.88rem;
  }

  .redeem-help{
    font-size:.76rem;
    line-height:1.32;
    max-width:100%;
  }

  .redeem-tutorial-card{
    width:100%;
    border-radius:22px;
    padding:14px 12px;
  }

  .redeem-tutorial-card h3{
    font-size:1.12rem;
    line-height:1.1;
  }

  .redeem-tutorial-card p{
    font-size:.82rem;
  }

  .reward-tutorial-gallery{
    grid-template-columns:1fr;
    gap:10px;
  }

  .reward-tutorial-shot{
    border-radius:18px;
  }

  .reward-tutorial-lightbox{
    padding:8px;
    overflow-x:hidden!important;
  }

  .reward-tutorial-lightbox-card{
    width:100%;
    min-height:calc(100dvh - 16px);
    border-radius:22px;
    padding:14px 10px;
    gap:10px;
  }

  .reward-tutorial-lightbox-card h2{
    font-size:1.35rem;
    line-height:1.08;
  }

  .reward-tutorial-lightbox-figure img{
    max-height:calc(100dvh - 205px);
    border-radius:18px;
  }
}

@media (max-width:380px){
  .redeem-overlay{
    padding:6px;
  }

  .redeem-modal{
    padding:14px 10px;
    gap:8px;
  }

  .redeem-modal h2{
    font-size:clamp(1.45rem,8vw,2.05rem);
  }

  .redeem-prize-image-wrap{
    width:min(136px,40vw);
  }

  .redeem-prize-name{
    font-size:clamp(.95rem,4.8vw,1.25rem);
  }

  .redeem-button{
    min-height:48px;
    font-size:.82rem;
  }
}
