.skip-to-content{z-index:10000;background:var(--ui-accent,#fabea0);color:var(--ui-text-strong,#1f2937);border-radius:0 0 8px;padding:.75rem 1.5rem;font-weight:600;text-decoration:none;position:absolute;top:0;left:-9999px}.skip-to-content:focus{left:0}:root{--bg-color:#fff;--text-color:#000;--link-hover-color:#000;--keyword-bg:#ff06;--keyword-bg-hover:#ff0c;--text-muted:#888;--select-arrow:"%23000000";--error-color:#c00;--skeleton-bg:#e0e0e0;--ui-surface:#faf9f7;--ui-surface-elevated:#fff;--ui-border:#e5e7eb;--ui-border-soft:#f3f4f6;--ui-accent:#fabea0;--ui-accent-hover:#e5ab8e;--ui-accent-soft:#f9ece0;--ui-text-strong:#1f2937;--ui-text:#374151;--ui-text-muted:#6b7280;--ui-text-subtle:#9ca3af;--color-success:#10b981;--color-success-hover:#059669;--color-error-text:#ef4444;--color-error-hover:#dc2626;--color-warning:#f59e0b;--color-warning-hover:#d97706;--color-primary:#3b82f6;--color-primary-hover:#2563eb;--text-color-hover:#000;--font-mono:"IBM Plex Mono", monospace}html.dark-theme{--bg-color:#121212;--text-color:#e0e0e0;--link-hover-color:#e0e0e0;--keyword-bg:#ff03;--keyword-bg-hover:#ff06;--text-muted:#aaa;--select-arrow:"%23e0e0e0";--error-color:#ff6b6b;--skeleton-bg:#333;--ui-surface:#1f1f1f;--ui-surface-elevated:#262626;--ui-border:#3a3a3a;--ui-border-soft:#2e2e2e;--ui-accent:#d89b7f;--ui-accent-hover:#e5ab8e;--ui-accent-soft:#2e211b;--ui-text-strong:#f3f4f6;--ui-text:#e5e7eb;--ui-text-muted:#9ca3af;--ui-text-subtle:#6b7280;--color-success:#10b981;--color-success-hover:#059669;--color-error-text:#ff6b6b;--color-error-hover:#fa5252;--color-warning:#f59e0b;--color-warning-hover:#d97706;--color-primary:#3b82f6;--color-primary-hover:#2563eb;--text-color-hover:silver}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.95)translateY(8px)}to{opacity:1;transform:scale(1)translateY(0)}}.blinking-cursor{animation:1s step-end infinite blink}.animate-spin{animation:1s linear infinite spin}.animate-pulse{animation:2s cubic-bezier(.4,0,.6,1) infinite pulse}.btn-primary:active:not(:disabled),.btn-secondary:active:not(:disabled),.btn-danger:active:not(:disabled),.btn-danger-outline:active:not(:disabled),.btn-hover-highlight:active:not(:disabled),.btn-continue:active:not(:disabled),.course-icon-button:active:not(:disabled),.interactive-word:active,.sentence-action-btn:active:not(:disabled),.close-icon:active,.language-chip:active,.sidebar-lang-chip:active,.lang-controls-add-btn:active,.lang-controls-chip-remove-btn:active{transition:transform 50ms;transform:scale(.96)}body{background-color:var(--bg-color);color:var(--text-color);margin:0;padding:0;font-family:Elms Sans,Kosugi,sans-serif;font-size:1rem;overflow-x:hidden}html,body,#root{min-height:100%}body.modal-open,body.modal-open .app-container>.main-content,body.modal-open main,body.modal-open .course-main-panel{overflow:hidden!important}@media (width<=600px){body.modal-open .app-container{width:100%;position:fixed;overflow:hidden!important}}html,*{scrollbar-width:thin;scrollbar-color:var(--text-muted) transparent}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background-color:var(--text-muted);background-clip:content-box;border:2px solid #0000;border-radius:999px}::-webkit-scrollbar-thumb:hover{background-color:var(--text-color)}input,select,textarea,button{font-family:inherit}input[type=checkbox]{appearance:none;background-color:var(--bg-color);border:1.5px solid var(--text-color);cursor:pointer;vertical-align:middle;border-radius:4px;flex-shrink:0;place-content:center;width:1.15rem;height:1.15rem;margin:0;transition:all .2s cubic-bezier(.4,0,.2,1);display:inline-grid;position:relative}input[type=checkbox]:checked{background-color:var(--text-color)}input[type=checkbox]:before{content:"";background-color:var(--bg-color);clip-path:polygon(14% 44%,0 65%,50% 100%,100% 16%,80% 0%,43% 62%);width:.65rem;height:.65rem;transition:transform .12s cubic-bezier(.4,0,.2,1);transform:scale(0)}input[type=checkbox]:checked:before{transform:scale(1)}input[type=checkbox]:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}input[type=checkbox]:disabled{opacity:.5;cursor:not-allowed}#root{width:100%;height:100%;margin:auto}h1,h2,h3,h4,h5,h6{margin:0;font-weight:400}h3,h4,h5,h6{font-size:1rem}h1.main-heading{color:var(--text-color);font-size:1.85em;line-height:1.5}button{font:inherit;color:inherit;cursor:pointer;background:0 0;border:none;padding:0}.progress-track{background:var(--skeleton-bg);border-radius:999px;width:100%;overflow:hidden}.progress-fill{border-radius:999px;height:100%;transition:width .3s}.error-banner{text-align:left;color:var(--color-error-text);background-color:#ef44441a;border:1px solid #ef444433;border-radius:8px;flex-direction:column;gap:.5rem;padding:.75rem 1rem;font-size:.85em;display:flex}.app-container{box-sizing:border-box;flex-direction:column;width:100%;max-width:1550px;height:100dvh;min-height:0;margin:0 auto;padding:0 1rem;display:flex;overflow:hidden}main{flex:1;align-items:flex-start;min-height:0;display:flex;overflow-y:auto}.main-content{box-sizing:border-box;flex-grow:1;width:100%;min-width:0;padding-bottom:1rem}.course-overview{flex-shrink:0;width:20rem;max-height:100%;padding-right:.5rem;overflow-y:auto}.interactive-word{color:var(--text-color);text-decoration:none;transition:color .2s ease-in-out,background-color .2s ease-in-out}.interactive-word:hover{color:var(--link-hover-color)}.sidebar-lang-chip-row{flex-wrap:wrap;gap:.4rem;display:flex}.language-chip,.sidebar-lang-chip{cursor:pointer;border-radius:6px;justify-content:flex-start;align-items:center;padding:2px 8px;font-size:.85em;transition:all .2s;display:inline-flex}.sidebar-lang-chip-active,.language-chip.current{background-color:var(--keyword-bg)!important;border:1px solid var(--text-color)!important;color:var(--text-color)!important}.sidebar-lang-chip-inactive{border:1px solid var(--skeleton-bg);color:var(--text-muted);background-color:#0000}.btn-hover-highlight{transition:background-color .2s}.btn-hover-highlight:hover{background-color:var(--keyword-bg)!important}.btn-continue{transition:background-color .2s}.btn-continue:hover{background-color:var(--keyword-bg-hover)!important}.btn-hover-highlight:disabled:hover,.btn-continue:disabled:hover{background-color:#0000!important}.highlighted-keyword{background-color:var(--keyword-bg);border-radius:2px;padding:0 2px;font-weight:700}.highlighted-keyword:hover{background-color:var(--keyword-bg-hover)}.read-along-block{border-radius:6px;flex-direction:column;gap:.25rem;margin:-2px -4px;padding:2px 4px;transition:background-color .3s;display:flex}.read-along-active{background-color:#3b82f614;transition:background-color .3s}h3.read-along-active{border-radius:4px;margin-left:-4px;margin-right:-4px;padding:2px 4px}.settings-input{width:100%;font:inherit;color:var(--text-color);border:1px solid var(--skeleton-bg);box-sizing:border-box;background-color:#0000;border-radius:8px;outline:none;padding:.6rem .9rem;transition:border-color .2s;display:block}.settings-input:focus{border-color:var(--text-color)}.settings-input::placeholder{color:var(--text-muted);opacity:.7}.settings-select{font:inherit;color:var(--text-color);border:1px solid var(--skeleton-bg);box-sizing:border-box;cursor:pointer;appearance:none;background-color:#0000;background-image:url(data:image/svg+xml;charset=US-ASCII,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%22292.4%22%20height%3D%22292.4%22%3E%3Cpath%20fill%3D%22%23000000%22%20d%3D%22M287%2069.4a17.6%2017.6%200%200%200-13-5.4H18.4c-5%200-9.3%201.8-12.9%205.4A17.6%2017.6%200%200%200%200%2082.2c0%205%201.8%209.3%205.4%2012.9l128%20127.9c3.6%203.6%207.8%205.4%2012.8%205.4s9.2-1.8%2012.8-5.4L287%2095c3.5-3.5%205.4-7.8%205.4-12.8%200-5-1.9-9.2-5.5-12.8z%22%2F%3E%3C%2Fsvg%3E);background-position:right .8rem center;background-repeat:no-repeat;background-size:.65em;border-radius:8px;outline:none;flex:1;padding:.6rem 2rem .6rem .9rem;transition:border-color .2s}.settings-select:focus{border-color:var(--text-color)}.skeleton-bar{background-color:var(--skeleton-bg);height:1rem;margin-bottom:.75rem}html.dark-theme .settings-select{background-image:url(data:image/svg+xml;charset=US-ASCII,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%22292.4%22%20height%3D%22292.4%22%3E%3Cpath%20fill%3D%22%23e0e0e0%22%20d%3D%22M287%2069.4a17.6%2017.6%200%200%200-13-5.4H18.4c-5%200-9.3%201.8-12.9%205.4A17.6%2017.6%200%200%200%200%2082.2c0%205%201.8%209.3%205.4%2012.9l128%20127.9c3.6%203.6%207.8%205.4%2012.8%205.4s9.2-1.8%2012.8-5.4L287%2095c3.5-3.5%205.4-7.8%205.4-12.8%200-5-1.9-9.2-5.5-12.8z%22%2F%3E%3C%2Fsvg%3E)}html.dark-theme .settings-select option{color:#e0e0e0;background-color:#2a2a2a}.btn-primary{background-color:var(--text-color);color:var(--bg-color);cursor:pointer;border:none;border-radius:10px;justify-content:center;align-items:center;gap:.4rem;padding:.7rem 1.5rem;text-decoration:none;display:inline-flex}.btn-primary:disabled{cursor:not-allowed;opacity:.7}.big-yellow-button{background-color:var(--keyword-bg);letter-spacing:.05em;text-transform:uppercase;cursor:pointer;color:inherit;z-index:9999;border:none;border-radius:8px;justify-content:center;align-items:center;gap:.5rem;padding:.7rem 1rem;font-size:.9em;transition:all .2s;display:inline-flex}.big-yellow-button:hover:not(:disabled){background-color:var(--keyword-bg-hover)}.big-yellow-button:disabled{cursor:default;opacity:.5}.btn-secondary{border:1px solid var(--skeleton-bg);color:var(--text-color);cursor:pointer;background-color:#0000;border-radius:10px;justify-content:center;align-items:center;gap:.4rem;padding:.7rem 1.5rem;text-decoration:none;display:inline-flex}.btn-danger{background-color:var(--color-error-text);color:#fff;cursor:pointer;border:none;border-radius:10px;justify-content:center;align-items:center;gap:.4rem;padding:.7rem 1.5rem;display:inline-flex}.btn-danger:disabled{cursor:not-allowed;opacity:.7}.btn-danger-outline{color:var(--color-error-text);cursor:pointer;background-color:#ef44441a;border:1px solid #ef44444d;border-radius:10px;justify-content:center;align-items:center;gap:.4rem;padding:.7rem 1.5rem;display:inline-flex}.btn-danger-outline:disabled{cursor:not-allowed;opacity:.7}.close-icon{background-color:var(--ui-surface);border:1px solid var(--ui-border);width:2.75rem;height:2.75rem;color:var(--ui-text-strong);z-index:10;cursor:pointer;border-radius:999px;justify-content:center;align-items:center;transition:all .25s cubic-bezier(.4,0,.2,1);display:flex;position:absolute;top:1rem;right:1rem}.close-icon:hover{background-color:var(--ui-border-soft);border-color:var(--ui-text-subtle)}.loading-container{justify-content:center;align-items:center;width:100%;min-height:400px;display:flex}.loading-text{color:var(--text-muted);font-size:1.2rem}.empty-state{color:var(--text-muted);padding:3rem 0}.action-row{flex-wrap:wrap;gap:.75rem;display:flex}.page-header{flex-direction:column;flex-shrink:0;width:100%;margin-bottom:1.25rem;line-height:1.5;display:flex}.page-header.page-header-with-actions{flex-flow:wrap;justify-content:space-between;align-items:center;gap:1rem}.language-pill{background-color:var(--ui-surface);border:1px solid var(--ui-accent-soft);cursor:pointer;border-radius:999px;justify-content:center;align-items:center;gap:.75rem;min-width:0;padding:.75rem 1.25rem;text-decoration:none;transition:all .2s;display:flex}.language-pill:hover{background-color:var(--ui-surface-elevated);border-color:var(--ui-accent);transform:translateY(-2px);box-shadow:0 4px 6px -1px #fabea033}.language-pill.small{cursor:default;gap:.4rem;padding:0 .6rem}.language-pill.small:hover{background-color:var(--ui-surface);border-color:var(--ui-accent-soft);box-shadow:none;transform:none}.language-flag{justify-content:center;align-items:center;font-size:1.4rem;display:flex;transform:translateY(-.12em)}.language-pill.small .language-flag{font-size:1.1rem;transform:translateY(-.09em)}.language-name{color:var(--ui-text);white-space:nowrap;text-overflow:ellipsis;font-weight:500;overflow:hidden}.language-pill.small .language-name{font-size:.75rem}.footer-text{color:var(--text-muted);font-size:.9em}.footer-text a{color:inherit;text-decoration:none;transition:color .2s ease-in-out}.footer-text a:hover{color:var(--link-hover-color);text-decoration:underline}.sticky-footer{text-align:center;background-color:var(--bg-color);border-top:1px solid var(--skeleton-bg);flex-shrink:0;margin-top:auto;padding:1.5rem 0}@media (width<=600px){.sticky-footer{border-top:none}}.ascii-art{text-align:left;white-space:pre;color:var(--text-muted);margin:2rem 0;font-family:monospace;font-size:.8em;line-height:1.1}@media (width<=600px){.header{display:none}h1.main-heading{font-size:1.5em;line-height:1.2}main{flex-direction:column;align-items:stretch}.course-overview{border:none;width:100%;max-height:none;margin:0;padding-right:0;display:none;position:static}.show-sidebar-mobile .course-overview{display:block}.show-sidebar-mobile .main-content{display:none}.main-content{max-width:none;padding-bottom:1.25rem}.app-container{height:auto;min-height:100%;padding:.5rem;overflow:visible;padding-bottom:calc(50px + env(safe-area-inset-bottom))!important}.settings-select{padding:.5rem 2rem .5rem .75rem}main{height:auto!important;overflow:visible!important}}.course-layout{overflow:hidden}.course-overview{min-height:0;max-height:100%;overflow-y:auto}.course-main-panel{height:100%;min-height:0;overflow-y:auto}@media (width<=600px){.course-layout{height:auto!important;overflow:visible!important}.course-overview{min-height:auto;max-height:none;overflow-y:visible!important}.course-main-panel{min-height:auto;height:auto!important;overflow-y:visible!important}}.context-menu{flex-shrink:0;position:relative}.context-menu-trigger{border:1px solid var(--skeleton-bg);background:var(--bg-color);height:100%;color:var(--text-muted);cursor:pointer;border-radius:8px;justify-content:center;align-items:center;padding:.5rem;transition:background-color .15s,color .15s,border-color .15s;display:flex}.context-menu-trigger:hover{background-color:var(--skeleton-bg);color:var(--text-color);border-color:var(--text-muted)}.context-menu-dropdown{border:1px solid var(--skeleton-bg);background-color:var(--bg-color);z-index:30;border-radius:8px;flex-direction:column;min-width:220px;display:flex;position:absolute;top:calc(100% + .35rem);right:0;overflow:hidden;box-shadow:0 4px 12px #00000029}.context-menu-dropdown button{width:100%;color:var(--text-color);font:inherit;text-align:left;cursor:pointer;background:0 0;border:none;align-items:center;gap:.65rem;padding:.75rem .9rem;transition:background-color .15s,color .15s;display:flex}.context-menu-dropdown button:hover:not(:disabled){background-color:var(--skeleton-bg)}.context-menu-dropdown button:disabled{cursor:default;opacity:.45}.context-menu-danger:not(:disabled){color:var(--color-error-text)}.lang-controls-chip-row{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.lang-controls-chip{background-color:var(--skeleton-bg);color:var(--text-color);border-radius:999px;align-items:center;gap:.3rem;padding:.35rem .8rem;font-size:.9em;display:inline-flex}.lang-controls-chip-remove-btn{cursor:pointer;color:var(--text-muted);background:0 0;border:none;align-items:center;padding:0 0 0 .2rem;display:inline-flex}.lang-controls-dropdown-wrapper{position:relative}.lang-controls-add-btn{border:1px dashed var(--text-muted);color:var(--text-muted);cursor:pointer;background-color:#0000;border-radius:999px;align-items:center;gap:.3rem;padding:.35rem .8rem;font-size:.9em;display:inline-flex}.lang-controls-dropdown{z-index:1000;background-color:var(--bg-color);border:1px solid var(--skeleton-bg);border-radius:8px;width:180px;max-height:200px;margin-top:.25rem;position:absolute;top:100%;left:0;overflow-y:auto;box-shadow:0 4px 12px #00000026}.lang-controls-dropdown-item{cursor:pointer;color:var(--text-color);padding:.5rem .75rem;font-size:.9em}.lang-controls-dropdown-item:hover{background-color:var(--skeleton-bg)}.loading-skeleton-page{background-color:var(--bg-color);justify-content:center;align-items:center;width:100%;min-height:100vh;display:flex}.loading-skeleton-icon{opacity:.7;width:64px;height:64px;animation:1.4s ease-in-out infinite loading-skeleton-pulse}@keyframes loading-skeleton-pulse{0%,to{opacity:.4;transform:scale(.96)}50%{opacity:1;transform:scale(1)}}.header{background-color:var(--bg-color);border-bottom:1px solid var(--skeleton-bg);z-index:1100;flex-shrink:0;align-items:center;gap:1.5rem;margin-bottom:1.25rem;padding:1rem 0;display:flex;position:sticky;top:0}.title-container{flex:1;align-items:center;gap:1.5rem;display:flex}.main-title{letter-spacing:.1em;text-transform:uppercase;white-space:nowrap;color:var(--text-color);cursor:pointer;background:0 0;border:none;align-items:center;gap:.5rem;padding:0;font-size:1.2rem;text-decoration:none;display:flex}.main-title img{width:24px;height:24px;display:block}.main-title-btn{background:var(--keyword-bg);border:1px solid var(--skeleton-bg);border-radius:16px;padding:6px 12px;font-size:.8em;font-weight:700}.mobile-toggle-btn{text-transform:uppercase;letter-spacing:.05em;cursor:pointer;color:var(--text-color);align-items:center;gap:8px;display:none}.controls-label{color:var(--text-muted);margin-left:auto;font-size:.9em}.header-nav{align-items:center;gap:1rem;margin-left:auto;display:flex}.header-nav-btn,.btn-primary{color:var(--text-color);cursor:pointer;background:0 0;border:none;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;gap:.5rem;padding:.5rem 1rem;text-decoration:none;transition:background-color .2s;display:flex}.header-nav-btn.active{background-color:var(--keyword-bg)}@media (width<=600px){.header{display:none}.header-nav{display:none!important}.title-container{justify-content:space-between;align-items:center;width:100%;display:flex}.main-title{text-align:left;width:auto;margin-bottom:0;font-size:1.2em}.mobile-toggle-btn{align-self:center;display:flex}.controls-label{text-align:center;align-self:flex-start;width:100%;margin-left:0}.header.header-admin{justify-content:space-between;gap:.25rem;margin-bottom:.75rem;padding:.5rem .75rem;display:flex}.header.header-admin .title-container{flex:none;gap:.5rem;width:auto}.header.header-admin .header-title-text{display:none}.header.header-admin .header-nav{flex:1;justify-content:flex-end;gap:.1rem;margin-left:0;display:flex!important}.header.header-admin .header-nav-btn{border-radius:4px;flex-direction:column;flex:1;gap:2px;min-width:0;padding:.4rem .25rem}.header.header-admin .header-nav-btn svg{width:16px;height:16px}.header.header-admin .header-nav-text{white-space:nowrap;text-overflow:ellipsis;text-align:center;width:100%;font-size:.6rem;overflow:hidden}}.mobile-bottom-nav{background-color:var(--bg-color);border-top:1px solid var(--skeleton-bg);z-index:1000;padding-bottom:env(safe-area-inset-bottom);display:none;position:fixed;bottom:0;left:0;right:0}.mobile-bottom-nav-inner{justify-content:space-around;align-items:center;height:60px;display:flex}.mobile-bottom-nav-btn{min-width:60px;height:100%;color:var(--text-muted);cursor:pointer;background:0 0;border:none;flex-direction:column;flex:1 0;justify-content:center;align-items:center;gap:4px;font-size:.7rem;transition:color .2s;display:flex}.mobile-bottom-nav-btn.active{color:var(--text-color)}.mobile-bottom-nav-btn.study-btn{color:#f59e0b;background-color:#0000;flex-grow:1.2;flex-shrink:0;min-width:75px;font-weight:600;transition:all .2s;overflow:visible}.mobile-bottom-nav-btn.study-btn.active{color:#d97706;transform:scale(1.1)}.mobile-bottom-nav-btn.study-btn svg{color:inherit;filter:drop-shadow(0 0 2px #f59e0b33)}@media (width<=600px){.mobile-bottom-nav{display:block}}.protected-route-centered{justify-content:center;align-items:center;min-height:60vh;display:flex}.protected-route-card{border:1px solid var(--skeleton-bg);box-sizing:border-box;border-radius:12px;width:100%;max-width:460px;padding:1.5rem}.protected-route-card-wide{border:1px solid var(--skeleton-bg);box-sizing:border-box;border-radius:12px;width:100%;max-width:540px;padding:1.5rem}.protected-route-heading{margin-top:0;margin-bottom:.75rem}.protected-route-loading-text{color:var(--text-muted)}.protected-route-error-text{color:var(--color-error-text);margin-top:0;margin-bottom:0}.protected-route-desc{color:var(--text-muted);margin-top:0;margin-bottom:1rem}.protected-route-form{flex-direction:column;gap:.75rem;display:flex}.protected-route-input-full{width:100%}.protected-route-form-error{color:var(--color-error-text);margin-top:.75rem;margin-bottom:0;font-size:.9em}
