body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.auth-page{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;padding:20px}.auth-container{animation:slideUp .6s ease-out;background:#fff;border-radius:20px;box-shadow:0 20px 40px #0000001a;max-width:450px;overflow:hidden;width:100%}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.auth-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:40px 30px 20px;text-align:center}.auth-title{font-size:2.5rem;font-weight:700;margin:0 0 10px;text-shadow:0 2px 4px #0000001a}.auth-tagline{font-size:1.1rem;font-weight:300;margin:0;opacity:.9}.auth-content{padding:30px}.auth-form-container{text-align:center}.auth-form-container h2{color:#333;font-size:1.8rem;font-weight:600;margin:0 0 10px}.auth-subtitle{color:#666;font-size:1rem;margin:0 0 30px}.auth-form{text-align:left}.form-group label{font-size:.9rem}.form-input{border-radius:10px}.form-input::placeholder{color:#999}.auth-button{border:none;border-radius:10px;cursor:pointer;font-size:1rem;font-weight:600;margin-top:10px;padding:14px 20px;transition:all .3s ease;width:100%}.auth-button.primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.auth-button.primary:hover:not(:disabled){box-shadow:0 8px 25px #667eea4d;transform:translateY(-2px)}.auth-button:disabled{cursor:not-allowed;opacity:.7;transform:none}.auth-switch{border-top:1px solid #e1e5e9;margin-top:25px;padding-top:20px;text-align:center}.auth-switch p{color:#666;font-size:.9rem;margin:0}.link-button{background:none;border:none;color:#667eea;cursor:pointer;font-size:.9rem;font-weight:600;margin:0;padding:0;text-decoration:underline}.link-button:hover{color:#764ba2}.forgot-password-link{color:#667eea;display:block;font-size:.8rem;margin-top:8px;text-align:right;text-decoration:none}.forgot-password-link:hover{color:#764ba2;text-decoration:underline}.auth-footer,.error-message{font-size:.9rem}.auth-footer{background:#f8f9fa;color:#666;padding:20px 30px 30px;text-align:center}@media (max-width:480px){.auth-page{padding:10px}.auth-container{border-radius:15px}.auth-header{padding:30px 20px 15px}.auth-title{font-size:2rem}.auth-content{padding:20px}.auth-footer{padding:15px 20px 20px}}.auth-button:disabled{position:relative}.auth-button:disabled:after{animation:spin 1s linear infinite;border:2px solid #0000;border-radius:50%;border-top-color:currentcolor;content:"";height:20px;left:50%;margin-left:-10px;margin-top:-10px;position:absolute;top:50%;width:20px}.language-flag-icon{display:inline-block;height:auto;object-fit:contain;vertical-align:middle;width:24px}.language-profile-selector{background:#fff;border-radius:12px;box-shadow:0 4px 20px #00000026;max-height:80vh;overflow-y:auto;padding:24px}.language-profile-header{align-items:center;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;margin-bottom:20px;padding-bottom:16px}.language-profile-header h3{color:#333;font-size:1.5rem;font-weight:600;margin:0}.error-message{border-radius:6px;margin-bottom:16px;padding:12px}.language-profiles-list{margin-bottom:20px}.no-profiles{color:#666;padding:40px 20px;text-align:center}.no-profiles p{margin:8px 0}.language-profile-item{align-items:center;border:1px solid #e0e0e0;margin-bottom:12px;padding:16px;transition:all .2s ease;-webkit-user-select:none;user-select:none}.language-profile-item:hover{background:#f8f9fa;border-color:#007bff;box-shadow:0 2px 8px #007bff1a;transform:translateY(-1px)}.language-profile-item.active{background:#f8fff9;border-color:#28a745;cursor:default}.language-profile-item.active:hover{box-shadow:0 2px 8px #28a7451a;transform:none}.profile-info{align-items:center;flex:1 1}.language-flag{margin-right:12px}.profile-details{flex:1 1}.profile-name{margin-bottom:4px}.profile-actions{align-items:center;display:flex;gap:8px}.add-profile-btn{background:#28a745;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:500;padding:12px 20px;transition:all .2s ease;width:100%}.add-profile-btn:hover{background:#218838}.create-profile-form{border-top:1px solid #e0e0e0;margin-top:20px;padding-top:20px}.create-profile-form h4{color:#333;font-size:1.2rem;margin:0 0 16px}.form-group{margin-bottom:16px}.form-group label{margin-bottom:6px}.form-group input,.form-group select{font-size:1rem;padding:10px 12px;width:100%}.form-group input:focus,.form-group select:focus{border-color:#007bff;box-shadow:0 0 0 3px #007bff1a;outline:none}.form-actions{gap:12px;margin-top:20px}.create-btn{background:#007bff;border:none;border-radius:6px;color:#fff;cursor:pointer;flex:1 1;font-size:1rem;font-weight:500;padding:12px 20px;transition:all .2s ease}.create-btn:hover{background:#0056b3}.cancel-btn{border:none;border-radius:6px;cursor:pointer;flex:1 1;font-size:1rem;font-weight:500;padding:12px 20px;transition:all .2s ease}.loading{padding:40px 20px}@media (max-width:600px){.language-profile-selector{margin:10px;max-height:90vh;padding:16px}.language-profile-item{align-items:flex-start;flex-direction:column;gap:12px}.profile-actions{justify-content:flex-end;width:100%}.form-actions{flex-direction:column}}.welcome-setup{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:calc(100vh - 70px);padding:20px 20px 0}.welcome-content{background:#fff;border-radius:16px;box-shadow:0 8px 32px #0000001a;max-width:600px;padding:40px;text-align:center;width:100%}.welcome-header h1{color:#333;font-size:2.5rem;font-weight:700;margin-bottom:12px}.welcome-header p{color:#666;font-size:1.2rem;margin-bottom:32px}.setup-form{text-align:left}.language-selection{margin-bottom:32px}.language-selection h3{color:#333;font-size:1.3rem;margin-bottom:20px;text-align:center}.language-options{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(2,1fr);margin-bottom:24px}.language-option-item{gap:10px}.language-option,.language-option-item{align-items:center;display:flex;flex-direction:column}.language-option{background:#fff;border:2px solid #e0e0e0;border-radius:12px;cursor:pointer;font-size:1rem;justify-content:center;padding:20px 16px;transition:all .3s ease;width:100%}.language-option:hover{border-color:#007bff;box-shadow:0 4px 12px #007bff26;transform:translateY(-2px)}.language-option.selected{background-image:var(--flag-bg);background-position:50%;background-repeat:no-repeat;background-size:cover;border-color:#007bff;box-shadow:0 4px 12px #007bff33;min-height:100px}.language-flag{border-radius:4px;box-shadow:0 1px 4px #00000026;display:block;margin-bottom:8px;width:48px}.language-name{color:#000;text-align:center}.form-group{margin-bottom:24px}.form-group label{font-size:1.1rem}.form-group input{font-size:1rem;padding:12px 16px;width:100%}.form-group input:focus{border-color:#007bff;box-shadow:0 0 0 3px #007bff1a;outline:none}.create-profile-btn{background:#007bff;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:600;padding:16px 24px;transition:all .3s ease;width:100%}.create-profile-btn:hover:not(:disabled){background:#0056b3;box-shadow:0 4px 12px #007bff4d;transform:translateY(-1px)}.create-profile-btn:disabled{background:#6c757d;box-shadow:none;cursor:not-allowed;transform:none}.error-message{text-align:center}.success-icon{font-size:4rem;margin-bottom:24px}.welcome-content h2{color:#333;font-size:2rem;font-weight:600;margin-bottom:16px}.welcome-content p{color:#666;font-size:1.1rem;margin-bottom:16px}.welcome-content ul{margin:20px 0;padding-left:20px;text-align:left}.welcome-content li{color:#555;font-size:1rem;margin-bottom:8px}.get-started-btn{background:#28a745;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:600;margin-top:24px;padding:16px 32px;transition:all .3s ease}.get-started-btn:hover{background:#218838;box-shadow:0 4px 12px #28a7454d;transform:translateY(-1px)}@media (max-width:768px){.welcome-content{margin:10px;padding:24px}.welcome-header h1{font-size:2rem}.language-options{grid-template-columns:repeat(2,1fr)}.language-option{padding:16px 12px}.language-flag{width:40px}}.mobile-input-buttons{align-items:center;display:flex;gap:8px;justify-content:flex-start;width:100%}.input-buttons-row{align-items:center;display:flex;gap:10px;width:35%}.input-aux-button{align-items:center;background:#f8f9fa;border:1px solid #e0e0e0;border-radius:6px;cursor:pointer;display:inline-flex;justify-content:center;padding:5px 10px;position:relative;transition:background-color .2s}.input-aux-button:disabled{cursor:not-allowed;opacity:.6}.input-aux-button:hover:not(:disabled){background:#e9ecef}.input-aux-icon{height:25px;object-fit:contain;width:30px}.chat-image-preview-container{margin-bottom:8px;position:relative;width:120px}.chat-image-preview{border:1px solid #ddd;border-radius:8px;height:120px;object-fit:cover;width:120px}.chat-image-remove-button{background:#000000b3;border:none;border-radius:12px;color:#fff;cursor:pointer;height:24px;position:absolute;right:4px;top:4px;width:24px}.send-button{align-items:center;background:#007bff;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;gap:6px;justify-content:center;margin-left:auto;padding:11px 16px;width:50%}.send-button:disabled{background:#a7aaad;cursor:not-allowed}.send-button .loading-spinner{animation:spin 1s linear infinite;border:2px solid #fff;border-radius:50%;border-top-color:#0000;height:12px;width:12px}.mobile-hint-container{background:#e3f2fd;border:1px solid #bbdefb;border-radius:6px;margin-top:12px;padding:16px}.mobile-hint-header{align-items:center;display:flex;justify-content:right;margin-top:16px}.mobile-hint-text{word-wrap:break-word;color:#1976d2;font-size:16px;line-height:1.4;overflow-wrap:break-word;white-space:pre-wrap}.mobile-hint-button{border:none;border-radius:4px;cursor:pointer;font-size:12px;font-weight:700;padding:6px 12px;transition:opacity .2s}.mobile-hint-send-button{background:#28a745;color:#fff}.mobile-hint-close-button{background:#6c757d;color:#fff}.mobile-correction-loading{background:#f0f8ff;border:1px solid #b3d9ff;border-radius:4px;color:#06c;padding:8px 12px}.mobile-correction-loading p{margin:0}.mobile-correction-content{background:#e3f2fd;border:1px solid #bbdefb;border-radius:6px;flex-shrink:0;margin-top:12px;padding:16px}.mobile-correction-header{align-items:center;display:flex;justify-content:right;margin-top:16px}.mobile-correction-title{color:#495057;font-size:14px;font-weight:700}.mobile-correction-buttons{display:flex;gap:8px}.mobile-correction-text{word-wrap:break-word;color:#1976d2;font-size:16px;line-height:1.4;overflow-wrap:break-word;white-space:pre-wrap}.current-goal-section{padding:10px}.current-goal-container{align-items:center;animation:slideInFromLeft 1s ease-out,flashHighlight .5s ease-in-out 1s;border:1px solid #e0e0e0;border-radius:8px;cursor:pointer;display:flex;gap:16px;justify-content:flex-start;padding:10px 20px}.current-goal-icon{align-items:center;animation:bounceIn .8s ease-out .3s both;display:flex;flex-direction:row;gap:10px;height:32px;justify-content:center;margin:0 25px 0 15px;width:32px}.current-goal-icon img{height:100%;object-fit:contain;width:100%}.current-goal-counter{color:#555;font-size:18px;font-weight:500;margin-top:0;text-align:center}.current-goal-content{color:#3d3d3d;flex:1 1}.current-goal-text{animation:fadeInUp .8s ease-out .7s both;font-size:18px;font-weight:500;line-height:1.2;text-align:center}.current-goals-panel{background-color:#f8f9fa;border:1px solid #e0e0e0;border-radius:8px;margin-top:8px;max-height:0;opacity:0;overflow:hidden;transition:max-height .3s ease-out,opacity .3s ease-out,margin-top .3s ease-out}.current-goals-panel.expanded{max-height:400px;opacity:1}@keyframes slideInFromLeft{0%{opacity:0;transform:translateX(-100%)}to{opacity:1;transform:translateX(0)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes flashHighlight{0%{box-shadow:0 0 0 0 #ffffffb3}50%{box-shadow:0 0 0 10px #ffffff1a}to{box-shadow:0 0 0 0 #fff0}}.goal-transitioning{animation:goalTransition 1s ease-in-out 2s}.goal-icon-transition{animation:goalIconTransition 1s ease-in-out 2s}@keyframes goalTransition{0%{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.05)}to{opacity:1;transform:scale(1)}}@keyframes goalIconTransition{0%{opacity:1;transform:scale(1) rotate(0deg)}25%{opacity:.7;transform:scale(1.2) rotate(180deg)}50%{opacity:.5;transform:scale(.8) rotate(1turn)}75%{opacity:.8;transform:scale(1.1) rotate(540deg)}to{opacity:1;transform:scale(1) rotate(2turn)}}.thinking-bubbles-container{align-items:center;display:flex;gap:10px;left:3%;position:absolute;top:5%;z-index:6}.thinking-bubble-container{height:100px;position:relative;width:100px}.thinking-bubble-background{height:100%;left:0;object-fit:contain;position:absolute;top:0;width:100%}.thinking-bubble-item{height:50px;left:0;object-fit:contain;position:absolute;top:0;transform:translate(50%,50%);width:50px}.thinking-bubble-ellipsis{align-items:flex-start;background:#fffc;border:2px solid #333;border-radius:50%;color:#333;display:flex;font-size:24px;font-weight:700;height:50px;justify-content:center;width:50px}.quest-stage-container{position:relative}.quest-background{display:block;height:auto;object-fit:contain;width:100%;z-index:1}.quest-stage-overlay{inset:0;pointer-events:none}.quest-foreground,.quest-stage-overlay{height:100%;position:absolute;width:100%}.quest-foreground{left:0;object-fit:contain;top:0;z-index:3}.quest-koko{left:0;top:0;z-index:2}.quest-koko,.quest-object-overlay{height:100%;object-fit:contain;position:absolute;width:100%}.quest-object-overlay{z-index:5}.chat-fade-overlay{background:linear-gradient(180deg,#f9f9f9 0,#f9f9f9cc 30%,#f9f9f94d 70%,#f9f9f900);height:20px;left:0;pointer-events:none;position:absolute;top:0;width:100%;z-index:199}.chat-container{display:flex;flex-direction:column;height:100vh;margin:15px 20px 10px;max-width:100%;overflow:hidden}.chat-content-wrapper,.chat-main{display:flex;flex:1 1;flex-direction:column;overflow:hidden}.chat-content-wrapper{-ms-overflow-style:none;position:relative;scrollbar-width:none}.chat-content-wrapper::-webkit-scrollbar{display:none}.chat-content{-ms-overflow-style:none;background:#f9f9f9;display:flex;flex:1 1;flex-direction:column;min-height:0;overflow-y:auto;position:relative;scrollbar-width:none;z-index:100}.chat-content::-webkit-scrollbar{display:none}.ai-thinking-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.ai-thinking-container{background:#fff;border-radius:12px;box-shadow:0 8px 32px #0003;max-width:300px;padding:40px;text-align:center}.ai-thinking-spinner{animation:spin 1s linear infinite;border:4px solid #f3f3f3;border-radius:50%;border-top-color:#007bff;height:40px;margin:0 auto 20px;width:40px}.ai-thinking-container p{color:#333;font-size:16px;font-weight:500;margin:0}.loading-overlay{align-items:center;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;pointer-events:all;position:fixed;right:0;top:0;z-index:99999}.loading-overlay-container{align-items:center;background-color:#fff;border-radius:8px;box-shadow:0 4px 6px #0000001a;display:flex;flex-direction:column;gap:12px;padding:20px}.loading-overlay-spinner{animation:spin 1s linear infinite;border:3px solid #f3f3f3;border-radius:50%;border-top-color:#007bff;height:32px;width:32px}.loading-overlay-text{color:#333;font-size:16px;font-weight:500}@media (max-width:768px){.chat-container{flex-direction:column;height:calc(100vh - 70px);margin:0;padding:0 10px}.chat-container,.chat-main{display:flex;overflow:hidden}.chat-content,.chat-main{flex:1 1;flex-direction:column}.chat-content{background:#f9f9f9;display:flex;min-height:0;overflow-y:auto;position:relative;transition:height .3s ease;z-index:100}.chat-content.has-correction{flex:1 1;min-height:20vh}.mobile-controls{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px;margin-top:10px}.mobile-control-group{flex:1 1;min-width:120px}.mobile-input-form{background:#fff;border-top:1px solid #eee;flex-direction:column;flex-shrink:0;gap:8px;order:3;padding-top:12px}.mobile-correction-container{background:#f8f9fa;border-bottom:1px solid #dee2e6;border-radius:0;border-top:1px solid #dee2e6;flex-shrink:0;height:auto;margin:0;max-height:20vh;min-height:auto;order:2;overflow-y:auto;padding:12px}.mobile-input-buttons{display:flex;gap:8px}}.load-more-container{margin-bottom:12px;text-align:center}.load-more-button{background:#007bff;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;padding:8px 16px}.load-more-button:disabled{background:#6c757d;cursor:not-allowed;opacity:.6}.load-more-spinner{animation:spin 1s linear infinite;border:2px solid #fff;border-radius:50%;border-top-color:#0000;display:inline-block;height:12px;margin-right:8px;width:12px}.restart-divider{background-color:#ddd;height:1px;margin:16px 0;position:relative;width:100%}.restart-divider-text{background-color:#fff;color:#666;font-size:12px;font-weight:500;left:50%;padding:0 12px;position:absolute;top:-8px;transform:translateX(-50%)}.ai-message-container{margin:8px 0;overflow:visible;position:relative;text-align:left}.ai-message-container.has-tip-balloon{z-index:50}.mobile-ai-message{align-items:center;display:flex;gap:8px}.mobile-message-bubble{align-items:center;background:#e8e9ea;border-radius:12px;color:#222;cursor:pointer;display:flex;flex:1 1;justify-content:center;line-height:2;min-height:60px;overflow:visible;padding:8px 14px;position:relative;transition:filter .2s;word-break:break-word}.mobile-message-bubble.text-hidden{z-index:2}.mobile-message-bubble.text-visible{z-index:1}.mobile-message-bubble .new-word{position:relative;z-index:3!important}.new-word-tip-anchor{display:inline-block;position:relative;z-index:12}.new-word-tip-balloon{background:#fff8e1;border:1px solid #ffe082;border-radius:10px;box-shadow:0 2px 10px #0000001f;color:#5d4037;font-size:13px;line-height:1.45;max-width:min(260px,72vw);padding:10px 12px;pointer-events:none;text-align:left;width:-webkit-max-content;width:max-content}.new-word-tip-balloon--fixed{position:fixed;z-index:300}.new-word-tip-balloon--dismissible{pointer-events:auto}.new-word-tip-balloon__content{align-items:flex-start;display:flex;gap:8px}.new-word-tip-balloon__text{flex:1 1}.new-word-tip-balloon__dismiss{background:#0000;border:none;color:#8d6e63;cursor:pointer;flex-shrink:0;font-size:14px;line-height:1;padding:0 2px}.new-word-tip-balloon:before{border-color:#ffe082 #0000 #0000;border-style:solid;border-width:13px 13px 0;top:100%}.new-word-tip-balloon:after,.new-word-tip-balloon:before{content:"";height:0;left:50%;left:var(--tip-tail-left,50%);position:absolute;transform:translateX(-50%);width:0}.new-word-tip-balloon:after{border-color:#fff8e1 #0000 #0000;border-style:solid;border-width:13px 13px 0;top:calc(100% - 1px)}.mobile-message-bubble.text-hidden .regular-word{z-index:1}.mobile-message-bubble.text-visible .regular-word{position:relative;z-index:3}.user-message-container{margin:8px 0;text-align:right}.user-message-bubble{background:#d1e7dd;border-radius:12px;color:#222;display:inline-block;line-height:1.5;max-width:80%;padding:8px 14px;word-break:break-word}.user-message-bubble .new-word{animation:none!important;background:#0000!important;border:none!important;box-shadow:none!important;color:inherit!important;filter:none!important;font-size:inherit!important;font-weight:inherit!important;margin:0!important;padding:0!important;position:relative}.user-message-image{border-radius:8px;display:block;margin-top:8px;max-height:220px;max-width:220px}.user-message-image-placeholder{color:#4b5563;font-size:12px;margin-top:8px}.illustration-container{margin-top:8px;text-align:center}.illustration-image{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;display:block;margin:0 auto;max-width:90%}.mobile-message-buttons{display:flex;flex-direction:column;flex-shrink:0;gap:6px;height:100%;justify-content:center;width:50px}.mobile-message-buttons button{align-items:center;border:none;border-radius:4px;cursor:pointer;display:flex;font-size:14px;justify-content:center;padding:8px 6px;width:100%}.mobile-message-buttons button:disabled{cursor:not-allowed;opacity:.6}.hide-show-button{background:#298afb;color:#fff}.play-pause-tip-anchor{display:flex;flex:1 1;height:100%;min-height:0;width:100%}.play-pause-tip-anchor .play-pause-button{flex:1 1;min-height:0}.play-pause-button{background:#298afb;color:#fff}.play-pause-button.playing{background:#f5c842}.play-pause-spinner{animation:spin 1s linear infinite;border:1px solid #fff;border-radius:50%;border-top-color:#0000;height:8px;width:8px}.explain-button{background:#298afb;color:#fff}@media (max-width:768px){.mobile-ai-message{align-items:stretch;gap:8px;margin:8px 0;width:100%}.mobile-message-buttons{align-self:stretch;flex-direction:column;gap:6px;justify-content:stretch;width:50px}.mobile-message-buttons .play-pause-tip-anchor{flex:1 1;min-height:0;width:100%}.mobile-message-buttons>.explain-button{flex:1 1;min-height:0}.mobile-message-buttons button{box-sizing:border-box;flex:1 1;height:auto;min-height:0;padding:5px 12px}.mobile-message-buttons button div,.mobile-message-buttons button span{font-size:18px}}.unit-progress-container{margin-bottom:16px;margin-top:16px}.unit-progress-main{align-items:flex-start;display:flex;gap:16px}.quest-title-section{background-color:#f0f8ff;border:1px solid #e0e0e0;border-radius:8px;flex-basis:calc(50% - 8px);flex-grow:0;flex-shrink:0;position:relative}.quest-title-header{align-items:center;border-radius:6px;cursor:pointer;display:flex;justify-content:space-between;margin-bottom:8px;padding:8px;transition:background-color .2s ease;-webkit-user-select:none;user-select:none}.quest-title-header:hover{background-color:#0000000d}.quest-title{color:#495057;flex:1 1;font-size:16px;font-weight:600;margin-right:8px}.score-section{background-color:#f0f8ff;border:1px solid #e0e0e0;border-radius:8px;flex-basis:calc(50% - 8px);flex-grow:0;flex-shrink:0;min-width:0;position:relative}.score-header{align-items:center;border-radius:6px;cursor:pointer;display:flex;justify-content:space-between;padding:8px;transition:background-color .2s ease;-webkit-user-select:none;user-select:none}.score-header:hover{background-color:#0000000d}.score-info{flex:1 1;margin-right:8px}.score-text{color:#666;display:block;font-size:16px;font-weight:500;margin-bottom:4px}.score-progress-bar-container{background-color:#e0e0e0;border-radius:3px;height:6px;overflow:hidden;width:100%}.score-progress-bar{background-color:#28a745;height:100%;transition:width .3s ease}.collapse-toggle{align-items:center;background:none;border:none;border-radius:4px;cursor:pointer;display:flex;justify-content:center;padding:4px 0 4px 8px;transition:background-color .2s ease}.collapse-toggle:hover{background-color:#0000001a}.collapse-icon{color:#6c757d;display:inline-block;font-size:.8rem;transition:transform .2s ease}.collapse-icon.collapsed{transform:rotate(-90deg)}.collapse-icon.expanded{transform:rotate(0deg)}.goals-component,.words-patterns-component{display:inline-block;position:relative}.goals-header,.words-patterns-header{align-items:center;background:#f8f9fa;border:1px solid #e0e0e0;border-radius:6px;cursor:pointer;display:flex;justify-content:space-between;padding:5px 10px;transition:background-color .2s}.goals-header:hover,.words-patterns-header:hover{background:#e9ecef}.goals-title,.words-patterns-title{align-items:center;color:#333;display:flex;font-size:.9rem;font-weight:600}.goals-icon,.words-patterns-icon{filter:brightness(0) saturate(100%) invert(20%) sepia(0) saturate(0) hue-rotate(0deg) brightness(0) contrast(100%);height:25px;width:25px}.goals-icon{margin-right:10px}.goals-content,.words-patterns-content{background-color:#f8f9fa;border:1px solid #e0e0e0;border-radius:8px;bottom:100%;box-shadow:0 4px 8px #0000001a;left:0;margin-bottom:8px;max-height:300px;opacity:0;overflow-y:auto;pointer-events:none;position:absolute;right:0;transition:opacity .3s ease-out,margin-bottom .3s ease-out,pointer-events .3s ease-out;z-index:100}.words-patterns-content.expanded{border-radius:0;bottom:0;height:85vh;left:0;margin:0;max-height:none;opacity:1;pointer-events:auto;position:fixed;right:0;top:70px;width:100vw;z-index:200}.words-patterns-close-btn{background:none;border:1px solid #ced4da;border-radius:4px;color:#6c757d;cursor:pointer;font-size:1.75rem;line-height:1;padding:2px 8px;position:absolute;right:12px;top:3px;transition:background-color .2s ease,color .2s ease,border-color .2s ease;z-index:10}.words-patterns-close-btn:hover{background-color:#00000014;border-color:#adb5bd;color:#333}.goals-content.expanded{border-radius:0;bottom:0;height:83vh;left:0;margin:0;max-height:none;opacity:1;pointer-events:auto;position:fixed;right:0;top:70px;width:100vw;z-index:200}.focus-words-section{background-color:#f0f8ff;border-bottom:1px solid #e0e0e0;border-radius:8px 8px 0 0;padding:12px}.focus-words-grid{display:flex;flex-wrap:wrap;line-height:2;row-gap:10px}.focus-word-entry{display:inline}.focus-word-translation{color:#333;font-weight:400}.focus-word{background:#e8f5e8;border:1px solid #388e3c;border-radius:4px;cursor:pointer;display:inline-block;font-weight:400;margin-right:20px;padding:0 8px;pointer-events:auto!important;position:relative;transition:box-shadow .3s,background .3s,color .3s;z-index:20}.focus-word:hover{background:#d4edda;border-color:#28a745;color:#155724}.quest-patterns-section{background-color:#f0f8ff;border-radius:0 0 8px 8px;border-top:1px solid #e0e0e0;padding:12px;pointer-events:auto;transition:opacity .3s ease-out,margin-top .3s ease-out,pointer-events .3s ease-out}.goals-content{padding:12px}.quest-goal-item{border-bottom:1px solid #e9ecef;padding:8px 0}.quest-goal-item:last-child{border-bottom:none}.quest-goal-item.achieved{color:#28a745}.quest-goal-item.not-started{color:#6c757d}.goal-status-icon{margin-right:8px}.goal-text{font-size:.9rem}.goals-flash{animation:goalsFlash 3s ease-in-out}.goals-flash .goals-content{animation:goalsContentFlash 3s ease-in-out}.goals-flash .goals-header{animation:goalsHeaderFlash 3s ease-in-out}@keyframes goalsFlash{0%{background-color:initial;box-shadow:0 0 0 0 #28a74566}10%{background-color:#28a74526;box-shadow:0 0 0 6px #28a74566}20%{background-color:#28a74540;box-shadow:0 0 0 12px #28a7454d}30%{background-color:#28a74533;box-shadow:0 0 0 8px #28a74540}40%{background-color:#28a7451a;box-shadow:0 0 0 4px #28a74526}50%{background-color:initial;box-shadow:0 0 0 0 #28a74500}60%{background-color:#28a74526;box-shadow:0 0 0 6px #28a74566}70%{background-color:#28a74540;box-shadow:0 0 0 12px #28a7454d}80%{background-color:#28a74533;box-shadow:0 0 0 8px #28a74540}90%{background-color:#28a7451a;box-shadow:0 0 0 4px #28a74526}to{background-color:initial;box-shadow:0 0 0 0 #28a74500}}@keyframes goalsContentFlash{0%{background-color:initial}10%{background-color:#28a7451a}20%{background-color:#28a74533}30%{background-color:#28a74526}40%{background-color:#28a7451a}50%{background-color:initial}60%{background-color:#28a7451a}70%{background-color:#28a74533}80%{background-color:#28a74526}90%{background-color:#28a7451a}to{background-color:initial}}@keyframes goalsHeaderFlash{0%{background-color:#f8f9fa;color:#333}10%{background-color:#28a74533;color:#155724}20%{background-color:#28a7454d;color:#155724}30%{background-color:#28a74540;color:#155724}40%{background-color:#28a74533;color:#155724}50%{background-color:#f8f9fa;color:#333}60%{background-color:#28a74533;color:#155724}70%{background-color:#28a7454d;color:#155724}80%{background-color:#28a74540;color:#155724}90%{background-color:#28a74533;color:#155724}to{background-color:#f8f9fa;color:#333}}.focus-words-header,.patterns-header{border-bottom:1px solid #e0e0e0;margin-bottom:12px;padding-bottom:8px}.focus-words-header h4,.patterns-header h4{color:#495057;font-size:14px;font-weight:700;margin:0}.patterns-list{display:block}.pattern-group{background-color:#fff;border:1px solid #e0e0e0;border-radius:6px;margin-bottom:16px;padding:12px}.pattern-original{color:#6c757d;font-size:13px;font-style:italic;margin-bottom:8px}.pattern-quest{color:#495057;font-size:14px;line-height:1.4;margin-top:8px}.pattern-text{display:inline}.pattern-word{background:#e8f5e8;border:1px solid #388e3c;border-radius:4px;cursor:pointer;display:inline-block;font-weight:400;margin:2px;padding:0 8px;pointer-events:auto!important;position:relative;transition:box-shadow .3s,background .3s,color .3s;z-index:20}.pattern-word:hover{background:#d4edda;border-color:#28a745;color:#155724}.pattern-punctuation{color:#495057;display:inline-block;font-weight:400;margin:0 1px}.pattern-play-button{align-items:center;background:#007bff;border:none;border-radius:4px;color:#fff;cursor:pointer;display:inline-flex;font-size:12px;gap:4px;margin-left:8px;opacity:1;padding:4px 8px;transition:background-color .2s,opacity .2s}.pattern-play-button:hover:not(:disabled){background:#0056b3}.pattern-play-button:disabled{cursor:not-allowed;opacity:.6}.pattern-loading-spinner{animation:spin 1s linear infinite;border:1px solid #fff;border-radius:50%;border-top-color:#0000;height:8px;width:8px}.quest-goals-list{background-color:#f0f8ff;border:1px solid #e0e0e0;border-radius:8px;box-shadow:0 4px 8px #0000001a;left:-110%;opacity:0;overflow:hidden;padding:12px;position:absolute;right:-2%;top:100%;transition:max-height .3s ease-out,opacity .3s ease-out,margin-top .3s ease-out;z-index:10}.quest-goals-list.expanded{margin-top:12px;opacity:1;z-index:200}.quest-goal-item{align-items:center;border-radius:6px;display:flex;gap:8px;margin-bottom:6px;padding:8px 12px;transition:background-color .2s ease}.quest-goal-item:hover{background-color:#0000000d}.quest-goal-item.achieved{background-color:#d4edda;border-left:3px solid #28a745}.quest-goal-item.not-started{background-color:#f8f9fa;border-left:3px solid #6c757d}.goal-status-icon{font-size:16px;font-weight:700;min-width:20px;text-align:center}.quest-goal-item.achieved .goal-status-icon{color:#28a745}.quest-goal-item.not-started .goal-status-icon{color:#6c757d}.goal-text{color:#495057;font-size:14px;line-height:1.4}@media (max-width:768px){.unit-progress-main{gap:12px}.focus-word-item{font-size:.85rem;min-height:36px;padding:6px 8px}.collapse-icon{font-size:.75rem}.quest-title,.score-text{font-size:15px}}@media (max-width:480px){.focus-word-item{font-size:.8rem;min-height:32px;padding:4px 6px}.collapse-icon{font-size:.7rem}.quest-title,.score-text{font-size:14px}}.ux-tip{align-items:stretch;background:#fff8e1;border:1px solid #ffe082;border-radius:8px;box-shadow:0 2px 8px #0000000f;color:#5d4037;display:flex;flex-direction:column;font-size:14px;gap:8px;line-height:1.45;margin:8px 0;padding:10px 12px;text-align:left}.ux-tip-header{align-items:flex-start;display:flex;gap:8px}.ux-tip-inline{margin:6px 0 0}.ux-tip-text{flex:1 1}.ux-tip-dismiss{background:#0000;color:#8d6e63;flex-shrink:0;line-height:1;padding:0 2px}.ux-tip-action,.ux-tip-dismiss{border:none;cursor:pointer;font-size:14px}.ux-tip-action{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:6px;color:#fff;font-weight:600;padding:8px 12px;width:100%}.ux-tip-action:active{opacity:.9}.chat-input-tip{margin-bottom:4px}.quest-steps-tip-balloon{--tip-tail-left:71px;background:#fff8e1;border:1px solid #ffe082;border-radius:10px;box-shadow:0 2px 10px #0000001f;color:#5d4037;font-size:13px;line-height:1.45;max-width:min(260px,72vw);padding:10px 12px;pointer-events:none;text-align:left;width:-webkit-max-content;width:max-content;z-index:300}.quest-steps-tip-balloon:before{border-color:#ffe082 #0000 #0000;border-style:solid;border-width:13px 13px 0;top:100%}.quest-steps-tip-balloon:after,.quest-steps-tip-balloon:before{content:"";height:0;left:var(--tip-tail-left);position:absolute;transform:translateX(-50%);width:0}.quest-steps-tip-balloon:after{border-color:#fff8e1 #0000 #0000;border-style:solid;border-width:13px 13px 0;top:calc(100% - 1px)}.word-bank-nav-btn{align-items:center;background:none;border:none;border-radius:6px;cursor:pointer;display:inline-flex;justify-content:center;padding:4px 8px;position:relative;transition:background .2s}.word-bank-nav-btn:hover{background:#f0f0f0}.word-bank-nav-icon{height:26px;object-fit:contain;width:26px}.word-bank-nav-badge{background:#1976d2;border-radius:8px;color:#fff;font-size:10px;font-weight:700;height:16px;line-height:16px;min-width:16px;padding:0 4px;position:absolute;right:0;text-align:center;top:-2px}.word-bank-nav-btn-mobile{display:inline-flex;margin-left:auto;margin-right:8px}.word-bank-overlay{z-index:2100}.word-bank-panel{background:#fff;border-radius:12px;box-shadow:0 8px 32px #0000002e;display:flex;flex-direction:column;max-height:80vh;overflow:hidden;width:375px}.word-bank-header{align-items:center;display:flex;justify-content:space-between;padding:16px 16px 0}.word-bank-title{color:#222;font-size:20px;font-weight:700;margin:0}.word-bank-close{background:#0000;border:none;color:#666;cursor:pointer;font-size:18px;padding:4px 8px}.word-bank-subtitle{color:#666;font-size:13px;line-height:1.45;margin:8px 16px 12px;text-align:left}.word-bank-list{flex:1 1;overflow-y:auto;padding:0 12px 16px}.word-bank-item{align-items:baseline;border-bottom:1px solid #eee;display:flex;gap:25px;padding:10px 8px;text-align:left}.word-bank-front{color:#222;flex-shrink:0;font-weight:600}.word-bank-back{color:#555;font-size:14px;overflow:hidden;text-align:right;text-overflow:ellipsis;white-space:nowrap}.word-bank-empty{color:#888;font-size:14px;padding:16px 8px;text-align:center}.quest-completion-overlay{z-index:2200}.quest-completion-panel{background:#fff;border-radius:14px;box-shadow:0 8px 32px #0003;padding:24px 20px 20px;position:relative;text-align:center;width:360px}.quest-completion-close{background:#0000;border:none;color:#666;cursor:pointer;font-size:18px;line-height:1;padding:4px 8px;position:absolute;right:12px;top:12px}.quest-completion-close:hover{color:#333}.quest-completion-title{color:#222;font-size:22px;font-weight:700;margin:0 0 10px}.quest-completion-subtitle{color:#444;font-size:15px;line-height:1.5;margin:0 0 20px}.quest-completion-actions{display:flex;flex-direction:column;gap:10px}.quest-completion-btn{border:none;border-radius:8px;cursor:pointer;font-size:16px;font-weight:600;padding:12px 16px}.quest-completion-btn-primary{background:#1976d2;color:#fff}.quest-completion-btn-secondary{background:#f0f0f0;color:#333}.quest-waitlist-panel{text-align:left;width:min(420px,92vw)}.quest-waitlist-copy{text-align:left}.quest-waitlist-form{margin-top:4px}.quest-waitlist-label{color:#333;display:block;font-size:14px;font-weight:600;margin-bottom:8px}.quest-waitlist-input{border:2px solid #e1e5e9;border-radius:8px;box-sizing:border-box;font-size:15px;margin-bottom:16px;padding:12px 14px;width:100%}.quest-waitlist-input:focus{border-color:#1976d2;outline:none}.quest-waitlist-error{background:#fee;border:1px solid #fcc;border-radius:8px;color:#c33;font-size:14px;margin-bottom:12px;padding:10px 12px}.new-word-fly{animation:flyToWordBank .85s ease-in forwards;background:#fff8dc;border:2px solid gold;border-radius:6px;color:#b8860b;font-size:16px;font-weight:700;padding:4px 10px;pointer-events:none;position:fixed;transform:translate(-50%,-50%);z-index:3000}@keyframes flyToWordBank{0%{opacity:1;transform:translate(-50%,-50%) scale(1)}70%{opacity:1;transform:translate(calc(-50% + var(--fly-dx)),calc(-50% + var(--fly-dy))) scale(.7)}to{opacity:0;transform:translate(calc(-50% + var(--fly-dx)),calc(-50% + var(--fly-dy))) scale(.3)}}.mobile-modal:not(.word-meaning-modal-panel){align-items:center;background:#00000080;bottom:0;box-sizing:border-box;display:flex;justify-content:center;left:0;padding:0 20px;position:fixed;right:0;top:0;z-index:1000}.mobile-modal.word-meaning-modal-panel{background:#fff;border-radius:8px;box-sizing:border-box;display:flex;flex-direction:column;height:-webkit-fit-content;height:fit-content;max-height:60vh;max-width:375px;overflow:hidden;padding:20px;position:relative;text-align:center;width:100%}.word-meaning-modal-loading{align-items:center;display:flex;flex-shrink:0;gap:8px;justify-content:center;padding:20px}.word-meaning-modal-spinner{animation:spin 1s linear infinite;border:2px solid #007bff;border-radius:50%;border-top-color:#0000;height:20px;width:20px}.word-meaning-modal-base-form{color:red;flex-shrink:0;font-size:28px;font-weight:700;margin-bottom:8px}.word-meaning-modal-meaning{box-sizing:border-box;flex:0 1 auto;font-size:20px;line-height:1.4;margin:25px 10px 10px;max-width:100%;min-height:0;overflow-x:hidden;overflow-y:auto;padding:8px}.word-meaning-modal-reading{color:#888;flex-shrink:0;font-size:20px;margin-bottom:8px}.word-meaning-modal-actions{align-items:center;display:flex;flex-shrink:0;justify-content:center;margin-bottom:20px;margin-top:20px}.word-meaning-modal-close-btn{background:#007bff;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:16px;min-width:-webkit-fit-content;min-width:fit-content;padding:10px 20px}.word-meaning-modal-close-btn:hover{background:#0069d9}.flashcard-page{box-sizing:border-box;display:flex;flex-direction:column;flex-grow:1;height:calc(100vh - 70px);margin:0 auto;max-width:100%;overflow-y:auto;padding:0 30px}.flashcard-page__title{font-size:1.5rem;margin-bottom:1rem;text-align:center}.flashcard-stats{grid-gap:.5rem;display:grid;gap:.5rem;grid-template-columns:repeat(auto-fit,minmax(70px,1fr));margin-bottom:1rem}.flashcard-stats__item{background:#f9f9f9;font-size:.9rem;padding:.75rem;text-align:center}.flashcard-stats__label{font-size:.8rem;font-weight:700}.flashcard-rating--again{color:#d32f2f}.flashcard-rating--hard{color:#e65100}.flashcard-rating--good{color:#f9a825}.flashcard-rating--easy{color:#2e7d32}.flashcard-stats__count{font-size:1.2rem;font-weight:700}.flashcard-toolbar{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.flashcard-toolbar__actions{display:flex;flex-wrap:wrap;gap:.5rem}.flashcard-btn{background:#fff;border:1px solid #ccc;border-radius:4px;cursor:pointer;font-size:.9rem;padding:.5rem 1rem}.flashcard-btn:disabled{background:#f5f5f5;cursor:not-allowed;opacity:.6}.flashcard-btn--full{width:100%}.flashcard-btn--show-answer{font-size:1rem;padding:.75rem 1.5rem}.flashcard-btn--rating{padding:.75rem .5rem}.flashcard-btn--small{font-size:.8rem;padding:.25rem .5rem}.flashcard-btn--danger{color:#d32f2f}.flashcard-import-label{display:inline-block}.flashcard-file-input{display:none}.flashcard-error-text{color:red}.flashcard-error-text--small{font-size:.8rem}.flashcard-section{margin-bottom:1rem}.flashcard-special-panel{background:#f9f9f9;border:1px solid #ddd;border-radius:8px;margin-top:1rem;padding:1rem}.flashcard-special-panel__title{font-size:1rem;margin:0 0 1rem}.flashcard-special-panel__desc{color:#666;font-size:.9rem;margin-bottom:1rem}.flashcard-card-list{display:flex;flex-direction:column;gap:.5rem}.flashcard-card-item{background:#fff;border:1px solid #ccc;border-radius:8px;padding:.75rem}.flashcard-card-item--special{border-color:#ddd;border-radius:6px}.flashcard-card-header{align-items:center;display:flex;margin-bottom:.5rem}.flashcard-badge{border-radius:4px;font-size:.8rem;padding:.25rem .5rem}.flashcard-badge--spaced{margin-left:.5rem}.flashcard-badge--type{background:#e3f2fd;color:#666}.flashcard-badge--special{background:#ff6b35;color:#fff}.flashcard-badge--verb-regular{background:#28a745;color:#fff}.flashcard-badge--verb-irregular{background:#dc3545;color:#fff}.flashcard-badge--study{font-size:.7rem;font-weight:700;position:absolute;right:.5rem;top:.5rem}.flashcard-meta{color:#666;font-size:.8rem;margin-left:.5rem}.flashcard-field{margin-bottom:.5rem}.flashcard-field__label{font-size:.9rem;font-weight:700}.flashcard-field__value{font-size:.9rem}.flashcard-field__value--muted{color:#666}.flashcard-field__meta{color:#666;font-size:.8rem}.flashcard-empty-message{color:#666;font-size:.9rem;padding:1rem;text-align:center}.flashcard-all-view{margin-bottom:2rem}.flashcard-all-toolbar{align-items:center;display:flex;gap:1rem;margin-bottom:.5rem}.flashcard-all-select{align-items:center;display:flex;gap:.5rem}.flashcard-all-select--disabled{cursor:not-allowed;opacity:.6}.flashcard-checkbox{margin:0}.flashcard-checkbox--spaced{margin-right:.5rem}.flashcard-select-label{font-size:.9rem;font-weight:700}.flashcard-selected-count{color:#888;font-size:.8rem}.flashcard-category{font-size:.8rem;font-weight:700}.flashcard-card-actions{display:flex;flex-wrap:wrap;gap:.25rem}.flashcard-input{border:1px solid #ccc;border-radius:4px;box-sizing:border-box;font-size:.9rem;padding:.75rem;width:100%}.flashcard-input--inline{padding:.25rem}.flashcard-study{margin-bottom:1.5rem}.flashcard-direction{margin-bottom:.75rem}.flashcard-direction__label{font-size:.9rem;font-weight:700}.flashcard-direction__select{border:1px solid #ccc;border-radius:4px;font-size:.9rem;margin-left:.5rem;padding:.25rem}.flashcard-prompt{align-items:center;background:#f9f9f9;border-radius:8px;display:flex;font-size:1.2rem;justify-content:center;margin-bottom:1rem;min-height:80px;padding:1rem;position:relative;text-align:center}.flashcard-ratings{grid-gap:.5rem;display:grid;gap:.5rem;grid-template-columns:repeat(2,1fr)}.flashcard-add-form{margin-bottom:1rem}.flashcard-separator{border:none;border-top:1px solid #eee;margin:1.5rem 0}.flashcard-add-form__title{font-size:1.2rem;margin-bottom:.5rem}.flashcard-add-form__subtitle{color:#666;font-size:.9rem;line-height:1.4;margin:0 0 1rem}.flashcard-textarea{border:1px solid #ccc;border-radius:4px;box-sizing:border-box;font-family:inherit;font-size:.9rem;min-height:8rem;padding:.75rem;resize:vertical;width:100%}.flashcard-status{color:#2e7d32;font-size:.9rem;margin-bottom:.75rem}.flashcard-load-more{margin-top:1rem}.flashcard-warning{color:orange;font-weight:700}.flashcard-form-group,.flashcard-warning{margin-bottom:.75rem}.flashcard-form-label{display:block;font-size:.9rem;font-weight:700;margin-bottom:.25rem}.unit-info-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.unit-info-dialog{background:#fff;border-radius:12px;box-shadow:0 20px 40px #0003;max-height:80vh;max-width:500px;overflow:hidden;width:100%}.unit-info-header{align-items:center;border-bottom:1px solid #eee;display:flex;padding:20px;position:relative}.unit-info-icon{align-items:center;border-radius:8px;display:flex;font-size:1.5rem;height:48px;justify-content:center;overflow:hidden;width:48px}.unit-info-image{border-radius:8px;height:100%;object-fit:cover;width:100%}.unit-info-title{flex:1 1;text-align:center}.unit-info-title h2{color:#333;font-size:1.5rem;margin:0 0 4px}.unit-info-goal{background:#f5f5f5;border-left:3px solid #8b4513;border-radius:6px;color:#8b4513;font-size:.85rem;font-style:italic;margin:8px 0 0;padding:8px 12px;text-align:left}.unit-info-content{max-height:60vh;overflow-y:auto;padding:20px}.unit-info-description h3{color:#333;font-size:1.1rem;margin:0 0 12px}.unit-info-description p{color:#666;line-height:1.5;margin:0 0 24px}.unit-info-words h3{color:#333;font-size:1.1rem;margin:0 0 16px}.unit-words-list{grid-gap:8px;display:grid;gap:8px;grid-template-columns:1fr 1fr}.unit-word-item{align-items:center;background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;display:flex;justify-content:space-between;padding:12px;transition:all .2s}.unit-word-item.known{background:#d4edda;border-color:#c3e6cb}.unit-word-item.unknown{filter:blur(4px);opacity:.5}.unit-word-text{color:#333;font-size:1.1rem;font-weight:600}.unit-info-quest-stage h3{color:#333;font-size:1.1rem;margin:0 0 16px}.quest-stage-preview{display:flex;justify-content:center;margin-bottom:24px}.quest-stage-preview-container{border:2px solid #e9ecef;border-radius:12px;box-shadow:0 4px 12px #00000026;height:100%;overflow:hidden;position:relative;width:100%}.quest-stage-preview-background{height:100%;left:0;object-fit:cover;position:absolute;top:0;width:100%}.quest-stage-preview-overlay{height:100%;left:0;pointer-events:none;position:absolute;top:0;width:100%}.quest-stage-preview-foreground{z-index:2}.quest-stage-preview-foreground,.quest-stage-preview-koko{height:100%;left:0;object-fit:cover;position:absolute;top:0;width:100%}.quest-stage-preview-koko{z-index:1}.quest-stage-preview-scene{height:100%;object-fit:cover;width:100%}.unit-info-footer{border-top:1px solid #eee;display:flex;gap:12px;justify-content:center;padding:20px;text-align:center}.unit-info-close-btn{background:#6c757d;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:12px 24px;transition:background-color .2s}.unit-info-close-btn:hover{background:#5a6268}.unit-info-start-btn{background:#ff6b35;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:12px 24px;transition:background-color .2s}.unit-info-start-btn:hover{background:#e55a2b}@media (max-width:768px){.unit-info-overlay{padding:16px}.unit-info-dialog{max-height:90vh}.unit-info-content,.unit-info-footer,.unit-info-header{padding:16px}}.learning-units-page{display:flex;flex-direction:column;flex-grow:1;height:calc(100vh - 70px)}.learning-units-content{margin:0 auto;max-width:1200px}.learning-units-header{margin-bottom:40px;text-align:center}.learning-units-header h1{color:#333;font-size:2.5rem;margin-bottom:10px}.learning-units-header p{color:#666;font-size:1.1rem;margin:0}.learning-units-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin:0 auto;max-width:800px}.learning-units-loading{align-items:center;color:#666;display:flex;flex-direction:column;height:50vh;justify-content:center}.loading-spinner{border:4px solid #f3f3f3;border-top-color:#ff6b35;height:40px;margin-bottom:16px;width:40px}@media (max-width:768px){.learning-units-header h1{font-size:2rem}.learning-units-header p{font-size:1rem}.learning-units-grid{gap:24px;grid-template-columns:repeat(2,1fr)}}@media (min-width:769px) and (max-width:1024px){.learning-units-grid{grid-template-columns:repeat(2,1fr)}}.journey-map-section{text-align:center}.journey-map-title{color:#333;font-size:1.5rem;margin-bottom:20px}.journey-map-wrapper{display:inline-block;max-width:100%;position:relative}.journey-map-image{display:block;height:auto;max-width:100%;vertical-align:top}.journey-map-area{background:#0000;border:none;cursor:pointer;margin:0;padding:0;position:absolute;transition:background-color .2s ease}.journey-map-area:hover{background-color:#667eea26}.journey-map-area:focus{outline:2px solid #667eea99;outline-offset:2px}.journey-map-overlay{background-color:#fff9;border:none;border-radius:4px;cursor:not-allowed;margin:0;padding:0;pointer-events:auto;position:absolute}.learning-units-free-chat{margin-left:auto;margin-right:auto;max-width:400px}.unit-chat-container{display:flex;flex-direction:column;height:calc(100vh - 70px);margin:0 auto;max-width:1000px;overflow:hidden}.unit-chat-container>.quest-stage-container{flex-shrink:0}.unit-chat-container>.chat-container{flex:1 1;height:auto;min-height:0}.confetti-overlay{align-items:center;bottom:0;display:flex;justify-content:center;left:0;pointer-events:none;position:fixed;right:0;top:0;z-index:9999}.unit-completed-message{animation:bounceIn .6s ease-out;background:#fffffff2;border-radius:16px;box-shadow:0 20px 40px #0003;padding:40px;pointer-events:auto;text-align:center}.unit-completed-message h1{color:#28a745;font-size:2.5rem;font-weight:700;margin:0 0 16px}.unit-completed-message p{color:#666;font-size:1.2rem;margin:0}@keyframes bounceIn{0%{opacity:0;transform:scale(.3)}50%{transform:scale(1.05)}70%{transform:scale(.9)}to{opacity:1;transform:scale(1)}}.audio-enable-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000c;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:10000}.audio-enable-content{animation:slideInUp .5s ease-out;background:#fff;border-radius:16px;box-shadow:0 20px 40px #0000004d;margin:20px;max-width:400px;padding:30px;text-align:center}.audio-enable-content h2{color:#333;font-size:1.5rem;font-weight:700;margin:0 0 25px}.audio-enable-content p{color:#666;font-size:1.1rem;line-height:1.5;margin:0 0 24px}.audio-enable-button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:12px;box-shadow:0 4px 15px #667eea66;color:#fff;cursor:pointer;font-size:1.2rem;font-weight:700;padding:16px 32px;transition:all .3s ease}.audio-enable-button:hover{box-shadow:0 6px 20px #667eea99;transform:translateY(-2px)}.audio-enable-button:active{transform:translateY(0)}@keyframes slideInUp{0%{opacity:0;transform:translateY(50px)}to{opacity:1;transform:translateY(0)}}@media (max-width:768px){.unit-chat-container{display:flex;flex-direction:column;height:calc(100vh - 70px);margin:0;overflow:hidden}.unit-completed-message{margin:20px;padding:24px}.unit-completed-message h1{font-size:2rem}.unit-completed-message p{font-size:1rem}.audio-enable-content{margin:16px;padding:24px}.audio-enable-content h2{font-size:1.5rem}.audio-enable-content p{font-size:1rem}.audio-enable-button{font-size:1.1rem;padding:12px 24px}}.free-chat-container{display:flex;flex-direction:column;height:100vh;margin:0 auto;max-width:1000px;overflow:hidden}.free-chat-container>.quest-stage-container{flex-shrink:0}.free-chat-container>.chat-container,.free-chat-container>.review-quiz-page.chat-container{flex:1 1;height:auto;min-height:0}@media (max-width:768px){.free-chat-container{display:flex;flex-direction:column;height:calc(100vh - 70px);margin:0;overflow:hidden}}.admin-page{margin:0 auto;max-width:1200px;padding:20px}.admin-header{margin-bottom:30px;text-align:center}.admin-header h1{color:#333;font-size:2.5rem;margin-bottom:10px}.admin-header p{color:#666;font-size:1.1rem}.access-denied{color:#666;padding:60px 20px;text-align:center}.access-denied h2{color:#c33;margin-bottom:20px}.loading{color:#666;font-size:1.2rem;padding:60px 20px;text-align:center}.error-message{background:#fee;border:1px solid #fcc;border-radius:8px;color:#c33;margin-bottom:20px;padding:12px 16px}.success-message{background:#efe;border:1px solid #c8e6c9;color:#2e7d32}.stats-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:30px}.stat-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:20px;text-align:center;transition:transform .2s ease}.stat-card:hover{transform:translateY(-2px)}.stat-card h3{color:#666;font-size:.9rem;letter-spacing:.5px;margin-bottom:10px;text-transform:uppercase}.stat-number{color:#333;font-size:2rem;font-weight:700;margin:0}.filters-section{display:flex;flex-wrap:wrap;gap:15px;margin-bottom:30px}.filter-group{flex:1 1;min-width:200px}.filter-input,.filter-select{border:1px solid #ddd;border-radius:6px;font-size:1rem;padding:10px 12px;transition:border-color .2s ease;width:100%}.filter-input:focus,.filter-select:focus{border-color:#007bff;box-shadow:0 0 0 3px #007bff1a;outline:none}.users-section{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:20px}.users-section h2{color:#333;font-size:1.5rem;margin-bottom:20px}.users-table{overflow-x:auto}.users-table table{border-collapse:collapse;font-size:.9rem;width:100%}.users-table td,.users-table th{border-bottom:1px solid #eee;padding:12px;text-align:left}.users-table th{color:#333;font-weight:600}.users-table th,.users-table tr:hover{background:#f8f9fa}.users-table tr.suspended{background:#fff5f5;opacity:.6}.role-badge,.status-badge{border-radius:12px;font-size:.8rem;font-weight:500;padding:4px 8px;text-transform:uppercase}.role-badge.admin{background:#e3f2fd;color:#1976d2}.role-badge.user{background:#f3e5f5;color:#7b1fa2}.status-badge.active{background:#e8f5e8;color:#2e7d32}.status-badge.suspended{background:#ffebee;color:#c62828}.action-buttons{display:flex;flex-wrap:wrap;gap:8px}.action-btn{align-items:center;background:none;border:none;border-radius:4px;cursor:pointer;display:flex;font-size:1rem;height:32px;justify-content:center;padding:6px;transition:all .2s ease;width:32px}.action-btn:hover:not(:disabled){background:#f0f0f0;transform:scale(1.1)}.action-btn:disabled{cursor:not-allowed;opacity:.5;transform:none}.action-btn.suspend:hover{background:#fff3cd;color:#856404}.action-btn.unsuspend:hover{background:#d4edda;color:#155724}.action-btn.promote:hover{background:#d1ecf1;color:#0c5460}.action-btn.delete:hover,.action-btn.demote:hover{background:#f8d7da;color:#721c24}.pagination{align-items:center;border-top:1px solid #eee;display:flex;gap:15px;justify-content:center;margin-top:20px;padding-top:20px}.page-btn{background:#007bff;border:none;border-radius:6px;color:#fff;cursor:pointer;padding:8px 16px;transition:all .2s ease}.page-btn:hover:not(:disabled){background:#0056b3}.page-btn:disabled{background:#6c757d;cursor:not-allowed}.page-info{color:#666;font-size:.9rem}.modal-content{max-width:600px;width:100%}.modal-header{align-items:center;border-bottom:1px solid #eee;display:flex;justify-content:space-between;padding:20px}.modal-header h3{color:#333;margin:0}.close-btn{background:none;border:none;border-radius:4px;color:#666;cursor:pointer;font-size:24px;padding:4px;transition:all .2s ease}.close-btn:hover{background:#f5f5f5;color:#333}.modal-body{padding:20px}.user-details{grid-gap:15px;display:grid;gap:15px}.detail-group{align-items:center;border-bottom:1px solid #f0f0f0;display:flex;justify-content:space-between;padding:10px 0}.detail-group:last-child{border-bottom:none}.detail-group label{color:#333;font-weight:600;min-width:120px}.detail-group span{color:#666;text-align:right}.detail-section{border-top:1px solid #eee;margin-top:20px;padding-top:20px}.detail-section h4{color:#333;font-size:1.1rem;margin-bottom:15px}.stats-grid-small{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));margin-bottom:20px}.stat-item{align-items:center;background:#f8f9fa;border-radius:6px;display:flex;justify-content:space-between;padding:10px}.stat-item label{color:#333;font-size:.9rem;font-weight:500}.stat-item span{color:#007bff;font-weight:600}.language-profiles-list{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));max-height:300px;overflow-y:auto}.language-profile-item{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;display:flex;flex-direction:column;justify-content:space-between;min-height:80px;padding:12px}.profile-header{gap:10px;margin-bottom:8px}.profile-flag{flex-shrink:0;height:auto;width:24px}.profile-name{color:#333;flex:1 1;font-size:.9rem;font-weight:600}.profile-details{align-items:center;color:#666;display:flex;font-size:.85rem;justify-content:space-between;margin-top:auto}.profile-created{font-size:.8rem}.no-profiles-message{background:#f8f9fa;border:1px dashed #dee2e6;border-radius:6px;color:#666;grid-column:1/-1;padding:20px;text-align:center}.no-profiles-message p{font-style:italic;margin:0}.form-group label{font-weight:600}.form-textarea{border:1px solid #ddd;border-radius:6px;font-family:inherit;font-size:1rem;padding:10px 12px;resize:vertical;transition:border-color .2s ease;width:100%}.form-textarea:focus{border-color:#007bff;box-shadow:0 0 0 3px #007bff1a;outline:none}.modal-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:20px}.cancel-btn,.suspend-btn{border:none;border-radius:6px;cursor:pointer;font-size:1rem;font-weight:500;padding:10px 20px;transition:all .2s ease}.cancel-btn{background:#6c757d;color:#fff}.cancel-btn:hover{background:#545b62}.suspend-btn{background:#dc3545;color:#fff}.suspend-btn:hover{background:#c82333}@media (max-width:768px){.admin-page{padding:10px}.admin-header h1{font-size:2rem}.stats-grid{gap:15px;grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.filters-section{flex-direction:column}.filter-group{min-width:auto}.users-table{font-size:.8rem}.users-table td,.users-table th{padding:8px}.action-buttons{flex-direction:column;gap:4px}.action-btn{font-size:.9rem;height:28px;width:28px}.modal-content{margin:10px;max-width:none}.detail-group{align-items:flex-start;flex-direction:column;gap:5px}.detail-group label{min-width:auto}.detail-group span{text-align:left}.language-profiles-list{grid-template-columns:1fr}.language-profile-item{min-height:70px;padding:10px}.profile-name{font-size:.85rem}.profile-details{font-size:.8rem}}.sessions-management{max-height:60vh;overflow-y:auto}.sessions-summary{background:#f8f9fa;border-radius:8px;margin-bottom:20px;padding:15px}.sessions-summary p{color:#666;margin:5px 0}.language-sessions h4{color:#333;font-size:1.2rem;margin-bottom:15px}.language-session-group{border:1px solid #e0e0e0;border-radius:8px;margin-bottom:15px;overflow:hidden}.language-header{align-items:center;background:#f8f9fa;border-bottom:1px solid #e0e0e0;display:flex;gap:10px;padding:12px 15px}.language-flag{flex-shrink:0;height:auto;width:24px}.language-name{color:#333;flex:1 1;font-weight:600}.session-count{background:#007bff;border-radius:12px;color:#fff;font-size:.8rem;font-weight:500;padding:4px 8px}.session-details{background:#fff;padding:10px 15px}.session-item{align-items:center;border-bottom:1px solid #f0f0f0;display:flex;justify-content:space-between;padding:8px 0}.session-item:last-child{border-bottom:none}.session-info{color:#666;font-size:.9rem}.session-status{border-radius:8px;font-size:.8rem;font-weight:500;padding:2px 6px}.session-status.active{background:#e8f5e8;color:#2e7d32}.session-status.inactive{background:#ffebee;color:#c62828}.language-actions{background:#f8f9fa;border-top:1px solid #e0e0e0;padding:10px 15px}.delete-language-sessions-btn{background:#dc3545;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.9rem;padding:8px 16px;transition:background-color .2s ease;width:100%}.delete-language-sessions-btn:hover:not(:disabled){background:#c62828}.delete-language-sessions-btn:disabled{background:#6c757d;cursor:not-allowed}.no-sessions{color:#666;padding:40px 20px;text-align:center}.no-sessions p{font-size:1.1rem;margin:0}.searchable-language-select{position:relative}.searchable-language-input{border:2px solid #e1e5e9;border-radius:10px;box-sizing:border-box;font-size:1rem;padding:12px 16px;transition:border-color .2s ease,box-shadow .2s ease;width:100%}.searchable-language-input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.searchable-language-list{background:#fff;border:1px solid #d0d4e4;border-radius:10px;box-shadow:0 8px 24px #1a1a2e1f;left:0;list-style:none;margin:0;max-height:220px;overflow-y:auto;padding:6px 0;position:absolute;right:0;top:calc(100% + 4px);z-index:10}.searchable-language-option{color:#1a1a2e;cursor:pointer;font-size:.95rem;padding:10px 16px}.searchable-language-option-highlighted,.searchable-language-option:hover{background:#f3f5ff}.searchable-language-option-selected{color:#667eea;font-weight:600}.searchable-language-empty{color:#6b6b88;font-size:.95rem;padding:12px 16px}.request-language-modal{max-width:440px;overflow:visible;padding:0;width:100%}.request-language-modal-header{align-items:center;display:flex;gap:16px;justify-content:space-between;padding:24px 24px 0}.request-language-modal-header h2{color:#1a1a2e;font-size:1.35rem;margin:0}.request-language-close{align-items:center;background:#0000;border:none;border-radius:8px;color:#4a4a68;cursor:pointer;display:flex;flex-shrink:0;font-size:1.6rem;height:36px;justify-content:center;line-height:1;width:36px}.request-language-close:hover{background:#f3f5ff}.request-language-body{padding:20px 24px 24px}.request-language-lead{color:#4a4a68;font-size:.98rem;line-height:1.55;margin:0 0 20px}.request-language-body .form-group{margin-bottom:18px}.request-language-body .form-group label{color:#333;display:block;font-size:.9rem;font-weight:500;margin-bottom:8px}.request-language-body .form-input{border:2px solid #e1e5e9;border-radius:10px;box-sizing:border-box;font-size:1rem;padding:12px 16px;transition:border-color .2s ease,box-shadow .2s ease;width:100%}.request-language-body .form-input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.request-language-body .error-message{background:#fee;border:1px solid #fcc;border-radius:8px;color:#c33;font-size:.9rem;margin-bottom:20px;padding:12px 16px}.request-language-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:24px}.request-language-success{background:#edf7f1;border:1px solid #b7e4c7;border-radius:10px;color:#2d6a4f;line-height:1.5;margin:0 0 20px;padding:14px 16px}.landing-page{background:#fafbff;color:#1a1a2e;line-height:1.6;min-height:100vh}.landing-section-inner{margin:0 auto;max-width:1080px;padding:0 24px}.landing-header{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffffeb;border-bottom:1px solid #667eea1f;position:-webkit-sticky;position:sticky;top:0;z-index:100}.landing-header-inner{align-items:center;display:flex;gap:16px;justify-content:space-between;margin:0 auto;max-width:1080px;padding:14px 24px}.landing-brand{align-items:center;color:inherit;display:flex;gap:12px;min-width:0;text-decoration:none}.landing-logo{border-radius:10px;flex-shrink:0;height:40px;width:40px}.landing-brand-name{font-size:1rem;font-weight:700;line-height:1.2}.landing-header-actions{display:flex;flex-shrink:0;gap:10px}.landing-btn{align-items:center;border:none;border-radius:10px;box-sizing:border-box;cursor:pointer;display:inline-flex;font-size:.95rem;font-weight:600;justify-content:center;padding:10px 18px;text-decoration:none;transition:transform .2s ease,box-shadow .2s ease,background .2s ease;white-space:nowrap}.landing-btn:hover{transform:translateY(-1px)}.landing-btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 4px 14px #667eea59;color:#fff}.landing-btn-primary:hover{box-shadow:0 8px 22px #667eea66}.landing-btn-secondary{background:#fff;color:#5b6fd6}.landing-btn-secondary:hover{background:#f3f5ff}.landing-btn-ghost{background:#0000;color:#4a4a68}.landing-btn-ghost:hover{background:#f0f2ff}.landing-btn-large{font-size:1rem;padding:14px 24px}.landing-hero{background:linear-gradient(160deg,#12122a,#1e1c42 50%,#161432);color:#fff;padding:72px 0 80px}.landing-hero-inner{text-align:center}.landing-eyebrow{font-size:.95rem;font-weight:500;letter-spacing:.02em;margin:0 0 16px;opacity:.9}.landing-hero h1{font-size:clamp(2.2rem,5vw,3.4rem);font-weight:800;line-height:1.15;margin:0 0 20px;text-shadow:0 2px 12px #00000026}.landing-hero-lead{font-size:clamp(1.05rem,2.2vw,1.25rem);margin:0 auto 32px;max-width:720px;opacity:.95}.landing-hero-actions{display:flex;flex-wrap:wrap;gap:14px;justify-content:center}.landing-hero-actions--stacked{align-items:stretch;flex-direction:column;margin:0 auto;max-width:280px}.landing-hero-actions--stacked .landing-btn-large{width:100%}.landing-hero-note{font-size:.9rem;margin:24px 0 0;opacity:.85}.landing-section{padding:72px 0}.landing-section h2{color:#1a1a2e;font-size:clamp(1.6rem,3vw,2.2rem);line-height:1.25;margin:0 0 24px}.landing-prose p{color:#3d3d5c;font-size:1.05rem;margin:0 0 16px}.landing-prose p:last-child{margin-bottom:0}.landing-solution{background:#fff}.landing-benefits{grid-gap:20px;counter-reset:landing-point;display:grid;gap:20px}.landing-benefit{grid-column-gap:20px;grid-row-gap:8px;background:#fff;border:1px solid #667eea24;border-radius:16px;box-shadow:0 4px 20px #1a1a2e0f;column-gap:20px;counter-increment:landing-point;display:grid;grid-template-columns:52px 1fr;padding:24px 28px;row-gap:8px}.landing-benefit:before{align-items:center;align-self:start;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;box-shadow:0 4px 12px #667eea4d;color:#fff;content:counter(landing-point);display:flex;font-size:1.15rem;font-weight:700;grid-row:1/span 2;height:44px;justify-content:center;line-height:1;width:44px}.landing-benefit h3{color:#1a1a2e;font-size:1.15rem;grid-column:2;line-height:1.35;margin:0;padding-top:8px}.landing-benefit p{color:#4a4a68;font-size:1.02rem;grid-column:2;line-height:1.65;margin:0}.landing-features{background:#f3f5ff}.landing-feature-list{grid-gap:48px;display:grid;gap:48px;margin-top:40px}.landing-feature{grid-gap:32px;align-items:center;display:grid;gap:32px;grid-template-columns:1fr 1fr}.landing-feature-reverse .landing-feature-copy{order:2}.landing-feature-reverse .landing-feature-media{order:1}.landing-feature-copy h3{color:#1a1a2e;font-size:1.35rem;margin:0 0 12px}.landing-feature-copy p{color:#4a4a68;font-size:1.02rem;margin:0}.landing-feature-media{background:#fff;border:1px solid #d0d4e4;border-radius:16px;box-shadow:0 16px 40px #1a1a2e24;max-height:350px;overflow:hidden}.landing-feature-media img{display:block;height:auto;max-height:350px;vertical-align:middle;width:100%}.landing-ci{background:#fff}.landing-ci-inner{grid-gap:40px;align-items:center;display:grid;gap:40px;grid-template-columns:1.2fr .8fr}.landing-ci-copy p{color:#3d3d5c;font-size:1.05rem;margin:0 0 16px}.landing-ci-copy p:last-child{margin-bottom:0}.landing-ci-visual{align-items:center;background:#0000;display:flex;justify-content:center}.landing-ci-stage{background:#fff;border:1px solid #d0d4e4;border-radius:16px;box-shadow:0 16px 40px #1a1a2e24;max-width:320px;overflow:hidden;position:relative;width:100%}.landing-ci-stage-bg{display:block;height:auto;width:100%}.landing-ci-stage-overlay{height:100%;inset:0;pointer-events:none;position:absolute;width:100%}.landing-ci-stage-koko{height:100%;inset:0;object-fit:contain;position:absolute;width:100%}.landing-spot-visual{background:#0000;padding:32px 0}.landing-spot-visual-inner{align-items:center;display:flex;justify-content:center}.landing-spot-visual-inner img{height:auto;max-width:220px;width:100%}.landing-overview-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(2,1fr)}.landing-overview-card{background:#fff;border:1px solid #667eea26;border-radius:14px;box-shadow:0 4px 16px #1a1a2e0d;padding:24px}.landing-overview-card h3{color:#667eea;font-size:1rem;letter-spacing:.04em;margin:0 0 10px;text-transform:uppercase}.landing-overview-card p{color:#4a4a68;font-size:.98rem;margin:0}.landing-overview-request-btn{background:#f3f5ff;border:1px solid #c8d0f8;border-radius:10px;color:#5b6fd6;cursor:pointer;font-size:.92rem;font-weight:600;margin-top:16px;padding:10px 16px;transition:background .2s ease,transform .2s ease,border-color .2s ease}.landing-overview-request-btn:hover{background:#e8ecff;border-color:#a8b4f0;transform:translateY(-1px)}.landing-language-flag{display:inline-block;height:auto;object-fit:contain;vertical-align:-.1em;width:20px}.landing-cta{background:linear-gradient(160deg,#12122a,#1e1c42 50%,#161432);color:#fff}.landing-cta h2{color:#fff}.landing-cta-inner{text-align:center}.landing-cta p{font-size:1.08rem;margin:0 auto 28px;max-width:620px;opacity:.95}.landing-footer{background:#1a1a2e;color:#ffffffbf;font-size:.9rem;padding:28px 0 36px}.landing-footer-inner{align-items:center;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between}.landing-footer p{margin:0}.landing-footer a{color:#b8c4ff;text-decoration:none}.landing-footer-discord{align-items:center;display:inline-flex;gap:8px}.landing-footer-discord-icon{flex-shrink:0;height:18px;width:18px}.landing-footer a:hover{text-decoration:underline}@media (max-width:900px){.landing-ci-inner,.landing-feature,.landing-overview-grid{grid-template-columns:1fr}.landing-feature-reverse .landing-feature-copy,.landing-feature-reverse .landing-feature-media{order:0}.landing-ci-visual{order:-1}}@media (max-width:640px){.landing-header-inner{padding:12px 16px}.landing-brand-name{display:none}.landing-section-inner{padding:0 16px}.landing-hero{padding:56px 0 64px}.landing-section{padding:56px 0}.landing-header-actions .landing-btn-ghost{display:none}.landing-hero-actions{align-items:stretch;flex-direction:column}.landing-btn-large{width:100%}}body,html{height:100%;margin:0;padding:0}#root{display:flex;flex-direction:column;height:100vh}@media (min-width:769px){#root{align-items:center;background:#d8d8d8}.app-shell{background:#fff;box-shadow:0 0 24px #0000001f;display:flex;flex-direction:column;height:100vh;max-width:100%;overflow:hidden;width:430px}#root:has(.app-shell--full-width){align-items:stretch;background:#fff}.app-shell--full-width{box-shadow:none;max-width:none;width:100%}.app-shell-content{display:flex;flex:1 1;flex-direction:column;min-height:0;overflow:hidden}.app-shell-content>*{flex:1 1;min-height:0;overflow:auto}}@media (max-width:768px){.app-shell{display:flex;flex-direction:column;height:100vh}.app-shell-content{display:flex;flex:1 1;flex-direction:column;min-height:0;overflow:hidden}.app-shell--full-width .app-shell-content{-webkit-overflow-scrolling:touch;overflow-y:auto}.app-shell--full-width .app-shell-content>*{flex:none;min-height:auto;overflow:visible}}.App{text-align:center}.App-logo{height:40vmin;pointer-events:none}@media (prefers-reduced-motion:no-preference){.App-logo{animation:App-logo-spin 20s linear infinite}}.App-header{background-color:#282c34;color:#fff;padding:20px}.App-link{color:#61dafb}@keyframes App-logo-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.app-navigation{align-items:center;background:#fff;box-shadow:0 2px 10px #0000001a;display:flex;height:50px;justify-content:space-between;padding:0 10px;position:-webkit-sticky;position:sticky;top:0;z-index:1000}.nav-brand,.nav-brand-link{align-items:center;display:flex;gap:10px}.nav-brand-link{color:inherit;text-decoration:none;transition:opacity .3s ease}.nav-brand-link:hover{opacity:.8}.nav-logo{height:40px;width:40px}.nav-title{color:#333;font-size:1.5rem;font-weight:700}.nav-links{display:none}.nav-link{border-radius:8px;color:#333;font-weight:500;padding:8px 16px;text-decoration:none;transition:all .3s ease}.nav-link:hover{background:#f0f0f0;color:#667eea}.nav-user{display:none}.user-greeting{color:#666;font-size:.9rem}.logout-btn{background:#ff4757;border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:500;padding:8px 16px;transition:all .3s ease}.logout-btn:hover{background:#ff3742;transform:translateY(-1px)}.home-container{background:linear-gradient(135deg,#f5f7fa,#c3cfe2);flex-grow:1}.home-container,.home-content{display:flex;flex-direction:column}.home-content{justify-content:flex-start;margin:0 auto;max-width:1200px;padding:20px;text-align:center}.home-content h1{color:#333;font-size:3rem;font-weight:700;margin-bottom:10px}.home-subtitle{color:#666;font-size:1.2rem;margin-bottom:40px}.user-welcome{background:#fff;border-radius:15px;box-shadow:0 5px 15px #0000001a;display:inline-block;margin-bottom:40px;padding:20px}.user-welcome p{color:#333;font-size:1.1rem;margin:0}.feature-grid{grid-gap:30px;display:grid;gap:30px;margin-top:20px}.feature-card{background:#fff;border-radius:15px;box-shadow:0 5px 15px #0000001a;padding:30px;transition:all .3s ease}.feature-card:hover{box-shadow:0 10px 25px #00000026;transform:translateY(-5px)}.feature-card-clickable{cursor:pointer}.feature-card h3{color:#333;font-size:1.5rem;margin-bottom:15px}.feature-card p{color:#666;line-height:1.6;margin-bottom:20px}.feature-link{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;box-sizing:border-box;color:#fff;cursor:pointer;display:flex;font-size:1rem;font-weight:600;justify-content:center;padding:12px 20px;text-decoration:none;transition:all .3s ease}.feature-link:hover:not(:disabled){box-shadow:0 5px 15px #667eea4d;transform:translateY(-2px)}.feature-link:disabled{cursor:not-allowed;opacity:.6}.profile-container{margin-top:40px;max-width:800px;padding:0 20px}.profile-header{align-items:center;display:flex;justify-content:space-between}.profile-header h2{color:#333;margin:0}.logout-button{background:#ff4757;border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:500;padding:10px 20px}.profile-info{background:#fff;border-radius:10px;box-shadow:0 2px 10px #0000001a;display:flex;flex-direction:column;gap:0;margin:10px;padding:20px}.info-group{align-items:center!important;background-color:#f9f9f9!important;border-bottom:1px solid #eee;display:flex!important;flex-direction:row!important;gap:15px!important;justify-content:space-between!important;margin-bottom:5px!important;padding:12px 0!important}.info-group:last-child{border-bottom:none}.info-group label{color:#333;display:block;flex-shrink:0;font-weight:600;margin:0;min-width:120px;padding:0}.info-group span{color:#666;display:block;flex:1 1;margin:0;padding:0;text-align:right}.profile-form{background:#fff;padding:20px}.form-section{margin-bottom:30px}.form-section h3{border-bottom:2px solid #667eea;color:#333;padding-bottom:10px}.form-group,.form-section h3{margin-bottom:20px}.form-group label{color:#333;display:block;font-weight:500;margin-bottom:8px}.voice-speed-slider-row{align-items:center;display:flex;gap:12px}.voice-speed-end-icon{display:block;flex-shrink:0;height:auto;width:32px}.voice-speed-slider-wrap{align-items:center;display:flex;flex:1 1}.voice-speed-slider{--thumb-size:20px;-webkit-appearance:none;appearance:none;background:#0000;cursor:pointer;height:24px;margin:0 calc(var(--thumb-size)/-2);width:calc(100% + var(--thumb-size))}.voice-speed-slider:focus{outline:none}.voice-speed-slider:focus-visible::-webkit-slider-thumb{box-shadow:0 0 0 3px #007bff40}.voice-speed-slider::-webkit-slider-runnable-track{background:linear-gradient(90deg,#007bff 0,#007bff 0,#e0e0e0 0,#e0e0e0);background:linear-gradient(to right,#007bff 0,#007bff var(--speed-fill,0),#e0e0e0 var(--speed-fill,0),#e0e0e0 100%);border-radius:4px;height:8px}.voice-speed-slider::-webkit-slider-thumb{-webkit-appearance:none;background:#007bff;border:2px solid #fff;border-radius:50%;box-shadow:0 1px 4px #0003;height:var(--thumb-size);margin-top:-6px;width:var(--thumb-size)}.voice-speed-slider::-moz-range-track{background:linear-gradient(90deg,#007bff 0,#007bff 0,#e0e0e0 0,#e0e0e0);background:linear-gradient(to right,#007bff 0,#007bff var(--speed-fill,0),#e0e0e0 var(--speed-fill,0),#e0e0e0 100%);border-radius:4px;height:8px}.voice-speed-slider::-moz-range-thumb{background:#007bff;border:2px solid #fff;border-radius:50%;box-shadow:0 1px 4px #0003;height:var(--thumb-size);width:var(--thumb-size)}.form-input{border:2px solid #e1e5e9;border-radius:8px;box-sizing:border-box;font-size:1rem;padding:12px 16px;transition:all .3s ease;width:100%}.form-input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.form-input:disabled{background:#f5f5f5;cursor:not-allowed}.form-actions{display:flex;gap:15px;justify-content:flex-end}.cancel-button,.edit-button,.save-button{border:none;border-radius:8px;cursor:pointer;font-weight:600;padding:12px 24px;transition:all .3s ease}.edit-button{background:#667eea;color:#fff}.save-button{background:#28a745;color:#fff}.cancel-button{background:#6c757d;color:#fff}.cancel-button:hover,.edit-button:hover,.save-button:hover{transform:translateY(-1px)}.success-message{background:#d4edda;border:1px solid #c3e6cb;border-radius:8px;color:#155724;margin-bottom:20px;padding:12px 16px}.loading-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;flex-direction:column;justify-content:center;min-height:100vh}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:50px;margin-bottom:20px;width:50px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.mobile-menu-btn{background:none;border:none;border-radius:4px;cursor:pointer;display:block;padding:8px;transition:background-color .3s ease}.mobile-menu-btn:hover{background-color:#f0f0f0}.hamburger{display:flex;flex-direction:column;height:18px;justify-content:space-between;width:24px}.hamburger span{background-color:#333;display:block;height:2px;transform-origin:center;transition:all .3s ease;width:100%}.hamburger.open span:first-child{transform:rotate(45deg) translate(5px,5px)}.hamburger.open span:nth-child(2){opacity:0}.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(7px,-6px)}.mobile-menu-overlay{background-color:#00000080;height:100%;left:0;opacity:0;position:fixed;top:0;transition:all .3s ease;visibility:hidden;width:100%;z-index:2000}.mobile-menu-overlay.open{opacity:1;visibility:visible}.mobile-menu{background-color:#fff;box-shadow:-2px 0 10px #0000001a;display:flex;flex-direction:column;height:100%;position:fixed;right:0;top:0;transform:translateX(100%);transition:transform .3s ease;width:280px}.mobile-menu-overlay.open .mobile-menu{transform:translateX(0)}.mobile-menu-links{flex:1 1;padding:20px 0}.mobile-menu-link{align-items:center;background:none;border:none;color:#333;cursor:pointer;display:flex;font-size:1rem;font-weight:500;gap:12px;padding:16px 20px;text-align:left;text-decoration:none;transition:background-color .3s ease;width:100%}.mobile-menu-link:hover{background-color:#f0f0f0}.mobile-menu-link.logout{color:#ff4757}.mobile-menu-link.logout:hover{background-color:#fff5f5}.mobile-menu-icon{border-radius:4px;flex-shrink:0}.mobile-menu-links img.mobile-menu-icon{height:25px;object-fit:contain;width:25px}.mobile-menu-divider{background-color:#eee;height:1px;margin:8px 20px}.language-profile-btn{align-items:center;background:#f8f9fa;border:1px solid #dee2e6;border-radius:6px;cursor:pointer;display:flex;font-size:.9rem;gap:6px;padding:6px 12px;transition:all .2s ease}.language-profile-btn:hover{background:#e9ecef;border-color:#adb5bd}.nav-flag{flex-shrink:0;height:auto;margin-right:6px;width:20px}.modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:2000}.modal-content{background:#fff;border-radius:12px;box-shadow:0 4px 20px #00000026;max-height:90vh;max-width:45vw;overflow:hidden}@media (max-width:768px){.home-content h1{font-size:2rem}.feature-grid{grid-template-columns:1fr}.profile-header{gap:15px;text-align:center}.form-actions,.info-group,.profile-header{flex-direction:column}.info-group{align-items:flex-start;gap:8px}.info-group label{min-width:auto;text-align:left}.info-group span{text-align:left}}.review-quiz-page.chat-container .chat-main{display:flex;flex-direction:column;overflow:hidden;padding-top:12px}.review-quiz-page.chat-container{max-width:none}.review-quiz-title{color:#333;font-size:1.75rem;margin:0 0 8px;text-align:center}.review-quiz-muted{color:#666;line-height:1.5;text-align:center}.review-quiz-progress{color:#888;font-size:1.95rem;margin:0 0 24px;text-align:center}.review-quiz-context{display:flex;flex:1 1;flex-direction:column;gap:0;margin-bottom:24px;min-height:0;overflow-y:auto;text-align:left}.review-quiz-context .mobile-ai-message{margin:8px 0;width:100%}.review-quiz-context .review-quiz-plain-bubble{align-items:flex-start;cursor:default;justify-content:flex-start;line-height:1.6;min-height:0;min-height:auto;white-space:pre-wrap}.review-quiz-message-inline{display:block;white-space:pre-wrap;width:100%}.review-quiz-inline-input{background:#fff;border:1px solid #bbb;border-radius:6px;box-sizing:border-box;color:#222;display:inline-block;font:inherit;line-height:inherit;margin:0 2px;max-width:100%;padding:2px 6px;vertical-align:initial}.review-quiz-inline-input:focus{border-color:#667eea;box-shadow:0 0 0 2px #667eea33;outline:none}.review-quiz-inline-input:disabled{background:#f0f0f0;color:#555;cursor:not-allowed}.review-quiz-inline-input.review-quiz-inline-input--incorrect-bg:disabled{background:#f99e9e!important;border-color:#c77;color:#222!important}.review-quiz-inline-input.review-quiz-inline-input--correct-bg:disabled{background:#d3ffd7!important;border-color:#8c8;color:#222!important}.review-quiz-inline-input--fade-wrong-out{opacity:0;transition:opacity .35s ease}.review-quiz-inline-input--correct-reveal-start{opacity:0}.review-quiz-inline-input--correct-reveal-active{opacity:1;transition:opacity .35s ease}@keyframes review-quiz-shake{0%,to{transform:translateX(0)}20%{transform:translateX(-7px)}40%{transform:translateX(7px)}60%{transform:translateX(-5px)}80%{transform:translateX(5px)}}.review-quiz-context .mobile-ai-message.review-quiz-message--shake,.review-quiz-context .user-message-container.review-quiz-message--shake{animation:review-quiz-shake .5s ease}.review-quiz-controls{display:flex;flex-direction:column;flex-shrink:0;gap:12px;margin-top:auto;padding-bottom:16px}.review-quiz-debug-ease{color:#888;font-family:ui-monospace,monospace;font-size:.8rem;margin:0}.review-quiz-btn{border:none;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:600;padding:12px 20px}.review-quiz-btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.review-quiz-btn-primary:disabled{cursor:not-allowed;opacity:.55}.review-quiz-btn-secondary{background:#fff;border:1px solid #ccc;border-radius:8px;color:#444;cursor:pointer;font-size:1rem;font-weight:600;margin-top:30px;padding:12px 20px;transition:background .2s ease,border-color .2s ease}.review-quiz-btn-secondary:hover:not(:disabled){background:#f5f5f5;border-color:#bbb}.review-quiz-btn-secondary:disabled{cursor:not-allowed;opacity:.55}.review-quiz-feedback{margin-bottom:16px}.review-quiz-feedback--wrong p{color:#333;line-height:1.5;margin:0 0 12px}.review-quiz-error{color:#c62828;margin-bottom:12px}
/*# sourceMappingURL=main.58d5a63b.css.map*/