:root{--color-bg: #1a0f0a;--color-bg-panel: #2c1810;--color-bg-panel-light: #3d2418;--color-gold: #d4a853;--color-gold-light: #f0d78c;--color-gold-dark: #a67c2e;--color-cream: #f5e6d3;--color-cream-muted: #c4a882;--color-win: #2ecc71;--color-miss: #95a5a6;--color-error: #e74c3c;--font-display: "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Noto Sans JP", sans-serif;--radius: 16px;--shadow: 0 8px 32px rgba(0, 0, 0, .4);--safe-bottom: env(safe-area-inset-bottom, 0px)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%}body{font-family:var(--font-display);background:var(--color-bg);color:var(--color-cream);min-height:100dvh;line-height:1.6;-webkit-font-smoothing:antialiased}#root{min-height:100dvh}.app{min-height:100dvh;display:flex;flex-direction:column;background:radial-gradient(ellipse at 50% 0%,#4a2818 0%,transparent 60%),radial-gradient(ellipse at 50% 100%,#2a1508 0%,transparent 50%),var(--color-bg);padding:0 16px calc(16px + var(--safe-bottom))}.header{text-align:center;padding:24px 0 16px}.header-badge{display:inline-block;font-size:.75rem;font-weight:700;letter-spacing:.15em;color:var(--color-gold-dark);background:linear-gradient(135deg,#3d2418,#2c1810);border:1px solid var(--color-gold-dark);border-radius:999px;padding:4px 16px;margin-bottom:8px}.shop-name{font-size:1.75rem;font-weight:800;background:linear-gradient(180deg,var(--color-gold-light) 0%,var(--color-gold) 50%,var(--color-gold-dark) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-shadow:none;filter:drop-shadow(0 2px 4px rgba(212,168,83,.3))}.greeting{font-size:.875rem;color:var(--color-cream-muted);margin-top:4px}.mock-badge{display:inline-block;margin-top:8px;font-size:.7rem;font-weight:600;color:#fff;background:#e67e22;border-radius:4px;padding:2px 8px}.main{flex:1;display:flex;align-items:center;justify-content:center;padding:8px 0 24px}.footer{text-align:center;font-size:.75rem;color:var(--color-cream-muted);opacity:.7;padding-bottom:8px}.panel{width:100%;max-width:400px;background:linear-gradient(160deg,var(--color-bg-panel-light) 0%,var(--color-bg-panel) 100%);border:1px solid var(--color-gold-dark);border-radius:var(--radius);box-shadow:var(--shadow);padding:32px 24px;position:relative;overflow:hidden}.panel:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent,var(--color-gold),transparent)}.panel--center{display:flex;flex-direction:column;align-items:center;text-align:center;gap:12px}.panel-title{font-size:1.25rem;font-weight:700;color:var(--color-cream)}.panel-sub{font-size:.875rem;color:var(--color-cream-muted);line-height:1.7}.panel--result{text-align:center}.card-icon{width:72px;height:auto;filter:drop-shadow(0 4px 8px rgba(0,0,0,.3))}.btn-draw{width:100%;max-width:280px;margin-top:16px;padding:18px 32px;font-family:inherit;font-size:1.25rem;font-weight:800;letter-spacing:.05em;color:#2c1810;background:linear-gradient(180deg,var(--color-gold-light) 0%,var(--color-gold) 40%,var(--color-gold-dark) 100%);border:none;border-radius:999px;cursor:pointer;box-shadow:0 4px 0 var(--color-gold-dark),0 8px 24px #d4a85366;transition:transform .15s,box-shadow .15s;-webkit-tap-highlight-color:transparent}.btn-draw:active{transform:translateY(3px);box-shadow:0 1px 0 var(--color-gold-dark),0 4px 12px #d4a8534d}.spinner{width:48px;height:48px;border:3px solid var(--color-bg-panel-light);border-top-color:var(--color-gold);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@keyframes panel-shake{0%{transform:rotate(-.4deg)}to{transform:rotate(.4deg)}}.draw-stage{width:100%;display:flex;flex-direction:column;align-items:center;gap:20px;position:relative}.draw-sparkles{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.draw-sparkle{position:absolute;width:6px;height:6px;border-radius:50%;background:var(--color-gold-light);opacity:0;animation:sparkle-float 1.4s ease-in-out infinite}.draw-sparkle--1{top:8%;left:12%;animation-delay:0s}.draw-sparkle--2{top:18%;right:10%;animation-delay:.2s}.draw-sparkle--3{top:42%;left:6%;animation-delay:.45s}.draw-sparkle--4{top:55%;right:8%;animation-delay:.7s}.draw-sparkle--5{bottom:28%;left:18%;animation-delay:.15s}.draw-sparkle--6{bottom:22%;right:16%;animation-delay:.55s}.draw-sparkle--7{top:30%;left:45%;animation-delay:.85s}.draw-sparkle--8{bottom:40%;right:42%;animation-delay:1s}@keyframes sparkle-float{0%,to{opacity:0;transform:scale(.5) translateY(0)}50%{opacity:1;transform:scale(1.2) translateY(-8px)}}.gacha-capsule-machine{width:200px;display:flex;flex-direction:column;align-items:center;animation:machine-bounce .55s ease-in-out infinite}@keyframes machine-bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.gacha-capsule-machine__top{width:120px;height:18px;border-radius:12px 12px 4px 4px;background:linear-gradient(180deg,#c9983f,#8b6914);border:2px solid var(--color-gold-dark);box-shadow:inset 0 2px 4px #ffffff40}.gacha-capsule-machine__window{width:168px;height:120px;background:linear-gradient(180deg,#1f120c,#120a06);border:3px solid var(--color-gold);border-radius:12px;overflow:hidden;position:relative;box-shadow:inset 0 0 24px #000c,0 8px 20px #00000059}.gacha-reel{width:100%;height:100%;position:relative;overflow:hidden}.gacha-reel__track{display:flex;flex-direction:column;animation:reel-scroll .35s linear infinite}.gacha-reel__item{height:56px;display:flex;align-items:center;justify-content:center;font-size:2rem;font-weight:800;color:var(--color-gold-light);text-shadow:0 0 12px rgba(240,215,140,.5)}@keyframes reel-scroll{0%{transform:translateY(0)}to{transform:translateY(-504px)}}.gacha-reel__frame{position:absolute;top:32px;right:12px;bottom:32px;left:12px;border:2px solid rgba(212,168,83,.55);border-radius:8px;box-shadow:0 0 0 999px #00000073,inset 0 0 16px #d4a85326;pointer-events:none}.gacha-capsule-machine__knob{width:44px;height:44px;margin-top:-8px;border-radius:50%;background:radial-gradient(circle at 35% 30%,#f0d78c,#a67c2e);border:3px solid var(--color-gold-dark);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 8px #00000059}.gacha-capsule-machine__knob-inner{width:14px;height:14px;border-radius:50%;background:#5c3d0f;animation:knob-spin .8s linear infinite}@keyframes knob-spin{to{transform:rotate(360deg)}}.gacha-capsule-machine__base{width:180px;height:28px;margin-top:4px;border-radius:0 0 16px 16px;background:linear-gradient(180deg,#6b4518,#3d2418);border:2px solid var(--color-gold-dark);border-top:none}.draw-status{font-size:1.125rem;font-weight:700;color:var(--color-gold-light);min-height:1.6em;animation:text-pulse .9s ease-in-out infinite}.draw-dots{display:flex;gap:8px}.draw-dots span{width:8px;height:8px;border-radius:50%;background:var(--color-gold);animation:dot-pulse .6s ease-in-out infinite}.draw-dots span:nth-child(2){animation-delay:.15s}.draw-dots span:nth-child(3){animation-delay:.3s}@keyframes dot-pulse{0%,to{opacity:.3;transform:scale(.8)}50%{opacity:1;transform:scale(1.2)}}@keyframes text-pulse{0%,to{opacity:1}50%{opacity:.55}}.reveal-stage{width:100%;display:flex;flex-direction:column;align-items:center;gap:20px;position:relative}.reveal-flash{position:absolute;top:-20%;right:-20%;bottom:-20%;left:-20%;background:radial-gradient(circle,rgba(255,255,255,.35) 0%,transparent 65%);animation:reveal-flash .9s ease-out forwards;pointer-events:none}@keyframes reveal-flash{0%{opacity:0;transform:scale(.6)}30%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(1.2)}}.reveal-card{width:120px;height:168px;perspective:800px;position:relative}.reveal-card__back,.reveal-card__front{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;border-radius:12px;backface-visibility:hidden;font-size:1.5rem;font-weight:800;border:3px solid var(--color-gold)}.reveal-card__back{background:linear-gradient(145deg,#8b4513,#5c2e0a);color:var(--color-gold-light);animation:card-flip-back .9s ease-in-out forwards}.reveal-card__front{transform:rotateY(180deg);animation:card-flip-front .9s ease-in-out forwards}.reveal-stage--win .reveal-card__front{background:linear-gradient(145deg,#58d68d,#1e8449);color:#fff;box-shadow:0 0 32px #2ecc718c}.reveal-stage--miss .reveal-card__front{background:linear-gradient(145deg,#7f8c8d,#566573);color:#ecf0f1}@keyframes card-flip-back{0%{transform:rotateY(0)}to{transform:rotateY(-180deg)}}@keyframes card-flip-front{0%{transform:rotateY(180deg)}to{transform:rotateY(0)}}.reveal-text{font-size:1.125rem;font-weight:700;color:var(--color-gold-light);animation:text-pulse .6s ease-in-out infinite}.panel--result-enter{animation:result-pop .55s cubic-bezier(.34,1.56,.64,1) both}@keyframes result-pop{0%{opacity:0;transform:scale(.85) translateY(16px)}to{opacity:1;transform:scale(1) translateY(0)}}.panel--drawing{padding:28px 20px 36px;animation:panel-shake .12s ease-in-out infinite alternate}.panel--result-enter.panel--win,.panel--result-enter.panel--miss{animation:result-pop .55s cubic-bezier(.34,1.56,.64,1) both}.result-badge{display:inline-block;font-size:.875rem;font-weight:800;letter-spacing:.1em;padding:6px 20px;border-radius:999px;margin-bottom:8px}.result-badge--win{color:#1a0f0a;background:linear-gradient(135deg,#58d68d,#27ae60);box-shadow:0 0 24px #2ecc7166;animation:win-glow 1.5s ease-in-out infinite alternate}@keyframes win-glow{0%{box-shadow:0 0 16px #2ecc714d}to{box-shadow:0 0 32px #2ecc7199}}.result-badge--miss{color:var(--color-cream);background:#555;border:1px solid #777}.result-badge--already{color:var(--color-gold-dark);background:#d4a85326;border:1px solid var(--color-gold-dark)}.panel--win{border-color:var(--color-win)}.panel--win:before{background:linear-gradient(90deg,transparent,var(--color-win),transparent)}.panel--miss{display:flex;flex-direction:column;align-items:center;gap:12px}.code-box{width:100%;background:#0000004d;border:2px dashed var(--color-gold);border-radius:12px;padding:16px;margin:12px 0}.code-box--small{padding:12px;margin:8px 0}.code-label{display:block;font-size:.75rem;color:var(--color-cream-muted);margin-bottom:4px}.code-value{display:block;font-size:1.75rem;font-weight:800;letter-spacing:.2em;color:var(--color-gold-light);font-variant-numeric:tabular-nums}.code-box--small .code-value{font-size:1.25rem}.expiry{font-size:.8rem;color:var(--color-cream-muted)}.staff-note{margin-top:16px;padding:12px 16px;font-size:.9rem;font-weight:700;color:var(--color-gold-light);background:#d4a8531f;border-radius:8px;border:1px solid var(--color-gold-dark)}.panel--already{gap:16px}.next-draw{font-size:.875rem;color:var(--color-cream-muted);line-height:1.8}.next-draw strong{font-size:1.1rem;color:var(--color-gold-light)}.today-result{width:100%}.panel--error{border-color:var(--color-error)}.error-icon{width:56px;height:56px;display:flex;align-items:center;justify-content:center;font-size:1.75rem;font-weight:800;color:#fff;background:var(--color-error);border-radius:50%;margin-bottom:4px}.hint{margin-top:8px;font-size:.8rem;opacity:.8}
