:root{--primary-100:#5DA399;--primary-200:#40867d;--primary-300:#004840;--accent-100:#FF6B6B;--accent-200:#8f001a;--text-100:#333333;--text-200:#5c5c5c;--bg-100:#c4ced1;--bg-200:#b8c6cb;--bg-300:#aeb5b7;font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:var(--text-100);background-color:var(--bg-100);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}input[type=text],input[type=search],input[type=email],input[type=password]{font-size:16px!important}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}:root{touch-action:manipulation;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}html,body{touch-action:manipulation;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}.menu-container{position:relative}.menu-container>div{position:fixed;top:20px;left:20px;display:flex;align-items:center;gap:10px}.menu-button{z-index:998;background:none;border:none;cursor:pointer;padding:10px;outline:none;color:var(--text-100);line-height:.8}.menu-button span{text-decoration:underline}.menu-button:focus,.menu-button:focus-visible{outline:none}.menu-button:hover{border:none}.menu-list{box-sizing:border-box;position:fixed;left:0;top:0;height:100vh;width:250px;background-color:var(--bg-200);z-index:999;overflow-y:auto}.menu-list::-webkit-scrollbar{width:8px}.menu-list::-webkit-scrollbar-track{background:transparent}.menu-list::-webkit-scrollbar-thumb{background:var(--primary-100);border-radius:4px}.menu-list::-webkit-scrollbar-thumb:hover{background:var(--primary-200)}.menu-list ul{list-style:none;padding:60px 20px 20px;margin:0}.menu-title{text-align:left;text-indent:25px;color:var(--primary-200);font-weight:lighter}.menu-list ul li a:hover{color:var(--accent-100)}.close-button{position:absolute;top:20px;right:20px;background:none;border:none;cursor:pointer;padding:10px;display:none;outline:none}.close-icon{display:block;width:20px;height:20px;position:relative}.close-icon:before,.close-icon:after{content:"";position:absolute;top:50%;left:0;width:100%;height:2px;background-color:var(--text-100)}.close-icon:before{transform:rotate(45deg)}.close-icon:after{transform:rotate(-45deg)}.menu-list ul{list-style:none;padding:0 0 2em;margin:0}.menu-list li{padding:15px 25px;text-align:left;border-bottom:1px solid var(--primary-100)}.menu-list a{color:var(--text-200);text-decoration:none;font-size:1.1rem}.menu-list a:hover{color:var(--accent-100)}.menu-button,.close-button{display:none}.menu-list{transform:translate(0);transition:transform .3s ease-in-out}@media (max-width: 768px){.menu-list{transform:translate(-100%)}.menu-list.open{transform:translate(0)}.menu-button,.close-button{display:block}}.draggable-ball{position:fixed;width:60px;height:60px;background-color:var(--accent-100);border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff;font-size:16px;-webkit-user-select:none;user-select:none;touch-action:none;z-index:1000;box-shadow:0 2px 8px var(--bg-100),0 0 15px var(--accent-100);transition:box-shadow .2s ease;animation:glow 2s ease-in-out infinite}@keyframes glow{0%{box-shadow:0 2px 8px var(--bg-100),0 0 15px var(--accent-100)}50%{box-shadow:0 2px 8px var(--bg-100),0 0 25px var(--accent-100)}to{box-shadow:0 2px 8px var(--bg-100),0 0 15px var(--accent-100)}}.draggable-ball:active{box-shadow:0 4px 12px 0 0 15px var(--accent-100);cursor:grabbing}.countdown{font-size:12px;margin-top:2px}@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.2)}to{transform:scale(1)}}.pulsing{animation:pulse .5s ease-in-out infinite}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1200}.modal-content{background:var(--bg-300);padding:.5rem;border-radius:12px;width:85%;max-width:400px;box-shadow:0 8px 24px #0000000d;color:var(--text-100);position:relative;z-index:1201}.modal-title{margin:0 0 1rem;font-size:1.3rem;text-align:left;color:var(--text-100);font-weight:600}.modal-body{margin-bottom:1.5rem}.modal-body{display:flex;align-items:center;gap:10px;padding:0 1rem;border-bottom:1px solid var(--text-200)}.checkbox-wrapper{display:inline-block;position:relative;cursor:pointer}.checkbox-wrapper input[type=checkbox]{opacity:0;position:absolute;cursor:pointer}.checkbox-wrapper .checkmark{position:relative;display:inline-block;width:20px;height:20px;border:2px solid var(--primary-200);border-radius:4px;transition:all .2s ease}.checkbox-wrapper input[type=checkbox]:checked+.checkmark{background-color:var(--primary-200);border-color:var(--primary-200)}.checkbox-wrapper .checkmark:after{content:"";position:absolute;display:none;left:6px;top:2px;width:5px;height:10px;border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg)}.checkbox-wrapper input[type=checkbox]:checked+.checkmark:after{display:block}.checkbox-label{font-size:1.1rem;line-height:1.6;margin-left:8px;text-align:left}.modal-button{width:100%;padding:.8rem;font-size:1rem;background-color:var(--primary-200);color:var(--text-100);border:none;border-radius:6px;cursor:pointer;transition:all .2s ease;font-weight:500}.search-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;justify-content:center;align-items:flex-start;padding-top:10vh;z-index:1000}.search-modal{background-color:var(--bg-200);padding:20px;border-radius:8px;width:90%;max-width:500px;max-height:80vh;display:flex;flex-direction:column;gap:15px;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background-color:rgba(var(--bg-200-rgb),.9);box-sizing:border-box}.search-input-container{position:relative;width:100%;box-sizing:border-box}.search-input{width:100%;padding:10px;box-sizing:border-box;border:1px solid var(--accent-100);border-radius:4px;background-color:var(--bg-100);color:var(--text-100);font-size:16px}.search-confirm-button{position:absolute;right:5px;top:50%;transform:translateY(-50%);padding:5px 10px;background-color:var(--primary-100);color:var(--text-100);border:none;border-radius:4px;cursor:pointer;font-size:14px}.search-confirm-button:hover{background-color:var(--primary-200)}.search-input:focus{outline:none;border-color:var(--accent-100)}.search-results{overflow-y:auto;max-height:calc(80vh - 100px);background-color:rgba(var(--bg-100),.9)}.search-results::-webkit-scrollbar{width:8px}.search-results::-webkit-scrollbar-track{background:transparent}.search-results::-webkit-scrollbar-thumb{background:var(--primary-100);border-radius:4px}.search-results::-webkit-scrollbar-thumb:hover{background:var(--primary-200)}.search-result-item{padding:10px;cursor:pointer;color:var(--text-100);border-bottom:1px solid var(--bg-300);text-align:left}.search-result-item:hover{background-color:var(--primary-100);color:var(--accent-100)}.meteor-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1300;opacity:0;transition:opacity .5s ease}.meteor-modal-overlay.meteor-modal-enter{opacity:1}.meteor-modal-overlay.meteor-modal-exit{opacity:0}.meteor-modal{position:relative;background-color:transparent;border-radius:8px;overflow:hidden;box-shadow:0 4px 20px #0000004d;transform:translate(100%,100%) scale(.5);opacity:0;transition:transform .5s ease-out,opacity .5s ease}.meteor-modal.meteor-modal-enter{transform:translate(0) scale(1);opacity:1}.meteor-modal.meteor-modal-exit{transform:translate(100%,100%) scale(.5);opacity:0}@media (min-width: 768px){.meteor-modal{width:500px;height:600px}}@media (max-width: 767px){.meteor-modal{width:100%;height:100%;border-radius:0}}.meteor-content{width:100%;height:100%;position:relative;overflow:hidden}.meteor-close-button{position:absolute;top:10px;right:10px;background:#00000080;color:#fff;border:none;border-radius:50%;width:30px;height:30px;display:flex;justify-content:center;align-items:center;cursor:pointer;font-size:16px;z-index:1301;transition:background-color .2s;padding:0}.meteor-close-button:hover{background:#000c}.girl-image-container{position:absolute;top:0;left:0;width:100%;height:70%;display:flex;flex-direction:column;justify-content:center;align-items:center;z-index:1}.girl-image{max-width:80%;max-height:80%;object-fit:contain}.audio-control-button{margin-top:10px;padding:8px 16px;background-color:#ffffff4d;border:1px solid rgba(255,255,255,.5);border-radius:20px;color:#fff;font-size:14px;cursor:pointer;transition:all .3s ease;position:absolute;bottom:0}.audio-control-button:hover{background-color:#ffffff80}.meteor-text{position:absolute;bottom:40px;left:0;width:100%;text-align:center;color:#fff;font-size:16px;line-height:1.5;z-index:2;text-shadow:0 0 5px rgba(0,0,0,.7)}.meteor-text p{margin:5px 0}.music-credit{font-size:12px;color:#ffffffb3;margin-top:15px;font-style:italic}.fade-container{position:relative;width:350px;height:445px}.fade-img{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:contain;opacity:0;transition:opacity 2s ease-in-out}.fade-img.show{opacity:1}.floating{animation:floatUpDown 4s ease-in-out infinite}@keyframes floatUpDown{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.search-button-wrapper{height:40px;display:block;width:98px;margin-left:16px;background-color:#ffffff26;border-radius:.4rem;text-align:right;cursor:pointer}.search-button-wrapper .search-button{display:inline-block}@media screen and (min-width: 768px){.search-button-wrapper{margin-left:113px;width:130px}}.chat-container{position:fixed;bottom:20px;right:20px;z-index:1000}.chat-toggle-button{width:60px;height:60px;border-radius:50%;background-color:var(--text-200);border:none;cursor:pointer;font-size:24px;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 10px #0000001a;transition:transform .2s;padding:0}.chat-toggle-button:hover{transform:scale(1.1)}.chat-room{position:fixed;right:20px;bottom:80px;width:400px;height:800px;background-color:var(--bg-200);border-radius:12px;box-shadow:0 4px 20px #00000026;display:flex;flex-direction:column;overflow:hidden}.chat-header{padding:15px;background-color:var(--text-200);display:flex;justify-content:flex-start}.chat-close-button{background:none;border:none;font-size:20px;cursor:pointer;position:absolute;right:0;z-index:11;padding-top:.3em;color:var(--bg-100);top:-5px}.messages-wrapper{flex:1;overflow:hidden;padding:0;display:flex;flex-direction:column;scroll-behavior:smooth;height:calc(100% - 100px);min-height:300px;position:relative}.loading-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background-color:var(--bg-100);display:flex;justify-content:center;align-items:center;z-index:10}.loading-content{background-color:var(--bg-200);color:var(--text-100);padding:10px 20px;border-radius:8px;font-size:14px;box-shadow:0 2px 8px #0003}.virtual-list{padding:0;height:100%!important;width:100%!important;max-height:100%;overflow-y:auto;position:relative}.messages-container{flex:1;overflow:visible;padding:20px;display:flex;flex-direction:column;height:100%;width:100%;position:relative;box-sizing:border-box}.chat-message-list{padding-right:2px}.chat-message-list::-webkit-scrollbar{width:2px}.chat-message-list::-webkit-scrollbar-track{background:transparent}.chat-message-list::-webkit-scrollbar-thumb{background-color:var(--primary-100);border-radius:4px}.chat-message-list::-webkit-scrollbar-thumb:hover{background-color:var(--bg-300)}[data-testid=virtuoso-item-list]{padding-bottom:0!important;box-sizing:border-box}[data-testid=virtuoso-scroller]{overflow-y:auto!important;height:100%!important;overscroll-behavior:contain;position:relative;-webkit-overflow-scrolling:touch}.no-more-messages{text-align:center;color:var(--text-200);font-size:.4em;width:100%;position:absolute;top:2em}.message{margin:8px 0;display:flex;width:100%}.message-self{justify-content:flex-end}.message-other{justify-content:flex-start}.message-content{max-width:75%;padding:10px 15px;border-radius:12px;background-color:var(--bg-300);color:var(--text-100);text-align:left}.message-self .message-content{background-color:var(--primary-100);color:var(--text-100)}.message p{margin:0;word-wrap:break-word}.media-preview{position:relative;cursor:pointer;max-width:200px;height:150px;border-radius:8px;overflow:hidden;background-color:var(--bg-200)}.media-preview img,.media-preview video{width:100%;height:100%;display:block;object-fit:cover}.play-overlay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:24px;color:#fff;background-color:#00000080;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center}.media-viewer{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000e6;display:flex;align-items:center;justify-content:center;z-index:2000;cursor:pointer}.media-viewer-content{max-width:90%;max-height:90vh}.media-viewer-content img,.media-viewer-content video{max-width:100%;max-height:90vh;object-fit:contain}.message img,.message video{max-width:100%;border-radius:8px}.message audio{width:250px;height:36px;border-radius:18px;background-color:var(--bg-200);margin:5px 0;transition:all .3s ease}.message audio:hover{transform:scale(1.02);box-shadow:0 2px 8px #0000001a}.input-container{padding:10px;background-color:var(--text-200);display:flex;gap:10px;align-items:center}.input-container input[type=text]{flex:1;padding:10px;border:none;border-radius:20px;background-color:var(--bg-200);color:var(--text-100)}.input-container textarea{box-sizing:border-box;resize:none;min-height:1em;overflow-y:auto;flex:1;padding:.5em;border-radius:.3em;border:1px solid rgba(0,0,0,.1);box-shadow:0 2px 4px #0000000d;transition:all .2s ease;background-color:var(--bg-200);color:var(--text-100);line-height:1em;max-height:3em;font-size:1em}.input-container textarea::-webkit-scrollbar{width:2px}.input-container textarea::-webkit-scrollbar-track{background:transparent}.input-container textarea::-webkit-scrollbar-thumb{background-color:var(--primary-100);border-radius:4px}.input-container textarea::-webkit-scrollbar-thumb:hover{background-color:var(--bg-300)}.input-wrapper{padding:0;flex:1}.input-container .send-button,.input-container .upload-button{padding:0;background-color:unset;border:none;cursor:pointer;color:var(--bg-100);box-sizing:border-box}.input-container .send-button svg{width:2em;vertical-align:middle}@media (max-width: 768px){.chat-room{position:fixed;top:0;left:0;right:0;bottom:0;width:100%;height:100%;border-radius:0}.chat-header{padding:0;background-color:transparent}.chat-close-button{color:var(--text-100);top:0}.chat-toggle-button{width:40px;height:40px;font-size:20px}}.welcome-modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#000c;display:flex;justify-content:center;align-items:center;z-index:1000}.welcome-modal-content{display:flex;flex-direction:column;background-color:unset;background-image:url(/assets/welcome-XRoZfVTv.svg);background-position:top;background-repeat:no-repeat;background-size:cover;padding:0;border-radius:12px;text-align:center;box-shadow:0 4px 20px #00000026;width:90%;max-width:600px;min-height:440px;position:relative}.welcome-modal-content button{position:absolute;bottom:-2rem;left:0;right:0;margin:auto;padding:0;border:none;cursor:pointer;font-size:1.2rem;transition:all .3s ease;background-color:#ffe6e3;color:#3f3f3f;border-radius:50%;width:2.5rem;height:2.5rem;animation:pulseScale 1.5s ease-in-out infinite}@keyframes pulseScale{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1)}}.welcome-modal-content button:hover{background-color:var(--primary-200);transform:scale(1.05);color:#fff}@media (max-width: 768px){.welcome-modal-content{min-height:300px;width:85%}.welcome-modal-content button{height:2rem;width:2rem;font-size:1rem}}.flashcard{width:90vw;max-width:300px;height:auto;min-height:400px;perspective:1000px;margin:20px auto}@media screen and (min-width: 768px){.flashcard{max-width:400px}}.card-content{position:relative;background:var(--primary-100);padding:2rem;border-radius:15px;box-shadow:0 4px 8px #0000001a;margin-bottom:1rem;min-height:250px;display:flex;flex-direction:column;justify-content:center;align-items:center}.card-content.full-version{border:1px solid var(--primary-200);background:var(--bg-300)}.nav-btn{position:absolute;top:50%;transform:translateY(-50%);background-color:var(--bg-200);color:var(--text-200);border:none;border-radius:50%;width:40px;height:40px;font-size:20px;display:flex;justify-content:center;align-items:center;cursor:pointer;z-index:10;opacity:.4;transition:opacity .3s ease;padding:0}.nav-btn:hover{opacity:1}.prev-btn{left:10px}.next-btn{right:10px}.close-example-btn{position:absolute;top:0;right:0;background-color:unset;color:var(--text-100);z-index:3}.show-example-btn{position:absolute;width:71px;height:37px;right:0;top:13px;color:var(--text-200);background-color:var(--primary-200);font-size:15px;display:block;padding:0;margin:0;border:none;cursor:pointer;border-radius:20px 0 0 20px;transition:opacity .3s ease;z-index:1}.show-example-btn:hover{opacity:.8}@media screen and (max-width: 767px){.show-example-btn{width:60px;height:32px;font-size:14px;top:10px}}.example-list{margin:0;padding:0;width:0;height:0;overflow:visible;list-style:none}.example-list li{position:absolute;top:0;left:0;width:100%;height:100%;overflow:hidden;background:var(--bg-300);border-radius:15px;display:block;z-index:2;padding:20px;box-sizing:border-box;flex-direction:column;justify-content:center}.example-list li p{margin:10px 0;padding:6px;border-radius:10px;transition:all .3s ease}.example-list li p:first-child{font-size:1.3rem;font-weight:500;color:var(--text-100);background-color:var(--primary-200);box-shadow:0 2px 4px #0000001a}.example-list li p:nth-child(2){font-size:1.1rem;color:var(--text-200);transform:translateY(0);opacity:1;transition:opacity .4s ease,transform .4s ease}.example-list li p:nth-child(3){font-size:1.1rem;color:var(--text-200);font-style:italic;transform:translateY(0);opacity:1;transition:opacity .4s ease,transform .4s ease}.example-list li p[style*="display: none"],.translation-hidden{display:block!important;transform:translateY(-10px);opacity:0;visibility:hidden;height:0;margin:0;padding:0;overflow:hidden}.translation-visible{display:block;transform:translateY(0);opacity:1;visibility:visible;height:auto;margin:10px 0;padding:6px!important}.example-item{cursor:pointer;transition:transform .3s ease}.example-item:hover{transform:scale(1.02)}.japanese-example{position:relative}.japanese{font-size:clamp(2rem,5vw,3rem);margin:0;color:var(--text-100)}.kana{font-size:clamp(1rem,3vw,1.5rem);margin:1rem 0;color:var(--text-100)}.meaning{font-size:clamp(1.2rem,4vw,1.8rem);margin:0;color:var(--text-200);opacity:0;transform:translateY(-10px);transition:opacity .3s ease,transform .3s ease;line-height:1}.category{margin:0;opacity:0;transform:translateY(-10px);transition:opacity .3s ease,transform .3s ease;font-size:clamp(.45rem,1.5vw,.675rem);color:var(--text-200)}.category.show,.meaning.show{opacity:1;transform:translateY(0)}.card-actions{display:flex;justify-content:space-between;gap:1rem}.card-actions button{flex:1;padding:clamp(.5rem,2vw,.8rem);border:none;border-radius:8px;font-size:clamp(.8rem,2.5vw,1rem);cursor:pointer;transition:transform .2s,background-color .2s}.card-actions button:hover{transform:translateY(-2px)}.forgot-btn{background-color:var(--bg-300);color:var(--text-200);box-shadow:0 4px 8px var(--bg-200)}.switch-btn{background-color:var(--primary-300);color:var(--bg-100);box-shadow:0 4px 8px var(--bg-300)}.remember-btn{background-color:var(--accent-100);color:var(--text-200);box-shadow:0 4px 8px var(--bg-300)}.card-image{width:200px;height:140px;margin-bottom:1rem;border-radius:8px;object-fit:cover;opacity:1;transition:opacity .3s ease}.card-image.loading{opacity:.5}.last-card-tip{position:absolute;top:.2rem;right:0;left:0;color:var(--text-100);font-size:.9rem;width:200px;margin:auto;border-radius:1rem;opacity:1}.no-data{height:300px;background-color:var(--primary-100);border-radius:.5rem;display:flex;justify-content:center;align-items:center}.language-button{margin-left:10px;background:none;border:none;padding:8px;cursor:pointer;font-size:1.2rem;color:var(--text-100)}.radio-wrapper{padding:10px;transition:background-color .2s;border-radius:6px;cursor:pointer}.radio-wrapper input[type=radio]{-moz-appearance:none;appearance:none;-webkit-appearance:none;width:20px;height:20px;border:2px solid var(--text-100);border-radius:50%;outline:none;position:relative;cursor:pointer;transition:all .2s}.radio-wrapper input[type=radio]:checked{border-color:var(--primary-200)}.radio-wrapper input[type=radio]:checked:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:10px;height:10px;background-color:var(--primary-200);border-radius:50%}.language-modal .close-language-button{background:none var(--text-200);border-radius:10%;width:70px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;padding:0;color:#000;font-size:1.5rem}.language-modal .sure-language-button{background:none var(--primary-200);border-radius:10%;width:70px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;padding:0;color:#fff;font-size:1.5rem}#root{max-width:1280px;margin:0 auto;padding:2rem;text-align:center}html,body{position:fixed;width:100%;height:100%;overflow:hidden;overscroll-behavior:none;-webkit-overflow-scrolling:touch;background-color:var(--bg-100)}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (prefers-reduced-motion: no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}.control-content{display:flex;align-items:center;width:100%;background-color:var(--bg-300);border-radius:8px;justify-content:center}svg{vertical-align:middle}
