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-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{display:inline-block;font-size:24px;font-variant-emoji:emoji;margin-right:12px;min-width:24px;text-rendering:optimizeLegibility}.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{border:1px solid #ddd;border-radius:6px;font-size:1rem;padding:10px 12px;transition:border-color .2s ease;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:100vh;padding:20px}.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(auto-fit,minmax(120px,1fr));margin-bottom:24px}.language-option{align-items:center;background:#fff;border:2px solid #e0e0e0;border-radius:12px;cursor:pointer;display:flex;flex-direction:column;font-size:1rem;padding:20px 16px;transition:all .3s ease}.language-option:hover{border-color:#007bff;box-shadow:0 4px 12px #007bff26;transform:translateY(-2px)}.language-option.selected{background:#f8f9ff;border-color:#007bff;box-shadow:0 4px 12px #007bff33}.language-flag{display:block;font-family:Segoe UI Emoji,Apple Color Emoji,Noto Color Emoji,Android Emoji,EmojiSymbols,EmojiOne Mozilla,Twemoji Mozilla,Segoe UI Symbol,Arial,sans-serif;font-size:2rem;line-height:1;margin-bottom:8px}.form-group{margin-bottom:24px}.form-group label{font-size:1.1rem}.form-group input{border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;padding:12px 16px;transition:border-color .3s ease;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{font-size:1.5rem}}.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:25px}.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}.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:0 auto;max-width:1000px;overflow:hidden}.chat-content-wrapper,.chat-main{display:flex;flex:1 1;flex-direction:column;overflow:hidden}.chat-content,.chat-content-wrapper{position:relative}.chat-content{background:#f9f9f9;display:flex;flex:1 1;flex-direction:column;min-height:0;overflow-y:auto;z-index:100}.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}.chat-sidebar{display:none}.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-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;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}.mobile-input-buttons{display:flex;gap:8px}.mobile-message-buttons{align-items:center;flex-direction:row;height:35px}.mobile-message-buttons button{height:100%;padding:12px}.mobile-message-buttons button div,.mobile-message-buttons button span{font-size:18px}.mobile-modal{padding:0 20px}.mobile-ai-message{align-items:baseline;display:flex;gap:8px;margin:8px 0;text-align:left;width:100%}}.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 8px;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%)}.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;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}.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}.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;justify-content:center;padding:8px 6px;width:100%}.mobile-message-buttons button:disabled{cursor:not-allowed;opacity:.6}.hide-show-button,.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}.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{height:85vh}.goals-content.expanded,.words-patterns-content.expanded{border-radius:0;bottom:0;left:0;margin:0;max-height:none;opacity:1;pointer-events:auto;position:fixed;right:0;top:70px;width:100vw;z-index:200}.goals-content.expanded{height:83vh}.focus-words-grid{background-color:#f0f8ff;border-bottom:1px solid #e0e0e0;border-radius:8px 8px 0 0;line-height:2;padding:12px}.focus-word{background:#e8f5e8;border:1px solid #388e3c;border-radius:4px;cursor:pointer;display:inline-block;font-weight:400;margin:4px;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}}.patterns-header{border-bottom:1px solid #e0e0e0;margin-bottom:12px;padding-bottom:8px}.patterns-header h4{color:#495057;font-size:14px;font-weight:600;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}}.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}.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{margin-top:10px;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-radius:4px;cursor:not-allowed;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:100vh;margin:0 auto;max-width:1000px;overflow:hidden}.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:40px;text-align:center}.audio-enable-content h2{color:#333;font-size:2rem;font-weight:700;margin:0 0 16px}.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}@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{display:inline-block;font-family:Segoe UI Emoji,Apple Color Emoji,Noto Color Emoji,Android Emoji,EmojiSymbols,EmojiOne Mozilla,Twemoji Mozilla,Segoe UI Symbol,Arial,sans-serif;font-size:1.2rem;font-variant-emoji:emoji;line-height:1;min-width:1.2rem;text-align:center;text-rendering:optimizeLegibility}.profile-flag:not(:has(*)){color:#007bff;font-family:Arial,sans-serif;font-weight:700}.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;max-height:200px}.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{font-size:1.2rem;text-align:center;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}body,html{height:100%;margin:0;padding:0}#root{display:flex;flex-direction:column;height:100vh}.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:flex;gap:30px}.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{align-items:center;display:flex;gap:15px}.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;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));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{box-shadow:0 5px 15px #667eea4d;transform:translateY(-2px)}.profile-container{margin:40px auto;max-width:800px;padding:0 20px}.profile-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:30px}.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-bottom:30px;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;border-radius:10px;box-shadow:0 2px 10px #0000001a;padding:30px}.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}.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:none;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-header{background-color:#f8f9fa;border-bottom:1px solid #eee;padding:20px}.mobile-user-greeting{color:#333;font-size:1.1rem;font-weight:600}.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{font-family:Segoe UI Emoji,Apple Color Emoji,Noto Color Emoji,Android Emoji,EmojiSymbols,EmojiOne Mozilla,Twemoji Mozilla,Segoe UI Symbol,Arial,sans-serif;font-size:1.2rem;line-height:1;text-align:center;width:24px}.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{font-family:Segoe UI Emoji,Apple Color Emoji,Noto Color Emoji,Android Emoji,EmojiSymbols,EmojiOne Mozilla,Twemoji Mozilla,Segoe UI Symbol,Arial,sans-serif;line-height:1;margin-right:6px}.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:90vw;overflow:hidden}@media (max-width:768px){.app-navigation{flex-direction:row;gap:0;height:50px;padding:0 10px}.nav-links,.nav-user{display:none}.mobile-menu-btn{display:block}.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{max-width:720px;min-height:60vh;padding:24px 20px 48px}.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-direction:column;gap:0;margin-bottom:24px;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;gap:12px;margin-top:8px}.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;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.342a8a3a.css.map*/