*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body{background:#0d0d1a;height:100%;overflow-x:hidden}#root{min-height:100dvh}button{outline:none}@keyframes sparkle{0%,to{opacity:.15;transform:scale(1)}50%{opacity:.45;transform:scale(1.8)}}@keyframes floatLogo{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes confettiFall{0%{opacity:1;transform:translateY(-10px)rotate(0)}to{opacity:0;transform:translateY(100vh)rotate(720deg)}}@keyframes pulse{0%,to{transform:scale(1)}50%{color:#ff1744;transform:scale(1.15)}}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes hintGlow{0%,to{box-shadow:0 0 8px #ffd70066}50%{box-shadow:0 0 20px #ffd700e6}}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-6px)}40%{transform:translate(6px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}}.card-scene{perspective:700px;aspect-ratio:1;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;width:100%}.card-inner{width:100%;height:100%;transform-style:preserve-3d;will-change:transform;transition:transform .32s cubic-bezier(.4,0,.2,1);position:relative}.card-inner.flipped{transform:rotateY(180deg)}.card-face{backface-visibility:hidden;border-radius:10px;justify-content:center;align-items:center;display:flex;position:absolute;inset:0;overflow:hidden}.card-back{background:linear-gradient(135deg,#1a1a2e 0%,#16213e 100%);border:2px solid #ffffff26;transform:rotateY(0)}.card-front{background:linear-gradient(135deg,#fff8f0 0%,#fff3e0 100%);border:2px solid #fff;transition:border-color .3s,box-shadow .3s;transform:rotateY(180deg)}.card-front.matched{border-color:gold;box-shadow:0 0 14px #ffd700cc,inset 0 0 8px #ffd70033}.card-scene.active:hover .card-inner{transform:rotateY(0)translateY(-3px)scale(1.04)}.card-scene.active:hover .card-inner.flipped{transform:rotateY(180deg)translateY(-3px)scale(1.04)}@keyframes matchPop{0%{transform:scale(1)}40%{transform:scale(1.12)}70%{transform:scale(.96)}to{transform:scale(1)}}.card-scene.matched-pop{animation:.4s forwards matchPop}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:#0d0d1a}::-webkit-scrollbar-thumb{background:#333;border-radius:2px}.home-container{background:linear-gradient(160deg,#1a0000 0%,#2d0000 40%,#1a0808 100%);flex-direction:column;justify-content:center;align-items:center;gap:0;min-height:100dvh;padding:20px 16px;font-family:"Press Start 2P",monospace;display:flex;position:relative;overflow:hidden}.home-bg-pattern{pointer-events:none;position:absolute;inset:0}.home-sparkle{background:gold;border-radius:50%;animation:2s ease-in-out infinite sparkle;position:absolute}.home-logo-area{text-align:center;margin-bottom:24px;animation:3s ease-in-out infinite floatLogo}.home-logo-subtitle{letter-spacing:8px;color:gold;text-shadow:0 0 20px gold;margin-bottom:4px;font-size:11px}.home-logo-title{color:#fff;text-shadow:3px 3px #c00,6px 6px #800,0 0 30px #ffd70080;margin-bottom:4px;font-size:32px;line-height:1.2}.home-logo-english{letter-spacing:4px;color:#ffd70099;margin-top:6px;font-size:9px}.home-ball-row{align-items:flex-end;gap:16px;margin-bottom:20px;display:flex}.home-ball-item{cursor:default;flex-direction:column;align-items:center;gap:4px;transition:transform .2s;display:flex}.home-ball-item:hover{transform:scale(1.15)translateY(-6px)}.home-ball-label{letter-spacing:1px;margin-top:2px;font-size:7px}.home-stage-info{flex-direction:column;gap:6px;width:100%;max-width:320px;margin-bottom:20px;display:flex}.home-stage-info-item{color:#ccc;background:#ffffff0d;border:1px solid #ffd70026;border-radius:6px;justify-content:space-between;align-items:center;padding:6px 12px;font-size:9px;display:flex}.home-stage-info-grid{color:#aaa;font-size:9px}.home-stage-diff{color:#fff;letter-spacing:1px;border-radius:3px;padding:2px 6px;font-size:7px}.home-best-score{color:gold;background:#ffd7001a;border:1px solid #ffd70066;border-radius:8px;align-items:center;gap:8px;margin-bottom:20px;padding:8px 20px;display:flex}.home-best-score-icon{font-size:16px}.home-best-score-label{letter-spacing:2px;font-size:8px}.home-best-score-value{font-size:18px;font-weight:700}.home-start-btn{cursor:pointer;background:linear-gradient(#e53935 0%,#b71c1c 100%);border:3px solid gold;border-radius:8px;flex-direction:column;align-items:center;gap:4px;margin-bottom:16px;padding:16px 48px;transition:transform .15s;display:flex;box-shadow:0 4px 20px #e5393580,0 0 0 1px #800}.home-start-btn:hover{transform:scale(1.05)}.home-start-btn:active{transform:scale(.97)}.home-start-btn-text{color:gold;text-shadow:2px 2px #800;font-family:"Press Start 2P",monospace;font-size:16px}.home-start-btn-sub{color:#ffd700b3;letter-spacing:3px;font-family:"Press Start 2P",monospace;font-size:7px}.home-footer{color:#ffffff40;letter-spacing:3px;margin-top:4px;font-size:7px}.home-version{color:#fff3;pointer-events:none;font-family:"Press Start 2P",monospace;font-size:7px;position:fixed;bottom:8px;right:12px}.result-screen{background:linear-gradient(160deg,#1a0000 0%,#0d0d1a 100%);justify-content:center;align-items:center;min-height:100dvh;display:flex}.gi-bar{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:100;box-sizing:border-box;background:#000000d9;border-bottom:2px solid #ffd7004d;align-items:center;gap:8px;width:100%;padding:8px 12px;display:flex;position:sticky;top:0}.gi-home-btn{color:gold;cursor:pointer;background:#e53935cc;border:1px solid #c00;border-radius:6px;flex-shrink:0;padding:4px 8px;font-size:18px;line-height:1;transition:transform .15s}.gi-home-btn-icon{display:block}.gi-stage-block{flex-direction:column;gap:1px;min-width:56px;display:flex}.gi-stage-name{font-family:"Press Start 2P",monospace;font-size:8px;font-weight:700}.gi-stage-ball{color:#ffffff80;font-family:"Press Start 2P",monospace;font-size:6px}.gi-center-block{flex:1;justify-content:center;align-items:center;gap:8px;display:flex}.gi-stat-item{flex-direction:column;align-items:center;gap:1px;display:flex}.gi-stat-label{color:#ffffff73;letter-spacing:.5px;font-family:"Press Start 2P",monospace;font-size:6px}.gi-stat-value{color:gold;font-family:"Press Start 2P",monospace;font-size:13px;font-weight:700}.gi-stat-value--danger{color:#ff5252;animation:.8s infinite pulse}.gi-stat-value--score{color:#4caf50}.gi-divider{background:#ffffff26;width:1px;height:28px}.gi-hint-btn{color:gold;cursor:pointer;background:#ffffff14;border:1px solid #fff3;border-radius:6px;flex-direction:column;flex-shrink:0;align-items:center;gap:1px;min-width:40px;padding:4px 8px;transition:all .2s;display:flex}.gi-hint-btn--active{background:#ffd70040;border-color:gold}.gi-hint-btn--empty{opacity:.35}.gi-hint-btn--shaking{animation:.4s shake}.gi-hint-icon{font-size:16px}.gi-hint-count{color:gold;font-family:"Press Start 2P",monospace;font-size:7px}.gi-skip-btn{color:#4caf50;cursor:pointer;background:#4caf5033;border:1px solid #4caf5099;border-radius:6px;flex-direction:column;flex-shrink:0;align-items:center;gap:1px;min-width:40px;padding:4px 8px;transition:all .15s;display:flex}.gi-skip-icon{font-size:14px}.gi-skip-label{color:#4caf50;letter-spacing:.5px;font-family:"Press Start 2P",monospace;font-size:6px}.card-scene{cursor:default}.card-scene.active{cursor:pointer}.card-back-content{justify-content:center;align-items:center;width:72%;height:72%;display:flex}.card-matched-overlay{pointer-events:none;background:#ffd70021;border-radius:8px;position:absolute;inset:0}.card-pokemon-img{object-fit:contain;image-rendering:pixelated;filter:drop-shadow(1px 2px 4px #00000040)}.card-matched-badge{color:gold;text-shadow:0 1px 3px #00000080;font-size:24px;font-weight:700;position:absolute;top:4px;right:6px}.board-wrapper{background:linear-gradient(160deg,#0d0d1a 0%,#1a0d00 100%);flex-direction:column;min-height:100dvh;display:flex}.board-area{box-sizing:border-box;flex:1;justify-content:center;align-items:center;padding:12px;display:flex}.board-grid{gap:8px;width:100%;max-width:480px;max-height:calc(100dvh - 130px);display:grid}.board-progress-wrap{flex-direction:column;gap:4px;padding:6px 16px 12px;display:flex}.board-progress-label{justify-content:space-between;align-items:center;display:flex}.board-progress-label-text{color:#fff6;font-family:"Press Start 2P",monospace;font-size:7px}.board-progress-label-count{color:gold;font-family:"Press Start 2P",monospace;font-size:7px}.board-progress-bar{background:#ffffff1a;border-radius:3px;width:100%;height:6px;overflow:hidden}.board-progress-fill{background:linear-gradient(90deg,#e53935,gold);border-radius:3px;height:100%;transition:width .4s}.fro-backdrop{z-index:999;opacity:0;background:#000000eb;justify-content:center;align-items:center;padding:16px;transition:opacity .4s;display:flex;position:fixed;inset:0}.fro-backdrop.fro-show{opacity:1}.fro-panel{z-index:1;background:linear-gradient(160deg,#1a0000 0%,#2d0000 100%);border:2px solid #ffd70080;border-radius:16px;flex-direction:column;align-items:center;gap:10px;width:100%;max-width:360px;padding:28px 24px;transition:transform .4s cubic-bezier(.34,1.56,.64,1);display:flex;position:relative;transform:scale(.8)translateY(30px);box-shadow:0 0 40px #ffd70033}.fro-panel.fro-show{transform:scale(1)translateY(0)}.fro-new-best-badge{color:#1a0000;background:linear-gradient(90deg,gold,#ffa000);border-radius:20px;padding:4px 12px;font-family:"Press Start 2P",monospace;font-size:9px;font-weight:700}.fro-clear-badge{color:gold;text-shadow:2px 2px #c00,0 0 20px #ffd70099;font-family:"Press Start 2P",monospace;font-size:20px}.fro-final-score{color:gold;text-shadow:3px 3px #c00,0 0 30px #ffd70080;font-family:"Press Start 2P",monospace;font-size:40px}.fro-final-score-label{color:#fff6;letter-spacing:3px;font-family:"Press Start 2P",monospace;font-size:7px}.fro-stage-breakdown{background:#ffffff0a;border-radius:8px;flex-direction:column;gap:6px;width:100%;padding:8px 12px;display:flex}.fro-breakdown-row{justify-content:space-between;align-items:center;display:flex}.fro-breakdown-row-left{align-items:center;gap:6px;display:flex}.fro-stage-label{font-family:"Press Start 2P",monospace;font-size:8px}.fro-breakdown-score{color:#4caf50;font-family:"Press Start 2P",monospace;font-size:10px}.fro-btn-row{flex-wrap:wrap;justify-content:center;gap:10px;width:100%;display:flex}.fro-next-btn{cursor:pointer;background:linear-gradient(#e53935 0%,#b71c1c 100%);border:2px solid gold;border-radius:8px;flex-direction:column;flex:1;align-items:center;gap:3px;padding:10px 20px;transition:transform .15s;display:flex}.fro-next-btn:hover{transform:scale(1.05)}.fro-next-btn-text{color:gold;font-family:"Press Start 2P",monospace;font-size:10px}.fro-home-btn{cursor:pointer;color:#ccc;background:#ffffff14;border:1px solid #ffffff40;border-radius:8px;padding:10px 16px;font-family:"Press Start 2P",monospace;font-size:9px;transition:transform .15s}.fro-home-btn:hover{transform:scale(1.05)}.snackbar-root{opacity:0;z-index:500;pointer-events:none;transition:transform .32s cubic-bezier(.34,1.56,.64,1),opacity .25s;position:fixed;bottom:64px;left:50%;transform:translate(-50%,16px)scale(.92)}.snackbar-root--visible{opacity:1;transform:translate(-50%)scale(1)}.snackbar-card{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:linear-gradient(135deg,#1a0000f5 0%,#2d0000f5 100%);border:2px solid gold;border-radius:30px;align-items:center;gap:10px;padding:8px 18px 8px 8px;display:flex;box-shadow:0 6px 24px #ffd7004d,0 0 0 1px #ffd70026}.snackbar-avatar{background:linear-gradient(135deg,#fff8f0,#fff3e0);border:2px solid gold;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex;overflow:hidden}.snackbar-avatar img{object-fit:contain;width:90%;height:90%;image-rendering:pixelated}.snackbar-text{flex-direction:column;gap:2px;display:flex}.snackbar-label{color:gold;letter-spacing:2px;font-family:"Press Start 2P",monospace;font-size:7px}.snackbar-name{color:#fff;text-shadow:1px 1px #c00;font-family:"Press Start 2P",monospace;font-size:11px}.snackbar-sparkle{margin-left:4px;font-size:16px;animation:.8s ease-in-out infinite sparkle}.loading-screen{background:linear-gradient(160deg,#0d0d1a 0%,#1a0d00 100%);flex-direction:column;justify-content:center;align-items:center;gap:24px;min-height:100dvh;display:flex}.loading-gif{object-fit:contain;width:120px;height:120px}.loading-text{color:gold;font-family:"Press Start 2P",monospace;font-size:24px;animation:1s step-start infinite blink}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}
