#root{min-height:100vh;display:flex;flex-direction:column}.header{position:sticky;top:0;z-index:var(--z-sticky);background-color:var(--bg-primary);border-bottom:2px solid var(--border-color);padding:var(--spacing-sm) var(--spacing-md)}.header-content{display:flex;align-items:center;justify-content:space-between;max-width:800px;margin:0 auto}.header-logo{display:flex;align-items:center;gap:var(--spacing-sm);font-weight:700;font-size:var(--font-size-lg);color:var(--primary)}.logo-icon{font-size:24px}.logo-text{display:none}@media(min-width:768px){.logo-text{display:inline}}.header-stats{display:flex;align-items:center;gap:var(--spacing-md)}.stat{display:flex;align-items:center;gap:var(--spacing-xs);font-weight:600;font-size:var(--font-size-sm)}.stat-icon{font-size:18px}.stat-value{color:var(--text-primary)}.stat.streak .stat-value{color:#ff9600}.stat.xp .stat-value{color:var(--warning)}.stat.hearts .stat-value{color:var(--incorrect)}.user-menu{position:relative}.user-avatar{width:36px;height:36px;border-radius:50%;overflow:hidden;display:flex;align-items:center;justify-content:center;background-color:var(--primary);color:var(--white);font-weight:700;font-size:var(--font-size-sm);transition:transform var(--transition-fast);cursor:pointer;border:none;padding:0}.user-avatar:hover{transform:scale(1.1)}.avatar-img{width:100%;height:100%;object-fit:cover}.avatar-placeholder{text-transform:uppercase}.user-dropdown{position:absolute;top:calc(100% + 8px);right:0;background-color:var(--bg-primary);border:2px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);min-width:220px;z-index:var(--z-dropdown);overflow:hidden}.dropdown-header{padding:var(--spacing-md);background-color:var(--bg-secondary)}.dropdown-name{display:block;font-weight:700;color:var(--text-primary);font-size:var(--font-size-md)}.dropdown-email{display:block;font-size:var(--font-size-sm);color:var(--text-secondary);margin-top:2px}.dropdown-divider{height:1px;background-color:var(--border-color)}.dropdown-item{display:flex;align-items:center;gap:var(--spacing-sm);width:100%;padding:var(--spacing-md);font-size:var(--font-size-md);color:var(--text-primary);background:none;border:none;cursor:pointer;text-align:left;transition:background-color var(--transition-fast)}.dropdown-item:hover{background-color:var(--bg-secondary)}.dropdown-item.logout{color:var(--incorrect)}.dropdown-item.logout:hover{background-color:#ffeef0}.dropdown-icon{font-size:18px}@media(min-width:768px){.header{padding:var(--spacing-md) var(--spacing-lg)}.stat{font-size:var(--font-size-md)}.stat-icon{font-size:20px}.user-avatar{width:40px;height:40px}}@media(min-width:1024px){.header{padding-left:calc(220px + var(--spacing-lg))}.header-content{max-width:1000px}.logo-text{font-size:var(--font-size-xl)}.header-stats{gap:var(--spacing-lg)}.stat{font-size:var(--font-size-lg)}.stat-icon{font-size:24px}.user-avatar{width:44px;height:44px}}.bottom-nav{position:fixed;bottom:0;left:0;right:0;z-index:var(--z-sticky);display:flex;align-items:center;justify-content:space-around;background-color:var(--bg-primary);border-top:2px solid var(--border-color);padding:var(--spacing-sm) var(--spacing-md);padding-bottom:calc(var(--spacing-sm) + env(safe-area-inset-bottom,0px))}.nav-item{display:flex;flex-direction:column;align-items:center;gap:2px;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-md);transition:all var(--transition-fast);color:var(--text-secondary);min-width:60px;min-height:44px;justify-content:center}.nav-item:hover{background-color:var(--gray-100)}.nav-item:active{transform:scale(.95)}.nav-item.active{color:var(--primary)}.nav-item.active .nav-icon{transform:scale(1.1)}.nav-icon{font-size:24px;transition:transform var(--transition-fast)}.nav-label{font-size:var(--font-size-xs);font-weight:600}@media(min-width:768px){.bottom-nav{padding:var(--spacing-md) var(--spacing-lg);justify-content:center;gap:var(--spacing-lg)}.nav-item{flex-direction:row;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg);min-width:auto}.nav-label{font-size:var(--font-size-sm)}}@media(min-width:1024px){.bottom-nav{position:fixed;inset:0 auto 0 0;width:220px;flex-direction:column;justify-content:flex-start;align-items:stretch;padding:var(--spacing-xl) var(--spacing-md);padding-top:80px;border-top:none;border-right:2px solid var(--border-color);gap:var(--spacing-xs)}.nav-item{flex-direction:row;justify-content:flex-start;padding:var(--spacing-md) var(--spacing-lg);border-radius:var(--radius-lg)}.nav-icon{font-size:28px}.nav-label{font-size:var(--font-size-md);font-weight:700}.nav-item.active{background-color:var(--gray-50)}}.unit-card{background-color:var(--bg-primary);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-md);transition:all var(--transition-normal)}.unit-card.locked{opacity:.6}.unit-card.locked .unit-header{cursor:not-allowed}.unit-header{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);cursor:pointer;transition:background-color var(--transition-fast);border-left:4px solid var(--unit-color, var(--primary))}.unit-card.unlocked .unit-header:hover{background-color:var(--gray-50)}.unit-icon-wrapper{position:relative;width:50px;height:50px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--unit-color, var(--primary)),color-mix(in srgb,var(--unit-color, var(--primary)) 70%,black));border-radius:var(--radius-md)}.unit-icon{font-size:28px}.lock-icon{position:absolute;bottom:-4px;right:-4px;font-size:16px;background-color:var(--bg-primary);border-radius:50%;padding:2px}.unit-card.premium-locked{opacity:.85}.unit-card.premium-locked .unit-header{cursor:pointer}.unit-card.premium-locked .unit-header:hover{background-color:#fff8e6}.pro-badge{position:absolute;bottom:-4px;right:-4px;font-size:10px;font-weight:700;background:linear-gradient(135deg,#ffc800,#ff9600);color:var(--white);padding:2px 6px;border-radius:var(--radius-full);border:2px solid var(--bg-primary)}.upgrade-cta{font-size:var(--font-size-sm);font-weight:700;color:#ff9600;white-space:nowrap}.unit-info{flex:1;min-width:0}.unit-name{font-size:var(--font-size-lg);font-weight:700;color:var(--text-primary);margin-bottom:2px}.unit-description{font-size:var(--font-size-sm);color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.unit-progress{flex-shrink:0}.progress-ring{position:relative;width:40px;height:40px}.progress-ring svg{width:100%;height:100%;transform:rotate(-90deg)}.progress-ring-bg{fill:none;stroke:var(--gray-100);stroke-width:3}.progress-ring-fill{fill:none;stroke:var(--unit-color, var(--primary));stroke-width:3;stroke-linecap:round;transition:stroke-dasharray var(--transition-slow)}.progress-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:var(--font-size-xs);font-weight:600;color:var(--text-primary)}.expand-icon{font-size:var(--font-size-sm);color:var(--text-secondary);transition:transform var(--transition-fast)}.expand-icon.expanded{transform:rotate(180deg)}.unit-lessons{border-top:1px solid var(--border-color);padding:var(--spacing-sm);animation:slideDown var(--transition-normal) ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.lesson-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);border-radius:var(--radius-md);transition:background-color var(--transition-fast)}.lesson-item.unlocked:hover{background-color:var(--gray-50)}.lesson-item.locked{opacity:.5;cursor:not-allowed}.lesson-number{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background-color:var(--gray-100);border-radius:50%;font-weight:700;font-size:var(--font-size-sm);color:var(--text-secondary)}.lesson-item.completed .lesson-number{background-color:var(--primary);color:var(--white)}.lesson-info{flex:1;min-width:0}.lesson-name{font-weight:600;color:var(--text-primary)}.lesson-lock-hint{margin-top:4px;font-size:12px;color:var(--text-secondary)}.lesson-crowns{display:flex;gap:2px;margin-top:4px}.crown{font-size:12px;opacity:.3}.crown.filled{opacity:1}.lesson-lock,.lesson-arrow,.lesson-check{font-size:var(--font-size-lg)}.lesson-check{color:var(--primary);font-weight:700}@media(min-width:768px){.unit-header{padding:var(--spacing-lg)}.unit-icon-wrapper{width:60px;height:60px}.unit-icon{font-size:32px}.unit-name{font-size:var(--font-size-xl)}.progress-ring{width:50px;height:50px}}.lesson-meta{display:flex;flex-direction:column;gap:4px;margin-top:4px}.lesson-score{display:flex;align-items:center;gap:8px}.score-bar{width:60px;height:6px;background-color:var(--gray-100);border-radius:var(--radius-full);overflow:hidden}.score-fill{height:100%;border-radius:var(--radius-full);transition:width var(--transition-normal);background:linear-gradient(90deg,var(--primary),color-mix(in srgb,var(--primary) 70%,black))}.score-text{font-size:11px;font-weight:600;color:var(--text-secondary);min-width:32px}.lesson-mastery-hint{display:flex;align-items:center}.mastery-pill{font-size:10px;font-weight:700;padding:2px 6px;border-radius:var(--radius-full);color:var(--white);opacity:.95}.mastery-pill.mastered{background:#58cc02}.mastery-pill.learning{background:#ff9600}.mastery-pill.weak{background:#ff4b4b}.mastery-pill.not-started{background:var(--gray-300);color:var(--text-primary)}.lesson-item.needs-review{background-color:#ffc8001a;border:1px dashed #ffc800}.lesson-item.needs-review .lesson-number{background-color:#ffc800;color:var(--white);animation:pulse 2s infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.review-badge{font-size:18px;animation:spin 3s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.lesson-item.mastery-mastered .lesson-number{background-color:#58cc02;color:var(--white)}.lesson-item.mastery-learning .lesson-number{background-color:#ffc800;color:var(--white)}.lesson-item.mastery-weak .lesson-number{background-color:#ff4b4b;color:var(--white)}.home-page{min-height:100vh;display:flex;flex-direction:column;background-color:var(--bg-secondary)}.home-main{flex:1;padding:var(--spacing-md);padding-bottom:100px;max-width:600px;margin:0 auto;width:100%}.skill-tree{display:flex;flex-direction:column;gap:var(--spacing-md)}.welcome-message{text-align:center;padding:var(--spacing-lg);margin-top:var(--spacing-md);background-color:var(--bg-primary);border-radius:var(--radius-lg);animation:fadeIn var(--transition-slow) ease}.welcome-message h2{font-size:var(--font-size-lg);color:var(--primary);margin-bottom:var(--spacing-sm)}.welcome-message p{color:var(--text-secondary);margin-bottom:var(--spacing-md);font-size:var(--font-size-sm)}.welcome-arrow{font-size:32px;color:var(--primary);animation:bounce 1s ease infinite}@media(min-width:768px){.home-main{padding:var(--spacing-xl);padding-bottom:100px}.skill-tree{gap:var(--spacing-lg)}.welcome-message{padding:var(--spacing-xl)}.welcome-message h2{font-size:var(--font-size-xl)}.welcome-message p{font-size:var(--font-size-md)}}@media(min-width:1024px){.home-page{padding-left:220px}.home-main{padding-bottom:var(--spacing-xl);max-width:700px}}.exercise{flex:1;display:flex;flex-direction:column;gap:var(--spacing-lg)}.exercise-prompt{text-align:center}.prompt-label{font-size:var(--font-size-sm);color:var(--text-secondary);margin-bottom:var(--spacing-sm);text-transform:uppercase;letter-spacing:.5px}.prompt-text{font-size:var(--font-size-xl);font-weight:700;color:var(--text-primary);display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);flex-wrap:wrap}.speak-button{padding:var(--spacing-sm);font-size:24px;background-color:var(--secondary);border-radius:50%;transition:all var(--transition-fast);line-height:1}.speak-button:hover{background-color:var(--secondary-dark);transform:scale(1.1)}.speak-button.small{padding:var(--spacing-xs);font-size:16px}.options-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-md)}.option-button{padding:var(--spacing-md);background-color:var(--bg-primary);border:2px solid var(--border-color);border-radius:var(--radius-md);font-size:var(--font-size-md);font-weight:600;color:var(--text-primary);transition:all var(--transition-fast);text-align:center;min-height:60px;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-button)}.option-button:hover:not(:disabled){border-color:var(--primary);background-color:var(--gray-50)}.option-button.selected{border-color:var(--secondary);background-color:#ddf4ff;box-shadow:0 4px 0 var(--secondary)}.option-button.correct{border-color:var(--correct);background-color:#d7ffb8;box-shadow:0 4px 0 var(--correct)}.option-button.incorrect{border-color:var(--incorrect);background-color:#ffdfe0;box-shadow:0 4px 0 var(--incorrect)}.option-button:disabled{cursor:not-allowed}.options-row{display:flex;justify-content:center;gap:var(--spacing-md);flex-wrap:wrap}.option-chip{padding:var(--spacing-sm) var(--spacing-lg);background-color:var(--bg-primary);border:2px solid var(--border-color);border-radius:var(--radius-full);font-size:var(--font-size-md);font-weight:600;color:var(--text-primary);transition:all var(--transition-fast);box-shadow:var(--shadow-button)}.option-chip:hover:not(:disabled){border-color:var(--primary)}.option-chip.selected{border-color:var(--secondary);background-color:#ddf4ff}.option-chip.correct{border-color:var(--correct);background-color:#d7ffb8}.option-chip.incorrect{border-color:var(--incorrect);background-color:#ffdfe0}.check-button{margin-top:auto;padding:var(--spacing-md) var(--spacing-xl);background-color:var(--primary);color:var(--white);font-size:var(--font-size-lg);font-weight:700;border-radius:var(--radius-lg);text-transform:uppercase;letter-spacing:1px;box-shadow:0 4px 0 var(--primary-dark);transition:all var(--transition-fast)}.check-button:hover:not(:disabled){background-color:var(--primary-light)}.check-button:active:not(:disabled){transform:translateY(2px);box-shadow:0 2px 0 var(--primary-dark)}.check-button:disabled{background-color:var(--gray-200);box-shadow:0 4px 0 var(--gray-300);cursor:not-allowed}.input-container{display:flex;flex-direction:column;gap:var(--spacing-md)}.answer-input{width:100%;padding:var(--spacing-md);font-size:var(--font-size-lg);border:2px solid var(--border-color);border-radius:var(--radius-md);background-color:var(--bg-primary);color:var(--text-primary);text-align:center;transition:all var(--transition-fast)}.answer-input:focus{outline:none;border-color:var(--secondary)}.answer-input.correct{border-color:var(--correct);background-color:#d7ffb8}.answer-input.incorrect{border-color:var(--incorrect);background-color:#ffdfe0}.correct-answer{text-align:center;color:var(--incorrect);font-weight:600}.correct-answer strong{color:var(--text-primary)}.fill-sentence{display:inline}.blank{display:inline-block;min-width:80px;padding:var(--spacing-xs) var(--spacing-sm);background-color:var(--gray-100);border-radius:var(--radius-sm);margin:0 var(--spacing-xs);font-weight:600}.blank.filled{background-color:#ddf4ff;color:var(--secondary-dark)}.blank.correct{background-color:#d7ffb8;color:var(--primary-dark)}.blank.incorrect{background-color:#ffdfe0;color:#ea2b2b}.translation-hint{font-size:var(--font-size-md);color:var(--text-secondary);font-style:italic}.pairs-container{display:flex;gap:var(--spacing-md);justify-content:center;width:100%;max-width:500px;margin:0 auto}.pairs-column{display:flex;flex-direction:column;gap:var(--spacing-sm);flex:1;min-width:0}.pairs-column.left .pair-item{background-color:var(--bg-primary)}.pairs-column.right .pair-item{background-color:#f8f9fa}.pair-item{padding:var(--spacing-sm) var(--spacing-md);min-height:52px;background-color:var(--bg-primary);border:2px solid var(--border-color);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:600;color:var(--text-primary);transition:all var(--transition-fast);box-shadow:0 2px 0 var(--gray-200);word-break:break-word;display:flex;align-items:center;justify-content:center;text-align:center}.pair-item:hover:not(:disabled):not(.matched){border-color:var(--secondary);transform:translateY(-1px);box-shadow:0 3px 0 var(--gray-200)}.pair-item.selected{border-color:var(--secondary);background-color:#ddf4ff;transform:scale(1.02);box-shadow:0 2px 0 var(--secondary)}.pair-item.matched{border-color:var(--correct);background-color:#d7ffb8;opacity:.8;box-shadow:0 2px 0 var(--correct)}.pair-item.wrong{border-color:var(--incorrect);background-color:#ffdfe0;animation:shake .3s ease}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.match-progress{display:flex;justify-content:center;gap:var(--spacing-sm);margin-top:var(--spacing-md)}.progress-dot{width:12px;height:12px;border-radius:50%;background-color:var(--gray-200);transition:background-color var(--transition-fast)}.progress-dot.filled{background-color:var(--primary)}.answer-area{min-height:80px;padding:var(--spacing-md);background-color:var(--gray-50);border:2px dashed var(--border-color);border-radius:var(--radius-md);display:flex;flex-wrap:wrap;gap:var(--spacing-sm);align-items:center;justify-content:center}.answer-area.correct{border-color:var(--correct);background-color:#d7ffb8}.answer-area.incorrect{border-color:var(--incorrect);background-color:#ffdfe0}.placeholder{color:var(--text-secondary);font-style:italic}.words-bank{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);justify-content:center;padding:var(--spacing-md)}.word-chip{padding:var(--spacing-sm) var(--spacing-md);background-color:var(--bg-primary);border:2px solid var(--border-color);border-radius:var(--radius-md);font-size:var(--font-size-md);font-weight:600;color:var(--text-primary);transition:all var(--transition-fast);box-shadow:var(--shadow-button)}.word-chip:hover:not(:disabled){border-color:var(--secondary);transform:translateY(-2px)}.word-chip.selected{background-color:#ddf4ff;border-color:var(--secondary)}.audio-controls{display:flex;justify-content:center;gap:var(--spacing-lg);margin:var(--spacing-lg) 0}.audio-button{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-lg);background-color:var(--secondary);border-radius:var(--radius-lg);color:var(--white);transition:all var(--transition-fast);box-shadow:0 4px 0 var(--secondary-dark)}.audio-button:hover{background-color:var(--secondary-dark)}.audio-button.main{min-width:100px}.audio-button.slow{background-color:var(--gray-400);box-shadow:0 4px 0 var(--gray-500)}.audio-button.slow:hover{background-color:var(--gray-500)}.audio-icon{font-size:32px}.audio-label{font-size:var(--font-size-sm);font-weight:600}@media(max-width:374px){.prompt-text{font-size:var(--font-size-lg)}.option-button{padding:var(--spacing-sm);min-height:50px;font-size:var(--font-size-sm)}.pair-item{padding:var(--spacing-xs) var(--spacing-sm);font-size:var(--font-size-xs);min-height:40px}.audio-button{padding:var(--spacing-md)}.audio-icon{font-size:24px}.check-button{padding:var(--spacing-sm) var(--spacing-lg);font-size:var(--font-size-md)}}@media(min-width:768px){.exercise{gap:var(--spacing-xl)}.prompt-text{font-size:var(--font-size-2xl)}.options-grid{grid-template-columns:repeat(2,1fr);max-width:500px;margin:0 auto;gap:var(--spacing-lg)}.option-button{padding:var(--spacing-lg);font-size:var(--font-size-lg);min-height:80px}.pairs-container{gap:var(--spacing-xl);max-width:700px}.pairs-column{gap:var(--spacing-sm)}.pair-item{padding:var(--spacing-md) var(--spacing-lg);font-size:var(--font-size-md);min-height:60px;box-shadow:0 3px 0 var(--gray-200)}.pair-item.selected{box-shadow:0 3px 0 var(--secondary)}.pair-item.matched{box-shadow:0 3px 0 var(--correct)}.answer-input{font-size:var(--font-size-xl);max-width:500px;margin:0 auto;padding:var(--spacing-lg)}.check-button{max-width:400px;margin-left:auto;margin-right:auto}.audio-controls{gap:var(--spacing-xl)}.audio-button{padding:var(--spacing-xl);min-width:120px}.audio-icon{font-size:40px}}@media(min-width:1024px){.exercise{max-width:100%;margin:0 auto;gap:var(--spacing-2xl)}.exercise-prompt{padding:var(--spacing-lg) 0}.prompt-label{font-size:var(--font-size-md);margin-bottom:var(--spacing-md)}.prompt-text{font-size:36px;gap:var(--spacing-md)}.speak-button{padding:var(--spacing-md);font-size:28px}.options-grid{grid-template-columns:repeat(2,1fr);max-width:600px;gap:var(--spacing-xl)}.option-button{padding:var(--spacing-xl);font-size:var(--font-size-xl);min-height:100px;border-radius:var(--radius-lg);box-shadow:0 6px 0 var(--gray-200)}.option-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 0 var(--gray-200)}.option-button.selected{box-shadow:0 6px 0 var(--secondary)}.option-button.correct{box-shadow:0 6px 0 var(--correct)}.option-button.incorrect{box-shadow:0 6px 0 var(--incorrect)}.options-row{gap:var(--spacing-lg)}.option-chip{padding:var(--spacing-md) var(--spacing-xl);font-size:var(--font-size-lg)}.check-button{max-width:500px;padding:var(--spacing-lg) var(--spacing-2xl);font-size:var(--font-size-xl);border-radius:var(--radius-xl);box-shadow:0 6px 0 var(--primary-dark)}.check-button:active:not(:disabled){transform:translateY(3px);box-shadow:0 3px 0 var(--primary-dark)}.answer-input{max-width:600px;padding:var(--spacing-xl);font-size:var(--font-size-xl);border-radius:var(--radius-lg)}.fill-sentence{font-size:var(--font-size-xl);line-height:2}.blank{min-width:120px;padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-lg)}.translation-hint{font-size:var(--font-size-lg);margin-top:var(--spacing-md)}.pairs-container{max-width:900px;width:100%;gap:60px;padding:0 var(--spacing-xl)}.pairs-column{gap:var(--spacing-lg);flex:1;max-width:400px}.pair-item{padding:var(--spacing-xl) var(--spacing-2xl);min-height:80px;min-width:200px;font-size:var(--font-size-xl);border-radius:var(--radius-lg);box-shadow:0 4px 0 var(--gray-200)}.pair-item:hover:not(:disabled):not(.matched){transform:translateY(-2px);box-shadow:0 6px 0 var(--gray-200)}.pair-item.selected{box-shadow:0 4px 0 var(--secondary)}.pair-item.matched{box-shadow:0 4px 0 var(--correct)}.match-progress{margin-top:var(--spacing-xl);gap:var(--spacing-md)}.progress-dot{width:16px;height:16px}.answer-area{min-height:100px;padding:var(--spacing-xl);border-radius:var(--radius-lg)}.words-bank{padding:var(--spacing-xl);gap:var(--spacing-md)}.word-chip{padding:var(--spacing-md) var(--spacing-lg);font-size:var(--font-size-lg);border-radius:var(--radius-lg)}.audio-controls{gap:var(--spacing-2xl);margin:var(--spacing-xl) 0}.audio-button{padding:var(--spacing-2xl);min-width:160px;border-radius:var(--radius-xl);box-shadow:0 6px 0 var(--secondary-dark)}.audio-button.slow{box-shadow:0 6px 0 var(--gray-500)}.audio-icon{font-size:48px}.audio-label{font-size:var(--font-size-md)}}.exercise-container{flex:1;display:flex;flex-direction:column;animation:fadeIn var(--transition-normal) ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.exercise-container.correct{animation:correctPulse var(--transition-normal) ease}.exercise-container.incorrect{animation:incorrectShake var(--transition-normal) ease}@keyframes correctPulse{0%,to{transform:scale(1)}50%{transform:scale(1.02)}}@keyframes incorrectShake{0%,to{transform:translate(0)}20%,60%{transform:translate(-5px)}40%,80%{transform:translate(5px)}}.exercise-error{text-align:center;padding:var(--spacing-xl);color:var(--text-secondary)}.lesson-complete{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--spacing-lg);background:linear-gradient(135deg,#d7ffb8,#58cc02)}.completion-content{background-color:var(--bg-primary);border-radius:var(--radius-xl);padding:var(--spacing-xl);max-width:400px;width:100%;text-align:center;box-shadow:var(--shadow-lg);animation:popIn var(--transition-normal) ease}@keyframes popIn{0%{opacity:0;transform:scale(.8)}50%{transform:scale(1.05)}to{opacity:1;transform:scale(1)}}.celebration-icon{font-size:64px;margin-bottom:var(--spacing-md);animation:bounce 1s ease infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.completion-title{font-size:var(--font-size-2xl);font-weight:700;color:var(--primary);margin-bottom:var(--spacing-sm)}.completion-subtitle{font-size:var(--font-size-md);color:var(--text-secondary);margin-bottom:var(--spacing-xl)}.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-md);margin-bottom:var(--spacing-xl)}.stat-card{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-md);background-color:var(--gray-50);border-radius:var(--radius-md)}.stat-card .stat-icon{font-size:24px}.stat-card .stat-value{font-size:var(--font-size-lg);font-weight:700;color:var(--text-primary)}.perfect-badge{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-md);background:linear-gradient(135deg,#ffc800,#ff9600);border-radius:var(--radius-md);color:var(--white);font-weight:600;margin-bottom:var(--spacing-xl);animation:glow 2s ease infinite}@keyframes glow{0%,to{box-shadow:0 0 10px #ffc80080}50%{box-shadow:0 0 20px #ffc800cc}}.badge-icon{font-size:24px}.continue-button{width:100%;padding:var(--spacing-md) var(--spacing-xl);background-color:var(--primary);color:var(--white);font-size:var(--font-size-lg);font-weight:700;border-radius:var(--radius-lg);text-transform:uppercase;letter-spacing:1px;box-shadow:0 4px 0 var(--primary-dark);transition:all var(--transition-fast)}.continue-button:hover{background-color:var(--primary-light)}.continue-button:active{transform:translateY(2px);box-shadow:0 2px 0 var(--primary-dark)}@media(min-width:768px){.completion-content{padding:var(--spacing-2xl)}.celebration-icon{font-size:80px}}@media(min-width:1024px){.lesson-complete{padding:var(--spacing-2xl)}.completion-content{max-width:500px;padding:var(--spacing-2xl) var(--spacing-2xl) var(--spacing-xl);border-radius:var(--radius-xl)}.celebration-icon{font-size:96px;margin-bottom:var(--spacing-lg)}.completion-title{font-size:40px;margin-bottom:var(--spacing-md)}.completion-subtitle{font-size:var(--font-size-lg);margin-bottom:var(--spacing-2xl)}.stats-grid{gap:var(--spacing-lg);margin-bottom:var(--spacing-2xl)}.stat-card{padding:var(--spacing-lg);border-radius:var(--radius-lg)}.stat-card .stat-icon{font-size:32px}.stat-card .stat-value{font-size:var(--font-size-xl)}.stat-card .stat-label{font-size:var(--font-size-sm)}.perfect-badge{padding:var(--spacing-lg);font-size:var(--font-size-lg);border-radius:var(--radius-lg);margin-bottom:var(--spacing-2xl)}.badge-icon{font-size:28px}.continue-button{padding:var(--spacing-lg) var(--spacing-2xl);font-size:var(--font-size-xl);border-radius:var(--radius-xl);box-shadow:0 6px 0 var(--primary-dark)}.continue-button:active{transform:translateY(3px);box-shadow:0 3px 0 var(--primary-dark)}}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;padding:var(--spacing-lg);z-index:var(--z-modal);animation:fadeIn var(--transition-fast) ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background-color:var(--bg-primary);border-radius:var(--radius-xl);padding:var(--spacing-xl);max-width:400px;width:100%;text-align:center;box-shadow:var(--shadow-lg);animation:slideUp var(--transition-normal) ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-icon{font-size:64px;margin-bottom:var(--spacing-md)}.modal-title{font-size:var(--font-size-xl);font-weight:700;color:var(--text-primary);margin-bottom:var(--spacing-sm)}.modal-text{color:var(--text-secondary);margin-bottom:var(--spacing-lg);line-height:1.6}.modal-info{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-md);background-color:var(--gray-50);border-radius:var(--radius-md);margin-bottom:var(--spacing-lg)}.info-icon{font-size:20px}.info-text{font-size:var(--font-size-sm);color:var(--text-secondary)}.modal-actions{display:flex;flex-direction:column;gap:var(--spacing-md)}.modal-button{width:100%;padding:var(--spacing-md) var(--spacing-xl);font-size:var(--font-size-md);font-weight:700;border-radius:var(--radius-lg);transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm)}.modal-button.primary{background-color:var(--incorrect);color:var(--white);box-shadow:0 4px #c33}.modal-button.primary:hover{background-color:#f66}.modal-button.secondary{background-color:var(--gray-100);color:var(--text-primary);box-shadow:0 4px 0 var(--gray-200)}.modal-button.danger{background-color:var(--incorrect);color:var(--white);box-shadow:0 4px #c33}.modal-button.danger:hover{background-color:#f66}.button-icon{font-size:20px}.lesson-page{min-height:100vh;display:flex;flex-direction:column;background-color:var(--bg-primary)}.lesson-page-inner{flex:1;display:flex;flex-direction:column}.lesson-header{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);border-bottom:2px solid var(--border-color)}.exit-button{width:40px;height:40px;display:flex;align-items:center;justify-content:center;font-size:var(--font-size-xl);color:var(--text-secondary);border-radius:50%;transition:all var(--transition-fast)}.exit-button:hover{background-color:var(--gray-100);color:var(--text-primary)}.progress-bar-container{flex:1;height:16px;background-color:var(--gray-100);border-radius:var(--radius-full);overflow:hidden}.progress-bar{height:100%;background:linear-gradient(90deg,var(--primary),var(--primary-light));border-radius:var(--radius-full);transition:width var(--transition-normal)}.hearts-display{display:flex;align-items:center;gap:var(--spacing-xs);font-weight:600;color:var(--incorrect)}.lesson-main{flex:1;display:flex;flex-direction:column;padding:var(--spacing-md);max-width:600px;margin:0 auto;width:100%}.lesson-error{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-lg);text-align:center}.lesson-error h2{font-size:var(--font-size-xl);color:var(--text-primary)}.lesson-error button{padding:var(--spacing-md) var(--spacing-xl);background-color:var(--primary);color:var(--white);font-weight:700;border-radius:var(--radius-md);transition:background-color var(--transition-fast)}.lesson-error button:hover{background-color:var(--primary-dark)}.feedback-banner{position:fixed;bottom:0;left:0;right:0;display:flex;align-items:center;justify-content:center;gap:var(--spacing-md);padding:var(--spacing-lg);font-size:var(--font-size-lg);font-weight:700;animation:slideUp var(--transition-fast) ease}.feedback-banner.correct{background-color:#d7ffb8;color:var(--primary-dark)}.feedback-icon{font-size:var(--font-size-xl)}@media(max-width:374px){.lesson-header{padding:var(--spacing-sm);gap:var(--spacing-sm)}.exit-button{width:36px;height:36px;font-size:var(--font-size-lg)}.progress-bar-container{height:12px}.hearts-display{font-size:var(--font-size-sm)}.heart-icon{font-size:16px}}@media(min-width:768px){.lesson-header{padding:var(--spacing-lg) var(--spacing-xl)}.lesson-main{padding:var(--spacing-xl)}.progress-bar-container{height:20px}}@media(min-width:1024px){.lesson-page{max-width:1200px;margin:0 auto;padding:var(--spacing-lg);min-height:100vh;background-color:var(--bg-secondary)}.lesson-page-inner{position:relative;background-color:var(--bg-primary);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);min-height:calc(100vh - var(--spacing-lg) * 2);display:flex;flex-direction:column;overflow:hidden}.lesson-header{padding:var(--spacing-xl) var(--spacing-2xl);border-radius:var(--radius-xl) var(--radius-xl) 0 0}.exit-button{width:48px;height:48px;font-size:var(--font-size-xl)}.progress-bar-container{height:24px;max-width:700px;margin:0 auto}.hearts-display{font-size:var(--font-size-lg)}.heart-icon{font-size:24px}.lesson-main{max-width:100%;min-width:1000px;padding:var(--spacing-2xl) 64px}.feedback-banner{position:absolute;left:0;right:0;transform:none;max-width:none;width:100%;border-radius:0;font-size:var(--font-size-xl);padding:var(--spacing-xl)}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.feedback-icon{font-size:var(--font-size-2xl)}}.practice-page{min-height:100vh;display:flex;flex-direction:column;background-color:var(--bg-secondary)}.practice-header{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background-color:var(--bg-primary);border-bottom:1px solid var(--border-color)}.practice-info{display:flex;align-items:center;justify-content:center;gap:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);background-color:var(--bg-primary);border-bottom:1px solid var(--border-color)}.practice-badge{background:linear-gradient(135deg,#ffc800,#ff9600);color:#fff;font-size:var(--font-size-xs);font-weight:700;padding:4px 12px;border-radius:var(--radius-full);text-transform:uppercase}.practice-count{font-size:var(--font-size-sm);color:var(--text-secondary)}.exit-button{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background-color:var(--gray-100);border:none;border-radius:50%;font-size:var(--font-size-lg);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.exit-button:hover{background-color:var(--gray-200)}.progress-bar-container{flex:1;height:12px;background-color:var(--gray-100);border-radius:var(--radius-full);overflow:hidden}.progress-bar{height:100%;background:linear-gradient(90deg,#ffc800,#ff9600);border-radius:var(--radius-full);transition:width var(--transition-normal)}.hearts-display{display:flex;align-items:center;gap:4px}.heart-icon{font-size:20px}.heart-count{font-weight:700;color:#ff4b4b}.practice-main{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-lg)}.no-practice{text-align:center;max-width:400px;padding:var(--spacing-xl)}.no-practice-icon{font-size:64px;margin-bottom:var(--spacing-md)}.no-practice h2{font-size:var(--font-size-2xl);color:var(--text-primary);margin-bottom:var(--spacing-md)}.no-practice p{color:var(--text-secondary);margin-bottom:var(--spacing-md)}.no-practice-hint{font-size:var(--font-size-sm);color:var(--text-tertiary)}.primary-button{background:linear-gradient(135deg,var(--primary),#46a302);color:#fff;border:none;padding:var(--spacing-md) var(--spacing-xl);border-radius:var(--radius-full);font-size:var(--font-size-md);font-weight:700;cursor:pointer;transition:all var(--transition-fast);margin-top:var(--spacing-lg)}.primary-button:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.secondary-button{background-color:var(--gray-100);color:var(--text-primary);border:none;padding:var(--spacing-md) var(--spacing-xl);border-radius:var(--radius-full);font-size:var(--font-size-md);font-weight:700;cursor:pointer;transition:all var(--transition-fast)}.secondary-button:hover{background-color:var(--gray-200)}.practice-complete{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl);text-align:center}.complete-icon{font-size:80px;margin-bottom:var(--spacing-lg);animation:bounce .6s ease}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}.practice-complete h1{font-size:var(--font-size-3xl);color:var(--text-primary);margin-bottom:var(--spacing-xl)}.practice-stats{display:flex;gap:var(--spacing-xl);margin-bottom:var(--spacing-xl)}.stat{display:flex;flex-direction:column;align-items:center}.stat-value{font-size:var(--font-size-3xl);font-weight:700;color:var(--primary)}.complete-message{font-size:var(--font-size-lg);color:var(--text-secondary);margin-bottom:var(--spacing-xl);max-width:400px}.complete-actions{display:flex;gap:var(--spacing-md)}.feedback-banner{position:fixed;bottom:0;left:0;right:0;display:flex;align-items:center;justify-content:center;gap:var(--spacing-md);padding:var(--spacing-lg);animation:slideUp var(--transition-fast) ease}.feedback-banner.correct{background-color:#d7ffb8;color:#58a700}.feedback-banner.incorrect{background-color:#ffdfe0;color:#ea2b2b}.feedback-icon{font-size:var(--font-size-2xl);font-weight:700}.feedback-text{font-size:var(--font-size-lg);font-weight:700}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@media(min-width:768px){.practice-main{padding:var(--spacing-xl)}.practice-stats{gap:var(--spacing-3xl)}.stat-value{font-size:var(--font-size-4xl)}}.profile-page{min-height:100vh;display:flex;flex-direction:column;background-color:var(--bg-secondary)}.profile-main{flex:1;padding:var(--spacing-md);padding-bottom:100px;max-width:600px;margin:0 auto;width:100%}.profile-header{text-align:center;padding:var(--spacing-xl);background-color:var(--bg-primary);border-radius:var(--radius-lg);margin-bottom:var(--spacing-lg)}.profile-avatar-large{position:relative;width:100px;height:100px;margin:0 auto var(--spacing-md)}.avatar-img-large{width:100%;height:100%;border-radius:50%;object-fit:cover;border:4px solid var(--primary)}.avatar-placeholder-large{width:100%;height:100%;border-radius:50%;background-color:var(--primary);color:var(--white);display:flex;align-items:center;justify-content:center;font-size:40px;font-weight:700;text-transform:uppercase}.pro-badge{position:absolute;bottom:0;right:0;background:linear-gradient(135deg,#ffc800,#ff9600);color:var(--white);font-size:10px;font-weight:700;padding:4px 8px;border-radius:var(--radius-full);border:2px solid var(--bg-primary)}.profile-name{font-size:var(--font-size-xl);font-weight:700;color:var(--text-primary);margin-bottom:var(--spacing-xs)}.profile-email{font-size:var(--font-size-sm);color:var(--text-secondary);margin-bottom:var(--spacing-xs)}.profile-subtitle{font-size:var(--font-size-sm);color:var(--primary);font-weight:600}.subscription-section{margin-bottom:var(--spacing-lg)}.subscription-card{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-lg);background-color:var(--bg-primary);border-radius:var(--radius-md);box-shadow:var(--shadow-sm)}.subscription-info{display:flex;align-items:center;gap:var(--spacing-md)}.subscription-icon{font-size:32px}.subscription-text{display:flex;flex-direction:column;gap:2px}.subscription-plan{font-size:var(--font-size-md);font-weight:700;color:var(--text-primary)}.subscription-status{font-size:var(--font-size-sm);color:var(--text-secondary)}.upgrade-button,.manage-button{padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-sm);font-weight:700;border-radius:var(--radius-md);transition:all var(--transition-fast)}.upgrade-button{background-color:var(--primary);color:var(--white)}.upgrade-button:hover{background-color:var(--primary-dark)}.manage-button{background-color:var(--gray-100);color:var(--text-primary)}.manage-button:hover{background-color:var(--gray-200)}.logout-section{margin-top:var(--spacing-xl);text-align:center}.logout-button{padding:var(--spacing-md) var(--spacing-xl);background-color:var(--gray-100);color:var(--incorrect);font-size:var(--font-size-md);font-weight:600;border-radius:var(--radius-md);transition:all var(--transition-fast)}.logout-button:hover{background-color:#ffeef0}.section-title{font-size:var(--font-size-lg);font-weight:700;color:var(--text-primary);margin-bottom:var(--spacing-md)}.stats-section,.progress-section,.streak-freeze-section,.achievements-section{margin-bottom:var(--spacing-lg)}.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-md)}.stat-card{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-lg);background-color:var(--bg-primary);border-radius:var(--radius-md);box-shadow:var(--shadow-sm)}.stat-card .stat-icon{font-size:28px}.stat-card .stat-value{font-size:var(--font-size-xl);font-weight:700;color:var(--text-primary)}.stat-card .stat-label{font-size:var(--font-size-xs);color:var(--text-secondary)}.progress-card{background-color:var(--bg-primary);border-radius:var(--radius-md);padding:var(--spacing-lg);box-shadow:var(--shadow-sm)}.progress-header{display:flex;justify-content:space-between;margin-bottom:var(--spacing-sm)}.progress-label{font-weight:600;color:var(--text-primary)}.progress-value{font-weight:700;color:var(--primary)}.progress-bar-container{height:12px;background-color:var(--gray-100);border-radius:var(--radius-full);overflow:hidden;margin-bottom:var(--spacing-sm)}.progress-bar{height:100%;background:linear-gradient(90deg,var(--primary),var(--primary-light));border-radius:var(--radius-full);transition:width var(--transition-slow)}.progress-detail{font-size:var(--font-size-sm);color:var(--text-secondary);text-align:center}.streak-freeze-card{background-color:var(--bg-primary);border-radius:var(--radius-md);padding:var(--spacing-lg);box-shadow:var(--shadow-sm)}.freeze-info{display:flex;align-items:center;gap:var(--spacing-md)}.freeze-icon{font-size:40px}.freeze-text{display:flex;flex-direction:column;gap:var(--spacing-xs)}.freeze-count{font-size:var(--font-size-lg);font-weight:700;color:var(--text-primary)}.freeze-description{font-size:var(--font-size-sm);color:var(--text-secondary)}.achievements-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-md)}.achievement-card{position:relative;display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-lg);background-color:var(--bg-primary);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);text-align:center;transition:all var(--transition-fast)}.achievement-card.locked{opacity:.5}.achievement-card.unlocked{border:2px solid var(--warning)}.achievement-icon{font-size:32px}.achievement-name{font-size:var(--font-size-sm);font-weight:700;color:var(--text-primary)}.achievement-description{font-size:var(--font-size-xs);color:var(--text-secondary)}.achievement-lock{position:absolute;top:var(--spacing-sm);right:var(--spacing-sm);font-size:14px}@media(min-width:768px){.profile-main{padding:var(--spacing-xl);padding-bottom:100px}.stats-grid{grid-template-columns:repeat(4,1fr)}.achievements-grid{grid-template-columns:repeat(3,1fr)}}@media(min-width:1024px){.profile-page{padding-left:220px}.profile-main{padding-bottom:var(--spacing-xl);max-width:700px}.achievements-grid{grid-template-columns:repeat(4,1fr)}}.settings-page{min-height:100vh;display:flex;flex-direction:column;background-color:var(--bg-secondary)}.settings-main{flex:1;padding:var(--spacing-md);padding-bottom:100px;max-width:600px;margin:0 auto;width:100%}.settings-title{font-size:var(--font-size-xl);font-weight:700;color:var(--text-primary);margin-bottom:var(--spacing-lg)}.settings-section{margin-bottom:var(--spacing-lg)}.section-title{font-size:var(--font-size-sm);font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--spacing-md)}.setting-item{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md);padding:var(--spacing-md);background-color:var(--bg-primary);border-radius:var(--radius-md);margin-bottom:var(--spacing-sm);transition:background-color var(--transition-fast)}.setting-item.clickable{cursor:pointer}.setting-item.clickable:hover{background-color:var(--gray-50)}.setting-info{display:flex;align-items:center;gap:var(--spacing-md);flex:1}.setting-icon{font-size:24px}.setting-text{display:flex;flex-direction:column;gap:2px}.setting-name{font-weight:600;color:var(--text-primary)}.setting-name.danger{color:var(--incorrect)}.setting-description{font-size:var(--font-size-sm);color:var(--text-secondary)}.setting-arrow{font-size:var(--font-size-lg);color:var(--text-secondary)}.toggle{position:relative;display:inline-block;width:52px;height:28px;flex-shrink:0}.toggle input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;inset:0;background-color:var(--gray-200);border-radius:var(--radius-full);transition:all var(--transition-fast)}.toggle-slider:before{position:absolute;content:"";height:22px;width:22px;left:3px;bottom:3px;background-color:var(--white);border-radius:50%;transition:transform var(--transition-fast);box-shadow:var(--shadow-sm)}.toggle input:checked+.toggle-slider{background-color:var(--primary)}.toggle input:checked+.toggle-slider:before{transform:translate(24px)}.toggle input:focus-visible+.toggle-slider{outline:2px solid var(--primary);outline-offset:2px}.subscription-settings-card{background-color:var(--bg-primary);border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow-sm)}.subscription-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}.subscription-plan-info{display:flex;align-items:center;gap:var(--spacing-sm)}.plan-badge{padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:700;background:linear-gradient(135deg,#ffc800,#ff9600);color:var(--white)}.plan-name{font-size:var(--font-size-md);font-weight:600;color:var(--text-primary)}.plan-price{font-size:var(--font-size-sm);font-weight:700;color:var(--primary)}.plan-features-list{list-style:none;padding:0;margin:0 0 var(--spacing-lg) 0}.plan-features-list li{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-xs) 0;font-size:var(--font-size-sm);color:var(--text-secondary)}.plan-features-list .check-icon{color:var(--primary);font-weight:700}.subscription-button{width:100%;padding:var(--spacing-md);font-size:var(--font-size-md);font-weight:700;border-radius:var(--radius-md);transition:all var(--transition-fast)}.subscription-button.upgrade{background-color:var(--primary);color:var(--white);box-shadow:0 4px 0 var(--primary-dark)}.subscription-button.upgrade:hover{background-color:var(--primary-light)}.subscription-button.manage{background-color:var(--gray-100);color:var(--text-primary)}.subscription-button.manage:hover{background-color:var(--gray-200)}.modal-content{background-color:var(--bg-primary);border-radius:var(--radius-lg);padding:var(--spacing-xl);max-width:400px;width:100%;text-align:center}.modal-title{font-size:var(--font-size-lg);font-weight:700;color:var(--text-primary);margin-bottom:var(--spacing-md)}.modal-text{font-size:var(--font-size-sm);color:var(--text-secondary);line-height:1.6;margin-bottom:var(--spacing-lg)}.modal-actions{display:flex;gap:var(--spacing-md);justify-content:center}.modal-button{padding:var(--spacing-sm) var(--spacing-lg);font-size:var(--font-size-md);font-weight:600;border-radius:var(--radius-md);transition:all var(--transition-fast)}.modal-button.secondary{background-color:var(--gray-100);color:var(--text-primary)}.modal-button.secondary:hover{background-color:var(--gray-200)}.modal-button.danger{background-color:var(--incorrect);color:var(--white)}.modal-button.danger:hover{opacity:.9}.about-card{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md);padding:var(--spacing-xl);background-color:var(--bg-primary);border-radius:var(--radius-lg);text-align:center}.about-logo{font-size:64px}.about-name{font-size:var(--font-size-lg);font-weight:700;color:var(--text-primary)}.about-version{font-size:var(--font-size-sm);color:var(--text-secondary)}.about-description{font-size:var(--font-size-sm);color:var(--text-secondary);line-height:1.6}.about-features{display:flex;flex-wrap:wrap;justify-content:center;gap:var(--spacing-sm)}.feature{padding:var(--spacing-xs) var(--spacing-sm);background-color:var(--gray-50);border-radius:var(--radius-full);font-size:var(--font-size-xs);color:var(--primary);font-weight:600}@media(min-width:768px){.settings-main{padding:var(--spacing-xl);padding-bottom:100px}}@media(min-width:1024px){.settings-page{padding-left:220px}.settings-main{padding-bottom:var(--spacing-xl)}}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--spacing-lg);background:linear-gradient(135deg,var(--bg-secondary) 0%,#e8f5e9 100%)}.auth-container{width:100%;max-width:400px;background-color:var(--bg-primary);border-radius:var(--radius-xl);padding:var(--spacing-xl);box-shadow:var(--shadow-lg)}.auth-header{text-align:center;margin-bottom:var(--spacing-xl)}.auth-logo{display:inline-flex;align-items:center;gap:var(--spacing-sm);font-size:var(--font-size-xl);font-weight:700;color:var(--primary);margin-bottom:var(--spacing-lg)}.auth-logo .logo-icon{font-size:32px}.auth-header h1{font-size:var(--font-size-xl);color:var(--text-primary);margin-bottom:var(--spacing-xs)}.auth-header p{color:var(--text-secondary);font-size:var(--font-size-sm)}.auth-error{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md);background-color:#ffeef0;border:1px solid #ffc9cf;border-radius:var(--radius-md);color:#d93025;font-size:var(--font-size-sm);margin-bottom:var(--spacing-lg)}.auth-form{display:flex;flex-direction:column;gap:var(--spacing-md)}.form-group label{font-size:var(--font-size-sm);font-weight:600;color:var(--text-primary)}.form-group input{padding:var(--spacing-md);font-size:var(--font-size-md);border:2px solid var(--border-color);border-radius:var(--radius-md);background-color:var(--bg-primary);color:var(--text-primary);transition:all var(--transition-fast)}.form-group input:focus{outline:none;border-color:var(--primary)}.form-group input:disabled{background-color:var(--gray-100);cursor:not-allowed}.password-input-wrapper{position:relative;display:flex;align-items:center}.password-input-wrapper input{width:100%;padding-right:44px}.password-toggle{position:absolute;right:8px;display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;background:none;border:none;cursor:pointer;color:var(--text-secondary);border-radius:var(--radius-sm);transition:color var(--transition-fast)}.password-toggle:hover{color:var(--text-primary)}.password-toggle svg{width:20px;height:20px}.forgot-password{font-size:var(--font-size-sm);color:var(--secondary);text-align:right;margin-top:calc(-1 * var(--spacing-sm))}.forgot-password:hover{text-decoration:underline}.auth-button{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-md);font-size:var(--font-size-md);font-weight:700;border-radius:var(--radius-md);transition:all var(--transition-fast);cursor:pointer}.auth-button:disabled{opacity:.6;cursor:not-allowed}.auth-button.primary{background-color:var(--primary);color:var(--white);box-shadow:0 4px 0 var(--primary-dark)}.auth-button.primary:hover:not(:disabled){background-color:var(--primary-light)}.auth-button.primary:active:not(:disabled){transform:translateY(2px);box-shadow:0 2px 0 var(--primary-dark)}.auth-button.google{background-color:var(--white);color:var(--text-primary);border:2px solid var(--border-color);box-shadow:var(--shadow-sm)}.auth-button.google:hover:not(:disabled){background-color:var(--gray-50);border-color:var(--gray-300)}.google-icon{width:20px;height:20px}.auth-divider{display:flex;align-items:center;gap:var(--spacing-md);margin:var(--spacing-lg) 0}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background-color:var(--border-color)}.auth-divider span{font-size:var(--font-size-sm);color:var(--text-secondary)}.auth-footer{text-align:center;margin-top:var(--spacing-lg);font-size:var(--font-size-sm);color:var(--text-secondary)}.auth-footer a{color:var(--primary);font-weight:600}.auth-footer a:hover{text-decoration:underline}.auth-terms{text-align:center;margin-top:var(--spacing-md);font-size:var(--font-size-xs);color:var(--text-secondary)}.auth-terms a{color:var(--secondary)}.auth-terms a:hover{text-decoration:underline}@media(min-width:768px){.auth-container{padding:var(--spacing-2xl)}}.pricing-page{min-height:100vh;padding:var(--spacing-lg);background:linear-gradient(180deg,var(--bg-secondary) 0%,#e8f5e9 100%)}.pricing-container{max-width:1000px;margin:0 auto}.pricing-header{text-align:center;margin-bottom:var(--spacing-xl)}.pricing-header h1{font-size:var(--font-size-2xl);color:var(--text-primary);margin-bottom:var(--spacing-sm)}.pricing-header p{font-size:var(--font-size-md);color:var(--text-secondary)}.pricing-error{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-md);background-color:#ffeef0;border:1px solid #ffc9cf;border-radius:var(--radius-md);color:#d93025;font-size:var(--font-size-sm);margin-bottom:var(--spacing-lg);max-width:600px;margin-left:auto;margin-right:auto}.pricing-cards{display:grid;grid-template-columns:1fr;gap:var(--spacing-lg);margin-bottom:var(--spacing-xl)}@media(min-width:768px){.pricing-cards{grid-template-columns:repeat(3,1fr)}}.pricing-card{position:relative;background-color:var(--bg-primary);border-radius:var(--radius-xl);padding:var(--spacing-xl);box-shadow:var(--shadow-md);display:flex;flex-direction:column;transition:all var(--transition-fast);border:2px solid transparent}.pricing-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.pricing-card.popular{border-color:var(--primary);transform:scale(1.02)}.pricing-card.popular:hover{transform:scale(1.02) translateY(-4px)}.pricing-card.current{border-color:var(--secondary)}.popular-badge{position:absolute;top:-12px;left:50%;transform:translate(-50%);background:linear-gradient(90deg,var(--primary),var(--primary-light));color:var(--white);font-size:var(--font-size-xs);font-weight:700;padding:var(--spacing-xs) var(--spacing-md);border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.5px}.current-badge{position:absolute;top:-12px;left:50%;transform:translate(-50%);background-color:var(--secondary);color:var(--white);font-size:var(--font-size-xs);font-weight:700;padding:var(--spacing-xs) var(--spacing-md);border-radius:var(--radius-full)}.plan-header{text-align:center;margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-lg);border-bottom:1px solid var(--border-color)}.plan-name{font-size:var(--font-size-lg);font-weight:700;color:var(--text-primary);margin-bottom:var(--spacing-sm)}.plan-price{display:flex;align-items:baseline;justify-content:center;gap:var(--spacing-xs)}.price-amount{font-size:48px;font-weight:700;color:var(--text-primary)}.price-interval{font-size:var(--font-size-md);color:var(--text-secondary)}.plan-savings{margin-top:var(--spacing-sm);font-size:var(--font-size-sm);color:var(--primary);font-weight:600}.plan-features{flex:1;margin-bottom:var(--spacing-lg)}.plan-features li{display:flex;align-items:flex-start;gap:var(--spacing-sm);padding:var(--spacing-sm) 0;font-size:var(--font-size-sm);color:var(--text-primary)}.feature-icon{color:var(--primary);font-weight:700;flex-shrink:0}.plan-button{width:100%;padding:var(--spacing-md);font-size:var(--font-size-md);font-weight:700;border-radius:var(--radius-lg);transition:all var(--transition-fast);cursor:pointer}.plan-button:disabled{opacity:.6;cursor:not-allowed}.plan-button.primary{background-color:var(--primary);color:var(--white);box-shadow:0 4px 0 var(--primary-dark)}.plan-button.primary:hover:not(:disabled){background-color:var(--primary-light)}.plan-button.secondary{background-color:var(--gray-100);color:var(--text-primary);box-shadow:0 4px 0 var(--gray-200)}.plan-button.secondary:hover:not(:disabled){background-color:var(--gray-200)}.pricing-footer{text-align:center;padding:var(--spacing-xl);background-color:var(--bg-primary);border-radius:var(--radius-xl);margin-bottom:var(--spacing-xl)}.guarantee{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);font-size:var(--font-size-md);color:var(--text-primary);margin-bottom:var(--spacing-sm)}.guarantee-icon{font-size:24px}.payment-info{font-size:var(--font-size-sm);color:var(--text-secondary);margin-bottom:var(--spacing-md)}.login-prompt{font-size:var(--font-size-sm);color:var(--text-secondary)}.link-button{color:var(--primary);font-weight:600;background:none;border:none;cursor:pointer;padding:0}.link-button:hover{text-decoration:underline}.pricing-faq{background-color:var(--bg-primary);border-radius:var(--radius-xl);padding:var(--spacing-xl)}.pricing-faq h3{font-size:var(--font-size-lg);color:var(--text-primary);margin-bottom:var(--spacing-lg);text-align:center}.faq-item{padding:var(--spacing-md) 0;border-bottom:1px solid var(--border-color)}.faq-item:last-child{border-bottom:none}.faq-item h4{font-size:var(--font-size-md);font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-xs)}.faq-item p{font-size:var(--font-size-sm);color:var(--text-secondary);line-height:1.6}@media(min-width:768px){.pricing-page{padding:var(--spacing-2xl)}.pricing-header h1{font-size:40px}}.landing-page{min-height:100vh;display:flex;flex-direction:column;background-color:var(--bg-primary)}.landing-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md) var(--spacing-lg);position:sticky;top:0;background-color:var(--bg-primary);border-bottom:1px solid var(--border-color);z-index:var(--z-sticky)}.landing-logo{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--font-size-xl);font-weight:700;color:var(--primary)}.landing-logo .logo-icon{font-size:32px}.landing-nav{display:flex;align-items:center;gap:var(--spacing-md)}.nav-link{color:var(--text-primary);font-weight:600;padding:var(--spacing-sm) var(--spacing-md);transition:color var(--transition-fast)}.nav-link:hover{color:var(--primary)}.nav-button{background-color:var(--primary);color:var(--white);font-weight:700;padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-md);transition:background-color var(--transition-fast)}.nav-button:hover{background-color:var(--primary-dark)}.landing-main{flex:1}.hero-section{display:flex;flex-direction:column;align-items:center;padding:var(--spacing-2xl) var(--spacing-lg);background:linear-gradient(180deg,#e8f5e9 0%,var(--bg-primary) 100%)}.hero-content{text-align:center;max-width:600px;margin-bottom:var(--spacing-xl)}.hero-title{font-size:36px;font-weight:700;color:var(--text-primary);margin-bottom:var(--spacing-md);line-height:1.2}.hero-title .highlight{color:var(--primary)}.hero-subtitle{font-size:var(--font-size-lg);color:var(--text-secondary);margin-bottom:var(--spacing-xl);line-height:1.6}.hero-cta{display:flex;flex-direction:column;gap:var(--spacing-md);align-items:center}.cta-button{display:inline-flex;align-items:center;justify-content:center;padding:var(--spacing-md) var(--spacing-xl);font-size:var(--font-size-md);font-weight:700;border-radius:var(--radius-lg);transition:all var(--transition-fast);min-width:200px}.cta-button.primary{background-color:var(--primary);color:var(--white);box-shadow:0 4px 0 var(--primary-dark)}.cta-button.primary:hover{background-color:var(--primary-light)}.cta-button.primary:active{box-shadow:0 2px 0 var(--primary-dark);transform:translateY(2px)}.cta-button.primary.large{padding:var(--spacing-lg) var(--spacing-2xl);font-size:var(--font-size-lg)}.cta-button.secondary{background-color:var(--bg-primary);color:var(--primary);border:2px solid var(--primary)}.cta-button.secondary:hover{background-color:#e8f5e9}.hero-note{margin-top:var(--spacing-md);font-size:var(--font-size-sm);color:var(--text-secondary)}.hero-visual{width:100%;max-width:300px}.phone-mockup{background-color:var(--gray-800);border-radius:30px;padding:10px;box-shadow:var(--shadow-lg)}.phone-screen{background-color:var(--bg-primary);border-radius:22px;overflow:hidden;padding:var(--spacing-md)}.mockup-header{display:flex;align-items:center;gap:var(--spacing-sm);font-weight:700;color:var(--primary);margin-bottom:var(--spacing-lg)}.mockup-lesson{text-align:center}.mockup-question{font-size:var(--font-size-md);font-weight:600;margin-bottom:var(--spacing-md)}.mockup-options{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-sm)}.mockup-option{padding:var(--spacing-sm);background-color:var(--gray-100);border-radius:var(--radius-sm);font-size:var(--font-size-sm);font-weight:600}.mockup-option.correct{background-color:#d7ffb8;color:var(--primary-dark)}.section-title{font-size:var(--font-size-xl);font-weight:700;text-align:center;margin-bottom:var(--spacing-xl);color:var(--text-primary)}.section-subtitle{text-align:center;color:var(--text-secondary);font-size:var(--font-size-md);margin-top:calc(-1 * var(--spacing-md));margin-bottom:var(--spacing-xl)}.features-section{padding:var(--spacing-2xl) var(--spacing-lg);background-color:var(--bg-secondary)}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--spacing-lg);max-width:1000px;margin:0 auto}.feature-card{background-color:var(--bg-primary);padding:var(--spacing-lg);border-radius:var(--radius-lg);text-align:center;box-shadow:var(--shadow-sm);transition:transform var(--transition-fast)}.feature-card:hover{transform:translateY(-4px)}.feature-icon{font-size:40px;margin-bottom:var(--spacing-md);display:block}.feature-card h3{font-size:var(--font-size-lg);font-weight:700;margin-bottom:var(--spacing-sm);color:var(--text-primary)}.feature-card p{font-size:var(--font-size-sm);color:var(--text-secondary);line-height:1.6}.how-it-works-section{padding:var(--spacing-2xl) var(--spacing-lg)}.steps-grid{display:grid;grid-template-columns:1fr;gap:var(--spacing-lg);max-width:800px;margin:0 auto}.step-card{display:flex;flex-direction:column;align-items:center;text-align:center;padding:var(--spacing-lg);background-color:var(--bg-secondary);border-radius:var(--radius-lg);position:relative}.step-number{width:48px;height:48px;background-color:var(--primary);color:var(--white);border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-size:var(--font-size-xl);font-weight:700;margin-bottom:var(--spacing-md)}.step-card h3{font-size:var(--font-size-lg);font-weight:700;margin-bottom:var(--spacing-sm);color:var(--text-primary)}.step-card p{font-size:var(--font-size-sm);color:var(--text-secondary);line-height:1.6}.sample-section{padding:var(--spacing-2xl) var(--spacing-lg);background-color:var(--bg-secondary)}.sample-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:var(--spacing-md);max-width:800px;margin:0 auto var(--spacing-2xl)}.sample-card{perspective:600px;height:120px;cursor:pointer;background:none;border:none;padding:0;font-family:inherit}.sample-card .sample-card-front,.sample-card .sample-card-back{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-xs);width:100%;height:100%;border-radius:var(--radius-lg);backface-visibility:hidden;transition:transform .5s ease;position:absolute;top:0;left:0;padding:var(--spacing-md)}.sample-card{position:relative}.sample-card .sample-card-front{background-color:var(--bg-primary);border:2px solid var(--border-color)}.sample-card .sample-card-back{background-color:var(--primary);color:var(--white);transform:rotateY(180deg)}.sample-card.revealed .sample-card-front{transform:rotateY(180deg)}.sample-card.revealed .sample-card-back{transform:rotateY(0)}.sample-word{font-size:var(--font-size-lg);font-weight:700;color:var(--text-primary)}.sample-hint{font-size:var(--font-size-xs);color:var(--text-secondary)}.sample-translation{font-size:var(--font-size-lg);font-weight:700}.sample-original{font-size:var(--font-size-xs);opacity:.8}.mini-quiz{max-width:500px;margin:0 auto;background-color:var(--bg-primary);border-radius:var(--radius-lg);padding:var(--spacing-xl);box-shadow:var(--shadow-md)}.mini-quiz-title{font-size:var(--font-size-lg);font-weight:700;text-align:center;margin-bottom:var(--spacing-md);color:var(--primary)}.mini-quiz-question{font-size:var(--font-size-md);font-weight:600;text-align:center;margin-bottom:var(--spacing-lg);color:var(--text-primary)}.mini-quiz-options{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-sm)}.mini-quiz-option{padding:var(--spacing-md);border:2px solid var(--border-color);border-radius:var(--radius-md);background-color:var(--bg-primary);font-size:var(--font-size-sm);font-weight:600;cursor:pointer;transition:all var(--transition-fast);color:var(--text-primary);font-family:inherit}.mini-quiz-option:hover:not(:disabled){border-color:var(--primary);background-color:#e8f5e9}.mini-quiz-option:disabled{cursor:default}.mini-quiz-option.correct{border-color:var(--correct);background-color:#d7ffb8;color:var(--primary-dark)}.mini-quiz-option.incorrect{border-color:var(--incorrect);background-color:#ffe0e0;color:var(--incorrect)}.mini-quiz-feedback{margin-top:var(--spacing-md);padding:var(--spacing-md);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:600;text-align:center}.mini-quiz-feedback.correct{background-color:#d7ffb8;color:var(--primary-dark)}.mini-quiz-feedback.incorrect{background-color:#ffe0e0;color:var(--incorrect)}.content-section{padding:var(--spacing-2xl) var(--spacing-lg)}.content-grid{display:flex;flex-wrap:wrap;justify-content:center;gap:var(--spacing-md);max-width:800px;margin:0 auto}.content-item{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-md) var(--spacing-lg);background-color:var(--bg-secondary);border-radius:var(--radius-lg);min-width:100px}.content-icon{font-size:32px}.content-name{font-size:var(--font-size-sm);font-weight:600;color:var(--text-primary)}.social-proof-section{padding:var(--spacing-2xl) var(--spacing-lg);background-color:var(--bg-secondary)}.stats-bar{display:flex;justify-content:center;gap:var(--spacing-2xl);margin-bottom:var(--spacing-xl);flex-wrap:wrap}.stat-item{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xs)}.stat-number{font-size:var(--font-size-2xl);font-weight:700;color:var(--primary)}.testimonials-grid{display:grid;grid-template-columns:1fr;gap:var(--spacing-lg);max-width:1000px;margin:0 auto}.testimonial-card{background-color:var(--bg-primary);padding:var(--spacing-lg);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.testimonial-stars{color:#ffc800;font-size:var(--font-size-lg);margin-bottom:var(--spacing-sm)}.testimonial-text{font-size:var(--font-size-sm);color:var(--text-secondary);line-height:1.7;margin-bottom:var(--spacing-md);font-style:italic}.testimonial-author{display:flex;align-items:center;gap:var(--spacing-md)}.testimonial-avatar{width:40px;height:40px;background-color:var(--primary);color:var(--white);border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:var(--font-size-sm)}.testimonial-name{display:block;font-weight:700;font-size:var(--font-size-sm);color:var(--text-primary)}.testimonial-detail{font-size:var(--font-size-xs);color:var(--text-secondary)}.cta-section{padding:var(--spacing-2xl) var(--spacing-lg);text-align:center;background:linear-gradient(180deg,var(--bg-primary) 0%,#e8f5e9 100%)}.cta-section h2{font-size:var(--font-size-xl);font-weight:700;margin-bottom:var(--spacing-sm);color:var(--text-primary)}.cta-section p{font-size:var(--font-size-md);color:var(--text-secondary);margin-bottom:var(--spacing-xl)}.landing-footer{background-color:var(--gray-800);padding:var(--spacing-xl) var(--spacing-lg);color:var(--white)}.footer-content{max-width:1000px;margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:var(--spacing-lg)}.footer-logo{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--font-size-lg);font-weight:700}.footer-links{display:flex;gap:var(--spacing-lg)}.footer-links a{color:var(--gray-300);transition:color var(--transition-fast)}.footer-links a:hover{color:var(--white)}.footer-copy{font-size:var(--font-size-sm);color:var(--gray-400)}@media(min-width:768px){.hero-section{flex-direction:row;justify-content:center;gap:var(--spacing-2xl);padding:var(--spacing-2xl)}.hero-content{text-align:left;margin-bottom:0}.hero-title{font-size:48px}.hero-cta{flex-direction:row}.steps-grid{grid-template-columns:repeat(4,1fr)}.step-card{padding:var(--spacing-xl) var(--spacing-md)}.testimonials-grid{grid-template-columns:repeat(3,1fr)}.footer-content{flex-direction:row;justify-content:space-between}}[data-theme=dark] .hero-section{background:linear-gradient(180deg,#1a2e1a 0%,var(--bg-primary) 100%)}[data-theme=dark] .cta-button.secondary:hover{background-color:#1a2e1a}[data-theme=dark] .cta-section{background:linear-gradient(180deg,var(--bg-primary) 0%,#1a2e1a 100%)}[data-theme=dark] .mini-quiz-option:hover:not(:disabled){background-color:#1a2e1a}[data-theme=dark] .sample-card .sample-card-front{border-color:var(--border-color)}.admin-page{min-height:100vh;display:flex;flex-direction:column;background-color:var(--bg-secondary)}.admin-header{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background-color:var(--bg-primary);border-bottom:1px solid var(--gray-100);position:sticky;top:0;z-index:var(--z-sticky)}.back-button{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);background-color:var(--gray-100);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:600;color:var(--text-primary);transition:background-color var(--transition-fast)}.back-button:hover{background-color:var(--gray-200)}.back-arrow{font-size:var(--font-size-md)}.admin-title{font-size:var(--font-size-lg);font-weight:700;color:var(--text-primary)}.admin-main{flex:1;padding:var(--spacing-md);max-width:1200px;margin:0 auto;width:100%}.stats-section{margin-bottom:var(--spacing-lg)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:var(--spacing-md)}.stat-card{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background-color:var(--bg-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.stat-icon{font-size:32px}.stat-info{display:flex;flex-direction:column}.stat-value{font-size:var(--font-size-xl);font-weight:700;color:var(--text-primary)}.stat-label{font-size:var(--font-size-sm);color:var(--text-secondary)}.stat-card.stat-pro{background:linear-gradient(135deg,#fff9e6,#fff3cc)}.stat-card.stat-free{background:linear-gradient(135deg,#e8f5e9,#c8e6c9)}.users-section{background-color:var(--bg-primary);border-radius:var(--radius-lg);padding:var(--spacing-md);box-shadow:var(--shadow-sm)}.section-header{display:flex;flex-direction:column;gap:var(--spacing-md);margin-bottom:var(--spacing-md)}.section-title{font-size:var(--font-size-md);font-weight:700;color:var(--text-primary)}.search-container{position:relative;display:flex;align-items:center}.search-icon{position:absolute;left:var(--spacing-md);font-size:16px;pointer-events:none}.search-input{width:100%;padding:var(--spacing-sm) var(--spacing-md);padding-left:40px;padding-right:40px;font-size:var(--font-size-md);border:2px solid var(--gray-200);border-radius:var(--radius-md);transition:border-color var(--transition-fast)}.search-input:focus{outline:none;border-color:var(--primary)}.clear-search{position:absolute;right:var(--spacing-sm);width:28px;height:28px;display:flex;align-items:center;justify-content:center;font-size:18px;color:var(--text-secondary);background-color:var(--gray-100);border-radius:50%;transition:all var(--transition-fast)}.clear-search:hover{background-color:var(--gray-200);color:var(--text-primary)}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl);gap:var(--spacing-md)}.loading-spinner{width:40px;height:40px;border:4px solid var(--gray-200);border-top-color:var(--primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-container p{color:var(--text-secondary);font-size:var(--font-size-sm)}.empty-state{text-align:center;padding:var(--spacing-xl);color:var(--text-secondary)}.users-table-container{display:none;overflow-x:auto}.users-table{width:100%;border-collapse:collapse}.users-table th,.users-table td{padding:var(--spacing-sm) var(--spacing-md);text-align:left;border-bottom:1px solid var(--gray-100)}.users-table th{font-size:var(--font-size-sm);font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.users-table td{font-size:var(--font-size-sm);color:var(--text-primary)}.user-row{cursor:pointer;transition:background-color var(--transition-fast)}.user-row:hover{background-color:var(--gray-50)}.email-cell{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.badge{display:inline-block;padding:2px 8px;font-size:var(--font-size-xs);font-weight:700;border-radius:var(--radius-full);text-transform:uppercase}.badge-pro{background:linear-gradient(135deg,#ffc800,#ff9600);color:var(--white)}.badge-free{background-color:var(--gray-200);color:var(--text-secondary)}.badge-admin{background:linear-gradient(135deg,#667eea,#764ba2);color:var(--white);margin-right:var(--spacing-xs)}.users-cards{display:flex;flex-direction:column;gap:var(--spacing-sm)}.user-card{padding:var(--spacing-md);background-color:var(--bg-secondary);border-radius:var(--radius-md);cursor:pointer;transition:background-color var(--transition-fast)}.user-card:hover{background-color:var(--gray-100)}.user-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--spacing-sm);margin-bottom:var(--spacing-xs)}.user-email{font-size:var(--font-size-sm);font-weight:600;color:var(--text-primary);word-break:break-all;flex:1}.user-badges{display:flex;gap:var(--spacing-xs);flex-shrink:0}.user-card-body{display:flex;justify-content:space-between;align-items:center}.user-name{font-size:var(--font-size-sm);color:var(--text-secondary)}.user-date{font-size:var(--font-size-xs);color:var(--text-secondary)}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:var(--z-modal);padding:var(--spacing-md)}.modal-content{background-color:var(--bg-primary);border-radius:var(--radius-lg);max-width:480px;width:100%;max-height:90vh;overflow-y:auto;position:relative}.user-modal{padding:var(--spacing-xl)}.modal-close{position:absolute;top:var(--spacing-md);right:var(--spacing-md);width:32px;height:32px;display:flex;align-items:center;justify-content:center;font-size:24px;color:var(--text-secondary);background-color:var(--gray-100);border-radius:50%;transition:all var(--transition-fast)}.modal-close:hover{background-color:var(--gray-200);color:var(--text-primary)}.user-modal-header{display:flex;flex-direction:column;align-items:center;text-align:center;margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-lg);border-bottom:1px solid var(--gray-100)}.user-avatar{width:80px;height:80px;border-radius:50%;overflow:hidden;margin-bottom:var(--spacing-md);background-color:var(--primary);display:flex;align-items:center;justify-content:center}.user-avatar img{width:100%;height:100%;object-fit:cover}.avatar-placeholder{font-size:32px;font-weight:700;color:var(--white)}.user-modal-name{font-size:var(--font-size-lg);font-weight:700;color:var(--text-primary);margin-bottom:var(--spacing-xs)}.user-modal-email{font-size:var(--font-size-sm);color:var(--text-secondary);margin-bottom:var(--spacing-md);word-break:break-all}.user-modal-badges{display:flex;gap:var(--spacing-xs)}.user-modal-details{margin-bottom:var(--spacing-lg)}.detail-row{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm) 0;border-bottom:1px solid var(--gray-50)}.detail-row:last-child{border-bottom:none}.detail-label{font-size:var(--font-size-sm);color:var(--text-secondary)}.detail-value{font-size:var(--font-size-sm);color:var(--text-primary);font-weight:500;text-align:right;word-break:break-all;max-width:60%}.user-modal-subscription{background-color:var(--bg-secondary);border-radius:var(--radius-md);padding:var(--spacing-md)}.subscription-title{font-size:var(--font-size-md);font-weight:700;color:var(--text-primary);margin-bottom:var(--spacing-md)}.subscription-info{display:flex;flex-direction:column}.subscription-form{display:flex;flex-direction:column;gap:var(--spacing-md)}.form-group{display:flex;flex-direction:column;gap:var(--spacing-xs)}.form-group label{font-size:var(--font-size-sm);font-weight:600;color:var(--text-secondary)}.form-group select{padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-md);border:2px solid var(--gray-200);border-radius:var(--radius-md);background-color:var(--bg-primary);color:var(--text-primary);cursor:pointer}.form-group select:focus{outline:none;border-color:var(--primary)}.form-actions{display:flex;gap:var(--spacing-sm);justify-content:flex-end;margin-top:var(--spacing-sm)}.btn{padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-sm);font-weight:600;border-radius:var(--radius-md);transition:all var(--transition-fast);cursor:pointer}.btn-primary{background-color:var(--primary);color:var(--white)}.btn-primary:hover{background-color:var(--primary-dark)}.btn-secondary{background-color:var(--gray-200);color:var(--text-primary)}.btn-secondary:hover{background-color:var(--gray-300)}.btn-edit{width:100%;margin-top:var(--spacing-md);background-color:var(--primary);color:var(--white)}.btn-edit:hover{background-color:var(--primary-dark)}@media(min-width:768px){.admin-main{padding:var(--spacing-xl)}.section-header{flex-direction:row;justify-content:space-between;align-items:center}.search-container{width:300px}.users-table-container{display:block}.users-cards{display:none}.stats-grid{grid-template-columns:repeat(3,1fr)}}@media(min-width:1024px){.admin-page{padding-left:220px}.admin-header{padding:var(--spacing-md) var(--spacing-xl)}.admin-main{max-width:1000px}}.tickets-section{background-color:var(--bg-primary);border-radius:var(--radius-lg);padding:var(--spacing-md);box-shadow:var(--shadow-sm);margin-top:var(--spacing-lg)}.ticket-filters{display:flex;gap:var(--spacing-xs);flex-wrap:wrap}.filter-btn{padding:var(--spacing-xs) var(--spacing-sm);font-size:var(--font-size-sm);font-weight:500;background-color:var(--gray-100);color:var(--text-secondary);border-radius:var(--radius-md);transition:all var(--transition-fast)}.filter-btn:hover{background-color:var(--gray-200)}.filter-btn.active{background-color:var(--primary);color:var(--white)}.admin-tickets-list{display:grid;gap:var(--spacing-sm)}.admin-ticket-card{padding:var(--spacing-md);background-color:var(--bg-secondary);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);border:2px solid transparent}.admin-ticket-card:hover{border-color:var(--primary);background-color:var(--gray-50)}.ticket-card-top{display:flex;gap:var(--spacing-xs);margin-bottom:var(--spacing-sm)}.ticket-title{font-size:var(--font-size-md);font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-xs)}.ticket-preview{font-size:var(--font-size-sm);color:var(--text-secondary);margin-bottom:var(--spacing-sm);line-height:1.4}.ticket-card-meta{display:flex;justify-content:space-between;font-size:var(--font-size-xs);color:var(--text-secondary)}.ticket-replies-count{display:block;margin-top:var(--spacing-xs);font-size:var(--font-size-xs);color:var(--primary)}.status-badge{display:inline-block;padding:2px 10px;font-size:var(--font-size-xs);font-weight:600;border-radius:var(--radius-full);text-transform:uppercase}.status-badge.open{background-color:#e3f2fd;color:#1976d2}.status-badge.in_progress{background-color:#fff3e0;color:#f57c00}.status-badge.resolved{background-color:#e8f5e9;color:#388e3c}.status-badge.closed{background-color:#f5f5f5;color:#757575}.priority-badge{display:inline-block;padding:2px 10px;font-size:var(--font-size-xs);font-weight:600;border-radius:var(--radius-full);text-transform:uppercase}.priority-badge.low{background-color:#e8f5e9;color:#388e3c}.priority-badge.medium{background-color:#fff3e0;color:#f57c00}.priority-badge.high{background-color:#ffebee;color:#d32f2f}.ticket-modal{padding:var(--spacing-xl);max-width:600px}.ticket-modal-header{margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-md);border-bottom:1px solid var(--gray-100)}.ticket-badges{display:flex;gap:var(--spacing-xs);margin-bottom:var(--spacing-sm)}.ticket-modal-header h2{font-size:var(--font-size-lg);font-weight:700;color:var(--text-primary);margin-bottom:var(--spacing-xs)}.ticket-meta{font-size:var(--font-size-sm);color:var(--text-secondary)}.ticket-description{background-color:var(--bg-secondary);border-radius:var(--radius-md);padding:var(--spacing-md);margin-bottom:var(--spacing-md)}.ticket-description h4{font-size:var(--font-size-sm);font-weight:600;color:var(--text-secondary);margin-bottom:var(--spacing-sm)}.ticket-description p{font-size:var(--font-size-md);color:var(--text-primary);white-space:pre-wrap;line-height:1.5}.ticket-screenshots{margin-bottom:var(--spacing-md)}.ticket-screenshots h4{font-size:var(--font-size-sm);font-weight:600;color:var(--text-secondary);margin-bottom:var(--spacing-sm)}.screenshots-grid{display:flex;gap:var(--spacing-sm);flex-wrap:wrap}.screenshots-grid img{width:100px;height:100px;object-fit:cover;border-radius:var(--radius-md);cursor:pointer;transition:transform var(--transition-fast)}.screenshots-grid img:hover{transform:scale(1.05)}.ticket-status-section{margin-bottom:var(--spacing-lg);padding:var(--spacing-md);background-color:var(--bg-secondary);border-radius:var(--radius-md)}.ticket-status-section h4{font-size:var(--font-size-sm);font-weight:600;color:var(--text-secondary);margin-bottom:var(--spacing-sm)}.status-buttons{display:flex;gap:var(--spacing-xs);flex-wrap:wrap}.status-btn{padding:var(--spacing-xs) var(--spacing-md);font-size:var(--font-size-sm);font-weight:500;background-color:var(--gray-100);color:var(--text-secondary);border-radius:var(--radius-md);text-transform:capitalize;transition:all var(--transition-fast)}.status-btn:hover{background-color:var(--gray-200)}.status-btn.active{background-color:var(--primary);color:var(--white)}.ticket-replies-section{padding:var(--spacing-md);background-color:var(--bg-secondary);border-radius:var(--radius-md)}.ticket-replies-section h4{font-size:var(--font-size-sm);font-weight:600;color:var(--text-secondary);margin-bottom:var(--spacing-md)}.replies-list{display:flex;flex-direction:column;gap:var(--spacing-sm);max-height:200px;overflow-y:auto;margin-bottom:var(--spacing-md)}.reply{padding:var(--spacing-sm);background-color:var(--bg-primary);border-radius:var(--radius-md);border-left:3px solid var(--gray-300)}.reply.admin-reply{background-color:#e3f2fd;border-left-color:#2196f3}.reply.user-reply{border-left-color:var(--primary)}.reply-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-xs);font-size:var(--font-size-xs)}.reply-header strong{color:var(--text-primary)}.reply-header span{color:var(--text-secondary)}.reply p{font-size:var(--font-size-sm);color:var(--text-primary);line-height:1.4}.reply-form{display:flex;flex-direction:column;gap:var(--spacing-sm)}.reply-form textarea{width:100%;padding:var(--spacing-sm);font-size:var(--font-size-sm);border:2px solid var(--gray-200);border-radius:var(--radius-md);resize:vertical;min-height:80px;font-family:inherit}.reply-form textarea:focus{outline:none;border-color:var(--primary)}.reply-form .btn{align-self:flex-end}.reply-form .btn:disabled{opacity:.5;cursor:not-allowed}[data-theme=dark] .admin-ticket-card,[data-theme=dark] .ticket-description,[data-theme=dark] .ticket-status-section,[data-theme=dark] .ticket-replies-section{background-color:var(--bg-tertiary)}[data-theme=dark] .reply{background-color:var(--bg-secondary)}[data-theme=dark] .reply.admin-reply,[data-theme=dark] .status-badge.open{background-color:#1a3a5c}[data-theme=dark] .status-badge.in_progress{background-color:#3d2800}[data-theme=dark] .status-badge.resolved{background-color:#1b3d1e}[data-theme=dark] .status-badge.closed{background-color:#2d2d2d}@media(min-width:768px){.admin-tickets-list{grid-template-columns:repeat(2,1fr)}.ticket-filters{flex-wrap:nowrap}}.support-page{max-width:900px;margin:0 auto;padding:2rem 1rem}.back-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#f5f5f5;border:none;border-radius:8px;font-size:.9rem;font-weight:500;color:#666;cursor:pointer;margin-bottom:1rem;transition:background .2s}.back-btn:hover{background:#e0e0e0}[data-theme=dark] .back-btn{background:#2d2d2d;color:#ccc}[data-theme=dark] .back-btn:hover{background:#3d3d3d}.support-header{text-align:center;margin-bottom:2rem}.support-header h1{font-size:2rem;margin-bottom:.5rem}.support-header p{color:#666;margin-bottom:1.5rem}.new-ticket-btn{background:#58cc02;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:background .2s}.new-ticket-btn:hover{background:#4caf00}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.ticket-form-modal,.ticket-detail-modal{background:#fff;border-radius:16px;padding:2rem;width:100%;max-width:600px;max-height:90vh;overflow-y:auto}.ticket-form-modal h2,.ticket-detail-modal h2{margin-bottom:1.5rem}.form-group{margin-bottom:1rem}.form-group label{display:block;font-weight:600;margin-bottom:.5rem;color:#333}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.75rem;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;transition:border-color .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#58cc02}.form-group textarea{resize:vertical;min-height:100px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.screenshot-previews{display:flex;gap:.5rem;margin-top:.5rem;flex-wrap:wrap}.screenshot-preview{position:relative;width:80px;height:80px}.screenshot-preview img{width:100%;height:100%;object-fit:cover;border-radius:8px}.screenshot-preview button{position:absolute;top:-8px;right:-8px;width:24px;height:24px;border-radius:50%;background:#f44336;color:#fff;border:none;cursor:pointer;font-size:14px;line-height:1}.form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:1.5rem}.cancel-btn{padding:.75rem 1.5rem;border:2px solid #e0e0e0;background:#fff;border-radius:8px;font-size:1rem;cursor:pointer}.submit-btn{padding:.75rem 1.5rem;background:#58cc02;color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer}.submit-btn:disabled{background:#ccc;cursor:not-allowed}.tickets-list{display:grid;gap:1rem}.no-tickets{text-align:center;padding:3rem;background:#f5f5f5;border-radius:16px;color:#666}.ticket-card{background:#fff;border:2px solid #e0e0e0;border-radius:12px;padding:1.25rem;cursor:pointer;transition:border-color .2s,box-shadow .2s}.ticket-card:hover{border-color:#58cc02;box-shadow:0 4px 12px #0000001a}.ticket-card-header{display:flex;gap:.5rem;margin-bottom:.75rem}.ticket-card h3{font-size:1.1rem;margin-bottom:.5rem}.ticket-preview{color:#666;font-size:.9rem;margin-bottom:.75rem}.ticket-card-footer{display:flex;justify-content:space-between;font-size:.85rem;color:#888}.replies-indicator{margin-top:.5rem;font-size:.85rem;color:#2196f3}.status-badge{padding:.25rem .75rem;border-radius:20px;font-size:.75rem;font-weight:600;text-transform:uppercase}.status-badge.open{background:#e3f2fd;color:#1976d2}.status-badge.in_progress{background:#fff3e0;color:#f57c00}.status-badge.resolved{background:#e8f5e9;color:#388e3c}.status-badge.closed{background:#f5f5f5;color:#757575}.priority-badge{padding:.25rem .75rem;border-radius:20px;font-size:.75rem;font-weight:600;text-transform:uppercase}.priority-badge.low{background:#e8f5e9;color:#388e3c}.priority-badge.medium{background:#fff3e0;color:#f57c00}.priority-badge.high{background:#ffebee;color:#d32f2f}.ticket-detail-header{display:flex;gap:.5rem;align-items:center;margin-bottom:1rem}.ticket-detail-header .close-btn{margin-left:auto;background:none;border:none;font-size:1.5rem;cursor:pointer;color:#666}.ticket-meta{color:#666;font-size:.9rem;margin-bottom:1rem}.ticket-description{background:#f5f5f5;padding:1rem;border-radius:8px;margin-bottom:1rem;white-space:pre-wrap}.ticket-screenshots h4,.ticket-replies h4{margin-bottom:.75rem}.screenshots-grid{display:flex;gap:.5rem;flex-wrap:wrap}.screenshots-grid img{width:120px;height:120px;object-fit:cover;border-radius:8px;cursor:pointer}.ticket-replies{margin-top:1.5rem}.reply{background:#f5f5f5;padding:1rem;border-radius:8px;margin-bottom:.75rem}.reply.admin-reply{background:#e3f2fd;border-left:4px solid #2196f3}.reply-header{display:flex;justify-content:space-between;margin-bottom:.5rem;font-size:.85rem}.reply-header span{color:#888}[data-theme=dark] .ticket-form-modal,[data-theme=dark] .ticket-detail-modal{background:#1e1e1e;color:#fff}[data-theme=dark] .form-group input,[data-theme=dark] .form-group select,[data-theme=dark] .form-group textarea{background:#2d2d2d;border-color:#444;color:#fff}[data-theme=dark] .ticket-card{background:#1e1e1e;border-color:#333}[data-theme=dark] .no-tickets,[data-theme=dark] .ticket-description,[data-theme=dark] .reply{background:#2d2d2d}[data-theme=dark] .reply.admin-reply{background:#1a3a5c}@media(max-width:600px){.form-row{grid-template-columns:1fr}.ticket-form-modal,.ticket-detail-modal{padding:1.5rem}}:root{--primary: #58cc02;--primary-dark: #46a302;--primary-light: #7ed321;--secondary: #1cb0f6;--secondary-dark: #0095d9;--correct: #58cc02;--incorrect: #ff4b4b;--warning: #ffc800;--white: #ffffff;--gray-50: #f7f7f7;--gray-100: #e5e5e5;--gray-200: #cccccc;--gray-300: #afafaf;--gray-400: #777777;--gray-500: #4b4b4b;--gray-600: #3c3c3c;--gray-700: #2b2b2b;--gray-800: #1a1a1a;--black: #000000;--bg-primary: #ffffff;--bg-secondary: #f7f7f7;--bg-elevated: #ffffff;--text-primary: #3c3c3c;--text-secondary: #777777;--border-color: #e5e5e5;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--spacing-2xl: 48px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .1);--shadow-button: 0 4px 0 var(--gray-200);--font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, sans-serif;--font-size-xs: 12px;--font-size-sm: 14px;--font-size-md: 16px;--font-size-lg: 18px;--font-size-xl: 24px;--font-size-2xl: 32px;--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .35s ease;--z-base: 1;--z-dropdown: 100;--z-sticky: 200;--z-modal: 300;--z-toast: 400}[data-theme=dark]{--bg-primary: #1a1a1a;--bg-secondary: #2b2b2b;--bg-elevated: #3c3c3c;--text-primary: #ffffff;--text-secondary: #afafaf;--border-color: #4b4b4b;--shadow-button: 0 4px 0 var(--gray-700)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%}body{font-family:var(--font-family);background-color:var(--bg-secondary);color:var(--text-primary);line-height:1.5;min-height:100vh;min-height:-webkit-fill-available;overflow-x:hidden;padding-top:env(safe-area-inset-top,0px);padding-left:env(safe-area-inset-left,0px);padding-right:env(safe-area-inset-right,0px)}body.no-scroll{overflow:hidden;position:fixed;width:100%}button{font-family:inherit;cursor:pointer;border:none;background:none}input{font-family:inherit}a{text-decoration:none;color:inherit}ul,ol{list-style:none}img{max-width:100%;height:auto}.app{min-height:100vh;display:flex;flex-direction:column}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.confetti-container{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:var(--z-toast);overflow:hidden}.confetti-piece{position:absolute;width:10px;height:10px;top:-20px;animation:confetti-fall linear forwards}@keyframes confetti-fall{0%{transform:translateY(0) rotate(0);opacity:1}to{transform:translateY(100vh) rotate(720deg);opacity:0}}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}::selection{background-color:var(--primary);color:var(--white)}:focus-visible{outline:2px solid var(--primary);outline-offset:2px}
