*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
body{margin:0;min-height:100vh;padding:16px 14px 108px;font-family:system-ui,-apple-system,"Noto Sans TC",sans-serif;color:#fff;background:radial-gradient(circle at 10% 0%,rgba(255,55,150,.48),transparent 32%),radial-gradient(circle at 95% 4%,rgba(255,134,36,.42),transparent 34%),linear-gradient(160deg,#4a073f,#210825 55%,#08030d);overflow-x:hidden}
.app{max-width:480px;margin:auto}
.hero{display:flex;justify-content:space-between;align-items:flex-start;margin:8px 2px 14px}
h1{margin:0;font-size:34px;line-height:1;font-weight:1000;letter-spacing:-1px}.sub{margin:8px 0 0;opacity:.85;font-size:15px}
.iconBtns{display:flex;gap:10px}.iconBtns button{width:56px;height:66px;border-radius:18px;border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.08);color:#fff;font-size:23px;font-weight:900;box-shadow:0 12px 24px rgba(0,0,0,.2)}.iconBtns span{display:block;font-size:12px;margin-top:3px}
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:10px}.stat{min-height:64px;border-radius:18px;padding:9px;background:linear-gradient(145deg,rgba(255,255,255,.14),rgba(255,255,255,.065));border:1px solid rgba(255,255,255,.13);box-shadow:0 10px 24px rgba(0,0,0,.18)}.stat span{font-size:12px;opacity:.9;white-space:nowrap}.stat b{display:block;font-size:21px;margin-top:3px;color:#fff}
.stock{display:grid;grid-template-columns:repeat(7,1fr);gap:5px;margin-bottom:10px}.stock div{border:1px solid rgba(255,255,255,.16);background:rgba(255,255,255,.075);border-radius:14px;padding:7px 1px;text-align:center;font-weight:900;font-size:12px}.stock b{display:block;color:#ffd86a;font-size:15px}
.panel{border:1px solid rgba(255,255,255,.16);border-radius:22px;background:rgba(255,255,255,.075);padding:11px;margin-bottom:10px;box-shadow:0 14px 28px rgba(0,0,0,.18)}.panel b{color:#ffd86a}.panel small{display:block;opacity:.8;margin-top:4px;line-height:1.4}.livePanel{display:grid;grid-template-columns:auto 1fr auto;gap:12px;align-items:center}.rewardIcon{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:radial-gradient(circle,#fff3ad,#ffbf29 68%,#7b3b00);font-size:24px}
.stage{margin-top:8px}.guide{text-align:center;opacity:.8;font-size:13px;margin:0 0 8px}.ticketWrap{min-height:160px;display:flex;align-items:center}.ticket{width:100%;height:154px;border-radius:22px;position:relative;overflow:hidden;color:#251039;background:linear-gradient(180deg,#fffdf0,#ffe79f);border:2px solid rgba(255,255,255,.92);box-shadow:0 20px 44px rgba(0,0,0,.34);touch-action:none}.ticket:before{content:"";position:absolute;inset:10px;border:2px dashed rgba(37,16,57,.22);border-radius:16px;z-index:20;pointer-events:none}.ticket.shake{animation:shake .25s}
.cover{position:absolute;inset:0;z-index:10;background:linear-gradient(180deg,#fff8d5,#f2d27d);clip-path:inset(0 0 0 0);will-change:clip-path}.coverIn{height:100%;display:flex;align-items:center;gap:14px;padding:0 86px 0 22px}.logo{width:62px;height:112px;border-right:3px dashed rgba(37,16,57,.28);display:flex;align-items:center;justify-content:center;writing-mode:vertical-rl;font-size:31px;font-weight:1000}.main{font-size:25px;font-weight:1000}.en{font-size:13px;font-weight:900;letter-spacing:.12em;opacity:.55}.small{font-size:13px;opacity:.62;margin-top:8px}.tear{position:absolute;right:0;top:0;bottom:0;width:82px;z-index:25;border-left:4px dashed rgba(86,55,22,.55);background:linear-gradient(90deg,rgba(255,255,255,.08),#ffe28a 54%,#ffd15e);display:flex;align-items:center;justify-content:center;touch-action:none}.tear b{writing-mode:vertical-rl;font-size:22px}.hole{position:absolute;top:50%;width:28px;height:42px;border-radius:50%;background:#2c123c;z-index:30;transform:translateY(-50%)}.hole.left{left:-15px}.hole.right{right:-15px}
.result{position:absolute;inset:0;z-index:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:20px 30px;opacity:0}.ticket.reveal .result{opacity:1}.ticket.done .cover,.ticket.done .tear{display:none}.rank{font-size:36px;font-weight:1000}.title{font-size:14px;font-weight:900;opacity:.72;margin-top:5px}.quote{font-size:16px;font-weight:1000;margin-top:10px;line-height:1.4}
.actions{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:10px;margin-bottom:10px}.draw{min-height:60px;border:0;border-radius:17px;font-size:17px;font-weight:1000;color:#251039;box-shadow:0 15px 28px rgba(0,0,0,.28)}.draw small{display:block;font-size:12px;margin-top:3px}.single{background:linear-gradient(#fff,#e8e4e8)}.five{background:linear-gradient(#ffe9a9,#ffbe51)}.ten{background:linear-gradient(#ff78aa,#ff8b2f);color:#fff}
.tabs{position:fixed;left:0;right:0;bottom:0;z-index:50;padding:8px 14px calc(8px + env(safe-area-inset-bottom));background:linear-gradient(180deg,transparent,rgba(8,3,14,.95) 26%)}.tabbar{max-width:480px;margin:auto;height:68px;border-radius:24px;padding:7px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.13);display:grid;grid-template-columns:repeat(4,1fr);gap:6px}.nav{height:54px;border:0;border-radius:19px;background:transparent;color:rgba(255,255,255,.58);font-weight:900}.nav.active{color:#ffd86a;background:radial-gradient(circle at 50% 20%,rgba(255,216,106,.32),rgba(255,216,106,.08) 55%,transparent 72%)}.nav em{display:block;font-style:normal;font-size:21px}.view{display:none}.view.active{display:block}
button{font-family:inherit}.panel button,.card button,.prizeCard button{border:0;border-radius:16px;padding:12px 18px;background:linear-gradient(#fff,#e8e4e8);color:#251039;font-weight:1000}.goldBtn{width:100%;margin-top:10px;background:linear-gradient(#fff4b0,#ffcf4d 55%,#ffae2e)!important}.dangerBtn{width:100%;margin-top:10px;background:linear-gradient(#ffb0c6,#ff3d6e)!important;color:#fff!important}
.toast{position:fixed;left:50%;bottom:88px;transform:translateX(-50%);background:rgba(0,0,0,.82);border-radius:999px;padding:11px 16px;font-weight:900;opacity:0;transition:.2s;z-index:100}.toast.show{opacity:1}.modal{display:none;position:fixed;inset:0;background:rgba(0,0,0,.68);z-index:120;align-items:center;justify-content:center;padding:20px}.modal.show{display:flex}.card{width:min(92vw,390px);max-height:86vh;overflow:auto;border-radius:28px;color:#251039;text-align:center;padding:24px 20px;background:linear-gradient(145deg,#fff8cc,#fff,#ffd86a)}.card h2{margin:0 0 8px}.resultItem{background:rgba(37,16,57,.08);border:1px solid rgba(37,16,57,.12);border-radius:15px;padding:10px;margin:8px 0;text-align:left;font-weight:800;line-height:1.42}
.prizeModal{display:none;position:fixed;inset:0;z-index:130;align-items:center;justify-content:center;padding:20px;background:rgba(0,0,0,.75)}.prizeModal.show{display:flex}.prizeCard{width:min(92vw,390px);border-radius:32px;color:#251039;text-align:center;padding:30px 22px;background:linear-gradient(145deg,#fff8cc,#fff,#ffd86a);box-shadow:0 0 60px rgba(255,216,106,.45);animation:pop .32s}.prizeCard.A{background:linear-gradient(145deg,#fff4a8,#fff,#ffbf29)}.prizeCard.B{background:linear-gradient(145deg,#ffe4ff,#fff,#bb66ff)}.prizeCard.C{background:linear-gradient(145deg,#fff0d1,#fff,#ff8b2f)}.prizeCard.D{background:linear-gradient(145deg,#d9f0ff,#fff,#67b7ff)}.prizeRank{font-size:54px;font-weight:1000}.prizeName{font-size:22px;font-weight:1000;margin-top:8px}.prizeQuote{font-size:18px;font-weight:900;line-height:1.45;margin:14px 0 20px}
.fxLayer{pointer-events:none;position:fixed;inset:0;z-index:125;overflow:hidden}.spark{position:absolute;width:9px;height:16px;border-radius:2px;animation:fall 1.5s linear forwards}.flash{animation:flash .45s}.globalNotice{position:fixed;top:12px;left:50%;transform:translateX(-50%) translateY(-140%);z-index:140;width:min(92vw,390px);border-radius:18px;padding:14px;background:linear-gradient(145deg,#fff8cc,#fff,#ffd86a);color:#251039;box-shadow:0 20px 60px rgba(0,0,0,.45);font-weight:1000;text-align:center;transition:.35s}.globalNotice.show{transform:translateX(-50%) translateY(0)}
.log{background:rgba(0,0,0,.18);border-radius:14px;padding:10px;margin:8px 0;font-size:13px;line-height:1.5;border:1px solid rgba(255,255,255,.08)}
@keyframes pop{0%{transform:scale(.88);opacity:0}70%{transform:scale(1.04)}100%{transform:scale(1);opacity:1}}@keyframes fall{to{transform:translateY(110vh) rotate(720deg);opacity:.15}}@keyframes flash{0%,100%{filter:brightness(1)}50%{filter:brightness(1.8)}}@keyframes shake{0%,100%{transform:translateX(0)}25%{transform:translateX(-5px)}50%{transform:translateX(5px)}75%{transform:translateX(-3px)}}
@media(max-height:760px){body{padding-top:10px}.hero{margin-bottom:8px}h1{font-size:29px}.sub{font-size:13px}.panel{padding:10px;margin-bottom:8px}.stat{min-height:58px}.ticket{height:140px}.ticketWrap{min-height:146px}.draw{min-height:54px;font-size:16px}.stock div{padding:5px 1px}}


/* V3.5 optimizations */
.lastWarning{
  display:none;margin:0 0 10px;padding:10px 12px;border-radius:18px;
  background:linear-gradient(90deg,rgba(255,80,60,.22),rgba(255,216,106,.12));
  border:1px solid rgba(255,130,80,.28);
  color:#ffd86a;font-weight:1000;text-align:center;
  box-shadow:0 10px 24px rgba(255,80,40,.12);
}
.lastWarning.show{display:block;animation:pulseWarn 1.2s ease-in-out infinite}
.homeShareInvite{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin:10px 0 0}
.miniTask{
  min-height:92px;border-radius:20px;padding:12px;
  background:linear-gradient(145deg,rgba(255,255,255,.12),rgba(255,255,255,.055));
  border:1px solid rgba(255,255,255,.13);
  box-shadow:0 12px 24px rgba(0,0,0,.18)
}
.miniTask b{display:block;color:#ffd86a;font-size:14px;line-height:1.25}
.miniTask small{display:block;font-size:12px;opacity:.78;margin:5px 0 8px;line-height:1.3}
.miniTask button{
  width:100%;height:34px;border-radius:999px!important;padding:0!important;font-size:12px!important;
  background:linear-gradient(180deg,#fff4b0,#ffcf4d 55%,#ffae2e)!important;color:#251039!important
}
.miniTask.invite button{background:linear-gradient(180deg,#b0d5ff,#4669ff)!important;color:#fff!important}
.fxGlowA:before,.fxGlowB:before,.fxGlowC:before,.fxGlowD:before{
  content:"";position:fixed;inset:-20%;z-index:124;pointer-events:none;opacity:.0;animation:awardGlow 1.4s ease-out forwards
}
.fxGlowA:before{background:radial-gradient(circle,#fff7b0 0%,rgba(255,200,40,.35) 18%,transparent 56%)}
.fxGlowB:before{background:radial-gradient(circle,#ffd8ff 0%,rgba(170,80,255,.35) 18%,transparent 56%)}
.fxGlowC:before{background:radial-gradient(circle,#ffe2a8 0%,rgba(255,120,30,.28) 20%,transparent 58%)}
.fxGlowD:before{background:radial-gradient(circle,#d8f2ff 0%,rgba(80,180,255,.28) 20%,transparent 58%)}
@keyframes awardGlow{0%{opacity:0;transform:scale(.8)}28%{opacity:1}100%{opacity:0;transform:scale(1.15)}}
@keyframes pulseWarn{0%,100%{filter:brightness(1)}50%{filter:brightness(1.25)}}
@media(max-height:760px){
  .homeShareInvite{display:none}
  .ticket{height:136px}
  .ticketWrap{min-height:140px}
  .hero{margin-bottom:6px}
  .panel.livePanel{display:none}
}
@media(max-width:390px){
  .homeShareInvite{grid-template-columns:1fr}
  .miniTask{min-height:78px}
}


/* Public play version */
.publicNote{
  margin:8px 0 10px;
  padding:9px 12px;
  border-radius:16px;
  background:rgba(255,216,106,.1);
  border:1px solid rgba(255,216,106,.25);
  color:#ffd86a;
  font-size:12px;
  font-weight:900;
  text-align:center;
}


.hidden{display:none!important}
.adminGate{display:none;position:fixed;inset:0;z-index:160;background:rgba(0,0,0,.72);align-items:center;justify-content:center;padding:20px}
.adminGate.show{display:flex}
.adminGateCard{width:min(92vw,390px);border-radius:28px;background:linear-gradient(145deg,#fff,#fff7cd,#ffd86a);color:#251039;padding:24px;box-shadow:0 34px 90px rgba(0,0,0,.58)}
.adminGateCard h2{margin:0 0 6px;font-size:28px}
.adminGateCard p{margin:0 0 10px;font-weight:900;opacity:.75}
.adminGateCard input{width:100%;border:0;border-radius:14px;padding:13px;background:rgba(255,255,255,.92);color:#251039;font-weight:900}
.adminGateActions{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:12px}


.textInput{
  width:100%;border:0;border-radius:14px;padding:12px;margin-top:9px;
  background:rgba(255,255,255,.92);color:#251039;font-weight:900;font-size:15px;
}
.formGrid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:4px}
.adminPage .panel{margin-bottom:10px}
.adminHeader{
  display:flex;justify-content:space-between;align-items:center;gap:10px;
  border:1px solid rgba(255,255,255,.16);border-radius:22px;background:rgba(255,255,255,.075);
  padding:12px;margin-bottom:10px;
}
.adminHeader b{color:#ffd86a;font-size:20px}.adminHeader small{display:block;opacity:.78;margin-top:3px}
.adminTabs{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;margin-bottom:10px}
.adminTab{
  border:0;border-radius:14px;padding:10px 2px;background:rgba(255,255,255,.10);
  color:rgba(255,255,255,.68);font-weight:1000;font-size:12px
}
.adminTab.active{background:linear-gradient(180deg,#fff4b0,#ffcf4d 55%,#ffae2e);color:#251039}
.adminSection{display:none}.adminSection.active{display:block}
.adminGrid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.adminCard{
  min-height:86px;border-radius:18px;padding:12px;background:linear-gradient(145deg,rgba(255,255,255,.13),rgba(255,255,255,.06));
  border:1px solid rgba(255,255,255,.12)
}
.adminCard span{display:block;font-size:12px;opacity:.8}.adminCard b{display:block;font-size:24px;color:#ffd86a;margin-top:4px}
.codeItem{padding:10px;border-radius:13px;background:rgba(0,0,0,.18);margin:8px 0;line-height:1.45}
.codeItem b{color:#ffd86a}
@media(max-width:390px){
  .adminTabs{grid-template-columns:repeat(3,1fr)}
  .formGrid{grid-template-columns:1fr}
}


/* v2.1 fixed public/admin layout */
.tabbar .hidden{display:none!important}
body.adminMode .tabbar{grid-template-columns:repeat(5,1fr)}
body:not(.adminMode) .tabbar{grid-template-columns:repeat(4,1fr)}
body:not(.adminMode) .adminOnly{display:none!important}
.adminPage{padding-bottom:24px}
.homeShareInvite{margin-bottom:86px}
@media(max-height:820px){
  .homeShareInvite{display:none!important}
  .panel.livePanel{padding:10px!important}
  .ticket{height:138px!important}
  .ticketWrap{min-height:142px!important}
  .actions{margin-bottom:90px!important}
}
@media(max-width:420px){
  .draw{min-height:54px!important;font-size:15px!important}
  .draw small{font-size:11px!important}
  .stats{gap:6px!important}
  .stat{padding:8px!important}
  .stat b{font-size:19px!important}
}


/* Marquee + global award announcement */
.marqueeBox{
  height:42px;
  display:flex;
  align-items:center;
  overflow:hidden;
  margin:0 0 10px;
  padding:0 12px;
  border-radius:18px;
  border:1px solid rgba(255,216,106,.28);
  background:linear-gradient(90deg,rgba(255,216,106,.12),rgba(255,255,255,.055));
  color:#ffe889;
  font-weight:1000;
  white-space:nowrap;
  box-shadow:0 10px 24px rgba(0,0,0,.16);
}
.marqueeBox span{
  display:inline-block;
  padding-left:100%;
  animation:marqueeMove 12s linear infinite;
}
@keyframes marqueeMove{
  from{transform:translateX(0)}
  to{transform:translateX(-100%)}
}
.globalNotice{
  font-size:18px;
  line-height:1.4;
  border:2px solid rgba(255,216,106,.5);
}
.globalNotice.bigPrize{
  background:linear-gradient(145deg,#fff8cc,#fff,#ffd86a,#ff9e2c);
  animation:globalPrizePop .55s ease-out, globalPrizePulse 1.1s ease-in-out infinite .6s;
}
@keyframes globalPrizePop{
  0%{transform:translateX(-50%) translateY(-150%) scale(.82);opacity:0}
  70%{transform:translateX(-50%) translateY(0) scale(1.04);opacity:1}
  100%{transform:translateX(-50%) translateY(0) scale(1)}
}
@keyframes globalPrizePulse{
  0%,100%{filter:brightness(1)}
  50%{filter:brightness(1.22)}
}


/* UI optimization v1 */
body{padding-top:18px!important}
.hero{margin-bottom:12px!important}
h1{font-size:32px!important;letter-spacing:-.5px!important}
.sub{font-size:14px!important;line-height:1.45!important;max-width:220px}
.stats{gap:7px!important}
.stat{min-height:58px!important;border-radius:17px!important;padding:8px!important}
.stat span{font-size:12px!important}.stat b{font-size:22px!important}
.stock{gap:5px!important}.stock div{border-radius:13px!important;padding:6px 1px!important;font-size:12px!important}
.panel{border-radius:22px!important}
.livePanel{min-height:76px}
.stage{margin-top:10px!important}
.ticketWrap{min-height:150px!important}
.ticket{height:148px!important}
.actions{gap:9px!important;margin-top:12px!important;margin-bottom:104px!important}
.draw{min-height:58px!important;border-radius:18px!important}
.homeShareInvite{display:none!important}
.publicNote{font-size:12px!important;padding:8px 10px!important;margin-bottom:8px!important}
.marqueeBox{height:38px!important;margin-bottom:8px!important}
.view#memberView .panel:first-child .log{font-size:14px!important;line-height:1.7!important}
#newUser{display:none!important}
.fieldLabel{display:block;margin:14px 0 4px;color:#ffd86a;font-weight:1000;font-size:15px}
.fieldHelp{display:block;opacity:.72;font-size:12px;line-height:1.4;margin-bottom:5px}
.prizeEditor{margin-top:10px}
.prizeRow{border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.055);border-radius:18px;padding:12px;margin:10px 0}
.prizeRowTitle{display:flex;justify-content:space-between;align-items:center;color:#ffd86a;font-weight:1000;margin-bottom:8px}
.prizeGrid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.prizeGrid .full{grid-column:1/-1}
@media(max-height:780px){
  .hero{margin-bottom:8px!important}
  h1{font-size:29px!important}
  .iconBtns button{width:52px!important;height:60px!important}
  .livePanel{display:none!important}
  .ticket{height:136px!important}
  .ticketWrap{min-height:140px!important}
}
@media(max-width:390px){
  body{padding-left:12px!important;padding-right:12px!important}
  .prizeGrid{grid-template-columns:1fr}
}
