:root{--brand: #4F46E5;--bg: #F0F2F5;--nav-h: 64px;--hdr-h: 68px;--shadow-sm: 0 2px 8px rgba(0,0,0,.06);--shadow-md: 0 6px 20px rgba(0,0,0,.09)}*{box-sizing:border-box;margin:0;padding:0}html,body{overflow-x:hidden}body{font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,Segoe UI,Roboto,sans-serif;background:var(--bg);color:#111827;min-height:100dvh;-webkit-font-smoothing:antialiased}.dash-loading{display:flex;align-items:center;justify-content:center;min-height:100dvh}.dash-spinner{width:36px;height:36px;border:3px solid rgba(0,0,0,.08);border-top-color:var(--brand);border-radius:50%;animation:spin .75s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.dash-page{max-width:480px;margin:0 auto;min-height:100dvh;background:var(--bg);position:relative;overflow-x:hidden}.dash-header{position:sticky;top:0;z-index:100;height:var(--hdr-h);display:flex;align-items:center;justify-content:center;padding:0 14px;background:var(--brand);overflow:visible}.dash-header-center{flex:1;display:flex;align-items:flex-start;justify-content:center;height:100%;padding-top:10px;position:relative;z-index:10}.dash-header-logo-wrap{width:110px;height:110px;background:#fff;border-radius:24px;box-shadow:0 8px 28px #0003;display:flex;align-items:center;justify-content:center;padding:14px}.dash-header-logo{width:100%;height:100%;object-fit:contain}.dash-header-merchant{font-size:1rem;font-weight:800;letter-spacing:.05em;text-transform:uppercase;color:#fff}.dash-header-actions{position:absolute;right:14px;top:50%;transform:translateY(-50%);display:flex;align-items:center;gap:10px;z-index:20}.qr-mini-btn{width:38px;height:38px;border-radius:50%;background:#ffffff26;border:1.5px solid rgba(255,255,255,.3);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .15s}.qr-mini-btn:hover{background:#ffffff40}.dash-event-btn{width:38px;height:38px;border-radius:50%;background:#ffffff26;border:1.5px solid rgba(255,255,255,.3);color:#fff9;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .15s}.dash-event-btn--active{color:gold;border-color:#ffd70080;background:#ffd70026;animation:bell-shake 2.5s ease infinite}.dash-event-btn:hover{background:#ffffff40}@keyframes bell-shake{0%,to{transform:rotate(0)}10%{transform:rotate(-14deg)}20%{transform:rotate(14deg)}30%{transform:rotate(-10deg)}40%{transform:rotate(10deg)}50%{transform:rotate(0)}}@keyframes pulse{0%,to{transform:scale(1);box-shadow:0 0 #ef444466}50%{transform:scale(1.15);box-shadow:0 0 0 5px #ef444400}}.dash-scroll{overflow-y:auto;-webkit-overflow-scrolling:touch;padding-top:52px;padding-bottom:calc(var(--nav-h) + env(safe-area-inset-bottom,12px) + 8px)}.dash-scroll.has-carousel{padding-top:0}.dash-view-home{display:flex;flex-direction:column;gap:12px;padding:14px 14px 0}.dash-view{display:flex;flex-direction:column;gap:10px;padding:20px 16px 0}.view-title{font-size:1.4rem;font-weight:800;color:#111827;letter-spacing:-.025em;margin-bottom:6px}.carousel{position:relative;width:100%;aspect-ratio:16/9;overflow:hidden;background:var(--brand);flex-shrink:0}.carousel-empty{width:100%;aspect-ratio:16/9;flex-shrink:0}.carousel-track{display:flex;height:100%;transition:transform .55s cubic-bezier(.4,0,.2,1)}.carousel-slide{flex:0 0 100%;height:100%;overflow:hidden}.carousel-slide img{width:100%;height:100%;object-fit:cover;display:block;pointer-events:none}.carousel-dots{position:absolute;bottom:10px;left:0;right:0;display:flex;align-items:center;justify-content:center;gap:6px}.carousel-dot{width:7px;height:7px;border-radius:50%;background:#ffffff73;border:none;cursor:pointer;padding:0;transition:background .2s,transform .2s}.carousel-dot.active{background:#fff;transform:scale(1.3)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:#0000008c;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:20px}.identity-card{background:#fff;border-radius:22px;padding:18px 20px 16px;display:flex;flex-direction:column;gap:10px;box-shadow:var(--shadow-md)}.identity-top{display:flex;align-items:center;justify-content:space-between;gap:10px}.identity-name{font-size:1.05rem;font-weight:800;color:#111827;letter-spacing:-.01em}.identity-balance{display:flex;align-items:baseline;gap:7px;flex-wrap:wrap}.identity-greeting-pts{font-size:.85rem;font-weight:700;color:color-mix(in srgb,var(--brand) 65%,#000);align-self:baseline}.identity-pts{font-size:2rem;font-weight:900;color:var(--brand);letter-spacing:-.03em;line-height:1}.identity-lbl{font-size:.85rem;font-weight:700;color:color-mix(in srgb,var(--brand) 65%,#000)}.event-popup{background:#fff;border-radius:24px;padding:32px 24px 24px;width:calc(100% - 48px);max-width:340px;display:flex;flex-direction:column;align-items:center;gap:10px;position:relative;animation:fadeUp .3s cubic-bezier(.22,1,.36,1) both}.event-popup-close{position:absolute;top:14px;right:14px;width:28px;height:28px;border-radius:50%;background:#f3f4f6;color:#6b7280;display:flex;align-items:center;justify-content:center;border:none;cursor:pointer}.event-popup-icon{font-size:2.8rem;line-height:1}.event-popup-title{font-size:1.05rem;font-weight:800;color:#111827;text-align:center;line-height:1.3}.event-popup-sub{font-size:.85rem;color:#6b7280;text-align:center}.event-popup-btn{margin-top:8px;width:100%;height:48px;border-radius:999px;border:none;cursor:pointer;color:#fff;font-size:.95rem;font-weight:700;font-family:inherit;transition:opacity .15s,transform .15s}.event-popup-btn:hover{opacity:.9;transform:translateY(-1px)}.qr-modal-card{background:#fff;border-radius:28px;padding:28px 24px 24px;display:flex;flex-direction:column;align-items:center;gap:14px;width:min(340px,90vw);position:relative;box-shadow:0 30px 80px #00000059}.qr-modal-close{position:absolute;top:14px;right:14px;width:32px;height:32px;border-radius:50%;background:#f3f4f6;border:none;display:flex;align-items:center;justify-content:center;color:#6b7280;cursor:pointer}.qr-modal-merchant{font-size:.68rem;font-weight:700;letter-spacing:.09em;text-transform:uppercase;color:#9ca3af}.qr-code-wrap{padding:12px;background:#fff;border-radius:16px;border:2px solid #f3f4f6;line-height:0}.qr-code-img{width:220px;height:220px;display:block;image-rendering:pixelated}.qr-modal-name{font-size:1rem;font-weight:800;color:#111827;letter-spacing:.01em;text-transform:uppercase}.qr-modal-balance{display:flex;align-items:baseline;gap:6px;background:color-mix(in srgb,var(--brand) 8%,white);border:1.5px solid color-mix(in srgb,var(--brand) 18%,transparent);border-radius:999px;padding:6px 20px}.qr-balance-value{font-size:1.35rem;font-weight:800;color:var(--brand);letter-spacing:-.02em}.qr-balance-label{font-size:.8rem;font-weight:700;color:color-mix(in srgb,var(--brand) 70%,#000)}.wallet-buttons{display:flex;gap:10px}.google-wallet-btn,.apple-wallet-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:13px 12px;border-radius:16px;border:none;font-size:.82rem;font-weight:700;cursor:pointer;transition:transform .15s,box-shadow .15s;box-shadow:var(--shadow-md)}.google-wallet-btn{background:#fff;color:#111827}.apple-wallet-btn{background:#111827;color:#fff}.google-wallet-btn:hover,.apple-wallet-btn:hover{transform:translateY(-1px);box-shadow:0 10px 28px #0000002e}.google-wallet-btn:active,.apple-wallet-btn:active{transform:scale(.97)}.google-wallet-btn:disabled,.apple-wallet-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.birthday-gift-banner{display:flex;align-items:center;gap:14px;padding:14px 16px;border-radius:18px;background:linear-gradient(135deg,#fdf4ff,#fff);box-shadow:var(--shadow-sm);border:1.5px solid #e9d5ff}.birthday-gift-icon{font-size:1.8rem;flex-shrink:0}.birthday-gift-text{flex:1;display:flex;flex-direction:column;gap:2px}.birthday-gift-text strong:first-child{font-size:.9rem;color:#6b21a8;font-weight:700}.birthday-gift-text span{font-size:.8rem;color:#6b7280}.birthday-gift-text span strong{color:#7c3aed}.expiry-banner{display:flex;align-items:center;gap:14px;padding:14px 16px;border-radius:18px;background:linear-gradient(135deg,#fffbeb,#fff);box-shadow:var(--shadow-sm);border:1.5px solid #fcd34d}.expiry-banner-icon{font-size:1.5rem;flex-shrink:0}.expiry-banner-text{flex:1;display:flex;flex-direction:column;gap:2px}.expiry-banner-text strong{font-size:.875rem;color:#92400e;font-weight:700}.expiry-banner-text span{font-size:.78rem;color:#6b7280}.birthday-banner{display:flex;align-items:center;gap:14px;padding:14px 16px;border-radius:18px;background:linear-gradient(135deg,#fff7ed,#fff);box-shadow:var(--shadow-sm);border:1.5px solid #fed7aa;cursor:pointer;transition:transform .15s}.birthday-banner:active{transform:scale(.98)}.birthday-banner-icon{font-size:1.5rem;flex-shrink:0}.birthday-banner-text{flex:1;display:flex;flex-direction:column;gap:2px}.birthday-banner-text strong{font-size:.875rem;color:#111827;font-weight:700}.birthday-banner-text span{font-size:.78rem;color:#6b7280}.birthday-banner-arrow{font-size:1.4rem;color:#f97316;font-weight:700}.event-alert{display:flex;align-items:center;gap:14px;padding:14px 16px;border-radius:18px;background:#fff;box-shadow:var(--shadow-sm);border:1.5px solid color-mix(in srgb,var(--brand) 18%,transparent);cursor:pointer;transition:transform .15s}.event-alert:active{transform:scale(.98)}.event-alert-icon{font-size:1.6rem;flex-shrink:0}.event-alert div{flex:1}.event-alert strong{font-size:.9rem;color:#111827;display:block;font-weight:700}.event-alert p{font-size:.78rem;color:#6b7280;margin-top:2px}.event-alert-arrow{font-size:1.4rem;color:var(--brand);font-weight:700}.locations-section{display:flex;flex-direction:column;gap:10px}.section-label{font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#9ca3af}.locations-list{display:flex;flex-direction:column;gap:8px}.location-card{border-radius:18px;background:#fff;box-shadow:var(--shadow-sm);overflow:hidden}.location-card-header{display:flex;align-items:center;gap:10px;padding:14px 16px;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .15s}.location-card-header:active{background:#f9fafb}.location-card-header.expanded{border-bottom:1px solid #f3f4f6}.location-card-info{display:flex;flex-direction:column;gap:3px;flex:1}.location-chevron{color:#9ca3af;flex-shrink:0;transition:transform .25s ease}.location-chevron.open{transform:rotate(180deg)}.location-name{font-size:.95rem;font-weight:700;color:#111827}.location-address{font-size:.78rem;color:#6b7280;line-height:1.4}.location-promo-hint{font-size:.72rem;font-weight:600;color:var(--brand);margin-top:2px}.location-map-wrap{position:relative}.location-map-wrap iframe{display:block;width:100%;height:180px;border:0}.location-maps-link{display:block;padding:10px 16px;font-size:.8rem;font-weight:700;color:var(--brand);text-decoration:none;border-top:1px solid #f3f4f6;background:#fff;transition:background .15s}.location-maps-link:hover{background:#f9fafb}.location-promos{padding:10px 14px 14px;border-top:1px solid #f3f4f6;display:flex;flex-direction:column;gap:8px}.location-promos-label{font-size:.68rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:#9ca3af;margin-bottom:2px}.location-promo-row{display:flex;align-items:center;gap:8px}.location-promo-icon{font-size:1rem;flex-shrink:0}.location-promo-info{flex:1;display:flex;flex-direction:column;gap:1px}.location-promo-name{font-size:.82rem;font-weight:600;color:#111827}.location-promo-value{font-size:.8rem;font-weight:700;color:var(--brand)}.location-promo-until{font-size:.72rem;color:#9ca3af;flex-shrink:0}.location-reward-row{display:flex;align-items:center;gap:8px}.location-reward-desc{font-size:.74rem;color:#6b7280}.location-reward-cost{font-size:.78rem;font-weight:700;color:var(--brand);flex-shrink:0}.global-promos-list{display:flex;flex-direction:column;gap:12px}.global-promo-card{border-radius:20px;overflow:hidden;background:#fff;box-shadow:0 4px 18px #0000001a;border:1.5px solid rgba(0,0,0,.04)}.global-promo-img-wrap{position:relative;width:100%;aspect-ratio:16/7;overflow:hidden}.global-promo-img-wrap img{width:100%;height:100%;object-fit:cover;display:block}.global-promo-img-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to top,rgba(0,0,0,.6) 0%,transparent 55%);display:flex;align-items:flex-end;justify-content:flex-end;padding:12px 14px}.global-promo-no-img{background:linear-gradient(135deg,var(--brand) 0%,color-mix(in srgb,var(--brand) 65%,#000) 100%);padding:22px 18px;display:flex;align-items:center;justify-content:space-between}.global-promo-icon{font-size:2rem}.global-promo-value-badge{background:#fffffff2;color:var(--brand);font-size:.82rem;font-weight:800;padding:5px 13px;border-radius:999px;box-shadow:0 2px 10px #0000002e;white-space:nowrap;letter-spacing:.01em}.global-promo-info{padding:10px 15px 13px;display:flex;flex-direction:column;gap:3px}.global-promo-name{font-size:.9rem;font-weight:700;color:#111827}.global-promo-until{font-size:.74rem;color:#9ca3af}.bottom-nav{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:min(100%,480px);height:calc(var(--nav-h) + env(safe-area-inset-bottom,0px));padding-bottom:env(safe-area-inset-bottom,0px);display:flex;align-items:flex-start;background:#ffffffed;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-top:1px solid rgba(0,0,0,.07);z-index:200}.bottom-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding-top:11px;padding-bottom:0;border:none;background:transparent;cursor:pointer;color:#b0b8c6;font-size:.62rem;font-weight:600;letter-spacing:.02em;position:relative;transition:color .18s}.bottom-nav-item.active{color:var(--brand)}.bottom-nav-item svg{transition:transform .18s}.bottom-nav-item.active svg{transform:translateY(-1px)}.bottom-nav-item.active:after{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:28px;height:3px;border-radius:0 0 4px 4px;background:var(--brand)}.nav-badge{position:absolute;top:8px;right:calc(50% - 16px);width:7px;height:7px;border-radius:50%;background:#ef4444;border:1.5px solid rgba(255,255,255,.9)}.tab-loading{display:flex;justify-content:center;padding:40px 0}.tab-spinner{width:28px;height:28px;border:3px solid rgba(0,0,0,.07);border-top-color:var(--brand);border-radius:50%;animation:spin .75s linear infinite}.tab-empty{text-align:center;padding:40px 0;color:#9ca3af}.tab-empty-icon{font-size:2.2rem;margin-bottom:10px;opacity:.6}.tab-empty p{font-size:.875rem;line-height:1.5}.tx-list{display:flex;flex-direction:column;gap:8px}.tx-row{display:flex;align-items:center;gap:14px;padding:14px 16px;border-radius:18px;background:#fff;box-shadow:0 2px 10px #00000012;border:1px solid rgba(0,0,0,.05)}.tx-icon-wrap{width:42px;height:42px;border-radius:13px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.tx-row.earn .tx-icon-wrap{background:#d1fae5;color:#059669}.tx-row.redeem .tx-icon-wrap{background:color-mix(in srgb,var(--brand) 13%,white);color:var(--brand)}.tx-row.refund .tx-icon-wrap{background:#fef3c7;color:#d97706}.tx-info{flex:1;display:flex;flex-direction:column;gap:3px;min-width:0}.tx-type{font-size:.88rem;font-weight:700;color:#111827}.tx-date{font-size:.72rem;color:#9ca3af;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tx-points{font-size:.92rem;font-weight:800;white-space:nowrap;letter-spacing:-.01em}.tx-points.earn{color:#059669}.tx-points.redeem{color:var(--brand)}.tx-points.refund{color:#d97706}.tx-pagination{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:8px;padding:4px 0}.tx-page-btn{width:36px;height:36px;border-radius:50%;border:1.5px solid #e5e7eb;background:#fff;display:flex;align-items:center;justify-content:center;color:#374151;cursor:pointer;transition:border-color .15s,background .15s}.tx-page-btn:disabled{opacity:.35;cursor:default}.tx-page-btn:not(:disabled):hover{border-color:var(--brand);color:var(--brand);background:color-mix(in srgb,var(--brand) 6%,white)}.tx-page-info{font-size:.82rem;font-weight:600;color:#6b7280;min-width:48px;text-align:center}.rewards-grid{display:flex;flex-direction:column;gap:10px}.reward-card{background:#fff;border-radius:20px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:10px;border:1.5px solid rgba(0,0,0,.04);overflow:hidden}.reward-card-img{width:100%;aspect-ratio:16/7;overflow:hidden;border-radius:0}.reward-card-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s ease}.reward-card:hover .reward-card-img img{transform:scale(1.03)}.reward-card:not(:has(.reward-card-img)){padding:18px}.reward-card:has(.reward-card-img) .reward-card-header,.reward-card:has(.reward-card-img) .reward-name,.reward-card:has(.reward-card-img) .reward-desc,.reward-card:has(.reward-card-img) .reward-progress-bar,.reward-card:has(.reward-card-img) .reward-progress-text{padding-left:18px;padding-right:18px}.reward-card:has(.reward-card-img) .reward-card-header{padding-top:14px}.reward-card:has(.reward-card-img) .reward-progress-text{padding-bottom:16px}.reward-card.unlocked{border-color:color-mix(in srgb,var(--brand) 25%,transparent);background:linear-gradient(135deg,#fff 80%,color-mix(in srgb,var(--brand) 4%,white))}.reward-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.reward-badge{font-size:.7rem;font-weight:700;padding:4px 10px;border-radius:999px}.reward-card.unlocked .reward-badge{background:color-mix(in srgb,var(--brand) 12%,white);color:var(--brand)}.reward-card:not(.unlocked) .reward-badge{background:#f3f4f6;color:#9ca3af}.reward-cost{font-size:.8rem;font-weight:700;color:var(--brand);white-space:nowrap}.reward-card:not(.unlocked) .reward-cost{color:#9ca3af}.reward-name{font-size:1rem;font-weight:700;color:#111827;line-height:1.3}.reward-desc{font-size:.8rem;color:#6b7280;line-height:1.45}.reward-progress-bar{height:5px;background:#0000000f;border-radius:999px;overflow:hidden}.reward-progress-fill{height:100%;background:linear-gradient(90deg,var(--brand),color-mix(in srgb,var(--brand) 70%,#fff));border-radius:999px;transition:width .6s cubic-bezier(.4,0,.2,1)}.reward-progress-text{font-size:.72rem;color:#9ca3af;text-align:right;font-weight:600}.event-card{background:#fff;border-radius:20px;padding:18px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:12px;border:1.5px solid rgba(0,0,0,.04)}.event-card.available{border-color:color-mix(in srgb,var(--brand) 25%,transparent)}.event-card.played{opacity:.6}.event-card-header{display:flex;align-items:center;gap:14px}.event-type-icon{width:46px;height:46px;border-radius:14px;background:color-mix(in srgb,var(--brand) 10%,white);display:flex;align-items:center;justify-content:center;font-size:1.5rem;flex-shrink:0}.event-card-info{flex:1}.event-card-name{font-size:.95rem;font-weight:700;color:#111827}.event-card-trigger{font-size:.75rem;color:#9ca3af;margin-top:3px;font-weight:500}.event-status-badge{font-size:.7rem;font-weight:700;padding:5px 11px;border-radius:999px;white-space:nowrap}.badge-ready{background:color-mix(in srgb,var(--brand) 12%,white);color:var(--brand)}.badge-played{background:#f3f4f6;color:#9ca3af}.badge-locked{background:#fef2f2;color:#dc2626}.event-prizes-preview{display:flex;flex-wrap:wrap;gap:6px}.event-prize-chip{font-size:.72rem;padding:4px 10px;border-radius:999px;color:#fff;font-weight:600}.event-locked-msg{font-size:.8rem;color:#6b7280;background:#f9fafb;padding:10px 14px;border-radius:12px;line-height:1.5}.event-play-btn{width:100%;padding:13px;border:none;border-radius:14px;background:linear-gradient(135deg,var(--brand),color-mix(in srgb,var(--brand) 80%,#000));color:#fff;font-size:.95rem;font-weight:700;cursor:pointer;transition:opacity .2s,transform .15s;box-shadow:0 4px 14px color-mix(in srgb,var(--brand) 35%,transparent)}.event-play-btn:hover{opacity:.9}.event-play-btn:active{transform:scale(.97)}.profile-form{display:flex;flex-direction:column;gap:16px}.profile-field-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.profile-field{display:flex;flex-direction:column;gap:6px}.profile-field label{font-size:12px;font-weight:700;color:#374151;letter-spacing:.04em;text-transform:uppercase}.profile-birthday-hint{font-weight:400;color:#f97316;font-size:11px;text-transform:none;letter-spacing:0}.profile-birthday-locked{display:block;font-size:11px;color:#9ca3af;margin-top:4px;font-weight:400;text-transform:none;letter-spacing:0}.profile-field input{padding:12px 14px;border:1.5px solid #e5e7eb;border-radius:12px;font-size:15px;color:#111827;outline:none;background:#fff;transition:border-color .15s,box-shadow .15s;-webkit-appearance:none}.profile-field input:focus{border-color:var(--brand);box-shadow:0 0 0 3px color-mix(in srgb,var(--brand) 15%,transparent)}.profile-msg{padding:12px 16px;border-radius:12px;font-size:13px;font-weight:600}.profile-msg--ok{background:#f0fdf4;color:#16a34a;border:1px solid #bbf7d0}.profile-msg--err{background:#fef2f2;color:#dc2626;border:1px solid #fecaca}.btn-brand{padding:14px;border-radius:16px;border:none;background:linear-gradient(135deg,var(--brand),color-mix(in srgb,var(--brand) 80%,#000));color:#fff;font-size:1rem;font-weight:700;cursor:pointer;width:100%;transition:opacity .2s,transform .15s;box-shadow:0 4px 14px color-mix(in srgb,var(--brand) 30%,transparent)}.btn-brand:hover{opacity:.9}.btn-brand:active{transform:scale(.98)}.btn-brand:disabled{opacity:.55;cursor:not-allowed;transform:none;box-shadow:none}.roulette-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b8;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:2000;padding:16px}.roulette-modal{background:#fff;border-radius:28px;width:100%;max-width:360px;display:flex;flex-direction:column;align-items:center;overflow:hidden;box-shadow:0 2px #ffffff1f inset,0 32px 80px #00000061,0 8px 24px #0000002e;animation:rouletteIn .3s cubic-bezier(.34,1.56,.64,1)}@keyframes rouletteIn{0%{opacity:0;transform:scale(.82) translateY(24px)}to{opacity:1;transform:scale(1) translateY(0)}}.roulette-header{width:100%;display:flex;align-items:center;justify-content:space-between;padding:18px 20px 14px;border-bottom:1px solid #f1f5f9}.roulette-header-left{display:flex;align-items:center;gap:8px}.roulette-header-icon{font-size:1.15rem}.roulette-title{font-size:1.05rem;font-weight:800;color:#111827;letter-spacing:-.02em}.roulette-close{background:#f1f5f9;border:none;cursor:pointer;color:#64748b;padding:7px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s}.roulette-close:hover{background:#e2e8f0;color:#1e293b}.roulette-wheel-area{position:relative;width:100%;padding:28px 24px 16px;display:flex;justify-content:center;align-items:center}.roulette-pointer-wrap{position:absolute;top:10px;left:50%;transform:translate(-50%);z-index:10;filter:drop-shadow(0 3px 6px rgba(0,0,0,.28))}.roulette-pointer{width:0;height:0;border-left:13px solid transparent;border-right:13px solid transparent;border-top-width:22px;border-top-style:solid}.roulette-ring{width:100%;aspect-ratio:1;border-radius:50%;border:3px solid;box-shadow:0 0 0 6px #0000000a,0 0 32px #0000001f,0 16px 48px #0000002e;background:#fff}.roulette-wheel-rotate{width:100%;height:100%;border-radius:50%;overflow:hidden}.roulette-canvas{width:100%;height:100%;display:block}.roulette-action{width:100%;padding:4px 22px 26px;display:flex;flex-direction:column;align-items:center;gap:12px}.roulette-spin-btn{width:100%;padding:15px;border:none;border-radius:16px;color:#fff;font-size:1.05rem;font-weight:800;cursor:pointer;letter-spacing:.01em;display:flex;align-items:center;justify-content:center;gap:8px;box-shadow:0 4px 16px #0003,0 1px #ffffff26 inset;transition:opacity .15s,transform .15s,box-shadow .15s;animation:spinBtnPulse 2.4s ease-in-out infinite}.roulette-spin-btn:hover{opacity:.92;transform:translateY(-1px);box-shadow:0 6px 20px #00000040}.roulette-spin-btn:active{transform:scale(.97) translateY(0);animation:none}.roulette-spin-icon{font-size:1.1rem}@keyframes spinBtnPulse{0%,to{box-shadow:0 4px 16px #0003,0 1px #ffffff26 inset}50%{box-shadow:0 4px 24px #00000052,0 1px #ffffff26 inset}}.roulette-spinning-msg{font-size:.95rem;color:#6b7280;font-weight:700;letter-spacing:.04em;text-transform:uppercase;display:flex;align-items:center;gap:8px}.roulette-spinning-msg:before{content:"";width:14px;height:14px;border:2.5px solid #d1d5db;border-top-color:#6b7280;border-radius:50%;animation:rouletteSpin .7s linear infinite;display:inline-block}@keyframes rouletteSpin{to{transform:rotate(360deg)}}.roulette-result{display:flex;flex-direction:column;align-items:center;gap:8px;text-align:center;width:100%;animation:resultPop .4s cubic-bezier(.34,1.56,.64,1)}@keyframes resultPop{0%{opacity:0;transform:scale(.7)}to{opacity:1;transform:scale(1)}}.roulette-result-badge{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,#f8fafc,#e2e8f0);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px #0000001a,0 1px #fffc inset;margin-bottom:4px}.roulette-result-emoji{font-size:2.6rem;line-height:1}.roulette-result-title{font-size:1.25rem;font-weight:900;color:#111827;letter-spacing:-.02em}.roulette-result-label{font-size:1rem;font-weight:600;color:#374151}.roulette-result-points{font-size:.9rem;font-weight:700;padding:8px 20px;border-radius:999px;animation:resultPop .5s .1s cubic-bezier(.34,1.56,.64,1) both}.roulette-close-btn{margin-top:4px;padding:12px 32px;border:none;border-radius:14px;font-size:.95rem;font-weight:700;cursor:pointer;transition:filter .15s,transform .15s}.roulette-close-btn:hover{filter:brightness(.94)}.roulette-close-btn:active{transform:scale(.97)}.roulette-error{font-size:.82rem;color:#dc2626;text-align:center;background:#fef2f2;padding:10px 16px;border-radius:12px;width:100%;border:1px solid #fecaca}.tier-badge{display:inline-flex;align-items:center;gap:5px;padding:5px 14px;border-radius:20px;font-size:13px;font-weight:700;margin-top:12px;color:#fff;letter-spacing:.02em;box-shadow:0 2px 8px #00000026}.tier-next-row{margin-top:10px;width:100%;max-width:220px}.tier-next-label{font-size:11px;color:#00000073;text-align:center;margin-bottom:4px}.tier-progress-bar{height:5px;background:#0000001a;border-radius:3px;overflow:hidden}.tier-progress-fill{height:100%;border-radius:3px;transition:width .6s ease}.tier-bonus-banner{background:linear-gradient(135deg,#fef3c7,#fffbeb);border:1.5px solid #fcd34d;border-radius:14px;padding:12px 16px;display:flex;align-items:center;gap:12px;margin:10px 16px 0}.tier-bonus-icon{font-size:1.5rem;flex-shrink:0}.tier-bonus-text strong{display:block;font-size:14px;font-weight:700;color:#92400e}.tier-bonus-text span{font-size:13px;color:#b45309}.dash-legal-footer{display:flex;justify-content:center;align-items:center;gap:8px;padding:20px 16px 8px}.dash-legal-footer a{font-size:12px;color:#9ca3af;text-decoration:none}.dash-legal-footer a:hover{color:var(--brand);text-decoration:underline}.dash-legal-sep{font-size:12px;color:#d1d5db}.dash-powered{text-align:center;font-size:11px;font-weight:600;color:#d1d5db;letter-spacing:.04em;padding:4px 16px 20px}.register-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px 16px;font-family:Inter,sans-serif}.register-loading{min-height:100vh;display:flex;align-items:center;justify-content:center;font-size:15px;color:#94a3b8}.register-card{background:#fff;border-radius:20px;padding:40px 32px;max-width:420px;width:100%;box-shadow:0 8px 32px #0000001a;display:flex;flex-direction:column;align-items:center;gap:0}.register-logo{width:80px;height:80px;object-fit:contain;border-radius:16px;margin-bottom:20px}.register-logo-placeholder{width:80px;height:80px;border-radius:16px;background:var(--brand, #0592A7);display:flex;align-items:center;justify-content:center;font-size:32px;color:#fff;font-weight:700;margin-bottom:20px}.register-title{font-size:22px;font-weight:700;color:#0f172a;text-align:center;margin:0 0 8px}.register-subtitle{font-size:14px;color:#64748b;text-align:center;margin:0 0 28px;line-height:1.5}.register-form{width:100%;display:flex;flex-direction:column;gap:16px}.register-field{display:flex;flex-direction:column;gap:6px}.register-field label{font-size:13px;font-weight:600;color:#374151}.register-optional{font-weight:400;color:#94a3b8}.register-field input{padding:12px 14px;border:1.5px solid #e2e8f0;border-radius:10px;font-size:15px;color:#0f172a;outline:none;transition:border-color .15s}.register-field input:focus{border-color:var(--brand, #0592A7)}.register-error{background:#fef2f2;color:#e11d48;border:1px solid #fecdd3;border-radius:8px;padding:10px 14px;font-size:13px}.register-btn{width:100%;padding:14px;border:none;border-radius:12px;color:#fff;font-size:15px;font-weight:600;cursor:pointer;margin-top:4px;transition:opacity .15s,transform .1s}.register-btn:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.register-btn:disabled{opacity:.6;cursor:not-allowed}.register-legal{font-size:11px;color:#cbd5e1;text-align:center;margin-top:20px;line-height:1.5}.register-row-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}.register-hint{font-size:12px;color:#94a3b8;margin-top:4px}@media(max-width:380px){.register-row-2{grid-template-columns:1fr}}.invalid-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}.invalid-card{background:#fff;border-radius:var(--radius);padding:48px 32px;text-align:center;max-width:400px;width:100%;box-shadow:var(--shadow-md)}.invalid-icon{font-size:48px;margin-bottom:16px}.invalid-card h1{font-size:22px;font-weight:700;margin-bottom:12px;color:var(--text)}.invalid-card p{color:var(--muted);line-height:1.6}.legal-page{min-height:100dvh;background:var(--bg, #F0F2F5);display:flex;flex-direction:column;font-family:inherit;color:#111827}.legal-header{background:#fff;padding:16px 20px 12px;border-bottom:1px solid #e5e7eb;position:sticky;top:0;z-index:10}.legal-back{background:none;border:none;color:var(--brand, #4F46E5);font-size:14px;font-weight:600;cursor:pointer;padding:0;margin-bottom:6px}.legal-header-text h1{font-size:18px;font-weight:700;margin:0 0 2px;color:#111827}.legal-header-text p{font-size:12px;color:#9ca3af;margin:0}.legal-body{flex:1;padding:20px 20px 40px;max-width:680px;width:100%;margin:0 auto;box-sizing:border-box}.legal-section{margin-bottom:24px}.legal-section h2{font-size:14px;font-weight:700;color:#374151;margin:0 0 8px;text-transform:uppercase;letter-spacing:.04em}.legal-section p{font-size:14px;line-height:1.65;color:#4b5563;margin:0 0 6px}.legal-section ul{margin:0;padding-left:18px}.legal-section ul li{font-size:14px;line-height:1.65;color:#4b5563;margin-bottom:4px}.legal-section-footer{margin-top:8px!important;font-style:italic;color:#6b7280!important}.legal-footer{padding:16px 20px;text-align:center;background:#fff;border-top:1px solid #e5e7eb}.legal-footer p{font-size:13px;color:#9ca3af;margin:0}:root{--primary: #034650;--primary-dark: #022e36;--primary-light: #e0f2f1;--accent: #0e7490;--text: #1e293b;--muted: #64748b;--border: #e2e8f0;--surface: #ffffff;--surface-hover: #f8fafc;--bg: #f1f5f9;--radius: 12px;--shadow: 0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 4px 16px rgba(0,0,0,.1)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;-webkit-font-smoothing:antialiased}button,input{font-family:inherit}
