:root{--bg:#e9f0fa;--surface:#fff;--text:#1c2130;--text-sub:#667085;--border:#e3e6ef;--accent:#3aa6d9;--accent-hover:#2b90c2;--accent-strong:#1f7fae;--matched:#15803d;--matched-bg:#dcfce7;--error:#e5484d;--shadow:0 2px 8px #2d376414;--rounded:"Zen Kaku Gothic New", "Hiragino Sans", system-ui, sans-serif;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;font-family:system-ui,-apple-system,Segoe UI,Hiragino Sans,Noto Sans JP,Yu Gothic UI,sans-serif;line-height:1.6}*{box-sizing:border-box}body{background:var(--bg);color:var(--text);margin:0}html:before,body:before,body:after{content:"";z-index:-1;pointer-events:none;border-radius:50%;position:fixed}body:before{background:radial-gradient(circle,#60aaf04d,#0000 65%);width:60vmax;height:60vmax;animation:37s ease-in-out infinite drift-a;top:-20vmax;left:-15vmax}body:after{background:radial-gradient(circle,#69c8e942,#0000 65%);width:55vmax;height:55vmax;animation:47s ease-in-out infinite drift-b;bottom:-22vmax;right:-18vmax}html:before{background:radial-gradient(circle,#6ed7cd29,#0000 65%);width:45vmax;height:45vmax;animation:53s ease-in-out infinite drift-c;bottom:-25vmax;left:30vmax}@keyframes drift-a{0%,to{transform:translate(0)scale(1)}23%{transform:translate(4vmax,2vmax)scale(1.08)}47%{transform:translate(1vmax,6vmax)scale(.95)}71%{transform:translate(6vmax,3vmax)scale(1.12)}}@keyframes drift-b{0%,to{transform:translate(0)scale(1.08)}29%{transform:translate(-5vmax,-2vmax)scale(.94)}55%{transform:translate(-2vmax,-7vmax)scale(1.1)}78%{transform:translate(-6vmax,-4vmax)scale(1)}}@keyframes drift-c{0%,to{transform:translate(0)scale(1)}31%{transform:translate(5vmax,-3vmax)scale(1.1)}63%{transform:translate(-4vmax,-1vmax)scale(.92)}}@media (prefers-reduced-motion:reduce){html:before,body:before,body:after{animation:none}}.app{flex-direction:column;justify-content:center;gap:24px;max-width:640px;min-height:100dvh;margin:0 auto;padding:48px 20px;display:flex}h1{font-family:var(--rounded);text-align:center;margin:0;font-size:1.7rem;font-weight:700}.hero{flex-direction:column;align-items:center;gap:12px;display:flex;position:relative}.watermarks{z-index:-1;pointer-events:none;position:fixed;inset:0;overflow:hidden}.watermarks img{transform:rotate(var(--rot));animation:16s ease-in-out infinite alternate float-mark;position:absolute}@keyframes float-mark{0%{transform:translateY(8px) rotate(var(--rot))}to{transform:translateY(-22px) rotate(calc(var(--rot) + 9deg))}}@media (prefers-reduced-motion:reduce){.watermarks img{animation:none}}.logo{font-size:2.1rem}.tagline{font-family:var(--rounded);color:var(--accent-strong);text-align:center;margin:0;font-size:1rem;font-weight:500}.fist{margin-left:.15em;font-size:.85em}.site-header{background:var(--surface);box-shadow:0 1px 2px #2d37640f}.site-header nav{flex-wrap:wrap;align-items:center;gap:20px;max-width:640px;margin:0 auto;padding:12px 20px;display:flex}.site-header .brand{font-family:var(--rounded);color:var(--text);align-items:center;gap:8px;margin-right:auto;font-size:1.05rem;font-weight:700;text-decoration:none;display:inline-flex}.typo .t{color:var(--accent)}.site-header .brand .typo{text-underline-offset:6px}.site-header a{color:var(--text-sub);font-size:.9rem;text-decoration:none}.site-header a:hover{color:var(--accent-strong)}.page{flex-direction:column;min-height:100dvh;display:flex}.app--with-header{flex:1;justify-content:center;width:100%;min-height:0;padding-top:24px;padding-bottom:72px}.typo{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 40 6' preserveAspectRatio='none'%3E%3Cpath d='M0 3 Q2 0.8 4 3 T8 3 T12 3 T16 3 T20 3 T24 3 T28 3 T32 3 T36 3 T40 3' fill='none' stroke='%23e5484d' stroke-width='1.2'/%3E%3C/svg%3E");background-position:0 100%;background-repeat:no-repeat;background-size:100% .375em;padding-bottom:.12em}.lead{color:var(--text-sub);text-align:center;margin:0}.primary{font-family:var(--rounded);background:var(--accent);color:#fff;cursor:pointer;box-shadow:var(--shadow);border:none;border-radius:9999px;align-self:center;padding:13px 44px;font-size:1.05rem;font-weight:700;transition:background .15s}.primary:hover{background:var(--accent-hover)}.actions{flex-wrap:wrap;justify-content:center;gap:16px;display:flex}.secondary{font-family:var(--rounded);background:var(--surface);color:var(--accent-strong);cursor:pointer;box-shadow:var(--shadow);border:none;border-radius:9999px;padding:13px 44px;font-size:1.05rem;font-weight:700;transition:background .15s}.secondary:hover{background:#f3f7fc}.hud{color:var(--text-sub);font-variant-numeric:tabular-nums;justify-content:space-between;display:flex}.prompt{background:var(--surface);box-shadow:var(--shadow);word-break:break-all;border-radius:16px;margin:0;padding:28px;font-size:1.4rem;line-height:1.8}.matched{color:var(--matched);background:var(--matched-bg);border-radius:3px}.typing{background:var(--surface);width:100%;color:var(--text);box-shadow:var(--shadow);border:2px solid #0000;border-radius:12px;padding:14px 18px;font-size:1.2rem}.typing:focus{border-color:var(--accent);outline:none}.typing.error{border-color:var(--error)}.hint{min-height:1.6em;color:var(--text-sub);text-align:center;margin:0;font-size:.9rem}.quit{color:var(--text-sub);cursor:pointer;background:0 0;border:none;align-self:center;padding:4px 8px;font-size:.85rem;text-decoration:underline}.quit:hover{color:var(--error)}.stats{justify-content:center;gap:16px;margin:0;display:flex}.stats div{background:var(--surface);box-shadow:var(--shadow);text-align:center;border-radius:16px;min-width:120px;padding:18px 26px}.stats dt{color:var(--text-sub);font-size:.85rem}.stats dd{font-variant-numeric:tabular-nums;margin:4px 0 0;font-size:1.4rem;font-weight:700}.tips{background:var(--surface);box-shadow:var(--shadow);border-radius:16px;padding:20px 24px}.tips-title{font-family:var(--rounded);color:var(--accent-strong);margin:0 0 8px;font-size:.95rem;font-weight:700}.tips-body{margin:0;font-size:.95rem;line-height:1.8}.tips-more{color:var(--text-sub);cursor:pointer;background:0 0;border:none;margin-top:12px;padding:0;font-size:.85rem;text-decoration:underline}.tips-more:hover{color:var(--accent-strong)}@media (width<=480px){.app{padding:24px 16px}.watermarks img{max-width:36vw}.prompt{padding:18px;font-size:1.15rem}.stats{flex-direction:column}}
