@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;600;700;800&family=Nunito:wght@600;700;800&display=swap";:root{--bg: #fafbfc;--surface: #ffffff;--ink: #111827;--ink-soft: #5b6478;--muted: #6b7280;--border: #e3e8f2;--brand: #4f46e5;--brand-hover: #4338ca;--shadow-soft: 0 16px 36px rgba(15, 23, 42, .09);--shadow-card: 0 10px 24px rgba(15, 23, 42, .08);--font-ui: "Inter", "Nunito", "Noto Sans JP", "Hiragino Sans", "Yu Gothic", system-ui, sans-serif;--radius: 16px;--radius-sm: 10px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-family:var(--font-ui);color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{min-height:100dvh}:root{--correct: #22c55e;--wrong: #ef4444}#root{min-height:100vh}body{background:var(--bg);color:var(--ink);font-family:var(--font-ui);font-size:clamp(17px,1.8vw,20px);line-height:1.7}.app-guide{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;margin-bottom:.75rem;background:#4f46e50d;border:1px solid rgba(79,70,229,.1);border-radius:var(--radius-sm);animation:guide-fade-in .3s ease}.app-guide-icon{flex-shrink:0;font-size:.95rem;line-height:1}.app-guide-text{flex:1;font-size:.8rem;line-height:1.45;color:var(--ink-soft);margin:0}.app-guide-close{flex-shrink:0;background:none;border:none;padding:.2rem;cursor:pointer;color:var(--muted);font-size:.75rem;line-height:1;opacity:.6;transition:opacity .15s}.app-guide-close:hover{opacity:1}.app-guide-reopen{position:fixed;bottom:5rem;right:.75rem;width:2rem;height:2rem;border-radius:50%;background:var(--surface);border:1px solid var(--border);box-shadow:0 2px 8px #00000014;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:.8rem;font-weight:700;color:var(--brand);z-index:10;transition:transform .15s,box-shadow .15s}.app-guide-reopen:hover{transform:scale(1.1);box-shadow:0 4px 12px #0000001f}@keyframes guide-fade-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.page{width:min(1120px,calc(100% - 2rem));margin:0 auto;padding:1.2rem 0 3rem;display:grid;gap:1.2rem}.card{border:1px solid var(--border);border-radius:1.1rem;background:var(--surface);box-shadow:var(--shadow-card);padding:1.1rem}.app-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;border-bottom:1px solid var(--border);padding:.75rem 0 .95rem}.brand-mark{margin:0;display:inline-flex;align-items:center;gap:.45rem;font-size:1.03rem;font-weight:800;text-decoration:none;color:#0f172a;white-space:nowrap}.brand-logo{width:1.6em;height:1.6em}.locale-select-wrap{position:relative;display:inline-flex;align-items:center;gap:.5rem}.locale-select-label{font-size:.86rem;color:#1f2937;font-weight:700}.locale-select{min-height:36px;border-radius:.7rem;border:1px solid #ced6e8;background:#fff;color:#111827;font-size:.92rem;font-weight:600;padding:.32rem 2rem .32rem .75rem;font-family:var(--font-ui);-moz-appearance:none;appearance:none;-webkit-appearance:none;cursor:pointer}.locale-select-wrap:after{content:"";position:absolute;right:.85rem;top:50%;width:.38rem;height:.38rem;border-right:2px solid var(--brand);border-bottom:2px solid var(--brand);transform:translateY(-58%) rotate(45deg);pointer-events:none}.mini-page{width:min(1120px,calc(100% - 2rem));margin:0 auto;padding:1.2rem 0 3rem;display:grid;gap:1rem}.mini-layout{display:grid;gap:1rem}.mini-session-card,.mini-interaction-card{display:grid;gap:.75rem}.mini-app-title{margin:0;font-size:1.08rem;font-weight:800;color:#1f2937}.mini-app-prompt{margin:0;color:var(--ink-soft);font-size:.95rem}.mini-phase,.mini-hint,.mini-status-message,.mini-complete-title,.mini-session-result{margin:0}.mini-phase{font-weight:700}.mini-complete-title{font-weight:800;color:#16a34a}.mini-timer-shell{display:grid;gap:.35rem}.mini-timer-copy{font-size:.9rem;color:var(--muted);font-weight:700}.mini-timer-track{width:100%;height:11px;border-radius:999px;overflow:hidden;background:#e8efff;border:1px solid #c7d5ee}.mini-timer-fill{display:block;height:100%;background:linear-gradient(90deg,#38bdf8,#4f46e5);border-radius:inherit;transition:width .08s linear}.mini-timer-fill--warning{background:linear-gradient(90deg,#f97316,#ef4444)}.mini-timer-track--warning{animation:timer-pulse 1s ease-in-out infinite}@keyframes timer-pulse{0%,to{opacity:1}50%{opacity:.7}}.mini-score-area{display:grid;gap:.7rem;align-items:end}.score-board{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.6rem}.score-item{margin:0;background:#f8fbff;border:1px solid #dce5f8;border-radius:.75rem;padding:.45rem .55rem;display:grid;gap:.2rem;color:#334155}.score-item strong{color:#0f172a;font-size:1rem}.btn{border:0;border-radius:.8rem;font-family:var(--font-ui);font-weight:800;cursor:pointer}.btn-primary{min-height:3.5rem;background:var(--brand);color:#fff;box-shadow:var(--shadow-soft)}.btn-primary:hover{background:var(--brand-hover)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.mini-replay-btn{min-height:3.5rem}.mini-collection-link{display:inline-block;min-height:2.75rem;padding:8px 20px;font-size:.9rem;color:var(--brand);border:1px solid var(--border);border-radius:var(--radius-sm);text-decoration:none;text-align:center;font-family:var(--font-ui);transition:background .15s,border-color .15s}.mini-collection-link:hover{background:var(--surface);border-color:var(--brand)}.mini-signup-prompt{margin-top:.75rem;padding:1rem 1.25rem;background:linear-gradient(135deg,#f0f0ff,#e8f4fd);border:1px solid var(--brand);border-radius:var(--radius-sm);text-align:center;animation:signup-fade-in .4s ease-out}@keyframes signup-fade-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.mini-signup-heading{font-size:.95rem;font-weight:700;color:var(--ink);margin:0 0 .5rem;font-family:var(--font-ui)}.mini-signup-benefits{list-style:none;padding:0;margin:0 0 .75rem;display:flex;flex-direction:column;gap:.25rem}.mini-signup-benefits li{font-size:.85rem;color:var(--ink-soft);font-family:var(--font-ui)}.mini-signup-benefits li:before{content:"✓ ";color:var(--brand);font-weight:700}.mini-signup-cta{min-height:2.75rem;font-size:.9rem;width:100%}.feedback-overlay{position:relative;border-radius:.7rem;padding:.6rem .75rem;margin-top:.25rem;animation:feedback-pop .2s ease-out}@keyframes feedback-pop{0%{transform:scale(.92);opacity:0}to{transform:scale(1);opacity:1}}.feedback-overlay--correct{background:#ecfdf5;border:1px solid #86efac;color:#166534}.feedback-overlay--wrong{background:#fff7ed;border:1px solid #fdba74;color:#9a3412}.feedback-content{display:flex;align-items:center;justify-content:center;gap:.45rem;font-weight:700}.tap-grid{width:100%;display:grid;gap:.7rem;margin-top:.35rem;grid-template-columns:repeat(3,minmax(0,1fr))}.tap-grid-button{min-height:80px;border:1px solid #dbe3f4;border-radius:1rem;background:#f8faff;color:#0f172a;display:grid;place-items:center;font-size:2rem;font-weight:800;cursor:pointer;transition:transform .12s ease,border-color .12s ease,box-shadow .12s ease}.tap-grid-button:hover{border-color:#94a3b8;box-shadow:0 10px 24px #4f46e52e;transform:translateY(-1px)}.tap-grid-button:disabled{opacity:.55;cursor:not-allowed;transform:none}.tap-number{font-size:2rem;line-height:1}.choice-buttons{display:grid;gap:.7rem;grid-template-columns:repeat(2,minmax(0,1fr))}.choice-button{min-height:3.5rem;border:1px solid #dbe3f4;border-radius:1rem;background:#f8faff;color:#0f172a;display:grid;place-items:center;font-size:1.2rem;font-weight:700;cursor:pointer;font-family:var(--font-ui);transition:transform .12s ease,border-color .12s ease,box-shadow .12s ease}.choice-button:hover{border-color:#94a3b8;box-shadow:0 10px 24px #4f46e52e;transform:translateY(-1px)}.choice-button:disabled{opacity:.55;cursor:not-allowed;transform:none}.btn,.locale-select,.tap-grid-button{outline-offset:2px}.locale-select:focus-visible,.tap-grid-button:focus-visible{outline:3px solid rgba(79,70,229,.35)}.site-footer{border-top:1px solid var(--border);padding-top:1.2rem;display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}.site-footer-brand{display:grid;gap:.35rem}.site-footer-copy{margin:0;font-size:.82rem;color:var(--muted)}.site-footer-links{display:inline-flex;gap:.8rem;align-items:center;flex-wrap:wrap}.site-footer-link,.site-footer-button{border:0;background:none;padding:.35rem .25rem;margin:0;min-height:2.75rem;display:inline-flex;align-items:center;color:#1f2937;text-decoration:none;font-weight:600;cursor:pointer;font-size:.9rem;transition:color .2s ease}.site-footer-button{font-family:var(--font-ui)}.site-footer-link:hover,.site-footer-button:hover{color:var(--brand)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:100;padding:16px}.app-modal{width:100%;max-width:480px;max-height:80vh;overflow-y:auto;padding:24px;animation:pop-in .2s ease}@keyframes pop-in{0%{transform:scale(.92);opacity:0}to{transform:scale(1);opacity:1}}.app-modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.app-modal-header h2{font-size:1.2rem;font-weight:700}.app-modal-close{font-family:var(--font-ui);font-size:.85rem;padding:6px 14px;border:1.5px solid var(--border);border-radius:8px;background:var(--surface);color:var(--muted);cursor:pointer}.app-modal-body{font-size:.95rem;line-height:1.7;color:var(--ink-soft)}.app-modal-body p{margin-bottom:12px}.auth-inline{display:flex;align-items:center;gap:.5rem}.auth-email{font-size:.82rem;color:var(--muted);max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.auth-btn{border:1px solid var(--border);border-radius:.6rem;background:var(--surface);color:var(--ink);font-family:var(--font-ui);font-weight:600;cursor:pointer;transition:border-color .15s ease}.auth-btn:hover{border-color:var(--brand);color:var(--brand)}.auth-btn--small{padding:.35rem .75rem;font-size:.85rem;min-height:36px}.auth-modal{max-width:380px;width:calc(100% - 2rem)}.auth-form{display:grid;gap:.75rem;padding:.5rem 0}.auth-field{display:grid;gap:.25rem}.auth-label{font-size:.85rem;font-weight:600;color:var(--ink-soft)}.auth-input{min-height:2.75rem;border:1px solid var(--border);border-radius:var(--radius-sm);padding:.5rem .75rem;font-family:var(--font-ui);font-size:.95rem;color:var(--ink);background:var(--surface)}.auth-input:focus{outline:2px solid var(--brand);outline-offset:1px;border-color:var(--brand)}.auth-error{margin:0;font-size:.85rem;color:var(--wrong);font-weight:600}.auth-consent{display:flex;align-items:flex-start;gap:8px;padding:10px 12px;background:#f8fafc;border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;line-height:1.4}.auth-consent-checkbox{flex-shrink:0;width:18px;height:18px;margin-top:2px;accent-color:var(--brand)}.auth-consent-text{font-size:.8rem;color:var(--ink-soft)}.auth-submit{margin-top:.25rem}.auth-switch{border:0;background:none;color:var(--brand);font-family:var(--font-ui);font-size:.85rem;font-weight:600;cursor:pointer;padding:.35rem;text-align:center}.auth-switch:hover{text-decoration:underline}.level-badge{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.5rem}.level-badge-stars{display:flex;gap:.15rem;flex-wrap:wrap;justify-content:center}.level-star{color:#facc15;font-size:1.2rem;line-height:1}.level-badge-label{font-size:.85rem;font-weight:700;color:var(--ink-soft)}.level-badge-ranking{margin:0;font-size:.82rem;color:var(--muted);text-align:center}.gamification-overlay{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;z-index:1000;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:overlay-fade-in .3s ease}@keyframes overlay-fade-in{0%{opacity:0}to{opacity:1}}.level-up-content{display:flex;flex-direction:column;align-items:center;gap:.5rem;background:var(--surface);border-radius:var(--radius);padding:2rem 2.5rem;box-shadow:var(--shadow-soft);animation:level-up-pop .4s cubic-bezier(.34,1.56,.64,1)}@keyframes level-up-pop{0%{transform:scale(.5);opacity:0}to{transform:scale(1);opacity:1}}.level-up-stars{display:flex;gap:.2rem}.level-star-animate{font-size:1.6rem;animation:star-bounce .5s ease both}@keyframes star-bounce{0%{transform:scale(0) rotate(-180deg);opacity:0}60%{transform:scale(1.3) rotate(10deg)}to{transform:scale(1) rotate(0);opacity:1}}.level-up-message{margin:0;font-size:1.3rem;font-weight:800;color:var(--brand)}.level-up-numbers{margin:0;font-size:1.8rem;font-weight:800}.level-up-old{color:var(--muted)}.level-up-arrow{color:var(--ink-soft)}.level-up-new{color:var(--brand)}.item-reveal-card{display:flex;flex-direction:column;align-items:center;gap:.5rem;background:var(--surface);border-radius:var(--radius);padding:2rem 2.5rem;box-shadow:var(--shadow-soft);min-width:200px}.item-reveal-flip{animation:card-flip .6s ease}@keyframes card-flip{0%{transform:rotateY(180deg) scale(.8);opacity:0}50%{transform:rotateY(90deg) scale(.9)}to{transform:rotateY(0) scale(1);opacity:1}}.item-reveal-show{animation:item-settle .3s ease}@keyframes item-settle{0%{transform:scale(1.05)}to{transform:scale(1)}}.item-reveal-emoji{font-size:4rem;line-height:1}.item-reveal-name{margin:0;font-size:1.1rem;font-weight:700;color:var(--ink)}.item-reveal-message{margin:0;font-size:.9rem;color:var(--muted)}.item-special .item-reveal-card{border:2px solid #facc15;background:linear-gradient(135deg,#fffbeb 0%,var(--surface) 100%)}.item-special-sparkle{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:radial-gradient(circle at 30% 30%,rgba(250,204,21,.3) 0%,transparent 50%),radial-gradient(circle at 70% 60%,rgba(250,204,21,.2) 0%,transparent 40%);animation:sparkle-pulse 1.5s ease-in-out infinite}@keyframes sparkle-pulse{0%,to{opacity:.6}50%{opacity:1}}.paywall-backdrop{display:flex;align-items:center;justify-content:center;min-height:60vh;padding:1rem;animation:paywall-fade-in .35s ease}@keyframes paywall-fade-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.paywall-card{display:flex;flex-direction:column;align-items:center;gap:.75rem;max-width:480px;width:100%;padding:2rem 1.5rem;text-align:center}.paywall-icon{margin-bottom:.25rem}.paywall-title{margin:0;font-size:1.3rem;font-weight:800;color:var(--ink)}.paywall-description{margin:0;font-size:.95rem;color:var(--ink-soft);line-height:1.6}.paywall-features{list-style:none;margin:.5rem 0 .25rem;padding:0;display:grid;gap:.5rem;width:100%;text-align:left}.paywall-feature-item{display:flex;align-items:center;gap:.6rem;font-size:.93rem;font-weight:600;color:var(--ink);padding:.45rem .75rem;background:#f8faff;border:1px solid var(--border);border-radius:var(--radius-sm)}.paywall-check{flex-shrink:0}.paywall-subscribe-btn{width:100%;margin-top:.5rem;font-size:1.05rem}.paywall-login-prompt{margin:.5rem 0 0;font-size:.9rem;font-weight:600;color:var(--muted)}.paywall-free-link{display:inline-block;min-height:2.75rem;padding:8px 20px;font-size:.9rem;color:var(--brand);text-decoration:none;font-family:var(--font-ui);font-weight:600;transition:color .15s}.paywall-free-link:hover{text-decoration:underline}@media (min-width: 960px){.mini-layout{grid-template-columns:minmax(0,.72fr) minmax(0,1fr)}.tap-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (max-width: 959px){.mini-page{width:min(100%,calc(100% - 1rem))}.score-board{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 700px){.app-header{flex-wrap:wrap}.site-footer{flex-direction:column;align-items:flex-start}}.number-pair{display:flex;gap:1rem;justify-content:center;align-items:stretch;width:100%;max-width:480px;margin:0 auto}.number-card{flex:1;display:flex;align-items:center;justify-content:center;min-height:120px;font-size:3rem;font-weight:800;font-family:var(--font-ui);color:var(--ink);background:var(--surface);border:3px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-card);cursor:pointer;transition:transform .12s ease,box-shadow .12s ease,border-color .12s ease;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.number-card:active:not(:disabled){transform:scale(.96);box-shadow:var(--shadow-soft);border-color:var(--brand)}.number-card:disabled{opacity:.6;cursor:default}@media (min-width: 600px){.number-card{font-size:4rem;min-height:160px}}
