:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--social-bg:#f4f3ec80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}@media (prefers-color-scheme:dark){:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#c084fc;--accent-bg:#c084fc26;--accent-border:#c084fc80;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}#social .button-icon{filter:invert()brightness(2)}}#root{text-align:center;box-sizing:border-box;flex-direction:column;width:1126px;max-width:100%;min-height:100svh;margin:0 auto;display:flex}body{margin:0}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}:root{--color-sumi:#1a1a1a;--color-washi:#f7f3e9;--color-vermilion:#bc2406;--color-gold:#d4af37;--color-muted:#e8e2d1;--color-border:#d1cab0;--color-destructive:#9b1c1c;--color-glass:#ffffffb3;--font-heading:"Fredoka", sans-serif;--font-body:"Nunito", sans-serif;--shadow-soft:0 10px 30px #00000014}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-body);background-color:var(--color-washi);color:var(--color-sumi);background-image:radial-gradient(circle at 2px 2px, var(--color-border) 1px, transparent 0);background-size:40px 40px;justify-content:center;align-items:center;width:100vw;height:100vh;padding:1rem;display:flex;overflow:hidden}#root{justify-content:center;align-items:center;width:100%;max-width:1200px;height:100%;display:flex}.app-layout{align-items:flex-start;gap:2rem;width:100%;height:auto;display:flex}.container{background:var(--color-glass);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:var(--shadow-soft);border:1px solid #fffc;border-radius:2.5rem;flex-direction:column;flex:2;gap:1rem;max-height:98vh;padding:1.5rem 2.5rem;transition:transform .3s;display:flex;position:relative}.notepad-section{background:var(--color-glass);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:var(--shadow-soft);border:1px solid #fffc;border-radius:2rem;flex-direction:column;flex:1;align-self:stretch;gap:.8rem;max-height:98vh;padding:1.2rem;display:flex}.notepad-section textarea{width:100%;font-size:1rem;font-family:var(--font-body);border:1px solid var(--color-border);color:var(--color-sumi);resize:none;background:#fff;background-image:linear-gradient(var(--color-border) 1px, transparent 1px);background-position:0 2.5rem;background-size:100% 1.8rem;border-radius:1rem;outline:none;flex-grow:1;padding:.8rem 1rem 1rem;line-height:1.8rem;transition:border-color .3s}.notepad-section textarea:focus{border-color:var(--color-vermilion)}.notepad-section label{color:var(--color-sumi);opacity:.7;text-transform:uppercase;letter-spacing:.1rem;font-size:.8rem}h1{font-family:var(--font-heading);text-align:center;color:var(--color-sumi);text-transform:lowercase;filter:drop-shadow(0 4px 10px #0000000d);font-size:2.5rem;display:inline-block;position:relative}.header-row{justify-content:space-between;align-items:center;margin-bottom:.5rem;display:flex}.header-actions{align-items:center;gap:.5rem;display:flex}.icon-btn{border:1px solid var(--color-border);color:var(--color-sumi);cursor:pointer;background:#fff;border-radius:.8rem;justify-content:center;align-items:center;width:2.5rem;height:2.5rem;transition:all .3s;display:flex;box-shadow:0 2px 5px #0000000d}.icon-btn:hover{border-color:var(--color-vermilion);color:var(--color-vermilion)}.clear-btn{border:1px solid var(--color-border);color:var(--color-sumi);font-family:var(--font-body);cursor:pointer;opacity:.6;background:0 0;border-radius:.8rem;padding:.5rem 1rem;font-size:.9rem;transition:all .3s}.clear-btn:hover{opacity:1;background:var(--color-vermilion);color:#fff;border-color:var(--color-vermilion)}h1:after{content:"言霊";color:#fff;background:var(--color-vermilion);writing-mode:vertical-rl;border-radius:4px;padding:.2rem .3rem;font-size:.7rem;line-height:1;position:absolute;bottom:.8rem;right:-2.4rem}.input-section{flex-direction:column;gap:.3rem;display:flex}label{font-family:var(--font-heading);color:var(--color-vermilion);padding-left:.5rem;font-size:1rem;font-weight:600}input{width:100%;font-size:1.2rem;font-family:var(--font-body);color:var(--color-sumi);background:#fff;border:2px solid #0000;border-radius:1.2rem;outline:none;padding:.8rem 1.2rem;transition:all .4s cubic-bezier(.175,.885,.32,1.275);box-shadow:inset 0 2px 4px #00000008,0 4px 20px #00000005}input:focus{border-color:var(--color-vermilion);transform:translateY(-2px);box-shadow:0 0 0 4px #bc240626,0 10px 30px #0000000d}.letter-pool-wrapper{border-radius:1.8rem;flex-direction:column;flex-grow:1;min-height:0;padding:6px;transition:all .6s;display:flex}.letter-pool-wrapper.complete{background:linear-gradient(135deg, var(--color-gold) 0%, #f59e0b 100%);padding:10px}.letter-pool{border:1px solid var(--color-border);background:#fff9;border-radius:1.5rem;flex-wrap:wrap;justify-content:center;gap:.6rem;max-height:60vh;padding:1rem;display:flex;overflow-y:auto}.letter-pool::-webkit-scrollbar{width:6px}.letter-pool::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:10px}.letter-box{width:3rem;height:3rem;font-family:var(--font-heading);background:#fff;border-radius:.8rem;justify-content:center;align-items:center;font-size:1.5rem;font-weight:700;transition:all .4s cubic-bezier(.175,.885,.32,1.275);display:flex;position:relative}.letter-box.available{color:var(--color-sumi);box-shadow:0 5px 10px #0000000d}.letter-box.unavailable{color:#718096;border:1px dashed var(--color-border);opacity:.6;box-shadow:none;background:#0000000d;transform:scale(.9)}.count-superscript{background:var(--color-vermilion);color:#fff;z-index:10;border-radius:.6rem;justify-content:center;align-items:center;min-width:1.4rem;height:1.4rem;font-size:.8rem;font-weight:700;display:flex;position:absolute;top:-.6rem;right:-.6rem}.error-message{color:var(--color-vermilion);text-align:center;min-height:1.5rem;margin-top:.5rem;font-size:1rem;font-weight:700}.mobile-keyboard-section{flex-direction:column;flex-grow:1;justify-content:center;min-height:200px;display:flex}.virtual-keyboard{background:#fff6;border-radius:1.5rem;flex-direction:column;gap:.5rem;padding:.5rem;display:flex}.keyboard-row{justify-content:center;gap:.4rem;display:flex}.key{min-width:0;height:3.2rem;font-family:var(--font-heading);color:var(--color-sumi);cursor:pointer;transition:all .1s active;touch-action:manipulation;background:#fff;border:none;border-radius:.6rem;flex:1;justify-content:center;align-items:center;font-size:1.2rem;font-weight:700;display:flex;position:relative;box-shadow:0 2px 4px #0000001a}.key.backspace{background:var(--color-muted);flex:1.5}.key.space{background:var(--color-muted);flex:4}.key:active{background:var(--color-muted);transform:translateY(2px);box-shadow:0 1px 2px #0000001a}.key.unavailable{opacity:.3;cursor:not-allowed}.key.not-in-phrase{color:#a0aec0;box-shadow:none;border:1px dashed var(--color-border);background:#00000008}.key-count{background:var(--color-vermilion);color:#fff;border:1px solid #fff;border-radius:50%;justify-content:center;align-items:center;min-width:1.1rem;height:1.1rem;font-size:.65rem;font-weight:800;display:flex;position:absolute;top:-4px;right:-4px}.key-count.zero{background:#718096}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#0006;justify-content:center;align-items:center;padding:1.5rem;display:flex;position:fixed;inset:0}.modal-content{width:100%;max-width:500px;max-height:80vh;animation:.3s cubic-bezier(.175,.885,.32,1.275) modalIn;display:flex}@keyframes modalIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.notepad-section.modal{flex:1;height:60vh;max-height:none}.notepad-header{justify-content:space-between;align-items:center;display:flex}.close-modal{color:var(--color-sumi);opacity:.5;cursor:pointer;background:0 0;border:none;padding:.5rem;font-size:1.2rem}@media (prefers-reduced-motion:reduce){*{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}input:focus,.letter-box.available:hover{transform:none!important}}@media (width<=900px){.app-layout:not(.mobile-view){flex-direction:column;height:auto;padding:1rem;overflow-y:auto}#root{align-items:flex-start}.app-layout:not(.mobile-view) .container,.app-layout:not(.mobile-view) .notepad-section{flex:none;width:100%;max-height:none}.app-layout:not(.mobile-view) .notepad-section{height:300px}}@media (width<=768px){body{padding:0}.app-layout.mobile-view{flex-direction:column;gap:0;height:100dvh;padding:0;overflow-y:auto}.app-layout.mobile-view .container{-webkit-backdrop-filter:none;backdrop-filter:none;box-shadow:none;background:0 0;border:none;border-radius:0;flex-direction:column;gap:.8rem;width:100%;min-height:100%;padding:1rem;display:flex}.app-layout.mobile-view h1{font-size:1.8rem}.app-layout.mobile-view h1:after{display:none}.app-layout.mobile-view input{padding:.8rem 1.2rem;font-size:1.1rem}.app-layout.mobile-view label{font-size:.9rem}}@media (width<=600px){body:not(:has(.mobile-view)){align-items:flex-start;height:auto;overflow-y:auto}.app-layout:not(.mobile-view) .container{padding:1.5rem}}@media (width<=400px){.virtual-keyboard{grid-template-columns:repeat(6,1fr)}.key.space{grid-column:span 2}}
