:root{
  /* Primary UI color. If not overridden via settings, default to bright blue for better contrast */
  --qrmg-primary: #0ea5e9;
  /* Default effect colors; admins can override via custom CSS or settings */
  --qrmg-effect-snow: #ffffff;
  --qrmg-effect-petal-1: #ff8fb1;
  --qrmg-effect-petal-2: #ffc6d9;
  --qrmg-effect-confetti-1: #ff6b6b;
  --qrmg-effect-confetti-2: #ffd166;
  --qrmg-effect-confetti-3: #06d6a0;
}

.qrmg-wrap{max-width:480px;margin:16px auto;padding:12px;border-radius:16px;box-shadow:0 10px 30px rgba(0,0,0,.08);position:relative;overflow:visible}
.qrmg-stage{position:relative;width:100%;padding-top:100%}
.qrmg-wheel{position:absolute;inset:0;background-size:contain;background-position:center;background-repeat:no-repeat;border-radius:50%;will-change:transform;transform:rotate(0deg);}
.qrmg-wheel.qrmg-shine{overflow:hidden}
.qrmg-wheel.qrmg-shine::after{content:"";position:absolute;inset:-50%;background:linear-gradient(75deg, rgba(255,255,255,0) 30%, rgba(255,255,255,.35) 50%, rgba(255,255,255,0) 70%);transform:translateX(-120%) rotate(25deg);animation:qrmg-sweep 1.6s linear infinite}
@keyframes qrmg-sweep{0%{transform:translateX(-120%) rotate(25deg)}100%{transform:translateX(120%) rotate(25deg)}}
.qrmg-pointer{position:absolute;left:50%;top:var(--qrmg-pointer-offset, -60px);transform:translateX(-50%);width:64px;height:64px;background-size:contain;background-repeat:no-repeat;background-position:center;z-index:2}
.qrmg-form{margin-top:12px;display:flex;gap:8px;flex-wrap:wrap}
.qrmg-form input{flex:1;min-width:120px;padding:10px 12px;border:1px solid #ddd;border-radius:12px}
.qrmg-form button{padding:10px 16px;border:0;border-radius:12px;background:var(--qrmg-primary,#111);color:#fff;cursor:pointer;transition:background-color .2s}
.qrmg-popup{position:fixed;inset:0;background:var(--qrmg-modal-overlay, rgba(0,0,0,.4));display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:all .2s}
.qrmg-popup.show{opacity:1;pointer-events:auto}
.qrmg-popup .box{background:var(--qrmg-modal-bg, #fff);color:var(--qrmg-modal-text,#111);max-width:360px;width:92%;padding:20px;border-radius:var(--qrmg-modal-radius,16px);text-align:center;box-shadow:0 10px 24px rgba(0,0,0,.15);background-image:var(--qrmg-modal-bg-image, none);background-size:cover;background-position:center;}
.qrmg-close{margin-top:12px;background:#efefef;border:0;border-radius:10px;padding:8px 12px;cursor:pointer}
.qrmg-toast{position:fixed;left:50%;bottom:24px;transform:translateX(-50%) scale(.95);background:var(--qrmg-primary,#111);color:#fff;padding:8px 12px;border-radius:10px;opacity:0;transition:all .2s;z-index:9999}
.qrmg-toast.show{opacity:1;transform:translateX(-50%) scale(1)}
.qrmg-confetti{position:absolute;inset:0;pointer-events:none}
.qrmg-code{font:600 20px/1.2 ui-monospace, SFMono-Regular, Menlo, monospace; padding:8px 10px; background:#f6f6f6; border-radius:10px; margin-bottom:10px}
.qrmg-btn{display:inline-block; padding:10px 14px; border-radius:10px; background:var(--qrmg-primary,#111); color:#fff; text-decoration:none; border:0; cursor:pointer; transition:background-color .2s}

/* Glow animation for winning state */
@keyframes qrmgGlow {
  0% { box-shadow: 0 0 0 rgba(255,255,255,0.0); }
  50%{ box-shadow: 0 0 30px rgba(255,255,255,0.55); }
  100%{ box-shadow: 0 0 0 rgba(255,255,255,0.0); }
}
.qrmg-wrap.qrmg-glow{
  animation: qrmgGlow 2s ease-out 1;
}

/* Fly‑out label for prize */
.qrmg-flyout{
  position:absolute;
  left:50%;
  top:50%;
  transform:translate(-50%,-50%) scale(0.6);
  padding:10px 16px;
  background:var(--qrmg-flyout-bg,#fff);
  color:var(--qrmg-flyout-text,#111);
  border-radius:999px;
  font-weight:700;
  pointer-events:none;
  z-index:50;
  opacity:0;
}

/* Prevent mobile zoom on focus */
.qrmg-wrap input[type=text],
.qrmg-wrap input[type=tel],
.qrmg-wrap input[type=email],
.qrmg-wrap input[type=number],
.qrmg-wrap select,
.qrmg-wrap textarea{font-size:16px;}

/* === Pointer angle & jitter (restored) === */
.qrmg-pointer-wrap{position:absolute;inset:0;transform:rotate(var(--qrmg-pointer-angle,90deg));transform-origin:50% 50%;pointer-events:none}
.qrmg-pointer{transform:translateX(-50%);transform-origin:50% 10%}
.qrmg-pointer.qrmg-jitter{animation:qrmg-pointer-jitter 90ms ease-out}
@keyframes qrmg-pointer-jitter{
  0%{transform:translateX(-50%) rotate(0deg)}
  40%{transform:translateX(-50%) rotate(12deg)}
  80%{transform:translateX(-50%) rotate(-12deg)}
  100%{transform:translateX(-50%) rotate(0deg)}
}
