@import"https://fonts.googleapis.com/css2?family=Zen+Maru+Gothic:wght@500&display=swap";@import"https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@400;500;700&family=Noto+Sans+JP:wght@400;500;700&display=swap";body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;position:fixed;width:100%;height:100%;overflow:hidden;-webkit-text-size-adjust:100%;-webkit-touch-callout:none;-webkit-user-select:none;-webkit-tap-highlight-color:transparent;touch-action:manipulation}html{-webkit-text-size-adjust:100%;-ms-text-size-adjust:100%;position:fixed;width:100%;height:100%;overflow:hidden}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}html,body,#root{height:100%;margin:0;padding:0}.App{height:100vh;height:100dvh;max-height:100vh;max-height:100dvh;overflow-x:hidden;overflow-y:hidden}.content-wrapper{flex:1;display:flex;flex-direction:column;position:relative;overflow-y:hidden;overflow-x:hidden;height:100vh;height:100dvh;max-height:100vh;max-height:100dvh;z-index:1;padding-top:100px}.tab-content{flex:1;overflow-y:hidden;overflow-x:hidden;display:flex;height:calc(100vh - 100px);height:calc(100dvh - 100px);max-height:calc(100vh - 100px);max-height:calc(100dvh - 100px);position:relative;z-index:1;align-items:stretch;justify-content:flex-start}.background-component{position:absolute;top:0;left:0;width:100%;height:100%;z-index:-1}.auth-loading{position:fixed;top:0;left:0;width:100%;height:100vh;display:flex;flex-direction:column;justify-content:center;align-items:center;z-index:1000;color:#fff;font-size:1.2rem}.loading-spinner{width:40px;height:40px;border:3px solid rgba(255,255,255,.3);border-top:3px solid white;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:20px}.logo{position:absolute;top:20px;left:20px;z-index:1000}.logo img{height:30px;width:auto}*{font-family:Zen Maru Gothic,sans-serif;font-weight:500;font-size:1.1rem}img,svg,.background-component{font-size:initial}@media (max-width: 768px){.App{height:100vh;height:100dvh;max-height:100vh;max-height:100dvh;overflow-y:hidden;overflow-x:hidden;position:fixed;width:100%;top:0;left:0;-webkit-overflow-scrolling:touch;touch-action:manipulation;-webkit-transform:translateZ(0);transform:translateZ(0);backface-visibility:hidden;-webkit-backface-visibility:hidden}@supports not (height: 100dvh){.App{height:100vh;max-height:100vh}.content-wrapper{height:calc(100vh - 100px);max-height:calc(100vh - 100px);min-height:calc(100vh - 100px)}}.content-wrapper{height:calc(100vh - 100px);height:calc(100dvh - 100px);max-height:calc(100vh - 100px);max-height:calc(100dvh - 100px);min-height:calc(100vh - 100px);min-height:calc(100dvh - 100px);overflow-y:hidden;overflow-x:hidden;padding-top:100px;position:relative;-webkit-overflow-scrolling:touch;-webkit-transform:translateZ(0);transform:translateZ(0)}.tab-content{overflow-y:hidden;overflow-x:hidden;height:100%;max-height:100%;align-items:stretch;justify-content:flex-start;position:relative;-webkit-overflow-scrolling:touch;-webkit-transform:translateZ(0);transform:translateZ(0)}.logo{top:10px;left:10px}.logo img{height:25px}*{font-size:1rem}}@media (max-width: 480px){*{font-size:.9rem}.logo{top:5px;left:5px}.logo img{height:20px}}.login__button{display:flex;align-items:center;justify-content:center;gap:.5rem;cursor:pointer!important;margin-right:2rem;padding:.75rem 1.5rem;background:#000c;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);border-radius:2rem;font-size:.875rem;font-weight:600;color:#fff;transition:all .3s ease;outline:none}.login__button:hover{background:#323232cc;border-color:#ffffff4d;box-shadow:0 4px 20px #fff3}.login__button:focus{outline:none;box-shadow:0 0 0 2px #ffffff4d}.login-icon{width:1.125rem;height:1.125rem;stroke:currentColor;transition:transform .2s ease;flex-shrink:0;display:flex;align-items:center}.login__button:hover .login-icon{transform:translate(2px)}.login-text{font-weight:600;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;line-height:1;display:flex;align-items:center}@media (max-width: 768px){.login__button{padding:.6rem 1.2rem;font-size:.8rem;margin-right:1rem}.login-text{display:none}.login__button{padding:.6rem;border-radius:50%}}.about-container{position:fixed;top:0;left:0;width:100vw;height:100vh;padding:2rem;display:flex;justify-content:center;align-items:flex-start;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;overflow-y:auto;overflow-x:hidden;z-index:1}.about-content{max-width:900px;width:100%;padding:8rem 0 2rem;position:relative;z-index:2}.hero-section{text-align:center;margin-bottom:4rem}.hero-icon{margin-bottom:2rem}.aibo-logo{width:120px;height:120px;filter:drop-shadow(0 8px 32px rgba(0,0,0,.3))}.hero-section h1{font-size:4rem;font-weight:700;margin:0 0 1rem;background:linear-gradient(135deg,#fff,#f0f0f0);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1.2}.hero-subtitle{font-size:1.5rem;font-weight:300;opacity:.9;margin:0;line-height:1.4}.features-section,.how-it-works-section,.philosophy-section{margin-bottom:4rem}.features-section h2,.how-it-works-section h2,.philosophy-section h2{font-size:2.5rem;font-weight:600;text-align:center;margin-bottom:2rem;color:#fff;line-height:1.2}.description{font-size:1.2rem;line-height:1.8;text-align:center;margin-bottom:3rem;opacity:.9;max-width:700px;margin-left:auto;margin-right:auto}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem;margin-top:3rem}.feature-card{background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:20px;padding:2rem;text-align:center;border:1px solid rgba(255,255,255,.2);transition:transform .3s ease,box-shadow .3s ease}.feature-card:hover{transform:translateY(-5px);box-shadow:0 20px 40px #0003}.feature-icon{font-size:3rem;margin-bottom:1rem}.feature-card h3{font-size:1.5rem;font-weight:600;margin-bottom:1rem;color:#fff;line-height:1.3}.feature-card p{font-size:1rem;line-height:1.6;opacity:.9}.steps{display:flex;flex-direction:column;gap:2rem;max-width:600px;margin:0 auto}.step{display:flex;align-items:flex-start;gap:1.5rem;background:#ffffff0d;border-radius:15px;padding:2rem;border:1px solid rgba(255,255,255,.1)}.step-number{width:50px;height:50px;border-radius:50%;background:linear-gradient(135deg,#ff6b6b,#ffa726);display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700;color:#fff;flex-shrink:0}.step-content h3{font-size:1.3rem;font-weight:600;margin-bottom:.5rem;color:#fff;line-height:1.3}.step-content p{font-size:1rem;line-height:1.6;opacity:.9;margin:0}.cta-section{text-align:center;margin:4rem 0;padding:3rem 2rem;background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:25px;border:1px solid rgba(255,255,255,.2)}.cta-section h2{font-size:2.5rem;font-weight:600;margin-bottom:1rem;color:#fff;line-height:1.2}.cta-section p{font-size:1.2rem;margin-bottom:2rem;opacity:.9;line-height:1.6}.cta-button{padding:1rem 2rem!important;font-size:1.2rem!important;border-radius:50px!important;background:linear-gradient(135deg,#ff6b6b,#ffa726)!important;border:none!important;color:#fff!important;font-weight:600!important;transition:transform .3s ease,box-shadow .3s ease!important;text-transform:none!important}.cta-button:hover{transform:translateY(-2px)!important;box-shadow:0 10px 30px #ff6b6b66!important}.philosophy-section{text-align:center}.philosophy-section p{font-size:1.2rem;line-height:1.8;opacity:.9;max-width:700px;margin:0 auto}@media (max-width: 768px){.about-container{padding:1rem;box-sizing:border-box}.about-content{padding:5rem .5rem .5rem;box-sizing:border-box;width:100%;max-width:100%}.hero-section{margin-bottom:2.5rem;padding:0 .5rem}.aibo-logo{width:80px;height:80px}.hero-section h1{font-size:2rem;line-height:1.1;margin-bottom:.75rem;word-break:break-word}.hero-subtitle{font-size:1rem;line-height:1.4;padding:0 .5rem}.features-section h2,.how-it-works-section h2,.philosophy-section h2{font-size:1.75rem;margin-bottom:1.5rem;line-height:1.2;padding:0 .5rem}.description{font-size:.95rem;line-height:1.6;margin-bottom:2rem;padding:0 .5rem}.features-grid{grid-template-columns:1fr;gap:1.5rem;margin-top:2rem;padding:0 .5rem}.feature-card{padding:1.5rem;border-radius:15px;margin:0;box-sizing:border-box}.feature-icon{font-size:2.5rem;margin-bottom:.75rem}.feature-card h3{font-size:1.2rem;margin-bottom:.75rem;line-height:1.3}.feature-card p{font-size:.9rem;line-height:1.5}.steps{max-width:100%;gap:1.5rem;padding:0 .5rem}.step{flex-direction:column;text-align:center;padding:1.5rem;gap:1rem;box-sizing:border-box}.step-number{margin:0 auto;width:40px;height:40px;font-size:1.2rem}.step-content h3{font-size:1.1rem;margin-bottom:.5rem;line-height:1.3}.step-content p{font-size:.9rem;line-height:1.5}.cta-section{padding:2rem 1rem;margin:2.5rem .5rem;border-radius:20px;box-sizing:border-box}.cta-section h2{font-size:1.75rem;margin-bottom:1rem;line-height:1.2}.cta-section p{font-size:.95rem;margin-bottom:1.5rem;line-height:1.5}.cta-button{padding:.875rem 1.5rem!important;font-size:1rem!important;border-radius:25px!important}.philosophy-section{padding:0 .5rem;margin-bottom:2rem}.philosophy-section p{font-size:.95rem;line-height:1.6;max-width:100%}.features-section,.how-it-works-section,.philosophy-section{margin-bottom:2.5rem}}@media (max-width: 480px){.about-container{padding:.75rem}.about-content{padding:4.5rem .25rem .25rem}.hero-section h1{font-size:1.75rem}.hero-subtitle{font-size:.9rem}.features-section h2,.how-it-works-section h2,.philosophy-section h2{font-size:1.5rem}.description,.philosophy-section p,.cta-section p{font-size:.85rem}.feature-card,.step,.cta-section{padding:1.25rem}.feature-card h3{font-size:1.1rem}.feature-card p,.step-content p{font-size:.85rem}.step-content h3{font-size:1rem}}.explore-container{background:transparent;display:flex;flex:1;flex-direction:row;align-items:center;justify-content:center;overflow-y:hidden;overflow-x:hidden;height:100%;max-height:100%;width:100%}.search-container{position:relative;display:flex;align-items:center;justify-content:center;flex:1;width:50vw;height:100%;max-height:100%}.word-list-container{display:flex;flex-direction:column;align-items:center;justify-content:center;overflow-y:hidden;overflow-x:hidden;align-items:flex-start;height:100%;max-height:100%;flex:1}.word-list{display:flex;flex-direction:column;height:100%;max-height:100%;width:100%;overflow-y:scroll;overflow-x:hidden;align-items:center}.entry-motion-wrapper{width:100%;position:relative;transform-origin:center left}.entry-placeholder{display:flex;flex-direction:column;width:40vw;min-width:300px;max-width:600px;margin:20px auto;padding:25px;background:#f5eee699;border-radius:12px;box-shadow:0 4px 12px #8b451308;position:relative;border:1px solid rgba(180,165,150,.2);box-sizing:border-box}.entry-placeholder-header{display:flex;align-items:center;gap:16px;padding-bottom:20px;border-bottom:1px solid rgba(180,165,150,.15);margin-bottom:20px}.entry-placeholder-body{display:flex;flex-direction:column;width:100%;gap:12px}.placeholder-kanji{width:120px;height:48px;background:linear-gradient(90deg,#c8beb44d,#dcd2c880,#c8beb44d);border-radius:8px;animation:shimmer 2s infinite ease-in-out}.placeholder-actions{display:flex;align-items:center;gap:12px;margin-left:auto}.placeholder-button{width:24px;height:24px;background:linear-gradient(90deg,#a0b4a04d,#b4c8b480,#a0b4a04d);border-radius:4px;animation:shimmer 2s infinite ease-in-out;animation-delay:.2s}.placeholder-circle{width:40px;height:40px;background:linear-gradient(90deg,#b4a08c4d,#c8b4a080,#b4a08c4d);border-radius:50%;animation:shimmer 2s infinite ease-in-out;animation-delay:.4s}.placeholder-reading{width:80px;height:20px;background:linear-gradient(90deg,#a0968c4d,#b4aaa080,#a0968c4d);border-radius:4px;animation:shimmer 2s infinite ease-in-out;animation-delay:.6s}.placeholder-definition-line{height:16px;background:linear-gradient(90deg,#aaa0964d,#beb4aa80,#aaa0964d);border-radius:4px;animation:shimmer 2s infinite ease-in-out;animation-delay:.8s}.placeholder-definition-line:nth-child(2){width:85%;animation-delay:1s}.placeholder-definition-line.short{width:60%;animation-delay:1.2s}@keyframes shimmer{0%{opacity:.6;transform:scale(1)}50%{opacity:.8;transform:scale(1.02)}to{opacity:.6;transform:scale(1)}}.empty-state{text-align:center;padding:2rem;color:#666}.empty-state-icon{font-size:3rem;margin-bottom:1rem;opacity:.7}.empty-state h3{margin:0 0 .5rem;font-weight:500}.empty-state p{margin:0;font-size:.9rem}.random-words-container{width:100%;height:100%;display:flex;justify-content:center;align-items:center}.random-word-card{width:100%;background:#ffffff0d;border-radius:12px;padding:20px;transform-origin:center}@media (max-width: 768px){.explore-container{flex-direction:column;padding:1rem;gap:1rem;overflow-y:hidden;overflow-x:hidden;align-items:flex-start;justify-content:flex-start;height:100%;max-height:100%;width:100%;box-sizing:border-box;-webkit-overflow-scrolling:touch;position:relative}.search-container{width:100%;flex:none;padding:0 1rem;min-height:auto;height:auto;max-height:none;align-items:flex-start;justify-content:center;box-sizing:border-box;flex-shrink:0}.search-container input{width:100%;max-width:none;font-size:1rem;padding:14px 20px;border-radius:24px}.word-list-container{width:100%;flex:1;align-items:center;overflow-y:hidden;overflow-x:hidden;justify-content:flex-start;height:100%;max-height:100%;box-sizing:border-box;min-height:0}.word-list{margin-top:0;width:100%;padding:0 .5rem;height:100%;max-height:100%;overflow-y:auto;overflow-x:hidden;box-sizing:border-box;-webkit-overflow-scrolling:touch;position:relative}.word-list.empty{width:100%;justify-content:flex-start;padding-top:2rem;overflow-y:hidden}.random-words-container{padding:1rem 0;align-items:flex-start;justify-content:flex-start;width:100%;box-sizing:border-box;height:100%;overflow-y:hidden}.random-word-card{padding:1rem;border-radius:8px;margin:0 .5rem;width:calc(100% - 1rem);box-sizing:border-box}.entry-motion-wrapper{margin:.5rem 0;width:100%;box-sizing:border-box}.entry-placeholder{width:calc(100% - 2rem);max-width:none;min-width:0;margin:10px auto;padding:15px}.placeholder-kanji{width:100px;height:40px}.placeholder-circle{width:32px;height:32px}.placeholder-button{width:20px;height:20px}.empty-state{padding:1.5rem 1rem;width:100%;box-sizing:border-box}.empty-state-icon{font-size:2.5rem}.empty-state h3{font-size:1.3rem}.empty-state p{font-size:.9rem}}@media (max-width: 480px){.explore-container{padding:.5rem;gap:.5rem}.search-container{padding:0}.search-container input{font-size:.9rem;padding:12px 18px;border-radius:20px}.word-list{padding:0 .25rem}.random-word-card{padding:.75rem;margin:0 .25rem;width:calc(100% - .5rem)}.empty-state{padding:1rem .5rem}.entry-placeholder{width:calc(100% - 1rem);margin:8px auto;padding:12px}.placeholder-kanji{width:80px;height:32px}.placeholder-circle{width:28px;height:28px}.placeholder-button{width:18px;height:18px}}::-webkit-scrollbar{width:12px}::-webkit-scrollbar-thumb{background-color:#ccc;border-radius:6px}.content{display:flex;margin:120px auto 32px;padding:0 16px;max-width:960px;flex-direction:column;align-items:center}.definition{font-size:16px;font-weight:400;font-family:Verdana,sans-serif}.parts__of__speech{font-weight:700;font-size:10px;margin-left:10px;padding:5px}.kanji__column{cursor:pointer;width:auto;margin-right:20px;display:flex;flex-direction:column;flex:1;min-width:0}.button__column{width:40px;margin-right:10px}.save__button{cursor:pointer;color:#80808080}.entry__container:hover .save__button{cursor:pointer;color:#1976d2}.entry__container:hover .save__button:hover{color:#add8e6}.unsave__button{cursor:pointer;color:#1976d2}.definition__column{width:100%;color:#555;font-weight:700}.definition__row{padding-bottom:10px}.def__number{color:#1976d288;font-size:14px;padding-right:10px}.entry__container{display:flex;flex-direction:column;width:40vw;min-width:300px;max-width:600px;margin:20px auto;padding:25px;background:#faf6f1fa;border-radius:12px;box-shadow:0 4px 12px #0000000d;position:relative;transition:all .3s ease;border:1px solid rgba(139,69,19,.1);box-sizing:border-box}.entry__container:hover{transform:translateY(-2px);box-shadow:0 6px 16px #00000014}.entry__header{display:flex;align-items:center;gap:16px;padding-bottom:20px;border-bottom:1px solid rgba(139,69,19,.1);margin-bottom:20px}.entry__body{display:flex;flex-direction:column;width:100%}.kanji__primary{font-family:"Noto Serif JP",serif;font-size:32px;font-weight:500;color:#2c3e50;display:block;height:48px;line-height:48px;transition:transform .2s ease;text-shadow:1px 1px 2px rgba(0,0,0,.05);overflow:hidden;white-space:nowrap}.kanji__primary__row{display:flex;flex-direction:row;align-items:center;height:32px}.reading__primary{font-family:Noto Sans JP,sans-serif;font-weight:400;color:#7f8c8d;font-size:16px;display:inline-block;width:fit-content;height:24px;line-height:24px;transition:color .2s ease,transform .2s ease;margin-top:4px;overflow:hidden;white-space:nowrap}.kanji__primary__row .reading__primary{height:0;line-height:0;margin:0;padding:0;overflow:hidden}.entry__container:hover .reading__primary{color:#1976d2;transform:scale(.9)}.entry__container:hover .kanji__primary{transform:scale(1.05);text-shadow:2px 2px 4px rgba(0,0,0,.1)}.entry__card{padding:10px;font-family:din-round,sans-serif}.button__column{display:flex;align-items:center}.probability__column{display:flex;justify-content:flex-end;align-items:center;min-width:60px;margin-left:auto}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.entry__container{animation:fadeIn .5s ease-out}@media (max-width: 768px){.entry__container{width:calc(100% - 2rem);max-width:none;min-width:0;margin:10px auto;padding:15px;box-sizing:border-box}.kanji__primary{font-size:28px}.reading__primary{font-size:14px}}@media (max-width: 480px){.entry__container{width:calc(100% - 1rem);margin:8px auto;padding:12px}.kanji__primary{font-size:24px}.reading__primary{font-size:12px}}.recall-probability-circle{position:relative;display:flex;align-items:center;justify-content:center}.recall-probability-circle svg{position:absolute;top:0;left:0}.percentage-text{font-weight:700;z-index:1}.kanji-tooltip{animation:fadeInTooltip .2s ease-out;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}@keyframes fadeInTooltip{0%{opacity:0;transform:translateY(-8px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.kanji-tooltip{z-index:10000!important}.kanji-hoverable{font-family:inherit;font-size:inherit;font-weight:inherit;font-style:inherit;line-height:inherit;color:inherit;text-decoration:inherit;letter-spacing:inherit;text-shadow:inherit;transition:background-color .2s ease,box-shadow .2s ease;border-radius:2px;display:inline;position:relative}.kanji-hoverable:hover{background-color:#556b2f14;box-shadow:0 0 0 1px #556b2f26}.kanji-clickable{background-color:#8b45130d;border-radius:3px;padding:1px 2px;transition:background-color .2s ease,transform .2s ease,box-shadow .2s ease;cursor:pointer}.kanji-clickable:hover{background-color:#8b451326;transform:translateY(-1px);box-shadow:0 2px 6px #8b451340}.kanji-clickable:active{transform:translateY(0);box-shadow:0 1px 3px #8b451333}@media (max-width: 768px){.kanji-tooltip{max-width:250px!important;font-size:.875rem}.kanji-tooltip .MuiTypography-h3{font-size:2rem!important}.kanji-hoverable:hover{background-color:#556b2f0d;box-shadow:none}}.cursor{z-index:1000}.cursor-input-container{cursor:text;border-radius:8px;-webkit-user-select:none;user-select:none}.cursor-text-container{display:flex;align-items:baseline;position:relative;align-items:center}.cursor-text{display:inline-block;line-height:1}.cursor-placeholder{opacity:.6}.cursor-animated{display:inline-block;width:.4em;height:.8em;border-radius:.15em;animation:cursorSizeWave 2s ease-in-out infinite;transform-origin:center;position:relative;top:.05em}.cursor-animated.focused{animation:cursorFocusPulse .7s ease-in-out infinite}.cursor-animated.typing{animation:cursorFocusPulse .7s ease-in-out infinite;border-radius:50%;width:.6em;height:.6em}@keyframes turnIntoCircle{0%,to{border-radius:.15em}50%{border-radius:50%;height:.5em}}@keyframes cursorSizeBounce{0%,to{transform:translateY(0) scaleY(1) scaleX(1)}50%{transform:translateY(-3px) scaleY(1.1) scaleX(1.2)}}@keyframes cursorSizeWave{0%{transform:scaleX(1) scaleY(1)}25%{transform:scaleX(1.15) scaleY(.9)}50%{transform:scaleX(.85) scaleY(1.1)}75%{transform:scaleX(1.1) scaleY(.95)}to{transform:scaleX(1) scaleY(1)}}@keyframes cursorFocusPulse{0%,to{opacity:.5;transform:scale(1)}50%{opacity:1;transform:scale(1.1)}}@keyframes cursorBlink{0%,50%{opacity:1}51%,to{opacity:0}}@media (max-width: 768px){.cursor-animated{width:.4em;height:.7em;animation-duration:2.5s,4s}.cursor-animated.focused{animation-duration:2s,3s,1.5s}}.cursor-input-mobile{width:100%;padding:1rem 1.5rem;font-size:1.1rem;font-family:Zen Maru Gothic,sans-serif;font-weight:500;background:#ffffff1a;border:2px solid rgba(255,255,255,.2);border-radius:12px;color:#fff;outline:none;transition:all .3s ease;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.cursor-input-mobile::placeholder{color:#fff9;font-weight:400}.cursor-input-mobile:focus{border-color:#fff6;box-shadow:0 0 0 3px #ffffff1a;background:#ffffff26}.cursor-input-mobile:hover{border-color:#ffffff4d;background:#ffffff1f}@media (max-width: 768px){.cursor-input-mobile{font-size:1rem;padding:.875rem 1.25rem;border-radius:10px}}@media (max-width: 480px){.cursor-input-mobile{font-size:.9rem;padding:.75rem 1rem;border-radius:8px}}.word-list-container-saved{display:flex;flex-direction:column;align-items:center;justify-content:center;overflow-y:hidden;overflow-x:hidden;align-items:flex-start;height:100%;max-height:100%;flex:1}.word-list-saved{display:flex;flex-direction:column;height:100%;max-height:100%;width:100%;overflow-y:scroll;overflow-x:hidden;margin-top:90px}.date-spacer{position:relative;padding:10px 0;color:#8b7355b3;font-size:12px;font-weight:700;text-align:center;text-shadow:0 0 3px rgba(255,255,255,.3)}.date-spacer:before,.date-spacer:after{content:"";position:absolute;top:50%;width:20%;border-top:1px solid rgba(139,115,85,.25);transform:translateY(-50%);box-shadow:0 0 2px #ffffff1a}.date-spacer:before{left:15%}.date-spacer:after{right:15%}.saved-container{background:transparent;display:flex;flex:1;flex-direction:row;align-items:center;justify-content:center;overflow-y:hidden;overflow-x:hidden;height:100%;max-height:100%;width:100%}.search-container{font-size:calc(10px + 2vmin);color:#fff;display:flex;flex:1;width:50vw;align-items:center;justify-content:center;height:100%;max-height:100%}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:3rem 2rem;color:#4a4a4a;flex:1;width:100%;max-width:500px;margin:0 auto}.empty-state-icon{margin-bottom:1.5rem;opacity:.9}.empty-state-icon img{filter:brightness(.8)}.empty-state h3{font-size:1.8rem;font-weight:600;margin:0 0 1.5rem;color:#2c2c2c}.empty-state p{font-size:1.1rem;line-height:1.6;margin:0 0 1.5rem;color:#5a5a5a}.empty-state-hint{font-size:1rem;font-style:italic;color:#666!important}.explore-link{background:transparent;color:#5a5a5a;border:2px solid #5a5a5a;padding:.4rem .8rem;border-radius:6px;font-weight:600;font-size:inherit;font-family:inherit;cursor:pointer;transition:all .3s ease;display:inline-block;margin:0 .2rem}.explore-link:hover{background-color:#5a5a5a;color:#fff;transform:translateY(-1px)}@media (max-width: 768px){.saved-container{flex-direction:column;padding:1rem;gap:1rem;overflow-y:hidden;overflow-x:hidden;align-items:flex-start;justify-content:flex-start;height:100%;max-height:100%;width:100%;box-sizing:border-box;-webkit-overflow-scrolling:touch;position:relative}.search-container{width:100%;flex:none;padding:0;min-height:auto;height:auto;max-height:none;font-size:1rem;align-items:flex-start;justify-content:flex-start;box-sizing:border-box;flex-shrink:0}.word-list-container-saved{width:100%;flex:1;align-items:center;overflow-y:hidden;overflow-x:hidden;justify-content:flex-start;height:100%;max-height:100%;box-sizing:border-box;min-height:0}.word-list-saved{margin-top:0;width:100%;padding:0 .5rem;height:100%;max-height:100%;overflow-y:auto;overflow-x:hidden;box-sizing:border-box;-webkit-overflow-scrolling:touch;position:relative}.date-spacer{padding:1rem 0;font-size:.9rem;text-align:center;color:#8b7355;text-shadow:0 0 3px rgba(255,255,255,.3)}.empty-state{padding:2rem 1rem;margin-top:1rem;justify-content:flex-start;width:100%;max-width:none;box-sizing:border-box;overflow-y:hidden}.empty-state h3{font-size:1.5rem}.empty-state p{font-size:1rem}.empty-state-hint{font-size:.9rem}.explore-link{padding:.3rem .6rem;font-size:.9rem}}@media (max-width: 480px){.saved-container{padding:.5rem;gap:.5rem}.search-container{padding:0}.word-list-saved{padding:0 .25rem}.date-spacer{padding:.75rem 0;font-size:.8rem;text-align:center;color:#8b7355;text-shadow:0 0 3px rgba(255,255,255,.3)}.empty-state{padding:1.5rem .5rem}.empty-state h3{font-size:1.3rem}.empty-state p{font-size:.9rem}.explore-link{padding:.25rem .5rem;font-size:.85rem}}@keyframes wiggle{0%{transform:translateY(0) rotate(0)}25%{transform:translateY(-2px) rotate(3deg)}75%{transform:translateY(2px) rotate(-3deg)}to{transform:translateY(0) rotate(0)}}.wiggle__letter{display:inline-block;animation:wiggle 2s ease-in-out infinite;font-family:Fredoka,sans-serif;text-shadow:2px 2px 0px rgba(0,0,0,.1);font-weight:500;letter-spacing:1px}.coming__soon{font-size:calc(10px + 2vmin);color:#fff;display:flex;margin-bottom:100px;flex:1;width:50vw;align-items:center;justify-content:center}.coming__soon_container{background:transparent;display:flex;flex:1;flex-direction:row;align-items:center;justify-content:center;overflow-y:hidden;height:100%}.learn-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;width:100%;height:calc(100vh - 64px);box-sizing:border-box;position:relative;z-index:5}.card-review{background:#21212bd9;border-radius:15px;padding:2rem;width:100%;max-width:600px;box-shadow:0 8px 32px #0000004d;display:flex;flex-direction:column;align-items:center;position:relative;z-index:10;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.05)}.card-content{width:100%;display:flex;flex-direction:column;align-items:center;margin-bottom:2rem;text-align:center}.card-content .kanji{font-size:5rem;margin-bottom:1.5rem;color:#fff6f6}.card-content .reading{font-size:2.5rem;color:#fff6f6;opacity:.9;margin:1rem 0}.card-content .definition{font-size:1.5rem;color:#fff6f6;opacity:.8;margin:1rem 0;line-height:1.4}.reveal-buttons{display:flex;gap:1rem;margin:1rem 0}.reveal-button{padding:.8rem 1.5rem;border-radius:8px;border:1px solid #FFF6F6;background:transparent;color:#fff6f6;font-size:1rem;cursor:pointer;transition:all .2s}.reveal-button:hover{background:#fff6f61a}.reveal-button.view-entry-button{background:linear-gradient(45deg,#2196f3 30%,#21cbf3 90%);border:1px solid #2196F3;color:#fff;font-weight:500}.reveal-button.view-entry-button:hover{background:linear-gradient(45deg,#1976d2 30%,#2196f3 90%);transform:translateY(-1px);box-shadow:0 4px 8px #2196f34d}.rating-container{width:100%;display:flex;flex-direction:column;align-items:center;gap:1rem;margin-top:2rem}.rating-buttons{display:flex;justify-content:space-between;width:100%;gap:16px}.rating-button{flex:1;display:flex;align-items:center;justify-content:center;padding:20px;border-radius:12px;border:2px solid transparent;background-color:#ffffff1a;color:#fff6f6;cursor:pointer;transition:all .2s ease;min-height:80px;min-width:80px}.rating-button .emoji{font-size:40px}.rating-button:hover{transform:translateY(-5px);box-shadow:0 8px 16px #0003}.rating-button.again{background-color:#ff3c3c4d}.rating-button.hard{background-color:#ff96004d}.rating-button.good{background-color:#ffdc004d}.rating-button.easy{background-color:#32c8504d}.rating-button.selected{border:2px solid #FFF6F6;transform:translateY(-5px);box-shadow:0 8px 16px #0000004d}.rating-button.again:hover{background-color:#ff3c3c80}.rating-button.hard:hover{background-color:#ff960080}.rating-button.good:hover{background-color:#ffdc0080}.rating-button.easy:hover{background-color:#32c85080}.rating-button.again.selected{background-color:#ff3c3c66}.rating-button.hard.selected{background-color:#ff960066}.rating-button.good.selected{background-color:#ffdc0066}.rating-button.easy.selected{background-color:#32c85066}.submit-button{padding:.8rem 2rem;border-radius:8px;border:none;background:#fff6f6;color:#0a0a14;font-size:1rem;cursor:pointer;transition:all .2s;margin-top:1rem}.submit-button:hover{transform:translateY(-2px);box-shadow:0 2px 4px #0003}.progress{position:absolute;bottom:-30px;color:#fff6f6;opacity:.7}.no-cards-message,.completion-message{text-align:center;color:#fff6f6}.no-cards-message p,.completion-message p{margin:1rem 0;opacity:.8}@media (max-width: 768px){.learn-container{padding:1rem .5rem;height:100%;max-height:100%;justify-content:center;overflow-y:auto;box-sizing:border-box}.card-review{padding:1.5rem;max-width:100%;width:100%;margin-top:1rem;box-sizing:border-box}.card-content .kanji{font-size:3.5rem;margin-bottom:1rem}.card-content .reading{font-size:2rem;margin:.8rem 0}.card-content .definition{font-size:1.2rem;margin:.8rem 0}.reveal-buttons{gap:.5rem;flex-wrap:wrap}.reveal-button{padding:.6rem 1rem;font-size:.9rem;flex:1;min-width:120px}.rating-container{margin-top:1.5rem;width:100%;box-sizing:border-box}.rating-buttons{gap:8px;width:100%}.rating-button{flex:1;padding:12px 8px;min-height:60px;min-width:60px;border-radius:8px;box-sizing:border-box}.rating-button .emoji{font-size:28px}.progress{bottom:-25px;font-size:.9rem}.no-cards-message,.completion-message{padding:1rem;margin-top:2rem}}@media (max-width: 480px){.learn-container{padding:.75rem .25rem}.card-review{padding:1rem;margin-top:.5rem}.card-content .kanji{font-size:3rem}.card-content .reading{font-size:1.8rem}.card-content .definition{font-size:1.1rem}.rating-buttons{gap:6px}.rating-button{padding:10px 6px;min-height:50px;min-width:50px}.rating-button .emoji{font-size:24px}.reveal-button{padding:.5rem .8rem;font-size:.85rem;min-width:100px}}.completion-card{display:flex;flex-direction:column;align-items:center;text-align:center;background:linear-gradient(135deg,#93a5881f,#b6baa414);border:1px solid rgba(147,165,136,.2);box-shadow:0 6px 24px #00000026,0 2px 8px #93a5881a,inset 0 1px #ffffff0d;position:relative;overflow:hidden}.completion-card:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(239,237,230,.05),transparent);animation:shimmer 4s infinite}@keyframes shimmer{0%{left:-100%}to{left:100%}}.completion-icon{font-size:6rem!important;color:#93a588;margin-bottom:1.5rem;filter:drop-shadow(0 2px 6px rgba(147,165,136,.3));animation:gentle-pulse 3s ease-in-out infinite alternate}.completion-card .completion-icon.MuiSvgIcon-root{font-size:6rem!important;width:6rem!important;height:6rem!important}@keyframes gentle-pulse{0%{filter:drop-shadow(0 2px 6px rgba(147,165,136,.3));transform:scale(1);opacity:.9}to{filter:drop-shadow(0 3px 8px rgba(147,165,136,.4));transform:scale(1.02);opacity:1}}.completion-title{margin:0 0 2rem;color:#efe6dc;font-size:2.5rem;font-weight:500;text-shadow:0 1px 3px rgba(0,0,0,.2)}.completion-message{width:100%;max-width:500px}.completion-primary{font-size:1.3rem;color:#efe6dc;margin-bottom:1.5rem;line-height:1.6;font-weight:400}.completion-secondary{font-size:1.1rem;color:#efe6dcbf;margin-bottom:2rem;line-height:1.5}@media (max-width: 768px){.completion-card{padding:2.5rem 1.5rem;margin:.5rem;max-width:calc(100% - 1rem)}.completion-icon{font-size:4.5rem!important;margin-bottom:1.5rem;color:#93a588;filter:drop-shadow(0 2px 4px rgba(147,165,136,.25))}.completion-card .completion-icon.MuiSvgIcon-root{font-size:4.5rem!important;width:4.5rem!important;height:4.5rem!important}.completion-title{font-size:1.9rem;margin-bottom:2rem;line-height:1.3}.completion-message{max-width:100%}.completion-primary{font-size:1.1rem;margin-bottom:1.5rem;line-height:1.5}.completion-secondary{font-size:1rem;margin-bottom:0;line-height:1.4}}@media (max-width: 480px){.completion-card{padding:2rem 1.25rem;margin:.25rem}.completion-icon{font-size:4rem!important;margin-bottom:1.25rem;color:#93a588;filter:drop-shadow(0 1px 3px rgba(147,165,136,.2))}.completion-card .completion-icon.MuiSvgIcon-root{font-size:4rem!important;width:4rem!important;height:4rem!important}.completion-title{font-size:1.7rem;margin-bottom:1.75rem;line-height:1.25}.completion-primary{font-size:1rem;margin-bottom:1.25rem;line-height:1.45}.completion-secondary{font-size:.9rem;margin-bottom:0;line-height:1.4}}.dictionary-entry-container{padding:2rem;box-sizing:border-box;height:100vh;overflow-y:auto;scrollbar-width:thin;scrollbar-color:#7f8c8d #f1f1f1}.dictionary-entry-container::-webkit-scrollbar{width:8px}.dictionary-entry-container::-webkit-scrollbar-track{background:#faf8f080}.dictionary-entry-container::-webkit-scrollbar-thumb{background-color:#b0a99b;border-radius:4px}.MuiTypography-h4{font-family:Noto Sans JP,sans-serif!important;color:#2c3e50}.MuiAccordion-root{background:#faf6f1cc!important;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(139,69,19,.1)!important;box-shadow:0 2px 8px #0000000a!important;border-radius:12px!important;margin-bottom:16px!important;overflow:hidden!important}.MuiAccordion-root:before{display:none!important}.MuiAccordionSummary-root{background:#f3eee8b3!important;border-bottom:1px solid rgba(139,69,19,.1);border-radius:12px 12px 0 0!important}.MuiAccordionDetails-root{padding:24px!important;background-color:#faf6f199!important;border-radius:0 0 12px 12px!important}.MuiAccordionSummary-content .MuiTypography-h6{font-family:Noto Sans JP,sans-serif!important;color:#4a4a4a;font-weight:500!important}.MuiCard-root{background:#fffdfae6!important;border-radius:12px!important;box-shadow:none!important;border:1px solid rgba(139,69,19,.15)!important;margin-bottom:16px!important;overflow:hidden!important}.MuiCardContent-root{padding:16px!important}.kanji-text{font-family:"Noto Serif JP",serif;font-size:2.5rem;color:#2c3e50}.reading-text{font-family:Noto Sans JP,sans-serif;font-size:1.5rem;color:#556b2f}.MuiTypography-body1,.MuiTypography-body2,.MuiTypography-caption{font-family:Noto Sans JP,sans-serif!important;color:#4a4a4a}.MuiTypography-subtitle2{color:#2c3e50;font-weight:500!important}.MuiChip-root{font-family:Noto Sans JP,sans-serif!important;background-color:#556b2f1a!important;color:#2c3e50!important;border:1px solid rgba(85,107,47,.2)!important}.MuiChip-colorPrimary{background-color:#b0a99b33!important;color:#2c3e50!important;border-color:#b0a99b66!important}.MuiChip-colorSecondary{background-color:#6f806f33!important;color:#2c3e50!important;border-color:#6f806f66!important}.MuiChip-colorSuccess{background-color:#8fbc8f33!important;color:#2c3e50!important;border-color:#8fbc8f66!important}.MuiChip-colorWarning{background-color:#d2b48c4d!important;color:#2c3e50!important;border-color:#d2b48c80!important}.MuiButton-contained{background-color:#556b2f!important;box-shadow:none!important;transition:background-color .3s ease!important}.MuiButton-contained:hover{background-color:#6b8e23!important}.MuiIconButton-root{color:#556b2f!important}.MuiTextField-root .MuiOutlinedInput-root{background-color:#ffffffb3;border-radius:8px}.MuiTextField-root .MuiOutlinedInput-notchedOutline{border-color:#8b451333!important}.MuiTextField-root:hover .MuiOutlinedInput-notchedOutline{border-color:#556b2fb3!important}.MuiTextField-root .Mui-focused .MuiOutlinedInput-notchedOutline{border-color:#556b2f!important}.MuiCardContent-root .kanji-text{font-family:"Noto Serif JP",serif;font-weight:500;color:#2c3e50;line-height:1.2}.MuiCardContent-root .reading-text{font-family:Noto Sans JP,sans-serif;color:#556b2f;margin-top:4px}.sense-definitions li{margin-bottom:8px}.entry-info-panel{background:#f3eee8b3!important;padding:16px;border-radius:8px;border:1px solid rgba(139,69,19,.1)}.MuiContainer-root{padding:24px!important;max-width:1200px!important;margin:0 auto!important}.MuiGrid-container{margin:0!important;width:100%!important}.MuiGrid-item{padding:12px!important}@media (max-width: 768px){.dictionary-entry-container{padding:1rem}.MuiContainer-root{padding:16px!important}.MuiGrid-item{padding:8px!important}.MuiAccordionDetails-root{padding:16px!important}.MuiCardContent-root{padding:12px!important}.MuiTypography-h4{font-size:1.75rem!important}.kanji-text{font-size:2rem}.reading-text{font-size:1.25rem}}@media (max-width: 480px){.dictionary-entry-container{padding:.5rem}.MuiContainer-root{padding:12px!important}.MuiGrid-item{padding:6px!important}.MuiAccordionDetails-root{padding:12px!important}.MuiCardContent-root{padding:8px!important}.MuiTypography-h4{font-size:1.5rem!important}.MuiTypography-h5{font-size:1.25rem!important}.MuiTypography-h6{font-size:1.1rem!important}}.priority-chip{background:linear-gradient(45deg,#2196f3 30%,#21cbf3 90%);color:#fff;font-weight:500}.info-chip{background:linear-gradient(45deg,#ff6b6b 30%,#ff8e53 90%);color:#fff;font-weight:500}.MuiAccordion-root:before{display:none}.MuiAccordionSummary-root{border-radius:12px 12px 0 0;background:linear-gradient(45deg,#f8f9fa 30%,#e9ecef 90%)}.MuiAccordionSummary-root.Mui-expanded{background:linear-gradient(45deg,#e3f2fd 30%,#bbdefb 90%)}.MuiCard-root:hover{transform:translateY(-2px);box-shadow:0 4px 20px #0000001f}.sense-card{border-left:4px solid #2196F3;margin-bottom:16px}.sense-card:nth-child(odd){border-left-color:#4caf50}.sense-card:nth-child(2n){border-left-color:#ff9800}.example-card{background:linear-gradient(135deg,#f5f7fa,#c3cfe2);border-left:4px solid #9C27B0}.comment-card{background:#2196f30d;border-left:3px solid #2196F3}.notes-section{background:#4caf500d;border-radius:8px;padding:16px}.entry-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:24px;border-radius:16px;margin-bottom:24px;box-shadow:0 8px 32px #0000001a}.save-button{transition:all .3s ease}.save-button:hover{transform:scale(1.1)}.save-button.saved{color:#f44336}.chip-pos{background:linear-gradient(45deg,#4caf50 30%,#8bc34a 90%);color:#fff}.chip-field{background:linear-gradient(45deg,#2196f3 30%,#03dac6 90%);color:#fff}.chip-misc{background:linear-gradient(45deg,#ff9800 30%,#ffc107 90%);color:#fff}.chip-dialect{background:linear-gradient(45deg,#9c27b0 30%,#e91e63 90%);color:#fff}@media (max-width: 768px){.dictionary-entry-container{padding-top:10px}.MuiContainer-root{padding-left:8px!important;padding-right:8px!important}.MuiGrid-item{padding:8px!important}.entry-header{padding:16px;margin-bottom:16px}.sidebar-content{margin-top:16px}.MuiCard-root{margin-bottom:12px}.MuiAccordionSummary-content{flex-direction:column;align-items:flex-start}}@media (max-width: 480px){.MuiTypography-h4{font-size:1.5rem!important}.MuiTypography-h5{font-size:1.25rem!important}.MuiTypography-h6{font-size:1.1rem!important}.MuiChip-root{font-size:.75rem;height:24px}.MuiBox-root{margin-bottom:8px!important}}.loading-container{display:flex;justify-content:center;align-items:center;min-height:400px}.error-container{display:flex;justify-content:center;align-items:center;min-height:200px}.animate-item{opacity:0;transform:translateY(20px)}.animate-item.visible{opacity:1;transform:translateY(0);transition:all .3s ease-in-out}.sidebar-section{background:#ffffff40;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.18);border-radius:16px;box-shadow:0 8px 32px #1f26875e}.entry-info-panel{background:linear-gradient(135deg,#ffffff1a,#fff3);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);border-radius:16px}.scrollable-content{max-height:400px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(0,0,0,.2) transparent}.scrollable-content::-webkit-scrollbar{width:6px}.scrollable-content::-webkit-scrollbar-track{background:transparent}.scrollable-content::-webkit-scrollbar-thumb{background-color:#0003;border-radius:3px}.scrollable-content::-webkit-scrollbar-thumb:hover{background-color:#0006}::selection{background-color:#2196f34d;color:inherit}::-moz-selection{background-color:#2196f34d;color:inherit}.comment-item{position:relative;margin-bottom:8px}.comment-avatar{background:linear-gradient(45deg,#3f51b5,#2196f3);color:#fff;font-weight:700}.comment-content{line-height:1.6;word-wrap:break-word;overflow-wrap:break-word}.vote-section{display:flex;align-items:center;background:#00000005;border-radius:20px;padding:4px 8px;margin-right:8px}.vote-button{transition:all .2s ease-in-out;border-radius:50%}.vote-button:hover{background-color:#0000000a;transform:scale(1.1)}.vote-button.active{background-color:#2196f31a}.vote-score{min-width:24px;text-align:center;font-weight:500;transition:color .2s ease-in-out}.vote-score.positive{color:#4caf50}.vote-score.negative{color:#f44336}.reply-form-container{background:#00000005;border-radius:8px;padding:12px;margin-top:12px;border:1px solid rgba(0,0,0,.06)}.comment-item.depth-0{padding-left:0}.comment-item.depth-1{position:relative;border-left:3px solid rgba(33,150,243,.2);padding-left:12px}.comment-item.depth-2{position:relative;border-left:3px solid rgba(76,175,80,.2);padding-left:12px}.comment-item.depth-3{position:relative;border-left:3px solid rgba(255,152,0,.2);padding-left:12px}.comment-item.depth-4{position:relative;border-left:3px solid rgba(156,39,176,.2);padding-left:12px}.comment-item.depth-5{position:relative;border-left:3px solid rgba(233,30,99,.2);padding-left:12px}.comment-item[class*=depth-]:nth-child(6n+1){border-left-color:#2196f333}.comment-item[class*=depth-]:nth-child(6n+2){border-left-color:#4caf5033}.comment-item[class*=depth-]:nth-child(6n+3){border-left-color:#ff980033}.comment-item[class*=depth-]:nth-child(6n+4){border-left-color:#9c27b033}.comment-item[class*=depth-]:nth-child(6n+5){border-left-color:#e91e6333}.comment-item.depth-1 .MuiPaper-root{background-color:#2196f303}.comment-item.depth-2 .MuiPaper-root{background-color:#4caf5003}.comment-item.depth-3 .MuiPaper-root{background-color:#ff980003}.comment-item.depth-4 .MuiPaper-root{background-color:#9c27b003}.comment-item.depth-5 .MuiPaper-root{background-color:#e91e6303}.comment-item.depth-1:before,.comment-item.depth-2:before,.comment-item.depth-3:before,.comment-item.depth-4:before,.comment-item.depth-5:before{content:"";position:absolute;left:-16px;top:20px;width:12px;height:1px;background:currentColor;opacity:.3}.comment-item.depth-1:after,.comment-item.depth-2:after,.comment-item.depth-3:after,.comment-item.depth-4:after,.comment-item.depth-5:after{content:"";position:absolute;left:-16px;top:0;width:1px;height:20px;background:currentColor;opacity:.3}.comment-thread-line{position:absolute;left:-2px;top:0;bottom:0;width:2px;background:linear-gradient(to bottom,#e3f2fd,#bbdefb);opacity:.7}.comment-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:8px}.comment-actions .MuiButton-root{font-size:.75rem;padding:4px 8px;min-width:auto}.comment-metadata{display:flex;align-items:center;gap:8px;color:#0009;font-size:.75rem;margin-bottom:8px}.comment-edited-badge{background:#ffc1071a;color:#f57c00;border:1px solid rgba(255,193,7,.3)}.comment-you-chip{margin-left:8px!important;height:20px!important;font-size:.5rem!important;font-weight:400!important;background-color:#0000000a!important;color:#00000061!important;border-radius:8px!important;letter-spacing:.25px!important}.comment-you-chip .MuiChip-label{padding:2px 8px!important}.comment-deleted{opacity:.6;background:#00000005}.comment-deleted .comment-content{font-style:italic;color:#00000080}.comment-loading{opacity:.7;pointer-events:none}@media (max-width: 768px){.comment-item{margin-left:0!important}.comment-item.depth-1,.comment-item.depth-2,.comment-item.depth-3,.comment-item.depth-4,.comment-item.depth-5{border-left-width:2px;padding-left:8px}.comment-item:before,.comment-item:after{display:none}.comment-actions{justify-content:flex-start}.vote-section{flex-shrink:0}.comment-content{font-size:.9rem}.comment-metadata{font-size:.7rem}@media (max-width: 480px){.comment-item.depth-1,.comment-item.depth-2,.comment-item.depth-3,.comment-item.depth-4,.comment-item.depth-5{padding-left:6px;border-left-width:2px}}}@keyframes commentAppear{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.comment-new{animation:commentAppear .3s ease-out}.comment-item:hover{background:#00000003;border-radius:8px;transition:background .2s ease-in-out}.comment-item:focus-within{outline:2px solid rgba(33,150,243,.2);outline-offset:2px;border-radius:8px}.lofi-chip{display:inline-flex;align-items:center;padding:2px 8px;border-radius:12px;font-size:.65rem;font-weight:400;letter-spacing:.3px;line-height:1.2;text-transform:lowercase;transition:all .2s ease-in-out;border:1px solid transparent;margin-left:6px;max-height:18px;white-space:nowrap}.lofi-chip--you{background:linear-gradient(135deg,#a8cbba40,#ccded259);color:#496452cc;border-color:#a8cbba4d}.lofi-chip--you:hover{background:linear-gradient(135deg,#a8cbba59,#ccded273);transform:translateY(-.5px);box-shadow:0 2px 4px #0000000d}.lofi-chip--edited{background:linear-gradient(135deg,#eecec040,#f5e1d759);color:#8b6656cc;border-color:#eecec04d;margin-left:8px}.lofi-chip--edited:hover{background:linear-gradient(135deg,#eecec059,#f5e1d773);transform:translateY(-.5px);box-shadow:0 2px 4px #0000000d}.comments-list{padding:0;margin:0}.comments-list .comment-item{position:relative}.comment-item.depth-0{border-left:3px solid transparent}.comment-item.depth-1{border-left:3px solid #e3f2fd}.comment-item.depth-2{border-left:3px solid #bbdefb}.comment-item.depth-3{border-left:3px solid #90caf9}.comment-item.depth-4{border-left:3px solid #64b5f6}.comment-item.depth-5{border-left:3px solid #42a5f5}@media (max-width: 768px){.comment-item{margin-left:0!important}.comment-item.depth-1,.comment-item.depth-2,.comment-item.depth-3,.comment-item.depth-4,.comment-item.depth-5{border-left-width:2px;padding-left:8px}}.comments-loading{display:flex;justify-content:center;align-items:center;min-height:100px}.comment-enter{opacity:0;transform:translateY(20px)}.comment-enter-active{opacity:1;transform:translateY(0);transition:opacity .3s,transform .3s}.comment-exit{opacity:1}.comment-exit-active{opacity:0;transition:opacity .3s}.vote-button:hover{transform:scale(1.1);transition:transform .1s ease-in-out}.comment-item:before{content:"";position:absolute;left:-12px;top:32px;width:8px;height:calc(100% - 32px);border-left:1px solid #e0e0e0;border-bottom:1px solid #e0e0e0;border-radius:0 0 0 8px;display:none}.comment-item.depth-1:before,.comment-item.depth-2:before,.comment-item.depth-3:before,.comment-item.depth-4:before,.comment-item.depth-5:before{display:block}@media (max-width: 768px){.comment-item:before{display:none}}.notes-section-header{display:flex;align-items:center;width:100%}.notes-section-title{display:flex;align-items:center;flex-grow:1}.notes-section-title-icon{margin-right:8px;vertical-align:middle}.notes-section-status-chips{display:flex;gap:4px;margin-right:12px}.notes-section-status-chip{font-size:.75rem}.notes-section-error-message{margin-bottom:16px}.notes-section-text-field{margin-bottom:8px}.notes-section-helper-text{display:flex;justify-content:space-between;align-items:center}.notes-section-loading{margin-bottom:16px}.kanji-entry-container{background:linear-gradient(135deg,#f8f6f0,#faf8f3);height:100vh;padding:2rem;margin:0;box-sizing:border-box;overflow-y:auto;scrollbar-width:thin;scrollbar-color:#7f8c8d #f1f1f1}.kanji-entry-container::-webkit-scrollbar{width:8px}.kanji-entry-container::-webkit-scrollbar-track{background:#faf8f080}.kanji-entry-container::-webkit-scrollbar-thumb{background-color:#b0a99b;border-radius:4px}.kanji-entry-container .MuiContainer-root{background:transparent;padding:0!important;max-width:1200px!important;margin:0 auto!important}.kanji-entry-container .MuiAccordion-root{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(184,169,145,.15);box-shadow:0 4px 20px #b8a9911a;border-radius:12px!important;margin-bottom:16px;transition:all .3s ease}.kanji-entry-container .MuiAccordion-root:hover{box-shadow:0 6px 25px #b8a99133;transform:translateY(-2px)}.kanji-entry-container .MuiAccordion-root:before{display:none}.kanji-entry-container .MuiAccordionSummary-root{background:linear-gradient(135deg,#d4c4a8,#c4b59e);color:#5a5448;border-radius:12px 12px 0 0;min-height:56px}.kanji-entry-container .MuiAccordionSummary-root:hover{background:linear-gradient(135deg,#c4b59e,#b8a991)}.kanji-entry-container .MuiAccordionSummary-content{margin:12px 0}.kanji-entry-container .MuiAccordionDetails-root{background:#faf8f5f2;padding:24px;border-radius:0 0 12px 12px}.kanji-entry-container .MuiCard-root{background:#ffffffe6;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);border:1px solid rgba(184,169,145,.15);border-radius:8px;transition:all .3s ease}.kanji-entry-container .MuiCard-root:hover{box-shadow:0 4px 15px #b8a99126;transform:translateY(-1px)}.kanji-entry-container .MuiCardContent-root{padding:16px!important}.kanji-entry-container .MuiChip-root{margin:2px;font-weight:500;border-radius:16px}.kanji-entry-container .MuiChip-colorPrimary{background:linear-gradient(45deg,#b8a991 30%,#a69885 90%);color:#5a5448}.kanji-entry-container .MuiChip-colorSecondary{background:linear-gradient(45deg,#a8c4a2 30%,#9bb896 90%);color:#4a5547}.kanji-entry-container .MuiChip-colorSuccess{background:linear-gradient(45deg,#9bb896 30%,#8aad85 90%);color:#4a5547}.kanji-entry-container .MuiChip-colorWarning{background:linear-gradient(45deg,#e6c29a 30%,#ddb88a 90%);color:#6b5d4f}.kanji-entry-container .MuiChip-colorError{background:linear-gradient(45deg,#d4a5a5 30%,#c99999 90%);color:#6b4f4f}.kanji-entry-container .MuiChip-colorInfo{background:linear-gradient(45deg,#a5b5c4 30%,#99a9b8 90%);color:#4f5a6b}.kanji-entry-container .MuiPaper-root.kanji-info-panel{background:linear-gradient(135deg,#d4c4a826,#c4b59e26);border:1px solid rgba(184,169,145,.2);border-radius:12px;padding:24px}.kanji-entry-container .MuiIconButton-root{transition:all .3s ease}.kanji-entry-container .MuiIconButton-root:hover{background:#b8a99126;transform:scale(1.1)}.kanji-entry-container .MuiTypography-h2{text-shadow:2px 2px 4px rgba(90,84,72,.15);color:#5a5448}.kanji-entry-container .MuiTypography-h4,.kanji-entry-container .MuiTypography-h6{color:#6b5d4f;font-weight:600}.kanji-entry-container .component-card{min-height:80px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f0ede8,#ebe7e1)}.kanji-entry-container .component-symbol{font-family:Noto Sans CJK JP,Hiragino Sans,Yu Gothic,serif;font-size:1.5rem;font-weight:700;color:#6b5d4f}.kanji-entry-container .reading-chip-on{background:linear-gradient(45deg,#b8a991 30%,#a69885 90%)!important;color:#5a5448!important;font-size:1.1rem!important;font-weight:700!important;font-family:Noto Sans CJK JP,Hiragino Sans,Yu Gothic,serif!important}.kanji-entry-container .reading-chip-kun{background:linear-gradient(45deg,#a8c4a2 30%,#9bb896 90%)!important;color:#4a5547!important;font-size:1.1rem!important;font-weight:700!important;font-family:Noto Sans CJK JP,Hiragino Sans,Yu Gothic,serif!important}.kanji-entry-container .meaning-chip{background:linear-gradient(45deg,#a5b5c4 30%,#99a9b8 90%)!important;color:#4f5a6b!important;font-size:1rem!important;font-weight:500!important}.kanji-entry-container .radical-character{font-family:Noto Sans CJK JP,Hiragino Sans,Yu Gothic,serif;font-size:2.5rem;font-weight:700;color:#6b5d4f}.kanji-entry-container .nanori-chip{font-family:Noto Sans CJK JP,Hiragino Sans,Yu Gothic,serif!important;font-weight:500!important}@media (max-width: 768px){.kanji-entry-container{padding:1rem}.kanji-entry-container .MuiTypography-h2{font-size:3rem}.kanji-entry-container .MuiAccordionDetails-root{padding:16px!important}.kanji-entry-container .MuiCardContent-root{padding:12px!important}.kanji-entry-container .MuiContainer-root{padding:0!important}}@media (max-width: 480px){.kanji-entry-container{padding:.5rem}.kanji-entry-container .MuiTypography-h2{font-size:2.5rem}.kanji-entry-container .MuiTypography-h4{font-size:1.5rem!important}.kanji-entry-container .MuiTypography-h6{font-size:1.1rem!important}.kanji-entry-container .MuiChip-root{font-size:.75rem;height:24px}}.kanji-entry-container .fade-in{animation:fadeInUp .6s ease-out}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.kanji-entry-container .MuiAccordionSummary-root:focus-visible{outline:2px solid #a69885;outline-offset:2px}.kanji-entry-container .MuiIconButton-root:focus-visible{outline:2px solid #a69885;outline-offset:2px}.user-profile-dropdown{position:relative;display:flex;align-items:center;height:100%}.profile-trigger{display:flex;align-items:center;cursor:pointer;padding:.5rem;border-radius:50%;background:#ffffff0d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);transition:all .3s ease}.profile-trigger:hover{background:#ffffff1a;border-color:#fff3}.profile-avatar-container{position:relative;display:flex;align-items:center;justify-content:center}.profile-avatar{width:2.5rem;height:2.5rem;border-radius:50%;object-fit:cover;border:2px solid rgba(255,255,255,.3);transition:all .3s ease;position:relative;z-index:2}.profile-background{position:absolute;top:-8px;left:-8px;right:-8px;bottom:-8px;z-index:1;pointer-events:none}.dropdown-menu{position:absolute;top:calc(100% + .5rem);right:0;background:#000000d9;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:1rem;box-shadow:0 10px 30px #0000004d;min-width:250px;z-index:1000;overflow:hidden}.dropdown-header{padding:1.25rem;background:#ffffff0d}.profile-section{margin-bottom:1rem}.profile-section:last-child{margin-bottom:0}.profile-section-header{font-size:.65rem;font-weight:400;color:#888;letter-spacing:.3px;margin:.25rem 0 .5rem}.centered-avatar-section{text-align:center}.dropdown-avatar{width:3rem;height:3rem;border-radius:50%;object-fit:cover;border:2px solid rgba(255,255,255,.2)}.dropdown-user-info{flex:1;min-width:0}.dropdown-name{font-size:1.1rem;font-weight:600;color:#fff;margin-bottom:.25rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dropdown-email{font-size:1rem;font-weight:500;color:#fff;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dropdown-divider{height:1px;background:#ffffff1a;margin:0}.dropdown-item{width:100%;display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem;background:transparent;border:none;color:#fff;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;text-align:left}.logout-button{color:#ff6b6b}.logout-button:hover{background:#ff6b6b1a!important}.logout-icon{width:1rem;height:1rem;stroke:currentColor}.display-name-view{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.display-name-text{color:#fff;font-size:1rem;font-weight:500;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.edit-button{background:none;border:none;cursor:pointer;padding:.25rem;font-size:.75rem;border-radius:.25rem;transition:background-color .2s;color:#a0a0a0}.edit-button:hover{background-color:#ffffff1a;color:#fff}.display-name-edit{display:flex;flex-direction:column;gap:.5rem}.display-name-error{color:#ff6b6b;font-size:.75rem;margin-top:.25rem;padding:.25rem 0;line-height:1.3}.display-name-input{width:100%;padding:.5rem;font-size:.875rem;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:.375rem;color:#fff;transition:border-color .2s}.display-name-input:focus{outline:none;border-color:#fff6;background:#ffffff26}.display-name-input::placeholder{color:#a0a0a0}.edit-buttons{display:flex;gap:.5rem;align-items:center;justify-content:flex-end}.save-button,.cancel-button{width:1.75rem;height:1.75rem;border:none;border-radius:.25rem;cursor:pointer;font-size:.75rem;display:flex;align-items:center;justify-content:center;transition:all .2s}.save-button{background-color:#28a745cc;color:#fff}.save-button:hover{background-color:#28a745;transform:scale(1.05)}.cancel-button{background-color:#dc3545cc;color:#fff}.cancel-button:hover{background-color:#dc3545;transform:scale(1.05)}.loading-spinner{width:1rem;height:1rem;border:1.5px solid rgba(255,255,255,.3);border-top:1.5px solid #ffffff;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width: 768px){.dropdown-menu{min-width:200px;right:-1rem}}.app__bar{display:flex;width:100%;height:100px;background-color:transparent;z-index:100;position:fixed;top:0;left:0;right:0;align-items:center;justify-content:center;-webkit-transform:translateZ(0);transform:translateZ(0);backface-visibility:hidden;-webkit-backface-visibility:hidden;pointer-events:auto;transition:background .3s ease}.app__bar[style*="pointer-events: none"]{pointer-events:none!important}.app__bar.about-background{background:linear-gradient(135deg,#667eea,#764ba2)}.app__bar.about-background .tab__group,.app__bar.about-background .mobile-tab-trigger{background:#ffffff26;border:1px solid rgba(255,255,255,.25);-webkit-backdrop-filter:blur(25px);backdrop-filter:blur(25px)}.app__bar.about-background .mobile-tab-trigger:hover{background:#fff3;border-color:#ffffff59}.app__bar.about-background .app__bar__logo{filter:brightness(1.1) contrast(1.1)}.app__bar__logo{position:absolute;left:1rem;height:70px;width:70px;transition:transform .2s ease;cursor:pointer!important;margin-left:1rem;margin-top:1rem}.app__bar__logo:hover{transform:scale(1.1)}.tab__group{position:relative;display:flex;justify-content:center;align-items:center;height:auto;font-size:1rem;font-weight:600;color:#a0a0a0;gap:.5rem;transition:width .3s ease;margin:1rem 1.5rem;background:#ffffff1a;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:25px;border:1px solid rgba(255,255,255,.2);box-shadow:0 8px 32px #0000001a}.tab__group__tab{position:relative;z-index:1;cursor:pointer!important;padding:.8rem 1.6rem;margin:.5rem;user-select:none;font-weight:700;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;white-space:nowrap;min-width:fit-content}.tab-button-content{display:flex;align-items:center;gap:.5rem;position:relative;z-index:2}.tab-icon{display:flex;align-items:center;transition:transform .2s ease}.tab-icon svg{color:inherit;transition:color .2s ease}.tab-label{font-weight:700;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.tab__group__tab *{cursor:pointer!important;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.tab__group__tab:hover:not(.selected){font-weight:900}.tab__group__tab:hover .tab-icon{transform:translateY(-1px)}.tab__group__tab.selected{color:#a0a0a0}.settings__group{position:absolute;right:0;height:100%;display:flex;justify-content:flex-end;align-items:center;padding-right:1rem}.settings__group__button{cursor:pointer!important;background-color:transparent;border:none;font-size:1rem;font-weight:600;margin-right:1rem}.mobile-tab-group{position:relative;margin:1rem 1.5rem;z-index:200}.mobile-tab-trigger{display:flex;align-items:center;justify-content:center;padding:.75rem 1.5rem;background:#ffffff1a;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:20px;border:1px solid rgba(255,255,255,.2);box-shadow:0 8px 32px #0000001a;cursor:pointer;-webkit-user-select:none;user-select:none;color:#a0a0a0;font-weight:600;min-width:150px;transition:all .2s ease}.mobile-tab-trigger:hover{background:#ffffff26;border-color:#ffffff4d}.mobile-tab-content{display:flex;align-items:center;gap:.75rem;width:100%;justify-content:space-between}.mobile-tab-icon{display:flex;align-items:center;flex-shrink:0}.mobile-tab-label{font-weight:700;font-size:1rem;flex:1;text-align:left}.mobile-tab-chevron{display:flex;align-items:center;flex-shrink:0;opacity:.7}.mobile-tab-dropdown{position:absolute;top:calc(100% + .5rem);left:0;right:0;background:#000000d9;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:16px;box-shadow:0 10px 30px #0000004d;overflow:hidden;z-index:1000}.mobile-tab-option{position:relative;display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem;color:#fff;cursor:pointer;transition:all .2s ease;-webkit-user-select:none;user-select:none;border-bottom:1px solid rgba(255,255,255,.05)}.mobile-tab-option:last-child{border-bottom:none}.mobile-tab-option:hover{background:#ffffff1a}.mobile-tab-option.selected{background:#ffffff0d;color:#fff}.mobile-tab-option-icon{display:flex;align-items:center;flex-shrink:0}.mobile-tab-option-label{font-weight:600;font-size:.95rem;flex:1}.mobile-tab-option-indicator{position:absolute;right:1rem;width:8px;height:8px;border-radius:50%;background:linear-gradient(135deg,#ff6b6b,#ffa726);box-shadow:0 2px 8px #ff6b6b4d}@keyframes review-bounce{0%,60%,to{transform:translateY(0)}10%,30%,50%{transform:translateY(-3px)}20%,40%{transform:translateY(0)}}.review-alert{color:orange;animation:review-bounce 5s infinite}@media (max-width: 768px){.app__bar__logo{height:60px;width:60px;margin-left:.5rem}.mobile-tab-group{margin:.8rem 1rem}.mobile-tab-trigger{padding:.65rem 1.25rem;border-radius:16px;min-width:130px}.mobile-tab-content{gap:.5rem}.mobile-tab-label{font-size:.9rem}.mobile-tab-dropdown{border-radius:12px}.mobile-tab-option{padding:.875rem 1rem;gap:.5rem}.mobile-tab-option-label{font-size:.875rem}}@media (max-width: 480px){.app__bar__logo{height:50px;width:50px;margin-left:.25rem}.mobile-tab-group{margin:.6rem .75rem}.mobile-tab-trigger{padding:.5rem 1rem;min-width:110px}.mobile-tab-label{font-size:.85rem}.mobile-tab-option{padding:.75rem .875rem}.mobile-tab-option-label{font-size:.8rem}}.background{position:fixed;top:0;left:0;width:100%;height:100%;z-index:-1;overflow:hidden}.background canvas{width:100%!important;height:100%!important;position:absolute!important;left:0!important;top:0!important}
