*{-webkit-tap-highlight-color:transparent}body.no-scroll{overflow:hidden;touch-action:none;pointer-events:none}.dashboard-card{position:relative}.content-loading{filter:blur(4px);pointer-events:none}.spinner-container{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:9999;pointer-events:auto}.input-error{border-color:var(--color-error);animation:shake .5s}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.btn-back{position:absolute;top:20px;left:20px;background:transparent;border:none;cursor:pointer;padding:5px;z-index:10}:root{--swiper-theme-color: #007aff}:host{position:relative;display:block;margin-left:auto;margin-right:auto;z-index:1}.swiper{margin-left:auto;margin-right:auto;position:relative;overflow:hidden;list-style:none;padding:0;z-index:1;display:block}.swiper-vertical>.swiper-wrapper{flex-direction:column}.swiper-wrapper{position:relative;width:100%;height:100%;z-index:1;display:flex;transition-property:transform;transition-timing-function:var(--swiper-wrapper-transition-timing-function, initial);box-sizing:content-box}.swiper-android .swiper-slide,.swiper-ios .swiper-slide,.swiper-wrapper{transform:translateZ(0)}.swiper-horizontal{touch-action:pan-y}.swiper-vertical{touch-action:pan-x}.swiper-slide{flex-shrink:0;width:100%;height:100%;position:relative;transition-property:transform;display:block}.swiper-slide-invisible-blank{visibility:hidden}.swiper-autoheight,.swiper-autoheight .swiper-slide{height:auto}.swiper-autoheight .swiper-wrapper{align-items:flex-start;transition-property:transform,height}.swiper-backface-hidden .swiper-slide{transform:translateZ(0);backface-visibility:hidden}.swiper-3d.swiper-css-mode .swiper-wrapper{perspective:1200px}.swiper-3d .swiper-wrapper{transform-style:preserve-3d}.swiper-3d{perspective:1200px}.swiper-3d .swiper-slide,.swiper-3d .swiper-cube-shadow{transform-style:preserve-3d}.swiper-css-mode>.swiper-wrapper{overflow:auto;scrollbar-width:none;-ms-overflow-style:none}.swiper-css-mode>.swiper-wrapper::-webkit-scrollbar{display:none}.swiper-css-mode>.swiper-wrapper>.swiper-slide{scroll-snap-align:start start}.swiper-css-mode.swiper-horizontal>.swiper-wrapper{scroll-snap-type:x mandatory}.swiper-css-mode.swiper-vertical>.swiper-wrapper{scroll-snap-type:y mandatory}.swiper-css-mode.swiper-free-mode>.swiper-wrapper{scroll-snap-type:none}.swiper-css-mode.swiper-free-mode>.swiper-wrapper>.swiper-slide{scroll-snap-align:none}.swiper-css-mode.swiper-centered>.swiper-wrapper:before{content:"";flex-shrink:0;order:9999}.swiper-css-mode.swiper-centered>.swiper-wrapper>.swiper-slide{scroll-snap-align:center center;scroll-snap-stop:always}.swiper-css-mode.swiper-centered.swiper-horizontal>.swiper-wrapper>.swiper-slide:first-child{margin-inline-start:var(--swiper-centered-offset-before)}.swiper-css-mode.swiper-centered.swiper-horizontal>.swiper-wrapper:before{height:100%;min-height:1px;width:var(--swiper-centered-offset-after)}.swiper-css-mode.swiper-centered.swiper-vertical>.swiper-wrapper>.swiper-slide:first-child{margin-block-start:var(--swiper-centered-offset-before)}.swiper-css-mode.swiper-centered.swiper-vertical>.swiper-wrapper:before{width:100%;min-width:1px;height:var(--swiper-centered-offset-after)}.swiper-3d .swiper-slide-shadow,.swiper-3d .swiper-slide-shadow-left,.swiper-3d .swiper-slide-shadow-right,.swiper-3d .swiper-slide-shadow-top,.swiper-3d .swiper-slide-shadow-bottom{position:absolute;left:0;top:0;width:100%;height:100%;pointer-events:none;z-index:10}.swiper-3d .swiper-slide-shadow{background:#00000026}.swiper-3d .swiper-slide-shadow-left{background-image:linear-gradient(to left,#00000080,#0000)}.swiper-3d .swiper-slide-shadow-right{background-image:linear-gradient(to right,#00000080,#0000)}.swiper-3d .swiper-slide-shadow-top{background-image:linear-gradient(to top,#00000080,#0000)}.swiper-3d .swiper-slide-shadow-bottom{background-image:linear-gradient(to bottom,#00000080,#0000)}.swiper-lazy-preloader{width:42px;height:42px;position:absolute;left:50%;top:50%;margin-left:-21px;margin-top:-21px;z-index:10;transform-origin:50%;box-sizing:border-box;border:4px solid var(--swiper-preloader-color, var(--swiper-theme-color));border-radius:50%;border-top-color:transparent}:is(.swiper:not(.swiper-watch-progress),.swiper-watch-progress .swiper-slide-visible) .swiper-lazy-preloader{animation:swiper-preloader-spin 1s infinite linear}.swiper-lazy-preloader-white{--swiper-preloader-color: #fff}.swiper-lazy-preloader-black{--swiper-preloader-color: #000}@keyframes swiper-preloader-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}:root{--font-main: "Inter", sans-serif}:root{--bg-primary: #f0f2f5;--bg-secondary: #ffffff;--bg-lightest: #f9f9f9;--text-primary: #1c1e21;--text-secondary: #4a4f56;--accent-secondary: #dc2626;--accent-secondary-hover: #b91c1c;--border-color: #dddfe2;--card-shadow: 0 6px 24px rgba(0, 0, 0, .1);--text-on-accent: #ffffff;--accent-green: #22c55e;--accent-red: #ef4444;--accent-yellow: #f59e0b}[data-theme=purple]{--accent-primary: #800080;--accent-primary-hover: #6a006a;--tag-bg: #f2e6f2;--tag-text: #800080}[data-theme=red]{--accent-primary: #e50914;--accent-primary-hover: #b20710;--tag-bg: #fde8e8;--tag-text: #e50914}[data-theme=orange]{--accent-primary: #ea580c;--accent-primary-hover: #c2410c;--tag-bg: #ffedd5;--tag-text: #c2410c}@media(prefers-color-scheme:dark){:root{--bg-primary: #121212;--bg-secondary: #1e1e1e;--bg-lightest: #2a2a2a;--text-primary: #ffffff;--text-secondary: #a9a9b3;--accent-primary: #673ab7;--accent-secondary: #ef4444;--accent-secondary-hover: #f87171;--border-color: #333;--card-shadow: 0 6px 24px rgba(103, 58, 183, .15);--tag-bg: #3a2e4a;--tag-text: #e6d8ff;--text-on-accent: #ffffff}}body.loading .header,body.loading .main-nav{z-index:0}body.loading{overflow:hidden}body{margin:0;font-family:var(--font-main);background-color:var(--bg-primary);color:var(--text-primary);transition:background-color .3s,color .3s;-webkit-user-select:none;user-select:none;font-size:1.1em}.app-container{display:flex;flex-direction:column;height:100vh}.settings-card .setting-item{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.settings-card .setting-item:last-child{margin-bottom:0}.settings-card .setting-item span{font-weight:500}.settings-card .setting-item>*{background-color:var(--bg-lightest);border:1px solid var(--border-color);border-radius:8px;padding:8px}.update-check-btn{background-color:var(--accent-primary);color:#fff;border:none;padding:10px 20px;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:background-color .2s;width:100%;margin-top:16px}.update-check-btn:hover{background-color:var(--accent-primary-hover)}.progress-bar-container{height:8px;background-color:var(--border-color);border-radius:4px;overflow:hidden;display:flex;margin-bottom:12px}.progress-wrapper{position:relative}.progress-bar-container.empty{background-color:var(--border-color)}.progress-bar-segment{height:100%}.progress-bar-segment.correct{background-color:var(--accent-green)}.progress-bar-segment.incorrect{background-color:var(--accent-red)}.progress-bar-segment.missing{background-color:var(--accent-yellow)}.confetti-container{position:absolute;width:100%;height:100%;top:0;left:0;pointer-events:none;overflow:visible}.confetti-container:before{content:"";position:absolute;width:8px;height:8px;background:var(--accent-green);border-radius:50%;animation:confetti-pop .8s ease-out 1.5s forwards;opacity:0}.swiper{width:100%;height:100%;overflow:hidden}.swiper-slide{height:100%}.mySwiper .swiper-slide{background:var(--bg-primary)}.quiz-swiper .swiper-slide{background:var(--bg-secondary)}.font-size-selector{display:flex;gap:8px}.font-size-btn{background-color:var(--bg-primary);border:1px solid var(--border-color);color:var(--text-secondary);border-radius:8px;padding:8px 12px;font-weight:600;cursor:pointer;transition:all .2s ease-in-out}.font-size-btn.active{background-color:var(--accent-primary);color:#fff;border-color:var(--accent-primary)}.update-toast{position:fixed;bottom:20px;left:50%;transform:translate(-50%);background-color:var(--accent-green);color:#fff;padding:12px 24px;border-radius:8px;box-shadow:0 4px 20px #0003;z-index:1000;animation:fadeInOut 4s ease-in-out;font-weight:600}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#0009;display:flex;align-items:center;justify-content:center;z-index:2000;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.modal-content{background-color:var(--bg-secondary);padding:32px;border-radius:16px;box-shadow:0 10px 30px #0003;text-align:center;width:90%;max-width:320px}.modal-content p{margin:16px 0 24px;font-size:1.1rem;font-weight:500}.modal-close-btn{background-color:var(--accent-primary);color:#fff;border:none;padding:10px 20px;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:background-color .2s;width:100%}.modal-close-btn:hover{background-color:var(--accent-primary-hover)}.spinner{border:4px solid rgba(255,255,255,.2);border-left-color:var(--accent-primary);border-radius:50%;width:60px;height:60px;animation:spin 1s linear infinite;margin:0 auto}.checkmark{font-size:3rem;color:var(--accent-green)}.btn{width:100%;padding:12px;border-radius:8px;border:none;font-size:1rem;font-weight:600;cursor:pointer;transition:background-color .2s;display:flex;align-items:center;justify-content:center;gap:8px}.btn-primary{background-color:var(--text-primary);color:var(--bg-primary);margin-bottom:16px}.theme-dark .btn-primary{background-color:#fff;color:#121212}.theme-light .btn-primary{background-color:#1c1e21;color:#fff}.divider{margin:16px 0;color:var(--text-secondary);font-size:.875rem;position:relative;text-align:center}.divider:before,.divider:after{content:"";position:absolute;top:50%;width:40%;height:1px;background-color:var(--border-color)}.divider:before{left:0}.divider:after{right:0}.btn-social{background-color:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color);margin-bottom:12px}.btn-social:last-child{margin-bottom:0}.btn-social img{width:16px;height:16px}.spinner-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#0009;display:flex;align-items:center;justify-content:center;z-index:3000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.quiz-modal-overlay{visibility:hidden;opacity:0;position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;z-index:2000;transition:visibility 0s .3s,opacity .3s ease}.quiz-modal-overlay.open{visibility:visible;opacity:1;transition:opacity .3s ease}.quiz-modal-content{position:absolute;bottom:0;left:0;width:100%;height:calc(100% - 12px);background:var(--bg-secondary);border-top-left-radius:18px;border-top-right-radius:18px;box-shadow:0 -10px 40px #0003;display:flex;flex-direction:column;transform:translateY(100%);will-change:transform}.quiz-modal-overlay.open .quiz-modal-content{transform:translateY(0);transition:transform .4s cubic-bezier(.32,.72,0,1)}.quiz-modal-header{display:flex;align-items:center;padding:12px 92px 5px 16px;border-bottom:1px solid var(--border-color);flex-shrink:0;position:relative}.header-tabs-container{width:100%;overflow:hidden}.quiz-modal-header .main-nav{border-bottom:none;background:transparent;justify-content:flex-start;overflow-x:auto;-ms-overflow-style:none;scrollbar-width:none;width:100%;padding-right:0}.quiz-modal-header .main-nav .main-nav-inner{justify-content:flex-start!important;width:max-content}.quiz-modal-header .main-nav::-webkit-scrollbar{display:none}.quiz-modal-header .main-nav-btn{padding:12px 14px;font-size:18px;gap:8px}.close-quiz-btn{position:absolute;right:16px;top:50%;transform:translateY(-50%);background-color:var(--bg-lightest, #e4e6eb);color:var(--text-primary);border-radius:50%;width:30px;height:30px;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:700;cursor:pointer;border:none;z-index:20;box-shadow:0 1px 4px #0000001a}.settings-quiz-btn{position:absolute;right:56px;top:50%;transform:translateY(-50%);background-color:var(--bg-lightest, #e4e6eb);color:var(--text-primary);border-radius:50%;width:30px;height:30px;display:flex;align-items:center;justify-content:center;cursor:pointer;border:none;z-index:20;box-shadow:0 1px 4px #0000001a;padding:5px}.settings-quiz-btn svg{width:17px;height:17px}.settings-quiz-btn:hover{filter:brightness(.9)}.settings-quiz-btn.spin svg{animation:spin-settings 1s ease-in-out}.settings-quiz-btn.hint-attention{animation:settings-hint-pulse 1.2s ease-in-out}.settings-quiz-btn.hint-attention svg{animation:settings-hint-wiggle 1.2s ease-in-out}@keyframes settings-hint-pulse{0%,to{box-shadow:0 1px 4px #0000001a;transform:translateY(-50%) scale(1)}35%{box-shadow:0 0 0 6px color-mix(in srgb,var(--accent-primary) 20%,transparent),0 4px 16px color-mix(in srgb,var(--accent-primary) 34%,transparent);transform:translateY(-50%) scale(1.08)}70%{box-shadow:0 0 color-mix(in srgb,var(--accent-primary) 0%,transparent),0 4px 12px color-mix(in srgb,var(--accent-primary) 18%,transparent);transform:translateY(-50%) scale(1.02)}}@keyframes settings-hint-wiggle{0%,to{transform:rotate(0)}20%{transform:rotate(-18deg)}40%{transform:rotate(18deg)}60%{transform:rotate(-12deg)}80%{transform:rotate(12deg)}}.close-quiz-btn:hover{filter:brightness(.9)}.app-hint-toast,.quiz-audio-hint-toast{position:fixed;left:50%;bottom:24px;transform:translate(-50%) translateY(10px);background:color-mix(in srgb,var(--accent-primary) 88%,black 12%);color:#fff;padding:10px 16px;border-radius:999px;font-size:14px;font-weight:600;box-shadow:0 10px 24px color-mix(in srgb,var(--accent-primary) 30%,transparent);opacity:0;pointer-events:none;transition:opacity .22s ease,transform .22s ease;z-index:12000;width:max-content;max-width:min(calc(100vw - 24px),540px);white-space:nowrap}.app-hint-toast.show,.quiz-audio-hint-toast.show{opacity:1;transform:translate(-50%) translateY(0)}.quiz-swiper-container{flex-grow:1;overflow:hidden;position:relative}.confirm-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#0000004d;z-index:3000;display:flex;justify-content:center;align-items:center;opacity:0;visibility:hidden;transition:opacity .3s ease,visibility 0s .3s}.confirm-overlay.show{opacity:1;visibility:visible;transition:opacity .3s ease;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.confirm-box{background-color:var(--bg-secondary);width:90%;max-width:320px;border-radius:16px;padding:24px;text-align:center;box-shadow:0 10px 30px #0003}.confirm-title{font-weight:600;font-size:1.125rem;padding:0 0 12px;color:var(--text-primary)}.confirm-message{font-size:.95rem;padding:0 0 24px;color:var(--text-secondary);border-bottom:none}.confirm-actions{display:flex;gap:12px;justify-content:stretch}.confirm-btn{flex:1;background-color:var(--bg-lightest);border:none;font-size:1rem;cursor:pointer;border-radius:8px;color:var(--text-primary);font-weight:600;padding:12px;transition:filter .2s}.confirm-btn.danger{background-color:var(--accent-red, #ff3b30);color:#fff}.confirm-btn:active{filter:brightness(.9)}.settings-overlay-box{background-color:var(--bg-secondary);width:90%;max-width:360px;border-radius:20px;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d;border:1px solid var(--border-color);padding:0;position:relative;transform:scale(.95) translateY(10px);opacity:0;transition:transform .3s cubic-bezier(.19,1,.22,1),opacity .3s ease;will-change:transform,opacity;backface-visibility:hidden}.settings-overlay{position:fixed;inset:0;background-color:#0000004d;z-index:11000;display:flex;justify-content:center;align-items:center;opacity:0;visibility:hidden;pointer-events:none;backdrop-filter:blur(0);-webkit-backdrop-filter:blur(0);transition:opacity .25s ease,visibility 0s .25s,backdrop-filter .25s ease,-webkit-backdrop-filter .25s ease}.settings-overlay.show{opacity:1;visibility:visible;pointer-events:auto;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);transition:opacity .25s ease,backdrop-filter .25s ease,-webkit-backdrop-filter .25s ease}.settings-overlay.show .settings-overlay-box{transform:scale(1) translateY(0);opacity:1}.quiz-settings-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;background:linear-gradient(135deg,var(--bg-secondary) 0%,var(--bg-primary) 100%);border-bottom:1px solid var(--border-color)}.quiz-settings-header h2{margin:0;font-size:1.1rem;color:var(--text-primary);font-weight:700}.quiz-settings-header .close-btn{background:#0000000d;border:none;font-size:1.25rem;color:var(--text-secondary);cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease}.quiz-settings-header .close-btn:hover{background-color:#0000001a;color:var(--text-primary);transform:rotate(90deg)}.quiz-settings-body{padding:0;overflow-y:auto;max-height:60vh}.quiz-settings-body .settings-section{padding:20px;border-bottom:none}.quiz-settings-body .settings-section h3{border-bottom:2px solid var(--border-color)}@keyframes popIn{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}.settings-done-btn{width:100%;background-color:var(--accent-primary);color:#fff;border:none;font-size:1rem;font-weight:600;padding:14px;border-radius:12px;margin-top:24px;cursor:pointer;box-shadow:0 4px 12px rgba(var(--accent-primary-rgb),.3);transition:transform .1s,filter .2s}.settings-done-btn:active{transform:scale(.98);filter:brightness(.9)}.loader{width:48px;height:48px;display:inline-block;position:relative}.loader:after,.loader:before{content:"";box-sizing:border-box;width:48px;height:48px;border-radius:50%;background:var(--accent-primary);position:absolute;left:0;top:0;animation:animloader 2s linear infinite}.loader:after{animation-delay:-1s}@keyframes progressBarFill{0%{width:0%}to{width:var(--target-width)}}@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.1)}to{transform:scale(1)}}.progress-bar-container.completing .progress-bar-segment.animating{--target-width: 0;animation-name:progressBarFill;animation-duration:1.5s;animation-timing-function:cubic-bezier(.33,1,.68,1);animation-fill-mode:forwards}.progress-bar-container.completing .progress-bar-segment.correct.animating{--target-width: var(--correct-width);animation-duration:1s;animation-delay:0s}.progress-bar-container.completing .progress-bar-segment.incorrect.animating{--target-width: var(--incorrect-width);animation-duration:.4s;animation-delay:1s}.progress-bar-container.completing .progress-bar-segment.missing.animating{--target-width: var(--missing-width);animation-duration:.3s;animation-delay:1.4s}.progress-wrapper.completing{animation:pulse .5s ease-in-out 1s forwards}@keyframes confetti-pop{0%{transform:scale(0) translate(0);opacity:1}to{transform:scale(1.5) translate(var(--x),var(--y));opacity:0}}.confetti-container{position:absolute;width:100%;height:100%;top:0;left:0;pointer-events:none}.confetti-container:before{content:"";position:absolute;width:6px;height:6px;background-color:transparent;border-radius:50%;opacity:0;animation:confetti-pop .6s ease-out 1s forwards}.confetti-container[data-direction=top]:before{top:-4px;left:50%;--x: 0;--y: -80px;box-shadow:30px 10px #16a34a,-30px 5px #4ade80,50px 15px #15803d,-50px 20px #86efac}.confetti-container[data-direction=bottom]:before{bottom:-4px;left:50%;--x: 0;--y: 80px;box-shadow:-30px -10px #15803d,30px -5px #86efac,-50px -15px #16a34a,50px -20px #4ade80}.confetti-container[data-direction=left]:before{top:50%;left:-4px;--x: -80px;--y: 0;box-shadow:10px 25px #16a34a,5px -30px #4ade80,-15px 15px #15803d,-20px -20px #86efac}.confetti-container[data-direction=right]:before{top:50%;right:-4px;--x: 80px;--y: 0;box-shadow:-10px -25px #15803d,-5px 30px #86efac,15px -15px #16a34a,20px 20px #4ade80}@keyframes fadeInOut{0%{opacity:0;transform:translate(-50%,20px)}10%{opacity:1;transform:translate(-50%)}90%{opacity:1;transform:translate(-50%)}to{opacity:0;transform:translate(-50%,20px)}}@keyframes slide-in{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes slide-in-from-left{0%{transform:translate(-100%);opacity:0}to{transform:translate(0);opacity:1}}.login-form.enter-right{transform:translate(0);opacity:1;animation:slide-in .4s ease-in-out}.login-form.enter-left{transform:translate(0);opacity:1;animation:slide-in-from-left .4s ease-in-out}.anim-unfold{transform:perspective(1200px) rotateX(-90deg);transform-origin:top center}.quiz-modal-overlay.open .anim-unfold{transform:perspective(1200px) rotateX(0)}@keyframes animloader{0%{transform:scale(0);opacity:1}to{transform:scale(1);opacity:0}}.page-placeholder{padding:40px;text-align:center;color:var(--text-secondary)}.page-placeholder h2{margin:0 0 12px;color:var(--text-primary);font-size:1.5rem}.page-placeholder p{margin:0 auto;max-width:520px;line-height:1.6}.exercise-logged-out-state{display:flex;flex-direction:column;align-items:center;gap:16px;padding-top:56px;padding-bottom:56px}.placeholder-action-btn{background-color:var(--accent-primary);color:#fff;border:none;padding:10px 20px;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:background-color .2s ease}.placeholder-action-btn:hover{background-color:#311b92}.vocabulary-empty-state{grid-column:1 / -1;padding-top:56px;padding-bottom:56px}.content-container{flex-grow:1;overflow:hidden;position:relative;transform:translateZ(0)}.page-content{height:100%;overflow-y:auto;padding:24px;box-sizing:border-box}.warning-box{background-color:#ef4444;color:#fff;padding:16px;border-radius:8px;margin-bottom:24px;cursor:pointer;border:2px solid #b91c1c}.theme-light .warning-box{background-color:#fee2e2;color:#b91c1c;border-color:#fca5a5}.warning-box a{text-decoration:underline}.vocabulary-page{display:flex;flex-direction:column;gap:24px}.vocab-header{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border-color);padding-bottom:16px}.vocab-header h2{margin:0;font-size:1.375rem}.quiz-btn{background-color:var(--accent-primary);color:#fff;border:none;padding:10px 20px;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:background-color .2s;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent!important}.quiz-btn:hover{background-color:#311b92}.quiz-btn.is-disabled{opacity:.55;cursor:not-allowed}.quiz-btn.is-disabled:hover{background-color:var(--accent-primary)}.vocab-sort-controls{display:flex;gap:8px;margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid var(--border-color)}.vocab-sort-controls button{background-color:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-secondary);border-radius:8px;padding:8px 12px;font-weight:600;cursor:pointer;transition:all .2s ease-in-out;display:flex;align-items:center;gap:6px;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent!important}.vocab-sort-controls button.is-active{background-color:var(--accent-primary);color:#fff;border-color:var(--accent-primary)}.sort-arrow{transition:transform .3s ease}.sort-arrow.is-desc{transform:rotate(180deg)}.vocab-grid-container{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;position:relative}.vocab-item-card{background-color:var(--bg-secondary);border-radius:12px;box-shadow:var(--card-shadow);cursor:pointer;overflow:hidden;transition:background-color .3s ease-in-out,border-left-color .3s ease-in-out,box-shadow .3s ease-in-out,opacity .3s ease-in-out;-webkit-tap-highlight-color:transparent;border-left:5px solid transparent}@media(prefers-color-scheme:dark){.vocab-item-card{box-shadow:0 8px 24px #00000047}}.theme-dark .vocab-item-card{box-shadow:0 8px 24px #00000047}.vocab-grid-mounted .vocab-item-card{transition:background-color .3s ease-in-out,border-left-color .3s ease-in-out,box-shadow .3s ease-in-out,opacity .3s ease-in-out,transform 1s}.vocab-item-card.is-deleting{opacity:0;transform:scale(.9);transition:opacity .5s ease,transform .5s ease;pointer-events:none}.vocab-item-card.familiarity--new{border-left-color:#ef4444}.vocab-item-card.familiarity--learning{border-left-color:#f59e0b}.vocab-item-card.familiarity--known{border-left-color:#22c55e}.vocab-card-header{padding:16px;font-size:1.125rem;font-weight:600;display:flex;align-items:center;justify-content:space-between;gap:8px}.vocab-card-header-main{display:inline-flex;align-items:center;flex-wrap:wrap;gap:8px;min-width:0}.vocab-inline-audio-btn{margin-left:auto;flex-shrink:0;width:32px;height:32px;border:1.5px solid rgba(49,27,146,.2);background:#ffffffeb;box-shadow:0 1px 3px #0f172a14}.vocab-inline-audio-btn svg circle{fill:transparent}.vocab-inline-audio-btn:hover:not(:disabled){border-color:#311b9257;background:#fff}.vocab-inline-audio-btn.is-playing{background:#fff;border-color:#311b9257}.audio-btn.vocab-inline-audio-btn.is-loading{background:#fffffff0;border-color:color-mix(in srgb,var(--accent-primary) 38%,white);box-shadow:0 4px 10px #0f172a1f}.audio-btn.vocab-inline-audio-btn.is-loading:before{content:"";position:absolute;inset:0;border-radius:50%;background:radial-gradient(circle at center,color-mix(in srgb,var(--accent-primary) 14%,white),transparent 72%);animation:tooltip-audio-pulse 1.2s ease-in-out infinite}.audio-btn.vocab-inline-audio-btn.is-loading:after{content:"";position:absolute;top:0;left:-35%;width:58%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.98),color-mix(in srgb,var(--accent-primary) 14%,white),rgba(255,255,255,.98),transparent);transform:skew(-18deg) translate(0);animation:dre-shimmer 1.15s ease-in-out infinite;border-radius:50%}@media(prefers-color-scheme:dark){.audio-btn.vocab-inline-audio-btn.is-loading{background:#080808f5;border-color:#ffffff24;box-shadow:0 4px 14px #00000057}.audio-btn.vocab-inline-audio-btn.is-loading:before{background:radial-gradient(circle at center,rgba(255,255,255,.1),transparent 72%)}.audio-btn.vocab-inline-audio-btn.is-loading:after{background:linear-gradient(90deg,transparent,rgba(255,255,255,.94),rgba(255,255,255,.72),rgba(255,255,255,.94),transparent)}}.vocab-inline-audio-btn:disabled:not(.is-loading):not(.is-playing){opacity:.45}.new-tag{background-color:var(--accent-primary);color:#fff;font-size:.75rem;font-weight:700;padding:2px 6px;border-radius:4px;vertical-align:middle;animation:flash-new 2s infinite}@keyframes flash-new{0%,to{opacity:1}50%{opacity:.5}}.word-type{font-style:italic;font-weight:400;color:var(--text-secondary);font-size:.875rem}.vocab-card-body{display:grid;grid-template-rows:0fr;transition:grid-template-rows .5s cubic-bezier(.25,.8,.25,1)}.vocab-item-card.is-expanded .vocab-card-body{grid-template-rows:1fr}.vocab-card-content{overflow:hidden;padding:0 16px;opacity:0;transition:opacity .5s cubic-bezier(.25,.8,.25,1)}.vocab-item-card.is-expanded .vocab-card-content{padding-bottom:16px;opacity:1}.vocab-card-body p{margin:0 0 8px;font-size:.875rem;color:var(--text-secondary)}.vocab-card-body p:last-child{margin-bottom:0}.vocab-card-body strong{color:var(--text-primary)}.highlighted-word{color:var(--accent-primary);font-weight:700}@media(prefers-color-scheme:dark){.highlighted-word{color:#e6d8ff}}.complete-btn{background-color:var(--accent-primary);color:#fff;border:none;padding:10px 20px;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:background-color .2s;width:100%;margin-top:16px}.complete-btn:hover{background-color:#311b92}.exercise-header{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border-color);padding-bottom:16px;margin-bottom:16px}.exercise-header h2{margin:0;font-size:1.375rem}.login-container{padding:24px}.login-card{max-width:400px;margin:0 auto;padding:32px;overflow:hidden;background-color:var(--bg-secondary);border-radius:16px;box-shadow:var(--card-shadow);text-align:center}.login-card h2{margin-top:0;margin-bottom:24px;font-size:1.5rem}.login-header{display:flex;align-items:center;justify-content:center;position:relative;margin-bottom:11px}.login-header h2{margin:0}.btn-back{position:absolute;left:0;background:none;border:none;cursor:pointer;color:var(--text-secondary);padding:0}.input-group{margin-bottom:16px}.input-group input{width:100%;padding:12px;border-radius:8px;border:1px solid var(--border-color);background-color:var(--bg-primary);color:var(--text-primary);font-size:1rem;box-sizing:border-box;-webkit-tap-highlight-color:transparent}.input-group input:-webkit-autofill,.input-group input:-webkit-autofill:hover,.input-group input:-webkit-autofill:focus,.input-group input:-webkit-autofill:active{-webkit-box-shadow:0 0 0 30px var(--bg-primary) inset!important;-webkit-text-fill-color:var(--text-primary)!important}.email-display{font-weight:600;word-break:break-all}.login-form{transition:transform .5s ease-in-out,opacity .5s ease-in-out}.login-form.exit-left{transform:translate(-100%);opacity:0}.login-form.exit-right{transform:translate(100%);opacity:0}.error-message{background-color:#ef4444;color:#fff;padding:16px;border-radius:8px;margin-bottom:24px;animation:fade-in .5s ease-in-out}@keyframes fade-in{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.quiz-content{padding:24px}.btn-back-arrow{background:none;border:none;cursor:pointer;color:var(--accent-primary);padding:0;margin-right:8px;display:inline-flex;align-items:center;justify-content:center}.btn-back-arrow:hover{opacity:.8}.password-form{padding-top:16px}.password-checklist{display:grid;gap:6px;margin-top:-2px;margin-bottom:16px;padding:10px 12px;border-radius:12px;background:var(--bg-primary);border:1px solid var(--border-color)}.password-checklist div{position:relative;padding-left:18px;font-size:.74rem;line-height:1.35;opacity:.72;color:var(--text-secondary)}.password-checklist div:before{content:"";position:absolute;top:50%;left:0;width:10px;height:10px;margin-top:-5px;border-radius:999px;background:#94a3b873}.password-checklist div.is-valid{opacity:1;color:#15803d}.password-checklist div.is-valid:before{background:#38d46a;box-shadow:0 0 0 3px #38d46a2e}.verification-code-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:16px}.verification-code-box{display:flex;align-items:center;justify-content:center;width:100%;height:52px;border-radius:12px;border:1px solid var(--border-color);background-color:var(--bg-primary);color:var(--text-primary);text-align:center;font-size:1.5rem;font-weight:700;box-sizing:border-box;-webkit-tap-highlight-color:transparent;transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease,background-color .18s ease}.verification-code-box.is-active{border-color:var(--accent-primary);box-shadow:0 0 0 3px #6366f126}.verification-code-box.is-filled{border-color:var(--accent-primary)}.verification-code-box.is-new{animation:verificationDigitPop .22s ease-out}.verification-code-box.is-verifying{animation:verificationDigitPulse .9s ease-in-out infinite}@keyframes verificationDigitPop{0%{transform:scale(.84)}60%{transform:scale(1.08)}to{transform:scale(1)}}@keyframes verificationDigitPulse{0%,to{transform:translateY(0);box-shadow:0 0 #6366f129}50%{transform:translateY(-1px);box-shadow:0 0 0 4px #6366f11a}}.verification-panel{position:relative;min-height:238px}.verification-keypad{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;transition:opacity .22s ease,transform .22s ease}.verification-keypad-btn{height:52px;border:1px solid var(--border-color);border-radius:12px;background-color:var(--bg-primary);color:var(--text-primary);font-size:1.1rem;font-weight:700;cursor:pointer;transition:border-color .2s ease,transform .1s ease,background-color .2s ease}.verification-keypad-btn:hover{border-color:var(--accent-primary)}.verification-keypad-btn:active{transform:scale(.98)}.verification-keypad-btn:disabled{opacity:.6;cursor:default}.verification-keypad-btn-delete{font-size:.9rem}.verification-keypad-spacer{height:52px}.verification-status{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;gap:8px;color:var(--text-secondary);font-size:.95rem;opacity:0;transform:translateY(8px);pointer-events:none;transition:opacity .22s ease,transform .22s ease}.verification-panel.is-verifying .verification-keypad{opacity:0;transform:translateY(-6px);pointer-events:none}.verification-panel.is-verifying .verification-status{opacity:1;transform:translateY(0)}.vocab-actions-row{display:flex;justify-content:flex-end;gap:8px;margin-top:16px;padding-top:16px;border-top:1px solid var(--border-color)}.vocab-action-btn{background:none;border:1px solid var(--border-color);border-radius:4px;padding:6px;cursor:pointer;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;transition:all .2s ease}.vocab-action-btn:hover{background-color:var(--bg-primary);color:var(--accent-primary);border-color:var(--accent-primary)}.vocab-action-btn svg{width:16px;height:16px}.btn-thumbs-down:hover{color:#ef4444;border-color:#ef4444}.btn-thumbs-up:hover{color:#22c55e;border-color:#22c55e}.btn-delete:hover{color:#ef4444;border-color:#ef4444}.btn-audio:hover{color:var(--accent-primary);border-color:var(--accent-primary);background-color:var(--bg-primary)}@keyframes spin{to{transform:rotate(360deg)}}.egh-spinner{animation:spin 1s linear infinite}.fade-enter{opacity:0;transform:scale(.9)}.fade-enter-active{opacity:1;transform:scale(1);transition:opacity .3s ease,transform .3s ease}.fade-exit{opacity:1;transform:scale(1)}.fade-exit-active{opacity:0;transform:scale(.9);transition:opacity .3s ease,transform .3s ease}.egh-modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;opacity:0;pointer-events:none;transition:opacity .3s ease}.egh-modal-overlay.is-open{opacity:1;pointer-events:auto}.egh-modal-content{background-color:var(--bg-secondary);padding:24px;border-radius:12px;width:90%;max-width:500px;box-shadow:0 10px 25px #0000001a;position:relative;max-height:90vh;overflow-y:auto;transform:scale(.95);opacity:0;transition:transform .3s ease,opacity .3s ease}.egh-modal-overlay.is-open .egh-modal-content{transform:scale(1);opacity:1}.egh-close{position:absolute;right:20px;top:20px;font-size:24px;font-weight:700;cursor:pointer;color:var(--text-secondary);line-height:1}.egh-close:hover{color:var(--text-primary)}.egh-modal-content h3{margin-top:0;margin-bottom:20px;color:var(--text-primary);font-size:1.25rem}.form-group{margin-bottom:16px}.form-group label{display:block;margin-bottom:8px;font-weight:600;color:var(--text-primary);font-size:.9rem}.form-group input,.form-group textarea{width:100%;padding:10px;border:1px solid var(--border-color);border-radius:6px;font-size:1rem;font-family:inherit;background-color:var(--bg-primary);color:var(--text-primary);box-sizing:border-box}.form-group textarea{resize:vertical;min-height:80px}.form-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:24px}.btn-cancel{background-color:var(--bg-primary);color:var(--text-primary);border:1px solid var(--border-color);padding:8px 16px;border-radius:6px;cursor:pointer;font-weight:600}.btn-save{background-color:var(--accent-primary);color:#fff;border:none;padding:8px 16px;border-radius:6px;cursor:pointer;font-weight:600}.btn-delete-confirm{background-color:#dc2626;color:#fff;border:none;padding:8px 16px;border-radius:6px;cursor:pointer;font-weight:600}.shimmer-loader{display:inline-block;width:96px;max-width:100%;height:.85em;margin-left:5px;border-radius:999px;vertical-align:middle;background:linear-gradient(90deg,color-mix(in srgb,var(--bg-lightest) 88%,var(--border-color) 12%),color-mix(in srgb,var(--bg-lightest) 55%,var(--border-color) 45%) 24%,color-mix(in srgb,var(--bg-lightest) 88%,var(--border-color) 12%) 48% 100%);background-size:200% 100%;animation:tooltip-translation-shimmer 1.1s linear infinite}.vocab-translation-text{display:inline-block;margin-left:5px;animation:vocab-translation-fade-in .28s ease-out}@keyframes vocab-translation-fade-in{0%{opacity:0;transform:translateY(2px)}to{opacity:1;transform:translateY(0)}}.app-version-dashboard{font-size:.75rem;color:var(--text-secondary);text-align:center;margin-top:16px}.desktop-layout{display:flex;width:100%;height:100%}.desktop-column{flex:1;display:flex;flex-direction:column;border-right:1px solid var(--border-color);min-width:0;background-color:var(--bg-primary)}.desktop-column:last-child{border-right:none}.desktop-column h2{padding:16px;margin:0;font-size:1.25rem;border-bottom:1px solid var(--border-color);background-color:var(--bg-secondary);text-align:center;color:var(--text-primary);z-index:10}.desktop-column .page-content{flex:1;overflow-y:auto}.header{background-color:var(--bg-primary);padding:16px 24px;display:flex;justify-content:space-between;align-items:center;position:relative;flex-shrink:0}.header .header-title{text-align:left}.header h1{margin:0;font-size:28px;font-family:Poppins,sans-serif}.brand-title{display:flex;align-items:baseline;gap:0}.brand-accent{color:var(--accent-primary)}.brand-neutral{color:var(--text-primary)}.app-version{font-size:.75rem;color:var(--text-secondary);margin-top:-4px;display:block}.mute-btn{background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-primary);border-radius:50%;width:40px;height:40px;cursor:pointer;font-size:1.25rem;display:flex;align-items:center;justify-content:center;padding:0;z-index:1}.settings-btn{background:transparent;border:none;color:var(--text-primary);cursor:pointer;padding:8px;display:flex;align-items:center;justify-content:center;border-radius:50%}.settings-btn:hover,.settings-btn:active{background-color:transparent}.settings-btn.spin{animation:spin-settings 1s ease-in-out}@keyframes spin-settings{0%{transform:rotate(0)}to{transform:rotate(180deg)}}.main-nav{display:flex;justify-content:center;background-color:var(--bg-primary);border-bottom:1px solid var(--border-color);flex-shrink:0;position:relative;overflow:hidden}.main-nav--large{justify-content:flex-start;overflow-x:auto;-ms-overflow-style:none;scrollbar-width:none}.main-nav--large::-webkit-scrollbar{display:none}.main-nav-inner{display:flex;justify-content:center;position:relative;width:100%}.main-nav--large .main-nav-inner{width:auto}.main-nav-btn{background:none;border:none;color:var(--text-secondary);font-family:Poppins,sans-serif;font-size:1rem;font-weight:500;padding:16px 12px;cursor:pointer;position:relative;z-index:2;transition:color .6s cubic-bezier(.68,-.55,.27,1.55);flex-shrink:0;white-space:nowrap;display:flex;align-items:center;gap:8px}.main-nav--fixed .main-nav-btn{font-size:18px}.main-nav--large .main-nav-btn{font-size:1.25rem;padding:20px 24px}.main-nav-btn.active{color:var(--accent-primary)}.underline{position:absolute;bottom:-1px;left:0;height:3px;background-color:var(--accent-primary);z-index:2;transition:transform .6s cubic-bezier(.68,-.55,.27,1.55),width .6s cubic-bezier(.68,-.55,.27,1.55)}.underline.no-transition{transition:none}@keyframes flashConfirm{0%,to{background-color:var(--accent-primary)}50%{background-color:var(--flash-color)}}.underline.animate-flash{animation:flashConfirm .4s ease-out;animation-delay:.2s}.sub-nav{display:flex;background-color:var(--bg-primary);padding:8px 0;border-bottom:1px solid var(--border-color);overflow-x:auto;-ms-overflow-style:none;scrollbar-width:none}.sub-nav::-webkit-scrollbar{display:none}.sub-nav-btn{background:none;border:none;color:var(--text-secondary);font-size:.875rem;padding:8px 16px;cursor:pointer;font-weight:500;white-space:nowrap}.sub-nav-btn.active{color:var(--accent-primary);border-bottom:2px solid var(--accent-primary);padding-bottom:6px}.exercise-list{padding-top:0;display:grid;gap:24px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.card{background-color:var(--bg-secondary);border-radius:30px 4px;box-shadow:var(--card-shadow);display:flex;flex-direction:column;transition:transform .2s ease-in-out,box-shadow .2s ease-in-out,top .2s ease-in-out;overflow:visible;position:relative;top:0;border:1px solid var(--border-color)}.card:before{content:"";position:absolute;inset:0;border-radius:30px 4px;opacity:0;background:transparent;box-shadow:0 0 #d92d2000,0 0 #d92d2000,0 0 #d92d2000;transform:scale(1);pointer-events:none;z-index:-1}.card.card--new:before{animation:exercise-card-new-glow 1.8s ease-in-out infinite}.card.card--new-exiting:before{animation:exercise-card-new-glow-out .52s cubic-bezier(.22,1,.36,1) forwards}.card:hover{transform:translateY(-5px);box-shadow:0 10px 20px #0000001a,0 6px 6px #00000026;top:-2px}.card.card-entering{opacity:0;filter:blur(6px);animation:exercise-card-enter .82s cubic-bezier(.22,1,.36,1) forwards;will-change:opacity,filter;pointer-events:none}.card-image-container{position:relative;height:120px;border-radius:30px 4px 0 0;overflow:hidden}.card-image-container .card-image{position:absolute;inset:0;width:100%;height:120px;object-fit:cover;display:block;opacity:0;transition:opacity .5s ease-in-out}.card-image-container .card-image.loaded{opacity:1}.card-image-placeholder{position:absolute;inset:0;width:100%;height:120px;display:flex;align-items:center;justify-content:center;background:linear-gradient(45deg,#4527a01a,#4527a005);color:var(--accent-primary);opacity:1}.card-image-placeholder.is-lazy:after{content:"";position:absolute;inset:0;background:linear-gradient(110deg,transparent 0%,rgba(255,255,255,.18) 45%,transparent 100%);transform:translate(-100%);animation:image-lazy-shimmer 1.4s ease-in-out infinite}@media(prefers-color-scheme:dark){.card-image-placeholder{background:linear-gradient(45deg,#673ab740,#673ab70d);color:#fff}}.card-tag{position:absolute;top:12px;background-color:var(--accent-primary);color:#fff;padding:6px 10px;border-radius:8px;font-size:.75rem;font-weight:600;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.category-tag{left:12px;display:flex;align-items:center;gap:6px}.level-tag{right:12px}.card-content{padding:16px;display:flex;flex-direction:column;flex-grow:1;overflow:visible}.card-title{font-size:1.125rem;font-weight:700;margin:0 0 12px;color:var(--text-primary);line-height:1.4}.card-meta{display:flex;align-items:center;gap:12px;font-size:.8125rem;color:var(--text-secondary);margin-bottom:12px}.meta-item{display:flex;align-items:center;gap:6px}.meta-date{min-height:24px}.meta-date-badge{display:inline-flex;align-items:center;justify-content:center;background-color:#d92d20;color:#fff;font-weight:700;letter-spacing:.08em;font-size:.6875rem;padding:4px 8px;border-radius:999px;margin-left:8px;animation:exercise-new-pulse 1.8s ease-in-out infinite}.meta-date-badge--exiting{animation:exercise-new-pop-out .52s cubic-bezier(.22,1,.36,1) forwards}.meta-date-static{white-space:nowrap}.new-tag{background-color:#d92d20;color:#fff;font-weight:600;padding:4px 8px;border-radius:6px}.card-divider{border:none;height:1px;background-color:var(--border-color);margin:0 0 12px}.vocab-label{font-size:.8125rem;font-weight:600;color:var(--text-secondary);margin:0 0 8px}.vocab-tags{display:flex;flex-wrap:wrap;gap:8px}.vocab-tag{background-color:var(--tag-bg);color:var(--tag-text);padding:4px 10px;border-radius:12px;font-size:.75rem;font-weight:500;position:relative;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:width .2s ease-in-out}@media(prefers-color-scheme:dark){.vocab-tag{background-color:var(--accent-primary)!important;color:#fff!important}}.theme-dark .vocab-tag{background-color:var(--accent-primary)!important;color:#fff!important}.complete-btn.completed{background-color:var(--bg-tertiary);color:var(--text-secondary);cursor:not-allowed}.vocab-tag.is-loading{background-color:var(--tag-bg);position:relative;overflow:hidden}.vocab-tag.is-loading .vocab-term{color:transparent}.vocab-tag.is-loading:after{content:"";position:absolute;top:0;left:-150%;width:150%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);animation:shimmer 1.5s infinite}.vocab-tag .vocab-term{opacity:0;transition:opacity .3s ease-in-out}.vocab-tag .vocab-term.is-loaded{opacity:1}@keyframes shimmer{to{left:150%}}@keyframes image-lazy-shimmer{to{transform:translate(100%)}}@keyframes exercise-new-pulse{0%,to{transform:scale(1);box-shadow:0 0 #d92d2038}50%{transform:scale(1.06);box-shadow:0 0 0 8px #d92d2000}}@keyframes exercise-card-new-glow{0%,to{opacity:.52;box-shadow:0 0 6px #d92d2014,0 0 14px 2px #d92d200d,0 0 22px 5px #d92d2008}50%{opacity:.9;box-shadow:0 0 8px #d92d201c,0 0 18px 3px #d92d2014,0 0 28px 7px #d92d200b}}@keyframes exercise-new-pop{0%{opacity:1;transform:scale(1)}70%{opacity:1;transform:scale(1.14)}to{opacity:0;transform:scale(.84)}}@keyframes exercise-card-new-glow-out{0%{opacity:.62;transform:scale(1);box-shadow:0 0 7px #d92d2017,0 0 16px 3px #d92d2011,0 0 24px 6px #d92d200a}45%{opacity:.78;transform:scale(1.045);box-shadow:0 0 10px 1px #d92d201c,0 0 24px 5px #d92d2014,0 0 34px 9px #d92d200d}to{opacity:0;transform:scale(.96);box-shadow:0 0 4px #d92d2000,0 0 10px 1px #d92d2000,0 0 16px 3px #d92d2000}}@keyframes exercise-new-pop-out{0%{opacity:1;transform:scale(1);filter:blur(0)}45%{opacity:1;transform:scale(1.16);filter:blur(0)}to{opacity:0;transform:scale(.74);filter:blur(2px)}}@keyframes exercise-card-enter{0%{opacity:0;filter:blur(6px)}55%{opacity:.82;filter:blur(2px)}to{opacity:1;filter:blur(0)}}.card--reading .card-image-container,.card--reading .card-image-container .card-image,.card--reading .card-image-placeholder{height:180px}.skeleton-exercise-card .skeleton{background-color:#e0e0e0;position:relative;overflow:hidden}.skeleton-exercise-card .skeleton:after{content:"";position:absolute;top:0;left:-150%;width:150%;height:100%;background:linear-gradient(to right,transparent 0%,#e8e8e8 50%,transparent 100%);animation:shimmer 1.5s infinite}.skeleton-exercise-card .card-image-container,.skeleton-exercise-card .card-image-placeholder.skeleton{height:180px}.skeleton-exercise-card .skeleton-text{height:1em;border-radius:4px;display:inline-block;vertical-align:middle}.skeleton-exercise-card .card-title.skeleton-text{height:24px;margin-bottom:10px;width:80%}.skeleton-exercise-card .card-meta .meta-item .skeleton-text{height:14px}.skeleton-exercise-card .skeleton-level-text{width:18px;height:14px}.skeleton-exercise-card .progress-bar-skeleton{height:20px;border-radius:10px;margin:10px 0}.skeleton-exercise-card .complete-btn.skeleton{width:100%;height:40px;border-radius:8px}.skeleton-exercise-card .card-tag{display:inline-flex;align-items:center;gap:5px}.language-settings-card{padding:24px;border-bottom:1px solid var(--border-color)}.language-settings-card.language-settings-card--embedded{padding:20px 0 0;border-bottom:none;border-top:1px solid var(--border-color)}.language-settings-card h3{margin-top:0;margin-bottom:20px;font-size:.9rem;color:var(--accent-primary);font-weight:700;text-transform:uppercase;letter-spacing:.1em;border-bottom:2px solid var(--bg-secondary);padding-bottom:8px}.language-settings-card.language-settings-card--embedded h3{margin-bottom:18px}.language-group{display:flex;flex-direction:column;gap:20px}.language-item{display:flex;flex-direction:column;align-items:flex-start;gap:8px}.language-item.row{flex-direction:row;justify-content:space-between;align-items:center}.language-label{font-weight:500;color:var(--text-primary)}.language-select{width:100%;padding:12px;border-radius:12px;border:1px solid var(--border-color);background-color:var(--bg-secondary);color:var(--text-primary);font-size:1rem;transition:all .2s ease;appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right 12px center;background-size:16px}.language-select:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #2563eb1a;background-color:var(--bg-primary)}.language-settings-card.is-saving .language-item:not(.row){opacity:.72}.language-select:disabled{background-color:color-mix(in srgb,var(--accent-primary) 8%,var(--bg-secondary) 92%);border-color:color-mix(in srgb,var(--accent-primary) 32%,var(--border-color) 68%);color:color-mix(in srgb,var(--text-primary) 72%,transparent);cursor:wait;filter:blur(.45px) saturate(.82);box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--accent-primary) 20%,transparent)}.language-settings-card.is-saving .language-select:disabled{background-image:linear-gradient(135deg,color-mix(in srgb,var(--accent-primary) 10%,transparent),transparent),url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat,no-repeat;background-position:left 0 top 0,right 12px center;background-size:auto,16px}.language-settings-card.is-saving .language-item.row .slider{cursor:wait;background-color:color-mix(in srgb,var(--accent-primary) 24%,var(--bg-tertiary, #ccc) 76%);box-shadow:0 0 0 1px color-mix(in srgb,var(--accent-primary) 20%,transparent)}.switch.is-disabled{opacity:.7}.switch.is-disabled .slider{cursor:not-allowed;background-color:color-mix(in srgb,var(--accent-primary) 18%,var(--bg-tertiary, #ccc) 82%);box-shadow:0 0 0 1px color-mix(in srgb,var(--accent-primary) 16%,transparent);filter:saturate(.82)}.switch.is-disabled .slider:before{box-shadow:0 2px 4px #00000024}.switch{position:relative;display:inline-block;width:50px;height:28px}.slider{position:absolute;cursor:pointer;inset:0;background-color:var(--bg-tertiary, #ccc);transition:.4s;border-radius:34px}.slider:before{position:absolute;content:"";height:20px;width:20px;left:4px;bottom:4px;background-color:#fff;transition:.4s;border-radius:50%;box-shadow:0 2px 4px #0003}input:checked+.slider{background-color:var(--accent-primary, #4caf50)}input:focus+.slider{box-shadow:0 0 1px var(--accent-primary, #4caf50)}input:checked+.slider:before{transform:translate(22px)}.dashboard-container{display:flex;flex-direction:column;gap:32px;width:100%;max-width:1200px;margin:0 auto}.dashboard-card{background-color:var(--bg-secondary);border-radius:16px;padding:24px;box-shadow:var(--card-shadow);transition:all .3s ease}.user-info-card{display:flex;flex-direction:column;gap:24px}.user-card-header{display:flex;align-items:center;gap:16px;min-width:0}.user-avatar{width:56px;height:56px;border-radius:50%;background-color:var(--accent-primary);color:var(--bg-secondary);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #0000001a;overflow:hidden;flex:0 0 56px}.user-avatar-image{width:100%;height:100%;object-fit:cover;display:block}.user-details{display:flex;flex-direction:column;min-width:0;flex:1}.user-name{margin:0;font-size:1.5rem;font-weight:700;color:var(--text-primary);line-height:1.2;overflow-wrap:anywhere;word-break:break-word;max-width:100%}.user-name--medium{font-size:1.35rem}.user-name--small{font-size:1.15rem}.user-name--tiny{font-size:1rem}.user-role{font-size:.9rem;color:var(--text-secondary);font-weight:500}.user-progress-section{margin-top:8px}.user-info-card .language-settings-card--embedded{margin-top:-4px}.progress-header{display:flex;justify-content:space-between;margin-bottom:8px;font-size:.9rem;color:var(--text-secondary)}.progress-title{font-weight:600}.progress-bar-container{height:8px;background-color:var(--bg-primary);border-radius:4px;overflow:hidden}.progress-bar-fill{height:100%;background-color:var(--accent-primary);border-radius:4px;transition:width .5s ease-out}.section-title{font-size:1.25rem;font-weight:700;color:var(--text-primary);margin:0 0 16px}.level-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px}.level-card{background-color:var(--bg-secondary);border-radius:16px;padding:20px;box-shadow:var(--card-shadow);transition:all .3s cubic-bezier(.25,.8,.25,1);border:1px solid transparent;display:flex;flex-direction:column;gap:16px;cursor:default}.level-card.active{border-color:var(--border-color)}.level-card.inactive{opacity:.6;filter:grayscale(.8);background-color:var(--bg-primary)}.level-card-header{display:flex;justify-content:space-between;align-items:center}.level-info{display:flex;align-items:center;gap:12px}.level-badge{background-color:var(--bg-primary);color:var(--text-primary);font-weight:800;padding:6px 10px;border-radius:8px;font-size:.9rem}.level-card.active .level-badge{background-color:var(--accent-primary);color:#fff}.level-name{font-weight:600;color:var(--text-primary);font-size:1rem}.level-controls{display:flex;align-items:center;gap:12px}.level-controls-column{display:flex;flex-direction:column;align-items:center;gap:6px;width:44px;flex:0 0 44px}.level-stats-slot{min-height:12px;display:flex;align-items:center;justify-content:center;width:44px;flex:0 0 44px;text-align:center}.switch{position:relative;display:inline-block;width:44px;height:24px}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;inset:0;background-color:#ccc;transition:.4s;border-radius:24px}.slider:before{position:absolute;content:"";height:18px;width:18px;left:3px;bottom:3px;background-color:#fff;transition:.4s;border-radius:50%;box-shadow:0 2px 4px #0003}input:checked+.slider{background-color:var(--accent-primary)}input:checked+.slider:before{transform:translate(20px)}.level-mini-progress{display:flex;align-items:center;gap:12px}.mini-bar-container{flex:1;height:6px;background-color:var(--bg-primary);border-radius:3px;overflow:hidden;width:100%}.mini-bar-fill{height:100%;background-color:var(--accent-primary);border-radius:3px;transition:width .5s ease-out}.mini-bar-fill.is-resetting{transition:none}.mini-stats-text{font-size:.75rem;color:var(--text-secondary);font-weight:600;line-height:1;text-align:center;white-space:nowrap;display:block;width:100%}.mini-stats-text--small{font-size:.68rem}.mini-stats-skeleton{display:inline-block;width:36px;height:12px;border-radius:999px;background:linear-gradient(90deg,var(--bg-primary) 0%,rgba(255,255,255,.35) 50%,var(--bg-primary) 100%);background-size:200% 100%;animation:dashboard-shimmer 1.3s linear infinite}@keyframes dashboard-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes fly-in{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.fly-in{animation:fly-in .6s cubic-bezier(.2,.8,.2,1) forwards}.prepare-animation{opacity:0}@media(max-width:600px){.level-grid{grid-template-columns:1fr}}.skeleton{background-color:#e0e0e0;position:relative;overflow:hidden;border-radius:4px}.skeleton:after{content:"";position:absolute;top:0;left:-150%;width:150%;height:100%;background:linear-gradient(to right,transparent 0%,rgba(255,255,255,.4) 50%,transparent 100%);animation:shimmer 1.5s infinite}.user-name-skeleton{height:28px;width:150px;margin-bottom:5px}.user-role-skeleton{height:18px;width:100px}[data-theme=dark] .skeleton{background-color:#333}[data-theme=dark] .skeleton:after{background:linear-gradient(to right,transparent 0%,rgba(255,255,255,.1) 50%,transparent 100%)}.skeleton-vocab-card .skeleton,.skeleton-vocab-card .skeleton-line{background-color:#e0e0e0;position:relative;overflow:hidden;border-radius:4px}.skeleton-vocab-card .skeleton:after,.skeleton-vocab-card .skeleton-line:after{content:"";position:absolute;top:0;left:-150%;width:150%;height:100%;background:linear-gradient(to right,transparent 0%,#f0f0f0 50%,transparent 100%);animation:shimmer 1.5s infinite}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.skeleton-line{height:16px;display:block}.button-spinner{width:20px;height:20px;border:2px solid var(--bg-primary);border-bottom-color:transparent;border-radius:50%;display:inline-block;box-sizing:border-box;animation:rotation 1s linear infinite}@keyframes rotation{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.quiz-article-container{margin-bottom:2.5em;padding:8px 0 28px;background-color:transparent;max-width:100%;margin-left:auto;margin-right:auto}.article-title{margin-top:0;margin-bottom:.75em;font-size:1.9em;font-weight:600;color:var(--text-primary);line-height:1.3;text-align:center;padding:0 18px .5em;border-bottom:2px solid var(--accent-primary, #800080)}.article-banner{width:100%;height:clamp(230px,32vw,360px);margin-top:.5em;margin-bottom:2.4em;border-radius:0;box-shadow:none;display:block;position:relative;overflow:hidden}.article-banner img{display:block;width:100%;height:100%;object-fit:cover;margin:0;border-radius:0}.article-header-overlay{position:relative;width:100%;height:250px;margin-bottom:24px;border-radius:12px;overflow:hidden;box-shadow:0 4px 12px #00000026;display:flex;justify-content:center;align-items:center;text-align:center}.article-header-overlay img{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;transition:transform .5s ease;z-index:0}.article-header-overlay:hover img{transform:scale(1.02)}.header-overlay-gradient{position:absolute;top:0;left:0;width:100%;height:100%;background:#00000059;z-index:1;pointer-events:none}.article-header-overlay .article-title-overlay{position:relative;z-index:2;color:#fff;font-size:2rem;font-weight:700;text-shadow:0 2px 10px rgba(0,0,0,.5);margin:0;padding:20px;width:100%;line-height:1.2}.article-content{display:grid;gap:2.8rem}.article-paragraph-block{margin-bottom:0;display:flow-root}.section-heading{max-width:760px;margin:0 auto .9em;padding:0 12px;font-size:clamp(1.45rem,2.5vw,1.9rem);font-weight:700;letter-spacing:-.02em;color:var(--text-primary);line-height:1.2;position:relative}.section-heading:before{content:"";display:block;width:54px;height:2px;margin-bottom:14px;background:color-mix(in srgb,var(--accent-primary, #800080) 72%,transparent);border-radius:999px}.paragraph-image{position:relative;width:100vw;max-width:100vw;height:clamp(220px,42vw,360px);overflow:hidden;margin-top:10px;margin-bottom:22px;margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw);border-radius:0;box-shadow:none;display:block}.paragraph-image img{position:absolute;inset:0;display:block;width:100%;height:100%;object-fit:cover;margin:0;border-radius:0;opacity:0;transition:opacity .5s ease-in-out}.paragraph-image img.loaded{opacity:1}.article-image-placeholder{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(45deg,#4527a01a,#4527a005);color:var(--accent-primary)}.article-image-placeholder.is-lazy:after{content:"";position:absolute;inset:0;background:linear-gradient(110deg,transparent 0%,rgba(255,255,255,.18) 45%,transparent 100%);transform:translate(-100%);animation:article-image-shimmer 1.4s ease-in-out infinite}@media(prefers-color-scheme:dark){.article-image-placeholder{background:linear-gradient(45deg,#673ab740,#673ab70d);color:#fff}}@keyframes article-image-shimmer{to{transform:translate(100%)}}.paragraph-image.left,.paragraph-image.right{float:none;display:block}.article-text{max-width:760px;margin:0 auto;padding:0 12px;font-size:1.08rem;line-height:1.9;color:var(--text-primary);text-align:justify;text-justify:inter-word;-webkit-hyphens:auto;hyphens:auto;text-wrap:pretty;opacity:.96}.interactive-text-container{display:inline}.article-text.is-lead{font-size:1.16rem;line-height:2}.article-text.is-lead .interactive-text-container:first-letter{float:left;font-size:4rem;line-height:.84;font-weight:700;margin-right:.12em;margin-top:.12em;color:var(--accent-primary, #800080)}@media(max-width:768px){.quiz-article-container{padding:6px 0 18px}.article-title{font-size:1.6em}.article-banner,.article-banner img{height:200px}.section-heading{font-size:1.4rem;padding:0 10px}.paragraph-image{float:none!important;width:100vw;max-width:100vw;height:clamp(200px,54vw,320px);margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw);margin-top:1em;margin-bottom:18px}.article-text{padding:0 10px;font-size:1.03rem;line-height:1.84;text-align:left;-webkit-hyphens:none;hyphens:none}.article-text.is-lead{font-size:1.08rem;line-height:1.9}.article-text.is-lead .interactive-text-container:first-letter{font-size:3.2rem;margin-top:.08em}}@media(max-width:480px){.article-banner,.article-banner img{height:150px}}.interactive-word{cursor:pointer;display:inline;border-radius:5px;padding:0 2px;transition:background-color .2s,color .2s;user-select:none;-webkit-user-select:none;box-decoration-break:clone;-webkit-box-decoration-break:clone}.highlighted{background-color:#f0f0f0;color:var(--accent-primary, #800080);font-weight:inherit;text-shadow:0 0 0 currentColor,.35px 0 0 currentColor,-.35px 0 0 currentColor,0 .35px 0 currentColor}.theme-highlight-active{background-color:#f0f0f0;color:var(--accent-primary, #800080)!important;font-weight:inherit;text-shadow:0 0 0 currentColor,.35px 0 0 currentColor,-.35px 0 0 currentColor,0 .35px 0 currentColor;border-radius:5px;padding:0 2px}.vocabulary-highlight{background-color:#007bff1a;color:#007bff;font-weight:inherit;text-shadow:0 0 0 currentColor,.35px 0 0 currentColor,-.35px 0 0 currentColor,0 .35px 0 currentColor;padding:0 2px;border-radius:5px}.vocabulary-highlight.theme-highlight-active{background-color:#f0f0f0;color:var(--accent-primary, #800080)!important}@media(prefers-color-scheme:dark){.vocabulary-highlight{background-color:#007bff66;color:#66b0ff}.theme-highlight-active,.vocabulary-highlight.theme-highlight-active{background-color:var(--accent-primary, #800080)!important;color:var(--text-on-accent, #ffffff)!important}}.definition-tooltip{background:var(--active-theme-color, #800080);color:#fff;border-radius:12px;box-shadow:0 4px 10px #00000040;padding:10px 15px;width:300px;max-width:320px;font-size:var(--tooltip-font-size, .78em);border:none;line-height:1.5;z-index:10000;position:fixed;top:0;left:0;opacity:0;transform:scale(.95);transition:opacity .2s ease-in-out,transform .2s ease-in-out,visibility 0s linear .2s;pointer-events:none;visibility:hidden}.definition-tooltip.visible{opacity:1;transform:scale(1);pointer-events:auto;visibility:visible;transition:opacity .2s ease-in-out,transform .2s ease-in-out,visibility 0s linear 0s}.definition-tooltip.is-loading-content{width:auto;min-width:unset;max-width:none;padding:4px 10px;display:flex;justify-content:center;align-items:center;border-radius:20px;font-size:var(--tooltip-loading-font-size, .74em)}.tooltip-loading{color:#ffffffe6;text-align:center;font-style:italic;padding:10px;font-size:.9em}.tooltip-header{display:flex;align-items:flex-start;gap:8px;margin-bottom:8px;border-bottom:1px solid rgba(255,255,255,.2);padding-bottom:8px}.tooltip-entry+.tooltip-entry{margin-top:10px;padding-top:10px;border-top:1px solid rgba(255,255,255,.18)}.tooltip-entry .tooltip-header{margin-bottom:8px}.tooltip-entry .tooltip-body:last-child{margin-bottom:0}.audio-btn{background:none;border:none;cursor:pointer;padding:0;width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:transform .2s,background-color .28s ease,box-shadow .28s ease,border-color .28s ease;position:relative;flex-shrink:0;overflow:hidden;will-change:transform,opacity}.audio-btn:hover{transform:scale(1.1)}.audio-btn:disabled{cursor:default}.audio-btn.is-playing{background-color:#fff;transform:none}.audio-btn svg{width:100%;height:100%;display:block;opacity:1;transform:scale(1);transition:opacity .28s ease,transform .34s cubic-bezier(.22,.9,.22,1.12)}.audio-btn svg circle{fill:#fff}.audio-btn svg path{fill:var(--active-theme-color, #800080)}.audio-btn svg line{stroke:var(--active-theme-color, #800080);stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.audio-waveform{width:100%;height:100%;display:inline-flex;align-items:center;justify-content:center;gap:2px;opacity:1;transform:scale(1);transition:opacity .28s ease,transform .34s cubic-bezier(.22,.9,.22,1.12)}.audio-waveform span{width:2px;height:9px;border-radius:999px;background:var(--active-theme-color, #800080);animation:tooltip-audio-wave .9s ease-in-out infinite;transform-origin:center}.audio-waveform span:nth-child(2){animation-delay:.1s}.audio-waveform span:nth-child(3){animation-delay:.2s}.audio-waveform span:nth-child(4){animation-delay:.3s}@keyframes tooltip-audio-wave{0%,to{transform:scaleY(.45);opacity:.7}50%{transform:scaleY(1);opacity:1}}.audio-btn.is-loading{cursor:wait;background:radial-gradient(circle at 30% 30%,#ffffff4d,#ffffff14 68%),#ffffff1f;box-shadow:inset 0 0 0 1px #ffffff2e,0 0 0 1px #ffffff14}.audio-btn.is-loading svg,.audio-btn.is-loading .audio-waveform{opacity:0;transform:scale(.72)}.audio-btn.is-loading:before{content:"";position:absolute;inset:0;border-radius:50%;background:radial-gradient(circle at center,rgba(255,255,255,.18),transparent 72%);animation:tooltip-audio-pulse 1.2s ease-in-out infinite}.audio-btn.is-loading:after{content:"";position:absolute;top:0;left:-35%;width:58%;height:100%;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.92) 48%,transparent 100%);transform:skew(-18deg) translate(0);animation:dre-shimmer 1.15s ease-in-out infinite;border-radius:50%}@keyframes dre-shimmer{0%{transform:skew(-18deg) translate(-150%);opacity:0}20%{opacity:.9}to{transform:skew(-18deg) translate(320%);opacity:0}}@keyframes tooltip-audio-pulse{0%,to{opacity:.45;transform:scale(.94)}50%{opacity:.9;transform:scale(1.02)}}.definition-tooltip .word-title{font-weight:700;font-size:var(--tooltip-title-font-size, .98em);color:#fff;display:block;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:clip}.definition-tooltip .word-type{font-style:italic;color:#fffc;font-size:.9em;display:block;margin-top:2px;line-height:1.15}.word-meta{min-width:0;flex:1 1 auto;display:flex;flex-direction:column;justify-content:center;overflow:hidden;padding-top:1px}.definition-tooltip .word-title.is-phrase.is-long{font-size:.91em}.definition-tooltip .word-title.is-phrase.is-very-long{font-size:.84em}.wordlist-btn{position:relative;margin-left:auto;width:28px;height:28px;padding:0;border:1.5px solid rgba(255,255,255,.32);border-radius:999px;background:#ffffff14;color:#fff;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:transform .22s ease,border-color .22s ease,background-color .22s ease,opacity .22s ease}.wordlist-btn:hover:not(:disabled){transform:scale(1.06);background:#ffffff24;border-color:#ffffff80}.wordlist-btn:disabled{cursor:default}.wordlist-icon{position:absolute;width:15px;height:15px;opacity:0;transform:scale(.82);transition:opacity .22s ease,transform .22s ease}.wordlist-icon path,.wordlist-icon circle{fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.wordlist-btn.state-plus .plus-icon,.wordlist-btn.state-loading .loading-icon,.wordlist-btn.state-added .tick-icon,.wordlist-btn.state-error .error-icon{opacity:1;transform:scale(1)}.wordlist-btn.state-loading .loading-icon{animation:tooltip-wordlist-spin 1s linear infinite}.wordlist-btn.state-loading .loading-icon circle{stroke-dasharray:44 100;stroke-dashoffset:8}.wordlist-btn.state-added{background:#ffffff29;border-color:#ffffff7a}.wordlist-btn.state-error{background:#ff78782e;border-color:#ffb4b4bf}@keyframes tooltip-wordlist-spin{0%{transform:scale(1) rotate(0)}to{transform:scale(1) rotate(360deg)}}.tooltip-body{line-height:1.5}.definition{margin:0 0 8px}.definition strong{color:#fff;font-weight:800}.definition em{color:#ffffffe6}.translation{margin-top:8px;padding-top:8px;border-top:1px dashed rgba(255,255,255,.3);font-size:.85em;color:#ffffffe6}.translation strong{color:#fff}.tooltip-translation-loader{display:inline-block;width:96px;max-width:100%;height:.85em;border-radius:999px;vertical-align:middle;background:linear-gradient(90deg,#ffffff2e,#ffffff6b,#ffffff2e);background-size:200% 100%;animation:tooltip-translation-shimmer 1.1s linear infinite}@keyframes tooltip-translation-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.example-sentence{margin-top:8px;font-style:italic;color:#ffffffd9}.tooltip-arrow{position:absolute;bottom:-6px;left:50%;transform:translate(-50%);width:0;height:0;border-left:6px solid transparent;border-right:6px solid transparent;border-top:6px solid var(--active-theme-color, #800080)}body.light-mode .wordlist-btn{border-color:#ffffff73;background:#ffffff24}body.light-mode .wordlist-btn:hover:not(:disabled){background:#fff3}.discussion-questions-list{display:flex;flex-direction:column;gap:10px;padding-bottom:120px}.discussion-question-card{position:relative;display:flex;align-items:flex-start;gap:10px;width:100%;padding:15px 18px;border:1px solid var(--border-color);border-left:4px solid var(--border-color);border-radius:12px;background:var(--bg-secondary);color:var(--text-primary);text-align:left;cursor:pointer;transition:background-color .25s ease,border-left-color .25s ease,transform .25s ease,padding-left .25s ease,box-shadow .25s ease;-webkit-tap-highlight-color:transparent}.discussion-question-card:active{transform:scale(1.01)}.discussion-question-card.is-active{background-color:rgba(var(--accent-primary-rgb),.18);border-color:var(--accent-primary);border-left-color:var(--accent-primary);padding-left:23px;box-shadow:0 8px 18px #0000001a}.discussion-question-number{flex:0 0 auto;min-width:24px;color:var(--text-secondary);font-size:.96rem;font-weight:700}.discussion-question-text{font-size:1rem;font-weight:600;line-height:1.55}.discussion-question-text .interactive-word,.discussion-question-text .theme-highlight-active,.discussion-question-text .highlighted,.discussion-question-text .vocabulary-highlight{padding-left:0;padding-right:0;text-shadow:none}.theme-dark .discussion-question-card.is-active{background-color:rgba(var(--accent-primary-rgb),.22);box-shadow:0 8px 18px #0000003d}@media(max-width:640px){.discussion-question-card{padding:14px 16px}}.quiz-finish-screen{display:flex;flex-direction:column;align-items:center;justify-content:flex-start;text-align:center;min-height:100%;padding:48px 20px 120px}.quiz-finish-screen h3{margin:0 0 12px}.quiz-finish-screen p{max-width:320px;margin:0;line-height:1.6;color:var(--text-secondary)}.quiz-finish-button{display:inline-flex;align-items:center;justify-content:center;width:100%;max-width:260px;min-height:50px;margin-top:24px;padding:12px 22px;background:var(--accent-primary);color:var(--text-on-accent);border:none;border-radius:999px;font-size:1rem;font-weight:700;cursor:pointer;box-shadow:0 8px 20px rgba(var(--accent-primary-rgb),.24);transition:transform .16s ease,filter .2s ease,box-shadow .2s ease}.quiz-finish-button:hover{filter:brightness(1.02);box-shadow:0 10px 24px rgba(var(--accent-primary-rgb),.3)}.quiz-finish-button:active{transform:translateY(1px) scale(.99)}.quiz-mcq-container{max-width:100%;margin:0 auto;box-sizing:border-box;color:var(--text-primary)}.mcq-questions-list{list-style:none;padding:0;margin:0;display:grid;gap:18px}.mcq-question-item{position:relative;list-style:none;padding:20px 18px 18px;border:1px solid color-mix(in srgb,var(--border-color) 78%,transparent);border-radius:12px;background:var(--bg-secondary);box-shadow:0 1px 3px #0000000f;overflow:hidden;transition:border-color .25s ease,box-shadow .25s ease}.mcq-question-item:before{content:"";position:absolute;inset:0 auto 0 0;width:5px;background:var(--accent-primary);opacity:.9}.mcq-question-item.correct:before{background:var(--accent-green)}.mcq-question-item.incorrect:before{background:var(--accent-red)}.mcq-question-item.unanswered:before{background:var(--accent-yellow)}.mcq-question-item.checked.correct{border-color:color-mix(in srgb,var(--accent-green) 45%,var(--border-color) 55%);box-shadow:0 1px 3px #0000000f}.mcq-question-item.checked.incorrect{border-color:color-mix(in srgb,var(--accent-red) 45%,var(--border-color) 55%);box-shadow:0 1px 3px #0000000f}.mcq-question-item.shake-incorrect{animation:quizShake .42s ease-in-out}.mcq-question-item.checked.unanswered{border-color:color-mix(in srgb,var(--accent-yellow) 55%,var(--border-color) 45%);box-shadow:0 1px 3px #0000000f}.mcq-question-shell{display:grid;gap:14px}.mcq-question-header{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}.mcq-question-number,.mcq-question-status{display:inline-flex;align-items:center;gap:6px;min-height:30px;padding:0 12px;border-radius:999px;font-size:.72rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.mcq-question-number{background:color-mix(in srgb,var(--accent-primary) 12%,var(--bg-primary) 88%);color:var(--accent-primary);border:1px solid color-mix(in srgb,var(--accent-primary) 20%,transparent)}.mcq-question-status{border:1px solid transparent}.mcq-question-status.correct{color:#15803d;background:#22c55e1f;border-color:#22c55e4d}.mcq-question-status.incorrect{color:#b91c1c;background:#ef44441f;border-color:#ef44444d}.mcq-question-status.unanswered{color:#b45309;background:#f59e0b24;border-color:#f59e0b4d}.mcq-question-text{font-size:1rem;font-weight:600;line-height:1.65;color:var(--text-primary)}.mcq-options-list{list-style:none;padding:0;margin:18px 0 0;display:grid;gap:10px}.mcq-option{position:relative;font-size:.95em}.mcq-option input[type=radio]{display:none}.mcq-option label{display:grid;grid-template-columns:auto 1fr;align-items:center;gap:12px;padding:14px 16px;border:1px solid color-mix(in srgb,var(--border-color) 85%,transparent);border-radius:10px;background:var(--bg-primary);color:var(--text-primary);transition:transform .18s ease,background-color .25s ease,border-color .25s ease,box-shadow .25s ease,color .25s ease;cursor:pointer;position:relative;overflow:hidden}.mcq-option label:before{content:"";width:22px;height:22px;border-radius:50%;border:2px solid color-mix(in srgb,var(--accent-primary) 35%,var(--border-color) 65%);background:transparent;box-sizing:border-box;transition:transform .18s ease,background-color .2s ease,border-color .2s ease}.mcq-option label:hover{border-color:color-mix(in srgb,var(--accent-primary) 45%,var(--border-color) 55%);box-shadow:0 1px 3px #0000000f}.mcq-option input[type=radio]:checked+label{background:var(--accent-primary);color:var(--text-on-accent);border-color:color-mix(in srgb,var(--accent-primary) 80%,black 20%);box-shadow:none}.mcq-option input[type=radio]:checked+label:before{background:var(--text-on-accent);border-color:var(--text-on-accent);box-shadow:inset 0 0 0 5px var(--accent-primary);transform:scale(1.05)}.mcq-question-item.checked .mcq-option label{cursor:default}.mcq-question-item.checked .mcq-option.correct-answer label{border-color:#22c55e73;background:#22c55e1f;color:var(--text-primary);font-weight:700;box-shadow:none}.mcq-question-item.checked .mcq-option.correct-answer label:before{background:var(--accent-green);border-color:var(--accent-green);box-shadow:inset 0 0 0 5px #fffffff2}.mcq-question-item.checked .mcq-option.selected-incorrect label{border-color:#ef444473;background:#ef44441f;color:var(--text-primary);text-decoration:line-through;box-shadow:none}.mcq-question-item.checked .mcq-option.selected-incorrect label:before{background:var(--accent-red);border-color:var(--accent-red);box-shadow:inset 0 0 0 5px #fffffff2}.mcq-question-item.checked .mcq-option.selected-incorrect label span,.mcq-question-item.checked .mcq-option.selected-incorrect label .interactive-word{text-decoration:line-through}.mcq-question-item.checked .mcq-option.correct-answer label:after,.mcq-question-item.checked .mcq-option.selected-incorrect label:after{position:absolute;right:14px;top:50%;transform:translateY(-50%);font-weight:800;font-size:1rem}.mcq-question-item.checked .mcq-option.correct-answer label:after{content:"✓";color:#15803d}.mcq-question-item.checked .mcq-option.selected-incorrect label:after{content:"✗";color:#b91c1c}.mcq-controls{margin-top:26px;text-align:center;padding:10px 0 72px}.mcq-check-button,.mcq-reset-button{display:inline-flex;align-items:center;justify-content:center;min-width:180px;min-height:48px;padding:12px 22px;background:var(--accent-primary);color:var(--text-on-accent);border:none;border-radius:999px;cursor:pointer;font-size:.98rem;font-weight:800;letter-spacing:.01em;transition:background-color .2s ease,filter .2s ease;box-shadow:none}.mcq-check-button:hover,.mcq-reset-button:hover{filter:brightness(1.02)}.mcq-feedback-overall{margin-top:0;margin-bottom:10px;padding:14px 16px;font-weight:800;font-size:1rem;border-radius:18px;border:1px solid transparent}.mcq-feedback-overall.success{color:#15803d;background:#22c55e1f;border-color:#22c55e4d}.mcq-feedback-overall.error{color:#b91c1c;background:#ef44441f;border-color:#ef44444d}.mcq-checking-indicator{text-align:center;font-size:.98em;color:var(--text-secondary);padding:10px;font-style:italic}.quiz-placeholder{padding:20px;text-align:center;color:var(--text-secondary)}.confetti-piece{position:absolute;width:8px;height:16px;background-color:#28a745;opacity:0;z-index:9999;pointer-events:none;animation:fadeAndFly 1.5s ease-out forwards}@keyframes fadeAndFly{0%{transform:translate(0) rotate(0) scale(1);opacity:1}to{transform:translate(var(--x),var(--y)) rotate(var(--rot)) scale(.2);opacity:0}}@media(max-width:640px){.mcq-question-item{padding:16px;border-radius:10px}.mcq-option label{padding:13px 14px}.mcq-controls{padding-left:14px;padding-right:14px}}@media(prefers-color-scheme:dark){.mcq-question-item,.mcq-option label{box-shadow:none}}.quiz-tf-container{max-width:100%;margin:0 auto;color:var(--text-primary)}.tf-questions-list{list-style:none;padding:0;margin:0;display:grid;gap:18px}.tf-question-block{position:relative;padding:20px 18px 18px;border:1px solid color-mix(in srgb,var(--border-color) 78%,transparent);border-radius:12px;background:var(--bg-secondary);box-shadow:0 1px 3px #0000000f;overflow:hidden;transition:border-color .25s ease,box-shadow .25s ease}.tf-question-block:before{content:"";position:absolute;inset:0 auto 0 0;width:5px;background:var(--accent-primary)}.tf-question-block.correct:before{background:var(--accent-green)}.tf-question-block.incorrect:before{background:var(--accent-red)}.tf-question-block.unanswered:before{background:var(--accent-yellow)}.tf-question-block.checked.correct{border-color:color-mix(in srgb,var(--accent-green) 45%,var(--border-color) 55%);box-shadow:0 1px 3px #0000000f}.tf-question-block.checked.incorrect{border-color:color-mix(in srgb,var(--accent-red) 45%,var(--border-color) 55%);box-shadow:0 1px 3px #0000000f}.tf-question-block.shake-incorrect{animation:quizShake .42s ease-in-out}.tf-question-block.checked.unanswered{border-color:color-mix(in srgb,var(--accent-yellow) 55%,var(--border-color) 45%);box-shadow:0 1px 3px #0000000f}.tf-question-shell{display:grid;gap:14px}.tf-question-header{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}.tf-question-number,.tf-question-status{display:inline-flex;align-items:center;min-height:30px;padding:0 12px;border-radius:999px;font-size:.72rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.tf-question-number{background:color-mix(in srgb,var(--accent-primary) 12%,var(--bg-primary) 88%);color:var(--accent-primary);border:1px solid color-mix(in srgb,var(--accent-primary) 20%,transparent)}.tf-question-status.correct{color:#15803d;background:#22c55e1f;border:1px solid rgba(34,197,94,.3)}.tf-question-status.incorrect{color:#b91c1c;background:#ef44441f;border:1px solid rgba(239,68,68,.3)}.tf-question-status.unanswered{color:#b45309;background:#f59e0b24;border:1px solid rgba(245,158,11,.3)}.tf-question-text{margin:0;font-size:1rem;font-weight:600;line-height:1.65}.tf-options{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:18px}.tf-btn{display:flex;align-items:center;justify-content:center;min-height:46px;padding:10px 16px;border-radius:999px;border:1px solid color-mix(in srgb,var(--border-color) 85%,transparent);background:var(--bg-primary);color:var(--text-primary);text-align:center;cursor:pointer;transition:transform .18s ease,border-color .25s ease,box-shadow .25s ease,background-color .25s ease,color .25s ease;font-size:.95rem;font-weight:700;font-family:var(--font-main);position:relative;overflow:hidden}.tf-btn:hover:not(:disabled){border-color:color-mix(in srgb,var(--accent-primary) 45%,var(--border-color) 55%);box-shadow:0 1px 3px #0000000f}.tf-btn.selected{background:var(--accent-primary);color:var(--text-on-accent);border-color:color-mix(in srgb,var(--accent-primary) 80%,black 20%);box-shadow:none}.tf-btn.correct-answer{background:#22c55e1f;border-color:#22c55e73;color:var(--text-primary);box-shadow:none}.tf-btn.wrong-answer{background:#ef44441f;border-color:#ef444473;color:var(--text-primary);text-decoration:line-through;box-shadow:none}.tf-btn.correct-answer:after,.tf-btn.wrong-answer:after{position:absolute;right:12px;top:50%;transform:translateY(-50%);font-weight:800;font-size:.95rem}.tf-btn.correct-answer:after{content:"✓";color:var(--accent-green)}.tf-btn.wrong-answer:after{content:"✕";color:var(--accent-red)}.tf-btn:disabled{cursor:default}.tf-controls{margin-top:26px}@media(max-width:640px){.tf-question-block{padding:16px;border-radius:10px}.tf-btn{min-height:46px}}@keyframes quizShake{0%,to{transform:translate(0)}20%{transform:translate(-6px)}40%{transform:translate(5px)}60%{transform:translate(-4px)}80%{transform:translate(3px)}}@media(prefers-color-scheme:dark){.tf-question-block,.tf-btn{box-shadow:none}}.setting-item{display:flex;justify-content:space-between;align-items:center;min-height:48px;padding:4px 0}.setting-item span{font-weight:500;color:var(--text-primary)}.logout-item{margin-top:32px}.button-logout{width:100%;padding:14px;background-color:transparent;color:var(--color-error, #ef4444);border:1px solid var(--border-color);border-radius:12px;cursor:pointer;font-weight:600;transition:all .2s ease}.button-logout:hover{background-color:#ef44440d;border-color:var(--color-error, #ef4444)}.button-logout:active{transform:scale(.98)}.button-logout:disabled{opacity:.5;cursor:not-allowed}.app-version-dashboard{font-size:.8rem;color:var(--text-secondary);text-align:center;margin-top:24px;opacity:.7}.theme-selector{display:flex;gap:12px}.theme-button{width:32px;height:32px;border-radius:50%;border:3px solid transparent;cursor:pointer;transition:transform .2s cubic-bezier(.34,1.56,.64,1),box-shadow .2s;box-shadow:0 2px 4px #0000001a}.theme-button:hover{transform:scale(1.1)}.theme-button.active{border-color:var(--bg-primary);box-shadow:0 0 0 2px var(--text-primary);transform:scale(1.1)}.theme-button.purple{background-color:purple}.theme-button.red{background-color:#e50914}.theme-button.orange{background-color:#ea580c}.settings-modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#0009;display:flex;justify-content:center;align-items:center;z-index:3000;opacity:0;transition:opacity .4s ease;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.settings-modal-overlay.visible{opacity:1}.settings-modal-content{background-color:var(--bg-primary);width:90%;max-width:480px;max-height:85vh;overflow:hidden;border-radius:20px;box-shadow:0 15px 40px #00000040;transform:scale(.95);transition:transform .4s cubic-bezier(.19,1,.22,1);display:flex;flex-direction:column}.settings-modal-overlay.visible .settings-modal-content{transform:scale(1)}.settings-modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;background:linear-gradient(135deg,var(--bg-secondary) 0%,var(--bg-primary) 100%);border-bottom:1px solid var(--border-color)}.settings-modal-header h2{margin:0;font-size:1.4rem;color:var(--text-primary);font-weight:700}.settings-modal-header .close-btn{background:#0000000d;border:none;font-size:1.25rem;color:var(--text-secondary);cursor:pointer;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease}.settings-modal-header .close-btn:hover{background-color:#0000001a;color:var(--text-primary);transform:rotate(90deg)}.settings-modal-body{padding:0;overflow-y:auto;flex-grow:1;overscroll-behavior:contain}.settings-section{padding:24px;border-bottom:1px solid var(--border-color)}.settings-section:last-child{border-bottom:none}.settings-section h3{margin-top:0;margin-bottom:20px;font-size:.9rem;color:var(--accent-primary);font-weight:700;text-transform:uppercase;letter-spacing:.1em;border-bottom:2px solid var(--bg-secondary);padding-bottom:8px}.settings-group{display:flex;flex-direction:column;gap:20px}.study-modal-overlay *,.study-modal-overlay *:before,.study-modal-overlay *:after{box-sizing:border-box}.study-modal-overlay{position:fixed;inset:0;z-index:2100;display:flex;align-items:flex-end;justify-content:center;background:#0009;opacity:0;pointer-events:none;transition:opacity .3s ease}.study-modal-overlay.is-open{opacity:1;pointer-events:auto}.study-modal-shell{width:100%;height:calc(100% - 12px);display:flex;flex-direction:column;overflow:hidden;background:var(--bg-secondary);border-top-left-radius:18px;border-top-right-radius:18px;box-shadow:0 -10px 40px #0003;transform:translateY(100%);opacity:0;transition:transform .4s cubic-bezier(.32,.72,0,1),opacity .3s ease}.study-modal-overlay.is-open .study-modal-shell{transform:translateY(0);opacity:1}.study-modal-header{flex-shrink:0;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;padding:20px 30px;border-bottom:1px solid var(--border-color);background:var(--bg-secondary);z-index:1}.study-header-left,.study-header-center{color:var(--accent-primary);font-weight:700}.study-header-left{font-size:1.5rem}.study-header-center{font-size:1.25rem;text-align:center}.study-header-right{display:flex;align-items:center;justify-self:end;gap:20px}.study-points{color:var(--text-secondary);font-size:1.1rem;font-weight:600}.study-close{border:none;background:transparent;color:#aaa;cursor:pointer;font-size:2rem;line-height:1;padding:0}.study-close:hover{color:var(--text-primary)}.study-modal-body-scroll{flex:1;overflow-y:auto;padding:30px;overflow-x:hidden}.study-options-container{display:flex;justify-content:center;flex-wrap:wrap;gap:20px;padding:20px 0}.study-option-box,.study-option-btn,.study-check-btn,.study-next-btn,.study-quit-cancel,.study-quit-confirm{font-family:var(--font-main);-webkit-tap-highlight-color:transparent}.study-option-box{width:100px;height:100px;border-radius:12px;border:2px solid var(--accent-primary);background:var(--bg-lightest);color:var(--accent-primary);font-size:24px;font-weight:700;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 4px #0000000d}.study-option-box:hover{background:var(--accent-primary);color:var(--text-on-accent);transform:translateY(-2px)}.study-option-box:disabled,.study-option-box.is-disabled{opacity:.42;cursor:not-allowed;background:var(--bg-secondary);color:var(--text-secondary);border-color:var(--border-color);box-shadow:none}.study-option-box:disabled:hover,.study-option-box.is-disabled:hover{background:var(--bg-secondary);color:var(--text-secondary);transform:none}.study-loader{opacity:0;transition:opacity .5s ease-in-out}.study-loader.is-visible{opacity:1}.study-loader-graphic{width:140px;height:120px;margin:40px auto 20px;perspective:600px}.study-loader-graphic svg{width:100%;height:100%;overflow:visible;transform:rotateX(30deg)}.loader-card{fill:#fff;stroke:var(--accent-primary);stroke-width:1.5;rx:4;filter:drop-shadow(0 3px 0 color-mix(in srgb,var(--accent-primary) 20%,transparent))}.loader-card-soft{fill:color-mix(in srgb,var(--accent-primary) 12%,white)}.loader-card-decor{stroke:var(--accent-primary);stroke-width:2;stroke-linecap:round}.loader-card-decor-soft{opacity:.6}.stack-group{animation:study-stack-slide 1s ease-in-out infinite}.flier-left{opacity:0;animation:study-fly-left 2s cubic-bezier(.1,.8,.2,1) infinite}.flier-right{opacity:0;animation:study-fly-right 2s cubic-bezier(.1,.8,.2,1) infinite 1s}.card-fade{animation:study-card-fade 1s linear infinite}.study-loader-text{color:var(--accent-primary);text-align:center;font-size:1.2rem;font-weight:600;animation:study-text-pulse 2s ease-in-out infinite}.study-match-stage{display:flex;flex-direction:column;gap:18px;width:100%}.study-match-prompt{color:var(--text-secondary);text-align:center;font-size:1rem;line-height:1.5}.study-match-board{display:flex;flex-direction:column;gap:14px;align-items:stretch}.study-review-grid{max-width:1120px;width:100%;margin:0 auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:28px}.study-match-row{display:grid;gap:14px}.study-match-board.is-definition-mode .study-match-row{grid-template-columns:minmax(0,250px) minmax(0,1fr)}.study-match-board.is-translation-mode .study-match-row{grid-template-columns:minmax(0,1fr) minmax(0,1fr)}.study-match-card{border-radius:10px;border:2px solid color-mix(in srgb,var(--border-color) 86%,transparent);background:var(--bg-secondary);color:var(--text-primary);box-shadow:0 8px 18px #0000000d;cursor:pointer;transition:border-color .18s ease,background-color .18s ease,box-shadow .22s ease,transform .22s ease,min-height .35s ease,padding .35s ease;outline:none;position:relative;z-index:1;-webkit-tap-highlight-color:transparent}@media(hover:hover){.study-match-card:hover{border-color:color-mix(in srgb,var(--accent-primary) 34%,var(--border-color));transform:scale(1.015);z-index:2}}.study-match-card.is-selected{border-color:var(--accent-primary);background:color-mix(in srgb,var(--accent-primary) 10%,var(--bg-secondary));box-shadow:0 10px 20px color-mix(in srgb,var(--accent-primary) 14%,transparent);transform:scale(1.04);z-index:3}.study-match-card.is-matched{background:color-mix(in srgb,#2ecc71 14%,var(--bg-secondary))!important;border-color:#2f9246!important;color:color-mix(in srgb,#2f9246 86%,var(--text-primary));box-shadow:0 10px 18px #2f92461f;z-index:1}.study-match-card.is-mistake{border-color:var(--accent-primary);background:color-mix(in srgb,var(--accent-primary) 12%,var(--bg-secondary));animation:study-match-shake .4s}.study-match-word-card{opacity:0;transform:translateY(24px) scale(.97);display:flex;align-items:center;justify-content:center;text-align:center;align-self:stretch;height:100%;transition:opacity .42s ease var(--card-delay),transform .56s cubic-bezier(.18,.9,.22,1.08) var(--card-delay),border-color .2s ease,background-color .2s ease,box-shadow .25s ease,min-height .35s ease,padding .35s ease}.study-match-word-card.is-visible{opacity:1;transform:translateY(0) scale(1)}.study-flashcard-container{height:260px;perspective:1000px;opacity:0;transform:translateY(34px);transition:opacity .42s ease var(--card-delay),transform .52s cubic-bezier(.18,.9,.22,1.08) var(--card-delay);will-change:transform,opacity}.study-flashcard-container.is-visible{opacity:1;transform:translateY(0)}.study-flashcard{background-color:transparent;position:relative;width:100%;height:100%;cursor:pointer;display:flex;flex-direction:column;perspective:1000px}.study-flashcard.is-locked{cursor:default}.study-flashcard-inner{position:relative;width:100%;height:100%;transition:transform .82s cubic-bezier(.34,1.56,.64,1),box-shadow .3s ease;transform-style:preserve-3d;transform-origin:center center;box-shadow:0 12px 28px #0000001f;border-radius:15px;will-change:transform}.study-flashcard:not(.is-locked):not(.is-flipped):hover .study-flashcard-inner{transform:translateY(-8px) rotateX(5deg);box-shadow:0 18px 36px #0000002e}.study-flashcard.is-flipped .study-flashcard-inner{transform:rotateY(180deg)}.study-flashcard-front,.study-flashcard-back{position:absolute;inset:0;width:100%;height:100%;border-radius:15px;backface-visibility:hidden;-webkit-backface-visibility:hidden;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:18px 16px;transform-style:preserve-3d}.study-flashcard-front{background:var(--accent-primary);border:2px solid var(--accent-primary);color:var(--text-on-accent);position:relative;font-weight:800;text-shadow:0 2px 4px rgba(0,0,0,.28)}.study-flashcard-front h3{margin:0;font-size:1.5rem;line-height:1.18;color:inherit}.study-flashcard-back{background:color-mix(in srgb,var(--accent-primary) 82%,black 8%);border:2px solid color-mix(in srgb,var(--accent-primary) 88%,black 12%);color:#fff;transform:rotateY(180deg);box-shadow:inset 0 0 20px #0000001f}.study-flashcard-back p{margin:0;font-size:1rem;line-height:1.38;font-weight:500;width:100%;max-height:100%;overflow:hidden;overflow-wrap:anywhere}.study-flashcard-translation{margin:0;font-size:.92rem;line-height:1.32;color:#ffffffe6;transition:opacity .24s ease,transform .24s ease}.study-flashcard-translation.hidden{opacity:0;transform:translateY(-6px)}.study-match-stage.is-board-active .study-match-word-card{height:92px;min-height:92px;padding:16px 18px;align-items:center;justify-content:center;opacity:1;transform:translateY(0) scale(1)}.study-match-board.is-definition-mode .study-match-word-card{min-height:108px;padding:18px}.study-match-definition-card{padding:18px 20px;height:92px;min-height:92px;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;overflow:hidden;opacity:0;transform:translate(26px) scale(.985);transition:opacity .35s ease var(--card-delay),transform .48s cubic-bezier(.22,1,.36,1) var(--card-delay),border-color .2s ease,background-color .2s ease,box-shadow .25s ease}.study-match-definition-card.is-visible{opacity:1;transform:translate(0) scale(1)}.study-match-board.is-definition-mode .study-match-definition-card{height:auto;min-height:116px;padding:18px 20px;overflow:visible}.study-match-card-main{font-size:1.18rem;font-weight:700;line-height:1.4;width:100%;overflow-wrap:anywhere}.study-match-word-card .study-match-card-main{font-size:1rem;line-height:1.22}.study-match-definition-card .study-match-card-main{font-size:.92rem;line-height:1.28}.study-match-board.is-definition-mode .study-match-definition-card .study-match-card-main{font-size:.96rem;line-height:1.34}.study-match-card.is-unavailable{opacity:.38;filter:saturate(.4);cursor:default;pointer-events:none}.study-next-btn-container{display:flex;justify-content:center;width:100%;margin-top:30px;padding-bottom:20px}.study-next-btn{position:relative;padding:12px 40px;border:none;border-radius:999px;background:var(--accent-primary);color:var(--text-on-accent);font-size:18px;font-weight:700;cursor:pointer;box-shadow:0 4px 10px color-mix(in srgb,var(--accent-primary) 30%,transparent);transition:all .3s ease}.study-next-btn:hover{transform:translateY(-2px)}.study-next-btn:disabled{background:#ccc;box-shadow:none;cursor:not-allowed;transform:none}.study-next-btn:disabled:hover:after{content:attr(data-tooltip);position:absolute;left:50%;bottom:120%;transform:translate(-50%);padding:8px 12px;border-radius:6px;background:#333;color:#fff;font-size:14px;white-space:nowrap}.study-quiz-container{width:100%;max-width:600px;margin:0 auto;padding:20px;text-align:center}.study-question-card{width:100%;margin-bottom:30px;padding:34px 32px;border:1px solid var(--border-color);border-radius:16px;background:var(--bg-secondary);box-shadow:0 10px 26px #0000000f;overflow-wrap:anywhere}.study-question-label{display:block;margin-bottom:5px;color:var(--text-secondary);font-size:.8rem}.study-question-text,.study-example-box{color:var(--text-primary);font-size:1.38rem;line-height:1.65;overflow-wrap:anywhere}.study-options-grid{display:grid;gap:15px;width:100%}.study-option-btn{width:100%;padding:15px 20px;border:2px solid color-mix(in srgb,var(--border-color) 80%,transparent);border-radius:10px;background:var(--bg-lightest);color:var(--text-primary);font-size:1.1rem;font-weight:600;text-transform:capitalize;cursor:pointer;transition:all .2s ease;white-space:normal;line-height:1.35;-webkit-user-select:none;user-select:none}.study-option-btn:hover{border-color:var(--accent-primary);color:var(--accent-primary)}.study-option-btn.correct{background:#d4edda;border-color:#28a745;color:#155724}.study-option-btn.incorrect{background:#f8d7da;border-color:#dc3545;color:#721c24}.study-audio-card{display:flex;flex-direction:column;align-items:center;gap:20px}.study-audio-card p{margin:0;color:var(--text-secondary);font-style:italic}.study-big-audio-btn{width:100px;height:100px;border:none;border-radius:50%;background:var(--accent-primary);color:var(--text-on-accent);display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 4px 15px #0003;-webkit-tap-highlight-color:transparent}.study-big-audio-btn:hover{background:var(--accent-primary-hover);transform:scale(1.05)}.study-input-container{display:flex;justify-content:center;flex-wrap:wrap;gap:14px;margin-top:26px;padding-top:4px}.study-input{width:min(320px,100%);min-height:52px;padding:12px 18px;border:2px solid #ddd;border-radius:12px;font-size:1.1rem;font-weight:600;text-align:center;transition:border-color .2s ease,box-shadow .2s ease;background:var(--bg-secondary);color:var(--text-primary)}.study-input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 4px color-mix(in srgb,var(--accent-primary) 14%,transparent)}.study-input::placeholder{color:var(--text-secondary);text-align:center}.study-input.is-success{border-color:#28a745}.study-input.is-error{border-color:#dc3545}.study-check-btn,.study-close-session-btn,.study-quit-confirm{border:none;background:var(--accent-primary);color:var(--text-on-accent);font-weight:700;cursor:pointer}.study-check-btn{min-height:52px;padding:12px 28px;border-radius:12px;font-size:1.05rem;box-shadow:0 10px 22px color-mix(in srgb,var(--accent-primary) 20%,transparent);transition:transform .2s ease,box-shadow .2s ease,background-color .2s ease}.study-check-btn:hover:not(:disabled){background:var(--accent-primary-hover);transform:translateY(-1px)}.study-check-btn:disabled{opacity:.72;box-shadow:none;cursor:default}.study-feedback{min-height:28px;margin-top:18px;font-weight:700;line-height:1.5}.study-feedback.success{color:#28a745}.study-feedback.error,.study-inline-error{color:#dc3545}.study-gap{display:inline-block;padding:0 2px;font-weight:700;color:var(--accent-primary)}.study-final-card{text-align:center}.study-final-card h2{margin-top:0}.study-final-score{margin:20px 0;font-size:2rem;font-weight:700}.study-saving-spinner{width:42px;height:42px;margin:20px auto 0;border:4px solid color-mix(in srgb,var(--accent-primary) 16%,transparent);border-top-color:var(--accent-primary);border-radius:50%;animation:study-spin .8s linear infinite}.study-quit-overlay{position:fixed;inset:0;z-index:2101;display:flex;align-items:center;justify-content:center;background:#00000073;opacity:0;pointer-events:none;transition:opacity .25s ease}.study-quit-overlay.is-open{opacity:1;pointer-events:auto}.study-quit-modal{width:min(92vw,360px);padding:24px;border-radius:16px;background:var(--bg-secondary);box-shadow:var(--card-shadow)}.study-quit-modal h3{margin-top:0}.study-quit-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:20px}.study-quit-cancel,.study-quit-confirm{padding:10px 16px;border-radius:10px}.study-quit-cancel{border:1px solid var(--border-color);background:var(--bg-lightest);color:var(--text-primary);cursor:pointer}.fade-in{opacity:0;transform:translateY(12px) scale(.985);animation:study-slide-in .38s cubic-bezier(.22,1,.36,1) forwards}.fade-out{opacity:0;transform:translateY(-10px) scale(.985);transition:opacity .28s ease,transform .28s cubic-bezier(.4,0,1,1)}.study-quiz-container .fade-in{will-change:opacity,transform}.transition-primary{animation-delay:0ms;transition-delay:0ms}.transition-secondary{animation-delay:70ms;transition-delay:40ms}.transition-tertiary{animation-delay:.13s;transition-delay:80ms}.score-pop{animation:study-score-pop .4s cubic-bezier(.175,.885,.32,1.275);color:#28a745}.pulse{animation:study-btn-pulse 1.5s infinite}@keyframes study-stack-slide{0%{transform:translate(0)}to{transform:translateY(8px)}}@keyframes study-fly-left{0%{transform:translate(-80px,-60px) rotate(-15deg) scale(1.1);opacity:0}35%{opacity:1}50%{transform:translate(0) rotate(0) scale(1);opacity:1}50.1%,to{opacity:0}}@keyframes study-fly-right{0%{transform:translate(80px,-60px) rotate(15deg) scale(1.1);opacity:0}35%{opacity:1}50%{transform:translate(0) rotate(0) scale(1);opacity:1}50.1%,to{opacity:0}}@keyframes study-card-fade{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translateY(6px)}}@keyframes study-text-pulse{0%,to{opacity:.7}50%{opacity:1}}@keyframes study-fly-up{to{opacity:1;transform:translateY(0)}}@keyframes study-spin{to{transform:rotate(360deg)}}@keyframes study-match-shake{0%,to{transform:translate(0)}20%{transform:translate(-4px)}40%{transform:translate(4px)}60%{transform:translate(-3px)}80%{transform:translate(3px)}}@keyframes study-slide-in{to{opacity:1;transform:translateY(0) scale(1)}}@keyframes study-score-pop{0%{transform:scale(1)}50%{transform:scale(1.5)}to{transform:scale(1)}}@keyframes study-btn-pulse{0%{box-shadow:0 0 color-mix(in srgb,var(--accent-primary) 70%,transparent)}to{box-shadow:0 0 0 0 transparent}}@media(max-width:600px){.study-modal-shell{width:100%;height:100%;border-top-left-radius:18px;border-top-right-radius:18px;transform:translateY(100%)}.study-modal-overlay.is-open .study-modal-shell{transform:translateY(0)}.study-modal-header{display:flex;flex-direction:column;gap:10px;padding:10px 15px}.study-header-left{display:none}.study-header-right{width:100%;justify-content:space-between}.study-modal-body-scroll{padding:18px 16px 24px}.study-quiz-container{padding:4px 0 12px}.study-question-card{padding:26px 18px;margin-bottom:20px}.study-question-text,.study-example-box{font-size:1.12rem;line-height:1.6}.study-input{width:100%;min-width:0}.study-check-btn{width:100%}.study-input-container{margin-top:22px}.study-review-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.study-review-grid.has-odd-tail .study-flashcard-container:last-child{grid-column:1 / -1;justify-self:center;width:calc(50% - 6px)}.study-flashcard-container{width:100%;height:auto;aspect-ratio:.96 / 1}.study-flashcard-front,.study-flashcard-back{padding:14px 10px}.study-flashcard-front h3{font-size:.94rem;line-height:1.14}.study-flashcard-translation{font-size:.74rem;line-height:1.18}.study-flashcard-back p{font-size:.84rem;line-height:1.24}.study-match-board.is-definition-mode .study-match-row{grid-template-columns:minmax(0,138px) minmax(0,1fr);gap:12px}.study-match-board.is-translation-mode .study-match-row{grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:12px}.study-match-card-main{font-size:.98rem}.study-match-definition-card{min-height:88px;padding:14px}.study-match-stage.is-board-active .study-match-word-card{height:82px;min-height:82px;padding:14px 12px}.study-match-board.is-definition-mode .study-match-word-card{height:auto;min-height:96px;padding:14px 12px}.study-match-definition-card{height:82px;min-height:82px;padding:12px 10px}.study-match-board.is-definition-mode .study-match-definition-card{height:auto;min-height:110px;padding:14px 12px}.study-match-definition-card .study-match-card-main{font-size:.8rem;line-height:1.22}.study-match-board.is-definition-mode .study-match-definition-card .study-match-card-main{font-size:.84rem;line-height:1.26}.study-match-word-card .study-match-card-main{font-size:.82rem;line-height:1.14}}
