:root{--brand-primary: #6c5ce7;--brand-secondary: #764ba2;--brand-gradient: linear-gradient(135deg, #667eea, #764ba2);--app-bg: #f0eeff;--app-text: #1e1b4b;--app-text-secondary: #6b7280;--app-card-bg: #ffffff;--app-card-shadow: 0 2px 12px rgba(108,92,231,.08);--app-section-label: #9ca3af;--app-border: #e8e3ff;--color-success: #43a047;--color-warning: #ff9800;--color-error: #e53935;--color-info: #1976d2;--color-gold: #ffd700;--color-xp: #ffeb3b;--cell-bg: #ffffff;--cell-bg-given: #f5f3ff;--cell-bg-selected: #ede8ff;--cell-bg-related: #f5f3ff;--cell-bg-same: #ddd6fe;--cell-bg-conflict: #fee2e2;--cell-text: #1e1b4b;--cell-text-user: #6c5ce7;--cell-text-hint: #10b981;--cell-text-conflict: #dc2626;--border-thick: #c4b5fd;--border-thin: #ede9fe;--game-bg: linear-gradient(160deg, #f0eeff 0%, #e8e2ff 100%);--game-card-bg: #ffffff;--game-card-shadow: 0 8px 32px rgba(108, 92, 231, .12);--game-topbar-text: #1e1b4b;--game-muted: #9ca3af;--action-bar-bg: #f8f7ff;--action-btn-text: #4b5563;--action-btn-hover: #ede9fe;--numpad-btn-bg: #f8f7ff;--numpad-btn-shadow: 0 2px 8px rgba(108, 92, 231, .08);--font-base: -apple-system, BlinkMacSystemFont, "Segoe UI", "Sarabun", "Roboto", sans-serif;--font-mono: ui-monospace, SFMono-Regular, "SF Mono", Consolas, monospace;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--radius-sm: 6px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--radius-2xl: 28px;--radius-full: 9999px;--shadow-md: 0 4px 6px rgba(0,0,0,.1);--shadow-lg: 0 10px 15px rgba(0,0,0,.1);--shadow-modal: 0 20px 60px rgba(0,0,0,.5);--duration-fast: .1s;--duration-base: .2s;--ease-default: cubic-bezier(.4, 0, .2, 1)}.splash-screen{position:fixed;inset:0;background:var(--brand-gradient);display:flex;align-items:center;justify-content:center;z-index:9999;animation:splash-bg-in .3s ease both}.splash-screen.splash-leave{animation:splash-leave .35s cubic-bezier(.4,0,.2,1) forwards}@keyframes splash-bg-in{0%{opacity:0}to{opacity:1}}@keyframes splash-leave{to{opacity:0;transform:scale(1.08)}}.splash-logo-wrap{display:flex;flex-direction:column;align-items:center;gap:28px;transform:translateY(-20px)}.splash-logo{width:160px;height:160px;filter:drop-shadow(0 12px 24px rgba(0,0,0,.25));animation:logo-pop .7s cubic-bezier(.34,1.56,.64,1) both}@keyframes logo-pop{0%{transform:scale(.4) rotate(-8deg);opacity:0}60%{transform:scale(1.08) rotate(2deg);opacity:1}to{transform:scale(1) rotate(0);opacity:1}}.splash-board{transform-origin:center;animation:board-reveal .5s ease-out .2s both}@keyframes board-reveal{0%{transform:scale(0)}to{transform:scale(1)}}.splash-grid line{stroke-dasharray:200;stroke-dashoffset:200;animation:grid-draw .45s ease-out forwards}.splash-grid line:nth-child(1){animation-delay:.5s}.splash-grid line:nth-child(2){animation-delay:.55s}.splash-grid line:nth-child(3){animation-delay:.6s}.splash-grid line:nth-child(4){animation-delay:.65s}@keyframes grid-draw{to{stroke-dashoffset:0}}.splash-numbers .n{opacity:0;transform-origin:center;animation:num-pop .32s cubic-bezier(.34,1.56,.64,1) forwards}.splash-numbers .n1{animation-delay:.85s}.splash-numbers .n2{animation-delay:.95s}.splash-numbers .n3{animation-delay:1.05s}.splash-numbers .n4{animation-delay:1.15s}.splash-numbers .n5{animation-delay:1.25s}.splash-numbers .n6{animation-delay:1.35s}.splash-numbers .n7{animation-delay:1.45s}@keyframes num-pop{0%{opacity:0;transform:scale(.3)}60%{opacity:1;transform:scale(1.2)}to{opacity:1;transform:scale(1)}}.splash-title{font-size:32px;font-weight:800;letter-spacing:.5px;color:#fff;text-shadow:0 2px 12px rgba(0,0,0,.25);opacity:0;animation:title-in .5s ease-out 1.3s forwards}.splash-title span{font-weight:400;opacity:.85}@keyframes title-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.splash-dots{display:flex;gap:8px;opacity:0;animation:dots-in .4s ease-out 1.6s forwards}.splash-dots span{width:8px;height:8px;border-radius:50%;background:#ffffffb3;animation:dot-bounce 1s ease-in-out infinite}.splash-dots span:nth-child(1){animation-delay:0s}.splash-dots span:nth-child(2){animation-delay:.15s}.splash-dots span:nth-child(3){animation-delay:.3s}@keyframes dots-in{to{opacity:1}}@keyframes dot-bounce{0%,80%,to{transform:scale(.7);opacity:.5}40%{transform:scale(1.1);opacity:1}}@media (prefers-reduced-motion: reduce){.splash-logo,.splash-board,.splash-grid line,.splash-numbers .n,.splash-title,.splash-dots,.splash-dots span{animation:none;opacity:1;transform:none;stroke-dashoffset:0}}.cell,.numpad-num,.game-topbar .stat-value,#timer{font-family:"Fredoka",var(--font-base)}.numpad-num{letter-spacing:-.5px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%}#app{width:100%;min-height:100dvh;display:flex;flex-direction:column;align-items:center}body{font-family:var(--font-base);background:var(--app-bg);background-attachment:fixed;color:var(--app-text);min-height:100vh;min-height:-webkit-fill-available;min-height:100dvh;padding:calc(var(--space-4) + env(safe-area-inset-top)) calc(var(--space-4) + env(safe-area-inset-right)) var(--space-4) calc(var(--space-4) + env(safe-area-inset-left));-webkit-font-smoothing:antialiased;overscroll-behavior-y:contain}html{height:-webkit-fill-available}button{font-family:inherit;cursor:pointer}input,textarea{font-family:inherit}.hidden{display:none!important}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:80vh;text-align:center}.loading-screen h1{font-size:40px;margin-bottom:12px}.loading-screen p{opacity:.7}.view{width:100%;max-width:520px;margin:0 auto;display:flex;flex-direction:column;align-items:center;padding:0 16px calc(88px + env(safe-area-inset-bottom))}h1{font-size:clamp(24px,6vw,36px);margin-bottom:8px}h2{font-size:24px}h3{font-size:18px}.subtitle{opacity:.85;margin-bottom:20px}.header{position:sticky;top:0;z-index:25;width:100%;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);background:transparent;display:flex;align-items:center;justify-content:space-between;padding:8px 0;margin-bottom:8px}.user-badge{background:var(--app-card-bg);padding:6px 12px;border-radius:var(--radius-full);display:inline-flex;align-items:center;gap:8px;font-weight:400;color:var(--app-text);border:none;cursor:pointer;transition:background var(--duration-fast);font-family:inherit;font-size:14px;box-shadow:var(--app-card-shadow)}.user-badge:hover{background:#f0ecff}.user-badge:active{transform:scale(.98)}.user-avatar-img{width:24px;height:24px;border-radius:50%;object-fit:cover;flex-shrink:0}.badge-tag{background:#ede9fe;color:#6c5ce7;padding:2px 8px;border-radius:var(--radius-full);font-size:10px;font-weight:400;letter-spacing:.4px;text-transform:uppercase}.save-banner{width:100%;max-width:520px;background:var(--app-card-bg);border:1px solid var(--app-border);color:var(--app-text);padding:10px 14px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:8px;font-size:13px;box-shadow:var(--app-card-shadow)}.save-banner span{flex:1;line-height:1.4}.save-banner .btn{white-space:nowrap}.stat-pill{background:var(--app-card-bg);box-shadow:var(--app-card-shadow);color:var(--app-text);padding:6px 12px;border-radius:var(--radius-full);font-size:13px;font-weight:400;display:inline-flex;align-items:center;gap:4px}.card{background:var(--app-card-bg);border-radius:var(--radius-xl);padding:var(--space-4) var(--space-4);width:100%;max-width:520px;margin-bottom:var(--space-3);box-shadow:var(--app-card-shadow)}.card h3{margin-bottom:10px;color:var(--app-text);font-size:15px;font-weight:600}@media (max-height: 740px){h1{font-size:clamp(22px,5.5vw,30px);margin-bottom:4px}.card{padding:var(--space-4);margin-bottom:var(--space-3)}.card h3{font-size:16px;margin-bottom:8px}.header{margin-bottom:8px}.xp-bar{margin:2px 0 8px}.daily-card{padding:var(--space-4) var(--space-4)}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);min-height:44px;padding:0 var(--space-4);border:none;border-radius:var(--radius-md);background:var(--brand-primary);color:#fff;font-size:15px;font-weight:400;transition:transform var(--duration-fast),background var(--duration-fast)}.btn:hover{background:#5b4ed0}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.4;cursor:not-allowed}.btn--secondary{background:var(--app-card-bg);color:var(--app-text);border:1px solid var(--app-border)}.btn--secondary:hover{background:#f0ecff}.btn--full{width:100%}.btn--small{min-height:36px;padding:0 12px;font-size:13px}.top-bar{position:sticky;top:0;z-index:25;width:100%;max-width:520px;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);background:var(--app-bg);display:flex;justify-content:space-between;align-items:center;padding:10px 4px;margin-bottom:10px;gap:8px}.icon-btn{width:38px;height:38px;border:none;border-radius:var(--radius-full);background:var(--app-card-bg);color:var(--app-text);font-size:16px;box-shadow:var(--app-card-shadow)}.icon-btn:hover{background:#f0ecff}.game-topbar{display:flex;align-items:center;justify-content:space-between;padding:4px 0 12px;gap:6px;overflow:visible}.mode-pill{display:flex;align-items:center;gap:5px;background:#f0ecff;border:none;border-radius:var(--radius-full);padding:6px 12px 6px 8px;font-size:13px;font-weight:400;color:var(--game-topbar-text);cursor:pointer;white-space:nowrap;flex-shrink:0}.mode-pill:hover{background:#e8e2ff}.mode-pill.no-click{cursor:default;pointer-events:none}.mode-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.game-stats-row{display:flex;gap:6px}.stat-block{display:flex;flex-direction:column;align-items:center;gap:1px;background:#f0ecff;border-radius:12px;padding:5px 10px;min-width:58px}.stat-label{font-size:8px;font-weight:400;letter-spacing:.6px;color:var(--game-muted);text-transform:uppercase}.stat-value{font-size:15px;font-weight:400;font-variant-numeric:tabular-nums;color:var(--game-topbar-text)}.topbar-actions{display:flex;gap:6px;align-items:center}.topbar-icon-btn{width:32px;height:32px;border:none;border-radius:var(--radius-full);background:#f0ecff;color:#6c5ce7;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0}.topbar-icon-btn:hover{background:#e8e2ff}.board-wrap{position:relative;width:min(100%,440px)}.board-overlay{position:absolute;inset:0;border-radius:var(--radius-lg);background:#ffffffd1;backdrop-filter:blur(6px);display:none;align-items:center;justify-content:center;z-index:10}.board-overlay.open{display:flex}.board-menu{display:flex;flex-direction:column;gap:12px;width:72%}.board-menu-btn{width:100%;min-height:48px;border:none;border-radius:14px;font-size:16px;font-weight:400;cursor:pointer;transition:opacity .15s}.board-menu-btn:hover{opacity:.85}.board-menu-btn--resume{background:#6c5ce7;color:#fff}.board-menu-btn--new{background:#f0ecff;color:#6c5ce7}.board-menu-btn--leave{background:#fee2e2;color:#ef4444}.board{display:grid;grid-template-columns:repeat(9,1fr);width:100%;aspect-ratio:1;background:var(--border-thick);border:2.5px solid var(--border-thick);border-radius:var(--radius-lg);overflow:hidden}.cell{background:var(--cell-bg);color:var(--cell-text);display:flex;align-items:center;justify-content:center;font-size:clamp(16px,4.2vw,26px);font-weight:400;cursor:pointer;user-select:none;transition:background var(--duration-fast);border-right:1px solid var(--border-thin);border-bottom:1px solid var(--border-thin);position:relative}.cell.given{font-weight:400;color:var(--cell-text);background:var(--cell-bg-given)}.cell.user{color:var(--cell-text-user);font-weight:400}.cell.hint{color:var(--cell-text-hint);font-weight:400}.cell.conflict{color:var(--cell-text-conflict)!important;background:var(--cell-bg-conflict)!important}.cell.selected{background:var(--cell-bg-selected)!important;box-shadow:inset 0 0 0 2px #6c5ce7}.cell.related{background:var(--cell-bg-related)}.cell.same-num{background:var(--cell-bg-same)}.cell:nth-child(3n):not(:nth-child(9n)){border-right:2px solid var(--border-thick)}.cell:nth-child(n+19):nth-child(-n+27),.cell:nth-child(n+46):nth-child(-n+54){border-bottom:2px solid var(--border-thick)}.cell-notes{display:grid;grid-template-columns:repeat(3,1fr);width:100%;height:100%;padding:1px}.cell-notes span{display:flex;align-items:center;justify-content:center;font-size:clamp(7px,1.5vw,10px);font-weight:600;color:#7c6cdc;line-height:1}.action-bar{display:flex;justify-content:space-between;align-items:center;width:min(100%,440px);padding:10px 4px 6px;gap:4px}.action-btn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;border:none;background:transparent;color:var(--action-btn-text);font-size:11px;font-weight:600;padding:8px 2px;border-radius:var(--radius-lg);transition:background var(--duration-fast),color var(--duration-fast),opacity var(--duration-fast);cursor:pointer}.action-btn:hover{background:var(--action-btn-hover)}.action-btn:disabled{opacity:.35;cursor:default}.action-btn--erase{background:#f0ecff;color:#6c5ce7}.action-btn--erase:hover{background:#e8e2ff}.action-btn--notes-on{background:#f0ecff;color:#6c5ce7}.action-btn--notes-on:hover{background:#e8e2ff}.notes-btn-inner,.hint-btn-inner{position:relative;display:inline-flex;align-items:center;justify-content:center}.notes-badge{position:absolute;top:-6px;right:-10px;background:#d1d5db;color:#fff;font-size:8px;font-weight:800;letter-spacing:.3px;padding:1px 4px;border-radius:99px;line-height:1.4;pointer-events:none}.notes-badge.on{background:#6c5ce7}.hint-count-badge{position:absolute;top:-6px;right:-8px;background:#6c5ce7;color:#fff;font-size:9px;font-weight:800;width:16px;height:16px;border-radius:50%;display:flex;align-items:center;justify-content:center;pointer-events:none}.numpad{display:flex;flex-direction:row;justify-content:space-between;width:min(100%,440px);padding:4px 0 8px;gap:0}.numpad button{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;border:1.5px solid #e8e3ff;background:#f5f3ff;margin:0 2px;padding:10px 2px;transition:transform var(--duration-fast),background var(--duration-fast);cursor:pointer;border-radius:var(--radius-md)}.numpad button:hover{background:#ede8ff;border-color:#c4b5fd}.numpad button:active{transform:scale(.92)}.numpad button.done{opacity:.25;pointer-events:none}.numpad-num{font-size:clamp(20px,5vw,28px);font-weight:400;color:var(--cell-text);line-height:1}.numpad-count{font-size:10px;font-weight:600;color:var(--game-muted);min-height:14px;line-height:1}.bottom-nav{position:fixed;bottom:0;left:0;right:0;background:#fff;display:flex;justify-content:space-around;padding:8px 0 calc(8px + env(safe-area-inset-bottom));border-top:1px solid var(--app-border);z-index:30}.bottom-nav button{flex:1;background:transparent;border:none;color:#9ca3af;font-size:11px;display:flex;flex-direction:column;align-items:center;gap:2px;padding:6px}.bottom-nav button .icon{font-size:20px;line-height:1}.bottom-nav button.active{color:var(--brand-primary)}.daily-card{text-align:center}.daily-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.daily-head h3{margin:0}.daily-date{opacity:.75;font-size:12px;margin-bottom:6px}.live-stats-card{padding:12px 14px!important}.live-stats-header{display:flex;align-items:center;gap:8px;margin-bottom:10px}.live-dot-wrap{display:inline-flex;align-items:center;gap:5px;background:#10b9812e;border:1px solid rgba(16,185,129,.4);border-radius:var(--radius-full);padding:2px 8px;font-size:10px;font-weight:700;color:#10b981;letter-spacing:.8px}.live-dot{width:7px;height:7px;background:#10b981;border-radius:50%;animation:live-pulse 1.6s ease-in-out infinite}@keyframes live-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.75)}}.live-stats-title{font-size:13px;font-weight:600;opacity:.8}.live-stats-grid{display:flex;align-items:stretch;gap:0}.ls-block{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:0 4px}.ls-block--online .ls-value{color:#10b981}.ls-divider{width:1px;background:var(--app-border);margin:0 4px;align-self:stretch}.ls-value{font-size:22px;font-weight:400;line-height:1;letter-spacing:-.5px;color:var(--app-text)}.ls-label{font-size:10px;font-weight:400;color:var(--app-text-secondary);text-transform:uppercase;letter-spacing:.4px}.ls-sub{display:flex;gap:6px;font-size:10px;color:var(--app-text-secondary);margin-top:2px;flex-wrap:wrap;justify-content:center}.daily-difficulty{display:inline-block;background:#ffffff40;padding:3px 10px;border-radius:var(--radius-full);font-size:11px;text-transform:uppercase;letter-spacing:.3px;color:#fff}.daily-status{font-size:14px;opacity:.9;margin-bottom:12px}.practice-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;margin-top:8px}.practice-btn{min-height:56px;padding:6px 4px;flex-direction:column;gap:2px;font-size:18px}.practice-btn span{font-size:11px;font-weight:600;opacity:.9}.save-banner--compact{padding:6px 10px;font-size:12px;margin-bottom:8px}.save-banner--compact .btn{min-height:30px;padding:0 10px;font-size:12px}.guest-id-chip{display:inline-block;font-family:Courier New,monospace;font-size:12px;font-weight:700;letter-spacing:1px;color:#fde68a;background:#fde68a1f;border:1px solid rgba(253,230,138,.3);border-radius:4px;padding:0 5px;margin-left:4px}.view--home{gap:8px;padding-top:4px}.view--home .card{margin-bottom:0}.view--home .quests-card{min-height:70px}.home-header{width:100%;display:flex;align-items:center;justify-content:space-between;gap:8px}.home-user-btn{display:inline-flex;align-items:center;gap:10px;background:var(--app-card-bg);border:none;border-radius:var(--radius-xl);padding:8px 14px 8px 8px;cursor:pointer;box-shadow:var(--app-card-shadow)}.home-avatar{width:34px;height:34px;border-radius:50%;background:#ede9fe;color:var(--brand-primary);display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden}.home-user-info{display:flex;flex-direction:column;align-items:flex-start;gap:1px}.home-user-name{font-size:14px;color:var(--app-text);line-height:1.2}.home-user-id{font-size:10px;color:var(--app-text-secondary);font-family:Courier New,monospace;letter-spacing:.5px}.home-header-right{display:flex;align-items:center;gap:6px}.home-icon-btn{width:34px;height:34px;border:none;border-radius:50%;background:var(--app-card-bg);color:var(--app-text);display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:var(--app-card-shadow)}.home-icon-btn:hover{background:#f0ecff}.home-xp{width:100%;padding:2px 0 4px}.home-xp-label{display:flex;justify-content:space-between;font-size:12px;color:var(--app-text-secondary);margin-bottom:5px}.home-save-banner{width:100%;background:var(--app-card-bg);border:1px solid var(--app-border);border-radius:var(--radius-lg);padding:10px 14px;display:flex;align-items:center;justify-content:space-between;gap:12px;font-size:13px;color:var(--app-text-secondary);box-shadow:var(--app-card-shadow)}.home-save-banner span{flex:1}.daily-card-v2{width:100%;background:linear-gradient(135deg,#6c5ce7,#764ba2);border-radius:var(--radius-xl);padding:16px;color:#fff}.daily-card-v2-head{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:12px;gap:8px}.daily-card-v2-title{display:flex;align-items:center;gap:6px;font-size:16px;color:#fff;margin-bottom:4px}.daily-card-v2-date{font-size:12px;opacity:.8}.daily-card-v2-btn{width:100%;background:#fff;color:var(--brand-primary);min-height:44px;border-radius:var(--radius-full)}.daily-card-v2-btn:hover{background:#f0ecff}.home-section-label{width:100%;font-size:11px;font-weight:400;letter-spacing:.8px;color:var(--app-text-secondary);text-transform:uppercase;margin-bottom:-2px}.practice-grid-v2{width:100%;display:grid;grid-template-columns:1fr 1fr;gap:8px}.practice-card-v2{background:var(--app-card-bg);border:1px solid var(--app-border);border-radius:var(--radius-lg);padding:14px;display:flex;align-items:center;gap:12px;cursor:pointer;text-align:left;box-shadow:var(--app-card-shadow);transition:background var(--duration-fast)}.practice-card-v2:hover{background:#f8f7ff}.practice-card-v2-icon{flex-shrink:0;display:flex}.practice-card-v2-labels{display:flex;flex-direction:column;gap:2px}.practice-card-v2-name{font-size:14px;color:var(--app-text)}.practice-card-v2-sub{font-size:11px;color:var(--app-text-secondary)}.btn--primary{background:var(--brand-primary);color:#fff;border:none}.btn--primary:hover{background:#5b4ed0}.view--game{padding-bottom:24px;overflow-y:auto;min-height:100dvh;height:auto;justify-content:flex-start;background:transparent}.game-card{width:min(100%,440px);background:var(--game-card-bg);border-radius:24px;box-shadow:var(--game-card-shadow);padding:16px;display:flex;flex-direction:column;align-items:center;gap:0;margin-top:8px}.game-footer{padding:12px 16px;width:100%;text-align:center;font-size:12px;color:#ffffff4d;text-decoration:none;letter-spacing:.5px;transition:color .2s;flex-shrink:0}.game-footer:hover{color:#ffffffa6}.modal-bg{position:fixed;inset:0;background:#000000b3;display:none;align-items:center;justify-content:center;z-index:100;padding:20px}.modal-bg.active{display:flex}.modal{background:#fff;border-radius:var(--radius-2xl);padding:28px;text-align:center;box-shadow:0 24px 64px #6c5ce72e;max-width:400px;width:100%;color:var(--app-text)}.modal h2{margin-bottom:10px;color:var(--app-text)}.modal .big-number{font-size:44px;font-weight:700;color:var(--brand-primary);font-variant-numeric:tabular-nums;margin:12px 0 8px}.modal-buttons{display:flex;gap:10px;justify-content:center;margin-top:16px}.auth-modal{text-align:left;position:relative}.auth-modal h2{text-align:center;margin-bottom:6px}.auth-sub{text-align:center;font-size:14px;color:var(--app-text-secondary);margin-bottom:18px}.modal-close{position:absolute;top:12px;right:14px;width:32px;height:32px;border:none;background:#f3f0ff;color:var(--app-text-secondary);border-radius:50%;font-size:20px;line-height:1;cursor:pointer}.modal-close:hover{background:#ede9fe}.auth-tabs{display:flex;gap:4px;background:#f3f0ff;padding:4px;border-radius:var(--radius-md);margin-bottom:18px}.auth-tab{flex:1;background:transparent;border:none;color:var(--app-text-secondary);padding:10px;font-size:14px;font-weight:700;border-radius:var(--radius-sm);cursor:pointer}.auth-tab.active{background:#fff;color:var(--brand-primary);box-shadow:0 1px 4px #6c5ce71f}.auth-form{display:flex;flex-direction:column;gap:12px}.auth-field{display:flex;flex-direction:column;gap:4px}.auth-field>span{font-size:12px;font-weight:600;color:var(--app-text-secondary);text-transform:uppercase;letter-spacing:.5px}.auth-field input{padding:12px 14px;border:1.5px solid var(--app-border);border-radius:var(--radius-md);background:#faf9ff;color:var(--app-text);font-size:15px;outline:none;transition:border-color .15s}.auth-field input::placeholder{color:#c4bfda}.auth-field input:focus{border-color:var(--brand-primary)}.auth-error{min-height:18px;color:var(--color-error);font-size:13px;text-align:center;margin:4px 0 0}.auth-note{margin-top:14px;text-align:center;font-size:13px;color:var(--app-text-secondary)}.auth-link{background:none;border:none;color:var(--brand-primary);font-weight:700;text-decoration:underline;cursor:pointer;font-size:inherit;padding:0}.btn-google{width:100%;display:flex;align-items:center;justify-content:center;gap:10px;background:#fff;color:#1f1f1f;border:1.5px solid var(--app-border);border-radius:var(--radius-md);padding:12px 16px;font-size:15px;font-weight:600;cursor:pointer;margin-bottom:4px;transition:background .15s,box-shadow .15s;box-shadow:0 1px 3px #00000014}.btn-google:hover{background:#f5f5f5;box-shadow:0 2px 6px #0000001a}.btn-google:active{background:#ebebeb}.btn-google:disabled{opacity:.6;cursor:not-allowed}.auth-divider{display:flex;align-items:center;gap:10px;margin:14px 0 10px;color:var(--app-text-secondary);font-size:12px}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--app-border)}.lb-tabs{display:flex;gap:4px;background:#ede9fe;padding:4px;border-radius:var(--radius-md);margin-bottom:6px;width:100%}.lb-tabs--main{position:sticky;top:54px;z-index:24;background:var(--app-bg);padding-top:4px}.lb-tabs--main .lb-tab{padding:10px;font-size:14px}.lb-tabs--date{position:sticky;top:110px;z-index:23;background:var(--app-bg);margin-bottom:8px}.lb-tab-sm{flex:1;background:transparent;border:none;color:var(--app-text-secondary);padding:7px;font-size:12px;font-weight:400;border-radius:var(--radius-sm);cursor:pointer}.lb-tab-sm.active{background:#fff;color:var(--brand-primary)}.lb-tab{flex:1;background:transparent;border:none;color:var(--app-text-secondary);padding:10px;font-size:14px;font-weight:400;border-radius:var(--radius-sm);cursor:pointer}.lb-tab.active{background:#fff;color:var(--brand-primary)}.lb-guest-badge{width:100%;max-width:520px;background:var(--app-card-bg);border:1px solid var(--app-border);border-radius:var(--radius-md);padding:8px 14px;font-size:12px;color:var(--app-text-secondary);margin-bottom:10px;display:flex;align-items:center;gap:6px;box-shadow:var(--app-card-shadow)}.lb-guest-badge strong{font-family:Courier New,monospace;font-size:14px;letter-spacing:1px;color:var(--brand-primary)}.lb-guest-id{font-family:Courier New,monospace;font-size:13px;letter-spacing:.5px}.lb-meta{width:100%;max-width:520px;font-size:13px;color:var(--app-text-secondary);display:flex;gap:8px;margin-bottom:8px}.lb-list{width:100%;max-width:520px;display:flex;flex-direction:column;gap:6px}.lb-row{display:grid;grid-template-columns:44px 1fr auto;align-items:center;gap:10px;background:var(--app-card-bg);padding:12px 14px;border-radius:var(--radius-lg);border:1px solid var(--app-border);transition:background var(--duration-fast);box-shadow:var(--app-card-shadow)}.lb-row.is-me{background:#ede9fe;border-color:#c4b5fd}.lb-row.flash{animation:lbFlash 1s ease}@keyframes lbFlash{0%,to{background:#ede9fe}50%{background:#ddd6fe}}.lb-rank{font-size:16px;font-weight:400;font-variant-numeric:tabular-nums;text-align:center;color:var(--app-text)}.lb-rank-badge{width:32px;height:32px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:14px;font-weight:400}.lb-rank-1{background:#fef3c7;color:#d97706}.lb-rank-2{background:#f1f5f9;color:#64748b}.lb-rank-3{background:#fef0e7;color:#c2410c}.lb-rank-other{background:#ede9fe;color:var(--brand-primary)}.lb-name{font-size:14px;font-weight:400;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--app-text)}.lb-sub-name{font-size:11px;color:var(--app-text-secondary);margin-top:1px}.lb-you{background:#ede9fe;color:var(--brand-primary);padding:1px 6px;border-radius:var(--radius-full);font-size:10px;letter-spacing:.4px;text-transform:uppercase;margin-left:4px}.lb-score{display:flex;flex-direction:column;align-items:flex-end;font-variant-numeric:tabular-nums}.lb-score strong{font-size:15px;color:var(--brand-primary)}.lb-score small{font-size:11px;color:var(--app-text-secondary)}.lb-empty{width:100%;max-width:520px;background:var(--app-card-bg);border-radius:var(--radius-lg);padding:30px 16px;text-align:center;color:var(--app-text-secondary);box-shadow:var(--app-card-shadow)}.lb-empty p{margin-bottom:8px}.lb-skeleton{width:100%;display:flex;flex-direction:column;gap:6px}.lb-skeleton-row{height:52px;background:linear-gradient(90deg,#f0ecff,#e8e3ff,#f0ecff);background-size:200% 100%;border-radius:var(--radius-md);animation:lbShimmer 1.4s linear infinite}@keyframes lbShimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.lb-scroll{display:block;margin:14px auto 6px;box-shadow:0 4px 16px #0006}.quest-row{display:grid;grid-template-columns:32px 1fr auto;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--app-border)}.quest-row:last-child{border-bottom:none}.quest-icon{font-size:22px;text-align:center}.quest-title{font-size:14px;color:var(--app-text);margin-bottom:6px}.quest-bar{height:6px;background:#e8e3ff;border-radius:var(--radius-full);overflow:hidden}.quest-bar-fill{height:100%;background:linear-gradient(90deg,var(--brand-primary),#a78bfa);transition:width var(--duration-base)}.quest-meta{display:flex;justify-content:space-between;font-size:11px;color:var(--app-text-secondary);margin-top:4px}.quest-tag{background:#d1fae5;color:#059669;padding:4px 10px;border-radius:var(--radius-full);font-size:11px;letter-spacing:.4px;text-transform:uppercase}.quest-tag.muted{background:#ede9fe;color:var(--app-text-secondary)}.quest-claimed{opacity:.65}.onb-modal{text-align:center;max-width:440px}.onb-dots{display:flex;justify-content:center;gap:8px;margin-bottom:14px}.onb-dot{width:8px;height:8px;border-radius:50%;background:#ffffff40;transition:background var(--duration-fast),transform var(--duration-fast)}.onb-dot.active{background:var(--color-xp);transform:scale(1.4)}.onb-dot.done{background:#ffffffb3}.onb-emoji{font-size:56px;margin-bottom:6px;line-height:1}.onb-sub{opacity:.85;font-size:14px;margin-top:4px}.onb-list{list-style:none;padding:0;margin:14px 0 0;text-align:left;display:flex;flex-direction:column;gap:10px}.onb-list li{background:#0003;padding:10px 14px;border-radius:var(--radius-md);font-size:14px;line-height:1.45}.onb-choices{display:flex;gap:10px;justify-content:center;margin-top:8px}.onb-choices .btn.selected{background:#ffec8059;outline:2px solid var(--color-xp)}.xp-bar{position:sticky;top:52px;z-index:24;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);background:transparent;width:100%;padding:4px 0 6px;margin:0 0 8px}.xp-bar-label{display:flex;justify-content:space-between;font-size:12px;font-weight:400;color:var(--app-text);margin-bottom:4px;font-variant-numeric:tabular-nums}.xp-bar-track{height:6px;background:#e8e3ff;border-radius:var(--radius-full);overflow:hidden}.xp-bar-fill{height:100%;background:linear-gradient(90deg,var(--color-xp),var(--color-warning));transition:width var(--duration-base)}.shop-tabs{position:sticky;top:54px;z-index:24;background:var(--app-bg);display:flex;gap:6px;flex-wrap:wrap;padding:6px 0;margin-bottom:8px;width:100%}.shop-tab{background:var(--app-card-bg);border:1px solid var(--app-border);color:var(--app-text-secondary);padding:6px 14px;border-radius:var(--radius-full);font-size:13px;font-weight:400;cursor:pointer;display:inline-flex;align-items:center;gap:4px}.shop-tab.active{background:var(--brand-primary);color:#fff;border-color:var(--brand-primary)}.shop-grid{width:100%;display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.shop-card{background:var(--app-card-bg);border:1px solid var(--app-border);border-radius:var(--radius-lg);padding:12px 8px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:4px;min-height:0;box-shadow:var(--app-card-shadow)}.shop-card.shop-rarity-rare{border-color:#2196f366}.shop-card.shop-rarity-epic{border-color:#9c27b066}.shop-card.shop-rarity-legendary{border-color:#ffd70099}.shop-preview{font-size:30px;line-height:1}.shop-name{font-size:12px;line-height:1.2;color:var(--app-text)}.shop-desc{font-size:10px;color:var(--app-text-secondary);line-height:1.2}.shop-rarity{font-size:9px;text-transform:uppercase;letter-spacing:.4px;color:var(--app-text-secondary)}.shop-action{margin-top:auto;padding-top:4px;width:100%}.shop-action .btn{width:100%;font-size:11px;padding:5px 4px;min-height:32px}.shop-loading{padding:30px;color:var(--app-text-secondary);text-align:center}.profile-hero{width:100%;max-width:520px;display:flex;flex-direction:column;align-items:center;padding:16px 0}.profile-avatar{width:88px;height:88px;border-radius:50%;background:var(--brand-primary);border:none;font-size:44px;color:#fff;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:transform var(--duration-fast);box-shadow:0 4px 16px #6c5ce74d}.profile-avatar:hover{transform:scale(1.05)}.profile-name{display:flex;align-items:center;gap:6px;margin-top:10px;font-size:20px;color:var(--app-text)}.icon-btn--ghost{background:transparent;width:28px;height:28px;font-size:14px;color:var(--app-text-secondary);border:none;border-radius:50%}.icon-btn--ghost:hover{background:#ede9fe}.profile-stats{width:100%;max-width:520px;display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:14px}.stat-tile{background:var(--app-card-bg);border-radius:var(--radius-lg);padding:12px 10px;text-align:center;box-shadow:var(--app-card-shadow)}.stat-label{font-size:10px;color:var(--app-text-secondary);text-transform:uppercase;letter-spacing:.5px}.stat-value{font-size:18px;font-weight:400;margin-top:4px;color:var(--app-text)}.profile-row{width:100%;background:transparent;border:none;color:var(--app-text);text-align:left;padding:14px 4px;font-size:14px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--app-border);cursor:pointer;font-family:inherit}.profile-row:last-child{border-bottom:none}.profile-row:hover{background:#f8f7ff}.profile-row small{color:var(--app-text-secondary);font-size:12px}.profile-row .row-icon{margin-right:10px;color:var(--brand-primary)}.profile-row.danger strong{color:#ef4444}.avatar-grid{margin-top:16px;width:100%;max-width:520px;background:var(--app-card-bg);border-radius:var(--radius-lg);padding:14px;display:grid;grid-template-columns:repeat(7,1fr);gap:8px;box-shadow:var(--app-card-shadow)}.avatar-cell{aspect-ratio:1;background:#f5f3ff;border:2px solid transparent;border-radius:var(--radius-md);font-size:24px;cursor:pointer;display:flex;align-items:center;justify-content:center}.avatar-cell:hover{background:#ede9fe}.avatar-cell.selected{border-color:var(--brand-primary);background:#ede9fe}.ach-grid{width:100%;max-width:720px;display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}.ach-card{background:#ffffff1a;border-radius:var(--radius-lg);padding:14px 10px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:6px;position:relative;overflow:hidden}.ach-card.locked{opacity:.55}.ach-card.unlocked{background:#ffec801f;border:1px solid rgba(255,236,128,.3)}.ach-icon{font-size:38px;width:60px;height:60px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;background:#00000040;border:3px solid var(--tier-color, #cd7f32)}.ach-name{font-weight:700;font-size:14px}.ach-desc{font-size:11px;opacity:.75;line-height:1.3}.ach-tier{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:2px 8px;border-radius:var(--radius-full)}.ach-rewards{display:flex;gap:8px;font-size:11px}.stats-body{width:100%;max-width:520px}.lvl-modal{text-align:center}.lvl-stars{font-size:60px;animation:lvlPulse 1.4s ease-in-out infinite}@keyframes lvlPulse{0%,to{transform:scale(1)}50%{transform:scale(1.15)}}.paywall-modal{max-width:440px}.paywall-plans{display:flex;gap:10px;margin:12px 0}.paywall-plan{flex:1;background:#ffffff1a;border:2px solid rgba(255,255,255,.2);color:#fff;border-radius:var(--radius-md);padding:14px 10px;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:4px}.paywall-plan strong{font-size:14px}.paywall-plan span{font-size:16px;font-weight:700}.paywall-plan small{font-size:10px;opacity:.8;color:var(--color-xp)}.paywall-plan.recommended{background:#ffec802e;border-color:var(--color-xp)}.float-reward{position:fixed;transform:translate(-50%);pointer-events:none;font-weight:700;font-size:14px;color:var(--color-xp);text-shadow:0 2px 6px rgba(0,0,0,.5);z-index:250;animation:floatUp 1.2s ease-out forwards}@keyframes floatUp{0%{opacity:0;transform:translate(-50%)}20%{opacity:1}to{opacity:0;transform:translate(-50%,-50px)}}.shop-premium-badge{position:absolute;top:6px;right:6px;background:linear-gradient(135deg,var(--color-xp),var(--color-warning));color:#1a1a2e;border-radius:var(--radius-full);padding:2px 6px;font-size:10px;font-weight:700}.shop-card.previewable{cursor:pointer;position:relative}.shop-card.previewable:hover{transform:translateY(-2px);transition:transform var(--duration-fast)}.stats-chart{width:100%;display:block;margin-top:8px}.recap-hero{text-align:center;margin-bottom:16px}.recap-hero h2{margin-top:6px}body{background:var(--app-bg);background-attachment:fixed;transition:background .4s ease;position:relative}body.bg-default{background:var(--app-bg);background-attachment:fixed}body[class*=bg-]:not(.bg-default) .view{background:#ffffff73;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:var(--radius-xl);margin-top:8px;margin-bottom:8px}body[class*=bg-]:not(.bg-default) .bottom-nav{background:#fff9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}body.bg-blank-white{background:#fafafa;color:#1a1a2e}body.bg-solid-navy{background:#0d1b2a}body.bg-solid-forest{background:#1b4332}body.bg-pattern-dots{background:radial-gradient(circle at 1px 1px,rgba(255,255,255,.18) 1px,transparent 1px),var(--brand-gradient);background-size:22px 22px,auto;background-attachment:fixed,fixed}body.bg-pattern-waves{background:repeating-linear-gradient(45deg,#ffffff0d 0 10px,#fff0 10px 20px),var(--brand-gradient);background-attachment:fixed,fixed}body.bg-anim-rain{overflow-x:hidden}body.bg-anim-rain:before{content:"";position:fixed;inset:0;background-image:repeating-linear-gradient(100deg,rgba(255,255,255,.12) 0 1px,transparent 1px 8px);animation:rainShift .7s linear infinite;pointer-events:none;z-index:0}@keyframes rainShift{0%{transform:translateZ(0)}to{transform:translate3d(-8px,40px,0)}}body.bg-anim-stars{background:radial-gradient(circle at 20% 30%,rgba(255,255,255,.9) .5px,transparent 1.5px),radial-gradient(circle at 70% 80%,rgba(255,255,255,.7) .5px,transparent 1.5px),radial-gradient(circle at 40% 60%,rgba(255,255,255,.8) .5px,transparent 1.5px),radial-gradient(circle at 85% 15%,rgba(255,255,255,.6) .5px,transparent 1.5px),linear-gradient(135deg,#0d1b2a,#1b1b3a);background-size:200px 200px,240px 240px,180px 180px,260px 260px,auto;background-attachment:fixed;animation:starsTwinkle 4s ease-in-out infinite alternate}@keyframes starsTwinkle{0%{opacity:.85}to{opacity:1}}body.bg-anim-aurora{background:linear-gradient(120deg,#0f2027,#2c5364,#1e6091,#4eba6f,#1f4068);background-size:400% 400%;background-attachment:fixed;animation:auroraShift 14s ease infinite}@keyframes auroraShift{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}@media (prefers-reduced-motion: reduce){body.bg-anim-rain:before,body.bg-anim-stars,body.bg-anim-aurora{animation:none!important}}.ledger-list{display:flex;flex-direction:column;gap:4px;max-height:60vh;overflow-y:auto}.ledger-row{display:flex;justify-content:space-between;align-items:center;padding:10px 4px;border-bottom:1px solid rgba(255,255,255,.08)}.ledger-row:last-child{border-bottom:none}.ledger-reason{display:flex;flex-direction:column;font-size:13px}.ledger-reason strong{font-weight:600}.ledger-reason small{opacity:.6;font-size:11px;margin-top:2px}.ledger-amount{font-weight:700;font-size:15px;font-variant-numeric:tabular-nums}.mute-btn{background:#0000004d;border:none;border-radius:var(--radius-full);width:34px;height:34px;font-size:16px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:background var(--duration-fast)}.mute-btn:hover{background:#00000080}.mute-btn:active{transform:scale(.95)}.toast{position:fixed;bottom:90px;left:50%;transform:translate(-50%);background:#1a1a2ef2;color:#fff;padding:12px 20px;border-radius:var(--radius-md);z-index:200;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translate(-50%,20px)}to{opacity:1;transform:translate(-50%)}}:focus-visible{outline:2px solid white;outline-offset:2px}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}}.loading-overlay{position:fixed;inset:0;background:#000000b3;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:999;gap:16px;animation:fadeIn .2s ease-out}.spinner{width:50px;height:50px;border:4px solid rgba(255,255,255,.15);border-left-color:#fff;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}
