@charset "UTF-8";@import"https://fonts.googleapis.com/css2?family=Diplomata&display=swap";*{margin:0;padding:0;box-sizing:border-box}html,body{min-height:100%;overflow-x:hidden;overflow-y:auto;scroll-behavior:auto}a,.nav-link,.story-link,.main-navigation-menu a{min-height:44px;touch-action:manipulation;-webkit-tap-highlight-color:var(--black-10);text-decoration:none;color:inherit}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}:root{--color-primary: #99DA44;--color-primary-hover: #7AB832;--color-primary-active: #6BA228;--color-primary-light: #aadf65;--color-action: #557597;--color-action-hover: #46607F;--color-action-active: #354961;--color-action-light: #739FC7;--color-action-lighter: #7ec5f74f;--color-success: #27ae60;--color-success-hover: #2ecc71;--color-success-active: #248b4f;--color-success-light: #d4edda;--color-warning: #f39c12;--color-warning-dark: #c05621;--color-error: #e74c3c;--color-error-light: #f8d7da;--error-light-bg: #fff5f5;--masculine-blue: #4a90e2;--feminine-red: #e74c3c;--neuter-green: #27ae60;--masculine-blue-light: rgba(74, 144, 226, .1);--feminine-red-light: rgba(231, 76, 60, .1);--neuter-green-light: rgba(39, 174, 96, .1);--masculine-blue-alpha-30: rgba(74, 144, 226, .3);--feminine-red-alpha-30: rgba(231, 76, 60, .3);--neuter-green-alpha-30: #27ae604d;--gray-50: #f8f9fa;--gray-100: #f1f1f1;--gray-200: #e9ecef;--gray-300: #dee2e6;--gray-400: #ced4da;--gray-500: #adb5bd;--gray-600: #6c757d;--gray-700: #495057;--gray-800: #343a40;--gray-900: #212529;--text-primary: black;--text-black: black;--text-secondary: #6c757d;--text-muted: #adb5bd;--text-white: #ffffff;--text-on-primary: #ffffff;--text-dark-blue: #2c3e50;--bg-primary: #ffffff;--bg-white: #ffffff;--bg-secondary: #f8f9fa;--bg-surface: #f1f1f1;--bg-panel: #fafbfc;--bg-dark: #557597;--bg-black: black;--bg-gold: gold;--bg-gold-light: rgba(255, 217, 0, .539);--black-05: rgba(0, 0, 0, .05);--black-10: rgba(0, 0, 0, .1);--black-20: rgba(0, 0, 0, .2);--black-30: rgba(0, 0, 0, .3);--black-50: rgba(0, 0, 0, .5);--black-70: rgba(0, 0, 0, .7);--black-90: rgba(0, 0, 0, .9);--border-light: #e9ecef;--border-medium: #ced4da;--border-strong: #adb5bd;--border-dark: #4c637a;--border-orange: orange;--border-gold: gold;--border-dark-light: black;--hover-overlay: rgba(0, 0, 0, .05);--focus-ring: rgba(52, 152, 219, .3);--disabled-opacity: .6;--tap-highlight: rgba(0, 0, 0, .1);--shadow-light: 0 1px 3px rgba(0, 0, 0, .1);--shadow-medium: 0 2px 8px rgba(0, 0, 0, .1);--shadow-heavy: 0 4px 15px rgba(0, 0, 0, .15);--shadow-extra: 0 2px 4px rgba(0, 0, 0, .4);--radius-small: 4px;--radius-medium: 8px;--radius-large: 12px;--radius-pill: 20px;--radius-circle: 50%;--font-xs: .7rem;--font-sm: .75rem;--font-md: .85rem;--font-base: .9rem;--font-lg: 1rem;--font-xl: 1.1rem;--font-2xl: 1.4rem;--font-3xl: 1.5rem;--font-4xl: 1.6rem;--font-5xl: 1.8rem;--font-6xl: 2.5rem;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-xxl: 3rem;--navigation-height: 80px}[data-theme=dark]{color-scheme:dark;--color-primary: #59747B;--color-primary-hover: #7AB832;--color-primary-active: #6BA228;--color-primary-light: #aadf65;--color-action: #6d8caf;--color-action-hover: #5a7592;--color-action-active: #4a5f75;--color-action-light: rgba(109, 140, 175, .5);--color-action-lighter: rgba(109, 140, 175, .3);--color-success: #27ae60;--color-success-hover: #2ecc71;--color-success-active: #248b4f;--color-success-light: #525e54;--color-warning: #f39c12;--color-warning-dark: #c05621;--color-error: #e74c3c;--color-error-light: #f8d7da;--error-light-bg: #fff5f5;--text-primary: #f3f4f6;--text-black: black;--text-secondary: var(--text-primary);--text-muted: #94a3b8;--text-white: #ffffff;--text-on-primary: #0b1410;--text-dark-blue: #dddcdc;--bg-primary: #353535;--bg-white: #ffffff;--bg-secondary: #201f1f;--bg-surface: #1f2937;--bg-panel: #353535;--bg-dark: #2f3435;--bg-black: #000000;--bg-gold: gold;--bg-gold-light: rgba(255, 217, 0, .539);--border-light: #adb0b3;--border-medium: var(--border-light);--border-strong: #868a8f;--border-dark: #dfdfdf;--border-orange: orange;--border-gold: gold;--border-dark-light: var(--border-dark);--gray-50: #5c5b5b;--gray-100: #747474;--gray-600: #d3d3d3;--hover-overlay: rgba(255, 255, 255, .06);--focus-ring: rgba(147, 197, 253, .35);--tap-highlight: rgba(255, 255, 255, .08);--shadow-light: 0 1px 3px rgba(0, 0, 0, .6);--shadow-medium: 0 2px 8px rgba(0, 0, 0, .55);--shadow-heavy: 0 4px 15px rgba(0, 0, 0, .6);--shadow-extra: 0 2px 4px rgba(0, 0, 0, .8);--black-05: rgba(255, 255, 255, .05);--black-10: rgba(255, 255, 255, .1);--black-20: rgba(255, 255, 255, .2);--black-30: rgba(255, 255, 255, .3);--black-50: rgba(255, 255, 255, .5);--black-70: rgba(255, 255, 255, .7);--black-90: rgba(19, 19, 19, .9)}.preferences-icon{display:inline-block;vertical-align:middle;margin-right:.5rem;object-fit:contain;filter:brightness(.9);transition:filter .2s ease}.btn:hover .preferences-icon,.btn:focus .preferences-icon{filter:brightness(1.1)}.btn.active .preferences-icon,.btn:active .preferences-icon{filter:brightness(1.2)}.lesson-icon{display:inline-block;vertical-align:middle;margin:0 auto;object-fit:contain;filter:brightness(.9);transition:filter .2s ease}.btn:hover .lesson-icon,.btn:focus .lesson-icon{filter:brightness(1.1)}.btn.active .lesson-icon,.btn:active .lesson-icon{filter:brightness(1.2)}h2 .lesson-icon{margin-right:.5rem;vertical-align:baseline}.normal-icon{display:inline-block;vertical-align:middle;margin:0 auto;object-fit:contain;filter:brightness(.9);transition:filter .2s ease}a:hover .normal-icon,a:focus .normal-icon{filter:brightness(1.1)}a.active .normal-icon,a:active .normal-icon{filter:brightness(1.2)}.bookmark-icon{display:inline-block;vertical-align:middle;object-fit:contain;filter:brightness(.9);transition:filter .2s ease,transform .2s ease}.btn:hover .bookmark-icon,.btn:focus .bookmark-icon{filter:brightness(1.1);transform:scale(1.05)}.btn.active .bookmark-icon,.btn:active .bookmark-icon{filter:brightness(1.1);transform:scale(1.05)}.btn--icon-only .bookmark-icon{margin-right:0}.study-option-icon{display:block;margin:0 auto;object-fit:contain;filter:brightness(.9);transition:filter .3s ease,transform .3s ease}.panel--interactive:hover .study-option-icon,.panel--interactive:focus .study-option-icon{filter:brightness(1.1);transform:scale(1.1)}.panel--interactive:active .study-option-icon{filter:brightness(1.2);transform:scale(1.05)}.header-menu-icon{display:inline-block;vertical-align:middle;object-fit:contain;filter:brightness(.9);transition:filter .2s ease,transform .2s ease}.header-user-menu-item:hover .header-menu-icon,.header-user-menu-item:focus .header-menu-icon{filter:brightness(1.1);transform:scale(1.05)}.header-user-menu-item:active .header-menu-icon{filter:brightness(1.2);transform:scale(1.02)}.btn-icon{display:inline-block;vertical-align:middle;margin-right:.5rem;object-fit:contain;filter:brightness(.9);transition:filter .2s ease,transform .2s ease}.btn:hover .btn-icon,.btn:focus .btn-icon{filter:brightness(1.1);transform:scale(1.05)}.btn:active .btn-icon{filter:brightness(1.2);transform:scale(1.02)}.tab-icon-image{display:inline-block;vertical-align:middle;margin-right:.5rem;object-fit:contain;filter:brightness(.9);transition:filter .2s ease}.empty-state-icon-image{display:block;margin:0 auto;object-fit:contain;filter:brightness(.8);opacity:.7;transition:filter .3s ease,opacity .3s ease}.section-header-icon{display:inline-block;vertical-align:middle;margin-right:.5rem;object-fit:contain;filter:brightness(.9);transition:filter .2s ease,transform .2s ease}.preference-group-header:hover .section-header-icon,.preference-group-header:focus .section-header-icon{filter:brightness(1.1);transform:scale(1.05)}.stats-icon{display:block;margin:0 auto;object-fit:contain;filter:brightness(.8);transition:filter .3s ease,transform .3s ease}.panel--stats:hover .stats-icon{filter:brightness(1);transform:scale(1.1)}.diplomata-regular{font-family:Diplomata,serif;font-weight:400;font-style:normal}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--bg-light)}html,body{min-height:100%;overflow-x:hidden}.app{min-height:100vh;display:flex;flex-direction:column;margin:0;padding:0;scroll-behavior:auto}.app-body{flex:1;display:flex;flex-direction:column;overflow-x:hidden;background:var(--white-20);scroll-behavior:auto}@media (max-width: 1279px){.app{padding-top:var(--header-height, 64px)}}@media (max-width: 1279px){.native .app{padding-top:0}}.page{position:relative;flex:1;padding:1rem;padding-bottom:calc(var(--navigation-height) + 1rem);background:var(--bg-secondary);min-height:calc(100vh - 50px);margin-bottom:30vh;border-bottom:1px solid var(--border-strong);border-radius:0 0 50px 50px;box-shadow:var(--shadow-extra)}.page .page-content{display:flex;flex-direction:column;margin-bottom:var(--spacing-xl);gap:var(--spacing-md)}.page-content{flex:1}.page--auth{display:flex;align-items:flex-start;justify-content:center;min-height:100vh}.page--auth .page-content{width:100%;max-width:500px;padding:var(--spacing-md) var(--spacing-md)}@media (min-width: 1280px){.page{padding-bottom:1rem}}.story-list-stats{display:flex;justify-content:center;align-items:center;gap:.5rem;margin-top:.5rem;font-size:.9rem;color:var(--gray-500)}.story-list-stat-item{color:var(--gray-600);font-weight:500}.stat-separator{color:var(--gray-400)}.panel{margin:0;background:var(--bg-primary);border-radius:var(--radius-large);box-shadow:var(--shadow-heavy);padding:var(--spacing-md);border:1px solid var(--border-strong);transition:var(--transition-normal)}.panel h1,.panel h2,.panel h3,.panel h4{color:var(--text-dark-blue);font-weight:700}.panel--interactive{cursor:pointer;transition:all .2s ease}.panel--interactive:focus-visible{transform:translateY(-1px)}.panel--clickable{cursor:pointer}.panel--small{padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-medium)}.panel--large{padding:var(--spacing-lg) var(--spacing-xl)}.panel--compact{padding:var(--spacing-xs)}.panel--selected{border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary-light);background:var(--color-primary-lighter, rgba(0, 123, 255, .05));transform:translateY(-2px)}.panel--selected:before{content:"✓";position:absolute;top:8px;right:8px;background:var(--color-primary);color:#fff;width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;z-index:10}.panel--disabled{opacity:.6;cursor:not-allowed;filter:grayscale(.3)}.panel--loading{position:relative;pointer-events:none}.panel--loading:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:20px;height:20px;border:2px solid var(--border-light);border-top:2px solid var(--color-primary);border-radius:50%;animation:spin 1s linear infinite}.panel:focus-visible{outline:2px solid var(--focus-ring);outline-offset:2px}@media (prefers-reduced-motion: reduce){.panel,.panel--interactive,.panel--flashcard__inner{transition:none;transform:none}.panel--interactive:hover{transform:none}}@keyframes spin{0%{transform:translate(-50%,-50%) rotate(0)}to{transform:translate(-50%,-50%) rotate(360deg)}}.panel-grid{display:grid;gap:var(--spacing-sm);grid-template-columns:1fr}.panel-grid--dense{grid-template-columns:1fr;gap:var(--spacing-sm)}.panel-grid--horizontal,.panel-grid--stats{grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:var(--spacing-sm)}.panel-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.panel-stack{position:relative}.panel-stack .panel{position:absolute;top:0;left:0;width:100%}.panel-stack .panel:nth-child(1){z-index:3}.panel-stack .panel:nth-child(2){z-index:2;transform:translate(4px,4px)}.panel-stack .panel:nth-child(3){z-index:1;transform:translate(8px,8px)}.panel--auth{max-width:400px;padding:var(--spacing-lg);text-align:center}.panel--auth__header{margin-bottom:var(--spacing-md)}.panel--auth__header h1{font-size:var(--font-3xl);font-weight:700;color:var(--text-primary);margin-bottom:var(--spacing-sm)}.panel--auth__header p{color:var(--text-secondary);font-size:var(--font-md)}.panel--auth__form{display:flex;flex-direction:column;gap:var(--spacing-lg);text-align:left}.panel--auth__divider{display:flex;align-items:center;gap:var(--spacing-md);margin:var(--spacing-lg) 0;color:var(--text-secondary);font-size:var(--font-sm)}.panel--auth__divider:before,.panel--auth__divider:after{content:"";flex:1;height:1px;background:var(--border-medium)}.panel--auth__link{text-align:center;margin-top:var(--spacing-lg);color:var(--text-secondary);font-size:var(--font-lg)}.panel--auth__link a{color:var(--color-action-light);text-decoration:none;font-weight:600;transition:color .2s ease}.panel--auth__link a:hover{color:var(--color-action-dark);text-decoration:underline}.panel--auth__link .sign-up-here{font-size:var(--font-xl);text-decoration:underline}.panel--word{text-align:center;min-height:150px;display:flex;flex-direction:column;justify-content:center;gap:var(--spacing-md);position:relative;padding:var(--spacing-md)}.panel--word.panel--interactive{overflow:hidden}.panel--word.panel--interactive.slide-left .panel--word__content{transform:translate(-100%);opacity:0}.panel--word.panel--interactive.slide-right .panel--word__content{transform:translate(100%);opacity:0}.panel--word__header{display:flex;justify-content:space-between;align-items:center;margin-top:5px;padding-bottom:.5rem;height:3rem;border-bottom:1px solid black}.panel--word__count{position:absolute;left:10;bottom:10px;background-color:var(--gray-500);border:1px solid var(--border-dark);border-radius:6px;padding:var(--spacing-xs);color:var(--text-white);font-weight:700;width:fit-content;justify-self:center}.panel--word__actions{justify-self:flex-end}.panel--word .panel--word__content{display:flex;flex-direction:column;flex-wrap:wrap;transition:transform .3s ease-out,opacity .3s ease-out;transform:translate(0);opacity:1;align-content:center;gap:1rem}.panel--word__term{font-size:var(--font-4xl);font-weight:600;color:var(--text-primary);margin:0}.panel--word__term--long{font-size:var(--font-2xl);word-break:break-word}.panel--word__translation{font-size:var(--font-xl);color:var(--color-action);font-weight:500;font-style:italic;margin:0;margin-left:-.5rem}.vocabulary-grid .panel--word__translation{font-size:1.5rem}.panel--word__example{font-size:var(--font-size-small);color:var(--text-secondary);font-style:italic;line-height:1.4;text-align:left}.panel--profile{display:flex;flex-direction:column;text-align:center;gap:var(--spacing-lg);align-items:center}.panel--profile__avatar{align-self:center;display:flex;flex-direction:column;align-items:center}.panel--profile__avatar .avatar-circle{width:108px;height:108px;border:2px solid var(--border-dark);border-radius:50%;background:var(--color-primary);display:flex;align-items:center;justify-content:center;font-size:2rem;font-weight:700;color:#fff;box-shadow:var(--shadow-extra)}.panel--profile__avatar .avatar-circle--clickable{cursor:pointer;transition:var(--transition-normal);position:relative}.panel--profile__avatar .avatar-circle--clickable:hover{transform:translateY(-2px)}.panel--profile__avatar .avatar-circle--clickable:active{transform:translateY(0)}.panel--profile__avatar .avatar-circle--clickable:focus-visible{outline:3px solid var(--focus-ring, var(--color-primary-light));outline-offset:3px}.panel--profile__avatar .avatar-circle--clickable:hover:after{opacity:1;transform:scale(1)}.panel--profile__info{flex:1;width:100%}.panel--profile__info .profile-display h2{margin:0 0 var(--spacing-sm) 0;color:var(--text-primary);font-size:var(--font-2xl)}.panel--profile__info .profile-display .profile-email{color:var(--text-secondary);margin:0 0 var(--spacing-xs) 0;font-size:var(--font-md)}.panel--profile__info .profile-display .profile-level{color:var(--text-secondary);margin:0 0 var(--spacing-md) 0;font-size:var(--font-md)}.panel--profile__info .profile-form{display:flex;flex-direction:column;gap:var(--spacing-md);max-width:400px;margin:0 auto}.panel--profile__info .profile-form .form-input,.panel--profile__info .profile-form .form-select{padding:var(--spacing-sm);border:1px solid var(--border-medium);border-radius:var(--radius-medium);background:var(--bg-primary);color:var(--text-primary);font-size:var(--font-md);transition:var(--transition-normal)}.panel--profile__info .profile-form .form-input:focus,.panel--profile__info .profile-form .form-select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary-light)}.panel--profile__info .profile-form .form-actions{display:flex;flex-direction:column;gap:var(--spacing-md);margin-top:var(--spacing-sm)}.panel--profile__info .profile-form .form-actions .btn{width:100%}.panel--profile__actions{display:flex;flex-direction:column;gap:var(--spacing-sm);flex-wrap:wrap;margin-top:var(--spacing-md)}.panel--profile__actions .btn{width:100%}.panel--preferences .panel--preferences__header{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-sm);width:100%;text-align:left;padding:var(--spacing-sm) 0;margin:0 0 var(--spacing-xs) 0;background:transparent;border:none;cursor:pointer}.panel--preferences .panel--preferences__header h2{margin:0;font-size:var(--font-xl)}.panel--preferences .panel--preferences__header .preferences-expand-btn{pointer-events:none}.panel--preferences .panel--preferences__header:focus{outline:none;box-shadow:0 0 0 2px var(--color-primary-light);border-radius:var(--radius-small)}.panel--preferences__content{display:flex;flex-direction:column;gap:var(--spacing-lg);transition:max-height var(--transition-normal),opacity var(--transition-normal)}.panel--preferences .preference-group h3{margin:0 0 var(--spacing-md) 0;color:var(--text-primary);font-size:var(--font-lg);font-weight:600}.panel--preferences .preference-group .preference-controls{display:flex;flex-direction:column;gap:var(--spacing-sm)}.panel--preferences .preference-group .preference-item{display:flex;flex-direction:column;align-items:flex-start;gap:var(--spacing-xs);cursor:pointer;padding:var(--spacing-xs);border-radius:var(--radius-medium);transition:var(--transition-normal)}.panel--preferences .preference-group .preference-item:hover{background:var(--bg-secondary)}.panel--preferences .preference-group .preference-item input[type=checkbox]{width:18px;height:18px;accent-color:var(--color-primary)}.panel--preferences .preference-group .preference-item span{color:var(--text-primary);font-size:var(--font-md)}.panel--preferences .preference-group .preference-item .preference-select{margin-left:0;width:100%;padding:var(--spacing-xs) var(--spacing-sm);border:1px solid var(--border-medium);border-radius:var(--radius-small);background:var(--bg-primary);color:var(--text-primary);font-size:var(--font-sm)}.panel--preferences__content{gap:var(--spacing-md);margin-top:var(--spacing-md)}.panel--preferences .preference-group .preference-controls{gap:var(--spacing-xs)}.panel--preferences.is-collapsed .panel--preferences__content{max-height:0;overflow:hidden;opacity:0;padding-top:0;padding-bottom:0}.cache-status-indicator{display:flex;flex-direction:row;justify-content:center;align-items:center;gap:var(--spacing-sm);margin-bottom:-.8rem;padding:0}.cache-status-indicator .btn.refresh-button{border:none;font-size:var(--font-4xl)}.dashboard-section .panel--dashboard{display:flex;flex-direction:column;text-align:center;gap:var(--spacing-md)}.dashboard-section .panel--dashboard h2{border-bottom:2px solid var(--border-light);padding-bottom:var(--spacing-lg)}.dashboard-section .panel--dashboard__analytics .panel--analytics{padding:var(--spacing-md);background:var(--bg-secondary)}.panel--stats{text-align:center;padding:var(--spacing-md);transition:var(--transition-normal)}.panel--stats__icon{font-size:var(--font-2xl);margin-bottom:var(--spacing-sm)}.panel--stats__number{font-size:var(--font-3xl);font-weight:700;margin:var(--spacing-xs) 0;line-height:1}.panel--stats__label{font-size:var(--font-md);font-weight:600;color:var(--text-primary);margin:var(--spacing-xs) 0}.panel--stats__description{font-size:var(--font-sm);color:var(--text-secondary);margin:0}.panel--stats.panel--interactive:hover{transform:translateY(-4px);box-shadow:var(--shadow-large)}.panel--analytics .reading-heatmap{display:flex;gap:3px;justify-content:center}.panel--analytics .reading-heatmap .heatmap-week{display:grid;grid-template-rows:repeat(7,8px);gap:2px}.panel--analytics .reading-heatmap .heatmap-week .heatmap-day{width:8px;height:8px;border-radius:var(--radius-small);background:var(--bg-tertiary, #2a2a2a);transition:var(--transition-normal)}.panel--analytics .reading-heatmap .heatmap-week .heatmap-day.active{background:var(--color-success, #22c55e)}.panel--analytics .reading-heatmap .heatmap-week .heatmap-day:hover{transform:scale(1.2)}.header{display:grid;grid-template-columns:1fr 3fr 1fr;padding:var(--spacing-sm) var(--spacing-md);background:var(--color-primary);color:var(--bg-white);box-shadow:var(--shadow-extra);border-radius:0 0 10px 10px;align-items:center}.header--desktop{grid-template-columns:auto 1fr auto;padding:var(--spacing-md) var(--spacing-md) var(--spacing-xs)}.header .config-btn{background-color:var(--gray-50);color:var(--text-primary);font-weight:700}@media (max-width: 1279px){.header{position:fixed;top:0;left:0;width:100%;z-index:1000;transform:translateY(0);transition:transform .2s ease;will-change:transform}.header--hidden{transform:translateY(-100%)}}@media (max-width: 1279px) and (prefers-reduced-motion: reduce){.header{transition:none}}.native .header{position:static;top:auto;left:auto;width:auto;z-index:auto;transform:none}.header-section{display:flex;align-items:center}.header-section.streak-section{justify-content:flex-start}.header-section.streak-section .streak-display{display:flex;border:1px solid var(--border-dark);border-radius:8px;padding:.7rem .5rem;background-color:var(--color-action);align-items:center;gap:var(--spacing-xs);color:var(--text-white);font-weight:700}.header-section.streak-section .streak-icon{font-size:1.25rem;line-height:1}.header-section.streak-section .streak-count{font-size:1rem;line-height:1;min-width:1ch;text-align:left}.header-section.logo-section{pointer-events:none;justify-content:center}.header-section.logo-section h1.logo-text{margin:0;line-height:1;font-size:1.5rem}.header-section.logo-section .header-logo-link{pointer-events:auto;text-decoration:none;color:var(--text-white);display:inline-flex;align-items:center}.header-section.user-section{justify-self:flex-end;font-size:2rem}.header-section.user-section .log-in-btn{font-size:var(--font-2xl);padding:0;margin:0;border:none;background-color:inherit}.header .toast-notification{position:fixed;top:150px;left:50%;transform:translate(-50%,-50%);background:#000;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);color:var(--text-white);padding:var(--spacing-lg) var(--spacing-xl);border-radius:12px;border:1px solid rgba(255,255,255,.2);box-shadow:0 8px 32px #0003,0 4px 16px rgba(var(--color-success-rgb),.3),inset 0 1px #fff3;z-index:10000;animation:toastFadeInCenter .3s ease-out;font-weight:500;font-size:var(--font-md);text-align:center;max-width:80vw;opacity:1;pointer-events:none;overflow:hidden;--toast-duration: 2s}.header .toast-notification:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;animation:headerToastProgress var(--toast-duration) linear}.header .toast-notification.show{opacity:1;transform:translate(-50%,-50%) scale(1)}@keyframes toastFadeInCenter{0%{opacity:0;transform:translate(-50%,-50%) scale(.8)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}@keyframes headerToastProgress{0%{width:100%}to{width:0%}}.header--desktop .header-topbar{grid-column:1/-1;width:100%;display:flex;align-items:center;justify-content:center;margin-top:calc(var(--spacing-xs) * -1)}.header--desktop .header-section--left{justify-self:flex-start}.header--desktop .header-section--center{justify-self:center;flex:1;position:relative}.header--desktop .header-section--right{justify-self:flex-end;display:flex;align-items:flex-start;gap:var(--spacing-md)}.header--desktop .header-nav-main{display:flex;align-items:center;justify-content:center;gap:var(--spacing-lg);width:100%}.header--desktop .header-nav-item-wrapper{position:relative;display:flex;flex-direction:column;align-items:center}.header--desktop .header-nav-item{display:flex;align-items:center;padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-medium);text-decoration:none;color:var(--text-white);font-weight:500;font-size:var(--font-sm);transition:var(--transition-normal);min-width:80px;justify-content:center}.header--desktop .header-nav-item:hover{background:#ffffff1a;transform:translateY(-2px)}.header--desktop .header-nav-item--active{background:#fff3;font-weight:600}.header--desktop .header-nav-item__label{font-size:var(--font-sm);line-height:1}.header--desktop .header-nav-submenu{position:absolute;top:100%;left:50%;transform:translate(-50%);background:var(--color-primary);border:1px solid var(--border-dark);border-radius:0 0 1rem 1rem;box-shadow:var(--shadow-large);min-width:120px;z-index:1000;opacity:0;visibility:hidden;transition:all .2s ease-out;margin-top:var(--spacing-xs)}.header--desktop .header-nav-submenu--visible{opacity:1;visibility:visible}.header--desktop .header-nav-submenu-item{display:flex;align-items:center;justify-content:center;border-bottom:1px solid var(--border-light);border-radius:var(--radius-small);color:var(--text-white);font-size:var(--font-xs);font-weight:700;transition:var(--transition-fast);white-space:nowrap}.header--desktop .header-nav-submenu-item:hover{background:#fff3;transform:translateY(-1px)}.header--desktop .header-status{display:flex;align-items:center}.header--desktop .status-badge{padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-small);font-size:var(--font-xs);font-weight:600}.header--desktop .status-badge--offline{background:#ffe8a1;color:#6b4e00}.header--desktop .header-user{position:relative}.header--desktop .header-user-btn{font-size:var(--font-xl);position:relative;padding:0;min-width:44px;min-height:44px}.header--desktop .header-user-btn .avatar-display{width:100%;height:100%;border-radius:50%}.header--desktop .header-user-btn .avatar-display.avatar-display--small,.header--desktop .header-user-btn .avatar-display .avatar-display__image,.header--desktop .header-user-btn .avatar-display .avatar-display__letter{width:100%;height:100%}.header--desktop .header-user-menu{position:absolute;top:100%;right:0;margin-top:var(--spacing-sm);background:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-medium);box-shadow:var(--shadow-large);padding:var(--spacing-sm) 0;min-width:180px;z-index:1000;animation:fadeInDown .2s ease-out}.header--desktop .header-user-menu-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);color:var(--text-primary);text-decoration:none;font-size:var(--font-sm);width:100%;border:none;background:none;cursor:pointer;transition:var(--transition-fast)}.header--desktop .header-user-menu-item:hover{background:var(--bg-secondary)}.header--desktop .header-user-menu-item--action{color:var(--text-primary)}.header--desktop .header-user-menu-item--action:hover{background:var(--color-danger-light)}.header--desktop .header-user-menu-item__icon{font-size:1rem;width:1.2em;text-align:center}.header--desktop .header-user-menu-divider{border:none;border-top:1px solid var(--border-light);margin:var(--spacing-xs) 0}.header--desktop .header-section--left .streak-display{cursor:pointer;display:flex;border:1px solid var(--border-dark);border-radius:8px;padding:.7rem .5rem;background-color:var(--color-action);align-items:center;gap:var(--spacing-xs);color:var(--text-white);font-weight:700}.header--desktop .header-section--left .streak-display .streak-icon{font-size:1.25rem;line-height:1}.header--desktop .header-section--left .streak-display .streak-icon[src]{width:20px;height:20px;object-fit:contain;filter:brightness(1.1)}.header--desktop .header-section--left .streak-display .streak-count{font-size:1rem;line-height:1;min-width:1ch;text-align:left}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.main-navigation{width:100%;height:var(--navigation-height);background:var(--bg-dark);color:#fff;overflow:visible;position:fixed;bottom:0;left:0;z-index:100;flex-shrink:0;box-shadow:0 -2px 10px var(--black-20);border-top:1px solid var(--border-medium);transform:translateY(0);transition:transform .2s ease}.main-navigation-menu{display:flex;flex-direction:row;list-style:none;margin:0;padding:0;width:100%;justify-content:space-between;align-items:center}.main-navigation-menu li{margin-bottom:0;flex:1;display:flex;justify-content:center}.main-navigation-menu a{color:var(--text-muted);text-decoration:none;display:flex;align-items:center;justify-content:center;flex-direction:column;padding:var(--spacing-sm) .3rem;border-radius:var(--radius-medium);transition:all .3s ease;position:relative;white-space:nowrap;width:100%;min-width:0;max-width:100%;gap:.25rem;flex:1 1 0}.main-navigation-menu a span{display:flex;justify-content:center}.main-navigation-menu a.active{background:var(--color-primary);color:var(--text-white);font-weight:700;outline:2px solid var(--color-primary);outline-offset:2px;box-shadow:0 0 0 2px var(--focus-ring)}.main-navigation-menu a.active .main-navigation-icon .nav-icon-img{filter:brightness(1.2) contrast(1.1)}.main-navigation-logo{display:none}.main-navigation-content{display:flex;justify-content:space-between;flex-direction:row;width:100%;height:var(--navigation-height);position:relative;overflow:hidden;align-items:center;padding:.8rem .5rem}.main-navigation-icon{font-size:1.4rem;min-width:24px;text-align:center;display:block}.main-navigation-icon .nav-icon-img{text-align:bottom;justify-content:flex-end;align-items:flex-end;align-self:flex-end;justify-self:flex-end;width:25px;height:25px;margin:5px 0 0;padding:0;object-fit:contain;filter:brightness(.7);transition:var(--transition-fast)}.main-navigation-text{opacity:1;width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:.7rem;text-align:center;max-width:100%;font-weight:700;position:relative;display:flex;align-items:center;justify-content:center;gap:.25rem}.main-navigation .nav-count{background:var(--accent-primary);color:#fff;font-size:.6rem;font-weight:600;padding:.1rem .35rem;border-radius:10px;min-width:1.2rem;height:1.2rem;display:inline-flex;align-items:center;justify-content:center;line-height:1;margin-left:.2rem}.main-navigation--hidden{transform:translateY(100%)}@media (prefers-reduced-motion: reduce){.main-navigation{transition:none}}.user-info{display:flex;align-items:center;gap:.5rem;padding:.25rem;color:#fff;font-size:.8rem}.user-icon{font-size:1rem}.user-name{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.logout-button{display:flex;align-items:center;gap:.5rem;padding:.5rem;background:transparent;border:1px solid var(--border-medium);border-radius:4px;color:#fff;font-size:.8rem;cursor:pointer;transition:all .2s ease}.logout-button:hover{background:var(--red-dark);border-color:var(--red-medium)}.logout-icon{font-size:.9rem}.logout-text{font-weight:500}.auth-navigation{display:flex;flex-direction:column;gap:1rem;padding:1rem;height:100%;justify-content:center}.auth-nav-link{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:transparent;border:2px solid var(--border-medium);border-radius:8px;color:#fff;text-decoration:none;transition:all .2s ease;font-weight:600}.auth-nav-link:hover{background:#ffffff1a;border-color:var(--primary-medium);color:var(--primary-light)}.auth-nav-link.active{background:var(--primary-medium);border-color:var(--primary-medium);color:#fff}.auth-nav-icon{font-size:1.2rem}.auth-nav-text{font-size:.9rem}.dashboard-sidebar{display:flex;display:none;flex-direction:column;justify-content:flex-start;align-items:center;text-align:center;position:fixed;right:0;top:0;height:100vh;overflow-y:auto;z-index:100;width:300px;gap:1rem;padding:1rem;background:var(--bg-light);flex-shrink:0;border-left:1px solid var(--border-dark)}.dashboard-sidebar-section{background:var(--bg-white);margin-bottom:1.5rem;height:auto;width:16rem;padding:1rem;border-radius:8px;box-shadow:0 1px 3px var(--black-10)}.dashboard-sidebar-header{display:flex;justify-content:space-between}.story-card-container{width:100%}.panel--story{display:flex;flex-direction:column;gap:var(--spacing-md);position:relative;overflow:hidden;height:100%}.panel--story.read{border:2px solid black;background-color:var(--color-success-light);opacity:.9}.panel--story__header{display:flex;justify-content:space-between;align-items:center;padding:0}.panel--story__header .action-group{padding:0}.panel--story__header .story-card-read-indicator-btn{color:var(--color-success);font-weight:700;font-size:var(--font-lg)}.panel--story__main{display:flex;flex-direction:column;gap:.5rem;margin-bottom:var(--spacing-sm);width:100%;min-width:0}.panel--story__main--clickable{text-decoration:none;color:inherit;border-radius:var(--border-radius);background-color:inherit;padding:var(--spacing-xs);margin:calc(-1 * var(--spacing-xs));transition:background-color .2s ease}.panel--story__main--clickable:focus{outline:2px solid var(--accent-color);outline-offset:2px;text-decoration:none}.panel--story__title{display:block;font-size:var(--font-3xl);font-weight:600;color:var(--text-primary);margin:0;line-height:1.3;-webkit-hyphens:auto;-ms-hyphens:auto;hyphens:auto;word-wrap:break-word;overflow-wrap:break-word;word-break:break-word;min-width:0}.panel--story__content{font-family:Georgia,Times New Roman,Times,serif;font-size:var(--font-base);line-height:1.4;font-style:italic;-webkit-hyphens:auto;-ms-hyphens:auto;hyphens:auto;word-wrap:break-word;overflow-wrap:break-word;word-break:break-word;min-width:0}.panel--story__footer{display:flex;justify-content:space-between;align-items:center;margin-top:auto}.story-card-actions{display:flex;gap:var(--spacing-xs);align-items:center}.story-card-actions .btn{flex-shrink:0}.story-card-actions .story-card-lesson-btn{display:flex;flex-direction:column;font-size:var(--font-sm);white-space:nowrap}.story-card-actions .story-card-lesson-btn:hover{background-color:var(--accent-color);color:var(--text-white);text-decoration:none}.story-card-actions .story-card-lesson-btn:focus{outline:2px solid var(--accent-color);outline-offset:2px}.flashcard-controls-section{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-md)}.action-group--flashcard{-webkit-user-select:none;user-select:none}.action-group--flashcard .mode-btn{width:6rem}.action-group--flashcard .btn--primary.control-btn{display:flex;flex-direction:column;cursor:pointer;border-radius:8px;font-size:var(--font-base);min-width:3.5rem;min-height:3rem;transition:all .3s ease;line-height:.8;padding:.5rem .25rem;gap:.125rem}.action-group--flashcard .btn--primary.control-btn.last-pressed{border:2px solid var(--content-primary);box-shadow:0 0 0 1px #2c3e504d}.action-group--flashcard .btn--primary.control-btn .schedule-time{font-size:.75rem;font-weight:600;line-height:1;opacity:.9;text-align:center;min-height:.75rem;display:flex;align-items:center;justify-content:center}.action-group--flashcard .btn--primary.control-btn span:last-child{font-size:.8rem;font-weight:500;line-height:1;text-align:center}.action-group--flashcard .btn--primary.again-btn{background:var(--color-error)}.action-group--flashcard .btn--primary.again-btn:active{background:var(--color-error);filter:brightness(.8)}.action-group--flashcard .btn--primary.hard-btn{background:var(--color-warning)}.action-group--flashcard .btn--primary.hard-btn:active{background:var(--color-warning);filter:brightness(.8)}.action-group--flashcard .btn--primary.good-btn{background:var(--color-action)}.action-group--flashcard .btn--primary.good-btn:active{background:var(--color-success-hover);filter:brightness(.95)}.action-group--flashcard .btn--primary.easy-btn{background:var(--color-success)}.action-group--flashcard .btn--primary.easy-btn:active{background:var(--color-info);filter:brightness(.8)}.action-group--flashcard .btn--primary.disabled{opacity:.5;cursor:not-allowed;filter:grayscale(.5)}.action-group--flashcard .btn--primary.disabled:hover,.action-group--flashcard .btn--primary.disabled:active{transform:none;filter:grayscale(.5)}.auto-speed-controls{display:flex;align-items:center;justify-content:center;border-radius:8px;width:100%;padding:var(--spacing-sm);border:1px solid var(--border-medium);transition:all .3s ease}.auto-speed-controls .speed-buttons{display:flex;flex-direction:row;justify-content:space-around;align-items:center;border:none;border-radius:0;background:transparent;min-height:auto;width:100%}.auto-speed-controls .auto-speed-btn{width:5rem}.control-btn.last-pressed{border:2px solid var(--content-primary);box-shadow:0 0 0 1px #2c3e504d}.flashcard-main-text{font-size:var(--font-4xl);font-weight:700;color:var(--text-primary);line-height:1.2;text-align:center}.flashcard-translation{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-sm)}.flashcard-translation-text{font-size:var(--font-4xl);color:var(--text-primary);font-weight:700;text-align:center}.flashcard-example{font-size:var(--font-xl);color:var(--gray-600);font-style:italic;line-height:1.4;font-weight:400;text-align:center;margin-top:var(--spacing-sm);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}.flashcard-gender-indicator{position:absolute;display:flex;align-items:center;justify-content:center;top:.5rem;left:.5rem;z-index:10}.flashcard-counter{color:var(--gray-600);font-size:var(--font-base);margin-bottom:var(--spacing-md)}.flashcard-counter.srs-breakdown{display:flex;gap:var(--spacing-sm);justify-content:center;flex-wrap:wrap}.srs-stat{font-size:var(--font-sm);font-weight:500;padding:.25rem .5rem;border-radius:4px;white-space:nowrap}.srs-stat.new{background:var(--color-success);color:#fff}.srs-stat.learning{background:var(--color-warning);color:var(--gray-900)}.srs-stat.review{background:#000;color:#fff}.srs-stat.total{background:var(--gray-200);color:var(--gray-700)}.flashcard-display-section .btn.auto-mode-toggle-btn{position:absolute;align-self:flex-end;opacity:1}.deck-info{text-align:center;width:100%}.deck-info .deck-name{background-color:var(--bg-secondary);font-size:var(--font-md);color:var(--color-text-secondary);display:inline-block;padding:.2rem .5rem;border-radius:var(--border-radius-sm);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;box-shadow:var(--shadow-medium)}.deck-info .deck-name .deck-icon{margin-right:.35rem}.flashcard-display-section>.deck-info,.flashcard-display-section>.deck-info--flashcard{position:static;inset:auto;transform:none;text-align:center;width:100%}.panel--flashcard__content{position:relative;width:100%;height:100%;display:flex;flex-direction:column;padding:var(--spacing-md)}.panel--flashcard__content:after{content:"";display:block;width:75%;height:3px;background:var(--border-medium);border-radius:2px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:2}.panel--flashcard__question{position:absolute;top:2rem;left:1rem;right:1rem;bottom:50%;display:flex;align-items:center;justify-content:center;z-index:1}.panel--flashcard__answer{position:absolute;top:50%;left:1rem;right:1rem;bottom:2rem;display:flex;align-items:center;justify-content:center;z-index:1}.swipe-indicator{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--black-80);color:#fff;padding:var(--spacing-md) 1.5rem;border-radius:var(--radius-medium);font-size:var(--font-xl);font-weight:600;pointer-events:none;z-index:10;transition:opacity .2s ease}.swipe-indicator-easy{background:var(--color-info);color:#fff}.swipe-indicator-hard{background:var(--color-warning);color:var(--gray-900)}.swipe-indicator-good{background:var(--color-success);color:#fff}.swipe-indicator-again{background:var(--color-error);color:#fff}.flashcard-controls-panel .action-group--flashcard{display:grid;grid-template-columns:repeat(3,1fr);justify-content:space-around;padding:var(--spacing-sm) 0;gap:.5rem;min-height:4rem}.flashcard-controls-panel .action-group--flashcard .btn--primary.control-btn{min-width:3.75rem;max-width:none;flex:1;display:flex;flex-direction:column;justify-content:center;align-items:center}.flashcard-instructions,.flashcard-suspend-instructions{text-align:center;color:var(--gray-600);font-size:var(--font-sm);margin:var(--spacing-sm) 0;font-style:italic}.flashcard-instructions p,.flashcard-suspend-instructions p{margin:.25rem 0}.flashcard-instructions p.scroll-protection-hint,.flashcard-suspend-instructions p.scroll-protection-hint{display:block;background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:var(--radius-small);padding:var(--spacing-xs);margin-top:var(--spacing-sm);color:var(--gray-700);font-style:normal}.flashcard-instructions p.scroll-protection-hint small,.flashcard-suspend-instructions p.scroll-protection-hint small{font-size:.8em}.flashcard-instructions--rating{margin:0}.flashcard-instructions--rating p:last-child{display:none}.flashcard-suspend-section{display:flex;flex-direction:column;align-items:center;gap:0}.flashcard-suspend-section .flashcard-buttons-row{display:flex;flex-direction:row;gap:.75rem;align-items:center}.flashcard-suspend-section .btn--suspend{background:var(--gray-900);color:#fff;font-weight:700;border:1px solid var(--border-dark);padding:.5rem .75rem}@media (hover: hover) and (pointer: fine){.flashcard-suspend-section .btn--save-word:hover{background:var(--color-action-hover)}}.flashcard-suspend-section .btn--save-word.is-saved,.flashcard-suspend-section .btn--save-word:disabled{background:var(--bg-muted, var(--gray-700));color:var(--text-disabled, var(--gray-300));cursor:not-allowed;border-color:var(--border-dark)}.auto-mode-indicator{text-align:center;color:var(--gray-600);font-size:var(--font-sm);font-weight:500;margin:var(--spacing-sm) 0}.auto-mode-indicator span{display:none;color:var(--gray-600);font-size:var(--font-sm)}.flashcard-error{display:flex;align-items:center;justify-content:center;min-height:300px;background:var(--danger-light, var(--error-light-bg));border:2px solid var(--danger, var(--color-error));border-radius:var(--radius-medium);padding:var(--spacing-xl);margin:var(--spacing-md) 0}.flashcard-error-content{text-align:center;max-width:500px;width:100%;color:var(--danger, var(--color-error))}.flashcard-error-content p{margin:0;font-size:var(--font-xl);font-weight:500}.flashcard-additional-content{position:absolute;bottom:-16px}.card-state-dot{width:12px;height:12px;border-radius:50%}.card-state-dot.card-state-new{background:var(--color-success)}.card-state-dot.card-state-learning{background:orange}.card-state-dot.card-state-relearning{background:red}.card-state-dot.card-state-review{background:var(--color-action)}.card-state-icon{font-size:.8em}.card-state-info{color:var(--gray-600);font-size:var(--font-xs);font-weight:400}.modes-container{display:flex;flex-direction:column;align-items:center;position:relative;padding:var(--spacing-md);gap:var(--spacing-md);width:100%}.modes-container-title{margin:0;padding:0;font-size:var(--font-xl);font-weight:600;text-align:center;color:var(--text-primary)}.modes-container-btn{display:flex;flex-direction:column}.modes-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:.2rem;width:100%;justify-content:center;text-align:center;align-items:stretch}.modes-grid .mode-icon{display:inline-flex;align-items:center;justify-content:center;margin:6px 0}.modes-grid .mode-icon img{width:24px;height:24px;object-fit:contain}.panel--exercise,.panel--quiz,.panel--flashcard{position:relative;display:flex;flex-direction:column;min-width:280px;max-width:370px;height:320px;background:var(--bg-primary);border:1px solid var(--border-dark);border-radius:var(--radius-large);box-shadow:var(--shadow-medium);transition:var(--transition-normal);overflow:hidden}.panel--exercise:hover,.panel--quiz:hover,.panel--flashcard:hover{transform:translateY(-2px);box-shadow:var(--shadow-large)}.panel--exercise--swipeable{cursor:pointer;user-select:none;-webkit-user-select:none;touch-action:pan-y}.panel--exercise--interactive{cursor:pointer}.panel--exercise--interactive:active{transform:translateY(0)}.panel--exercise--lightning{animation:lightning-pulse 1s ease-in-out infinite alternate}.panel--exercise--timer{animation:timer-breathing 2s ease-in-out infinite}@keyframes lightning-pulse{0%{box-shadow:0 0 10px var(--color-warning)}to{box-shadow:0 0 20px var(--color-warning),0 0 30px var(--color-warning-light)}}@keyframes timer-breathing{0%,to{transform:scale(1);box-shadow:var(--shadow-medium)}50%{transform:scale(1.02);box-shadow:var(--shadow-large)}}.panel--flashcard{overflow-y:auto!important;overflow-x:hidden;touch-action:pan-y!important}.panel--flashcard.panel--swipeable{overflow-y:hidden!important;touch-action:none!important}.panel--quiz__content{display:flex;flex-direction:column;height:100%;padding:var(--spacing-md)}.panel--quiz__question{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding-bottom:var(--spacing-md);border-bottom:1px solid var(--border-light);margin-bottom:var(--spacing-md)}.panel--quiz__answer{flex:1;display:flex;flex-direction:column;gap:var(--spacing-sm);align-items:stretch;justify-content:center}.panel--quiz__answer--2-options .quiz-option{min-height:3rem}.panel--quiz__answer--3-options .quiz-option{min-height:2.5rem}.panel--quiz__answer--4-options .quiz-option{min-height:2rem;font-size:var(--font-sm)}.quiz-option{padding:var(--spacing-sm);border:1px solid var(--border-medium);border-radius:var(--radius-medium);background:var(--bg-secondary);cursor:pointer;transition:var(--transition-fast);text-align:center;font-weight:500}.quiz-option:hover{background:var(--bg-hover);border-color:var(--border-strong)}.quiz-option:active{transform:translateY(1px)}.quiz-option--selected{background:var(--color-primary);color:var(--text-white);border-color:var(--color-primary)}.quiz-option--correct{background:var(--color-success);color:var(--text-white);border-color:var(--color-success)}.quiz-option--incorrect{background:var(--color-error);color:var(--text-white);border-color:var(--color-error)}.quiz-option--disabled{opacity:.6;cursor:not-allowed;pointer-events:none}@keyframes modalAppear{0%{opacity:0;transform:scale(.9) translateY(-20px)}to{opacity:1;transform:scale(1) translateY(0)}}.preferences-modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:var(--black-30);backdrop-filter:blur(1px);-webkit-backdrop-filter:blur(1px);z-index:9999;display:flex;align-items:center;justify-content:center;padding:1rem}.preferences-modal__popup{background:var(--bg-primary);border:1px solid var(--border-dark);border-radius:12px;box-shadow:0 10px 40px var(--black-30);animation:modalAppear .3s ease-out;max-width:min(600px,95vw);width:95%;min-height:300px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;margin:auto;position:relative;z-index:1}.preferences-modal__popup .modal-popup__header{display:flex;flex-direction:row;justify-content:space-between;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);background:linear-gradient(135deg,var(--color-action) 0%,var(--color-action-hover) 100%);color:var(--text-white);flex-shrink:0}.preferences-modal__popup .modal-popup__header h2{margin:0;font-size:var(--font-3xl);display:flex;align-items:center;gap:.5rem}.preferences-modal__popup .btn-modal-close{background:#fff3;border:1px solid rgba(255,255,255,.5);color:#fff;font-size:var(--font-2xl);cursor:pointer;padding:.5rem;border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.preferences-modal__popup .btn-modal-close:hover{background:#ffffff4d;border-color:#ffffffb3}.preferences-modal__popup .modal-popup__content{display:flex;flex-direction:column;background:var(--bg-primary);padding:0;gap:0;align-items:stretch;text-align:left;overflow-y:auto;overflow-x:hidden;flex:1;min-height:0;scrollbar-width:thin;scrollbar-color:var(--color-primary) var(--gray-100)}.preferences-modal__popup .modal-popup__content::-webkit-scrollbar{width:max(8px,1vw)}.preferences-modal__popup .modal-popup__content::-webkit-scrollbar-track{background:var(--gray-100);border-radius:5px;margin:5px}.preferences-modal__popup .modal-popup__content::-webkit-scrollbar-thumb{background:var(--color-primary);border:2px solid var(--gray-50);border-radius:5px}.preferences-modal__popup .modal-popup__content::-webkit-scrollbar-thumb:hover{background:var(--color-primary-hover)}.preferences-modal-content{display:flex;flex-direction:column;gap:clamp(1rem,3vw,1.5rem);padding:clamp(1rem,4vw,1.5rem);min-height:min-content;height:100%;overflow-y:auto;overflow-x:hidden}.preferences-save-btn{min-width:max(220px,60vw);min-height:48px;border-radius:12px;font-weight:600;font-size:clamp(.875rem,4vw,1rem);transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;margin-top:auto;color:var(--text-primary);width:100%;margin-bottom:.5rem}.preferences-save-btn.has-changes{background:var(--color-action);border:none;box-shadow:0 4px 20px rgba(var(--color-success-rgb),.3),0 2px 8px rgba(var(--color-success-rgb),.2);color:var(--text-white)}.preferences-save-btn:disabled{opacity:.7;cursor:not-allowed;transform:none!important;box-shadow:none!important}.preference-group{display:flex;flex-direction:column;padding:var(--spacing-xs);justify-content:flex-start;height:100%}.preference-controls{display:flex;flex-direction:column;gap:0}.preference-item{display:flex;flex-direction:row;align-items:center;justify-content:space-between;padding:clamp(.5rem,2vw,.75rem);gap:0;min-height:max(2.5rem,44px);overflow:hidden;white-space:nowrap}.preference-item.checkbox-item{cursor:pointer;border-radius:var(--radius-medium);transition:background-color .2s ease}.preference-item.recently-changed{background:linear-gradient(135deg,var(--color-warning-light) 0%,var(--color-warning-lighter) 100%);border-radius:var(--radius-medium);position:relative;border-left:2px solid var(--color-warning)}.preference-label{display:flex;align-items:center;gap:var(--spacing-sm);font-weight:500;color:var(--text-primary);flex:1;min-width:0;overflow:hidden}.preference-label span{font-size:var(--font-base);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.preference-control{flex-shrink:1;min-width:0;max-width:100%}.preference-select{width:7rem;max-width:100%;padding:.25rem;border:1px solid var(--border-dark);border-radius:var(--radius-medium);background:var(--bg-primary);color:var(--text-primary);font-size:clamp(.875rem,4vw,1rem);cursor:pointer;transition:border-color .2s ease,box-shadow .2s ease;text-overflow:ellipsis;position:relative;z-index:10}.preference-select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary-alpha);z-index:20}.preferences-dropdown-menu{background:var(--bg-primary);border:1px solid var(--border-dark);border-radius:var(--radius-medium);box-shadow:0 4px 10px #0000001f;overflow:auto}.preferences-dropdown-option{padding:.4rem .6rem;color:var(--text-primary);cursor:pointer}.preferences-dropdown-option.is-active{background:var(--bg-secondary)}.preferences-dropdown-option.is-selected{background:var(--color-action);color:var(--text-dark)}.preference-checkbox{width:max(1.25rem,20px);height:max(1.25rem,20px);min-width:20px;min-height:20px;cursor:pointer;accent-color:var(--color-primary)}.preference-item--topics{display:flex;flex-direction:column}.preference-item--topics .preference-label{margin-bottom:var(--spacing-sm);align-self:flex-start}.preference-item--topics .preference-label span{font-size:var(--font-base);font-weight:600;color:var(--text-primary)}.preference-item--topics .preference-control--topics{width:100%}.preference-item--topics .topic-checkboxes{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-xs);padding:var(--spacing-sm);background:var(--bg-secondary);border-radius:var(--radius-medium);border:1px solid var(--border-light)}.preference-item--topics .topic-checkboxes .topic-checkbox{display:flex;align-items:center;justify-content:flex-start;gap:var(--spacing-xs);padding:var(--spacing-xs);border-radius:var(--radius-small);cursor:pointer;transition:all .15s ease;background:var(--bg-primary);border:1px solid var(--border-light);min-height:32px}.preference-item--topics .topic-checkboxes .topic-checkbox--all{font-weight:600;justify-content:flex-start}.preference-item--topics .topic-checkboxes .topic-checkbox input[type=checkbox]{margin:0;width:16px;height:16px;accent-color:var(--color-primary)}.preference-item--topics .topic-checkboxes .topic-checkbox .topic-label{font-size:var(--font-sm);color:var(--text-primary);-webkit-user-select:none;user-select:none;font-weight:500;white-space:nowrap}.preference-item--topics .topic-checkboxes .topic-checkbox .topic-label--all{font-weight:700;font-size:var(--font-base)}.btn.preferences-btn{min-height:32px;padding:.5rem 0;font-size:.8rem;width:100%;background-color:var(--bg-primary)}html body .toast-notification,.toast-notification{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:99999;background:var(--bg-black);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);color:var(--text-white);padding:18px 24px;border-radius:12px;border:1px solid rgba(255,255,255,.2);box-shadow:0 8px 32px #0003,0 4px 16px #22c55e4d,inset 0 1px #fff3;text-align:center;font-weight:500;font-size:16px;animation:toastFadeInCenter .3s ease-out;min-width:250px;max-width:80vw;opacity:1;visibility:visible;display:block;overflow:hidden}html body .toast-notification:before,.toast-notification:before{content:"";position:absolute;top:0;left:0;height:3px;background:var(--color-success);width:100%;animation:countdownProgress 2s linear forwards;border-radius:12px 12px 0 0}html body .toast-notification.toast-error,.toast-notification.toast-error{box-shadow:0 8px 32px #0003,0 4px 16px #dc26264d,inset 0 1px #fff3}html body .toast-notification.toast-error:before,.toast-notification.toast-error:before{background:#dc2626}.tooltip-trigger{background-color:var(--bg-black);color:var(--text-white);border:2px solid var(--text-white);border-radius:50%;min-width:20px;min-height:20px;font-size:11px;font-weight:600;cursor:pointer;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;transition:none;box-shadow:0 2px 8px rgba(var(--color-primary-rgb),.3)}.tooltip-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1001;animation:fadeIn .2s ease-out}.tooltip-overlay .tooltip-content{background:var(--bg-primary);border:1px solid rgba(255,255,255,.2);border-radius:16px;padding:var(--spacing-lg);max-width:calc(100vw - 2rem);margin:var(--spacing-lg);position:relative;box-shadow:0 20px 60px #0003,0 8px 24px #00000026,inset 0 1px #ffffff1a;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.tooltip-overlay .tooltip-content .tooltip-text{color:var(--text-primary);line-height:1.5;margin-bottom:var(--spacing-md);padding-right:2.5rem}.tooltip-overlay .tooltip-content .tooltip-close{position:absolute;top:var(--spacing-sm);right:var(--spacing-sm);background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--text-secondary);width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease}.tooltip-overlay .tooltip-content .tooltip-close:hover{color:var(--text-primary);background:#ffffff1a}@keyframes slideInFromTop{0%{transform:translateY(-20px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes toastFadeInCenter{0%{opacity:0;transform:translate(-50%,-50%) scale(.9)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}@keyframes countdownProgress{0%{width:100%}to{width:0%}}button,.btn{min-height:44px;min-width:44px;touch-action:manipulation;-webkit-tap-highlight-color:var(--black-10);-webkit-user-select:none;user-select:none;font-weight:500}.btn{padding:var(--spacing-sm) 1rem;border:none;border-radius:var(--radius-medium);cursor:pointer;font-size:.85rem;transition:all .3s ease;font-family:inherit;text-align:center;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-xs);white-space:nowrap}@media (hover: hover) and (pointer: fine){.btn:hover{transform:scale(1.02)}}.btn:focus{outline:none;outline-offset:0;box-shadow:none}.btn:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.btn:active{transform:scale(.98);transition:none}.btn:disabled{background:var(--gray-200);border-color:var(--gray-300);cursor:not-allowed;opacity:var(--disabled-opacity);transform:none;box-shadow:none;color:var(--text-muted)}@media (hover: hover) and (pointer: fine){.btn:disabled:hover{transform:none;box-shadow:none}}.btn.btn--large{font-size:1rem}.btn.btn--small{padding:var(--spacing-xs) var(--spacing-sm);font-size:.875rem;min-height:36px}.btn.btn--icon-only{padding:0;min-width:44px;aspect-ratio:1;font-size:1.2rem}.btn.btn--outline{background:transparent;border:2px solid currentColor}.btn.auto-mode-toggle-btn{opacity:0;transition:opacity .75s ease;border:none;font-size:var(--font-5xl)}.btn.auto-mode-toggle-btn.paused{opacity:.8}@media (hover: hover) and (pointer: fine){.btn.auto-mode-toggle-btn.paused:hover{opacity:.8}}.btn.auto-mode-toggle-btn:disabled{opacity:0;pointer-events:none}@media (hover: hover) and (pointer: fine){.btn.auto-mode-toggle-btn:disabled:hover{opacity:0}}@media (hover: hover) and (pointer: fine){.btn.auto-mode-toggle-btn:hover{opacity:.6}}.btn.btn-close-modal,.btn.btn--close-modal{background:#fff3;border:1px solid rgba(255,255,255,.5);color:#fff;border-radius:50%}button:focus{outline:none;outline-offset:0;box-shadow:none}button:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}button:focus:not(:focus-visible){outline:none}button:active{transform:scale(.98);transition:none}button:disabled{background:var(--gray-200);border-color:var(--gray-300);color:var(--text-muted);cursor:not-allowed;opacity:var(--disabled-opacity);transform:none;box-shadow:none}@media (hover: hover) and (pointer: fine){button:disabled:hover{transform:none;box-shadow:none}}a:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.btn--primary{background:var(--color-action);color:var(--text-white);border:2px solid var(--border-dark);box-shadow:var(--shadow-button)}.btn--primary.active{background:var(--color-success-active);border:2px solid var(--color-action)}@media (hover: hover) and (pointer: fine){.btn--primary:hover{background:var(--color-action-hover)}}.btn--secondary{background:transparent;color:var(--text-primary);border:2px solid var(--border-dark)}.btn--secondary.active{background:var(--color-action-active);color:var(--text-white)}@media (hover: hover) and (pointer: fine){.btn--secondary:hover{background:var(--color-primary);color:var(--text-white)}}.btn--success{background:var(--color-success);color:#fff}.btn--success:active{background:var(--color-success)}@media (hover: hover) and (pointer: fine){.btn--success:hover{background:var(--color-success-hover)}}.btn--danger{background:var(--color-error);color:#fff}.btn--danger:active{background:var(--color-error);filter:brightness(.8)}@media (hover: hover) and (pointer: fine){.btn--danger:hover{background:var(--color-error);filter:brightness(.9)}}.btn--warning{background:#ff9500;color:#fff}.btn--warning:active{background:#ff9500;filter:brightness(.8)}@media (hover: hover) and (pointer: fine){.btn--warning:hover{background:#ff9500;filter:brightness(.9)}}.btn--toggle{background:var(--bg-secondary);border:2px solid var(--border-medium);border-color:var(--border-dark);color:var(--text-secondary);font-weight:500;transition:all .3s ease;position:relative}.btn--toggle:active{transform:translateY(1px)}@media (hover: hover) and (pointer: fine){.btn--toggle:hover{background:var(--bg-hover);border-color:var(--border-strong);color:var(--text-primary);transform:translateY(-1px);box-shadow:0 2px 8px var(--black-10)}}.btn--toggle.btn--toggle-active:active{transform:translateY(1px)}@media (hover: hover) and (pointer: fine){.btn--toggle.btn--toggle-active:hover{background:var(--color-primary-hover);border-color:var(--color-primary-hover);transform:translateY(-1px);box-shadow:0 2px 8px var(--color-primary-alpha)}}.btn-save-toggle.save:before{content:"✚"}.btn-save-toggle.remove:before{content:"❌"}.btn-save-bulk-toggle.save:before{content:"💾"}.btn-save-bulk-toggle.remove:before{content:"🗑️"}.action-group{display:flex;align-items:center;gap:var(--spacing-sm);justify-content:center}.action-group--horizontal{flex-direction:row}.action-group--vertical{flex-direction:column}.action-group--vertical.action-group--divided .action-divider{width:auto;height:1px;margin:var(--spacing-xs) 0}.action-group--inline{gap:var(--spacing-xs)}.action-group--spaced{gap:var(--spacing-lg)}.action-group--start{justify-content:flex-start}.action-group--between{justify-content:space-between}.action-group--between button{align-self:flex-end;min-width:fit-content;width:7rem;font-size:.9rem;cursor:pointer;transition:all .2s ease;font-weight:550;min-height:2.2rem}@media (hover: hover) and (pointer: fine){.action-group--between button:hover{transform:translateY(-1px);box-shadow:0 2px 6px var(--black-15)}}.action-group--around{justify-content:space-around}.action-group--wrap{flex-wrap:wrap}.action-group--responsive{flex-direction:column;align-items:stretch}.action-group--responsive .btn{width:100%;justify-content:center}.action-group--card{margin-top:auto;padding-top:var(--spacing-sm)}.action-group--modal{margin-top:var(--spacing-lg);padding-top:var(--spacing-md);border-top:1px solid var(--border-light)}.action-group--form{margin-top:var(--spacing-lg);justify-content:flex-end}.action-group--game{padding:var(--spacing-md)}.action-group--empty-state{margin-top:var(--spacing-lg);flex-direction:column}.action-group--sidebar{flex-direction:column;align-items:stretch;gap:var(--spacing-xs)}.action-group--divided .action-divider{width:2px;height:40px;background:var(--border-medium);border-radius:1px;margin:0 var(--spacing-xs)}.action-group[role=group]{position:relative}.action-group--disabled{opacity:.6;pointer-events:none}.badge{display:inline-flex;align-items:center;justify-content:center;padding:.15rem .4rem;font-size:var(--font-xs);font-weight:500;border-radius:var(--radius-small);line-height:1;white-space:nowrap;transition:all .2s ease;border:1px solid var(--border-dark)}.badge--language{background-color:var(--color-action);color:var(--text-white)}.badge--language:hover{background-color:var(--color-action-hover)}.badge--level{background-color:var(--purple-primary);color:var(--text-white);font-weight:700;border:1px solid var(--border-dark);background-color:var(--color-action)}.badge--level:hover{background-color:#7c3aed}.badge--type{background-color:var(--color-success);color:var(--text-white)}.badge--type:hover{background-color:var(--color-success-hover)}.badge--category{color:var(--text-white)}.badge--category[data-category=travel]{background-color:#3498db}.badge--category[data-category=travel]:hover{background-color:#2980b9}.badge--category[data-category=food]{background-color:#e53935}.badge--category[data-category=food]:hover{background-color:#b71c1c}.badge--category[data-category=sport]{background-color:#e67e22}.badge--category[data-category=sport]:hover{background-color:#d35400}.badge--category[data-category=history]{background-color:#1f1e1d}.badge--category[data-category=history]:hover{background-color:#0e0d0d}.badge--category[data-category=science]{background-color:#9b59b6}.badge--category[data-category=science]:hover{background-color:#8e44ad}.badge--category[data-category=korea]{background:linear-gradient(90deg,#1976d2,#e74c3c)}.badge--category[data-category=korea]:hover{background:linear-gradient(90deg,#1565c0,#c0392b)}.badge--category[data-category=germany]{background:linear-gradient(90deg,#000 0% 33%,#d00 33% 66%,#ffce00 66% 100%)}.badge--category[data-category=germany]:hover{background:linear-gradient(90deg,#222 0% 33%,#a30000 33% 66%,#e6b800 66% 100%)}.badge--category[data-category=story]{background-color:#9c2f78}.badge--category[data-category=story]:hover{background-color:#801d5f}.badge--category[data-category="daily life"]{background-color:#16a039}.badge--category[data-category="daily life"]:hover{background-color:#1a700f}.badge--category[data-category=unknown],.badge--category:not([data-category]){background-color:var(--gray-500)}.badge--category[data-category=unknown]:hover,.badge--category:not([data-category]):hover{background-color:var(--gray-600)}.badge--gender{border-radius:var(--radius-circle);padding:0;color:var(--text-primary);font-size:var(--font-xl);font-weight:700;box-shadow:0 2px 4px var(--black-10);border:2px solid var(--border-dark);border-radius:50%;width:2rem;height:2rem;min-width:2rem;min-height:2rem}.badge--gender[data-gender=M],.badge--gender[data-gender=m],.badge--gender[data-gender=masculine]{background-color:var(--masculine-blue);color:var(--text-white)}.badge--gender[data-gender=F],.badge--gender[data-gender=f],.badge--gender[data-gender=feminine]{background-color:var(--feminine-red);color:var(--text-white)}.badge--gender[data-gender=N],.badge--gender[data-gender=n],.badge--gender[data-gender=neuter]{background-color:var(--neuter-green);color:var(--text-white)}.badge--small{padding:.2rem .6rem;font-size:var(--font-sm);border-radius:var(--radius-medium)}.badge--normal{padding:var(--spacing-sm);font-size:var(--font-lg);border-radius:var(--radius-medium)}.badge--pill{border-radius:var(--radius-pill)}.badge--rounded{border-radius:var(--radius-medium)}.badge--success{background-color:var(--color-success);color:var(--text-white)}.badge--warning{background-color:var(--color-warning);color:var(--text-white)}.badge--error{background-color:var(--color-error);color:var(--text-white)}.badge--info{background-color:var(--lightning-blue);color:var(--text-white)}.badge--interactive{cursor:pointer;transition:all .2s ease}.badge--interactive:hover{transform:translateY(-1px);box-shadow:var(--shadow-light)}.badge--interactive:active{transform:translateY(0)}.badge:focus-visible{outline:2px solid var(--focus-ring);outline-offset:2px}.badge-group{display:flex;gap:var(--spacing-sm);align-items:center;flex-wrap:wrap}.badge-group--column{flex-direction:column;gap:.2rem}.badge-group--center{justify-content:center}.badge-group--end{justify-content:flex-end}.form-field{font-family:inherit;padding:.5rem .75rem;border:1px solid var(--border-dark);border-radius:var(--radius-small);background:var(--bg-primary);line-height:1.5;transition:var(--transition-normal);min-height:44px;font-size:16px;-webkit-appearance:none;appearance:none;touch-action:manipulation}.form-field:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 2px var(--focus-ring)}.form-field:disabled{background:var(--gray-100);color:var(--gray-500);cursor:not-allowed;opacity:.6}.form-field--search{padding-left:2.5rem;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='%236B7280' viewBox='0 0 16 16'%3E%3Cpath d='M11.742 10.344a6.5 6.5 0 1 0-1.397 1.398h-.001c.03.04.062.078.098.115l3.85 3.85a1 1 0 0 0 1.415-1.414l-3.85-3.85a1.007 1.007 0 0 0-.115-.1zM12 6.5a5.5 5.5 0 1 1-11 0 5.5 5.5 0 0 1 11 0z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:.75rem center;background-size:16px}.form-field--select{cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%236B7280' viewBox='0 0 16 16'%3E%3Cpath d='M7.247 11.14 2.451 5.658C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:calc(100% - .75rem) center;background-size:12px;padding-right:1.5rem}.form-field--textarea{min-height:80px;resize:vertical;line-height:1.6}.form-field--small{padding:.375rem .5rem;font-size:.8125rem;min-height:36px}.form-field--large{padding:.75rem 1rem;font-size:1rem;min-height:52px}.form-field--narrow{min-width:90px;max-width:120px}.form-field--medium,.form-field--wide,.form-field--full{width:100%}.form-field--error{border-color:var(--color-error)}.form-field--error:focus{border-color:var(--color-error);box-shadow:0 0 0 2px var(--color-error-light)}.form-field--success{border-color:var(--color-success)}.form-field--success:focus{border-color:var(--color-success);box-shadow:0 0 0 2px var(--color-success-light)}.form-field--deck{padding:.75rem 1.5rem;border:2px solid var(--color-action-active);background:var(--bg-primary);color:var(--text-dark-blue);border-radius:var(--radius-medium);font-weight:500;font-size:.95rem;cursor:pointer;min-width:100%;transition:all .2s ease;text-align:center;text-align-last:center;background:green}.form-field--deck:focus{outline:none;border-color:red;box-shadow:0 0 0 3px var(--focus-ring)}.form-field--deck option{text-align:center;padding:.5rem;background:green;color:var(--text-dark-blue)}.form-group{display:flex;flex-direction:column;gap:.5rem;position:relative}.form-group--horizontal{flex-direction:column;align-items:stretch;gap:.75rem}.form-group--inline{flex-direction:row;align-items:end;gap:.5rem}.form-group--compact{gap:.25rem}.form-group--spacious{gap:1rem}.form-label{font-size:.875rem;font-weight:500;color:var(--gray-700);line-height:1.4}.form-label--small{font-size:.8125rem}.form-label--required:after{content:" *";color:var(--color-error)}.form-label--sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.form-filters{display:flex;flex-direction:column;align-items:stretch;flex-wrap:wrap;gap:1rem;padding:1rem;border:1px solid var(--border-light);border-radius:var(--radius-medium);background:var(--bg-panel)}.form-search-bar{display:flex;flex-direction:column;justify-content:space-between;align-items:stretch;gap:1rem;flex-wrap:wrap}.form-button-group{display:flex;flex-wrap:wrap;gap:.25rem}.form-help{font-size:.8125rem;color:var(--gray-600);line-height:1.4}.form-error{font-size:.8125rem;color:var(--color-error);line-height:1.4}.form-deck-selector{position:relative}.form-deck-selector .form-group{display:flex;flex-direction:column;align-items:center;gap:0;width:100%;position:relative}.form-deck-selector .custom-select{position:relative;width:100%;max-width:320px}.form-deck-selector .form-label{font-weight:600;color:var(--text-dark-blue);font-size:1rem;text-align:center}.card-count-controls{display:flex;flex-direction:row;gap:1rem;margin-top:1rem}.card-count-group{display:flex;flex-direction:row;align-items:stretch;gap:1rem}.card-count-group .form-group{flex:1;min-width:0}.card-count-group .form-group .form-label{font-size:.875rem;font-weight:500;color:var(--text-dark-blue);margin-bottom:.25rem;justify-self:flex-start}.card-count-group .form-group .form-field--number{max-width:80px;text-align:center;font-weight:500;justify-self:flex-end}.card-count-actions{display:flex;justify-content:center}.card-count-actions .fetch-cards-btn{align-self:flex-end;font-weight:600;min-width:100px;height:2.5rem}.card-count-actions .fetch-cards-btn:disabled{opacity:.6;cursor:not-allowed}.form-group--with-tooltip{position:relative}.input-with-tooltip{position:relative;width:100%}.input-tooltip{position:absolute;bottom:100%;left:0;right:0;margin-bottom:.5rem;padding:.5rem .75rem;background:var(--gray-900);color:#fff;font-size:.8125rem;line-height:1.4;border-radius:var(--radius-small);white-space:normal;text-align:center;z-index:1000;box-shadow:0 4px 12px #00000026;max-width:180px;margin-left:auto;margin-right:auto;animation:tooltip-fade-in .2s ease-out}.input-tooltip .tooltip-arrow{position:absolute;top:100%;left:50%;transform:translate(-50%);width:0;height:0;border-left:6px solid transparent;border-right:6px solid transparent;border-top:6px solid var(--gray-900)}.input-tooltip--error{background:var(--black-90)}.input-tooltip--error .tooltip-arrow{border-top-color:var(--black-90)}.input-tooltip--warning{background:var(--black-90);color:var(--gray-900)}.input-tooltip--warning .tooltip-arrow{border-top-color:var(--black-90)}.modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;display:flex;align-items:flex-start;justify-content:center;background:var(--black-30);backdrop-filter:blur(1px);-webkit-backdrop-filter:blur(1px);z-index:9999}.modal-popup{background:var(--bg-primary);margin:.25rem 0;width:90%;max-width:650px;max-height:85vh;border:1px solid var(--border-dark);border-radius:12px;box-shadow:0 10px 40px var(--black-30);overflow:hidden;animation:modalAppear .3s ease-out;display:flex;flex-direction:column}.modal-popup__header{display:flex;flex-direction:row;justify-content:space-between;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);background:linear-gradient(135deg,var(--color-action) 0%,var(--color-action-hover) 100%);color:var(--text-white);margin-bottom:1rem}.modal-popup__content{display:flex;flex-direction:column;align-items:center;text-align:center;gap:var(--spacing-md);background:var(--bg-primary);flex:1;min-height:0;padding:1rem;overflow-y:auto}.modal-popup__content h3{font-size:var(--font-3xl);font-weight:700;font-style:italic;padding:.5rem 0;border-bottom:1px solid var(--border-strong)}.btn-modal-close,.btn--modal-close{background:#fff3;border:1px solid rgba(255,255,255,.5);color:#fff;font-size:var(--font-4xl);cursor:pointer;padding:.5rem;border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.btn-modal-close:hover,.btn--modal-close:hover{background:#ffffff4d;border-color:#ffffffb3}.btn-modal-close--dark{--color-action-alpha: rgba(85, 117, 151, .4);background:var(--color-action-alpha);border:1px solid rgba(0,0,0,.5);color:#080808}.multiple-choice-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:transparent;z-index:1000}.multiple-choice-popup{background:var(--bg-primary);border-radius:12px;box-shadow:0 8px 32px var(--black-20);border:2px solid var(--border-dark);min-width:200px;max-width:300px;z-index:1001;width:var(--popup-width, auto);max-width:var(--popup-max-width, 300px);position:var(--popup-position, fixed);left:var(--popup-left, auto);top:var(--popup-top, auto);right:var(--popup-right, auto);bottom:var(--popup-bottom, auto);transform:var(--popup-transform, none);margin:var(--popup-margin, 0)}.multiple-choice-popup.mobile{position:fixed;top:30%;left:8px;right:8px;width:auto;max-width:500px;min-height:180px;transform:none;margin:0 auto 4rem;overflow:visible}.story-finished-overlay{position:absolute;top:25%;left:50%;transform:translate(-50%,-50%);z-index:10}.toast-notification{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--bg-black);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);color:var(--text-white);padding:18px 24px;border-radius:12px;border:1px solid rgba(255,255,255,.2);box-shadow:0 8px 32px #0003,0 4px 16px #0000001a,inset 0 1px #fff3;font-size:16px;font-weight:500;z-index:99999;opacity:1;transition:all .4s cubic-bezier(.25,.8,.25,1);pointer-events:none;min-width:250px;max-width:80vw;text-align:center;white-space:pre-line;overflow:hidden;position:relative}.toast-notification:before{content:"";position:absolute;top:0;left:0;height:3px;background:#22c55e;width:100%;animation:countdownProgressShort .75s linear forwards;border-radius:12px 12px 0 0}.toast-notification.saved:before,.toast-notification.removed:before,.toast-notification.info:before{animation:countdownProgressShort .75s linear forwards}.toast-notification.removed:before{background:#dc2626}.toast-notification.info:before{background:#ffffffb3}.toast-notification.show{transform:translate(-50%,-50%) scale(1)}.toast-notification.info{background:var(--gray-900);color:var(--text-white)}.toast-notification.fade-out{opacity:0;transform:translate(-50%,-50%) scale(.9);transition:all .3s ease-out}.page--flashcards .toast-notification.show{opacity:1}.page .toast-notification:not(.saved):not(.removed):not(.info):before{animation:countdownProgressMedium 2s linear forwards}@keyframes countdownProgressShort{0%{width:100%}to{width:0%}}@keyframes countdownProgressMedium{0%{width:100%}to{width:0%}}.content-filters{display:flex;justify-content:space-between;align-items:flex-end;gap:var(--spacing-md);flex-wrap:wrap}.content-filters .filter-btn{min-width:41px;min-height:41px;justify-content:center}.content-filters .clear-filters-btn{margin-left:auto;max-height:3rem}.filter-group{display:flex;flex-direction:column;gap:var(--spacing-xs);align-items:center}.filter-group .btn--toggle{white-space:nowrap;font-size:var(--font-sm);padding:.5rem .75rem}.content-search-sort{display:flex;justify-content:space-between;align-items:flex-end;margin:-1rem 0;padding:.5rem 0;gap:1rem}.content-search-sort .custom-select-container{z-index:1}.content-search-sort .custom-select-container .custom-select-dropdown{z-index:1100}.content-filters .custom-select-container{z-index:2}.content-filters .custom-select-container .custom-select-dropdown{z-index:1200}.custom-select-container{position:relative;z-index:1}.custom-select{position:relative;min-width:100px}.custom-select-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;padding:.5rem .75rem;background:var(--bg-primary);border:1px solid var(--border-dark);border-radius:4px;cursor:pointer;font-size:.9rem;text-align:left;transition:all .2s ease}.custom-select-toggle:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px #3b82f61a}.custom-select-value{flex:1;text-align:left}.custom-select-arrow{margin-left:.5rem;font-size:.8rem;color:var(--text-medium);transition:transform .2s ease}.custom-select-dropdown{position:absolute;top:100%;right:0;min-width:max(100%,220px);width:max-content;background:var(--bg-primary);border:1px solid var(--border-dark);border-top:none;border-radius:0 0 8px 8px;box-shadow:0 4px 6px #0000001a;z-index:1200;max-height:300px;overflow-y:auto}.custom-select-dropdown--multiple{min-width:max(100%,250px)}.custom-select-option{display:block;width:100%;padding:.6rem 1rem;background:var(--bg-primary);border:none;text-align:left;cursor:pointer;font-size:.9rem;transition:background-color .2s ease;white-space:nowrap}.custom-select-option:focus{background:var(--bg-primary)}.custom-select-option.selected{background:var(--color-action);color:var(--text-dark);border:1px solid var(--border-dark)}.custom-select-option--checkbox{display:flex;align-items:center;gap:.5rem;cursor:pointer;padding:.6rem 1rem}.custom-select-option--checkbox .custom-select-checkbox{margin:0;cursor:pointer}.custom-select-option--checkbox .custom-select-option-label{flex:1;cursor:pointer}.custom-select-option--checkbox.selected{background:var(--bg-selected, var(--bg-light))}.custom-select-option--checkbox.selected .custom-select-checkbox{accent-color:var(--primary)}.empty-state{text-align:center;padding:0rem 1rem 1rem;background:var(--gray-50);box-shadow:var(--shadow-heavy);border-radius:10px;border:2px dashed var(--gray-500);margin:.5rem auto;max-width:600px}.empty-state-icon{font-size:3rem;margin-bottom:1rem;opacity:.6;display:block}.empty-state h3{color:var(--gray-600);margin-bottom:1rem;font-size:1.3rem;font-weight:600}.empty-state p{color:var(--gray-600);margin-bottom:1.5rem;font-size:.9rem;line-height:1.5}.empty-state p:last-child{margin-bottom:0}.section-header{display:flex;align-items:center;margin-bottom:var(--spacing-lg);font-weight:700}.section-header h1,.section-header h2,.section-header h3{margin:0;color:var(--text-dark-blue)}.section-header--page{flex-direction:column;text-align:center;margin-bottom:2rem;position:relative}.section-header--page h1{font-size:1.8rem;margin-bottom:var(--spacing-sm)}.section-header--page p{color:var(--text-secondary);font-size:1.1rem;padding-bottom:1rem;text-align:center;margin-bottom:var(--spacing-xs);font-weight:400}@media (max-width: 480px){.section-header--page p{font-size:1rem}}.section-header--page:after{content:"";position:absolute;bottom:0;left:50%;transform:translate(-50%);width:90%;height:1px;border-bottom:1px solid var(--border-strong)}.section-header--exercise{flex-direction:column;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.section-header--exercise h2{font-size:1.5rem;text-align:center}.section-header--sidebar{justify-content:space-between;margin-bottom:1rem;border-bottom:1px solid var(--border-dark);padding-bottom:var(--spacing-xs)}.section-header--sidebar h3{margin-bottom:1rem;font-size:1.1rem}.auth-container{min-height:100vh;padding:1rem;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2)}.auth-card{width:100%;max-width:400px;background:var(--bg-primary);border-radius:12px;box-shadow:0 8px 32px #0000001a;padding:2rem;animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.auth-header{text-align:center;margin-bottom:2rem}.auth-header h1{font-size:2rem;font-weight:700;color:#2d3748;margin-bottom:.5rem}.auth-header p{color:#718096;font-size:.95rem}.auth-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-label{font-weight:600;color:var(--text-primary);font-size:.9rem}.form-input{padding:.875rem 1rem;border:2px solid #e2e8f0;border-radius:8px;font-size:1rem;transition:all .2s ease;background:var(--bg-primary)}.form-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-input.error{border-color:#e53e3e;box-shadow:0 0 0 3px #e53e3e1a}.form-error{color:#e53e3e;font-size:.85rem;margin-top:.25rem}.auth-button{padding:.875rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;position:relative;overflow:hidden}.auth-button:hover{transform:translateY(-1px);box-shadow:0 4px 12px #667eea4d}.auth-button:active{transform:translateY(0)}.auth-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.auth-button.loading{color:transparent}.auth-button.loading:after{content:"";position:absolute;top:50%;left:50%;width:20px;height:20px;margin:-10px 0 0 -10px;border:2px solid transparent;border-top:2px solid white;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.auth-divider{display:flex;align-items:center;gap:1rem;margin:1.5rem 0;color:#718096;font-size:.9rem}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:#e2e8f0}.auth-link{text-align:center;margin-top:1.5rem;color:#718096;font-size:.9rem}.auth-link a{color:#667eea;text-decoration:none;font-weight:600;transition:color .2s ease}.auth-link a:hover{color:#764ba2;text-decoration:underline}.success-message{padding:1rem;background:#f0fff4;border:1px solid #9ae6b4;border-radius:8px;color:#276749;margin-bottom:1rem;text-align:center;font-size:.9rem}.error-message{padding:1rem;background:#fed7d7;border:1px solid #feb2b2;border-radius:8px;color:#c53030;margin-bottom:1rem;text-align:center;font-size:.9rem}.resend-confirmation-btn{background:none;border:none;color:#667eea;text-decoration:underline;cursor:pointer;font-size:.9rem;margin-top:10px;padding:0;transition:color .2s ease}.resend-confirmation-btn:hover{color:#764ba2}.resend-confirmation-btn:disabled{opacity:.6;cursor:not-allowed}.password-strength{margin-top:.5rem}.strength-bar{height:4px;background:#e2e8f0;border-radius:2px;overflow:hidden;margin-bottom:.5rem}.strength-fill{height:100%;transition:all .3s ease;border-radius:2px}.strength-fill.weak{width:25%;background:#e53e3e}.strength-fill.fair{width:50%;background:#dd6b20}.strength-fill.good{width:75%;background:#38a169}.strength-fill.strong{width:100%;background:#2d3748}.strength-text{font-size:.8rem;color:#718096}.checkbox-group{display:flex;align-items:center;gap:.75rem}.checkbox-input{width:18px;height:18px;accent-color:#667eea;cursor:pointer}.checkbox-label{font-size:.9rem;color:#4a5568;cursor:pointer;-webkit-user-select:none;user-select:none}.forgot-password{text-align:right;margin-top:.5rem}.forgot-password a{color:var(--color-action-light);text-decoration:none;font-size:var(--font-xl);transition:color .2s ease}.forgot-password a:hover{color:#764ba2;text-decoration:underline}.google-button{width:100%;display:flex;align-items:center;justify-content:center;gap:.75rem;padding:.875rem 1rem;background:var(--bg-primary);border:2px solid var(--border-light);border-radius:var(--radius-medium);color:var(--text-primary);font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s ease}.google-button:hover{background:var(--gray-50);border-color:var(--border-medium);transform:translateY(-1px);box-shadow:var(--shadow-medium)}.google-button:active{transform:translateY(0)}.google-button:disabled{opacity:.5;cursor:not-allowed;transform:none}.google-button:disabled:hover{background:var(--bg-primary);transform:none;box-shadow:none}.google-button .google-icon{width:1.25rem;height:1.25rem;flex-shrink:0}.auth-loading-overlay{position:absolute;inset:0;background:#fffc;display:flex;align-items:center;justify-content:center;border-radius:12px;z-index:10}.auth-card{position:relative}.auth-loading{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2)}.loading-spinner{text-align:center;color:#fff}.spinner{width:40px;height:40px;border:4px solid rgba(255,255,255,.3);border-top:4px solid white;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 1rem}.loading-spinner p{font-size:1rem;margin:0}.stats{display:flex;align-items:center;color:var(--gray-600);font-weight:500;font-size:var(--font-base);gap:var(--spacing-sm)}.stats--centered{justify-content:center}.stats--space-between{justify-content:space-between}.stats--inline{display:inline-flex;gap:.25rem}.stats--vocab-count{color:var(--gray-500);font-size:var(--font-base)}.stats--word-count{font-size:var(--font-base)}.stats--saved-indicator{color:var(--color-success);font-weight:600}.stat-item{display:flex;align-items:center;gap:.25rem;color:var(--gray-600);font-weight:500}.stat-item--highlighted{color:var(--color-primary);font-weight:600}.stat-item--success{color:var(--color-success);font-weight:600}.stat-item--muted{color:var(--gray-500)}.stat-separator{color:var(--gray-400);margin:0 .25rem}.stat-count{font-weight:700;color:var(--text-primary)}.stat-label{color:var(--gray-500)}.modal-popup.lesson-mode-modal__popup{display:grid;grid-template-rows:minmax(60px,auto) 1fr minmax(80px,auto);grid-template-areas:"header" "content" "footer";width:100%;max-width:none;height:100dvh;max-height:100dvh;margin:0;overflow:hidden;position:relative;box-sizing:border-box}.lesson-mode-modal__popup .modal-popup__header{grid-area:header;position:relative;z-index:1;margin-bottom:0}.lesson-mode-modal__popup .modal-popup__content{grid-area:content;display:flex;flex-direction:column;padding:clamp(.75rem,1vh,1rem);gap:clamp(.75rem,1vh,1rem);overflow-y:auto;overflow-x:hidden;justify-content:flex-start;min-height:0;font-size:clamp(.9rem,1vh,1rem)}.lesson-mode-modal__popup--step-1 .modal-popup__content{overflow-y:auto}@media (max-height: 600px){.vocabulary-step__panel-section .panel--vocabulary--expanded .panel--vocabulary__content{max-height:min(250px,35vh)}.vocabulary-step__preview-section{min-height:250px}.vocabulary-preview__card{height:clamp(160px,16vh,220px)}.practice-content--scrollable{max-height:clamp(300px,40vh,450px)}}@media (min-width: 1024px){.practice-content--scrollable{max-height:none;height:auto}.lesson-mode-modal__popup--step-4 .modal-popup__content{max-height:none}}.lesson-mode-modal__popup .lesson-mode__footer{grid-area:footer;display:flex;flex-direction:column;width:100%;border-top:3px solid var(--border-dark);padding:clamp(.4rem,.6vh,.5rem) clamp(.75rem,.8vh,1rem);gap:clamp(.4rem,.4vh,.5rem);font-size:clamp(.85rem,.9vh,.9rem);background:var(--bg-primary);flex-shrink:0}.modal-overlay:has(.lesson-mode-modal__popup){z-index:10000;align-items:flex-start;justify-content:center;padding:0;margin:0;top:0;left:0}html:has(.lesson-mode-modal__popup),body:has(.lesson-mode-modal__popup){overflow:hidden}.vocabulary-step__panel-section{width:100%;flex-shrink:0}.vocabulary-step__panel-section .panel--vocabulary--expanded .panel--vocabulary__content{max-height:min(300px,30vh);height:auto;padding:var(--spacing-md);overflow-y:auto;overflow-x:hidden;scrollbar-width:thin;scrollbar-color:var(--color-primary) var(--bg-secondary)}.vocabulary-step__panel-section .panel--vocabulary--expanded .panel--vocabulary__content::-webkit-scrollbar{width:8px}.vocabulary-step__panel-section .panel--vocabulary--expanded .panel--vocabulary__content::-webkit-scrollbar-track{background:var(--bg-secondary);border-radius:4px}.vocabulary-step__panel-section .panel--vocabulary--expanded .panel--vocabulary__content::-webkit-scrollbar-thumb{background:var(--color-primary);border-radius:4px}.vocabulary-step__panel-section .panel--vocabulary--expanded .panel--vocabulary__content::-webkit-scrollbar-thumb:hover{background:var(--color-primary-hover)}.vocabulary-step__panel-section .panel--vocabulary--collapsed .panel--vocabulary__content{max-height:5rem;padding:.1rem;overflow:hidden}.vocabulary-step__panel-section .panel--vocabulary .panel--vocabulary__header{background:none;border-left:none;border-right:none;border-top:none;border-radius:0;padding:0;width:100%;text-align:left;cursor:pointer;transition:background-color .2s ease;background-color:var(--color-action-active)}.vocabulary-step__panel-section .panel--vocabulary .panel--vocabulary__header:hover{background-color:var(--bg-hover, rgba(0, 0, 0, .05))}.vocabulary-step__panel-section .panel--vocabulary .panel--vocabulary__header:focus{outline:2px solid var(--color-primary);outline-offset:-2px}.vocabulary-step__panel-section .panel--vocabulary .panel--vocabulary__header .vocabulary-expand-btn{pointer-events:none;background:transparent;border:none;color:inherit}.vocabulary-step__preview-section{margin-top:var(--spacing-md);width:100%;display:flex;flex-direction:column;justify-content:flex-start;flex:1;min-height:300px;overflow:visible}.vocabulary-preview{display:flex;flex-direction:column;align-items:center;text-align:center;gap:var(--spacing-md);min-height:100%;padding-bottom:var(--spacing-lg)}.vocabulary-preview__current{width:100%}.vocabulary-preview--empty{gap:1rem}.vocabulary-preview__progress{display:flex;flex-direction:column;width:100%}.vocabulary-preview__progress-bar{height:8px;background-color:var(--color-warning-dark);border-radius:4px;border:1px solid black;overflow:hidden;width:100%}.vocabulary-preview__progress .progress-bar__fill{background-color:var(--color-primary-hover);height:100%;transition:width .3s ease;border-radius:4px}.vocabulary-preview__current{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md)}.vocabulary-preview__counter{margin:-1rem 0 1rem;font-size:.875rem;color:var(--text-secondary);text-align:center}.vocabulary-preview__card{display:grid;grid-auto-rows:auto;row-gap:clamp(1rem,1.2vh,1.5rem);align-content:center;justify-items:center;width:100%;height:clamp(180px,18vh,240px);padding:0}.vocabulary-preview__card .vocabulary-word,.vocabulary-preview__card .vocabulary-translation{width:100%;text-align:center;margin:0;padding:clamp(.75rem,.8vh,1rem);flex:0 0 auto;font-size:clamp(1.8rem,2.5vh,3rem);font-weight:700}.vocabulary-preview__card .vocabulary-word{color:var(--text-primary);position:relative}.vocabulary-preview__card .vocabulary-word:after{content:"";position:absolute;bottom:-.75rem;left:50%;transform:translate(-50%);width:60px;height:2px;background:var(--border-medium);border-radius:1px}.vocabulary-preview__card .vocabulary-translation{color:var(--text-dark-blue)}.vocabulary-preview__card .vocabulary-translation:before{content:none}.vocabulary-preview__card:hover{transform:scale(1.02) translateY(-2px)}.vocabulary-preview__manual-controls{text-align:center;width:100%;padding:0 var(--spacing-md)}.vocabulary-preview__manual-controls .action-group button{width:auto}.vocabulary-preview__manual-controls .btn-primary{min-width:6rem}.vocabulary-preview__navigation .btn:disabled{opacity:.5;cursor:not-allowed}.focus-reading-content{display:flex;flex-direction:column;gap:clamp(.75rem,1vh,1rem);flex:1;overflow-y:auto;overflow-x:hidden;padding-bottom:clamp(.75rem,1vh,1rem);-webkit-mask-image:linear-gradient(to bottom,black 80%,transparent 100%);mask-image:linear-gradient(to bottom,black 80%,transparent 100%);-webkit-mask-size:100% 100%;mask-size:100% 100%;position:relative;font-size:clamp(.95rem,1.5vh,1.1rem);line-height:1.6}.lazy-vocab-test{display:flex;flex-direction:column;height:100%;width:100%;gap:1rem}.lazy-vocab-test--empty{justify-content:center;align-items:center;text-align:center;gap:1rem}.lazy-vocab-test__header{display:flex;flex-direction:column}.vocabulary-question__word{font-size:clamp(1.5rem,2.5vh,3rem);margin-bottom:clamp(.5rem,.8vh,1rem)}.lazy-vocab-test__question-wrapper{width:100%}.vocabulary-question__options{display:flex;flex-direction:column;gap:clamp(.4rem,.8vh,.6rem);width:100%}.vocabulary-question__options[role=radiogroup] .vocabulary-question__option[role=radio]:focus{z-index:1;outline:2px solid var(--color-primary);outline-offset:2px;box-sizing:border-box}.vocabulary-question__options[role=radiogroup]:before{content:""}.lazy-vocab-test .vocabulary-question__option{padding:clamp(.5rem,.8vh,1rem) clamp(.4rem,.4vh,.75rem);cursor:pointer;text-align:center;border:3px solid var(--border-dark);background-color:var(--bg-primary);color:var(--text-primary);font-size:clamp(1rem,1.8vh,1.5rem);font-weight:700;border-radius:.5rem;transition:background-color .2s ease,border-color .2s ease,transform .2s ease,box-shadow .2s ease;min-height:clamp(40px,5vh,65px);height:clamp(40px,5vh,65px);display:flex;align-items:center;justify-content:center;width:100%;box-sizing:border-box;flex:0 0 auto;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;position:relative;backface-visibility:hidden}.lazy-vocab-test .vocabulary-question__option:before{content:attr(data-keyboard-shortcut);position:absolute;top:6px;left:10px;font-size:.75rem;color:var(--text-primary);opacity:.7;font-weight:600;pointer-events:none;z-index:1;transition:none}.lazy-vocab-test .vocabulary-question__option .answer-text{display:flex;justify-content:center;align-items:center;width:100%;transition:none}@media (hover: hover) and (pointer: fine){.lazy-vocab-test .vocabulary-question__option:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}}.lazy-vocab-test .vocabulary-question__option--incorrect{border-color:var(--border-dark);background-color:var(--color-error);color:var(--text-white);font-weight:700;animation:pulse-correct .5s ease}.lazy-vocab-test .vocabulary-question__option--correct{border-color:var(--border-dark);background-color:var(--color-success);color:var(--text-white);opacity:1;animation:pulse-correct .5s ease}@keyframes pulse-correct{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1)}}.lazy-vocab-test__score{font-weight:600;color:var(--text-primary);background-color:var(--surface-color);padding:.5rem 1rem;border-radius:.375rem;border:1px solid var(--border-color)}.lazy-vocab-test__actions{display:flex;justify-content:space-around;margin-top:1rem}.step3-completion-results .completion-message{display:flex;flex-direction:column;gap:1rem;text-align:center}.lazy-practice-test{display:flex;flex-direction:column;height:100%;max-width:600px;margin:0 auto}.lazy-practice-test--empty{justify-content:center;align-items:center;text-align:center;gap:1rem}.lazy-practice-test__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px solid var(--border-color);flex-direction:column;gap:1rem;align-items:stretch}.lazy-practice-test__progress{flex:1;margin-right:0}.lazy-practice-test__question-counter{display:block;font-size:.875rem;color:var(--text-secondary);margin-bottom:.5rem}.lazy-practice-test__score{font-weight:600;color:var(--text-primary);background-color:var(--surface-color);padding:.5rem 1rem;border-radius:.375rem;border:1px solid var(--border-color)}.lazy-practice-test__question{margin-bottom:2rem}.lazy-practice-test__question-number{font-size:.875rem;color:var(--accent-color);font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.5rem}.lazy-practice-test__question-text{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin:0;line-height:1.4}.lazy-practice-test__options{display:grid;grid-template-columns:1fr;gap:.75rem;margin-bottom:2rem}.lazy-practice-test__option{padding:1rem 1.25rem;text-align:left;border:2px solid var(--border-dark);background-color:var(--surface-color);color:var(--text-primary);font-size:1rem;border-radius:.5rem;transition:all .2s ease;min-height:50px;display:flex;align-items:center}.lazy-practice-test__option:hover:not(:disabled){border-color:var(--accent-color);background-color:var(--accent-color-light);transform:translateY(-1px)}.lazy-practice-test__option--selected{border-color:var(--accent-color);background-color:var(--accent-color-light)}.lazy-practice-test__option--correct{border-color:var(--success-color);background-color:var(--success-color-light);color:var(--success-color-dark)}.lazy-practice-test__option--incorrect{border-color:var(--error-color);background-color:var(--error-color-light);color:var(--error-color-dark)}.lazy-practice-test__option--correct-answer{border-color:var(--success-color);background-color:var(--success-color-light);color:var(--success-color-dark);animation:pulse-correct .5s ease}.lazy-practice-test__result{text-align:center}.lazy-practice-test__feedback{padding:1rem;border-radius:.5rem;font-weight:600;font-size:1rem;margin-bottom:.5rem}.lazy-practice-test__feedback.correct{background-color:var(--success-color-light);color:var(--success-color-dark);border:1px solid var(--success-color)}.lazy-practice-test__feedback.incorrect{background-color:var(--error-color-light);color:var(--error-color-dark);border:1px solid var(--error-color)}.lazy-practice-test__hint{font-size:.875rem;color:var(--text-secondary);font-style:italic;padding:.75rem;background-color:var(--info-color-light);border-radius:.375rem;border:1px solid var(--info-color)}.practice-content{flex:1;display:flex;flex-direction:column;overflow:hidden}.practice-content--scrollable{overflow-y:auto;overflow-x:hidden;flex:1;max-height:60vh;padding:clamp(.5rem,.8vh,1rem);border:1px solid var(--border-color);border-radius:.5rem;background:var(--surface-color);margin-bottom:clamp(.5rem,.8vh,1rem);font-size:clamp(.85rem,1vh,1rem)}.practice-content--scrollable .story-title{margin:0 0 clamp(.75rem,1vh,1rem) 0;font-size:clamp(1.1rem,1.8vh,1.25rem);color:var(--text-primary);text-align:center;border-bottom:1px solid var(--border-color);padding-bottom:clamp(.4rem,.6vh,.5rem)}.practice-content--scrollable .practice-story-text{line-height:1.6;color:var(--text-primary)}.practice-content--scrollable .practice-progress{display:flex;justify-content:space-between;align-items:center;padding:clamp(.6rem,1vh,.75rem);background:var(--background-secondary);border-radius:.375rem;border:1px solid var(--border-color);font-size:clamp(.8rem,1.1vh,.875rem);color:var(--text-secondary);margin-top:clamp(1rem,1.5vh,1.5rem)}.practice-progress--inline{margin-top:2rem;margin-bottom:0}.lesson-mode-modal__popup .multiple-choice-area{width:100%;min-height:clamp(45px,5vh,65px);padding:0;border-top:1px solid var(--border-dark);display:flex;align-items:center;justify-content:center;position:relative;margin-bottom:clamp(-.75rem,-1vh,-.5rem)}.lesson-mode-modal__popup .multiple-choice-area:empty{min-height:clamp(30px,3.5vh,45px);padding:clamp(.3rem,.5vh,.5rem)}.lesson-mode-modal__popup .multiple-choice-placeholder{display:flex;align-items:center;justify-content:center;width:100%;min-height:50px;border:2px dashed var(--border-color);border-radius:.5rem;background:var(--background-color)}.lesson-mode-modal__popup .multiple-choice-instruction{color:var(--text-secondary);font-style:italic;text-align:center;font-size:.9rem}.lesson-mode-modal__popup .multiple-choice-inline{width:100%;border-radius:.5rem;padding:0;box-shadow:0 2px 8px #0000001a}.lesson-mode-modal__popup .multiple-choice-inline .multiple-choice-header{display:flex;justify-content:center;align-items:center;padding:0}.lesson-mode-modal__popup .multiple-choice-inline .btn-modal-close--small{width:24px;height:24px;font-size:.75rem;padding:0;min-width:auto}.lesson-mode-modal__popup .multiple-choice-inline .multiple-choice-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:.5rem}.lesson-mode-modal__popup .multiple-choice-inline .multiple-choice-option{padding:.5rem .75rem;font-size:.875rem;text-align:center;border-radius:.375rem;transition:all .2s ease;position:relative;display:flex;align-items:center;justify-content:center}.lesson-mode-modal__popup .multiple-choice-inline .multiple-choice-option .keyboard-shortcut{position:absolute;top:4px;left:8px;font-size:.625rem;color:var(--text-primary);opacity:.7;font-weight:600}.lesson-mode-modal__popup .multiple-choice-inline .multiple-choice-option .answer-text{display:flex;justify-content:center;align-items:center}.lesson-mode-modal__popup .multiple-choice-inline .multiple-choice-option--disabled{background-color:var(--color-error);border-color:var(--border-dark);color:var(--text-white);cursor:not-allowed;opacity:1}.lesson-mode-modal__popup .multiple-choice-inline .multiple-choice-option--disabled:hover{transform:none;box-shadow:none}.multiple-choice-inline--placeholder{opacity:.6}.vocabulary-hidden.vocabulary-word-selected{border:3px dashed #000;background-color:var(--primary-color-light);color:transparent}.lesson-mode-step--complete{justify-content:center;align-items:center}.lesson-mode-summary{display:flex;flex-direction:column;align-items:center;gap:2rem;text-align:center;max-width:400px;margin:0 auto}.lesson-mode-summary__score{display:flex;flex-direction:column;align-items:center;gap:1rem}.lesson-mode-summary__score-circle{width:100px;height:100px;border-radius:50%;background:linear-gradient(135deg,var(--primary-color),var(--accent-color));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:1.5rem;box-shadow:0 8px 24px #00000026}.lesson-mode-summary__percentage{font-size:1.5rem}.lesson-mode-summary__score-text{font-size:1.125rem;color:var(--text-secondary);margin:0}.lesson-mode-summary__breakdown{display:grid;grid-template-columns:1fr;gap:1rem;width:100%}.lesson-mode-summary__step{padding:1.5rem;background-color:var(--surface-color);border:1px solid var(--border-color);border-radius:.75rem}.lesson-mode-summary__step h5{margin:0 0 .5rem;font-size:1rem;color:var(--text-primary)}.lesson-mode-summary__step p{margin:0;font-size:1.125rem;font-weight:600;color:var(--primary-color)}.lesson-mode-summary__close-btn{padding:1rem 2rem;font-size:1.125rem;font-weight:600;background:linear-gradient(135deg,var(--success-color),var(--primary-color));border:none;color:#fff;border-radius:.75rem;box-shadow:0 4px 16px #00000026;transition:all .3s ease}.lesson-mode-summary__close-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #0003}.lesson-mode-modal__popup .lesson-mode__progress{color:var(--text-secondary);font-size:var(--font-md);align-self:center}.lesson-mode-modal__popup .lesson-mode__footer .action-group{margin:0;padding:0;border:none}.lesson-mode-modal__popup .lesson-mode__footer .action-group .btn{flex:1;min-width:0;max-width:none}.page .profile-page-content{display:flex;flex-direction:column;gap:var(--spacing-md)}.page .profile-page-content .auth-prompt{text-align:center;padding:4rem 2rem}.page .profile-page-content .auth-prompt h2{color:var(--text-primary);margin-bottom:1rem}.page .profile-page-content .auth-prompt p{color:var(--text-secondary);font-size:1.1rem}.page .profile-page-content .profile-form .form-field{display:flex;flex-direction:column;gap:var(--spacing-xs);margin-bottom:var(--spacing-md)}.page .profile-page-content .profile-form .form-field label{font-weight:600;font-size:var(--font-sm);color:var(--text-primary);margin-bottom:var(--spacing-xs)}.page .profile-page-content .profile-form .form-field .form-input,.page .profile-page-content .profile-form .form-field .form-select{padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--border-medium);border-radius:8px;background:var(--bg-primary);color:var(--text-primary);font-size:var(--font-md);transition:all .2s ease}.page .profile-page-content .profile-form .form-field .form-input:focus,.page .profile-page-content .profile-form .form-field .form-select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px rgba(var(--color-primary-rgb),.2)}.page .profile-page-content .profile-form .form-field .form-input:disabled,.page .profile-page-content .profile-form .form-field .form-select:disabled{opacity:.6;cursor:not-allowed;background:var(--bg-secondary)}.page .profile-page-content .panel--preferences{padding:.5rem}.page .profile-page-content .panel--preferences.is-collapsed{height:4.9rem}.page .profile-page-content .panel--preferences.is-collapsed .panel--preferences__header{border:none}.page .profile-page-content .panel--preferences__header{position:relative;padding-bottom:1rem;border-bottom:1px solid black;justify-content:center}.page .profile-page-content .panel--preferences__header h2{font-size:var(--font-2xl)}.page .profile-page-content .panel--preferences__header .btn.preferences-expand-btn{position:absolute;right:.5rem;top:45%;transform:translateY(-50%)}.page .profile-page-content .panel--preferences .preference-item{display:flex;flex-direction:row;gap:var(--spacing-xs);justify-content:space-between;align-items:center;transition:all .3s cubic-bezier(.4,0,.2,1);padding:var(--spacing-sm);border-radius:8px;background:#ffffff05;border:1px solid transparent;min-height:auto;overflow:hidden}.page .profile-page-content .panel--preferences .preference-item .preference-label{display:flex;align-items:center;gap:var(--spacing-sm);font-size:.1rem}.page .profile-page-content .panel--preferences .preference-item .preference-label span{font-size:.8rem;font-weight:700}.page .profile-page-content .panel--preferences .preference-item .preference-label .tooltip-trigger{margin-right:0;background-color:var(--bg-black)}.page .profile-page-content .panel--preferences .preference-item .preference-control{flex-shrink:0;margin-left:0;order:2}.page .profile-page-content .panel--preferences .preference-item .preference-control--topics{width:100%}.page .profile-page-content .panel--preferences .preference-item .preference-control--topics .topic-actions{display:flex;gap:var(--spacing-xs);justify-content:flex-end}.page .profile-page-content .panel--preferences .preference-item .preference-control--topics .topic-actions .btn--ghost{padding:var(--spacing-xs) var(--spacing-sm);font-size:var(--font-xs);opacity:.7;border:1px solid rgba(255,255,255,.2);background:transparent;color:var(--text-secondary)}.page .profile-page-content .panel--preferences .preference-item .preference-control--topics .topic-actions .btn--ghost:hover{opacity:1;background:#ffffff0d;color:var(--text-primary)}.page .profile-page-content .panel--preferences .preference-item--topics{flex-direction:column;align-items:stretch;gap:var(--spacing-sm)}.page .profile-page-content .panel--preferences .preference-item--topics .preference-label{align-self:flex-start}.page .profile-page-content .panel--preferences .preference-item.checkbox-item{flex-direction:row}.page .profile-page-content .panel--preferences .preference-item.checkbox-item .preference-label{order:1;flex:1}.page .profile-page-content .panel--preferences .preference-item.checkbox-item .preference-checkbox{order:2;margin-left:var(--spacing-sm)}.page .profile-page-content .panel--preferences .preference-item .preference-select{margin-left:0;width:140px}.page .profile-page-content .panel--preferences .preferences-toolbar .toolbar-actions{display:flex;justify-content:center;gap:var(--spacing-sm);flex-wrap:wrap}.page .profile-page-content .panel--preferences .preference-group{background:var(--bg-primary);border-top:1px solid black;border-radius:8px;margin:0;overflow:hidden;box-shadow:0 4px 20px #00000014,0 1px 3px #0000000d;transition:all .3s cubic-bezier(.4,0,.2,1)}.page .profile-page-content .panel--preferences .preference-group .preference-group-header{width:100%;border:none;border:1px solid black;border-radius:8px;padding:.5rem;display:flex;justify-content:space-between;align-items:center;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.page .profile-page-content .panel--preferences .preference-group .preference-group-header h3{margin:0;color:var(--text-primary);font-size:var(--font-xl);font-weight:600;letter-spacing:-.02em}.page .profile-page-content .panel--preferences .preference-group .preference-group-header .collapse-indicator{color:var(--text-secondary);font-size:var(--font-xl);transition:all .3s cubic-bezier(.4,0,.2,1);font-weight:300}.page .profile-page-content .panel--preferences .preference-group .preference-controls{padding:0;display:flex;flex-direction:column;gap:0;background:rgba(var(--bg-primary-rgb, 255, 255, 255),.5)}.page .profile-page-content .panel--preferences .preferences-save-section{display:flex;flex-direction:column;gap:1rem;text-align:center;padding:var(--spacing-md) 0;position:relative}.page .profile-page-content .panel--preferences .preferences-save-section:before{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:60%;height:2px;background:linear-gradient(90deg,transparent 0%,var(--border-medium) 20%,var(--color-primary) 50%,var(--border-medium) 80%,transparent 100%)}.page .profile-page-content .panel--preferences .preferences-save-section .unsaved-indicator{display:flex;justify-content:center;align-items:center;gap:var(--spacing-xs);color:var(--color-warning);font-size:var(--font-sm);font-weight:500}.page .profile-page-content .panel--preferences .preferences-save-section .unsaved-indicator .unsaved-dot{animation:pulse 1.5s infinite}.page .profile-page-content .panel--preferences .preferences-save-section .save-hint{margin-top:var(--spacing-sm);color:var(--text-secondary);font-size:var(--font-sm)}.page .profile-page-content .profile-footer-section{margin-top:var(--spacing-xl)}.page .profile-page-content .profile-footer-section .join-date{color:var(--text-secondary);margin:0;font-size:var(--font-sm);text-align:center}.page .profile-page-content .legal-links-section{text-align:center;margin:0 0 0 15px}.page .profile-page-content .legal-links-section .legal-links{display:flex;justify-content:center;align-items:center;gap:var(--spacing-sm);font-size:var(--font-sm)}.page .profile-page-content .legal-links-section .legal-links .legal-link{color:var(--text-secondary);text-decoration:none;transition:color .2s ease}.page .profile-page-content .legal-links-section .legal-links .legal-link:hover{color:var(--color-primary);text-decoration:underline}.page .profile-page-content .legal-links-section .legal-links .legal-separator{color:var(--text-tertiary);font-weight:300}.page .profile-page-content .remove-account-section{text-align:center}.page .profile-page-content .remove-account-section .btn--danger{border:2px solid var(--border-dark)}@keyframes modernPulse{0%,to{box-shadow:0 0 20px rgba(var(--color-success-rgb),.3),inset 0 1px #ffffff1a}50%{box-shadow:0 0 30px rgba(var(--color-success-rgb),.5),inset 0 1px #fff3}}@keyframes recentlyChangedPulse{0%{transform:scale(1);box-shadow:0 0 rgba(var(--color-success-rgb),.4)}50%{transform:scale(1.02);box-shadow:0 0 0 8px rgba(var(--color-success-rgb),.1)}to{transform:scale(1);box-shadow:0 0 rgba(var(--color-success-rgb),0)}}@keyframes modernSlideIn{0%{transform:translate(100%) scale(.9);opacity:0}60%{transform:translate(-8px) scale(1.02);opacity:1}to{transform:translate(0) scale(1);opacity:1}}@keyframes slideInFromRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes toastFadeInCenter{0%{opacity:0;transform:translate(-50%,-50%) scale(.95)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.community-leaderboard{max-width:900px;margin:0 auto;padding:2rem}.community-leaderboard .loading-container,.community-leaderboard .error-container{text-align:center;padding:4rem 2rem}.community-leaderboard .loading-container .loading-spinner,.community-leaderboard .error-container .loading-spinner{width:40px;height:40px;border:3px solid var(--border-primary);border-top:3px solid var(--primary);border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 1rem}.community-leaderboard .loading-container h2,.community-leaderboard .error-container h2{color:var(--text-primary);margin-bottom:1rem}.community-leaderboard .loading-container p,.community-leaderboard .error-container p{color:var(--text-secondary);margin-bottom:2rem}.community-leaderboard .leaderboard-header{text-align:center;margin-bottom:3rem}.community-leaderboard .leaderboard-header h2{color:var(--text-primary);margin:0 0 .5rem;font-size:2rem}.community-leaderboard .leaderboard-header p{color:var(--text-secondary);margin:0 0 2rem;font-size:1.1rem}.community-leaderboard .leaderboard-header .timeframe-selector{display:flex;justify-content:center;gap:.5rem;background:var(--surface-secondary);padding:.5rem;border-radius:8px;display:inline-flex}.community-leaderboard .leaderboard-header .timeframe-selector .timeframe-btn{padding:.5rem 1rem;border:none;background:transparent;color:var(--text-secondary);border-radius:6px;cursor:pointer;transition:all .2s ease;font-size:.9rem}.community-leaderboard .leaderboard-header .timeframe-selector .timeframe-btn:hover{color:var(--text-primary);background:var(--surface-tertiary)}.community-leaderboard .leaderboard-header .timeframe-selector .timeframe-btn.active{background:var(--primary);color:#fff}.community-leaderboard .community-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:3rem}.community-leaderboard .community-stats .stat-item{background:var(--surface-secondary);border:1px solid var(--border-primary);border-radius:12px;padding:1.5rem;text-align:center}.community-leaderboard .community-stats .stat-item .stat-label{display:block;color:var(--text-secondary);font-size:.9rem;margin-bottom:.5rem}.community-leaderboard .community-stats .stat-item .stat-value{display:block;color:var(--primary);font-size:2rem;font-weight:700}.community-leaderboard .user-rank-card{background:linear-gradient(135deg,var(--primary),var(--primary-hover));color:#fff;border-radius:12px;padding:2rem;margin-bottom:3rem;text-align:center}.community-leaderboard .user-rank-card h3{margin:0 0 1rem;font-size:1.2rem}.community-leaderboard .user-rank-card .rank-info{display:flex;align-items:center;justify-content:center;gap:1rem}.community-leaderboard .user-rank-card .rank-info .rank-position{font-size:2rem;font-weight:700}.community-leaderboard .user-rank-card .rank-info .rank-text{font-size:1.1rem}.community-leaderboard .rankings-list h3{color:var(--text-primary);margin:0 0 1.5rem;font-size:1.5rem;text-align:center}.community-leaderboard .rankings-list .ranking-item{display:flex;align-items:center;gap:1rem;padding:1.5rem;background:var(--surface-secondary);border:1px solid var(--border-primary);border-radius:12px;margin-bottom:1rem;transition:all .2s ease}.community-leaderboard .rankings-list .ranking-item:hover{transform:translateY(-1px);box-shadow:0 4px 12px #0000001a}.community-leaderboard .rankings-list .ranking-item.current-user{border-color:var(--primary);background:linear-gradient(135deg,var(--primary) 10,var(--surface-secondary))}.community-leaderboard .rankings-list .ranking-item .rank-badge{min-width:60px;height:60px;border-radius:50%;background:var(--surface-tertiary);display:flex;align-items:center;justify-content:center;font-size:1.2rem;font-weight:700;color:var(--text-primary)}.community-leaderboard .rankings-list .ranking-item .rank-badge:first-child{background:linear-gradient(135deg,gold,#ffed4e);color:#b8860b}.community-leaderboard .rankings-list .ranking-item .learner-info{flex:1}.community-leaderboard .rankings-list .ranking-item .learner-info .learner-name{display:block;font-weight:600;color:var(--text-primary);margin-bottom:.25rem}.community-leaderboard .rankings-list .ranking-item .learner-info .learner-level{display:block;color:var(--text-secondary);font-size:.9rem}.community-leaderboard .rankings-list .ranking-item .learner-stats{display:flex;gap:1.5rem}.community-leaderboard .rankings-list .ranking-item .learner-stats .stat{text-align:center}.community-leaderboard .rankings-list .ranking-item .learner-stats .stat .stat-number{display:block;font-weight:700;color:var(--primary);font-size:1.1rem}.community-leaderboard .rankings-list .ranking-item .learner-stats .stat .stat-label{display:block;color:var(--text-secondary);font-size:.8rem}.community-leaderboard .auth-prompt{text-align:center;padding:3rem 2rem;background:var(--surface-secondary);border:1px solid var(--border-primary);border-radius:12px;margin-top:2rem}.community-leaderboard .auth-prompt h3{color:var(--text-primary);margin:0 0 1rem}.community-leaderboard .auth-prompt p{color:var(--text-secondary);margin:0}.community-leaderboard .btn{padding:.75rem 1.5rem;border:none;border-radius:6px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s ease}.community-leaderboard .btn.btn--primary{background:var(--primary);color:#fff}.community-leaderboard .btn.btn--primary:hover{background:var(--primary-hover);transform:translateY(-1px)}@media (max-width: 768px){.community-leaderboard{padding:1rem}.community-leaderboard .timeframe-selector{flex-direction:column!important;width:100%}.community-leaderboard .timeframe-selector .timeframe-btn{width:100%;text-align:center}.community-leaderboard .community-stats{grid-template-columns:1fr;gap:1rem}.community-leaderboard .user-rank-card .rank-info{flex-direction:column;gap:.5rem}.community-leaderboard .ranking-item{flex-direction:column;text-align:center;gap:1rem}.community-leaderboard .ranking-item .learner-info{order:1}.community-leaderboard .ranking-item .rank-badge{order:0}.community-leaderboard .ranking-item .learner-stats{order:2;justify-content:center}}[data-theme=dark] .community-leaderboard .ranking-item:hover{box-shadow:0 4px 12px #ffffff0d}.theme-toggle{--toggle-bg-light: var(--gray-100);--toggle-bg-dark: var(--gray-800);--toggle-border: var(--border-medium);--knob-size: 24px;--toggle-height: 42px;--toggle-width: 64px;--sun: #ffcc00;--moon: #5865f2;position:relative;display:inline-flex;justify-content:center;height:var(--toggle-height);width:var(--toggle-width);border-radius:calc(var(--toggle-height) / 2);border:2px solid var(--toggle-border);background:var(--bg-secondary);padding:0;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .2s ease,border-color .2s ease,box-shadow .2s ease}.theme-toggle .theme-toggle__track{position:absolute;inset:0;display:flex;align-items:center;justify-content:space-between;padding:0 8px;pointer-events:none;z-index:2}.theme-toggle .theme-toggle__icon{width:16px;height:16px;display:inline-block;line-height:1;opacity:.8}.theme-toggle .theme-toggle__icon--sun{color:var(--sun)}.theme-toggle .theme-toggle__icon--moon{color:var(--moon)}.theme-toggle .theme-toggle__knob{position:absolute;top:50%;transform:translateY(-50%);left:4px;height:var(--knob-size);width:var(--knob-size);border-radius:50%;background:var(--surface);box-shadow:0 2px 6px var(--black-20);transition:left .2s ease,background .2s ease,box-shadow .2s ease,transform .2s ease;z-index:1}.theme-toggle.is-dark{background:var(--gray-900);border-color:var(--gray-700)}.theme-toggle.is-dark .theme-toggle__knob{left:calc(var(--toggle-width) - var(--knob-size) - 4px - 4px);background:var(--gray-100)}.theme-toggle.is-dark .theme-toggle__icon--sun{opacity:.35;filter:grayscale(.25)}.theme-toggle.is-dark .theme-toggle__icon--moon{opacity:1;color:#fff;filter:drop-shadow(0 0 2px rgba(255,255,255,.85)) drop-shadow(0 0 4px rgba(88,101,242,.6))}.theme-toggle:not(.is-dark){background:var(--gray-100);border-color:var(--gray-300)}.theme-toggle:not(.is-dark) .theme-toggle__icon--sun{opacity:1}.theme-toggle:not(.is-dark) .theme-toggle__icon--moon{opacity:.5;filter:grayscale(.2)}.panel--profile__theme-toggle{display:flex;align-items:center}.theme-toggle--floating{position:absolute;top:.75rem;right:1rem;z-index:5}.tour-welcome .driver-popover{max-width:380px;text-align:center}.tour-welcome .driver-popover-title{text-align:center;font-weight:700;margin-bottom:var(--spacing-md)}.tour-welcome .driver-popover-description{line-height:1.6}.tour-primary-cta{background:#4f46e5;color:#fff;border:none;padding:.55rem 1rem;border-radius:8px;font-weight:600}.tour-welcome .tour-primary-cta:hover{background:#4338ca}.tour-welcome .driver-close-btn{opacity:.85}.tour-welcome .driver-prev-btn{display:none}.tour-welcome .tour-footer,.tour-welcome .driver-popover footer,.tour-final .tour-footer,.tour-final .driver-popover footer{display:flex;flex-direction:row;justify-content:center;align-items:center;gap:0;padding:0 var(--spacing-sm);margin-top:2rem}.tour-final .driver-popover{max-width:380px;text-align:center}.tour-final .driver-popover-title{font-weight:700}.tour-final .driver-popover-description{line-height:1.6}.tour-final .driver-prev-btn{display:none}.tour-final .tour-start-learning{padding:0 .5rem;border-radius:6px}.driver-overlay{background:#00000026}.tour-welcome .driver-popover-arrow,.tour-final .driver-popover-arrow{display:none}.tour-em{font-weight:700}.avatar-display{display:inline-flex;align-items:center;justify-content:center;border-radius:50%;overflow:hidden;flex-shrink:0;position:relative;border:2px solid var(--border-dark);background-color:var(--color-action);font-weight:700;transition:var(--transition-normal);width:54px;height:54px}.avatar-display--clickable{cursor:pointer}.avatar-display--clickable:hover{transform:translateY(-2px);box-shadow:var(--shadow-large)}.avatar-display--clickable:active{transform:translateY(0)}.avatar-display--clickable:focus-visible{outline:3px solid var(--focus-ring, var(--color-primary-light));outline-offset:3px}.avatar-display__image{width:100%;height:100%;object-fit:cover;object-position:center;transform:scale(1.4);transition:transform .2s ease}.avatar-display__letter{display:flex;align-items:center;justify-content:center;width:100%;height:100%;line-height:1}.avatar-selector{max-width:600px;width:100%}.avatar-selector__header{text-align:center;margin-bottom:var(--spacing-lg)}.avatar-selector__header h3{margin:0 0 var(--spacing-sm) 0;font-size:var(--font-xl);color:var(--text-primary)}.avatar-selector__description{margin:0;color:var(--text-secondary);font-size:var(--font-sm)}.avatar-selector__categories{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);justify-content:center;margin-bottom:var(--spacing-lg);padding:0 var(--spacing-sm)}.avatar-category-btn{padding:var(--spacing-xs) var(--spacing-sm);border:1px solid var(--border-medium);border-radius:var(--radius-medium);background:var(--bg-secondary);color:var(--text-secondary);font-size:var(--font-sm);font-weight:500;cursor:pointer;transition:var(--transition-fast);white-space:nowrap}.avatar-category-btn:hover{background:var(--bg-tertiary);border-color:var(--border-dark)}.avatar-category-btn.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.avatar-selector__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:var(--spacing-md);margin-bottom:var(--spacing-xl);max-height:400px;overflow-y:auto;padding:var(--spacing-sm);border-radius:var(--radius-medium);background:var(--bg-secondary)}.avatar-selector__item{display:flex;flex-direction:column;align-items:center}.avatar-option{display:flex;align-items:center;justify-content:center;gap:var(--spacing-xs);padding:0;border:2px solid var(--border-light);border-radius:var(--radius-medium);background:var(--bg-primary);cursor:pointer;transition:var(--transition-fast);width:100%;max-width:120px;height:100%;overflow:hidden;background:var(--color-primary);font-size:var(--font-6xl)}.avatar-option:hover{border-color:var(--color-primary-light);transform:translateY(-2px);box-shadow:var(--shadow-medium)}.avatar-option.selected{border-color:var(--color-primary);background:var(--color-primary-light);box-shadow:var(--shadow-large)}.avatar-option:focus-visible{outline:2px solid var(--focus-ring, var(--color-primary));outline-offset:2px}.avatar-option__preview{position:relative;width:100%;height:100%}.avatar-option__image{width:100%;height:100%;object-fit:cover;object-position:center}.avatar-option__badge{position:absolute;top:2px;left:2px;display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:9999px;background:#fffffff2;box-shadow:var(--shadow-small);z-index:2}.avatar-option__badge img{width:16px;height:16px;display:block}.avatar-selector__actions{display:flex;gap:var(--spacing-md);justify-content:flex-end;padding-top:var(--spacing-md);border-top:1px solid var(--border-light)}.avatar-selector-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-md)}.avatar-selector-popup{background:var(--bg-primary);border-radius:var(--radius-large);padding:var(--spacing-xl);box-shadow:var(--shadow-extra);max-width:90vw;max-height:90vh;overflow-y:auto;position:relative}.home-page-content{display:flex;flex-direction:column;gap:var(--spacing-xl);margin:0 auto}.home-page-content .modes-container .modes-container-btn{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:var(--spacing-md);text-decoration:none;color:var(--text-primary);border-radius:var(--radius-medium);transition:var(--transition-normal);background:var(--bg-secondary);border:1px solid var(--border-strong);min-height:80px;justify-content:center}.home-page-content .modes-container .modes-container-btn:focus-visible{background:var(--color-primary-lighter);border-color:var(--color-primary);transform:translateY(-2px);box-shadow:var(--shadow-medium)}.home-page-content .modes-container .modes-container-btn .mode-icon{font-size:var(--font-3xl);line-height:1}.home-page-content .modes-container .modes-container-btn .mode-icon[src]{width:32px;height:32px;object-fit:contain}.home-page-content .modes-container .modes-container-btn .mode-label{font-size:var(--font-sm);font-weight:500;text-align:center}.home-page-content .modes-container .modes-container-btn .mode-status{font-size:var(--font-xs);color:var(--gray-500);font-style:italic}.home-page-content .modes-container .modes-container-btn--disabled{opacity:.6;cursor:not-allowed;pointer-events:none;background:var(--gray-100)}.home-page-content .modes-container .modes-container-btn--disabled:hover,.home-page-content .modes-container .modes-container-btn--disabled:focus-visible{transform:none;box-shadow:none;background:var(--gray-100);border-color:var(--gray-200)}.latest-story-section{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-sm)}.home-mascot{display:flex;justify-content:center;align-items:center;margin:0 0 0 40px;padding:0}.home-mascot--frame{inline-size:auto;block-size:auto;overflow:visible;position:static;--frame-size: 110px}.home-mascot--frame .home-mascot__frame{inline-size:var(--frame-size);block-size:var(--frame-size);overflow:hidden;border-radius:var(--radius-medium);position:relative}.home-mascot--frame .home-mascot__img{display:block;inline-size:155%;block-size:auto;transform:translate(-20%,-20%);transform-origin:center;filter:drop-shadow(var(--shadow-small))}.home-mascot__text{position:relative;align-self:center;margin-inline-start:var(--spacing-lg);padding:var(--spacing-sm);max-width:140px;margin:-35px 0 0 8px;background-color:var(--bg-white);color:var(--text-black);font-weight:700;border:3px solid var(--border-dark);border-radius:var(--radius-medium);box-shadow:var(--shadow-small);max-inline-size:clamp(160px,26vw,320px);line-height:1.25}.home-mascot__text:before,.home-mascot__text:after{content:"";position:absolute;top:60%;transform:translateY(-50%);pointer-events:none}.home-mascot__text:before{left:-20px;border-width:8px;border-style:solid;border-color:transparent var(--border-dark) transparent transparent}.home-mascot__text:after{left:-20px;border-width:8px;border-style:solid;border-color:transparent var(--border-dark) transparent transparent}.no-stories-message{grid-column:1/-1;text-align:center;padding:3rem 2rem;background:var(--gray-100);border-radius:10px;border:2px dashed var(--gray-300)}.no-stories-message h3{color:var(--gray-600);margin-bottom:.5rem;font-size:1.5rem}.no-stories-message p{color:var(--gray-500);margin:0;font-size:1rem}.story-list-page .panel--preferences{position:relative;margin-bottom:var(--spacing-sm);padding:0 var(--spacing-md) var(--spacing-md)}.story-list-page .panel--preferences.is-collapsed{height:3.8rem;overflow:hidden;padding:0 var(--spacing-md)}.story-list-page .panel--preferences__header{justify-content:center;border-bottom:2px solid var(--border-light);padding-bottom:1.2rem}.story-list-page .panel--preferences__header h2{margin-top:.8rem}.story-list-page .panel--preferences__header:focus{box-shadow:none}.story-list-page .panel--preferences .preferences-expand-btn{position:absolute;top:.5rem;right:var(--spacing-md)}.stories-grid{display:flex;flex-direction:column;gap:var(--spacing-md)}.stories-audios-link{display:flex;width:100%;text-decoration:none;justify-content:center;border:2px solid var(--border-dark);background-color:var(--bg-gold-light)}.stories-audios-link .stories-audios-link__content{display:flex;align-items:center;gap:var(--spacing-sm);font-weight:700}.stories-audios-link .stories-audios-link__icon{display:inline-block}.story-viewer-container{position:relative;width:100%;min-height:100vh;scroll-margin-top:0;scroll-snap-align:start}.story-viewer-container .section-header--page:after{display:none}.section-header--page{display:flex;flex-direction:column;margin:0 0 2rem;gap:1rem}.section-header--page h1{padding:0;margin:0}.section-header__toolbar{display:grid;grid-template-columns:1fr 2fr 1fr 1fr;align-items:stretch;height:2.5rem;width:100%}.section-header__toolbar button{width:100%}.section-header__toolbar .bookmark-button{border-right:0;border-left:0;border-radius:0}.section-header__toolbar .mark-read-button{border-radius:0 12px 12px 0;overflow:hidden;white-space:wrap;text-overflow:ellipsis;font-size:.75rem;padding-inline:.5rem}.section-header__toolbar .mark-read-button.active{background-color:var(--color-success);font-size:1.1rem}.section-header__actions{display:contents}.section-header__actions .badge-group{display:grid;grid-template-columns:1fr 1fr;align-items:center;justify-content:center;grid-column:span 1;gap:0;font-size:2rem;border-top:2px solid var(--border-dark);border-bottom:2px solid var(--border-dark)}.section-header__actions .badge--level,.section-header__actions .badge--language{font-size:1rem;height:100%;border-radius:0;border:none;border-right:2px solid var(--border-dark)}.story-viewer-header-back-link{display:flex;align-items:center;justify-content:center;text-align:center;background:var(--gray-600);color:#fff;border:none;margin-right:12px;border-radius:12px 0 0 12px;cursor:pointer;transition:background .3s;font-weight:700;text-decoration:none;line-height:1}.story-viewer-content,.story-content-container{display:flex;flex-direction:column;gap:var(--spacing-md)}.panel--vocabulary{position:relative;display:flex;flex-direction:column;border-radius:var(--radius-large);overflow:hidden;padding:0}.panel--vocabulary--expanded{max-height:none}.panel--vocabulary--collapsed{overflow-y:auto;overflow-x:hidden}.panel--vocabulary--collapsed .panel--vocabulary__content{max-height:4.8rem}.panel--vocabulary__header{display:grid;grid-template-columns:1fr auto 1fr;border-bottom:1px solid var(--border-dark);align-items:center;min-height:3.8rem;background:var(--color-action-active);border-left:none;border-right:none;border-top:none;border-radius:0;color:var(--text-white);padding:0;width:100%;text-align:left;cursor:pointer;transition:background-color .2s ease}.panel--vocabulary__header:focus{outline:2px solid var(--color-primary);outline-offset:-2px}.panel--vocabulary__header .panel--vocabulary__title{grid-column:2;text-align:center;border:none;font-size:1.2rem;margin:0;color:var(--text-white)}.panel--vocabulary__header .vocabulary-expand-btn{grid-column:3;justify-self:end;margin-right:var(--spacing-md);pointer-events:none;background:transparent;border:none;color:inherit}.panel--vocabulary__title{color:var(--text-primary);margin:0;font-size:1rem;font-weight:600}.panel--vocabulary__content{padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-panel);overflow-y:auto;overflow-x:hidden;scrollbar-width:thin;scrollbar-color:var(--color-action) var(--gray-100);padding:var(--spacing-xs)}.panel--vocabulary__content::-webkit-scrollbar{display:block;width:10px}.panel--vocabulary__content::-webkit-scrollbar-track{background:var(--gray-100);border-radius:5px;margin:5px}.panel--vocabulary__content::-webkit-scrollbar-thumb{background:var(--color-primary);border:2px solid var(--gray-50);border-radius:5px}.panel--vocabulary__content::-webkit-scrollbar-thumb:hover{background:var(--color-primary-hover)}.panel--vocabulary__list{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:var(--spacing-md);margin-bottom:var(--spacing-sm);text-align:center}.panel--vocabulary__list .vocabulary-item{border:1px solid var(--border-dark);border-top:0;border-radius:12px}.panel--vocabulary__help{background-color:var(--color-action-active);border-radius:var(--radius-medium);border-left:4px solid var(--color-primary);margin:var(--spacing-md) 0;padding:var(--spacing-sm);line-height:1.3}.panel--vocabulary__help p{margin:0;font-style:italic;color:var(--text-white);font-size:.85rem;text-align:justify}.panel--vocabulary__footer{display:flex;justify-content:center;padding:var(--spacing-sm) var(--spacing-md);border-top:1px solid var(--border-light);background:var(--bg-secondary)}.vocabulary-collapse-btn{padding:var(--spacing-xs) var(--spacing-md);font-size:1.2rem;border:1px solid var(--border-medium);border-radius:var(--radius-medium);transition:all .2s ease;width:100%;font-weight:700}.vocabulary-collapse-btn:hover{background:var(--color-secondary-hover);color:var(--text-primary);transform:translateY(-1px)}.learning-mode .panel--vocabulary--collapsed .panel--vocabulary__content,.practice-mode .panel--vocabulary--collapsed .panel--vocabulary__content{max-height:0;overflow:hidden;padding:0}.vocabulary-panel-word-btn{color:#fff;width:100%;font-weight:700;font-size:1rem}.vocabulary-panel-word-btn:hover{background-color:var(--color-action)}.vocabulary-panel-word-btn.active:hover{background-color:var(--color-success)}.vocabulary-panel-word-btn.long-word{font-size:.75rem}.vocabulary-translation{text-align:center;color:var(--text-dark);line-height:1.2;font-style:italic;font-size:.9rem;font-weight:700;opacity:.9;flex:1}.vocabulary-translation.long-word{font-size:.75rem}.vocabulary-translation:before{content:"☞";margin-right:var(--spacing-xs)}.story-title-in-content{color:var(--color-dark);font-size:1.8rem;font-weight:600;text-align:center;margin-bottom:var(--spacing-xl);padding-bottom:var(--spacing-md);border-bottom:2px solid var(--gray-200)}.panel--story-content{line-height:1.8;border-top-left-radius:0;border-top-right-radius:0}.interactive-text{-webkit-user-select:text;user-select:text;cursor:text}.interactive-text p{color:var(--text-primary);font-size:1.1rem;text-align:justify;line-height:2.2;margin-bottom:var(--spacing-lg);letter-spacing:.3px;word-wrap:break-word;overflow-wrap:break-word;hyphens:auto;-webkit-hyphens:auto;-ms-hyphens:auto}.interactive-text::selection{background:var(--color-primary) 47;color:var(--text-primary)}.interactive-text ::-moz-selection{background:var(--color-primary);color:var(--text-white)}.interactive-text-instructions{display:inline-block;margin:2.5rem 0 0;line-height:1.3;font-style:italic;color:var(--color-dark);font-size:.85rem}.content-loading-indicator{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 2rem;text-align:center;color:var(--text-secondary)}.content-loading-indicator .loading-spinner{width:32px;height:32px;border:3px solid var(--color-light);border-top:3px solid var(--color-primary);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}.content-loading-indicator p{margin:0;font-size:.95rem;color:var(--text-secondary)}.content-error-indicator{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 2rem;text-align:center}.content-error-indicator p{margin:0;font-size:.95rem;color:var(--text-secondary)}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.interactive-text-sentinel{display:block;height:2px;margin-top:8px}.hoverable-word{position:relative;cursor:pointer;padding:1px 2px;border-radius:3px;font-weight:700;-webkit-tap-highlight-color:transparent}.hoverable-word.vocabulary-normal{font-weight:400;color:inherit}.hoverable-word.prevent-selection{user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;-webkit-touch-callout:none}.hoverable-word.word-saved{color:var(--color-success);font-weight:700}.hoverable-word.word-saved.word-translated{color:var(--color-success)}.hoverable-word.word-translated{color:var(--text-black);font-style:italic;background-color:var(--gray-200);padding:1px 3px;border-radius:3px;transition:var(--transition-fast)}.hoverable-word.double-tap-saved{animation:double-tap-save .6s ease-in-out}@keyframes double-tap-save{0%{background-color:transparent;transform:scale(1)}50%{background-color:var(--color-success);color:#fff;transform:scale(1.05);box-shadow:0 0 10px var(--green-alpha-50)}to{background-color:transparent;transform:scale(1)}}.word-translation-tooltip{pointer-events:none;animation:tooltipFadeIn .2s ease-out}.word-translation-tooltip .tooltip-content{background:var(--color-primary);color:#fff;padding:8px 12px;border-radius:6px;font-size:.9rem;font-weight:500;white-space:nowrap;box-shadow:0 4px 12px #00000026;border:1px solid rgba(255,255,255,.1)}.word-translation-tooltip .tooltip-arrow{position:absolute;top:100%;left:50%;transform:translate(-50%);width:0;height:0;border-left:6px solid transparent;border-right:6px solid transparent;border-top:6px solid var(--color-primary)}@keyframes tooltipFadeIn{0%{opacity:0;transform:translate(-50%) translateY(5px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.panel--story-vocab-test{height:auto;padding:0}.panel--story-vocab-test__header{padding:var(--spacing-md);border-bottom:1px solid var(--border-strong);border-radius:12px;background:var(--color-action-active);text-align:center;font-size:var(--font-xl);font-weight:700}.panel--story-vocab-test__header h3{color:var(--text-white)}.panel--story-vocab-test__content{flex:1;padding:var(--spacing-xs);display:flex;flex-direction:column;gap:var(--spacing-sm)}.panel--story-vocab-test__controls{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);border-radius:var(--radius-large);border:1px solid var(--border-strong);box-shadow:var(--shadow-medium)}.panel--story-vocab-test__controls h4{margin:0;color:var(--text-primary);font-size:var(--font-xl);font-weight:600;text-align:center;letter-spacing:.3px}.panel--story-vocab-test__controls .action-group--around{width:100%}.panel--story-vocab-test__item{display:flex;flex-direction:column;justify-content:center;background:var(--bg-panel);border:2px dashed var(--border-medium);border-radius:var(--radius-medium);min-height:6rem;padding:var(--spacing-sm);transition:var(--transition-normal);cursor:pointer;overflow:hidden;position:relative;z-index:1;-webkit-tap-highlight-color:transparent}.panel--story-vocab-test__item:focus,.panel--story-vocab-test__item:focus-visible,.panel--story-vocab-test__item:focus-within{background:var(--bg-panel)!important;outline-offset:-2px}.panel--story-vocab-test__item:active{background:var(--bg-panel)!important;transform:translateY(0)}.panel--story-vocab-test__item:hover{background-color:var(--bg-hover, var(--bg-secondary));transform:translateY(-1px)}.panel--story-vocab-test__item.selected,.panel--story-vocab-test__item.is-selected,.panel--story-vocab-test__item[aria-selected=true]{background:var(--bg-panel)!important}.panel--story-vocab-test__item ::selection{background:var(--color-primary);color:var(--text-on-primary)}.panel--story-vocab-test__item ::-moz-selection{background:var(--color-primary);color:var(--text-on-primary)}.panel--story-vocab-test__item.correct{border-color:var(--color-success);background:var(--color-success-light);border-style:solid}.panel--story-vocab-test__item.correct:hover{background-color:inherit;transform:none}.panel--story-vocab-test__item.correct .panel--story-vocab-test__word{color:var(--text-primary);font-weight:700;font-size:1.2em;text-shadow:0 1px 2px var(--black-10)}.panel--story-vocab-test__item.incorrect{border-color:var(--color-error);background:var(--color-error-light);border-style:solid}.panel--story-vocab-test__item.incorrect:hover{background-color:inherit;transform:none}.panel--story-vocab-test__item.incorrect .panel--story-vocab-test__word{color:var(--text-black);font-weight:700;font-size:1.2em;text-shadow:0 1px 2px var(--black-10)}.panel--story-vocab-test__item.incorrect .typewriter-text{color:var(--text-black)}.panel--story-vocab-test__word{font-weight:600;color:var(--text-primary);font-size:var(--font-xl);margin-right:var(--spacing-sm)}.panel--story-vocab-test__options{display:flex;align-self:flex-end;justify-self:flex-end;gap:var(--spacing-xs);flex-wrap:wrap;align-items:center;margin-top:.3rem}.panel--story-vocab-test__options-container{align-self:flex-end}.panel--story-vocab-test__option{position:relative;flex-shrink:1;padding:var(--spacing-sm)}.panel--story-vocab-test__option.long-text{font-size:var(--font-sm)}.panel--story-vocab-test__example{display:block;overflow:visible;text-overflow:ellipsis;white-space:nowrap;word-wrap:break-word;max-width:100%;width:100%;position:relative;margin:var(--spacing-sm) 0 0 .5rem;font-size:var(--font-base);line-height:1.3;font-weight:400;color:var(--text-primary);font-style:italic;z-index:1}.panel--story-vocab-test__example .typewriter-text{display:inline;overflow:visible;text-overflow:unset;white-space:normal;max-width:100%;width:100%;position:relative;z-index:1;word-wrap:break-word;color:var(--text-primary)}.panel--story-vocab-test__progress{padding:var(--spacing-md);border-top:1px solid var(--gray-200);display:flex;justify-content:space-between;align-items:center;font-weight:700}.focus-mode-popup .action-group{gap:var(--spacing-md)}.focus-mode-popup .modal-popup__content{overflow-y:auto;-webkit-mask-image:linear-gradient(to bottom,black 80%,transparent 100%);mask-image:linear-gradient(to bottom,black 80%,transparent 100%)}.btn.focus-translation-btn{background-color:transparent;border:0;font-size:var(--font-6xl);height:44px;width:44px;margin-top:-4px}.btn.focus-translation-btn:disabled{opacity:.1;cursor:not-allowed;filter:grayscale(.3)}.focus-story-text p{margin-bottom:var(--spacing-lg);color:var(--color-dark);font-size:1.2rem;text-align:left}.hyperfocus-modal__popup .action-group--spaced button{width:5rem}.hyperfocus-modal__popup .action-group--modal{width:100%;border-top:3px solid var(--border-dark);background:linear-gradient(135deg,var(--color-action) 0%,var(--color-action-hover) 100%);padding:var(--spacing-md)}.hyperfocus-modal__popup .action-group--inline{display:flex;gap:var(--spacing-lg)}.hyperfocus-modal__popup .action-group--inline button{font-size:var(--font-6xl);border:none}.hyperfocus-modal__popup .action-group--inline button:disabled{background-color:var(--gray-400);cursor:not-allowed}.hyperfocus-modal__popup .modal-popup__content{padding:0}.hyperfocus-word-display-area{display:flex;padding:var(--spacing-md);position:relative;min-height:12rem;width:95%;min-width:320px;max-width:550px;font-size:var(--font-6xl);font-weight:700;color:var(--text-primary);align-items:center;justify-content:center;border-radius:var(--radius-pill);padding:var(--spacing-lg);border:2px solid var(--color-action);animation:wordAppear .3s ease-in-out;transition:all .3s ease,font-size .2s ease;-webkit-user-select:none;user-select:none;line-height:1.2;margin-top:var(--spacing-md)}.current-word{word-wrap:break-word;overflow-wrap:break-word;hyphens:auto;-webkit-hyphens:auto;-ms-hyphens:auto}.current-word.hyphenated-word{flex-direction:column;line-height:1.1}.current-word.hyphenated-word .word-part{display:block;text-align:center}.current-word:active{transform:translateY(0)}.word-play-indicator{position:absolute;top:.5rem;right:1.5rem;box-shadow:none;pointer-events:auto}.hyperfocus-story-finished-restart-btn span{background-color:var(--content-primary);font-size:var(--font-xl);border:1px solid var(--border-dark);border-radius:6px}.hyperfocus-word-counter{text-align:center;margin-top:-.5rem;font-size:1rem;color:var(--gray-600);font-weight:500;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.hyperfocus-instructions{display:none;background:var(--gray-50);border:1px solid var(--gray-300);border-radius:4px;box-shadow:0 1px 3px var(--black-10);color:var(--gray-700);font-family:monospace;font-size:.8rem;font-weight:600;line-height:1;padding:var(--spacing-xs) .4rem;white-space:nowrap;margin:0 .2rem}.story-content.learning-mode{display:flex;flex-direction:column;text-align:center;gap:.5rem}.learning-mode-content-container{display:flex;flex-direction:column;gap:var(--spacing-md)}.learning-mode .flashcard-title{color:var(--color-dark);font-size:1.8rem;font-weight:600;text-align:center;margin-top:var(--spacing-lg);margin-bottom:var(--spacing-xl);padding-bottom:1.4rem;border-bottom:2px solid var(--gray-200)}.story-content .flashcard-panels-container{display:flex;justify-content:center}.flashcard-top-controls{display:flex;flex-direction:column;justify-content:center;align-content:center;align-items:stretch;gap:var(--spacing-xl);margin:var(--spacing-md) 0 .5rem;flex-wrap:wrap}.story-content.learning-mode .speed-buttons{display:flex;flex-direction:row}.story-content .auto-speed-controls{display:flex;flex-direction:row;border:none;background:var(--bg-lighter);border-radius:var(--radius-medium);padding:var(--spacing-sm);margin-bottom:0;border:1px solid var(--border-light)}.story-content .flashcard-display{margin-bottom:7rem}.flashcard-instructions p:last-child{display:none}.auto-mode-indicator span{display:none}.vocabulary-hidden{background:var(--gray-50);color:transparent;border:2px dashed var(--gray-300);border-radius:4px;padding:0;width:4rem;height:2rem;display:inline-block;cursor:pointer;position:relative;white-space:nowrap}.vocabulary-hidden:before{content:"___";color:var(--gray-500);position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-weight:400;letter-spacing:2px}.vocabulary-revealed{color:var(--color-success);font-weight:500;white-space:nowrap}.vocabulary-revealed-saved{background:var(--color-success-light);color:var(--color-success);border-color:var(--material-green)}.vocabulary-word-selected{border:2px solid #000;box-shadow:0 0 4px #0000004d}.vocabulary-hidden.vocabulary-word-selected{background-color:var(--color-success-light);border:2px dashed var(--color-success);box-shadow:0 0 4px #0000004d}.vocabulary-correct-answer{color:var(--color-success-active)}.vocabulary-incorrect-answer{color:var(--color-error)}.practice-mode-controls{margin-top:auto}.practice-mode-progress{display:flex;flex-direction:column;text-align:center;border-top:1px solid var(--border-dark);font-weight:600;margin:10rem 0 2rem;padding-top:1rem}.multiple-choice-header{display:flex;padding:var(--spacing-md);font-size:1.2rem;font-weight:600;color:var(--color-dark);text-align:center;border-bottom:1px solid var(--gray-200);background:var(--gray-50);border-radius:10px 10px 0 0}.multiple-choice-options{display:flex;flex-direction:column;padding:var(--spacing-sm);gap:6px}.multiple-choice-option.disabled,.multiple-choice-option.incorrect{background-color:var(--error-color-light, #fee2e2)!important;color:var(--error-color-dark, #dc2626)!important;border-color:var(--error-color, #ef4444)!important;cursor:not-allowed!important;opacity:.7!important;pointer-events:none}.multiple-choice-option.disabled:hover,.multiple-choice-option.incorrect:hover{transform:none!important;box-shadow:none!important;background-color:var(--error-color-light, #fee2e2)!important}.story-vocabulary-item{display:flex;flex-direction:column;align-items:center;gap:.3rem;width:100%;background-color:red}.story-content-container .tts-panel{padding:var(--spacing-xs) var(--spacing-md);margin-bottom:-1rem;border-bottom:none;border-bottom-left-radius:0;border-bottom-right-radius:0}.story-content-container .tts-panel .tts-main-controls{display:flex;flex-direction:row;justify-content:space-between}.story-content-container .tts-panel .tts-main-controls .btn-text{display:none}.story-content-container .tts-panel .tts-playback-controls{display:flex;flex-direction:row}.story-content-container .tts-panel .tts-playback-controls button{font-size:var(--font-6xl);min-height:44px;min-width:44px;background-color:transparent;border:none;gap:0}.story-content-container .tts-panel .voice-selector,.story-content-container .tts-panel .speed-selector-label{display:none}.story-content-container .tts-panel .speed-selector-buttons{display:flex;gap:.5rem;align-items:center}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.05);opacity:.8}}.audios-page .page-content{padding:0;display:flex;flex-direction:column;gap:var(--spacing-lg)}.audios-filters-panel{display:flex;flex-direction:column;gap:var(--spacing-md)}.filter-controls{display:flex;flex-direction:column;gap:var(--spacing-sm)}.search-input-wrapper{flex:1}.search-input{width:100%;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--border-primary);border-radius:var(--radius-sm);background:var(--surface-secondary);color:var(--text-primary);font-size:var(--font-base);font-family:inherit}.search-input::placeholder{color:var(--text-secondary)}.search-input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 2px var(--accent-primary-alpha)}.filter-select,.sort-select{padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--border-primary);border-radius:var(--radius-sm);background:var(--surface-secondary);color:var(--text-primary);font-size:var(--font-base);font-family:inherit;cursor:pointer}.filter-select:focus,.sort-select:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 2px var(--accent-primary-alpha)}.audios-stats{padding-top:var(--spacing-xs);border-top:1px solid var(--border-secondary)}.stats-text{color:var(--text-secondary);font-size:var(--font-sm)}.audios-list{min-height:200px}.audios-grid{display:flex;flex-direction:column;gap:var(--spacing-md)}.audios-loading,.audios-empty{display:flex;justify-content:center;align-items:center;min-height:200px;color:var(--text-secondary)}.audio-item{display:flex;flex-direction:column;padding:.1rem .25rem;background:var(--surface-primary);border:2px solid var(--border-dark);border-radius:var(--radius-medium);transition:all .2s ease;align-items:flex-start;width:100%}.audio-item:hover{border-color:var(--border-hover);box-shadow:0 2px 8px var(--shadow-light)}.audio-item--listened{border-color:var(--color-success);background:var(--color-success-light)}.audio-item--unlistened{border-color:var(--border-dark)}.audio-item.audio-item--playing{border-color:var(--border-gold);background:var(--bg-gold-light);box-shadow:0 0 0 2px var(--accent-primary-alpha)}.audio-item .audio-item__title-row .audio-item__title{color:var(--accent-primary-dark)}.audio-item.audio-item--paused:not(.audio-item--playing){border:1px solid var(--border-gold);background:var(--bg-gold-light);opacity:.8}.audio-item__lower-row{display:grid;grid-template-columns:1fr 1fr 1fr;align-items:center;width:100%;padding:0}.audio-item__controls{display:flex;flex-direction:row;gap:0;justify-self:start}.audio-item__controls .audio-control-btn{display:flex;align-items:flex-end;justify-content:center;border:2px solid var(--border-primary);border-radius:var(--radius-round);background:var(--surface-secondary);color:var(--text-primary);cursor:pointer;transition:all .2s ease;min-width:0;min-height:0;width:36px;height:36px}.audio-item__controls .audio-control-btn:hover:not(:disabled){border-color:var(--accent-primary);background:var(--accent-primary-alpha);transform:scale(1.05)}.audio-item__controls .audio-control-btn:active:not(:disabled){transform:scale(.95)}.audio-item__controls .audio-control-btn:disabled{opacity:.5;cursor:not-allowed;background:inherit}.audio-item__controls .audio-control-btn .control-icon{font-size:var(--font-5xl);align-self:flex-end}.audio-item__controls .audio-control-btn--play.playing{border-color:var(--accent-primary);background:var(--accent-primary);color:#fff}.audio-item__controls .audio-control-btn--play.paused{border-color:var(--warning-primary);background:var(--warning-primary-alpha)}.audio-item__controls .audio-control-btn--stop:not(:disabled){border-color:var(--error-primary)}.audio-item__controls .audio-control-btn--stop:not(:disabled):hover{background:var(--error-primary-alpha)}.audio-item__title{font-size:var(--font-lg);font-weight:600;color:var(--text-primary);margin:2px 0 0;line-height:1.3;align-self:stretch;-webkit-hyphens:auto;hyphens:auto;overflow-wrap:break-word;word-break:normal;min-width:0}.audio-item__badges{display:flex;flex-direction:row;gap:var(--spacing-xs);align-items:center;text-align:center;justify-self:center;margin-top:2px}.audio-item__badges .badge--level,.audio-item__badges .badge--category{padding:var(--spacing-sm)}.audio-item__secondary-controls{display:flex;flex-direction:row;gap:var(--spacing-xs);justify-self:end}.speed-controls{display:flex;flex-direction:row;align-items:center;gap:var(--spacing-sm)}.speed-label{font-size:var(--font-sm);font-weight:600;color:var(--text-secondary)}.speed-buttons{display:flex;gap:var(--spacing-xs);min-width:0}.speed-btn{padding:var(--spacing-xs) var(--spacing-sm);border:2px solid var(--border-dark-light);border-radius:var(--radius-medium);background:inherit;color:var(--text-primary);font-size:var(--font-sm);font-weight:700;cursor:pointer;transition:all .2s ease;min-width:0;min-height:0;width:38px;height:38px}.speed-btn.active{border-color:var(--border-dark-light);background:var(--color-action);color:var(--text-white)}.text-popup-btn{display:flex;gap:var(--spacing-sm);padding:0;border:1px solid var(--border-primary);border-radius:var(--radius-sm);background:var(--surface-secondary);color:var(--text-primary);cursor:pointer;transition:all .2s ease;margin-right:-6px}.text-popup-btn:hover{border-color:var(--accent-primary);background:var(--accent-primary-alpha)}.text-popup-btn .text-icon{font-size:2rem;margin-top:-4px}.text-popup-btn .text-label{font-size:var(--font-sm);font-weight:500}.story-text-modal-overlay{z-index:1000}.story-text-modal{max-width:90vw;max-height:90vh;width:100%;display:flex;flex-direction:column}.story-text-modal .modal-popup__header{flex-shrink:0;padding:var(--spacing-md);border-bottom:1px solid var(--border-secondary)}.story-text-modal .modal-title{display:flex;align-items:center;gap:var(--spacing-sm);margin:0;font-size:var(--font-xl);color:var(--text-primary)}.story-text-modal .modal-title .story-icon{font-size:var(--font-xl)}.story-text-modal .modal-popup__content{flex:1;overflow-y:auto;padding:var(--spacing-md);-webkit-mask-image:linear-gradient(to bottom,black 80%,transparent 100%);mask-image:linear-gradient(to bottom,black 80%,transparent 100%)}.story-text-modal .modal-popup__footer{flex-shrink:0;padding:var(--spacing-md);border-top:1px solid var(--border-secondary);background:var(--surface-secondary)}.story-text-loading,.story-text-error,.story-text-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl);text-align:center;color:var(--text-secondary)}.story-text-error{color:var(--error-primary);gap:var(--spacing-md)}.story-text-display{line-height:1.6}.story-text-display p{margin-bottom:var(--spacing-md)}.story-metadata{display:flex;flex-wrap:wrap;gap:var(--spacing-md);color:var(--text-secondary);font-size:var(--font-xs);justify-content:center}.story-metadata>span{display:flex;align-items:center;gap:var(--spacing-xs)}.audios-page .filter-controls{display:flex;flex-direction:column}.audios-page .filter-controls .filter-group{display:flex;flex-direction:row;gap:var(--spacing-md);justify-content:space-between}.audios-page .filter-controls .filter-group .form-label{display:flex;flex:1 1 auto;justify-content:space-between;align-items:center}.audios-page .filter-controls .filter-group .preference-checkbox{margin-left:auto;justify-content:flex-end;justify-self:flex-end;text-align:right;align-items:flex-end}.audios-page .form-group{display:flex;flex-direction:row;justify-content:space-between}.audios-page .custom-select-container{gap:.5rem}.audios-grid{display:grid;grid-template-columns:1fr;gap:var(--spacing-md);grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}.story-text-modal{max-width:min(800px,90vw)}.translation-toggle-icon{background-color:var(--bg-primary);border-radius:50%;border:1px solid white;margin-top:3px}.vocabulary-page-content{display:flex;flex-direction:column;gap:.5rem}.vocabulary-controls-panel .form-field--search{width:100%}.vocabulary-stats-action{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md);padding-bottom:.5rem;border-bottom:1px solid var(--border-medium)}.vocabulary-stats{display:flex;justify-content:space-between;align-items:center;color:var(--gray-600);font-weight:500;padding:0 0 0 .2rem}.word-count{font-size:var(--font-base)}.saved-indicator{color:var(--color-success);font-weight:600}.vocabulary-controls-right{display:flex;align-items:center;gap:.75rem}.bulk-action-btn{position:relative;display:flex;align-items:center;gap:.25rem;min-width:42px;height:36px;padding:.5rem;border-radius:8px;font-size:16px;transition:all .2s ease}.bulk-action-btn:hover{transform:translateY(-1px);box-shadow:0 4px 8px #00000026}.bulk-action-btn.btn--danger{background:var(--danger-red);color:#fff;border:1px solid var(--danger-red)}.bulk-action-btn.btn--danger:hover{background:var(--danger-dark);border-color:var(--danger-dark)}.bulk-action-btn.btn--primary{background:var(--primary-blue);color:#fff;border:1px solid var(--primary-blue)}.bulk-action-btn.btn--primary:hover{background:var(--primary-dark);border-color:var(--primary-dark)}.bulk-action-btn--inactive{background:var(--gray-300);color:var(--gray-600);border:1px solid var(--gray-300);opacity:.7;cursor:default}.bulk-action-btn--inactive:hover{transform:none;box-shadow:none;background:var(--gray-300);border-color:var(--gray-300)}.bulk-action-btn--inactive.btn--secondary{background:var(--gray-200);color:var(--gray-500);border:1px solid var(--gray-200)}.bulk-action-btn--inactive.btn--secondary:hover{background:var(--gray-200);border-color:var(--gray-200)}.view-mode-toggle{display:flex;align-items:center;gap:.25rem;background:var(--bg-lighter);border-radius:8px;padding:.25rem;border:1px solid var(--border-light)}.vocabulary-grid{display:grid;gap:1rem}.vocabulary-grid.single-column{grid-template-columns:1fr}.vocabulary-grid.grid-view{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.vocabulary-grid.line-view{display:flex;flex-direction:column;gap:.5rem}.vocabulary-grid.mobile-flex-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(6rem,1fr));grid-auto-rows:1fr;gap:.5rem;width:100%;justify-content:center;text-align:center;align-items:stretch}.vocabulary-grid .badge{font-size:1rem;height:2rem}.vocabulary-grid .badge--gender{position:absolute;top:0;left:10px}.vocabulary-grid .vocabulary-source{display:flex;justify-content:flex-end;width:100%}.vocabulary-grid .vocabulary-source .word-source{font-size:var(--font-md);color:var(--gray-500);font-style:italic}.mobile-touch-instruction{text-align:center;margin:0;padding:.25rem .5rem;display:flex;align-items:center;justify-content:center;background:var(--color-action-lighter);font-size:var(--font-sm);font-weight:700}.vocabulary-word-article{font-style:italic;color:var(--gray-600);margin-right:.5rem;font-size:var(--font-sm)}.mobile-vocab-panel{padding:var(--spacing-sm);cursor:pointer;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;-webkit-user-select:none;-khtml-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.mobile-vocab-panel .milestone-badge{padding:2px 6px;border-radius:10px;font-weight:700;font-size:.8rem;background:var(--color-primary-light);color:#fff;line-height:1;box-shadow:0 1px 2px #0003;pointer-events:none}.mobile-vocab-panel:hover{transform:translateY(-1px)}.mobile-vocab-panel:focus-visible{outline:2px solid var(--focus-ring);outline-offset:2px;transform:translateY(-1px)}.mobile-vocab-panel--selected{border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary-light);background:var(--color-primary-lighter, rgba(0, 123, 255, .05));transform:translateY(-2px)}.mobile-vocab-panel--selected:before{content:"✓";position:absolute;top:8px;right:8px;background:var(--color-primary);color:#fff;width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;z-index:10}.mobile-vocab-panel--disabled{opacity:.6;cursor:not-allowed;filter:grayscale(.3);pointer-events:none}.mobile-vocab-tooltip{position:absolute;top:-2.5rem;background:var(--black-90);border:1px solid var(--border-light);color:#fff;padding:.5rem .75rem;border-radius:var(--radius-small);font-size:var(--font-sm);white-space:normal;word-wrap:break-word;-webkit-hyphens:auto;hyphens:auto;z-index:10;max-width:90vw;min-width:120px;width:max-content;left:50%;transform:translate(-50%)}.mobile-vocab-tooltip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:5px solid transparent;border-top-color:var(--black-90)}.mobile-vocab-tooltip.tooltip-left{left:0;transform:translate(0)}.mobile-vocab-tooltip.tooltip-left:after{left:20px;transform:translate(0)}.mobile-vocab-tooltip.tooltip-right{right:0;left:auto;transform:translate(0)}.mobile-vocab-tooltip.tooltip-right:after{right:20px;left:auto;transform:translate(0)}.mobile-vocab-word{overflow-wrap:break-word;hyphens:auto;-webkit-hyphens:auto;-moz-hyphens:auto;-ms-hyphens:auto;hyphenate-limit-chars:6 4 3;word-break:normal;line-break:loose;font-size:var(--font-lg);font-weight:600;color:var(--text-primary);margin-bottom:.25rem}.mobile-vocab-word.long-word{font-size:var(--font-base);line-height:1.15;overflow-wrap:anywhere}.mobile-vocab-translation{overflow-wrap:break-word;hyphens:auto;-webkit-hyphens:auto;-moz-hyphens:auto;-ms-hyphens:auto;hyphenate-limit-chars:6 3 3;word-break:normal;line-break:loose;font-size:var(--font-base);color:var(--color-action);font-style:italic}.vocab-back-to-top{position:fixed;left:0;bottom:100px;z-index:1100;width:40px;height:40px;border-top-right-radius:6px;border-bottom-right-radius:6px;display:flex;justify-content:center;font-size:1.8rem;font-weight:700;background:var(--color-action);color:#fff;border:2px solid #fff;box-shadow:var(--shadow-heavy);cursor:pointer;transition:transform .15s ease,box-shadow .15s ease;opacity:.7}.vocab-back-to-top:active{transform:translateY(0);opacity:1}.vocab-back-to-top:focus-visible{outline:3px solid var(--color-primary);outline-offset:2px}.vocab-bulk-fab{position:fixed;left:0;bottom:160px;z-index:1100;width:40px;height:40px;border-radius:0 6px 6px 0;display:flex;justify-content:center;font-size:1.8rem;font-weight:700;box-shadow:var(--shadow-heavy);border:2px solid #fff;background:var(--color-action)}.vocabulary-toggle-btn{position:absolute;top:.5rem;right:.5rem;z-index:5;min-width:2.5rem;min-height:2.5rem;padding:.25rem;border-radius:50%;font-size:1rem;line-height:1;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-medium);border:2px solid white;transition:all .2s ease}.vocabulary-toggle-btn:hover{transform:scale(1.1);box-shadow:var(--shadow-heavy)}.vocabulary-toggle-btn.saved{background:var(--color-success);border-color:var(--color-success)}.vocabulary-toggle-btn.unsaved{background:var(--color-primary);border-color:var(--color-primary)}.study-hub-options-section{text-align:center}.study-hub-options-section h2{margin-bottom:var(--spacing-lg)}.study-hub-options-grid{display:flex;flex-direction:row;gap:var(--spacing-xxl);justify-content:center}.study-hub-option-card{display:flex;flex-direction:column;max-width:9rem;background:var(--color-action-active);border:5px solid var(--border-orange);padding:var(--spacing-lg) var(--spacing-sm);text-align:center;align-items:center;gap:var(--spacing-lg);text-decoration:none;color:var(--text-white);box-shadow:0 2px 8px #000;flex:1}.study-hub-option-icon{font-size:var(--font-6xl);width:50px;height:60px;display:flex;align-items:center;justify-content:center;padding-bottom:.5rem;background:var(--bg-primary);border-radius:16px;border:4px solid var(--border-orange)}.study-hub-option-card h3{color:var(--text-white);min-height:3rem}.study-hub-option-card p{color:var(--text-white);align-items:flex-start}.study-hub-recent-activity-section{margin:var(--spacing-xxl) 0;text-align:center}.study-hub-recent-activity-section h2{color:var(--text-primary);margin-bottom:var(--spacing-lg);font-size:1.5rem}.study-hub-recent-activity-placeholder{padding-bottom:var(--spacing-xl)}.study-hub-placeholder-icon{font-size:3rem;margin-bottom:var(--spacing-md);opacity:.5}.study-hub-recent-activity-placeholder h3{margin-bottom:var(--spacing-md)}.study-hub-stat-content{display:flex;flex-direction:column;align-items:center}.quiz-page{display:flex;flex-direction:column;gap:1rem}.study-flashcard{display:flex;flex-direction:column;gap:1rem;text-align:center}.study-flashcard .modes-grid{padding-bottom:var(--spacing-md);border-bottom:1px solid var(--border-dark)}.study-flashcard .form-deck-selector{margin:0;gap:0}.study-flashcard .custom-select{padding-bottom:1rem;border-bottom:1px solid var(--border-dark)}.quiz-page{display:grid;grid-template-columns:1fr;gap:1rem}.quiz-page .quiz-modes-container{display:flex;flex-direction:column;width:100%}.quiz-page .study-mode-selector{margin:0;border-bottom:none;border-radius:var(--radius-large) var(--radius-large) 0 0}.quiz-page .study-mode-selector:after{content:"";display:block;width:85%;margin:0 auto;border-bottom:3px solid var(--border-dark);position:absolute;bottom:0}.quiz-page .study-mode-selector .modes-container-btn{min-width:8rem;font-size:var(--font-lg)}.quiz-page .quiz-modes-container button{display:flex;flex-direction:column;align-items:center;gap:.5rem;border-radius:12px;font-size:var(--font-base)}.quiz-page .quiz-modes-container button .mode-icon{font-size:var(--font-3xl)}.quiz-page .quiz-modes-container button .mode-icon img{width:24px;height:24px;object-fit:contain}.quiz-page .game-mode-selector{position:relative;border-top:none;margin:0;border-radius:0 0 var(--radius-large) var(--radius-large)}.panel--study{display:flex;flex-direction:column;border:2px solid var(--border-dark);border-radius:16px;padding:0rem;width:100%;min-width:280px;max-width:650px;min-height:320px;margin:0 auto;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 6px var(--black-05);-webkit-user-select:none;user-select:none;overflow:hidden;position:relative;z-index:1;touch-action:none;-webkit-tap-highlight-color:transparent}.panel--study-quiz{position:relative}.panel--study-quiz__content{display:flex;flex-direction:column;height:100%;justify-content:space-between}.panel--study-quiz__question{flex:1;font-size:var(--font-lg);color:var(--content-primary);height:190px;border-bottom:3px solid var(--border-darker, var(--border-dark));display:flex;flex-direction:column;align-items:center;text-align:center;position:relative}.panel--study-quiz__question .question-display{display:flex;flex-direction:column;width:100%;height:100%;justify-content:center}.panel--study-quiz__question .question-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md);font-size:var(--font-sm);color:var(--gray-600)}.panel--study-quiz__question .question-example{font-style:italic;color:var(--text-secondary);font-size:var(--font-base);margin:var(--spacing-sm) auto;padding:.2rem .5rem;background:var(--bg-light, var(--gray-50));border-radius:8px;min-width:90%;border-left:3px solid var(--color-action);border-right:3px solid var(--color-action);flex-shrink:0}.panel--study-quiz__question .question-example strong{font-weight:700}.panel--study-quiz__question .question-text{display:flex;align-items:center;justify-content:center;text-align:center;font-size:var(--font-5xl);font-weight:700;color:var(--text-primary);margin:-1.5rem 0 0;flex-grow:1}.panel--study-quiz__question .no-words-message{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;text-align:center;padding:var(--spacing-md)}.panel--study-quiz__question .no-words-message h3{color:var(--bootstrap-danger);margin-bottom:var(--spacing-sm);font-size:var(--font-xl)}.panel--study-quiz__question .no-words-message p{color:var(--gray-600);font-size:var(--font-base);line-height:1.4;margin:0}.panel--study-quiz.false-true-mode .question-text{display:flex;flex-direction:column}.panel--study-quiz.false-true-mode .article-masculine{color:var(--masculine-blue)}.panel--study-quiz.false-true-mode .article-feminine{color:var(--feminine-red)}.panel--study-quiz.false-true-mode .article-neuter{color:var(--neuter-green)}.panel--study-quiz.false-true-mode .incorrect-answer{text-decoration:line-through;opacity:.6}.panel--study-quiz.false-true-mode .correct-answer-display{position:absolute;font-size:1.2rem;font-weight:700;text-decoration:none;left:50%;transform:translate(-50%)}.panel--study-quiz__answer{height:130px;align-items:center}.panel--study-quiz__answer .quiz-answer-container{display:flex;height:100%}.panel--study-quiz__answer .quiz-answer-container.grid-2x2{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr}.panel--study-quiz__answer .quiz-answer-btn{display:flex;position:relative;flex:1;align-items:center;justify-content:center;text-align:center;border:3px solid var(--border-strong);background:var(--bg-primary);font-size:var(--font-base);color:var(--text-dark-blue);font-weight:700;transition:background-color .3s ease,border-color .3s ease,color .3s ease,opacity .3s ease}.panel--study-quiz__answer .quiz-answer-btn.long-text{white-space:normal;text-overflow:ellipsis}.panel--study-quiz__answer .quiz-answer-btn.selected{color:var(--text-white);background:var(--color-action-light);border-color:var(--primary, var(--color-primary))}.panel--study-quiz__answer .quiz-answer-btn.correct{color:var(--text-white);background:var(--success, var(--color-success));border-color:var(--success, var(--color-success));opacity:1}.panel--study-quiz__answer .quiz-answer-btn.incorrect{color:var(--text-white);background:var(--danger, var(--color-error));border-color:var(--danger, var(--color-error));opacity:1}.panel--study-quiz__answer .quiz-answer-btn.disabled{opacity:.3;cursor:not-allowed}.panel--study-quiz__answer .quiz-answer-btn:disabled{cursor:not-allowed}.panel--study-quiz__answer .quiz-answer-btn .keyboard-shortcut{position:absolute;top:6px;left:10px;font-size:var(--font-xs);color:var(--text-muted, var(--gray-600));opacity:.7}.panel--study-quiz__answer .quiz-answer-btn .answer-text{display:flex;justify-content:center}.panel--study-quiz__answer .quiz-answer-btn.selected .keyboard-shortcut,.panel--study-quiz__answer .quiz-answer-btn.correct .keyboard-shortcut,.panel--study-quiz__answer .quiz-answer-btn.incorrect .keyboard-shortcut{color:var(--white-80)}.panel--study-quiz__answer .grid-2x2 .quiz-answer-btn-1{border-radius:0 0 30px;border-top:none;border-left:none}.panel--study-quiz__answer .grid-2x2 .quiz-answer-btn-2{border-radius:0 0 0 30px;border-top:none;border-right:none}.panel--study-quiz__answer .grid-2x2 .quiz-answer-btn-3{border-radius:0 30px 0 12px;border-bottom:none;border-left:none}.panel--study-quiz__answer .grid-2x2 .quiz-answer-btn-4{border-radius:30px 0 12px;border-bottom:none;border-right:none}.panel--study-quiz__answer .quiz-answer-container.row .quiz-answer-btn-1{border-radius:0 0 30px 12px;border-top:none;border-left:none}.panel--study-quiz__answer .quiz-answer-container.row .quiz-answer-btn-2{border-radius:0 0 30px 30px;border-top:none}.panel--study-quiz__answer .quiz-answer-container.row .quiz-answer-btn-3{border-radius:0 0 12px 30px;border-top:none;border-right:none}.game-status-display{display:flex;justify-content:center;height:5rem;position:relative;transition:var(--transition-fast)}.game-status-display:empty{display:none}.game-status-display.previous-answer-correct{animation:answerFeedbackCorrect 1s ease-in-out forwards}.game-status-display.previous-answer-incorrect{animation:answerFeedbackIncorrect 1s ease-in-out forwards}.game-status-display.lightning-mode .lives-display{position:absolute;display:flex;flex-direction:row;align-self:center;right:0;margin-right:.8rem}.game-status-display.critical-time{animation:urgentPulse .5s infinite alternate;background:linear-gradient(135deg,#ff9100,#fff700);border-color:var(--lightning-red);box-shadow:0 0 30px var(--red-light-alpha-60)}.timer-display{position:relative;display:flex;align-items:center;align-self:center;height:3.5rem;gap:1rem;background-color:var(--color-action);border:1px solid var(--border-dark);border-radius:8px;padding:var(--spacing-lg);box-shadow:var(--shadow-heavy)}.timer-display.lightning-timer{background:linear-gradient(135deg,#7f5fff,#ff3cac);border:2px solid var(--color-action-light);border-radius:50%;width:4rem;height:4rem;padding:0;overflow:visible;justify-content:center}.timer-display.lightning-timer .timer-text{background-color:transparent;border:none;color:var(--text-white);font-size:1.2rem;font-weight:900;text-shadow:0 0 10px var(--white-80);min-width:auto;padding:0}.timer-text{background-color:var(--bg-primary);font-weight:700;font-size:var(--font-3xl);border:1px solid var(--border-dark);min-width:50px;padding:.5rem}.lightning-heart{animation:lightningPulse 1.2s ease-in-out infinite;-webkit-user-select:none;user-select:none;pointer-events:none}.lightning-bolt{position:absolute;font-size:1.5rem;color:var(--lightning-yellow);text-shadow:0 0 10px var(--lightning-yellow);animation:lightningBolt 2s infinite;pointer-events:none}.lightning-bolt.lightning-bolt-1{top:-10px;right:-10px;animation-delay:0s}.lightning-bolt.lightning-bolt-2{bottom:-10px;left:-10px;animation-delay:.3s}.lightning-ring{position:absolute;inset:-5px;border:2px solid transparent;border-radius:50%;background:linear-gradient(45deg,transparent,var(--lightning-yellow),transparent,var(--lightning-yellow));background-size:400% 400%;animation:lightningRing 3s linear infinite}.lightning-flash{position:absolute;inset:0;background:linear-gradient(45deg,transparent,var(--yellow-alpha-30),transparent);animation:lightningFlash .5s ease-in-out}.auto-skip-message{position:absolute;top:50%;left:50%;width:12rem;transform:translate(-50%,-50%);background:red;color:var(--text-white);padding:.5rem;border-radius:20px;font-size:1.5rem;font-weight:700;text-shadow:0 0 5px var(--lightning-yellow);animation:skipMessage .5s ease-in-out;text-align:center}.lightning-skip-effect{position:absolute;inset:0;pointer-events:none;z-index:10}.lives-display{display:flex;gap:.5rem;align-items:center}.life-heart{font-size:1.5rem;transition:opacity .3s ease}.life-heart.active{opacity:1}.life-heart.lost{font-size:2.3rem;opacity:.6;padding:0 .2rem}.protection-display{margin-top:3px}.protection-display .survival-protection-btn{font-size:var(--font-5xl);transition:opacity .3s ease;background-color:var(--bg-primary);border:none}.protection-display .survival-protection-btn.active{opacity:1}.protection-display .survival-protection-btn.inactive{opacity:.3}.protection-display .survival-protection-btn.earning{opacity:1;animation:protection-blink 1.2s infinite ease-in-out}.game-over-message h3{font-size:var(--font-4xl);color:var(--color-error);text-align:center}.scoreboard{display:flex;justify-content:space-around}.score-item{display:flex;flex-direction:column;align-items:center;flex:1;box-shadow:0 1px 3px var(--bg-medium)}.score-label{font-size:.8rem;font-weight:600;color:var(--gray-600);margin-bottom:.3rem;text-transform:uppercase;letter-spacing:.5px}.score-value{font-size:1.8rem;font-weight:700;line-height:1;margin-bottom:.5rem}.current-score-item{margin-top:.5rem;position:relative}.current-score-item:before,.current-score-item:after{content:"";position:absolute;top:50%;width:1px;height:60%;background:var(--border-dark);transform:translateY(-50%)}.current-score-item:before{left:-.5rem}.current-score-item:after{right:-.5rem}.season-best{color:var(--color-success)}.current-score{color:var(--color-action-hover);font-size:2.2rem}.all-time-best{color:var(--color-warning);position:relative}.all-time-best:after{content:"👑";position:absolute;top:-.3rem;right:-1rem;font-size:.9rem}.all-time-date{font-size:var(--font-xs);color:var(--color-text-secondary);margin-top:.2rem;font-weight:400}.new-best{animation:newBestGlow 2s ease-in-out;position:relative}.new-best-indicator{font-size:1rem;margin-left:.5rem;animation:newBestBounce 1s ease-in-out infinite alternate}.scoreboard .deck-info{position:absolute;bottom:-1.5rem;left:50%;transform:translate(-50%);width:100%}.deck-name{font-size:var(--font-xs);color:var(--color-text-secondary);text-align:center;padding:.2rem .5rem;background:var(--bg-light);border-radius:var(--border-radius-sm);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.deck-name .deck-icon{margin-right:.35rem}.deck-info--quiz{position:static;transform:none;margin-bottom:-1rem;width:100%;text-align:center}@keyframes newBestGlow{0%,to{text-shadow:none}50%{text-shadow:0 0 10px var(--color-success),0 0 20px var(--color-success)}}@keyframes lightningBolt{0%,to{opacity:1;filter:brightness(1);transform:scale(1) rotate(-5deg)}10%{opacity:.7;filter:brightness(1.5);transform:scale(1.4) rotate(0)}20%{opacity:1;filter:brightness(1.2);transform:scale(1) rotate(5deg)}30%{opacity:.8;filter:brightness(1.4);transform:scale(1.15) rotate(-5deg)}40%{opacity:1;filter:brightness(1);transform:scale(1) rotate(0)}}@keyframes newBestBounce{0%{transform:translateY(0)}to{transform:translateY(-3px)}}.toast-container{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:1000;display:flex;flex-direction:column;gap:.75rem;pointer-events:none;align-items:center}.toast-notification{background:var(--bg-panel);border:2px solid var(--border-medium);border-radius:var(--border-radius);padding:1rem 1.25rem;box-shadow:0 8px 32px #00000026;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);max-width:350px;min-width:280px;position:relative;overflow:hidden;pointer-events:auto;cursor:pointer;animation:toastSlideIn .4s cubic-bezier(.34,1.56,.64,1)}.toast-notification:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--toast-color, var(--color-success));animation:toastProgress var(--toast-duration, 4s) linear}.toast-notification.toast-daily-best{--toast-color: var(--color-success);border-color:var(--color-success)}.toast-notification.toast-all-time-best{--toast-color: var(--color-warning);border-color:var(--color-warning)}.toast-notification.toast-all-time-best:after{content:"✨";position:absolute;top:-5px;right:-5px;font-size:1.5rem;animation:toastSparkle 2s ease-in-out infinite}.toast-notification.toast-streak-milestone{--toast-color: var(--color-action);border-color:var(--color-action)}.toast-notification:hover{transform:translateY(-2px);box-shadow:0 12px 40px #0003;transition:transform .2s ease,box-shadow .2s ease}.toast-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem}.toast-icon{font-size:1.5rem;line-height:1;animation:toastIconPulse 1.5s ease-in-out infinite}.toast-title{font-size:1rem;font-weight:600;color:var(--toast-color, var(--color-success));margin:0;line-height:1.2}.toast-message{font-size:.875rem;color:var(--color-text);margin:0;line-height:1.4}.toast-score{font-weight:600;color:var(--toast-color, var(--color-success))}.toast-close{position:absolute;top:.5rem;right:.5rem;background:none;border:none;font-size:1.25rem;color:var(--color-text-secondary);cursor:pointer;padding:.25rem;border-radius:50%;line-height:1;opacity:.7}.toast-close:hover{opacity:1;background:var(--bg-hover)}@keyframes toastSlideIn{0%{transform:translate(100%) scale(.9);opacity:0}to{transform:translate(0) scale(1);opacity:1}}@keyframes toastProgress{0%{width:100%}to{width:0%}}@keyframes toastIconPulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}@keyframes toastSparkle{0%,to{transform:rotate(0) scale(1);opacity:.8}25%{transform:rotate(90deg) scale(1.2);opacity:1}50%{transform:rotate(180deg) scale(1);opacity:.9}75%{transform:rotate(270deg) scale(1.1);opacity:1}}@media (max-width: 768px){.toast-container{top:50%;left:50%;transform:translate(-50%,-50%);width:calc(100% - 2rem);max-width:400px}.toast-notification{max-width:none;min-width:auto;width:100%}}@keyframes answerFeedbackCorrect{0%{border-color:var(--border-medium);background-color:var(--bg-panel)}25%{border-color:var(--color-success);background-color:var(--color-success-light);box-shadow:0 0 15px var(--color-success)}to{border-color:var(--border-medium);background-color:var(--bg-panel);box-shadow:none}}@keyframes answerFeedbackIncorrect{0%{border-color:var(--border-medium);background-color:var(--bg-panel)}25%{border-color:var(--color-error);background-color:var(--color-error-light);box-shadow:0 0 15px var(--color-error)}to{border-color:var(--border-medium);background-color:var(--bg-panel);box-shadow:none}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes toastFadeIn{0%{opacity:0;transform:translate(-50%,-50%) scale(.8)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}@keyframes fadeOutCheck{0%{opacity:1;transform:scale(1.1)}to{opacity:0;transform:scale(1)}}@keyframes slideInBottom{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInTop{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@media (min-width: 481px) and (max-width: 1279px){.app-body{flex-direction:row;width:100%;max-width:1024px;margin:var(--spacing-xs) auto 0}}@media (min-width: 1280px){.app-body{flex-direction:row;width:768px;max-width:768px;margin:var(--spacing-xs) auto 0}}@media (min-width: 481px){.page{border:1px solid var(--border-dark);border-top:none;max-width:100%}}@media (min-width: 481px){.modal-popup{max-height:98vh;max-width:750px;overflow:visible;margin:auto 0}}@media (min-width: 481px){.modal-popup__header{border-radius:8px 8px 0 0}}@media (min-width: 1280px){.modal-popup .modal-popup__content{overflow-x:visible;overflow-y:auto;padding:1.5rem;border-radius:12px}}@media (min-width: 1280px){.tooltip-overlay .tooltip-content{max-width:600px}}@media (min-width: 1280px){.preference-select{width:9cap;min-width:9rem;text-align:left;padding:0 .5rem}}@media (min-width: 1280px){.header .header-section--right{align-items:center;margin-bottom:6px}}@media (min-width: 481px) and (max-width: 1279px){.header .user-section{gap:1rem}}@media (min-width: 481px) and (max-width: 1279px){.header .user-section .header-theme-toggle{display:flex;justify-content:center}}@media (min-width: 1280px){.header{height:100%;gap:0}}@media (min-width: 1280px){.page-content.home-page-content{gap:var(--spacing-xxl)}}.theme-toggle:focus{background-color:none}@media (min-width: 481px){.theme-toggle--floating{display:none}}@media (min-width: 481px){.modes-container-btn{max-height:80px;padding:var(--spacing-xs)}}@media (min-width: 481px){.story-card-container{width:100%}}@media (min-width: 481px){.stories-grid{display:grid;grid-template-columns:repeat(2,1fr);align-items:stretch}}@media (min-width: 1280px){.content-filters .clear-filters-btn{margin-left:0}}@media (min-width: 1280px){.btn--toggle{margin-top:auto}}@media (min-width: 1280px){.panel--story .stats{margin-top:auto}}@media (min-width: 1280px){.section-header__toolbar{width:102%}}@media (min-width: 1280px){.panel--vocabulary__header{min-height:0}}@media (min-width: 1280px){.panel--vocabulary--collapsed .panel--vocabulary__content{max-height:5.5rem}}@media (min-width: 481px){.panel--vocabulary__list{padding:var(--spacing-sm) var(--spacing-xl)}}@media (min-width: 481px){.panel--vocabulary__help{justify-self:center;width:94%;margin-bottom:var(--spacing-md);background-color:var(--color-action-active)}}@media (min-width: 481px){.panel--story-vocab-test__items{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-md)}}@media (min-width: 481px){.panel--story-vocab-test__controls .action-group--around{width:20rem}}.modal-popup.hyperfocus-modal__popup{overflow-x:hidden}@media (min-width: 1280px){.modal-popup.hyperfocus-modal__popup .modal-popup__content{padding:0}}@media (min-width: 1280px){.modal-popup.hyperfocus-modal__popup .hyperfocus-word-display-area{max-width:100%;min-width:min(420px,90vw);max-width:550px}}@media (min-width: 1280px){.modal-popup.lesson-mode-modal__popup{max-width:768px;height:99%;align-self:center}}@media (min-width: 481px){.modal-popup h3{margin-bottom:2rem}}@media (min-width: 481px) and (max-width: 1279px){.modal-popup .focus-reading-content{padding:0 var(--spacing-md)}}.modal-popup .vocabulary-step__preview-section{flex:0}@media (min-width: 481px){.modal-popup .vocabulary-step__preview-section .vocabulary-preview{margin-top:2rem;gap:3rem}}@media (min-width: 1280px){.modal-popup .vocabulary-step__preview-section .vocabulary-preview .progress-bar{width:50%;align-self:center}}@media (min-width: 481px){.modal-popup .vocabulary-step__preview-section .vocabulary-preview__navigation{justify-content:center;gap:var(--spacing-xxl)}}@media (min-width: 481px){.vocabulary-question__options{justify-self:center;max-width:25rem}}@media (min-width: 1280px){.flashcard-controls-section{align-self:center;width:70%}}@media (min-width: 481px){.flashcard-controls-section .auto-speed-controls .speed-buttons{justify-content:center;gap:2rem}}@media (min-width: 481px){.multiple-choice-popup.practice-mode{top:50%;left:50%;min-width:30rem;max-width:100%;transform:translate(-50%,-50%)}}@media (min-width: 481px){.multiple-choice-popup.practice-mode .multiple-choice-header{justify-content:space-between}}@media (min-width: 481px){.multiple-choice-popup.practice-mode .multiple-choice-header .btn-modal-close{margin-left:var(--spacing-md)}}@media (min-width: 481px){.study-hub-options-grid{gap:8rem}}@media (min-width: 481px) and (max-width: 1279px){.flashcard-panels-container{gap:5rem}}@media (min-width: 481px){.panel--study{height:25rem}}@media (min-width: 481px){.flashcard-main-text{font-size:var(--font-6xl)}}@media (min-width: 481px){.flashcard-translation-text{font-size:var(--font-6xl)}}@media (min-width: 481px){.flashcard-example{font-size:clamp(var(--font-xl),2.2vw,var(--font-3xl));white-space:normal;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;line-clamp:2;max-width:100%;padding:0 .25rem;word-break:normal;overflow-wrap:anywhere}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.sr-only-focusable:focus{position:static;width:auto;height:auto;padding:inherit;margin:inherit;overflow:visible;clip:auto;white-space:normal}@media (prefers-contrast: high){.vocabulary-question__option--correct{background-color:green;color:#fff;border-color:green}.vocabulary-question__option--incorrect{background-color:#c00;color:#fff;border-color:#c00}.vocabulary-question__option--correct-answer{background-color:#004d00;color:#fff;border-color:#004d00}}@media (prefers-reduced-motion: reduce){.vocabulary-progress__fill{transition:none}.typewriter-text{animation:none}.vocabulary-question__option{transition:none}}[aria-live]{position:relative}[role=toolbar]{display:flex;gap:.5rem;align-items:center}.btn[aria-pressed=true]{background-color:var(--color-action);color:#fff}.btn[aria-expanded=true]{background-color:var(--bg-surface)}.skip-link{position:absolute;top:-40px;left:6px;background:var(--primary-color, #007acc);color:#fff;padding:8px;text-decoration:none;border-radius:0 0 4px 4px;z-index:1000}.skip-link:focus{top:0}.panel:focus,.panel:focus-within,.card:focus,.card:focus-within,.bucket:focus,.bucket:focus-within,.panel--vocabulary:focus,.panel--vocabulary:focus-within{background:var(--bg-panel);outline:none}.selected,.is-selected,[aria-selected=true]{background:var(--bg-panel)}.panel ::selection,.card ::selection,.panel--vocabulary ::selection{background:var(--color-primary);color:var(--text-on-primary)}.panel ::-moz-selection,.card ::-moz-selection,.panel--vocabulary ::-moz-selection{background:var(--color-primary);color:var(--text-on-primary)}input,textarea,select,[contenteditable]{background:var(--bg-primary)}input:focus,textarea:focus,select:focus,[contenteditable]:focus{background:var(--bg-primary)}input:-webkit-autofill,textarea:-webkit-autofill,select:-webkit-autofill{-webkit-box-shadow:0 0 0 1000px var(--bg-primary) inset;-webkit-text-fill-color:var(--text-primary)}.skeleton-block{display:inline-block;background:var(--color-neutral-100, #f2f2f2);border-radius:8px;min-width:24px;min-height:24px;animation:skeleton-shimmer 1.1s ease-in-out infinite}.skeleton-line{display:block;height:14px;border-radius:6px;background:var(--color-neutral-100, #f2f2f2);animation:skeleton-shimmer 1.1s ease-in-out infinite}.skeleton-title{display:block;height:28px;max-width:220px;border-radius:8px;background:var(--color-neutral-100, #f2f2f2);animation:skeleton-shimmer 1.1s ease-in-out infinite}.skeleton-pill{display:inline-block;height:40px;width:96px;border-radius:999px;background:var(--color-neutral-100, #f2f2f2);animation:skeleton-shimmer 1.1s ease-in-out infinite}.skeleton-panel{width:100%;min-height:140px;border-radius:12px;background:var(--color-neutral-100, #f5f5f5);animation:skeleton-shimmer 1.1s ease-in-out infinite}.skeleton-nav-item{height:38px;margin:8px 10px;border-radius:8px;background:var(--color-neutral-90, #eee);animation:skeleton-shimmer 1.1s ease-in-out infinite}@keyframes skeleton-shimmer{0%{opacity:.7}50%{opacity:1}to{opacity:.7}}.text-bold{font-weight:600}.text-semibold{font-weight:500}.text-normal{font-weight:400}.srs-stats-display{background:var(--color-background-card);border-radius:.5rem;padding:1rem;margin:1rem 0}.srs-stats-display--loading{opacity:.6;pointer-events:none}.srs-stats-display--loading .srs-stat-item__value{background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0,#f0f0f0 75%);background-size:200% 100%;animation:loading 1.5s infinite;border-radius:4px;color:transparent}.srs-stats-main,.srs-stats-section{margin-bottom:1.5rem}.srs-stats-section:last-child{margin-bottom:0}.srs-stats-section__title{font-size:1rem;font-weight:600;color:var(--color-text-primary);margin-bottom:.75rem;border-bottom:1px solid var(--color-border);padding-bottom:.5rem}.srs-progress-bar{position:relative;height:8px;background:var(--color-background-secondary);border-radius:4px;margin-bottom:1rem;overflow:hidden}.srs-progress-bar__fill{height:100%;background:linear-gradient(90deg,#10b981,#059669);border-radius:4px;transition:width .3s ease;animation:fillProgress .5s ease-out}.srs-progress-bar__text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:.75rem;font-weight:600;color:var(--color-text-primary);text-shadow:0 1px 2px rgba(0,0,0,.1)}.srs-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(80px,1fr));gap:.75rem}.srs-stats-grid--ratings{grid-template-columns:repeat(4,1fr)}@media (max-width: 640px){.srs-stats-grid--ratings{grid-template-columns:repeat(2,1fr)}}@media (max-width: 640px){.srs-stats-grid{grid-template-columns:repeat(2,1fr)}}.srs-stat-item{text-align:center;padding:.75rem .5rem;background:var(--color-background-secondary);border-radius:.375rem;border:1px solid var(--color-border)}.srs-stat-item__value{font-size:1.25rem;font-weight:700;color:var(--color-text-primary);margin-bottom:.25rem;transition:all .2s ease}.srs-stat-item__label{font-size:.75rem;color:var(--color-text-secondary);text-transform:uppercase;font-weight:500;letter-spacing:.05em}.srs-stat-item--streak{background:linear-gradient(135deg,#fef3c7,#fde68a);border-color:#f59e0b}.srs-controls-section{margin-top:1rem}.srs-session-info{position:absolute;bottom:-24px;left:50%;transform:translate(-50%)}@media (max-width: 640px){.srs-session-info{flex-direction:column;gap:1rem;align-items:stretch}}.srs-card-info{display:flex}@media (max-width: 640px){.srs-card-info{justify-content:center}}.srs-difficulty{font-size:.8rem;color:var(--color-text-secondary);font-style:italic}.srs-session-controls{display:flex;gap:.5rem;align-items:center}@media (max-width: 640px){.srs-session-controls{justify-content:center}}.srs-session-complete h2{margin-bottom:.5rem;color:var(--color-text-primary)}.srs-session-complete p{margin-bottom:1.5rem;color:var(--color-text-secondary)}.srs-session-complete__actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}@media (max-width: 640px){.srs-session-complete__actions{flex-direction:column}}.srs-session-complete__description{margin-top:1rem;text-align:left}.srs-backlog-notice{background:#f0f9ff;border:1px solid #bfdbfe;border-radius:.5rem;padding:1rem;margin-bottom:1rem;color:#1e40af}@media (prefers-color-scheme: dark){.srs-backlog-notice{background:#1e3a8a;border-color:#3b82f6;color:#93c5fd}}.error-message,.loading-message{padding:1rem;border-radius:.5rem;margin-bottom:1rem}.error-message{background:#fef2f2;border:1px solid #fecaca;color:#dc2626}@media (prefers-color-scheme: dark){.error-message{background:#451a1a;border-color:#991b1b;color:#f87171}}.loading-message{background:#f0f9ff;border:1px solid #bfdbfe;color:#2563eb}@media (prefers-color-scheme: dark){.loading-message{background:#1e3a8a;border-color:#3b82f6;color:#93c5fd}}@keyframes fillProgress{0%{width:0}}@keyframes loading{0%{background-position:200% 0}to{background-position:-200% 0}}.driver-active .driver-overlay,.driver-active *{pointer-events:none}.driver-active .driver-active-element,.driver-active .driver-active-element *,.driver-popover,.driver-popover *{pointer-events:auto}@keyframes animate-fade-in{0%{opacity:0}to{opacity:1}}.driver-fade .driver-overlay{animation:animate-fade-in .2s ease-in-out}.driver-fade .driver-popover{animation:animate-fade-in .2s}.driver-popover{all:unset;box-sizing:border-box;color:#2d2d2d;margin:0;padding:15px;border-radius:5px;min-width:250px;max-width:300px;box-shadow:0 1px 10px #0006;z-index:1000000000;position:fixed;top:0;right:0;background-color:#fff}.driver-popover *{font-family:Helvetica Neue,Inter,ui-sans-serif,"Apple Color Emoji",Helvetica,Arial,sans-serif}.driver-popover-title{font:19px/normal sans-serif;font-weight:700;display:block;position:relative;line-height:1.5;zoom:1;margin:0}.driver-popover-close-btn{all:unset;position:absolute;top:0;right:0;width:32px;height:28px;cursor:pointer;font-size:18px;font-weight:500;color:#d2d2d2;z-index:1;text-align:center;transition:color;transition-duration:.2s}.driver-popover-close-btn:hover,.driver-popover-close-btn:focus{color:#2d2d2d}.driver-popover-title[style*=block]+.driver-popover-description{margin-top:5px}.driver-popover-description{margin-bottom:0;font:14px/normal sans-serif;line-height:1.5;font-weight:400;zoom:1}.driver-popover-footer{margin-top:15px;text-align:right;zoom:1;display:flex;align-items:center;justify-content:space-between}.driver-popover-progress-text{font-size:13px;font-weight:400;color:#727272;zoom:1}.driver-popover-footer button{all:unset;display:inline-block;box-sizing:border-box;padding:3px 7px;text-decoration:none;text-shadow:1px 1px 0 #fff;background-color:#fff;color:#2d2d2d;font:12px/normal sans-serif;cursor:pointer;outline:0;zoom:1;line-height:1.3;border:1px solid #ccc;border-radius:3px}.driver-popover-footer .driver-popover-btn-disabled{opacity:.5;pointer-events:none}:not(body):has(>.driver-active-element){overflow:hidden!important}.driver-no-interaction,.driver-no-interaction *{pointer-events:none!important}.driver-popover-footer button:hover,.driver-popover-footer button:focus{background-color:#f7f7f7}.driver-popover-navigation-btns{display:flex;flex-grow:1;justify-content:flex-end}.driver-popover-navigation-btns button+button{margin-left:4px}.driver-popover-arrow{content:"";position:absolute;border:5px solid #fff}.driver-popover-arrow-side-over{display:none}.driver-popover-arrow-side-left{left:100%;border-right-color:transparent;border-bottom-color:transparent;border-top-color:transparent}.driver-popover-arrow-side-right{right:100%;border-left-color:transparent;border-bottom-color:transparent;border-top-color:transparent}.driver-popover-arrow-side-top{top:100%;border-right-color:transparent;border-bottom-color:transparent;border-left-color:transparent}.driver-popover-arrow-side-bottom{bottom:100%;border-left-color:transparent;border-top-color:transparent;border-right-color:transparent}.driver-popover-arrow-side-center{display:none}.driver-popover-arrow-side-left.driver-popover-arrow-align-start,.driver-popover-arrow-side-right.driver-popover-arrow-align-start{top:15px}.driver-popover-arrow-side-top.driver-popover-arrow-align-start,.driver-popover-arrow-side-bottom.driver-popover-arrow-align-start{left:15px}.driver-popover-arrow-align-end.driver-popover-arrow-side-left,.driver-popover-arrow-align-end.driver-popover-arrow-side-right{bottom:15px}.driver-popover-arrow-side-top.driver-popover-arrow-align-end,.driver-popover-arrow-side-bottom.driver-popover-arrow-align-end{right:15px}.driver-popover-arrow-side-left.driver-popover-arrow-align-center,.driver-popover-arrow-side-right.driver-popover-arrow-align-center{top:50%;margin-top:-5px}.driver-popover-arrow-side-top.driver-popover-arrow-align-center,.driver-popover-arrow-side-bottom.driver-popover-arrow-align-center{left:50%;margin-left:-5px}.driver-popover-arrow-none{display:none}
