*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0e2a3a;--bg-surface: #143347;--bg-card: #1c4259;--text: #eef6fb;--text-muted: #7aadcc;--sky: #4ea7c4;--sky-dark: #2e7a96;--amber: #e9c46a;--amber-dark: #c49a12;--sunset: #f4a261;--green: #52b788;--red: #e07a5f;--border: rgba(255, 255, 255, .14);--radius-sm: 8px;--radius-md: 16px;--radius-lg: 24px;--shadow-card: 0 4px 16px rgba(0, 0, 0, .4);--font: system-ui, -apple-system, "Segoe UI", sans-serif;--card-w: 88px;--card-h: 84px;--card-mini-w: 56px;--card-mini-h: 52px;--palette-btn-w: 72px;--palette-btn-h: 64px}html,body{height:100%;font-family:var(--font);background-color:var(--bg);color:var(--text);overflow:hidden;font-size:16px;line-height:1.4}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}*:focus-visible{outline:3px solid var(--sky);outline-offset:2px;border-radius:var(--radius-sm)}#confetti-canvas{position:fixed;inset:0;pointer-events:none;z-index:1000}.app{display:flex;align-items:center;justify-content:center;width:100%;height:100%;overflow:hidden}.scene-root{position:relative;width:100%;height:100%;max-width:640px;margin:0 auto;overflow-y:auto;overflow-x:hidden}@keyframes shake{0%,to{transform:translate(0)}15%{transform:translate(-8px)}30%{transform:translate(8px)}45%{transform:translate(-6px)}60%{transform:translate(6px)}75%{transform:translate(-3px)}90%{transform:translate(3px)}}.shake{animation:shake .6s ease}@media (prefers-reduced-motion: reduce){.shake{animation:none}}.screen{display:flex;flex-direction:column;align-items:center;min-height:100%;padding:1.5rem 1rem;gap:1.25rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;border:none;border-radius:var(--radius-sm);font-family:var(--font);font-size:1rem;font-weight:600;cursor:pointer;min-height:48px;min-width:48px;transition:transform .1s,opacity .1s;text-align:center}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.45;cursor:not-allowed;transform:none}.btn--primary{background:linear-gradient(135deg,var(--sky) 0%,var(--sky-dark) 100%);color:#fff}.btn--ghost{background:transparent;border:2px solid var(--border);color:var(--text)}.btn--ghost:hover{border-color:var(--sky);color:var(--sky)}.btn--icon{padding:.75rem}@media (prefers-reduced-motion: reduce){.btn{transition:none}}.hud{width:100%;display:flex;flex-direction:column;gap:.5rem}.hud__info{display:flex;gap:1rem;font-size:.85rem;color:var(--text-muted);flex-wrap:wrap;align-items:center}.hud__mode{font-weight:700;color:var(--sky)}.hud__phase strong,.hud__score strong{color:var(--text)}.hud__timer-wrap{position:relative;height:10px;background:#ffffff1a;border-radius:99px;overflow:hidden}.hud__timer-bar{height:100%;border-radius:99px;transition:width 1s linear,background-color .3s;width:100%}.hud__timer-text{position:absolute;right:0;top:-18px;font-size:.75rem;color:var(--text-muted)}@media (prefers-reduced-motion: reduce){.hud__timer-bar{transition:width 1s linear}}.screen--menu{justify-content:flex-start;padding-top:2rem}.menu__header{text-align:center;display:flex;flex-direction:column;align-items:center;gap:.3rem}.menu__mascot{font-size:2.5rem;line-height:1}.menu__title{font-size:clamp(1.75rem,6vw,2.5rem);font-weight:800;background:linear-gradient(135deg,var(--sky) 0%,var(--amber) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1.1}.menu__subtitle{color:var(--text-muted);margin-top:.2rem;font-size:1rem;font-weight:600}.menu__tagline{color:var(--text-muted);font-size:.88rem}.menu__start-btn{width:100%;max-width:320px;font-size:1.1rem;padding:1rem 2rem}.menu__scores{width:100%;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:1rem}.menu__scores-title{font-size:1rem;font-weight:700;color:var(--sky);margin-bottom:.5rem}.menu__scores-empty{font-size:.9rem;color:var(--text-muted)}.menu__scores-ol{list-style:none;display:flex;flex-direction:column;gap:.3rem}.menu__score-item{display:grid;grid-template-columns:2rem 1fr auto auto;gap:.5rem;align-items:center;font-size:.85rem}.menu__score-rank{font-weight:700;color:var(--amber);font-size:.8rem}.menu__score-pts{font-weight:700}.menu__score-phase,.menu__score-date{color:var(--text-muted);font-size:.75rem}.menu__actions{display:flex;gap:.75rem;width:100%;justify-content:center;flex-wrap:wrap}.screen--rules{position:fixed;inset:0;background:#000000bf;z-index:200;display:flex;align-items:center;justify-content:center;padding:1rem;overflow-y:auto}.rules__box{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem;max-width:480px;width:100%;display:flex;flex-direction:column;gap:1rem;max-height:85vh;overflow-y:auto}.rules__title{font-size:1.5rem;font-weight:800;color:var(--sky)}.rules__subtitle{font-size:1rem;font-weight:700;color:var(--text)}.rules__list{padding-left:1.25rem;display:flex;flex-direction:column;gap:.4rem;font-size:.9rem;color:var(--text)}.rules__text{font-size:.9rem;color:var(--text-muted);font-family:monospace;background:#0000004d;padding:.5rem;border-radius:var(--radius-sm)}.rules__close{align-self:center;margin-top:.5rem}.screen--phase-intro{justify-content:center;min-height:100%}.phase-intro__badge{display:flex;flex-direction:column;align-items:center;gap:.5rem;opacity:0;transform:scale(.6);transition:opacity .4s ease,transform .4s ease}.phase-intro--visible .phase-intro__badge{opacity:1;transform:scale(1)}.phase-intro--exit .phase-intro__badge{opacity:0;transform:scale(1.2);transition:opacity .3s ease,transform .3s ease}.phase-intro__label{font-size:1rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.12em}.phase-intro__number{font-size:clamp(4rem,20vw,8rem);font-weight:900;background:linear-gradient(135deg,var(--sky) 0%,var(--amber) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1}.phase-intro__mode{font-size:1.1rem;font-weight:700;color:var(--text)}@media (prefers-reduced-motion: reduce){.phase-intro__badge,.phase-intro--exit .phase-intro__badge{transition:none}}.screen--memorize{gap:1rem}.memorize__instruction{font-size:1.1rem;font-weight:600;color:var(--text-muted)}.memorize__cards{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:center;padding:.5rem 0}.memorize__start-btn{width:100%;max-width:320px}@keyframes card-appear{0%{opacity:0;transform:translateY(12px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}.card{width:var(--card-w);height:var(--card-h);background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.3rem;box-shadow:var(--shadow-card);position:relative;perspective:600px;transform-style:preserve-3d;padding:.3rem}.card--appear{animation:card-appear .35s ease both}.card__flag-img{width:56px;height:38px;object-fit:cover;border-radius:3px;border:1px solid rgba(255,255,255,.15);display:block}.card__flag-name{font-size:.7rem;font-weight:600;color:var(--text);text-align:center;line-height:1.1;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.card--face-down{background:linear-gradient(135deg,var(--bg-surface) 0%,var(--bg) 100%);border:2px solid var(--sky)}.card__back{font-size:2rem;color:var(--sky)}.mini-card{width:var(--card-mini-w);height:var(--card-mini-h);background:var(--bg-card);border:1px solid var(--border);border-radius:6px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.2rem;box-shadow:0 2px 8px #0000004d;padding:.2rem}.mini-card--highlight{outline:3px solid var(--red);outline-offset:1px}.mini-card .card__flag-img{width:36px;height:24px}.mini-card .card__flag-name{font-size:.55rem}.screen--input{gap:.75rem;padding-bottom:1.5rem}.input__instruction{font-size:1.1rem;font-weight:600;color:var(--text-muted);margin-top:.25rem}.input__slots{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;padding:.5rem;background:#ffffff0a;border:1px dashed var(--border);border-radius:var(--radius-md);min-height:70px;width:100%;align-items:center}.input__slot{width:var(--card-mini-w);height:var(--card-mini-h);border-radius:6px;border:2px dashed rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:1.2rem}.input__slot--filled{border-color:transparent}.input__controls{display:flex;gap:.75rem;width:100%}.input__undo-btn,.input__confirm-btn{flex:1}.input__progress{font-size:.85rem;color:var(--text-muted)}.palette{width:100%}.palette__flag-grid{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center}.palette__flag-btn{width:var(--palette-btn-w);height:var(--palette-btn-h);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.2rem;background:var(--bg-card);border:2px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:transform .1s,border-color .1s;box-shadow:0 2px 6px #0000004d;min-height:48px;min-width:48px;padding:.3rem}.palette__flag-btn:hover:not(:disabled){transform:translateY(-3px);border-color:var(--sky)}.palette__flag-btn:active:not(:disabled){transform:scale(.93)}.palette__flag-btn--used{opacity:.3}.palette__flag-img{width:40px;height:27px;object-fit:cover;border-radius:2px;border:1px solid rgba(255,255,255,.12);display:block}.palette__flag-name{font-size:.58rem;font-weight:600;color:var(--text);text-align:center;line-height:1.1;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media (prefers-reduced-motion: reduce){.palette__flag-btn{transition:none}}.screen--result{justify-content:center;gap:1.25rem;text-align:center}.result__icon{width:80px;height:80px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:2.5rem;font-weight:900;font-style:normal}.result__icon--correct{background:#52b78826;color:var(--green);border:3px solid var(--green)}.result__icon--wrong{background:#e07a5f26;color:var(--red);border:3px solid var(--red)}.result__msg{font-size:1.1rem;font-weight:600;color:var(--text);max-width:320px}.result__points{font-size:2rem;font-weight:800;color:var(--amber);display:flex;flex-direction:column;align-items:center;gap:.2rem}.result__total{font-size:.9rem;color:var(--text-muted);font-weight:400}.result__comparison{display:flex;flex-direction:column;gap:.75rem;width:100%}.result__seq{display:flex;flex-direction:column;gap:.4rem}.result__seq-label{font-size:.85rem;color:var(--text-muted);font-weight:600}.result__seq-cards{display:flex;flex-wrap:wrap;gap:.4rem;justify-content:center}.result__continue-btn{width:100%;max-width:280px;margin-top:.5rem}.screen--gameover{justify-content:center;gap:1.25rem;text-align:center}.gameover__icon{font-size:4rem}.gameover__title{font-size:2rem;font-weight:800;color:var(--sunset)}.gameover__mode{font-size:1rem;color:var(--text-muted)}.gameover__score{display:flex;flex-direction:column;align-items:center;gap:.25rem;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:1.25rem 2rem}.gameover__score-label{font-size:.85rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em}.gameover__score-value{font-size:3rem;font-weight:900;color:var(--amber);line-height:1}.gameover__score-phase{font-size:.9rem;color:var(--text-muted)}.gameover__record{color:var(--amber);font-weight:700;font-size:1rem}.gameover__actions{display:flex;flex-direction:column;gap:.75rem;width:100%;max-width:280px}@media (max-width: 480px){:root{--card-w: 72px;--card-h: 70px;--card-mini-w: 48px;--card-mini-h: 44px;--palette-btn-w: 62px;--palette-btn-h: 56px}.card__flag-img{width:44px;height:30px}.card__flag-name{font-size:.6rem}.palette__flag-img{width:34px;height:23px}.palette__flag-name{font-size:.52rem}.screen{padding:1rem .75rem}}@media (max-height: 600px){.screen--menu{padding-top:1rem}}
