: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;border-inline:1px solid var(--border);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%}.top-nav{background:var(--bg-main);border-bottom:1px solid var(--bg-accent);z-index:100;justify-content:space-between;align-items:center;padding:.75rem 1.5rem;display:flex;position:sticky;top:0}.nav-brand{z-index:110;align-items:center;display:flex}.nav-title{color:var(--color-primary);letter-spacing:-.05em;margin:0;font-size:1.4rem;font-weight:900}.nav-actions{align-items:center;gap:1.5rem;display:flex}.nav-tools{align-items:center;gap:1rem;display:flex}.nav-tabs{background:var(--bg-accent);border-radius:12px;gap:5px;padding:4px;display:flex}.tab-btn{color:var(--text-muted);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:8px;padding:8px 16px;font-size:.75rem;font-weight:700;transition:all .2s}.tab-btn.active{background:var(--color-primary);color:var(--bg-main)}.nav-separator{background:#ffffff1a;width:1px;height:20px}.hamburger{cursor:pointer;z-index:110;background:0 0;border:none;flex-direction:column;justify-content:space-between;width:30px;height:20px;padding:0;display:none}.hamburger .bar{background-color:var(--color-primary);border-radius:10px;width:100%;height:3px;transition:all .3s}@media (width<=768px){.hamburger{display:flex}.hamburger.is-active .bar:first-child{transform:translateY(8.5px)rotate(45deg)}.hamburger.is-active .bar:nth-child(2){opacity:0}.hamburger.is-active .bar:nth-child(3){transform:translateY(-8.5px)rotate(-45deg)}.nav-actions{background:var(--bg-accent);z-index:100;flex-direction:column;justify-content:flex-start;width:80%;max-width:300px;height:100vh;padding:80px 2rem 2rem;transition:right .3s ease-in-out;position:fixed;top:0;right:-100%;box-shadow:-10px 0 30px #00000080}.nav-actions.mobile-open{right:0}.nav-tools{border-bottom:1px solid #ffffff0d;flex-direction:row;justify-content:space-between;width:100%;margin-bottom:2rem;padding-bottom:1rem}.nav-tabs{background:0 0;flex-direction:column;gap:1rem;width:100%;padding:0}.tab-btn{text-align:left;background:#ffffff08;width:100%;padding:15px;font-size:1rem}.nav-separator{display:none}}.lang-dropdown{width:auto;display:inline-block;position:relative}.lang-current-btn{background:var(--bg-accent);cursor:pointer;border:1px solid #ffffff0d;border-radius:10px;align-items:center;gap:8px;height:34px;padding:8px 12px;transition:all .2s;display:flex}.lang-current-btn:hover{border-color:var(--text-muted);background:#ffffff1a}.current-flag{object-fit:cover;border-radius:2px;width:20px;height:14px;display:block}.arrow{color:var(--text-muted);font-size:.6rem}.lang-menu{border:1px solid var(--bg-accent);z-index:1000;background:#2d3436;border-radius:10px;min-width:90px;padding:4px;list-style:none;position:absolute;top:calc(100% + 8px);right:0;box-shadow:0 10px 25px #00000080}.lang-menu li{cursor:pointer;color:var(--text-muted);border-radius:6px;align-items:center;gap:10px;padding:8px 12px;font-size:.75rem;font-weight:700;display:flex}.lang-menu li:hover{color:#fff;background:#ffffff0d}.lang-menu li.active{color:var(--color-primary);background:#2ecc711a}.flag-icon{object-fit:cover;border-radius:1px;width:18px;height:12px}.lang-overlay{z-index:999;background:0 0;position:fixed;inset:0}.game-container{flex-direction:column;align-items:center;gap:1rem;width:100%;max-width:600px;min-height:80vh;margin:0 auto;padding:16px;display:flex}.stats-display{background:var(--bg-accent);border-radius:50px;justify-content:space-around;width:100%;max-width:400px;margin-bottom:.5rem;padding:10px 20px;font-size:.85rem;font-weight:700;display:flex;box-shadow:0 4px 15px #0003}.stat-correct{color:var(--color-primary)}.stat-wrong{color:var(--color-danger)}.card{background:var(--bg-accent);aspect-ratio:4/3;border:1px solid #ffffff0d;border-radius:24px;flex-direction:column;justify-content:center;align-items:center;width:100%;min-height:220px;padding:24px;display:flex;position:relative;box-shadow:0 8px 30px #0000004d}.writing-display{color:#fff;text-align:center;word-break:break-all;margin:10px 0;font-size:clamp(2.5rem,12vw,4.5rem);font-weight:500;line-height:1.1}.kanji-clickable{cursor:pointer;text-align:center;border-radius:8px;min-width:44px;padding:0 4px;transition:background .2s;display:inline-block}.kanji-clickable:active{color:var(--color-primary);background:#2ecc7133}.meaning-text{color:var(--text-muted);text-transform:capitalize;margin-bottom:8px;font-size:1.1rem;font-weight:600}.input-section{flex-direction:column;gap:1.5rem;width:100%;margin-top:auto;display:flex}.input-section input{background:var(--bg-main);border:3px solid var(--bg-accent);color:#fff;text-align:center;border-radius:16px;outline:none;width:100%;padding:16px;font-size:1.5rem;transition:border-color .2s}.input-section input:focus{border-color:var(--color-primary)}.hints-container{grid-template-columns:repeat(3,1fr);gap:8px;width:100%;display:grid}.hint-btn{background:var(--bg-accent);color:#fff;text-transform:uppercase;cursor:pointer;transition:transform .1s active;border:none;border-radius:12px;justify-content:center;align-items:center;padding:12px 4px;font-size:.75rem;font-weight:800;display:flex}.hint-btn:active{background:#333;transform:scale(.95)}.audio-hint-btn{color:var(--color-primary);background:#2ecc7126;grid-column:span 1}.hint-btn:last-child{color:var(--text-muted);background:#ffffff0d}.empty-state-wrapper{justify-content:center;height:70vh}.empty-card{opacity:.7;border:2px dashed var(--bg-accent)!important;background:0 0!important}@media (width>=600px){.hints-container{grid-template-columns:repeat(auto-fit,minmax(100px,1fr))}.card{aspect-ratio:auto;padding:60px}}@media (height<=500px){.game-container{gap:.5rem;padding:5px}.card{aspect-ratio:auto;min-height:120px;padding:10px}.writing-display{font-size:2rem}.input-section{gap:.5rem}}.kanji-detail{color:#eee;flex-direction:column;gap:1.2rem;width:100%;display:flex}.kanji-main-section{background:linear-gradient(#ffffff08,#0000);border-radius:12px;justify-content:center;align-items:center;padding:1rem 0;display:flex}.kanji-character{color:#fff;text-shadow:0 0 20px #2ecc714d;margin:0;font-size:clamp(4.5rem,20vw,6.5rem);line-height:1}.info-block{flex-direction:column;gap:.6rem;display:flex}.info-block label{color:#3498db;text-transform:uppercase;letter-spacing:1.5px;border-bottom:1px solid #333;padding-bottom:4px;font-size:.7rem;font-weight:800}.list-rows{flex-wrap:wrap;gap:.5rem;padding:.2rem 0;display:flex}.row-item,.reading-row{background:#ffffff0d;border:1px solid #ffffff1a;border-radius:6px;padding:4px 10px;font-size:1rem}.reading-row{color:#2ecc71;font-weight:500}.readings-container{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.kanji-extras{background:#252525;border:1px solid #333;border-radius:12px;grid-template-columns:repeat(2,1fr);gap:.8rem;margin-top:.5rem;padding:12px;display:grid}.extra-item{color:#bbb;font-size:.8rem}.extra-item strong{color:#888;text-transform:uppercase;font-size:.65rem;display:block}.extra-item.heisig{color:#f1c40f;border-top:1px solid #333;grid-column:span 2;padding-top:.5rem}.modal-content{background-color:#1a1a1a!important;border:1px solid #444!important;border-radius:24px!important;padding:2.5rem 1.5rem 1.5rem!important}@media (width<=380px){.readings-container{grid-template-columns:1fr}.kanji-character{font-size:4rem}}.modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:9999;background-color:#000c;justify-content:center;align-items:center;width:100vw;height:100vh;padding:15px;display:flex;position:fixed;top:0;left:0}.modal-content{background-color:#1a1a1a;border:1px solid #333;border-radius:24px;flex-direction:column;width:100%;max-width:420px;max-height:85vh;animation:.25s cubic-bezier(.175,.885,.32,1.275) modalPop;display:flex;position:relative;overflow:hidden;box-shadow:0 20px 50px #0009}.kanji-detail-wrapper{padding:2rem 1.5rem 1.5rem;overflow-y:auto}.kanji-detail-wrapper::-webkit-scrollbar{width:5px}.kanji-detail-wrapper::-webkit-scrollbar-thumb{background:#444;border-radius:10px}.close-btn{color:#fff;cursor:pointer;z-index:100;background:#333;border:none;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:1.4rem;transition:all .2s;display:flex;position:absolute;top:12px;right:12px}.close-btn:hover{background:#f44;transform:scale(1.1)}.loading,.error{text-align:center;color:#888;padding:3rem;font-style:italic}@keyframes modalPop{0%{opacity:0;transform:scale(.9)translateY(20px)}to{opacity:1;transform:scale(1)translateY(0)}}@media (height<=600px){.modal-content{max-height:95vh}.kanji-detail-wrapper{padding-top:1.5rem}}.selection-container{flex-direction:column;gap:1rem;width:100%;padding-bottom:3rem;animation:.3s ease-out fadeIn;display:flex}.vocab-group-wrapper{border:1px solid var(--bg-accent);background:#ffffff05;border-radius:16px;transition:all .2s;overflow:hidden}.vocab-group-wrapper.is-expanded{background:#ffffff0a;border-color:#2ecc714d}.section-header{cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;padding:1.25rem;display:flex}.header-info{align-items:center;gap:12px;display:flex}.arrow-icon{color:var(--text-muted);font-size:.7rem;transition:transform .2s}.arrow-icon.down{color:var(--color-primary);transform:rotate(90deg)}.subgroup-label{color:#fff;text-transform:uppercase;letter-spacing:.05em;margin:0;font-size:.9rem;font-weight:800}.selection-count{color:var(--text-muted);font-size:.8rem;font-weight:600}.select-all-btn{background:var(--bg-accent);border:1px solid var(--text-muted);color:#fff;cursor:pointer;text-transform:uppercase;border-radius:8px;padding:6px 12px;font-size:.7rem;font-weight:700;transition:all .2s}.select-all-btn.all-active{border-color:var(--color-danger);color:var(--color-danger);background:#ff47571a}.options-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px;padding:0 1.25rem 1.25rem;animation:.2s ease-out slideDown;display:grid}.option-label{border:2px solid var(--bg-accent);cursor:pointer;background:var(--bg-main);min-height:54px;transition:transform .1s active;border-radius:12px;align-items:center;padding:12px 16px;display:flex}.option-label:active{transform:scale(.98)}.checkbox-custom{border:2px solid var(--text-muted);border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;margin-right:12px;display:flex}.active .checkbox-custom{background:var(--color-primary);border-color:var(--color-primary)}.checkmark{color:var(--bg-main);font-size:.8rem;font-weight:900}.option-text{color:#f1f5f9;font-size:.9rem;font-weight:600;line-height:1.2}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@media (width<=600px){.section-header{flex-direction:column;align-items:flex-start;gap:12px}.header-info{width:100%}.select-all-btn{text-align:center;width:100%;padding:10px}.options-grid{grid-template-columns:1fr}}.config-container{flex-direction:column;gap:2rem;width:100%;animation:.3s ease-out fadeIn;display:flex}.menu-section{flex-direction:column;gap:1rem;display:flex}.section-title{color:var(--color-primary);text-transform:uppercase;letter-spacing:.1em;border-bottom:1px solid var(--bg-accent);margin-bottom:.5rem;padding-bottom:8px;font-size:.8rem;font-weight:800}.settings-stack{flex-direction:column;gap:12px;display:flex}.setting-group{background:#ffffff05;border-radius:12px;flex-direction:column;gap:8px;display:flex}.select-container{width:100%}.config-select{background:var(--bg-accent);color:#fff;cursor:pointer;appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");background-position:right 1rem center;background-repeat:no-repeat;background-size:1em;border:2px solid #0000;border-radius:10px;outline:none;width:100%;padding:12px;font-size:.9rem;font-weight:600}.config-select:focus{border-color:var(--color-primary)}.sub-options-grid{grid-template-columns:1fr 1fr;gap:10px;display:grid}.options-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:10px;display:grid}.option-label{border:2px solid var(--bg-accent);cursor:pointer;-webkit-user-select:none;user-select:none;background:#ffffff08;border-radius:10px;align-items:center;padding:14px;transition:all .2s;display:flex}.hint-toggle{background:0 0;border-style:dashed;margin-left:1.5rem;padding:10px 14px;font-size:.85rem}@media (width<=600px){.sub-options-grid{grid-template-columns:1fr}.hint-toggle{margin-left:1rem}.options-grid{grid-template-columns:1fr}}.settings-disabled{opacity:.6;pointer-events:none}.nihongo-container{max-width:1000px;margin:0 auto;padding:10px;animation:.4s ease-out fadeIn}.nihongo-nav{background:var(--bg-accent);border-radius:12px;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:2rem;padding:4px;display:grid}.nav-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:8px;padding:12px;font-size:.9rem;font-weight:700;transition:all .2s}.nav-btn.active{background:var(--bg-main);color:var(--color-primary);box-shadow:0 4px 12px #0003}.group-section{margin-bottom:3rem}.group-title{color:var(--color-primary);text-transform:uppercase;letter-spacing:.15em;opacity:.8;margin-bottom:1.5rem;font-size:.75rem;font-weight:800}.grid-system{flex-wrap:wrap;justify-content:flex-start;gap:12px;display:flex}.column-block{flex-direction:column;flex:0 auto;gap:8px;display:flex}.column-label{text-align:center;color:var(--text-muted);text-transform:uppercase;font-size:.6rem;font-weight:900}.chars-container{flex-direction:column;gap:6px;display:flex}.char-card{background:var(--bg-accent);border:1px solid #ffffff0d;border-radius:10px;flex-direction:column;justify-content:center;align-items:center;width:58px;height:68px;transition:all .2s;display:flex}.char-card:active{border-color:var(--color-primary);transform:scale(.9)}.jp-text{color:#fff;font-size:1.6rem;font-weight:500}.romaji-text{color:var(--text-muted);margin-top:-2px;font-size:.7rem;font-weight:700}@media (width<=480px){.grid-system{gap:8px}.char-card{border-radius:8px;width:50px;height:60px}.jp-text{font-size:1.3rem}}.challenge-wrapper{flex-direction:column;gap:1rem;width:100%;max-width:600px;margin:0 auto;padding:10px;display:flex}.challenge-header{text-align:center;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:12px;padding:1.5rem}.challenge-level-title{color:#00d4ff;text-transform:uppercase;letter-spacing:2px;margin:0 0 1rem;font-size:1.8rem}.challenge-status-row{border-top:1px solid #ffffff1a;justify-content:space-around;align-items:center;padding-top:1rem;display:flex}.status-item{flex-direction:column;gap:.2rem;display:flex}.status-item .label{color:#888;font-size:.7rem;font-weight:700}.status-item .value{font-family:Courier New,Courier,monospace;font-size:1.1rem}.danger-pulse{color:#ff4d4d;animation:1.5s infinite pulse}@keyframes pulse{0%{opacity:1}50%{opacity:.5}to{opacity:1}}.challenge-failed{text-align:center;background:#1a1a1a;border:2px solid #ff4d4d;border-radius:20px;margin-top:2rem;padding:3rem}.challenge-failed h2{color:#ff4d4d;margin-bottom:1rem;font-size:2.5rem}:root{--bg-main:#1a1a1a;--bg-accent:#2d3436;--color-primary:#2ecc71;--color-danger:#ff4757;--text-muted:#636e72;--max-width:1200px}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-main);-webkit-font-smoothing:antialiased;height:100%;margin:0;padding:0;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif}.nachigo-container{background-color:var(--bg-main);color:#fff;flex-direction:column;min-height:100vh;display:flex}.main-content{width:100%;max-width:var(--max-width);flex-direction:column;flex:1;justify-content:flex-start;align-items:center;margin:0 auto;padding:2rem 1rem;display:flex;position:relative}@media (width<=768px){.main-content{padding:1rem .75rem}.options-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:8px}.subgroup-label{margin-bottom:.75rem;font-size:.7rem}}.main-content>div{width:100%;animation:.3s ease-out fadeIn}@keyframes fadeIn{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}.selection-container,.config-container{flex-direction:column;gap:1.5rem;width:100%;display:flex}.option-label{border:2px solid var(--bg-accent);cursor:pointer;background:#ffffff05;border-radius:10px;align-items:center;min-height:48px;padding:12px;transition:all .2s;display:flex}.option-label.active{border-color:var(--color-primary);background:#2ecc711a}.option-text{color:#e2e8f0;font-size:.9rem;font-weight:500}@media (width>=1024px){::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--bg-main)}::-webkit-scrollbar-thumb{background:var(--bg-accent);border-radius:10px}}.hidden-input{display:none!important}
