:root{--primary-color: #6366f1;--secondary-color: #f43f5e;--bg-color: #0f172a;--bg-gradient: radial-gradient(circle at top right, #1e1b4b, #0f172a);--card-bg: rgba(30, 41, 59, .7);--sidebar-bg: rgba(15, 23, 42, .95);--glass-border: rgba(255, 255, 255, .1);--glass-shadow: 0 10px 30px rgba(0, 0, 0, .5);--accent-glow: 0 0 20px rgba(99, 102, 241, .3);--accent: #6366f1;--accent-rgb: 99, 102, 241;--secondary-rgb: 244, 63, 94;--success-rgb: 34, 197, 94;--error-rgb: 239, 68, 68;--text-main: #f8fafc;--text-bright: #ffffff;--text-muted: #94a3b8;--text-dim: #94a3b8;--font-main: "Outfit", "Inter", system-ui, sans-serif;--hover-bg: rgba(255, 255, 255, .05);--scrollbar-thumb: rgba(255, 255, 255, .1);--header-gradient: linear-gradient(135deg, #fff 0%, #94a3b8 100%);--success-color: #22c55e;--error-color: #ef4444;--success-glow: 0 0 10px rgba(34, 197, 94, .5);--primary-light: #818cf8;--accent-light: #818cf8;--accent-primary: #6366f1;--bg-rgb: 15, 23, 42;--tense-glass: rgba(15, 23, 42, .7);--tense-glass-bright: rgba(30, 41, 59, .5)}[data-theme=light]{--bg-color: #f1f5f9;--bg-gradient: radial-gradient(circle at top right, #e2e8f0, #f1f5f9);--card-bg: #ffffffb3;--sidebar-bg: rgba(255, 255, 255, .95);--glass-border: rgba(0, 0, 0, .08);--glass-shadow: 0 10px 30px rgba(0, 0, 0, .05);--accent-glow: 0 0 20px rgba(99, 102, 241, .1);--accent-rgb: 99, 102, 241;--secondary-rgb: 225, 29, 72;--success-rgb: 22, 163, 74;--error-rgb: 220, 38, 38;--text-main: #0f172a;--text-bright: #000000;--text-muted: #64748b;--text-dim: #94a3b8;--hover-bg: rgba(0, 0, 0, .03);--scrollbar-thumb: rgba(0, 0, 0, .1);--header-gradient: linear-gradient(135deg, #0f172a 0%, #475569 100%);--success-color: #16a34a;--error-color: #dc2626;--success-glow: 0 0 10px rgba(22, 163, 74, .2);--primary-light: #6366f1;--accent-light: #6366f1;--accent-primary: #6366f1;--bg-rgb: 241, 245, 249;--tense-glass: #ffffffb3;--tense-glass-bright: rgba(255, 255, 255, .6)}.app-init-loader{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;background:var(--bg-color);color:var(--text-muted);font-family:var(--font-main);z-index:10000}.loader-dot{width:16px;height:16px;background:var(--primary-color);border-radius:50%;box-shadow:0 0 20px var(--primary-color)}.glass-card{background:var(--card-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--glass-border);box-shadow:var(--glass-shadow);border-radius:20px}.category-tag{display:inline-block;padding:4px 12px;border-radius:8px;font-size:.75rem;font-weight:700;background:rgba(var(--accent-rgb),.1);color:var(--primary-color);border:1px solid rgba(var(--accent-rgb),.2);margin-bottom:12px;letter-spacing:.5px}@keyframes pulse-glow{0%,to{transform:scale(1);opacity:1;box-shadow:0 0 20px var(--primary-color)}50%{transform:scale(1.1);opacity:.8;box-shadow:0 0 30px var(--primary-color)}}.pulse{animation:pulse-glow 2s infinite ease-in-out}@keyframes fadeInScale{0%{opacity:0;transform:scale(.98) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.animate-fade-in{animation:fadeInScale .6s cubic-bezier(.16,1,.3,1) forwards}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-color);color:var(--text-main);font-family:var(--font-main);min-height:100vh;display:flex;justify-content:center;align-items:flex-start;overflow-x:hidden;background:var(--bg-gradient)}#root{width:100%;min-height:100vh}.app-layout{display:flex;min-height:100vh;gap:30px;position:relative;padding:40px;max-width:1800px;margin:0 auto;width:100%}.sidebar{width:280px;height:95vh;position:sticky;top:20px;background:var(--card-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:24px;border:1px solid var(--glass-border);box-shadow:var(--glass-shadow);display:flex;flex-direction:column;padding:30px 10px 30px 20px;transition:transform .3s cubic-bezier(.4,0,.2,1);z-index:1000;overflow:hidden}.sidebar-header{margin-bottom:40px;display:flex;justify-content:space-between;align-items:center}.sidebar-logo .logo-text{font-size:1.8rem;margin-bottom:5px;text-align:left}.sidebar-logo .subtitle{font-size:.85rem;color:var(--text-muted)}.sidebar-nav{display:flex;flex-direction:column;gap:25px;flex:1;overflow-y:auto;padding-right:10px;margin-right:-10px}.sidebar-nav::-webkit-scrollbar{width:5px}.sidebar-nav::-webkit-scrollbar-track{background:transparent}.sidebar-nav::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border-radius:10px}.sidebar-nav::-webkit-scrollbar-thumb:hover{background:#6366f14d}.menu-group{display:flex;flex-direction:column;gap:12px}.menu-group-header{display:flex;align-items:center;gap:10px;padding:0 10px;font-size:.9rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted)}.menu-subitems{display:flex;flex-direction:column;gap:5px}.menu-item{display:flex;align-items:center;gap:10px;padding:12px 15px;border-radius:12px;background:transparent;color:var(--text-main);font-size:1rem;transition:all .2s ease;text-align:left;border:1px solid transparent}.menu-item:hover{background:var(--hover-bg);transform:translate(5px)}.menu-item.active{background:#6366f11a;border-color:#6366f14d;color:var(--primary-color);font-weight:700}.sidebar-settings-row{display:flex;align-items:center;gap:12px;margin-bottom:20px}.language-toggle{display:flex;background:var(--hover-bg);padding:4px;border-radius:12px;border:1px solid var(--glass-border);flex:1}.lang-btn{flex:1;padding:6px 12px;border-radius:8px;border:none;background:transparent;color:var(--text-muted);font-size:.75rem;font-weight:700;cursor:pointer;transition:all .2s ease}.lang-btn.active{background:var(--primary-color);color:var(--text-bright);box-shadow:0 4px 12px #6366f14d}.theme-toggle-sidebar{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:12px;border:1px solid var(--glass-border);background:var(--hover-bg);color:var(--text-main);cursor:pointer;transition:all .2s ease}.theme-toggle-sidebar:hover{background:var(--glass-border);transform:translateY(-2px)}.sidebar-footer{padding-top:20px;border-top:1px solid var(--glass-border)}.footer-status{display:flex;flex-direction:column;gap:5px}.status-label{font-size:.75rem;color:var(--text-muted);text-transform:uppercase}.status-indicator{display:flex;align-items:center;gap:8px;font-size:.85rem;font-weight:600}.status-indicator .dot{width:8px;height:8px;background:var(--success-color);border-radius:50%;box-shadow:var(--success-glow)}.app-content{flex:1;display:flex;flex-direction:column;gap:30px;width:100%}.app-header.compact{padding:15px 0;background:transparent;border:none}.context-title{font-size:1.2rem;font-weight:700;color:var(--text-main)}.mobile-menu-btn,.mobile-close{display:none;background:var(--hover-bg);border:1px solid var(--glass-border);color:var(--text-main);padding:10px;border-radius:12px}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:999}button{cursor:pointer;border:none;border-radius:12px;font-weight:600;transition:transform .2s cubic-bezier(.175,.885,.32,1.275),opacity .2s;font-family:inherit}button:hover{transform:scale(1.05)}button:active{transform:scale(.95)}.btn-primary{background:linear-gradient(135deg,var(--primary-color),#4f46e5);color:var(--text-bright);padding:12px 24px}.btn-secondary{background:var(--hover-bg);color:var(--text-main);border:1px solid var(--glass-border);padding:12px 24px}.btn-icon{background:var(--hover-bg);color:var(--text-main);width:44px;height:44px;display:flex;align-items:center;justify-content:center}.upload-section{text-align:center;display:flex;flex-direction:column;align-items:center;gap:20px}.upload-icon{background:#6366f11a;padding:20px;border-radius:50%}.file-label{display:inline-block;margin-top:10px}.progress-bar{width:100%;height:6px;background:var(--hover-bg);border-radius:3px;margin-bottom:20px;overflow:hidden}.progress{height:100%;background:linear-gradient(90deg,var(--primary-color),var(--secondary-color));transition:width .3s ease}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.q-badge{background:var(--primary-color);padding:4px 12px;border-radius:20px;font-size:.8rem;font-weight:700}.question-content{margin-bottom:30px}.fr-text{font-size:1.8rem;margin-bottom:8px;line-height:1.2}.en-text{color:var(--text-muted);font-size:1.1rem}.pronunciation{margin-top:15px;padding:10px;background:var(--hover-bg);border-radius:8px;font-style:italic;color:var(--primary-color)}.lang-tag{font-weight:700;color:var(--primary-color);margin-right:5px;font-style:normal}.reveal-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:10px}.answer-content{margin-top:20px;overflow:hidden}.ans-box{background:var(--hover-bg);border-radius:16px;padding:20px;border-left:4px solid var(--secondary-color)}.ans-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.ans-label{font-size:.75rem;text-transform:uppercase;letter-spacing:1px;color:var(--secondary-color);font-weight:700}.fr-text.primary{font-size:1.4rem;color:var(--text-main)}.nav-controls{display:flex;justify-content:space-between;align-items:center;margin-top:30px}.index-tracker{font-weight:600;color:var(--text-muted)}.colors-theory{display:flex;flex-direction:column;gap:20px}.theory-category-section{padding:30px}.category-header{display:flex;align-items:center;gap:12px;margin-bottom:20px;color:var(--primary-color)}.theory-desc{margin-bottom:20px;line-height:1.6;color:var(--text-muted)}.rules-list{display:flex;flex-direction:column;gap:15px}.rule-item{background:var(--hover-bg);padding:15px;border-radius:12px;border-left:3px solid var(--primary-color)}.rule-name{font-weight:700;margin-bottom:5px}.rule-desc{font-size:.95rem;color:var(--text-muted);margin-bottom:5px}.rule-ex{font-style:italic;font-size:.9rem;color:var(--primary-color)}.notable-box{margin-top:25px;display:flex;align-items:center;gap:10px;background:rgba(var(--error-rgb),.05);padding:12px 20px;border-radius:12px;color:var(--secondary-color);font-size:.9rem}.active-drill{padding:35px;min-height:450px;display:flex;flex-direction:column}.drill-progress{display:flex;align-items:center;gap:15px;flex:1;max-width:300px}.progress-bar-bg{flex:1;height:8px;background:var(--hover-bg);border-radius:10px;overflow:hidden}.progress-bar-fill{height:100%;background:var(--primary-color);transition:width .3s ease}.question-arena{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:30px}.q-text{font-size:1.8rem;text-align:center}.options-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:15px;width:100%;max-width:600px}.option-btn{padding:20px;background:var(--hover-bg);border:1px solid var(--glass-border);border-radius:16px;font-size:1.1rem;color:var(--text-main);transition:all .2s}.option-btn:hover:not(:disabled){background:var(--glass-border)}.option-btn.correct{background:rgba(var(--success-rgb),.2);border-color:var(--success-color);color:var(--success-color)}.option-btn.incorrect{background:rgba(var(--error-rgb),.2);border-color:var(--error-color);color:var(--error-color)}.feedback-box{width:100%;max-width:600px;padding:20px;border-radius:16px;display:flex;justify-content:space-between;align-items:center;animation:slideUp .3s ease}.feedback-box.correct{background:rgba(var(--success-rgb),.1);border:1px solid rgba(var(--success-rgb),.2)}.feedback-box.incorrect{background:rgba(var(--error-rgb),.1);border:1px solid rgba(var(--error-rgb),.2)}.feedback-content{display:flex;align-items:center;gap:12px}.btn-next{padding:10px 20px;background:var(--primary-color);color:var(--text-bright);border-radius:10px;display:flex;align-items:center;gap:8px}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.header-controls{display:flex;gap:15px;align-items:center}.toggle-btn.pulse{animation:pulse-glow 2s infinite}@keyframes pulse-glow{0%{box-shadow:0 0 #6c5ce766}70%{box-shadow:0 0 0 10px #6c5ce700}to{box-shadow:0 0 #6c5ce700}}.audio-only-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 0;gap:20px}.wave-animation{display:flex;align-items:center;gap:4px;height:40px}.wave-animation span{width:4px;height:20px;background:var(--primary-color);border-radius:2px;animation:wave 1s ease-in-out infinite}.wave-animation span:nth-child(2){animation-delay:.1s}.wave-animation span:nth-child(3){animation-delay:.2s}.wave-animation span:nth-child(4){animation-delay:.3s}.wave-animation span:nth-child(5){animation-delay:.4s}@keyframes wave{0%,to{height:10px;opacity:.5}50%{height:40px;opacity:1}}.play-hint{font-size:.8rem;margin-left:8px;font-weight:600}.btn-icon.large-play{padding:15px 25px;border-radius:50px;background:rgba(var(--accent-rgb),.1);border:1px solid rgba(var(--accent-rgb),.2);width:auto;height:auto}.btn-icon.large-play:hover{background:var(--primary-color);color:var(--text-bright)}.language-toggle-wrapper{margin-bottom:1.25rem}.lang-btn{flex:1;background:transparent;border:none;color:var(--text-secondary);padding:6px 0;font-size:.75rem;font-weight:700;cursor:pointer;border-radius:7px;transition:all .2s ease;letter-spacing:.5px}.lang-btn:hover{background:var(--hover-bg)}.admin-tabs{display:flex;gap:10px;margin-bottom:30px;border-bottom:1px solid var(--glass-border);padding-bottom:15px}.tab-item{display:flex;align-items:center;gap:8px;padding:10px 20px;border-radius:12px;background:transparent;color:var(--text-muted);font-size:.95rem;transition:all .2s}.tab-item:hover{background:var(--hover-bg)}.tab-item.active{background:#6366f11a;color:var(--primary-color);font-weight:700;box-shadow:0 4px 15px #6366f11a}.exam-row{display:flex;justify-content:space-between;align-items:center;padding:20px;margin-bottom:15px;transition:transform .2s}.exam-row:hover{transform:translateY(-2px);border-color:var(--primary-color)}.exam-main-info{display:flex;align-items:center;gap:15px}.exam-icon{width:44px;height:44px;background:#6366f11a;border-radius:12px;display:flex;align-items:center;justify-content:center;color:var(--primary-color)}.slug-tag{font-size:.75rem;color:var(--text-muted);font-family:monospace;background:#0003;padding:2px 6px;border-radius:4px}.exam-actions{display:flex;gap:10px}.btn-sm{padding:8px 16px;font-size:.85rem}.delete-btn:hover{background:rgba(var(--error-rgb),.1);color:var(--error-color)}.admin-question-modal{max-width:900px!important;width:95%!important}.form-sections-grid{display:grid;grid-template-columns:1fr 1fr;gap:30px;margin:20px 0}.form-section h3{font-size:.9rem;text-transform:uppercase;color:var(--primary-color);margin-bottom:15px;border-bottom:1px solid var(--glass-border);padding-bottom:5px}.options-input-grid{display:flex;flex-direction:column;gap:10px;margin-bottom:15px}.option-row{background:var(--hover-bg);padding:10px;border-radius:8px;display:flex;flex-direction:column;gap:5px}.option-row label{font-size:.7rem;font-weight:700;color:var(--text-muted)}.option-row input{font-size:.85rem;padding:6px 10px}.academic-toggle{background:var(--hover-bg)!important;border-radius:14px!important;padding:4px!important;margin:15px 0!important;display:inline-flex!important}.mode-tab{padding:8px 16px;border-radius:10px;font-size:.85rem;font-weight:600;color:var(--text-muted);transition:all .3s ease;background:transparent;border:none;cursor:pointer}.exam-flag{font-size:.65rem;font-weight:800;background:linear-gradient(135deg,#f59e0b,#d97706);color:var(--text-bright);padding:2px 6px;border-radius:4px;letter-spacing:.5px;box-shadow:0 2px 4px #d9770633}.no-tests{grid-column:1 / -1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center;gap:15px}.no-tests p{color:var(--text-muted);font-size:1.1rem}.card-meta{display:flex;align-items:center;gap:10px}.lang-btn:hover:not(.active){color:var(--text-bright);background:var(--hover-bg)}.accuracy-meter.high .accuracy-fill{background:var(--apple-green)}.reset-mastery-btn{display:flex;align-items:center;gap:6px;padding:6px 14px;background:rgba(var(--error-rgb),.1);border:1px solid rgba(var(--error-rgb),.2);border-radius:20px;color:var(--error-color);font-size:.85rem;font-weight:600;cursor:pointer;transition:all .3s ease;margin-left:auto}.reset-mastery-btn:hover:not(:disabled){background:#ef444433;border-color:#ef444466;transform:translateY(-2px);box-shadow:0 4px 12px #ef444433}.reset-mastery-btn:disabled{opacity:.5;cursor:not-allowed}.lang-btn.active{background:var(--primary);color:var(--text-bright);box-shadow:0 4px 12px #6366f14d}.italic{font-style:italic;opacity:.6}.header-main{display:flex;justify-content:space-between;align-items:center;width:100%}.view-toggle{display:flex;background:var(--hover-bg);padding:4px;border-radius:12px;border:1px solid var(--glass-border)}.toggle-btn{background:transparent;border:none;color:var(--text-muted);padding:8px 12px;border-radius:8px;cursor:pointer;display:flex;align-items:center;transition:all .3s ease}.toggle-btn.active{background:var(--primary-color);color:var(--text-bright);box-shadow:0 4px 12px #6c5ce74d}.list-view-container{width:100%;animation:fadeIn .5s ease}.list-header{margin-bottom:20px}.scroll-list{display:flex;flex-direction:column;gap:10px;max-height:70vh;overflow-y:auto;padding-right:10px}.scroll-list::-webkit-scrollbar{width:6px}.scroll-list::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border-radius:10px}.list-item{background:var(--card-bg);border:1px solid var(--glass-border);border-radius:12px;padding:15px 20px;display:flex;align-items:center;gap:20px;cursor:pointer;transition:all .2s ease}.list-item:hover{background:#ffffff12;transform:translate(5px);border-color:var(--glass-border)}.list-item.active{background:#6c5ce71a;border-color:var(--primary-color)}.item-number{font-size:.9rem;font-weight:700;color:var(--primary-color);opacity:.8;width:25px}.item-content{flex:1}.item-q{font-size:1.1rem;font-weight:600;margin-bottom:2px}.item-en{font-size:.85rem;color:var(--text-muted)}.practice-area{width:100%;display:flex;flex-direction:column;gap:30px}.card-container{width:100%;display:flex;justify-content:center}.main-card{width:100%;max-width:1200px;padding:40px;min-height:500px;display:flex;flex-direction:column}.app-main{width:100%;flex:1}.writing-container{width:100%;animation:fadeIn .5s ease}.writing-task-card{display:flex;flex-direction:column;gap:20px;position:relative}.word-indicator-badge{position:absolute;top:15px;right:15px;padding:4px 10px;border-radius:8px;font-size:.8rem;font-weight:700;display:flex;align-items:center;gap:8px;background:var(--hover-bg);border:1px solid var(--glass-border)}.word-indicator-badge.success{border-color:#4ade80;color:#4ade80}.word-indicator-badge.warning{border-color:#fbbf24;color:#fbbf24}.fr-prompt{font-size:1.1rem;line-height:1.6;margin-bottom:5px;color:var(--text-main);background:rgba(var(--accent-rgb),.05);padding:15px;border-radius:12px;border-left:4px solid var(--primary-color)}.en-prompt-small{font-size:.9rem;color:var(--text-muted);font-style:italic;margin-bottom:20px;padding-left:5px}.writing-input.loading{opacity:.7;cursor:wait}.input-wrapper{display:flex;flex-direction:column;gap:10px;position:relative}.input-loader{position:absolute;top:100px;left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:10px;z-index:10;pointer-events:none}.loader-dot.mini{width:12px;height:12px}.writing-input{width:100%;min-height:200px;background:var(--card-bg);border:1px solid var(--glass-border);border-radius:16px;padding:20px;color:var(--text-main);font-family:inherit;font-size:1.1rem;line-height:1.6;resize:vertical;transition:all .3s ease}.writing-input:focus{outline:none;background:var(--hover-bg);border-color:var(--primary-color);box-shadow:0 0 20px #6366f11a}.word-count-control{display:flex;justify-content:space-between;align-items:center;padding:0 5px}.word-metrics{display:flex;align-items:center;gap:15px;flex:1}.word-progress-container{flex:1;max-width:150px;height:6px;background:var(--hover-bg);border-radius:10px;overflow:hidden}.word-progress-bar{height:100%;background:var(--primary-color);transition:width .3s ease,background-color .3s ease}.word-progress-bar.success{background:var(--success-color)}.word-progress-bar.error{background:var(--error-color)}.count-pill{padding:4px 12px;border-radius:20px;font-size:.85rem;font-weight:700;background:var(--glass-border)}.count-pill.success{background:rgba(var(--success-rgb),.15);color:var(--success-color)}.count-pill.error{background:rgba(var(--error-rgb),.15);color:var(--error-color)}.status-icon{width:18px;height:18px}.status-icon.success{color:#4ade80}.status-icon.warning{color:#fbbf24}.status-icon.error{color:#fb7185}.keyboard-section{position:sticky;bottom:0;z-index:50;background:var(--card-bg);border-radius:16px 16px 0 0;padding:15px;border:1px solid var(--glass-border);box-shadow:0 -4px 20px #0000001f;margin-top:1rem}.keyboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;padding:0 5px;font-size:.85rem;font-weight:600;color:var(--text-muted)}.keyboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(36px,1fr));gap:8px}.key-btn,.accent-btn{background:var(--hover-bg);border:1px solid var(--glass-border);color:var(--text-main);padding:8px;border-radius:8px;font-size:1rem;font-weight:600;transition:all .2s cubic-bezier(.175,.885,.32,1.275);display:flex;align-items:center;justify-content:center;min-width:36px;height:36px}.key-btn:hover,.accent-btn:hover{background:rgba(var(--accent-rgb),.2);border-color:var(--primary-color);transform:translateY(-2px);color:var(--text-main)}.accent-bar{display:grid;grid-template-columns:repeat(auto-fit,minmax(32px,1fr));gap:6px;width:100%;padding:10px 0;margin-top:15px;border-top:1px solid var(--hover-bg)}.accent-btn{padding:4px;font-size:.9rem;min-width:32px;height:32px;background:var(--hover-bg)}.shift-btn{background:var(--glass-border);color:var(--text-bright);padding:4px 10px;border-radius:6px;font-size:.75rem;display:flex;align-items:center;gap:5px}.shift-btn.active{background:var(--primary-color)}.writing-selection-screen{display:flex;flex-direction:column;align-items:center;gap:2rem;padding:3rem 1rem;animation:fadeIn .5s ease}.writing-selection-header{text-align:center;display:flex;flex-direction:column;align-items:center;gap:.75rem}.writing-selection-header h2{font-size:1.75rem;margin:0}.writing-selection-header p{color:var(--text-muted);max-width:400px}.task-info-box{background:rgba(var(--accent-rgb),.06);border:1px solid var(--glass-border);border-radius:12px;padding:1rem 1.25rem;max-width:480px;text-align:left}.task-info-box p{margin:.5rem 0 0;font-size:.9rem;line-height:1.5;color:var(--text-main)}.task-time-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;border-radius:20px;background:var(--primary-color);color:#fff;font-size:.8rem;font-weight:600}.writing-selection-icon{color:var(--primary-color);opacity:.8}.writing-selection-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;max-width:700px;width:100%}.writing-selection-card{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:2rem;cursor:pointer;text-align:center;transition:all .3s ease}.writing-selection-card:hover{border-color:var(--primary-color);box-shadow:0 4px 24px rgba(var(--accent-rgb),.15)}.selection-card-icon{width:64px;height:64px;border-radius:50%;background:rgba(var(--accent-rgb),.1);display:flex;align-items:center;justify-content:center;color:var(--primary-color)}.writing-selection-card h3{margin:0;font-size:1.25rem}.writing-selection-card p{color:var(--text-muted);font-size:.85rem;line-height:1.5;margin:0}.selection-card-btn{padding:8px 20px;border-radius:20px;background:var(--primary-color);color:#fff;font-size:.85rem;font-weight:600;transition:all .2s}.writing-list-header{display:flex;align-items:center;gap:1rem;padding:.5rem 0;animation:fadeIn .5s ease}.writing-list-header h2{display:flex;align-items:center;gap:.5rem;margin:0;font-size:1.25rem}.writing-editor-header{display:flex;align-items:center;gap:1rem;animation:fadeIn .3s ease}.editor-header-info{display:flex;align-items:center;gap:.75rem}.writing-topic-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem;animation:fadeIn .4s ease}.writing-topic-card{display:flex;flex-direction:column;gap:.6rem;padding:1.25rem;cursor:pointer;transition:all .2s ease}.writing-topic-card:hover{border-color:var(--primary-color);box-shadow:0 4px 20px rgba(var(--accent-rgb),.12)}.topic-card-header{display:flex;justify-content:space-between;align-items:center}.topic-badge{font-size:.75rem;padding:3px 10px;border-radius:20px;background:rgba(var(--accent-rgb),.1);color:var(--primary-color);font-weight:600}.topic-index{font-size:.75rem;color:var(--text-muted);font-weight:600}.writing-topic-card h4{margin:0;font-size:1rem;line-height:1.4}.topic-prompt{font-size:.85rem;color:var(--text-muted);line-height:1.5;margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.topic-meta{font-size:.8rem;color:var(--text-muted);margin-top:auto}.exam-month-card{align-items:center;text-align:center;padding:2rem 1.25rem}.exam-month-icon{color:var(--primary-color);opacity:.8}.exam-month-card h3{margin:0;font-size:1.1rem}.exam-topic-list{grid-template-columns:1fr!important}.writing-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:4rem 1rem;text-align:center;animation:fadeIn .4s ease}.writing-empty-state p{color:var(--text-muted);font-size:1rem}.exam-documents{display:flex;flex-direction:column;gap:1rem;margin-top:.75rem}.exam-document-card{background:rgba(var(--accent-rgb),.04);border:1px solid var(--glass-border);border-radius:20px;padding:1rem 1.25rem}.exam-document-card p{margin:.5rem 0 0;font-size:.9rem;line-height:1.6;color:var(--text-main);white-space:pre-wrap}.exam-document-label{font-weight:700;font-size:.8rem;color:var(--primary-color);text-transform:uppercase;letter-spacing:.5px}.prompt-header-row{display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem}.prompt-header-row h3{margin:0;flex:1}.translation-toggle{flex-shrink:0;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--hover-bg);border:1px solid var(--glass-border);color:var(--text-muted);cursor:pointer;transition:all .2s}.translation-toggle:hover{border-color:var(--primary-color);color:var(--primary-color);background:rgba(var(--accent-rgb),.1)}.translation-toggle.active{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.writing-loading-grid{display:flex;align-items:center;justify-content:center;padding:4rem 1rem}.loading-card{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:2rem;text-align:center}.loading-card p{color:var(--text-muted)}@media (max-width: 640px){.writing-selection-cards,.writing-topic-grid{grid-template-columns:1fr}}.sample-box{background:var(--hover-bg);border-radius:16px;padding:20px;margin-top:10px;border-left:4px solid var(--secondary-color);max-height:300px;overflow-y:auto}.sample-label{font-size:.75rem;text-transform:uppercase;color:var(--secondary-color);font-weight:700;letter-spacing:1px}.sample-text{font-family:inherit;font-size:1rem;line-height:1.6;white-space:pre-wrap;color:var(--text-main);opacity:.9;margin-top:10px}.task-switcher{display:flex;background:var(--hover-bg);padding:4px;border-radius:15px;border:1px solid var(--glass-border)}.switcher-btn{background:transparent;padding:8px 16px;border-radius:12px;font-size:.9rem;color:var(--text-muted);white-space:nowrap}.switcher-btn.active{background:linear-gradient(135deg,var(--primary-color),#4f46e5);color:var(--text-bright);box-shadow:0 4px 15px #6366f14d}.btn-secondary.outline{width:100%;background:transparent;border-style:dashed;opacity:.7}.btn-secondary.outline:hover{opacity:1;background:var(--hover-bg)}.index-info{font-size:.9rem;letter-spacing:1px}.history-container{display:flex;flex-direction:column;gap:30px}.history-header{margin-bottom:20px}.history-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}.history-card{padding:20px;position:relative;display:flex;flex-direction:column;gap:15px}.category-tag{font-size:.7rem;letter-spacing:1px;text-transform:uppercase;color:var(--primary-color);font-weight:800}.entry-title{font-size:1.1rem;margin:0}.entry-meta{display:flex;gap:15px;color:var(--text-muted);font-size:.85rem}.meta-item{display:flex;align-items:center;gap:5px}.card-actions{display:flex;justify-content:space-between;align-items:center;margin-top:10px}.delete-icon-btn{background:rgba(var(--error-rgb),.1);color:var(--error-color);padding:8px;border-radius:8px}.delete-icon-btn:hover{background:#f43f5e33}.empty-state{display:flex;flex-direction:column;align-items:center;gap:15px;padding:80px 40px;text-align:center;color:var(--text-muted)}.muted-icon{opacity:.3}.hint{font-size:.85rem;font-style:italic}.detail-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000c;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:2000;display:flex;align-items:center;justify-content:center;padding:20px}.detail-modal{width:100%;max-width:800px;max-height:90vh;background:var(--bg-color);border-radius:24px;display:flex;flex-direction:column;overflow:hidden;border:1px solid var(--glass-border)}[data-theme=light] .detail-modal{background:#fff}.modal-header{padding:20px 30px;border-bottom:1px solid var(--glass-border);display:flex;justify-content:space-between;align-items:center}.modal-body{padding:30px;overflow-y:auto;display:flex;flex-direction:column;gap:20px}.prompt-recall{padding:15px;background:var(--hover-bg);border-radius:12px;border-left:4px solid var(--primary-color)}.user-content{font-size:1.1rem;line-height:1.8;white-space:pre-wrap;padding:25px;background:var(--hover-bg);border-radius:16px;min-height:200px;color:var(--text-main)}.detail-meta-footer{display:flex;justify-content:space-between;font-size:.85rem;color:var(--text-muted)}.close-btn{background:transparent;color:var(--text-bright)}.full-analysis-modal{max-width:700px}.full-analysis-body{display:flex;flex-direction:column;gap:1.5rem}.full-analysis-body .analysis-section h4{font-size:.85rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.75rem}.full-analysis-body .corrected-text{font-size:1rem;line-height:1.7;white-space:pre-wrap;padding:1.25rem;background:var(--card-bg);border-radius:12px;border-left:4px solid var(--accent);color:var(--text-main)}.full-analysis-body .score-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.full-analysis-body .score-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:var(--card-bg);border-radius:10px;font-size:.85rem}.full-analysis-body .score-item .score-val{font-weight:700;color:var(--primary-color)}.full-analysis-body .cefr-badge{display:inline-flex;padding:.35rem 1rem;background:var(--accent);color:#fff;border-radius:20px;font-weight:700;font-size:.85rem;align-self:flex-start;margin-top:.25rem}.full-analysis-body .mistake-row{padding:.6rem .75rem;border-bottom:1px solid var(--glass-border);display:flex;flex-wrap:wrap;gap:.35rem;align-items:baseline;background:var(--card-bg);border-radius:8px;margin-bottom:.25rem}.full-analysis-body .mistake-row:last-child{border-bottom:none}.full-analysis-body .mistake-original{color:var(--error-color);font-weight:600;font-size:.85rem}.full-analysis-body .mistake-arrow{color:var(--text-muted);font-size:.85rem}.full-analysis-body .mistake-correction{color:var(--accent);font-weight:600;font-size:.85rem}.full-analysis-body .mistake-explanation{width:100%;font-size:.8rem;color:var(--text-muted);margin-top:.15rem}.full-analysis-body .feedback-text{line-height:1.6;font-size:.9rem;color:var(--text-main)}.input-actions{display:flex;gap:10px;align-items:center}.save-btn{display:flex;align-items:center;gap:6px;transition:all .3s ease}.save-btn.saved{background:#22c55e!important;color:var(--text-bright)!important}.user-info-brief{padding:10px 0;margin-bottom:10px;border-bottom:1px solid var(--hover-bg)}.user-email-truncate{font-size:.8rem;color:#94a3b8;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:4px}.role-chip{font-size:.65rem;background:#6366f133;color:#6366f1;padding:2px 6px;border-radius:4px;text-transform:uppercase;font-weight:800}.logout-btn-universal{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;padding:12px;background:#f43f5e1a;color:#fb7185;font-size:.85rem;border-radius:12px;transition:all .2s;border:1px solid rgba(244,63,94,.1)}.logout-btn-universal:hover{background:#f43f5e33;transform:translateY(-2px);border-color:#f43f5e4d}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1.5rem;position:relative;overflow:hidden;background:var(--bg-color)}.login-bg{position:fixed;top:0;right:0;bottom:0;left:0;z-index:0;overflow:hidden}.login-bg-orb{position:absolute;width:500px;height:500px;border-radius:50%;filter:blur(120px);opacity:.15}.login-bg-orb.orba{top:-200px;right:-100px;background:var(--primary-color);animation:orbFloat 20s ease-in-out infinite}.login-bg-orb.orbb{bottom:-200px;left:-100px;background:#a855f7;animation:orbFloat 25s ease-in-out infinite reverse}@keyframes orbFloat{0%,to{transform:translate(0)}50%{transform:translate(40px,-40px)}}.login-card{position:relative;z-index:1;width:100%;max-width:400px;padding:2.5rem;background:var(--card-bg);border:1px solid var(--glass-border);border-radius:20px;display:flex;flex-direction:column;gap:1.25rem;animation:fadeInScale .5s ease-out}.login-logo{display:flex;align-items:center;justify-content:center;gap:.5rem;font-size:1.2rem;font-weight:800;text-decoration:none;color:var(--text-main);margin-bottom:.25rem}.login-logo-img{height:28px;width:auto}.login-logo .accent{color:var(--primary-color)}.login-header{text-align:center;display:flex;flex-direction:column;gap:.5rem}.login-header h1{font-size:1.5rem;font-weight:700;margin:0;color:var(--text-bright)}.login-header p{color:var(--text-muted);font-size:.88rem;margin:0}.login-error{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;border-radius:10px;background:rgba(var(--error-rgb),.1);border:1px solid rgba(var(--error-rgb),.2);color:var(--error-color);font-size:.85rem}.login-field{position:relative;display:flex;align-items:center;margin-bottom:.75rem}.login-field-icon{position:absolute;left:14px;color:var(--text-muted);pointer-events:none;z-index:1}.login-field input{width:100%;padding:13px 14px 13px 44px;background:var(--bg-color);border:1px solid var(--glass-border);border-radius:12px;color:var(--text-main);font-size:.92rem;transition:all .2s}.login-field input:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px rgba(var(--accent-rgb),.1);outline:none}.login-pw-toggle{position:absolute;right:12px;background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;display:flex}.login-btn{width:100%;padding:13px;font-size:.95rem;margin-top:.25rem}.login-footer-links{display:flex;gap:1rem;font-size:.85rem}.login-footer-links a{color:var(--primary-color);text-decoration:none}.login-footer-links a:hover{text-decoration:underline}.login-divider{display:flex;align-items:center;gap:.75rem;color:var(--text-dim);font-size:.8rem}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:var(--glass-border)}.login-signup-prompt{text-align:center;color:var(--text-muted);font-size:.85rem;margin:0}.login-signup-prompt a{color:var(--primary-color);text-decoration:none;font-weight:600}.login-signup-prompt a:hover{text-decoration:underline}.login-card{width:100%;max-width:420px;padding:40px;display:flex;flex-direction:column;gap:30px;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);animation:fadeInScale .6s cubic-bezier(.16,1,.3,1) forwards}.login-header{text-align:center;display:flex;flex-direction:column;align-items:center;gap:15px}.logo-icon-wrapper{width:64px;height:64px;background:#6366f11a;border-radius:20px;display:flex;align-items:center;justify-content:center;margin-bottom:5px}.login-title{font-size:2.2rem;font-weight:800;letter-spacing:-.5px;background:var(--header-gradient);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:5px}.login-subtitle{color:var(--text-muted);font-size:.95rem}.login-form{display:flex;flex-direction:column;gap:20px}.input-group{position:relative;display:flex;align-items:center}.input-icon{position:absolute;left:15px;color:var(--text-muted);pointer-events:none}.login-form input{width:100%;padding:14px 14px 14px 45px;background:var(--card-bg);border:1px solid var(--glass-border);border-radius:14px;color:var(--text-main);font-size:1rem;transition:all .3s ease}.login-form input:focus{background:var(--hover-bg);border-color:var(--primary-color);box-shadow:0 0 0 4px #6366f11a;outline:none}.login-submit{padding:14px;font-size:1rem;font-weight:700;margin-top:10px;display:flex;align-items:center;justify-content:center;gap:10px}.login-brand-footer{text-align:center;padding-top:10px}.login-brand-footer .separator{height:1px;background:linear-gradient(90deg,transparent,var(--glass-border),transparent);margin-bottom:20px}.login-brand-footer p{color:var(--text-muted);font-size:.8rem;text-transform:uppercase;letter-spacing:1px}.login-bg-elements{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0}.bg-blob{position:absolute;filter:blur(80px);border-radius:50%;opacity:.1}.blob-1{width:400px;height:400px;background:var(--primary-color);top:-100px;right:-100px;animation:float 20s infinite alternate}.blob-2{width:300px;height:300px;background:var(--secondary-color);bottom:-50px;left:-50px;animation:float 15s infinite alternate-reverse}@keyframes float{0%{transform:translate(0)}to{transform:translate(30px,30px)}}.glass-card{background:var(--card-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--glass-border);box-shadow:var(--glass-shadow)}.admin-login-btn:hover{background:var(--glass-border);color:var(--text-bright);border-style:solid}.admin-container{padding:20px;width:100%;max-width:1400px;margin:0 auto;animation:fadeIn .5s ease}.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:40px}.header-info{display:flex;align-items:center;gap:15px}.header-info h1{font-size:1.5rem;margin-bottom:2px}.stat-card{padding:20px 30px;width:fit-content;display:flex;flex-direction:column;gap:5px;margin-bottom:30px}.stat-label{font-size:.8rem;text-transform:uppercase;color:#94a3b8;letter-spacing:1px}.stat-value{font-size:2rem;font-weight:800;color:var(--primary-color)}.profiles-list{display:flex;flex-direction:column;gap:15px}.profile-row{display:flex;justify-content:space-between;align-items:center;padding:15px 25px;transition:all .2s;border-radius:20px}.profile-row:hover{transform:translate(5px);background:var(--hover-bg)}.profile-info{display:flex;align-items:center;gap:15px;flex:1}.avatar-placeholder{width:40px;height:40px;background:rgba(var(--accent-rgb),.1);border-radius:12px;display:flex;align-items:center;justify-content:center;color:var(--primary-color)}.details{display:flex;flex-direction:column}.email{font-weight:600}.admin-badge{font-size:.65rem;background:#6366f133;color:#6366f1;padding:2px 6px;border-radius:4px;text-transform:uppercase;font-weight:800;width:fit-content}.user-status{margin-top:4px}.last-seen{font-size:.75rem;color:#94a3b8;display:flex;align-items:center;gap:4px}.last-seen.online{color:var(--success-color)}.last-seen.online svg{filter:drop-shadow(0 0 5px rgba(34,197,94,.5))}.profile-times{display:flex;flex-direction:column;gap:2px}.last-signin{font-size:.75rem;color:#94a3b8;display:flex;align-items:center;gap:4px}.permissions-grid{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-start;max-width:600px}.perm-toggle{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--card-bg);border:1px solid var(--hover-bg);border-radius:10px;font-size:.8rem;color:#94a3b8;transition:all .2s}.perm-toggle.active{background:#22c55e1a;border-color:#22c55e4d;color:#4ade80}.perm-toggle:hover:not(.disabled){background:var(--glass-border);transform:translateY(-2px)}.perm-toggle.disabled{opacity:.5;cursor:not-allowed}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000c;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:2000;display:flex;align-items:center;justify-content:center;padding:20px}.modal-content{width:100%;max-width:500px;padding:40px;border-radius:32px}.form-group{display:flex;flex-direction:column;gap:8px;margin-bottom:20px}.form-group label{font-size:.9rem;font-weight:600;color:#94a3b8}.form-group input{padding:14px;background:var(--hover-bg);border:1px solid var(--glass-border);border-radius:14px;color:var(--text-bright);font-size:1rem}.checkbox-group{display:flex;gap:20px;margin:15px 0}.checkbox-group label{display:flex;align-items:center;gap:8px;font-size:.9rem;cursor:pointer}.modal-actions{display:flex;justify-content:flex-end;gap:15px;margin-top:30px}.writing-layout-grid{display:grid;grid-template-columns:1fr 400px;gap:24px;align-items:start;width:100%}.editor-main-section{min-width:0}.study-sidebar{position:sticky;top:24px;background:var(--card-bg);-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);border:1px solid var(--glass-border);border-radius:28px;height:calc(100vh - 120px);display:flex;flex-direction:column;overflow:hidden;box-shadow:0 25px 50px -12px #00000080;animation:fadeIn .6s ease-out}.sidebar-tabs{display:flex;padding:14px;gap:8px;background:var(--card-bg);border-bottom:1px solid var(--glass-border)}.tab-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:12px;border-radius:14px;font-size:.85rem;font-weight:600;color:var(--text-muted);transition:all .3s cubic-bezier(.4,0,.2,1);border:1px solid transparent;background:transparent;cursor:pointer}.tab-btn:hover{background:var(--hover-bg);color:var(--text-main)}.tab-btn.active{background:rgba(var(--accent-rgb),.15);border-color:rgba(var(--accent-rgb),.3);color:var(--primary-light);box-shadow:0 4px 12px rgba(var(--accent-rgb),.1)}.sidebar-scroll-area{flex:1;overflow-y:auto;padding:24px}.sidebar-scroll-area::-webkit-scrollbar{width:5px}.sidebar-scroll-area::-webkit-scrollbar-thumb{background:var(--glass-border);border-radius:10px}.sidebar-section{margin-bottom:28px}.section-label{display:flex;align-items:center;gap:10px;font-size:.75rem;font-weight:800;color:var(--primary-color);text-transform:uppercase;letter-spacing:.12em;margin-bottom:14px}.starter-chips{display:grid;grid-template-columns:1fr;gap:10px}.starter-chip{padding:12px 16px;background:var(--card-bg);border:1px solid var(--glass-border);border-radius:16px;font-size:.9rem;color:var(--text-main);cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);text-align:left;line-height:1.5;position:relative;overflow:hidden}.starter-chip:hover{background:rgba(var(--accent-rgb),.1);border-color:rgba(var(--accent-rgb),.4);transform:translate(5px)}.starter-chip:after{content:"+";position:absolute;right:15px;top:50%;transform:translateY(-50%);opacity:0;transition:all .2s;color:var(--primary-color);font-weight:700}.starter-chip:hover:after{opacity:1}.breakdown-item{display:flex;gap:14px;padding:16px;background:var(--hover-bg);border-left:3px solid rgba(var(--accent-rgb),.3);border-radius:0 16px 16px 0;margin-bottom:12px;font-size:.95rem;color:var(--text-main);line-height:1.6;transition:all .2s}.breakdown-item:hover{background:var(--hover-bg);border-left-color:var(--primary-color);opacity:.9}.breakdown-item span{flex-shrink:0;margin-top:2px}.sample-answer-box{background:var(--hover-bg);border:1px solid var(--glass-border);border-left:3px solid var(--accent-color);padding:1.25rem;border-radius:8px;font-size:1rem;line-height:1.7;color:var(--text-primary);white-space:pre-wrap;font-weight:400}.grammar-detail-item{margin-bottom:1.25rem;padding:1rem;background:var(--hover-bg);border-radius:10px;border:1px solid var(--glass-border);transition:all .3s ease}.grammar-detail-item:hover{background:var(--glass-border);border-color:var(--accent-light)}.grammar-rule-name{color:var(--accent-light);font-weight:600;font-size:.95rem;margin-bottom:.4rem;display:flex;align-items:center;gap:8px}.grammar-rule-name:before{content:"";display:block;width:4px;height:14px;background:var(--accent-color);border-radius:2px}.grammar-explanation{color:var(--text-secondary);font-size:.9rem;line-height:1.5;margin:0}.vocab-table-wrapper{margin-top:.5rem;border-radius:12px;overflow:hidden;border:1px solid var(--glass-border);background:var(--hover-bg)}.vocab-table{width:100%;border-collapse:collapse;font-size:.85rem}.vocab-table th{background:var(--hover-bg);color:var(--text-main);text-align:left;padding:12px 16px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;font-size:.75rem}.vocab-table td{padding:12px 16px;border-bottom:1px solid var(--glass-border);color:var(--text-muted)}.vocab-table tr:hover{background:var(--hover-bg);opacity:.8}.term-cell{font-weight:600;color:var(--accent-light)!important}.cat-badge{padding:2px 8px;border-radius:4px;font-size:.7rem;font-weight:700;text-transform:uppercase}.cat-badge.noun{background:#3498db33;color:#3498db}.cat-badge.verb{background:#2ecc7133;color:#2ecc71}.cat-badge.adj{background:#9b59b633;color:#9b59b6}.cat-badge.adv{background:#e67e2233;color:#e67e22}.meaning-cell{font-style:italic;opacity:.9}.sample-answer-box:before{content:"“";position:absolute;top:10px;left:15px;font-size:3rem;color:rgba(var(--accent-rgb),.1);font-family:serif}.useful-phrases{display:flex;flex-direction:column;gap:.75rem}.phrase-category{background:var(--card-bg);border-radius:10px;padding:.6rem .75rem}.phrase-category-title{font-size:.78rem;font-weight:700;color:var(--accent);margin-bottom:.4rem}.phrase-item{font-size:.8rem;line-height:1.6;color:var(--text-main);padding:.15rem 0 .15rem .5rem;border-left:2px solid var(--glass-border);margin-bottom:.15rem;font-style:italic}@media (max-width: 1400px){.writing-layout-grid{grid-template-columns:1fr 360px}}@media (max-width: 1100px){.writing-layout-grid{grid-template-columns:1fr}.study-sidebar{position:static;height:auto;max-height:800px}}@media (max-width: 1024px){.sidebar{width:240px}}.grammar-detail-item{background:var(--card-bg);border:1px solid var(--hover-bg);border-radius:12px;padding:12px 15px;margin-bottom:12px;transition:all .2s ease}.grammar-detail-item:hover{background:var(--hover-bg);border-color:rgba(var(--accent-rgb),.3);transform:translate(4px)}.grammar-rule-name{font-weight:700;color:var(--primary-light);font-size:.85rem;margin-bottom:4px}.writing-container{display:flex;flex-direction:column;gap:20px;width:100%}.filter-bar{display:flex;justify-content:flex-start;align-items:center;padding:12px 24px;background:rgba(var(--bg-rgb),.4);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--glass-border);border-radius:20px;animation:fadeIn .6s ease-out}.filter-group{display:flex;align-items:center;gap:15px}.filter-group label{display:flex;align-items:center;gap:8px;font-size:.85rem;font-weight:700;color:var(--primary-color);text-transform:uppercase;letter-spacing:.05em}.category-select{padding:8px 16px;background:var(--card-bg);border:1px solid var(--glass-border);border-radius:12px;color:var(--text-main);font-size:.9rem;cursor:pointer;transition:all .2s;outline:none;min-width:200px}.category-select:hover{background:var(--glass-border);border-color:#6366f166}.category-select:focus{border-color:var(--primary-color);box-shadow:0 0 0 2px rgba(var(--accent-rgb),.2)}.category-select option{background:var(--card-bg);color:var(--text-main)}.grammar-explanation{font-size:.8rem;color:var(--text-muted);line-height:1.4;margin:0}.vocab-table-wrapper{background:var(--card-bg);border:1px solid var(--hover-bg);border-radius:12px;overflow:hidden;margin-top:10px}.vocab-table{width:100%;border-collapse:collapse;font-size:.8rem}.vocab-table th{background:var(--hover-bg);padding:10px;text-align:left;color:#94a3b8;font-weight:600;border-bottom:1px solid var(--glass-border)}.vocab-table td{padding:10px;border-bottom:1px solid var(--hover-bg)}.vocab-table tr:hover{background:var(--hover-bg)}.term-cell{color:var(--text-main);font-weight:600}.meaning-cell{color:var(--text-muted)}.cat-badge{padding:2px 8px;border-radius:8px;font-size:.7rem;font-weight:700;text-transform:uppercase}.cat-badge.noun{background:#3b82f626;color:#60a5fa;border-left:3px solid #3b82f6}.cat-badge.verb{background:#10b98126;color:#34d399;border-left:3px solid #10b981}.cat-badge.adj{background:#8b5cf626;color:#a78bfa;border-left:3px solid #8b5cf6}@media (max-width: 768px){.app-layout{flex-direction:column;gap:0;padding:10px}.sidebar{position:fixed;top:0;left:0;height:100vh;border-radius:0 24px 24px 0;transform:translate(-100%);width:280px;z-index:9999;transition:transform .3s ease}.sidebar.open{transform:translate(0)}.sidebar-overlay,.mobile-menu-btn,.mobile-close{display:block}.keyboard-grid{grid-template-columns:repeat(4,1fr)}.app-content{gap:0}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.spin{display:inline-block;animation:spin 1s linear infinite}.sample-lang-label{font-size:.65rem;font-weight:800;text-transform:uppercase;letter-spacing:.05em;color:var(--primary-color);margin-bottom:8px;display:flex;align-items:center;gap:6px}.sample-lang-label:after{content:"";flex:1;height:1px;background:rgba(var(--accent-rgb),.1)}.sample-divider{height:1px;background:var(--glass-border);margin:16px 0}.sample-translation-text{font-size:.85rem;color:var(--text-muted);line-height:1.5;font-style:italic}.accuracy-badge{background:rgba(var(--accent-rgb),.15);border:1px solid rgba(var(--accent-rgb),.4);padding:8px 16px;border-radius:50px;display:flex;align-items:center;gap:10px;font-weight:700;color:var(--primary-color);box-shadow:0 0 15px rgba(var(--accent-rgb),.2)}.accuracy-value{font-size:1.2rem;background:linear-gradient(135deg,var(--primary-color),var(--primary-light));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.exam-mode-banner{background:linear-gradient(90deg,rgba(99,102,241,.1),transparent);border-left:4px solid var(--primary-color);padding:12px 20px;border-radius:8px;margin-bottom:5px;display:flex;justify-content:space-between;align-items:center}.exam-mode-info h4{font-size:.95rem;margin-bottom:4px;display:flex;align-items:center;gap:8px}.exam-mode-info p{font-size:.8rem;color:var(--text-muted)}.reference-comparison-box{background:var(--hover-bg);border-radius:16px;padding:20px;border:1px solid var(--glass-border);line-height:1.8;font-size:1.05rem}.ref-word{display:inline-block;margin-right:6px;transition:all .3s ease;color:var(--text-muted);opacity:.5}.ref-word.matched{color:var(--success-color);opacity:1;font-weight:600;transform:scale(1.05);text-shadow:0 0 10px rgba(var(--success-rgb),.3)}.ref-word.current{color:var(--primary-color);opacity:1;text-decoration:underline;text-underline-offset:4px}.exam-btn.active{background:var(--primary-color)!important;color:var(--text-bright)!important;box-shadow:0 0 20px rgba(var(--accent-rgb),.4)}.accuracy-ring-container{position:relative;width:60px;height:60px}.accuracy-ring-svg{transform:rotate(-90deg)}.accuracy-ring-circle{fill:none;stroke-width:4;stroke:var(--glass-border)}.accuracy-ring-progress{fill:none;stroke-width:4;stroke:var(--primary-color);stroke-linecap:round;transition:stroke-dashoffset .5s ease}.accuracy-text-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:.75rem;font-weight:800}.interactive-sample-answer{background:var(--card-bg);border-radius:20px;padding:24px;border:1px solid var(--glass-border);box-shadow:0 10px 30px #0003}.sample-sentence-group{margin-bottom:24px;padding:16px;background:var(--hover-bg);border-radius:16px;border:1px solid transparent;transition:all .3s ease}.sample-sentence-group:hover{background:var(--hover-bg);border-color:rgba(var(--accent-rgb),.2);transform:translate(5px);opacity:.9}.french-sentence{font-size:1.15rem;line-height:1.7;color:var(--text-main);margin-bottom:12px;font-family:Outfit,sans-serif;white-space:pre-wrap}.interactive-word{display:inline-block;cursor:pointer;transition:all .2s cubic-bezier(.175,.885,.32,1.275);border-radius:4px;padding:0 2px;position:relative}.interactive-word[data-meaning]:hover:after{content:attr(data-meaning);position:absolute;bottom:130%;left:50%;transform:translate(-50%);background:var(--primary-color);color:var(--text-bright);padding:6px 12px;border-radius:8px;font-size:.85rem;line-height:1.4;white-space:nowrap;z-index:1000;box-shadow:0 10px 25px #0006;pointer-events:none;animation:tooltipFadeIn .2s ease-out}.interactive-word[data-meaning]:hover:before{content:"";position:absolute;bottom:110%;left:50%;transform:translate(-50%);border:6px solid transparent;border-top-color:var(--primary-color);z-index:1000;pointer-events:none;animation:tooltipFadeIn .2s ease-out}@keyframes tooltipFadeIn{0%{opacity:0;transform:translate(-50%,5px)}to{opacity:1;transform:translate(-50%)}}.interactive-word.has-meaning{border-bottom:2px dotted rgba(var(--accent-rgb),.4)}.interactive-word:hover{background:rgba(var(--accent-rgb),.1);color:var(--primary-accent);transform:translateY(-1px) scale(1.02)}.interactive-word.has-meaning:hover{background:rgba(var(--accent-rgb),.15);border-bottom-color:var(--primary-accent);text-shadow:0 0 8px rgba(var(--accent-rgb),.2)}.translation-controls{display:flex;justify-content:flex-end}.btn-toggle-translation{background:transparent;border:1px solid var(--glass-border);color:var(--text-muted);font-size:.8rem;padding:6px 12px;border-radius:8px;cursor:pointer;display:flex;align-items:center;gap:6px;transition:all .2s ease}.btn-toggle-translation:hover{background:var(--primary-color);color:var(--text-bright);border-color:var(--primary-color)}.english-translation-reveal{margin-top:12px;padding:12px;background:rgba(var(--accent-rgb),.1);border-left:3px solid var(--primary-color);border-radius:0 8px 8px 0;font-size:1rem;color:var(--text-muted);font-style:italic;animation:slideDownFade .4s ease-out}@keyframes slideDownFade{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.study-material-layout{display:grid;grid-template-columns:240px 1fr;gap:24px;height:calc(100vh - 120px);padding:10px}.study-sidebar-nav{display:flex;flex-direction:column;gap:12px;padding:20px;height:fit-content}.study-nav-btn{display:flex;align-items:center;gap:12px;padding:14px 18px;border-radius:12px;background:transparent;color:var(--text-muted);border:1px solid transparent;transition:all .2s ease;font-weight:500;text-align:left}.study-nav-btn:hover{background:var(--hover-bg);color:var(--text-main)}.study-nav-btn.active{background:var(--primary-color);color:var(--text-bright);box-shadow:0 4px 15px rgba(var(--accent-rgb),.3)}.study-content-area{overflow-y:auto;padding-right:10px}.learn-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:20px}.lesson-card{padding:24px}.lesson-card h3{margin-bottom:12px;color:var(--primary-color);font-size:1.2rem}.lesson-card p{line-height:1.6;color:var(--text-muted)}.tense-chart-container{display:flex;flex-direction:column;gap:24px}.tense-selector{display:flex;overflow-x:auto;gap:10px;padding-bottom:10px}.tense-nav-item{white-space:nowrap;padding:10px 20px;border-radius:100px;background:var(--hover-bg);border:1px solid var(--glass-border);color:var(--text-muted);transition:all .2s ease}.tense-nav-item.active{background:var(--primary-color);color:var(--text-bright);border-color:var(--primary-color)}.verbs-explorer{display:flex;flex-direction:column;gap:1.5rem;max-width:1200px;margin:0 auto;animation:fadeIn .4s ease-out;padding-bottom:2rem}.sticky-controls{position:sticky;top:1rem;z-index:100;box-shadow:0 10px 30px rgba(var(--bg-rgb),.3)}.verbs-controls{padding:1.25rem;display:flex;flex-direction:column;gap:1.25rem;border-radius:20px;background:var(--card-bg);border:1px solid var(--glass-border);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);box-shadow:var(--glass-shadow)}.controls-top{display:flex;justify-content:space-between;align-items:center;gap:1.5rem}@media (max-width: 900px){.controls-top{flex-direction:column;align-items:stretch}}.search-wrapper{position:relative;flex:1}.verb-search-input{width:100%;padding:12px 12px 12px 42px;background:var(--hover-bg);border:1px solid var(--glass-border);border-radius:12px;color:var(--text-main);font-size:.95rem;transition:all .3s ease}.verb-search-input:focus{outline:none;background:var(--hover-bg);border-color:var(--primary-color);box-shadow:0 0 15px rgba(var(--accent-rgb),.15)}.study-toggles{display:flex;gap:10px}.toggle-icon-btn{display:flex;align-items:center;gap:10px;padding:10px 16px;border-radius:12px;background:var(--hover-bg);border:1px solid var(--glass-border);color:var(--text-muted);cursor:pointer;transition:all .2s cubic-bezier(.175,.885,.32,1.275);font-size:.85rem;font-weight:600;white-space:nowrap}.toggle-icon-btn:hover{background:var(--hover-bg);color:var(--text-main);transform:translateY(-2px)}.toggle-icon-btn.active{background:rgba(var(--accent-rgb),.15);border-color:var(--primary-color);color:var(--primary-color);box-shadow:0 4px 15px rgba(var(--accent-rgb),.2)}.direction-switcher{display:flex;padding:4px;background:rgba(var(--bg-rgb),.2);border-radius:14px;gap:4px;align-items:center;margin-top:-5px}.direction-btn{flex:1;padding:8px 12px;border-radius:10px;border:none;background:transparent;color:var(--text-muted);cursor:pointer;font-size:.8rem;font-weight:700;transition:all .2s;letter-spacing:.02em}.direction-btn.active{background:var(--hover-bg);color:var(--text-main)}.direction-divider{width:1px;height:16px;background:var(--glass-border)}.filter-chips-wrapper{position:relative;margin:0 -.5rem;padding:0 .5rem}.scrollable-chips{display:flex;gap:10px;overflow-x:auto;padding-bottom:8px;scrollbar-width:none;scroll-behavior:smooth;-webkit-overflow-scrolling:touch}.scrollable-chips::-webkit-scrollbar{display:none}.filter-chip{padding:8px 18px;border-radius:100px;background:var(--card-bg);border:1px solid var(--glass-border);color:var(--text-muted);font-size:.8rem;font-weight:600;cursor:pointer;transition:all .3s ease;white-space:nowrap;flex-shrink:0}.filter-chip:hover{background:var(--hover-bg);color:var(--text-main);border-color:var(--glass-border)}.filter-chip.active{background:var(--primary-color);color:var(--text-bright);border-color:var(--primary-color);box-shadow:0 4px 12px rgba(var(--accent-rgb),.4)}.verbs-stats-bar{display:flex;gap:15px;padding:0 10px;margin-bottom:-5px}.stat-pill{display:flex;align-items:center;gap:8px;padding:6px 14px;background:var(--card-bg);border:1px solid var(--glass-border);border-radius:100px;font-size:.8rem;color:var(--text-muted)}.stat-pill strong{color:var(--text-main);font-size:.9rem}.stat-pill.mastered{border-color:#fb03;color:#fb0}.verb-card{position:relative;padding:1.5rem;display:flex;flex-direction:column;gap:1.25rem;transition:all .3s cubic-bezier(.4,0,.2,1);overflow:hidden}.verb-card:hover{transform:translateY(-5px);border-color:rgba(var(--accent-rgb),.3);box-shadow:0 15px 40px #0006,0 0 20px rgba(var(--accent-rgb),.1)}.verb-card-header{display:flex;justify-content:space-between;align-items:flex-start}.verb-identity{display:flex;flex-direction:column;gap:.4rem}.verb-name{font-size:1.5rem;font-weight:800;color:var(--text-main);text-align:left;border:none;padding:0;margin:0;letter-spacing:-.02em}.pronunciation-punjabi{font-size:.85rem;color:var(--accent-light);font-weight:500;opacity:.9;letter-spacing:.02em}.verb-tag{font-size:.65rem;font-weight:800;padding:3px 10px;border-radius:6px;letter-spacing:.05em;width:fit-content;background:var(--hover-bg);color:var(--text-muted);border:1px solid var(--glass-border)}.verb-tag.group-er{color:#818cf8;border-color:#818cf84d}.verb-tag.group-ir{color:#f472b6;border-color:#f472b64d}.verb-tag.group-re{color:#fbbf24;border-color:#fbbf244d}.verb-tag.irregular{border-style:dashed;color:#f87171}.card-actions{display:flex;gap:8px}.audio-btn,.mastery-btn{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;background:var(--hover-bg);border:1px solid var(--glass-border);color:var(--text-muted);cursor:pointer;transition:all .2s}.audio-btn:hover{background:var(--primary-color);color:var(--text-bright);border-color:var(--primary-color)}.perfect-match-badge{display:inline-flex;align-items:center;gap:6px;margin-top:10px;padding:4px 10px;background:rgba(var(--success-rgb),.1);border:1px solid rgba(var(--success-rgb),.2);border-radius:20px;color:var(--success-color);font-size:.8rem;font-weight:600}.writing-icon-hint{display:flex;align-items:center;gap:8px;color:var(--primary);font-size:.85rem;font-weight:600;opacity:.8}.verb-content{display:flex;flex-direction:column;gap:1rem}.verb-meaning{font-size:1.1rem;font-weight:500;color:var(--text-main);line-height:1.4}.reveal-mini-btn{margin-top:.5rem;width:100%;padding:.6rem;border-radius:12px;background:rgba(var(--accent-rgb),.1);border:1px solid rgba(var(--accent-rgb),.2);color:var(--primary-color);font-size:.85rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.5rem;transition:all .2s}.reveal-mini-btn:hover{background:var(--primary-color);color:var(--text-bright)}.verb-example.blurred{filter:blur(4px);opacity:.4;pointer-events:none;transition:all .4s}.example-fr{font-style:italic;font-size:.95rem;margin-bottom:.3rem;color:var(--text-main);opacity:.9}.example-en{font-size:.85rem;opacity:.6}.no-results{grid-column:1 / -1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem;gap:1.5rem;color:var(--text-muted);opacity:.4;text-align:center}.tense-details-glass{background:var(--card-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:24px;padding:30px}.tense-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin:30px 0}.info-card{background:var(--card-bg);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--glass-border);border-radius:20px;padding:1.5rem}.info-card h3{font-size:.9rem;text-transform:uppercase;letter-spacing:1px;margin-bottom:8px;opacity:.8}.conjugation-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:20px;margin-top:20px}.conj-column{background:var(--hover-bg);padding:15px;border-radius:12px}.verb-name{color:var(--secondary-color);margin-bottom:15px;text-align:center;border-bottom:1px solid var(--glass-border);padding-bottom:8px}.conj-row{padding:4px 0;font-family:Outfit,sans-serif;font-size:.95rem}.flashcards-topics-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:20px}.topic-card{padding:30px;text-align:center;position:relative}.topic-icon{background:rgba(var(--accent-rgb),.1);width:60px;height:60px;border-radius:20px;display:flex;align-items:center;justify-content:center;margin:0 auto 20px}.flashcard-player{max-width:600px;margin:0 auto}.card-scene{height:350px;perspective:1000px;margin:40px 0;cursor:pointer}.flashcard-inner{position:relative;width:100%;height:100%;transform-style:preserve-3d}.card-face{position:absolute;width:100%;height:100%;backface-visibility:hidden;display:flex;flex-direction:column;align-items:center;justify-content:center;border-radius:20px;background:var(--card-bg);border:1px solid var(--glass-border);padding:40px;text-align:center}.card-back{transform:rotateY(180deg);background:var(--primary-color)}.card-face h2{font-size:2.5rem;margin-bottom:20px}.tap-hint{font-size:.85rem;opacity:.6;text-transform:uppercase;letter-spacing:1px}.player-controls{display:flex;align-items:center;justify-content:space-between}.progress-dots{display:flex;gap:6px}.dot{width:8px;height:8px;border-radius:50%;background:var(--glass-border);transition:all .3s ease}.dot.active{background:var(--primary-color);transform:scale(1.4)}.quiz-engine{padding:30px}.quiz-options{display:flex;flex-direction:column;gap:12px;margin-top:30px}.opt-btn{padding:16px 24px;border-radius:16px;background:var(--hover-bg);border:1px solid var(--glass-border);color:var(--text-main);text-align:left;transition:all .2s ease;font-size:1.05rem}.opt-btn:hover:not(:disabled){background:var(--hover-bg);border-color:rgba(var(--accent-rgb),.3);opacity:.9}.opt-btn.correct{background:rgba(var(--success-rgb),.1);border-color:var(--success-color);color:var(--success-color)}.opt-btn.wrong{background:rgba(var(--error-rgb),.1);border-color:var(--error-color);color:var(--error-color)}.quiz-feedback{margin-top:24px;padding:20px;border-radius:16px;animation:slideUpFade .3s ease-out}.quiz-feedback.correct{background:rgba(var(--success-rgb),.05);border:1px solid rgba(var(--success-rgb),.2)}.quiz-feedback.wrong{background:rgba(var(--error-rgb),.05);border:1px solid rgba(var(--error-rgb),.2)}@media (max-width: 992px){.study-material-layout{grid-template-columns:1fr;height:auto}.study-sidebar-nav{flex-direction:row;overflow-x:auto;padding:10px}}.theory-grid-container{display:flex;flex-direction:column;gap:30px;padding:10px}.theory-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:20px}.theory-card{padding:24px;display:flex;flex-direction:column;gap:15px;transition:all .3s cubic-bezier(.4,0,.2,1);border:1px solid var(--glass-border);background:var(--card-bg);border-radius:16px}.theory-card:hover{background:var(--card-bg);border-color:rgba(var(--accent-rgb),.4);transform:translateY(-4px);box-shadow:0 10px 30px -10px #00000080;opacity:.95}.theory-card-header{display:flex;align-items:center;gap:12px}.theory-icon-box{width:40px;height:40px;background:rgba(var(--accent-rgb),.1);border-radius:10px;display:flex;align-items:center;justify-content:center;color:var(--primary-color)}.theory-card h3{font-size:1.25rem;margin:0;color:var(--text-main)}.theory-desc{color:var(--text-muted);font-size:.95rem;line-height:1.5}.theory-items-grid{display:flex;flex-wrap:wrap;gap:8px}.theory-item-tag{background:var(--hover-bg);padding:6px 12px;border-radius:8px;border:1px solid var(--glass-border);display:flex;flex-direction:column;align-items:center;min-width:80px}.theory-item-tag .fr{font-weight:700;color:var(--primary-color)}.theory-item-tag .en{font-size:.75rem;color:var(--text-muted)}.theory-rules-list{display:flex;flex-direction:column;gap:12px}.theory-rule-box{background:rgba(var(--bg-rgb),.2);padding:12px;border-radius:10px;border-left:3px solid var(--primary-color)}.theory-rule-box .rule-name{font-weight:700;font-size:.85rem;margin-bottom:4px;color:var(--primary-light)}.theory-rule-box .rule-text{font-size:.9rem;color:var(--text-muted);margin-bottom:6px}.theory-rule-box .rule-ex code{font-family:inherit;color:var(--secondary-color);font-weight:600}.structure-alert{background:rgba(var(--success-rgb),.1);border:1px solid rgba(var(--success-rgb),.2);padding:10px 15px;border-radius:8px;color:var(--success-color);display:flex;align-items:center;gap:10px;font-size:.9rem}.date-builder-section{margin-top:20px;padding:30px;background:linear-gradient(135deg,#6366f10d,#a855f70d);border-radius:20px}.builder-controls{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-bottom:30px}.control-group{display:flex;flex-direction:column;gap:10px}.control-group label{font-weight:700;color:var(--text-muted);font-size:.85rem;text-transform:uppercase;letter-spacing:.5px}.date-builder-section select,.date-builder-section input{background:rgba(var(--bg-rgb),.6);border:1px solid var(--glass-border);color:var(--text-main);padding:12px;border-radius:10px;outline:none;transition:border-color .2s}.date-builder-section select:focus,.date-builder-section input:focus{border-color:var(--primary-color)}.builder-result{background:rgba(var(--bg-rgb),.2);padding:24px;border-radius:16px;text-align:center;border:1px dashed var(--glass-border)}.result-label{font-size:.85rem;color:var(--text-muted);margin-bottom:10px}.result-text.highlight{font-size:2rem;font-weight:800;background:linear-gradient(to right,var(--primary-color),#a855f7);-webkit-background-clip:text;-webkit-text-fill-color:transparent;text-shadow:0 4px 10px rgba(0,0,0,.2)}.quiz-selector{display:flex;gap:10px;overflow-x:auto;padding-bottom:10px}.mode-tab{padding:8px 16px;border-radius:20px;background:var(--hover-bg);border:1px solid var(--glass-border);color:var(--text-muted);white-space:nowrap;font-size:.85rem;transition:all .2s}.mode-tab.active{background:var(--primary-color);color:var(--text-bright);border-color:var(--primary-color);box-shadow:0 4px 12px #6366f14d}.difficulty-tag{position:absolute;top:15px;right:15px;font-size:.7rem;font-weight:800;text-transform:uppercase;background:#0000004d;padding:4px 10px;border-radius:6px;color:#94a3b8;border:1px solid var(--glass-border)}.translation-q{display:flex;flex-direction:column;align-items:center;gap:15px;padding:20px}.translation-q .en-text{font-size:1.5rem;font-weight:600;color:var(--text-bright)}.translation-q .fr-placeholder{font-size:.9rem;color:var(--text-muted);font-style:italic}@media (max-width: 640px){.result-text.highlight{font-size:1.5rem}.theory-grid{grid-template-columns:1fr}}.subjunctive-module{display:flex;flex-direction:column;gap:30px;animation:fadeIn .5s ease}.module-nav{display:flex;gap:15px;background:var(--hover-bg);padding:8px;border-radius:16px;border:1px solid var(--glass-border);width:fit-content}.nav-tab{display:flex;align-items:center;gap:8px;padding:10px 20px;border-radius:12px;background:transparent;color:var(--text-muted);font-weight:600;transition:all .3s ease}.nav-tab.active{background:var(--primary-color);color:var(--text-bright);box-shadow:0 4px 15px rgba(var(--accent-rgb),.3)}.subjunctive-theory{display:flex;flex-direction:column;gap:20px}.theory-block{padding:25px;display:flex;flex-direction:column;gap:15px}.theory-block h3{display:flex;align-items:center;gap:10px;color:var(--primary-color)}.structure-code{background:rgba(var(--bg-rgb),.3);padding:15px;border-radius:12px;font-family:Courier New,Courier,monospace;color:var(--secondary-color);font-size:1.1rem;text-align:center;border:1px dashed rgba(var(--secondary-rgb),.3)}.examples-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px}.example-item{padding:20px;position:relative}.trigger-badge{position:absolute;top:15px;right:15px;background:rgba(var(--error-rgb),.1);color:var(--secondary-color);padding:4px 10px;border-radius:8px;font-size:.75rem;font-weight:700;border:1px solid rgba(var(--error-rgb),.2)}.verbs-grid-subj{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:20px}.verb-card-subj{padding:20px}.verb-card-subj h4{color:var(--primary-color);font-size:1.2rem;margin-bottom:15px;text-transform:capitalize;border-bottom:1px solid var(--glass-border);padding-bottom:10px}.conj-row{display:flex;justify-content:space-between;padding:6px 0;border-bottom:1px solid var(--glass-border)}.conj-row .subject{color:var(--text-muted);font-size:.9rem}.conj-row .verb{font-weight:600;color:var(--text-main)}.drill-card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px}.drill-card{padding:30px;display:flex;flex-direction:column;align-items:center;gap:15px;text-align:center}.drill-card .icon-box{background:rgba(var(--accent-rgb),.1);padding:15px;border-radius:50%;color:var(--primary-color)}.difficulty{font-size:.7rem;padding:4px 10px;border-radius:20px;text-transform:uppercase;font-weight:800}.difficulty.easy{background:rgba(var(--success-rgb),.1);color:var(--success-color)}.difficulty.medium{background:rgba(var(--secondary-rgb),.1);color:var(--secondary-color)}.difficulty.hard{background:rgba(var(--error-rgb),.1);color:var(--error-color)}.active-drill{padding:40px;max-width:800px;margin:0 auto;width:100%}.drill-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:40px}.drill-progress{display:flex;align-items:center;gap:15px;flex:1}.progress-bar-bg{flex:1;height:8px;background:var(--hover-bg);border-radius:4px;overflow:hidden}.progress-bar-fill{height:100%;background:var(--primary-color);transition:width .3s ease;box-shadow:0 0 10px var(--primary-color)}.review-badge{background:var(--secondary-color);color:#000;padding:4px 12px;border-radius:20px;font-size:.8rem;font-weight:800}.question-arena{display:flex;flex-direction:column;gap:30px}.input-group-subj{display:flex;flex-direction:column;gap:15px}.input-group-subj input{background:var(--hover-bg);border:1px solid var(--glass-border);padding:15px 20px;border-radius:12px;color:var(--text-bright);font-size:1.1rem;outline:none;transition:border-color .3s ease}.input-group-subj input:focus{border-color:var(--primary-color)}.options-grid{display:grid;grid-template-columns:1fr 1fr;gap:15px}.option-btn{padding:15px;background:var(--hover-bg);border:1px solid var(--glass-border);color:var(--text-main);font-size:1rem;transition:all .2s ease}.option-btn:hover:not(:disabled){background:var(--hover-bg);opacity:.9}.option-btn.correct{background:var(--success-color);border-color:var(--success-color);color:var(--text-bright)}.option-btn.incorrect{background:var(--error-color);border-color:var(--error-color);color:var(--text-bright)}.feedback-box{display:flex;align-items:center;gap:15px;padding:20px;border-radius:16px;margin-top:20px}.feedback-box.correct{background:rgba(var(--success-rgb),.1);color:var(--success-color);border:1px solid rgba(var(--success-rgb),.2)}.feedback-box.incorrect{background:rgba(var(--error-rgb),.1);color:var(--error-color);border:1px solid rgba(var(--error-rgb),.2)}.feedback-box p{flex:1;font-weight:600}.btn-next{background:var(--text-main);color:var(--bg-main);padding:8px 16px;display:flex;align-items:center;gap:8px;font-size:.9rem}.drill-results{text-align:center;padding:60px;max-width:600px;margin:0 auto;display:flex;flex-direction:column;gap:30px}.accent-icon{color:var(--primary-color);margin:0 auto;filter:drop-shadow(0 0 10px var(--primary-color))}.final-score{display:flex;align-items:baseline;justify-content:center;gap:10px}.score-num{font-size:4rem;font-weight:900;color:var(--text-main)}.score-total{font-size:1.5rem;color:var(--text-muted)}.articles-module .grid-2-col{display:grid;grid-template-columns:1fr 1fr;gap:20px}.margin-top{margin-top:20px}.theory-pill{display:flex;flex-direction:column;background:var(--hover-bg);padding:12px 20px;border-radius:12px;border:1px solid var(--glass-border);transition:all .3s ease}.theory-pill.highlighted{border-color:var(--primary-color);background:rgba(var(--accent-rgb),.05)}.pill-fr{font-size:1.2rem;font-weight:800;color:var(--text-main)}.pill-type{font-size:.75rem;color:var(--text-muted);text-transform:uppercase}.pill-ex{font-size:.85rem;color:var(--primary-color);font-style:italic}.contraction-table{background:rgba(var(--bg-rgb),.2);border-radius:16px;overflow:hidden;border:1px solid var(--glass-border)}.table-header,.table-row{display:grid;grid-template-columns:1fr 1fr 1.5fr;padding:12px 20px;border-bottom:1px solid var(--glass-border)}.table-header{background:var(--hover-bg);font-weight:800;font-size:.8rem;text-transform:uppercase;color:var(--primary-color)}.contraction-table .combo{color:var(--text-muted)}.contraction-table .result{font-weight:800;color:var(--text-bright);background:rgba(var(--accent-rgb),.2);padding:2px 8px;border-radius:6px;width:fit-content}.contraction-table .ex{color:var(--text-main);font-style:italic}.note-box{display:flex;align-items:center;gap:12px;background:rgba(var(--secondary-rgb),.1);padding:15px;border-radius:12px;border:1px solid rgba(var(--secondary-rgb),.2)}.note-box p{color:var(--secondary-color);font-size:.9rem;margin:0}.neg-ex-row{display:flex;align-items:center;gap:15px;padding:10px;background:var(--hover-bg);border-radius:8px}.neg-ex-row .pos{color:var(--success-color)}.neg-ex-row .neg{color:var(--error-color);font-weight:700}.main-summary-table{width:100%;overflow-x:auto}.main-summary-table table{width:100%;border-collapse:collapse}.main-summary-table th,.main-summary-table td{padding:15px;text-align:center;border:1px solid var(--glass-border)}.main-summary-table th{background:var(--hover-bg);color:var(--primary-color);font-size:.8rem;text-transform:uppercase}.main-summary-table td{font-weight:600;color:var(--text-main)}.feedback-content{display:flex;align-items:center;gap:12px;flex:1}.smart-hint-zone{margin-bottom:20px}.btn-hint{display:flex;align-items:center;gap:8px;background:rgba(var(--secondary-rgb),.1);color:var(--secondary-color);padding:8px 16px;border-radius:10px;font-size:.85rem;font-weight:700;border:1px solid rgba(var(--secondary-rgb),.2)}.hint-bubble{background:rgba(var(--secondary-rgb),.05);border-left:4px solid var(--secondary-color);padding:12px 20px;border-radius:4px 12px 12px 4px}.hint-bubble p{margin:0;font-size:.95rem;color:var(--text-main)}.cat-badge{font-size:.7rem;text-transform:uppercase;font-weight:800;padding:2px 8px;border-radius:4px}.cat-badge.movement{background:#6366f1;color:var(--text-bright)}.cat-badge.possession{background:#8b5cf6;color:var(--text-bright)}.cat-badge.food{background:#10b981;color:var(--text-bright)}.cat-badge.negation{background:#ef4444;color:var(--text-bright)}.cat-badge.basic{background:#94a3b8;color:var(--text-bright)}.drill-status-badges{display:flex;gap:10px;align-items:center}.trans-q{margin-bottom:20px}.en-hint{display:block;font-size:.9rem;color:var(--text-muted);margin-bottom:10px;font-style:italic}.articles-module .theory-category-section{margin-bottom:40px}.articles-module .category-header{display:flex;align-items:center;gap:12px;margin-bottom:20px;padding-bottom:10px;border-bottom:1px solid var(--glass-border)}.articles-module .category-header h2{font-size:1.4rem;color:var(--primary-color);margin:0}.articles-module .grid-2-col{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:20px}.articles-module .theory-block{padding:24px;display:flex;flex-direction:column;gap:15px;transition:all .3s ease}.articles-module .theory-block:hover{border-color:rgba(var(--accent-rgb),.4);transform:translateY(-4px);background:var(--card-bg);opacity:.9}.articles-module .theory-block.span-2{grid-column:span 2}.articles-module .block-header{display:flex;justify-content:space-between;align-items:flex-start;gap:15px}.articles-module .block-header h3{font-size:1.1rem;color:var(--text-main);margin:0}.articles-module .exam-tip-badge{background:rgba(var(--secondary-rgb),.1);color:var(--secondary-color);padding:4px 10px;border-radius:8px;font-size:.75rem;font-weight:800;display:flex;align-items:center;gap:6px;border:1px solid rgba(var(--secondary-rgb),.2);white-space:nowrap}.articles-module .theory-desc{font-size:.95rem;color:var(--text-muted);line-height:1.5}.articles-module .theory-items{display:flex;flex-wrap:wrap;gap:10px}.articles-module .theory-pill{background:var(--hover-bg);border:1px solid var(--glass-border);border-radius:12px;padding:10px 15px;display:flex;flex-direction:column;gap:2px;min-width:120px}.articles-module .pill-fr{font-size:1.1rem;font-weight:700;color:var(--primary-color)}.articles-module .pill-type{font-size:.75rem;color:var(--text-muted);font-weight:600}.articles-module .pill-usage{font-size:.8rem;color:var(--primary-light);font-weight:600}.articles-module .pill-ex{font-size:.85rem;font-style:italic;opacity:.8}.articles-module .contraction-table{background:rgba(var(--bg-rgb),.2);border-radius:12px;overflow:hidden;border:1px solid var(--glass-border)}.articles-module .table-header{display:grid;grid-template-columns:1fr 1fr 2fr;background:var(--hover-bg);padding:10px 15px;font-size:.75rem;font-weight:800;color:var(--text-muted);letter-spacing:.5px}.articles-module .table-row{display:grid;grid-template-columns:1fr 1fr 2fr;padding:12px 15px;border-top:1px solid var(--glass-border);font-size:.95rem;align-items:center}.articles-module .table-row span:nth-child(2){color:var(--primary-color);font-weight:700}.articles-module .negation-examples{display:flex;flex-direction:column;gap:10px}.articles-module .neg-ex-row{display:flex;align-items:center;gap:15px;background:var(--hover-bg);padding:10px 15px;border-radius:10px;font-size:.9rem}.articles-module .neg-ex-row .pos{color:var(--success-color)}.articles-module .neg-ex-row .neg{color:var(--error-color);font-weight:600}.articles-module .rules-list{display:flex;flex-direction:column;gap:15px}.articles-module .rule-item{border-left:3px solid var(--primary-color);padding-left:15px;display:flex;flex-direction:column;gap:4px}.articles-module .rule-name{font-weight:700;color:var(--text-main)}.articles-module .rule-desc{font-size:.9rem;color:var(--text-muted)}.articles-module .rule-ex{font-size:.85rem;color:var(--primary-light);font-style:italic}.articles-module .theory-rule-highlight{background:rgba(var(--accent-rgb),.1);padding:10px 15px;border-radius:8px;font-size:.9rem;font-weight:600;color:var(--text-main);border-left:4px solid var(--primary-color)}.articles-module .theory-tip-text{font-size:.85rem;font-style:italic;color:var(--secondary-color);opacity:.9}.articles-module .exception-box{background:rgba(var(--error-rgb),.1);border:1px solid rgba(var(--error-rgb),.2);padding:12px 15px;border-radius:10px;color:var(--error-color);font-size:.9rem;display:flex;align-items:flex-start;gap:10px}.articles-module .main-summary-table{background:rgba(var(--bg-rgb),.2);border-radius:20px;padding:10px}.articles-module .main-summary-table th{border:none;font-size:.75rem;padding:20px 10px}.articles-module .main-summary-table td{border-color:var(--glass-border);padding:20px 10px}@media (max-width: 1024px){.articles-module .theory-block.span-2{grid-column:span 1}}@media (max-width: 768px){.articles-module .grid-2-col{grid-template-columns:1fr}.articles-module .table-header,.articles-module .table-row{grid-template-columns:1fr 1fr}.articles-module .table-header span:last-child,.articles-module .table-row span:last-child{display:none}}.family-friends-module{max-width:900px;margin:0 auto;padding:1.5rem}.module-nav{display:flex;justify-content:center;gap:1rem;margin-bottom:2.5rem;background:var(--hover-bg);padding:.5rem;border-radius:12px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.module-nav button{display:flex;align-items:center;gap:.6rem;padding:.8rem 1.5rem;border:none;background:transparent;color:var(--text-dim);border-radius:8px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);font-weight:500}.module-nav button.active{background:var(--bg-card);color:var(--text-main);box-shadow:0 4px 15px #0003;transform:translateY(-1px)}.module-nav button:hover:not(.active){color:var(--accent);background:var(--hover-bg)}.flashcard-container{display:flex;flex-direction:column;align-items:center;gap:2rem;perspective:1200px}.difficulty-selector{display:flex;gap:.5rem}.diff-pill{padding:.4rem 1rem;border-radius:20px;border:1px solid var(--glass-border);background:transparent;color:var(--text-muted);font-size:.85rem;cursor:pointer;transition:.3s}.diff-pill.active{background:var(--primary-color);color:var(--text-bright);border-color:var(--primary-color)}.flashcard{width:100%;max-width:400px;height:300px;cursor:pointer;position:relative;transform-style:preserve-3d;transition:transform .6s cubic-bezier(.4,0,.2,1)}.flashcard-front,.flashcard-back{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;backface-visibility:hidden;-webkit-backface-visibility:hidden;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:2rem;text-align:center;border-radius:20px}.flashcard-back{transform:rotateY(180deg)}.fr-word{font-size:2.5rem;font-weight:700;margin-bottom:1rem;color:var(--text-main);text-shadow:0 4px 10px rgba(0,0,0,.2)}.en-word{font-size:2.2rem;font-weight:600;color:var(--accent)}.article-tag{position:absolute;top:1.5rem;left:50%;transform:translate(-50%);font-weight:900;font-size:1.2rem;opacity:.8;letter-spacing:1px}.pronunciation-toggle{display:flex;background:rgba(var(--bg-rgb),.2);padding:4px;border-radius:20px;margin:1.5rem 0 1rem}.pronunciation-toggle button{padding:4px 12px;border-radius:15px;border:none;background:transparent;color:var(--text-dim);font-size:.75rem;cursor:pointer}.pronunciation-toggle button.active{background:var(--hover-bg);color:var(--text-main)}.pronunciation-text{font-size:1.1rem;color:var(--text-dim);font-style:italic}.flip-hint{position:absolute;bottom:1.5rem;font-size:.8rem;color:var(--text-dim);display:flex;align-items:center;gap:.5rem;opacity:.6}.article-tip{margin-top:2rem;padding:1rem;background:var(--hover-bg);border-radius:8px;display:flex;align-items:flex-start;gap:.8rem;font-size:.9rem;line-height:1.4;text-align:left}.flashcard-controls{display:flex;align-items:center;gap:2rem;margin-top:1rem}.flashcard-controls .count{font-weight:600;color:var(--text-dim);min-width:80px;text-align:center}.quiz-mode-selector{display:flex;overflow-x:auto;gap:.5rem;margin-bottom:2rem;padding-bottom:.5rem}.mode-tab{white-space:nowrap;padding:.6rem 1.2rem;border-radius:8px;border:1px solid var(--glass-border);background:transparent;color:var(--text-muted);cursor:pointer;transition:.2s}.mode-tab.active{background:rgba(var(--accent-rgb),.15);border-color:var(--accent);color:var(--accent)}.quiz-card{padding:3rem 2rem;text-align:center;min-height:400px;display:flex;flex-direction:column;justify-content:center}.quiz-q h3{font-size:1.8rem;margin-bottom:3rem;color:var(--text-main)}.options-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.option-btn{padding:1.2rem;border-radius:12px;border:2px solid var(--glass-border);background:var(--hover-bg);color:var(--text-main);font-size:1.1rem;cursor:pointer;transition:.3s}.option-btn:hover:not(:disabled){background:var(--hover-bg);border-color:var(--primary-color);opacity:.9}.option-btn.selected{background:rgba(var(--accent-rgb),.2);border-color:var(--accent)}.feedback-box{margin-top:2rem;padding:1rem;border-radius:8px;display:flex;align-items:center;gap:1rem;animation:slideUp .3s ease}.feedback-box.correct{background:rgba(var(--success-rgb),.15);color:var(--success-color);border-left:4px solid var(--success-color)}.feedback-box.incorrect{background:rgba(var(--error-rgb),.15);color:var(--error-color);border-left:4px solid var(--error-color)}.btn-next{margin-left:auto;display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--primary-color);color:var(--text-bright);border:none;border-radius:6px;font-weight:600;cursor:pointer}.builder-container{padding:2.5rem;text-align:center}.builder-header{display:flex;align-items:center;justify-content:center;gap:.8rem;margin-bottom:1.5rem;color:var(--accent)}.builder-en{font-size:1.3rem;color:var(--text-dim);margin-bottom:3rem;font-style:italic}.builder-slots{min-height:80px;border-bottom:2px solid var(--glass-border);margin-bottom:3rem;display:flex;flex-wrap:wrap;justify-content:center;gap:.8rem;padding-bottom:1rem}.word-pill{padding:.8rem 1.5rem;background:var(--hover-bg);border:1px solid var(--glass-border);border-radius:50px;cursor:pointer;transition:.2s;-webkit-user-select:none;user-select:none}.word-pill:hover{background:var(--hover-bg);border-color:var(--primary-color);transform:translateY(-2px)}.word-pill.active{background:var(--primary-color);color:var(--text-bright);border-color:var(--primary-color)}.builder-options{display:flex;flex-wrap:wrap;justify-content:center;gap:.8rem}.builder-actions{display:flex;justify-content:center;gap:1rem;margin-top:4rem}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 640px){.options-grid{grid-template-columns:1fr}.quiz-card{padding:1.5rem 1rem}.fr-word{font-size:1.8rem}}} .btn-next-drill{padding:10px 20px;background:var(--primary-color);color:var(--text-bright);border:none;border-radius:10px;font-weight:600;display:flex;align-items:center;gap:8px;cursor:pointer}@media (max-width: 768px){.vocab-row{flex-direction:column;align-items:flex-start;gap:10px}.vocab-pronunciation{text-align:left;align-items:flex-start}}.accuracy-indicator{margin-top:1rem;display:flex;flex-direction:column;gap:.5rem}.accuracy-bar-bg{height:6px;background:var(--hover-bg);border-radius:10px;overflow:hidden;border:1px solid var(--glass-border)}.accuracy-bar-fill{height:100%;border-radius:10px;transition:width .3s cubic-bezier(.4,0,.2,1),background-color .3s}.accuracy-percent{font-size:.75rem;font-weight:700;color:var(--text-muted);text-align:right;font-variant-numeric:tabular-nums}.accuracy-percent.perfect{color:var(--success-color)}.exam-card{padding:24px;display:flex;flex-direction:column;gap:1.2rem;border:1px solid var(--glass-border);background:var(--card-bg);border-radius:20px;transition:all .3s}.exam-card:hover{background:var(--card-bg);border-color:rgba(var(--accent-rgb),.3);opacity:.95}.exam-identity{display:flex;justify-content:space-between;align-items:flex-start}.exam-meaning{font-size:1.25rem;font-weight:700;color:var(--text-main);margin:0}.exam-pronunciation{display:flex;flex-direction:column;gap:2px;font-size:.8rem;color:var(--text-muted);margin-top:4px}.exam-input-wrapper{position:relative;display:flex;flex-direction:column;gap:10px}.exam-input{width:100%;background:rgba(var(--bg-rgb),.6);border:1px solid var(--glass-border);padding:14px 18px;border-radius:14px;color:var(--text-main);font-size:1.1rem;font-weight:500;outline:none;transition:all .2s;font-family:Outfit,sans-serif}.exam-input:focus{border-color:var(--primary-color);background:rgba(var(--bg-rgb),.8);box-shadow:0 0 0 4px rgba(var(--accent-rgb),.1)}.exam-input.perfect{border-color:var(--success-color);background:rgba(var(--success-rgb),.05)}.accent-bar-mini{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}.accent-btn-mini{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--hover-bg);border:1px solid var(--glass-border);border-radius:8px;color:var(--text-muted);font-size:.9rem;cursor:pointer;transition:all .2s}.accent-btn-mini:hover{background:var(--primary-color);color:var(--text-bright);border-color:var(--primary-color);transform:translateY(-2px)}.exam-actions{display:flex;gap:12px;margin-top:10px}.btn-reveal-exam{flex:1;padding:10px;border-radius:12px;background:var(--hover-bg);border:1px solid var(--glass-border);color:var(--text-muted);font-size:.85rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .2s}.btn-reveal-exam:hover{background:var(--hover-bg);color:var(--text-main);opacity:.9}.perfect-match-overlay{display:flex;align-items:center;gap:8px;color:var(--success-color);font-weight:700;font-size:.9rem;animation:bounceIn .5s cubic-bezier(.36,0,.66,-.56) both}@keyframes bounceIn{0%{transform:scale(.3);opacity:0}50%{transform:scale(1.05);opacity:1}70%{transform:scale(.9)}to{transform:scale(1)}}.speaking-practice-container{display:flex;flex-direction:column;gap:30px}.speaking-set{padding:30px}.set-header{margin-bottom:25px;border-bottom:1px solid var(--glass-border);padding-bottom:15px}.set-title{font-size:1.5rem;font-weight:800;color:var(--text-main)}.set-desc{color:var(--text-muted);font-size:.95rem;margin-top:5px}.speaking-lines-list{display:flex;flex-direction:column;gap:20px}.speaking-line-item{background:var(--hover-bg);border:1px solid var(--glass-border);border-radius:16px;padding:20px;transition:all .2s ease}.speaking-line-item:hover{background:var(--hover-bg);border-color:var(--primary-color)}.line-content{display:flex;flex-direction:column;gap:8px}.fr-row{display:flex;justify-content:space-between;align-items:flex-start;gap:15px}.fr-row .fr-text{font-size:1.2rem;font-weight:700;color:var(--text-main);line-height:1.4}.play-btn-mini{background:rgba(var(--accent-rgb),.1);color:var(--primary-color);padding:8px;border-radius:50%;flex-shrink:0;transition:all .2s;display:flex;align-items:center;justify-content:center}.play-btn-mini:hover{background:var(--primary-color);color:var(--text-bright);transform:scale(1.1)}.hi-row .hi-text{color:var(--primary-light);font-size:.95rem;font-style:italic;font-family:inherit}.en-row .en-text{color:var(--text-muted);font-size:.95rem}.floating-theme-toggle{position:fixed;bottom:30px;right:30px;z-index:1000;width:50px;height:50px;border-radius:50%;background:var(--primary-color);color:var(--text-bright);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(var(--accent-rgb),.4);cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);border:1px solid var(--glass-border);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.floating-theme-toggle:hover{transform:scale(1.1) rotate(15deg);box-shadow:0 8px 30px rgba(var(--accent-rgb),.6);background:var(--accent-color)}.floating-theme-toggle svg{filter:drop-shadow(0 0 5px rgba(255,255,255,.3))}@media (max-width: 768px){.floating-theme-toggle{bottom:20px;right:20px;width:45px;height:45px}}.sidebar-settings-row{display:flex;align-items:center;gap:12px;margin-bottom:15px}.theme-toggle-sidebar{width:36px;height:36px;border-radius:8px;background:var(--hover-bg);border:1px solid var(--glass-border);color:var(--text-main);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s}.theme-toggle-sidebar:hover{background:var(--primary-color);color:var(--text-bright);transform:translateY(-2px)}.home-page{max-width:1100px;margin:0 auto;padding:2rem 1.5rem;display:flex;flex-direction:column;gap:2.5rem}.home-welcome{display:flex;justify-content:space-between;align-items:flex-start}.home-welcome-text h1{font-size:2.2rem;font-weight:800;margin:0 0 .5rem;color:var(--text-bright)}.home-user-email{background:linear-gradient(135deg,var(--primary-color),#a855f7);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.home-welcome-subtitle{color:var(--text-muted);font-size:1.05rem;margin:0}.home-welcome-icon{color:var(--primary-color);animation:pulse 2s infinite ease-in-out}.home-section-title{display:flex;align-items:center;gap:.75rem;font-size:1.3rem;font-weight:700;color:var(--text-bright);margin:0 0 1rem}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1.25rem}.dashboard-card{display:flex;align-items:center;gap:1.25rem;padding:1.5rem;background:var(--card-bg);border:1px solid var(--glass-border);border-radius:20px;cursor:pointer;transition:all .3s cubic-bezier(.23,1,.32,1);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);box-shadow:var(--glass-shadow)}.dashboard-card:hover{background:var(--hover-bg);border-color:rgba(var(--accent-rgb),.3);box-shadow:var(--accent-glow)}.dashboard-card-icon{width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.accent-speaking .dashboard-card-icon{background:#6366f126;color:#818cf8}.accent-writing .dashboard-card-icon{background:#f43f5e26;color:#fb7185}.accent-reading .dashboard-card-icon{background:#10b98126;color:#34d399}.accent-listening .dashboard-card-icon{background:#f59e0b26;color:#fbbf24}.accent-study .dashboard-card-icon{background:#a855f726;color:#c084fc}.accent-vocab .dashboard-card-icon{background:#06b6d426;color:#22d3ee}.accent-history .dashboard-card-icon{background:#ec489926;color:#f472b6}.dashboard-card-text h3{font-size:1.1rem;font-weight:700;color:var(--text-bright);margin:0}.dashboard-card-text p{font-size:.85rem;color:var(--text-muted);margin:.25rem 0 0}.home-bottom-row{display:grid;grid-template-columns:1fr;gap:1.25rem}.home-streak-card{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;padding:1.5rem}.streak-left{display:flex;align-items:center;gap:1.25rem}.streak-icon{width:52px;height:52px;border-radius:14px;background:linear-gradient(135deg,#f59e0b33,#ef444426);color:#f59e0b;display:flex;align-items:center;justify-content:center}.streak-content{display:flex;flex-direction:column}.streak-count{font-size:2rem;font-weight:900;color:var(--text-bright);line-height:1}.streak-label{font-size:.85rem;color:var(--text-muted);margin-top:.15rem}.streak-week{display:flex;align-items:flex-end;gap:.75rem}.streak-day{display:flex;flex-direction:column;align-items:center;gap:.35rem}.streak-day-name{font-size:.65rem;font-weight:600;color:var(--text-muted);text-transform:uppercase}.streak-dot{width:28px;height:28px;border-radius:8px;background:var(--hover-bg);border:2px solid var(--glass-border);transition:all .3s ease}.streak-day.active .streak-dot{background:var(--primary-color);border-color:var(--primary-color);box-shadow:0 0 8px rgba(var(--accent-rgb),.4)}.streak-day.today .streak-dot{border-color:rgba(var(--accent-rgb),.5)}.streak-day.active.today .streak-dot{box-shadow:0 0 12px rgba(var(--accent-rgb),.6)}.streak-time{display:flex;align-items:center;gap:.4rem;font-size:.85rem;color:var(--text-muted)}@media (max-width: 640px){.home-welcome-text h1{font-size:1.6rem}.dashboard-grid{grid-template-columns:1fr}}@media (min-width: 768px){.home-bottom-row{grid-template-columns:1fr 1fr}}.home-target-card{display:flex;flex-direction:column;gap:1rem;padding:1.5rem}.target-header{display:flex;align-items:center;gap:.5rem;font-weight:700;font-size:.95rem;color:var(--text-bright)}.target-levels{display:flex;gap:.5rem;flex-wrap:wrap}.target-level-btn{display:flex;align-items:center;gap:.35rem;padding:.5rem 1rem;border-radius:8px;border:1.5px solid var(--glass-border);background:var(--card-bg);color:var(--text-muted);font-weight:600;font-size:.85rem;cursor:pointer;transition:all .2s ease}.target-level-btn:hover{border-color:var(--primary-color);color:var(--text-bright)}.target-level-btn.active{background:var(--primary-color);border-color:var(--primary-color);color:#fff}.target-level-btn:disabled{opacity:.6;cursor:not-allowed}.target-hint{font-size:.75rem;color:var(--text-muted);margin:0;line-height:1.4}.landing-page{min-height:100vh;background:var(--bg-gradient);color:var(--text-main);font-family:var(--font-main)}.landing-header{position:fixed;top:0;left:0;right:0;z-index:100;padding:1rem 2rem;background:#0f172acc;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--glass-border)}[data-theme=light] .landing-header{background:#fffc}.landing-header-inner{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center}.landing-logo{display:flex;align-items:center;gap:.75rem}.logo-sparkle{color:var(--primary-color)}.landing-logo-text{font-size:1.4rem;font-weight:800;color:var(--text-bright)}.landing-logo-text .accent{color:var(--primary-color)}.landing-nav{display:flex;align-items:center;gap:1rem}.landing-nav-btn{background:none;border:none;color:var(--text-muted);font-size:.95rem;font-weight:600;cursor:pointer;padding:.5rem 1rem;transition:color .2s}.landing-nav-btn:hover{color:var(--text-bright)}.landing-nav .theme-toggle{display:flex;align-items:center;justify-content:center;padding:.5rem;line-height:0}.landing-cta-btn{padding:.6rem 1.5rem;font-size:.9rem}.landing-hero{padding:8rem 2rem 4rem;position:relative;overflow:hidden}.landing-hero-bg{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none}.landing-hero-bg .hero-blob{position:absolute;filter:blur(100px);border-radius:50%;opacity:.12}.landing-hero-bg .blob-1{width:500px;height:500px;background:var(--primary-color);top:-150px;right:-100px;animation:float 25s infinite alternate}.landing-hero-bg .blob-2{width:400px;height:400px;background:var(--secondary-color);bottom:-100px;left:-100px;animation:float 20s infinite alternate-reverse}.landing-hero-content{max-width:1100px;margin:0 auto;position:relative;z-index:1;display:flex;align-items:center;gap:3rem}.hero-text{text-align:left;flex:1}.hero-image-wrapper{flex-shrink:0;width:400px}.hero-image{width:100%;height:auto;border-radius:24px;box-shadow:0 20px 60px #0000004d;object-fit:cover;aspect-ratio:3/4}.hero-text h1{font-size:3.5rem;font-weight:900;letter-spacing:-.03em;color:var(--text-bright);margin:0 0 1.25rem;line-height:1.1}.gradient-text{background:linear-gradient(135deg,var(--primary-color),#a855f7);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.hero-subtitle{font-size:1.2rem;color:var(--text-muted);line-height:1.6;margin:0 0 2rem}.hero-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.btn-hero{padding:1rem 2.5rem;font-size:1.1rem;display:flex;align-items:center;gap:.5rem}.btn-hero-secondary{padding:1rem 2.5rem;font-size:1.1rem}.hero-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;width:100%;max-width:800px;margin:3rem auto 0;position:relative;z-index:1}.hero-stat-card{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1.5rem 1rem;background:var(--card-bg);border:1px solid var(--glass-border);border-radius:16px;text-align:center;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.hero-stat-icon{color:var(--primary-color)}.hero-stat-value{font-size:1.5rem;font-weight:800;color:var(--text-bright)}.hero-stat-label{font-size:.8rem;color:var(--text-muted);font-weight:500}.landing-features{padding:6rem 2rem;max-width:1100px;margin:0 auto}.landing-section-header{text-align:center;margin-bottom:3rem}.landing-section-header h2{font-size:2.2rem;font-weight:800;color:var(--text-bright);margin:0 0 .75rem}.landing-section-header p{font-size:1.05rem;color:var(--text-muted);margin:0}.features-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem}.feature-card{padding:2rem;display:flex;flex-direction:column;gap:1rem;transition:all .3s ease}.feature-card:hover{transform:translateY(-5px);border-color:rgba(var(--accent-rgb),.3);box-shadow:var(--accent-glow)}.feature-icon{width:56px;height:56px;border-radius:14px;background:rgba(var(--accent-rgb),.1);color:var(--primary-color);display:flex;align-items:center;justify-content:center}.feature-card h3{font-size:1.2rem;font-weight:700;color:var(--text-bright);margin:0}.feature-card p{font-size:.95rem;color:var(--text-muted);line-height:1.6;margin:0}.landing-france-section{display:flex;align-items:center;gap:3rem;max-width:900px;margin:0 auto;padding:4rem 2rem}.france-image-wrapper{flex-shrink:0;width:280px;border-radius:50%;overflow:hidden;border:4px solid var(--glass-border);box-shadow:0 10px 40px #00000026}.france-image{width:100%;height:280px;object-fit:cover;display:block}.france-text h2{font-size:2rem;font-weight:800;color:var(--text-bright);margin:0 0 .75rem}.france-text p{font-size:1.05rem;color:var(--text-muted);line-height:1.7;margin:0}.landing-cta{padding:4rem 2rem 6rem;max-width:1100px;margin:0 auto}.landing-cta-card{text-align:center;padding:4rem 3rem;background:linear-gradient(135deg,rgba(var(--accent-rgb),.1),#a855f714);border:1px solid rgba(var(--accent-rgb),.2);border-radius:32px}.landing-cta-card h2{font-size:2rem;font-weight:800;color:var(--text-bright);margin:0 0 .75rem}.landing-cta-card p{font-size:1.05rem;color:var(--text-muted);margin:0 0 2rem;max-width:500px;margin-left:auto;margin-right:auto}.btn-cta{padding:1rem 2.5rem;font-size:1.1rem;display:inline-flex;align-items:center;gap:.5rem}.landing-footer{padding:3rem 2rem;border-top:1px solid var(--glass-border)}.landing-footer-inner{max-width:1100px;margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:1.5rem}.landing-footer-brand{display:flex;align-items:center;gap:.5rem;font-size:1.1rem;font-weight:700;color:var(--text-bright)}.landing-footer-links{display:flex;gap:1.5rem;flex-wrap:wrap;justify-content:center}.footer-link{background:none;border:none;color:var(--text-muted);font-size:.9rem;cursor:pointer;transition:color .2s}.footer-link:hover{color:var(--primary-color)}.landing-footer-copy{color:var(--text-dim);font-size:.8rem;margin:0}.tcf-canada-banner{padding:4rem 1.5rem;background:linear-gradient(135deg,rgba(var(--accent-rgb),.08),rgba(var(--accent-rgb),.02));border-top:1px solid var(--glass-border);border-bottom:1px solid var(--glass-border)}.tcf-canada-content{max-width:800px;margin:0 auto;text-align:center;display:flex;flex-direction:column;align-items:center;gap:1.25rem}.tcf-canada-content h2{font-size:1.6rem;margin:0}.tcf-canada-content>p{color:var(--text-muted);max-width:600px;line-height:1.6;margin:0}.tcf-canada-benefits{list-style:none;padding:0;margin:0;text-align:left;max-width:500px;width:100%}.tcf-canada-benefits li{display:flex;align-items:flex-start;gap:.75rem;padding:.5rem 0;font-size:.9rem;line-height:1.4;color:var(--text-main)}.tcf-canada-benefits li svg{flex-shrink:0;color:var(--primary-color);margin-top:2px}.landing-how-it-works{padding:4rem 1.5rem;max-width:1000px;margin:0 auto}.how-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:2rem}.how-step{padding:2rem 1.5rem;text-align:center;position:relative;display:flex;flex-direction:column;align-items:center;gap:.75rem}.how-step-number{position:absolute;top:-12px;left:-12px;width:32px;height:32px;border-radius:50%;background:var(--primary-color);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.9rem;font-weight:800}.how-step-icon{color:var(--primary-color);width:64px;height:64px;border-radius:50%;background:rgba(var(--accent-rgb),.1);display:flex;align-items:center;justify-content:center}.how-step h3{margin:0;font-size:1.05rem}.how-step p{margin:0;color:var(--text-muted);font-size:.85rem;line-height:1.5}.landing-faq{padding:4rem 1.5rem;max-width:700px;margin:0 auto}.faq-list{display:flex;flex-direction:column;gap:.75rem;margin-top:1.5rem}.faq-item{border:1px solid var(--glass-border);border-radius:12px;background:var(--card-bg);overflow:hidden;transition:border-color .2s}.faq-item.open{border-color:var(--primary-color)}.faq-question{width:100%;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem 1.25rem;background:none;border:none;color:var(--text-main);font-size:.95rem;font-weight:600;cursor:pointer;text-align:left;line-height:1.4}.faq-question:hover{color:var(--primary-color)}.faq-chevron{flex-shrink:0;transition:transform .3s ease;color:var(--text-muted)}.faq-chevron.rotated{transform:rotate(180deg);color:var(--primary-color)}.faq-answer{overflow:hidden;transition:max-height .3s ease}.faq-answer p{margin:0;padding:0 1.25rem 1rem;color:var(--text-muted);font-size:.9rem;line-height:1.6}.auth-back-btn{position:absolute;top:1.5rem;left:1.5rem;background:var(--hover-bg);border:1px solid var(--glass-border);color:var(--text-muted);padding:.5rem 1rem;border-radius:8px;font-size:.9rem;cursor:pointer;transition:all .2s}.auth-back-btn:hover{color:var(--text-bright);background:var(--hover-bg)}.separator-dot{color:var(--text-muted)}.legal-page{max-width:800px;margin:0 auto;padding:3rem 2rem 5rem;min-height:100vh}.legal-header{text-align:center;margin-bottom:3rem;position:relative}.legal-back-btn{position:absolute;left:0;top:0;display:flex;align-items:center;gap:.4rem;background:var(--hover-bg);border:1px solid var(--glass-border);color:var(--text-muted);padding:.5rem 1rem;border-radius:8px;font-size:.85rem;cursor:pointer;transition:all .2s}.legal-back-btn:hover{color:var(--text-bright);background:var(--hover-bg)}.legal-header-icon{width:64px;height:64px;margin:0 auto 1rem;border-radius:16px;background:rgba(var(--accent-rgb),.1);color:var(--primary-color);display:flex;align-items:center;justify-content:center}.legal-header h1{font-size:2rem;font-weight:800;color:var(--text-bright);margin:0 0 .5rem}.legal-last-updated{color:var(--text-muted);font-size:.9rem;margin:0}.legal-content{display:flex;flex-direction:column;gap:2rem}.legal-content section h2{font-size:1.3rem;font-weight:700;color:var(--text-bright);margin:0 0 .75rem}.legal-content section p{color:var(--text-muted);line-height:1.7;margin:0 0 .5rem}.legal-content section ul{color:var(--text-muted);line-height:1.7;padding-left:1.5rem}.legal-content section ul li{margin-bottom:.5rem}.legal-inline-link{background:none;border:none;color:var(--primary-color);font-weight:600;cursor:pointer;padding:0;font-size:inherit;text-decoration:underline}.legal-inline-link:hover{color:#4f46e5}.cookie-consent-overlay{position:fixed;bottom:0;left:0;right:0;z-index:10000;padding:1rem;display:flex;justify-content:center}.cookie-consent-banner{display:flex;align-items:center;gap:1.25rem;padding:1.25rem 1.5rem;max-width:800px;width:100%;position:relative;animation:slideUp .4s cubic-bezier(.16,1,.3,1)}.cookie-close{position:absolute;top:.5rem;right:.5rem;background:none;border:none;color:var(--text-muted);cursor:pointer;padding:.25rem}.cookie-consent-icon{width:44px;height:44px;border-radius:12px;background:rgba(var(--accent-rgb),.1);color:var(--primary-color);display:flex;align-items:center;justify-content:center;flex-shrink:0}.cookie-consent-text{flex:1}.cookie-consent-text p{color:var(--text-main);font-size:.9rem;margin:0 0 .25rem}.cookie-consent-actions{display:flex;gap:.75rem;flex-shrink:0}.cookie-btn{padding:.5rem 1.25rem;font-size:.85rem;white-space:nowrap}@keyframes slideUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}@media (max-width: 640px){.cookie-consent-banner{flex-direction:column;text-align:center}.cookie-consent-actions{width:100%}.cookie-btn{flex:1}.legal-back-btn{position:relative;margin-bottom:1rem;display:inline-flex}}@media (max-width: 768px){.landing-hero-content{flex-direction:column;text-align:center}.hero-text{text-align:center}.hero-image-wrapper{width:280px}.hero-text h1{font-size:2.2rem}.hero-stats{grid-template-columns:repeat(2,1fr)}.features-grid{grid-template-columns:1fr}.landing-france-section{flex-direction:column;text-align:center}.france-image-wrapper{width:200px}.france-image{height:200px}.landing-header{padding:.75rem 1rem}.landing-nav .landing-nav-btn{display:none}}.profile-page{max-width:900px;margin:0 auto;padding:1.5rem}.profile-header-card{display:flex;align-items:center;gap:1.25rem;padding:1.5rem;background:var(--card-bg);border-radius:16px;border:1px solid var(--border-color);margin-bottom:1.5rem}.profile-avatar{width:72px;height:72px;border-radius:50%;background:var(--hover-bg);display:flex;align-items:center;justify-content:center;color:var(--accent);flex-shrink:0}.profile-header-info h2{margin:0 0 .25rem;font-size:1.4rem;text-transform:capitalize}.profile-email,.profile-member-since{display:flex;align-items:center;gap:.4rem;margin:.15rem 0;font-size:.85rem;color:var(--text-muted)}.profile-plan-badge{margin-left:auto;display:flex;align-items:center;gap:.4rem;padding:.4rem .85rem;border-radius:20px;font-size:.85rem;font-weight:600;white-space:nowrap}.profile-plan-badge.free{background:var(--hover-bg);color:var(--text-muted)}.profile-plan-badge.pro{background:var(--accent);color:#fff}.profile-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}.profile-card{background:var(--card-bg);border-radius:16px;border:1px solid var(--border-color);padding:1.5rem}.profile-card.danger-zone{border-color:var(--error-color)}.profile-card-header{display:flex;align-items:center;gap:.6rem;margin-bottom:1.25rem;color:var(--accent)}.profile-card-header h3{margin:0;font-size:1rem}.permission-list{display:flex;flex-direction:column;gap:.5rem}.permission-row{display:flex;justify-content:space-between;align-items:center;padding:.5rem .75rem;background:var(--hover-bg);border-radius:8px;font-size:.85rem}.permission-label{text-transform:capitalize}.permission-yes{display:flex;align-items:center;gap:.3rem;color:#22c55e;font-size:.8rem}.permission-no{display:flex;align-items:center;gap:.3rem;color:var(--text-muted);font-size:.8rem}.password-form{display:flex;flex-direction:column;gap:.85rem}.password-field label{display:block;font-size:.8rem;font-weight:500;margin-bottom:.3rem;color:var(--text-muted)}.password-field input{width:100%;padding:.6rem .75rem;border:1px solid var(--border-color);border-radius:8px;background:var(--input-bg);color:var(--text);font-size:.9rem;box-sizing:border-box}.password-input-wrapper{position:relative}.password-input-wrapper input{padding-right:2.5rem}.pw-toggle{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px}.form-success{color:#22c55e;font-size:.85rem;margin:0}.form-error{color:var(--error-color);font-size:.85rem;margin:0}.usage-stats{display:flex;flex-direction:column;gap:.75rem}.usage-stat{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:var(--hover-bg);border-radius:8px}.usage-stat-value{font-weight:700;font-size:1.05rem}.danger-warning{font-size:.85rem;color:var(--error-color);margin:0 0 1rem}.danger-icon{color:var(--error-color)}.btn-danger{display:flex;align-items:center;gap:.4rem;padding:.6rem 1.2rem;background:var(--error-color);color:#fff;border:none;border-radius:10px;cursor:pointer;font-size:.85rem;font-weight:500;transition:opacity .2s}.btn-danger:hover{opacity:.85}.btn-danger:disabled{opacity:.5;cursor:not-allowed}.delete-confirm{display:flex;flex-direction:column;gap:.75rem}.delete-confirm p{font-size:.85rem;margin:0}.delete-confirm input{padding:.6rem .75rem;border:1px solid var(--error-color);border-radius:8px;background:var(--input-bg);color:var(--text);font-size:.9rem}.delete-actions{display:flex;gap:.75rem}@media (max-width: 768px){.profile-grid{grid-template-columns:1fr}.profile-header-card{flex-wrap:wrap}.profile-plan-badge{margin-left:0}}.waveform-speaking,.waveform-speaking-inline{width:100%;display:flex;justify-content:center;padding:.5rem 0}.waveform-canvas-speaking{width:100%;max-width:400px;height:60px;border-radius:12px;background:#6366f114;border:1px solid rgba(99,102,241,.2)}.waveform-speaking-inline .waveform-canvas-speaking{height:40px}.chat-toggle{flex-shrink:0;color:var(--text-muted);width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;border:1px solid var(--glass-border);background:var(--glass-bg)}.chat-toggle:hover{color:var(--text-main);border-color:var(--primary-color)}.exam-topic-card .topic-action{color:var(--primary-color);font-size:.85rem;font-weight:600}.speaking-task2-prep{display:flex;flex-direction:column;gap:1.5rem;padding:1.5rem;max-width:700px;margin:0 auto;animation:fadeIn .3s ease}.prep-header{display:flex;align-items:center;gap:1rem}.prep-header h2{flex:1;margin:0;font-size:1.3rem}.prep-timer{display:flex;align-items:center;gap:.5rem;font-size:1.2rem;font-weight:700;color:var(--primary-color)}.prep-situation-card{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:12px;padding:1.5rem}.prep-situation-card h3{margin:0 0 1rem;font-size:1.1rem}.situation-content{display:flex;flex-direction:column;gap:.75rem}.situation-text{font-size:1rem;line-height:1.6;margin:0}.situation-text-en{color:var(--text-muted);font-size:.9rem;line-height:1.5;margin:0;font-style:italic}.btn-icon{background:none;border:none;color:var(--primary-color);cursor:pointer;padding:4px;border-radius:6px;transition:all .2s;display:inline-flex;align-items:center}.btn-icon:hover{background:rgba(var(--accent-rgb),.1)}.role-info{margin-top:1.25rem;padding-top:1.25rem;border-top:1px solid var(--glass-border)}.role-info h4{margin:0 0 .5rem;font-size:1rem}.role-info p{margin:0 0 .5rem;line-height:1.5}.prep-tips{display:flex;align-items:flex-start;gap:.5rem;padding:1rem;background:rgba(var(--accent-rgb),.06);border-radius:8px;color:var(--text-muted);font-size:.9rem}.prep-tips p{margin:0;line-height:1.4}.prep-continue{display:flex;justify-content:center;padding:1rem 0}.mode-toggle{display:flex;align-items:center;gap:.75rem;justify-content:center;padding:.5rem 0}.mode-toggle-label{font-size:.85rem;font-weight:600;color:var(--text-muted)}.mode-toggle-buttons{display:flex;gap:.5rem}.mode-btn{display:flex;align-items:center;gap:.4rem;padding:.5rem 1rem;border:1px solid var(--glass-border);border-radius:8px;background:var(--card-bg);color:var(--text-main);cursor:pointer;font-size:.82rem;transition:all .2s}.mode-btn:hover{border-color:var(--primary-color)}.mode-btn.active{border-color:var(--primary-color);background:rgba(var(--accent-rgb),.08)}.mode-badge-free{font-size:.7rem;padding:1px 6px;border-radius:4px;background:rgba(var(--success-rgb),.15);color:var(--success-color);font-weight:700}.mode-badge-minutes{font-size:.7rem;padding:1px 6px;border-radius:4px;background:rgba(var(--accent-rgb),.1);color:var(--primary-color);font-weight:700}.timer-warning{color:#e74c3c!important;animation:pulse 1s infinite}.speaking-task2-live{display:flex;flex-direction:column;height:calc(100vh - 120px);max-width:800px;margin:0 auto;animation:fadeIn .3s ease;position:relative}.countdown-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:100;display:flex;align-items:center;justify-content:center;background:var(--bg-color)}.countdown-number{font-size:8rem;font-weight:800;color:var(--primary-color);animation:countPop 1s ease-out}@keyframes countPop{0%{transform:scale(1.5);opacity:.3}50%{transform:scale(1.1);opacity:1}to{transform:scale(1);opacity:1}}.live-header{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border-bottom:1px solid var(--glass-border);flex-shrink:0}.live-header-info{flex:1;display:flex;flex-direction:column;gap:.25rem}.live-header-info h3{margin:0;font-size:1rem}.live-status{display:flex;align-items:center;gap:.35rem;font-size:.8rem;color:var(--text-muted)}.live-timer{display:flex;align-items:center;gap:.4rem;font-size:1.1rem;font-weight:700;color:var(--primary-color);padding:.5rem .75rem;background:var(--glass-bg);border-radius:8px;border:1px solid var(--glass-border)}.conversation-area{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column}.conversation-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;text-align:center;color:var(--text-muted)}.conversation-empty h3{margin:0;font-size:1.2rem;color:var(--text-main)}.conversation-empty p{margin:0;max-width:300px}.mic-pulse{animation:micPulse 2s infinite;color:var(--primary-color)}@keyframes micPulse{0%,to{opacity:.5;transform:scale(1)}50%{opacity:1;transform:scale(1.1)}}.interim-text{font-style:italic;opacity:.7;margin-top:.5rem!important}.conversation-messages{display:flex;flex-direction:column;gap:.75rem;padding-bottom:1rem}.message{display:flex;flex-direction:column;max-width:85%}.message.user{align-self:flex-end}.message.ai{align-self:flex-start}.message-bubble{padding:.75rem 1rem;border-radius:16px;position:relative;display:flex;align-items:flex-start;gap:.5rem}.message.user .message-bubble{background:var(--primary-color);color:#fff;border-bottom-right-radius:4px}.message.ai .message-bubble{background:var(--glass-bg);border:1px solid var(--glass-border);border-bottom-left-radius:4px}.message.interim .message-bubble{opacity:.6}.message-bubble p{margin:0;line-height:1.4;flex:1}.btn-tts{flex-shrink:0;opacity:.6}.btn-tts:hover{opacity:1}.message-bubble.thinking{padding:.75rem 1.5rem;display:flex;align-items:center;justify-content:center}.live-footer{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.75rem 1rem;border-top:1px solid var(--glass-border);flex-shrink:0}.live-footer-center{flex:1;text-align:center}.ai-prompt{margin:0;color:var(--text-muted);font-style:italic;font-size:.85rem;animation:fadeIn .5s ease}.result-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.result-modal{background:var(--bg-color);border:1px solid var(--glass-border);border-radius:16px;padding:2rem;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;display:flex;flex-direction:column;gap:1.5rem}.result-header{display:flex;align-items:center;gap:.75rem;color:var(--primary-color)}.result-header h2{margin:0;font-size:1.4rem}.result-loading{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:2rem;color:var(--text-muted)}.result-score{display:flex;align-items:center;justify-content:center;gap:1.5rem;padding:1rem 0}.score-circle{width:100px;height:100px;border-radius:50%;background:linear-gradient(135deg,var(--primary-color),var(--primary-hover));display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff}.score-value{font-size:2rem;font-weight:800;line-height:1}.score-max{font-size:.75rem;opacity:.8}.cefr-badge{padding:.5rem 1.25rem;border-radius:20px;background:rgba(var(--accent-rgb),.1);border:1px solid var(--primary-color);color:var(--primary-color);font-size:1.5rem;font-weight:800}.result-breakdown{display:flex;flex-direction:column;gap:.75rem}.breakdown-item{display:flex;align-items:center;gap:.5rem;padding:.75rem;background:var(--glass-bg);border-radius:8px;font-size:.9rem}.result-feedback h4,.result-transcript h4{margin:0 0 .75rem;font-size:1rem;display:flex;align-items:center;gap:.5rem}.result-feedback p{margin:0;line-height:1.5;color:var(--text-muted)}.btn-text{background:none;border:none;color:var(--primary-color);cursor:pointer;font-size:.8rem;padding:2px 8px;border-radius:4px}.btn-text:hover{background:rgba(var(--accent-rgb),.1)}.transcript-text{max-height:200px;overflow-y:auto;padding:.75rem;background:var(--glass-bg);border-radius:8px;font-size:.82rem;line-height:1.6}.transcript-text p{margin:.25rem 0}.result-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.result-error{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:2rem;text-align:center;color:#e74c3c}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.seo-page{min-height:100vh;display:flex;flex-direction:column;background:var(--bg-color)}.seo-header{position:sticky;top:0;z-index:100;background:var(--bg);border-bottom:1px solid var(--glass-border);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.seo-header-inner{max-width:1100px;margin:0 auto;padding:.75rem 1.5rem;display:flex;align-items:center;justify-content:space-between}.seo-logo{font-size:1.3rem;font-weight:800;text-decoration:none;color:var(--text-main);display:flex;align-items:center;gap:.5rem}.seo-logo-img{height:28px;width:auto}.seo-nav{display:flex;align-items:center;gap:1.25rem}.seo-nav a{text-decoration:none;color:var(--text-muted);font-size:.88rem;font-weight:500;transition:color .2s}.seo-nav a:hover{color:var(--primary-color)}.seo-nav a.active{color:var(--primary-color);font-weight:700}.seo-cta{padding:6px 16px;font-size:.85rem}.mobile-menu-btn{display:none;background:none;border:none;color:var(--text-main);cursor:pointer;padding:4px}.mobile-nav{display:none;flex-direction:column;gap:.5rem;padding:.5rem 1.5rem 1rem;border-top:1px solid var(--glass-border)}.mobile-nav-link{text-decoration:none;color:var(--text-muted);font-size:.95rem;padding:.6rem 0;font-weight:500;transition:color .2s}.mobile-nav-link:hover{color:var(--primary-color)}.mobile-nav-actions{display:flex;align-items:center;gap:1rem;padding-top:.5rem;border-top:1px solid var(--glass-border)}@media (max-width: 768px){.seo-nav{display:none}.mobile-menu-btn,.mobile-nav{display:flex}}@media (max-width: 768px){.test-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr))!important;gap:.5rem!important}.test-card{padding:.75rem!important;min-height:auto!important}.test-card-content{flex-direction:column!important;align-items:center!important;text-align:center!important;gap:.25rem!important}.test-card-icon{display:none!important}.test-card-info h3{font-size:.8rem!important;margin:0!important}.test-card-info p,.test-card-footer{display:none!important}.card-meta .exam-flag{font-size:.6rem!important;padding:1px 4px!important}}.seo-hero{padding:4rem 1.5rem;text-align:center;max-width:800px;margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:1.25rem}.seo-hero-icon{color:var(--primary-color);width:64px;height:64px;border-radius:50%;background:rgba(var(--accent-rgb),.1);display:flex;align-items:center;justify-content:center}.seo-hero h1{font-size:2rem;line-height:1.3;margin:0}@media (max-width: 600px){.seo-hero h1{font-size:1.5rem}}.seo-hero-sub{color:var(--text-muted);font-size:1rem;line-height:1.6;max-width:650px;margin:0}.seo-hero-actions{display:flex;gap:1rem;flex-wrap:wrap;justify-content:center}.seo-section{padding:3rem 1.5rem;max-width:900px;margin:0 auto;width:100%;box-sizing:border-box}.seo-section-alt{background:rgba(var(--accent-rgb),.03);border-top:1px solid var(--glass-border);border-bottom:1px solid var(--glass-border);max-width:100%;padding:3rem 1.5rem}.seo-section-alt>*{max-width:900px;margin-left:auto;margin-right:auto}.seo-section h2{font-size:1.5rem;margin:0 0 1.25rem;text-align:center}.seo-section-sub{color:var(--text-muted);margin:-.75rem auto 2rem;max-width:600px;text-align:center}.seo-section p{color:var(--text-main);line-height:1.7;margin:0 0 1rem}.seo-features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;margin:1.5rem auto}.seo-feature-card{background:var(--card-bg);border:1px solid var(--glass-border);border-radius:12px;padding:1.5rem;display:flex;flex-direction:column;gap:.75rem}.seo-feature-icon{color:var(--primary-color);width:48px;height:48px;border-radius:12px;background:rgba(var(--accent-rgb),.1);display:flex;align-items:center;justify-content:center}.seo-feature-card h3{margin:0;font-size:1rem}.seo-feature-card p{margin:0;font-size:.85rem;line-height:1.5;color:var(--text-muted)}.seo-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin:1.5rem auto}.seo-step{text-align:center;padding:1.5rem}.seo-step-num{width:36px;height:36px;border-radius:50%;background:var(--primary-color);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-weight:800;margin-bottom:.75rem}.seo-step h3{margin:0 0 .5rem;font-size:1.05rem}.seo-step p{margin:0;font-size:.88rem;color:var(--text-muted);line-height:1.5}.seo-table-wrapper,.seo-compare-table-wrapper{margin:1.5rem auto;border-radius:12px;border:1px solid var(--glass-border);overflow:hidden}.seo-table,.seo-compare-table{width:100%;border-collapse:collapse;font-size:.88rem}.seo-table th,.seo-compare-table th{background:rgba(var(--accent-rgb),.06);padding:.75rem 1rem;text-align:left;font-weight:700;border-bottom:1px solid var(--glass-border)}.seo-table td,.seo-compare-table td{padding:.7rem 1rem;border-bottom:1px solid var(--glass-border);vertical-align:top}.seo-table tr:last-child td,.seo-compare-table tr:last-child td{border-bottom:none}.seo-cards-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem;margin:1.5rem auto}.seo-card{background:var(--card-bg);border:1px solid var(--glass-border);border-radius:20px;padding:1.5rem}.seo-card-icon{color:var(--primary-color);margin-bottom:.75rem}.seo-card h3{margin:0 0 .25rem;font-size:1.05rem}.seo-card-meta{font-size:.8rem;color:var(--primary-color);margin:0 0 .5rem!important;font-weight:600}.seo-card p{margin:0;font-size:.85rem;line-height:1.5;color:var(--text-muted)}.seo-checklist{list-style:none;padding:0;margin:1.5rem 0;display:flex;flex-direction:column;gap:.75rem}.seo-checklist li{display:flex;align-items:flex-start;gap:.75rem;font-size:.9rem;line-height:1.5}.seo-checklist li svg{flex-shrink:0;color:var(--primary-color);margin-top:3px}.seo-cta-row{display:flex;justify-content:center;margin-top:2rem}.seo-faq{display:flex;flex-direction:column;gap:1rem;margin:1.5rem 0}.seo-faq-item{background:var(--card-bg);border:1px solid var(--glass-border);border-radius:12px;padding:1.25rem}.seo-faq-item h3{margin:0 0 .5rem;font-size:1rem}.seo-faq-item p{margin:0;font-size:.88rem;line-height:1.6;color:var(--text-muted)}.seo-tips-list{list-style:none;padding:0;display:flex;flex-direction:column;gap:.75rem}.seo-tips-list li{display:flex;align-items:flex-start;gap:.75rem;font-size:.9rem;line-height:1.5;padding:.75rem 1rem;background:var(--card-bg);border:1px solid var(--glass-border);border-radius:8px}.seo-tips-list li svg{flex-shrink:0;color:var(--primary-color);margin-top:3px}.seo-note{font-size:.85rem!important;color:var(--text-muted)!important;font-style:italic;margin-top:.75rem!important}.seo-footer{margin-top:auto;border-top:1px solid var(--glass-border);padding:2rem 1.5rem}.seo-footer-inner{max-width:900px;margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:1rem;text-align:center}.seo-footer-links{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}.seo-footer-links a{text-decoration:none;color:var(--text-muted);font-size:.85rem;transition:color .2s}.seo-footer-links a:hover{color:var(--primary-color)}.seo-footer p{margin:0;color:var(--text-dim);font-size:.8rem}.practice-option:hover{border-color:var(--primary-color);background:rgba(var(--accent-rgb),.04)}.practice-option.selected{border-color:var(--primary-color);background:rgba(var(--accent-rgb),.08)}.practice-option-letter{width:28px;height:28px;border-radius:50%;background:rgba(var(--accent-rgb),.1);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.8rem;flex-shrink:0}.practice-option.selected .practice-option-letter{background:var(--primary-color);color:#fff}.practice-option-check{margin-left:auto;color:var(--primary-color);flex-shrink:0}.practice-quiz-footer{display:flex;align-items:center;justify-content:space-between;padding:.5rem 0}.practice-answered{font-size:.85rem;color:var(--text-muted)}.practice-result{display:flex;align-items:center;gap:2rem;padding:1.5rem;flex-wrap:wrap;justify-content:center}.practice-score-circle{width:120px;height:120px;border-radius:50%;background:linear-gradient(135deg,var(--primary-color),var(--primary-hover));display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff}.practice-score-value{font-size:1.6rem;font-weight:800}.practice-score-label{font-size:.75rem;opacity:.85}.practice-cefr-card{display:flex;align-items:center;gap:.75rem;padding:1rem 1.5rem;background:var(--card-bg);border:1px solid var(--glass-border);border-radius:12px}.practice-cefr-card strong{display:block;font-size:1.1rem;margin-bottom:.25rem}.practice-cefr-card p{margin:0;font-size:.85rem;color:var(--text-muted)}.practice-review{display:flex;flex-direction:column;gap:.75rem;margin:1.5rem 0}.practice-review-item{padding:1rem;border-radius:10px;border:1px solid var(--glass-border);font-size:.88rem;line-height:1.5}.practice-review-item.correct{border-color:#10b981;background:#10b9810d}.practice-review-item.incorrect{border-color:#ef4444;background:#ef44440d}.practice-review-q{font-weight:600;margin-bottom:.35rem}.practice-review-a{color:var(--text-muted)}.practice-review-correct{color:#10b981;margin-top:.25rem}.blog-page{background:var(--bg-color)}.blog-article{max-width:720px;margin:0 auto;padding:2.5rem 1.5rem}.blog-meta{display:flex;flex-wrap:wrap;align-items:center;gap:.75rem;margin-bottom:1rem}.blog-meta-item{display:flex;align-items:center;gap:.35rem;font-size:.82rem;color:var(--text-muted)}.blog-tag{display:inline-flex;align-items:center;gap:.25rem;padding:2px 10px;border-radius:20px;background:rgba(var(--accent-rgb),.08);color:var(--primary-color);font-size:.75rem;font-weight:600}.blog-title{font-size:1.8rem;line-height:1.3;margin:0 0 1.5rem}.blog-content{font-size:.95rem;line-height:1.8}.blog-content p{margin:0 0 1rem;color:var(--text-main)}.blog-content h2{font-size:1.25rem;margin:2rem 0 1rem}.blog-list{list-style:none;padding:0;display:flex;flex-direction:column;gap:.6rem;margin:1rem 0}.blog-list li{display:flex;align-items:flex-start;gap:.6rem;font-size:.92rem;line-height:1.5}.blog-cta{display:flex;justify-content:center;padding:1.5rem 0}.blog-share{margin-top:3rem;padding-top:1.5rem;border-top:1px solid var(--glass-border);font-size:.85rem;color:var(--text-muted);display:flex;flex-direction:column;gap:1rem}.blog-share p{margin:0}.blog-nav-links{display:flex;justify-content:space-between;flex-wrap:wrap;gap:.75rem}.blog-nav-links a{color:var(--primary-color);text-decoration:none;font-weight:600}.blog-nav-links a:hover{text-decoration:underline}.blog-related{padding:3rem 1.5rem;max-width:900px;margin:0 auto}.blog-related h2{text-align:center;margin-bottom:1.5rem;font-size:1.3rem}.blog-related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.blog-related-grid .seo-feature-card{cursor:pointer;transition:border-color .2s}.blog-related-grid .seo-feature-card:hover{border-color:var(--primary-color)}@media (max-width: 768px){.blog-title{font-size:1.4rem}.blog-related-grid{grid-template-columns:1fr}}@media (max-width: 768px){.seo-hero h1{font-size:1.5rem}.seo-hero-sub{font-size:.9rem}.seo-nav{display:none}.seo-features-grid,.seo-cards-grid,.seo-steps{grid-template-columns:1fr}.seo-section{padding:2rem 1rem}.seo-compare-table-wrapper,.seo-table-wrapper{overflow-x:auto}.seo-hero-actions{flex-direction:column;align-items:center}.how-steps{grid-template-columns:1fr;gap:2rem}.tcf-canada-content h2{font-size:1.3rem}.landing-hero-content{flex-direction:column;text-align:center}.hero-text h1{font-size:1.5rem}.hero-subtitle{font-size:.9rem}.hero-image-wrapper{display:none}.hero-stats{flex-wrap:wrap;gap:.75rem}.feature-card{padding:1.25rem}.features-grid{grid-template-columns:1fr}.landing-section-header h2{font-size:1.3rem}.landing-section-header p{font-size:.9rem}.landing-france-section{flex-direction:column;text-align:center;padding:2rem 1rem}.france-image-wrapper{max-width:100%}.faq-question{font-size:.88rem}.how-step{padding:1.25rem}.blog-related-grid{grid-template-columns:1fr}.blog-article{padding:1.5rem 1rem}.blog-title{font-size:1.4rem}.seo-features-grid{grid-template-columns:1fr}}.reading-module{max-width:1200px;margin:0 auto;display:flex;flex-direction:column;gap:2.5rem;padding:2rem 1.5rem}.reading-selection{max-width:1100px;margin:0 auto;display:flex;flex-direction:column;gap:2rem;padding:2rem 1rem}.test-card-icon{background:#6366f126;color:#818cf8;min-width:56px;height:56px;display:flex;align-items:center;justify-content:center;border-radius:20px;transition:all .3s}.test-card:hover .test-card-icon{background:var(--primary-color);color:var(--text-bright);transform:rotate(-5deg) scale(1.1)}.test-card-info{flex:1}.test-card-info p{font-size:.9rem;color:var(--text-muted);line-height:1.5}.questions-badge,.level-badge{font-size:.7rem;font-weight:700;padding:.2rem .5rem;border-radius:4px;text-transform:uppercase;letter-spacing:.025em}.questions-badge{color:#818cf8;background:#6366f126}.level-badge{color:#10b981;background:#10b98126}.back-circle-btn:hover{background:var(--primary-color);color:var(--text-bright);border-color:var(--primary-color);transform:translate(-3px)}.subtitle{color:var(--text-muted);font-size:.9rem;margin-top:.15rem;display:flex;align-items:center;gap:.5rem}.reading-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:3rem;align-items:start}@media (max-width: 968px){.reading-grid{grid-template-columns:1fr}.passage-card{margin-bottom:2rem}}.passage-card,.question-card{display:flex;flex-direction:column;padding:1.25rem}.question-card{min-height:450px;box-shadow:var(--glass-shadow)}.icon-btn:hover{background:var(--hover-bg);color:var(--text-main)}.passage-title{font-size:1.25rem;margin-bottom:1rem;color:var(--text-bright)}.fr-text{font-size:1.25rem;line-height:1.8;color:var(--text-main);white-space:pre-wrap}.en-text{margin-top:1rem;font-size:1rem;color:var(--text-muted);border-left:3px solid #6366f1;padding-left:1rem;font-style:italic}.question-header{margin-bottom:1.5rem}.question-header h3{color:var(--text-bright);margin-bottom:.5rem}.en-question{color:var(--text-muted);font-size:.9rem;margin-top:.25rem}.options-list{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.option-item{display:flex;align-items:center;gap:1rem;padding:1rem;background:var(--hover-bg);border:1px solid var(--glass-border);border-radius:12px;color:var(--text-main);cursor:pointer;text-align:left;transition:all .2s;position:relative;margin-bottom:.75rem}.option-item:last-child{margin-bottom:0}.option-item:hover:not(:disabled){background:rgba(var(--accent-rgb),.1);border-color:rgba(var(--accent-rgb),.3)}.option-item.selected{border-color:#6366f1;background:#6366f126;box-shadow:0 0 15px #6366f133}.option-item.correct{border-color:#10b981;background:#10b98126;box-shadow:0 0 15px #10b98133}.option-item.incorrect{border-color:#ef4444;background:#ef444426;box-shadow:0 0 15px #ef44441a}.option-label{background:var(--glass-border);width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:6px;font-weight:600;color:var(--text-muted);font-size:.9rem}.selected .option-label{background:var(--primary-color);color:var(--text-bright)}.correct .option-label{background:#10b981;color:var(--text-bright)}.incorrect .option-label{background:#ef4444;color:var(--text-bright)}.fr-opt{font-size:1rem;color:var(--text-main)}.status-icon{flex-shrink:0}.status-icon.success{color:#10b981}.status-icon.error{color:#ef4444}.feedback-banner{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border-radius:8px;font-weight:600}.explanation{font-size:.95rem;color:var(--text-muted);line-height:1.5}.btn-next{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem;background:var(--primary-color);color:var(--text-bright);border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:background .2s}.btn-next:hover{background:#4f46e5}.result-actions{display:flex;gap:1rem;margin-top:1rem}.btn-secondary{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;background:var(--hover-bg);color:var(--text-muted);border:1px solid var(--glass-border);border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s}.btn-secondary:hover{background:var(--hover-bg);color:var(--text-main)}.reading-results{display:flex;justify-content:center;padding:3rem;max-width:500px;margin:4rem auto;text-align:center}.results-content{display:flex;flex-direction:column;align-items:center;gap:1.5rem}.final-score-circle{width:120px;height:120px;border-radius:50%;border:4px solid #6366f1;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#6366f11a}.score-value{font-size:2.5rem;font-weight:700;color:var(--text-bright);line-height:1}.score-total{font-size:1rem;color:var(--text-muted)}.results-msg{color:var(--text-muted);font-size:1.1rem}.admin-btn:hover{background:#6366f133;color:#818cf8;border-color:#818cf8}.save-btn{background:#10b98126!important;color:#10b981!important;border-color:#10b9814d!important}.save-btn:hover{background:#10b981!important;color:var(--text-bright)!important}.cancel-btn{background:#ef444426!important;color:#ef4444!important;border-color:#ef44444d!important}.cancel-btn:hover{background:#ef4444!important;color:var(--text-bright)!important}.edit-container{display:flex;flex-direction:column;gap:1.5rem;margin-top:1rem;animation:fadeIn .3s ease-out}.edit-field{display:flex;flex-direction:column;gap:.5rem}.edit-field label{font-size:.8rem;font-weight:600;color:#6366f1;text-transform:uppercase;letter-spacing:.05em}.edit-textarea{width:100%;min-height:120px;padding:1rem;background:var(--hover-bg);border:1px solid var(--glass-border);border-radius:12px;color:var(--text-main);font-family:inherit;font-size:1.1rem;line-height:1.6;resize:vertical;transition:all .2s}.edit-textarea:focus{outline:none;border-color:#6366f1;background:var(--hover-bg);box-shadow:0 0 0 3px rgba(var(--accent-rgb),.2)}.fr-edit{border-left:4px solid #6366f1}.en-edit{border-left:4px solid var(--text-muted);font-style:italic;color:var(--text-muted)}@keyframes fadeIn{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}.navigator-toggle-btn{background:#6366f11a;border:1px solid rgba(99,102,241,.2);color:#818cf8;border-radius:6px;padding:.3rem .5rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.navigator-toggle-btn:hover{background:#6366f133;border-color:var(--glass-border);color:var(--text-bright)}.question-navigator-container{overflow:hidden;margin-bottom:1rem}.question-navigator{padding:1.5rem;background:var(--card-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(99,102,241,.2);border-radius:16px;box-shadow:var(--glass-shadow)}.nav-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--hover-bg);border:1px solid var(--glass-border);color:var(--text-muted);border-radius:8px;font-weight:600;font-size:.9rem;cursor:pointer;transition:all .2s}.nav-btn:hover{background:var(--hover-bg);color:var(--text-main);border-color:var(--glass-border);transform:translateY(-2px)}.nav-btn.active{background:var(--primary-color);color:var(--text-bright);border-color:var(--primary-color);box-shadow:0 0 10px rgba(var(--accent-rgb),.4)}.nav-btn.correct{background:#10b98133;color:#10b981;border-color:#10b98166}.nav-btn.correct.active{background:#10b981;color:var(--text-bright);box-shadow:0 0 10px rgba(var(--success-rgb),.4)}.nav-btn.incorrect{background:#ef444433;color:#ef4444;border-color:#ef444466}.nav-btn.incorrect.active{background:#ef4444;color:var(--text-bright);box-shadow:0 0 10px rgba(var(--error-rgb),.4)}.reading-results{width:100%;max-width:900px!important;margin:2rem auto!important;padding:3rem!important}.results-content{width:100%;display:flex;flex-direction:column;align-items:center;gap:2.5rem}.mode-toggle-group{display:flex;gap:1rem;margin-top:1rem;padding:.5rem;background:var(--hover-bg);border-radius:12px;border:1px solid var(--glass-border);width:fit-content}.mode-tab{display:flex;align-items:center;gap:.5rem;padding:.6rem 1.2rem;border-radius:8px;border:1px solid transparent;background:transparent;color:var(--text-muted);font-weight:600;cursor:pointer;transition:all .2s;font-size:.9rem}.mode-tab:hover{color:var(--text-bright);background:var(--hover-bg)}.mode-tab.active{background:var(--primary-color);color:var(--text-bright);box-shadow:0 4px 12px #6366f14d}.bookmark-btn.active{color:#facc15!important;border-color:#facc154d!important;background:#facc151a!important}.bookmark-btn.active:hover{background:#facc1533!important}.revision-list{display:flex;flex-direction:column;gap:1rem;grid-column:1 / -1;max-width:800px;margin:0 auto;width:100%}.revision-item-card{display:flex;align-items:center;justify-content:space-between;padding:1.5rem 2rem;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);border:1px solid var(--glass-border);background:var(--card-bg);border-radius:20px}.revision-item-card:hover{transform:translate(8px);border-color:var(--primary-color);background:var(--hover-bg);box-shadow:0 10px 30px -10px #6366f14d}.revision-item-info{flex:1}.test-tag{font-size:.75rem;font-weight:700;color:#818cf8;text-transform:uppercase;margin-bottom:.5rem;letter-spacing:.05em}.revision-item-info h3{font-size:1.2rem;margin-bottom:.5rem;color:var(--text-bright)}.fr-preview{font-size:.95rem;color:var(--text-muted);line-height:1.4}.revision-item-action{color:#6366f1;background:#6366f11a;padding:.5rem;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .3s}.revision-item-card:hover .revision-item-action{background:var(--primary-color);color:var(--text-bright);transform:scale(1.1)}.breadcrumb-link:first-child{padding-left:0}.accent-icon{color:#6366f1;filter:drop-shadow(0 0 15px rgba(99,102,241,.4));animation:pulse 2s infinite ease-in-out}.results-summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1.5rem;width:100%}.result-stat-box{background:var(--card-bg);border:1px solid var(--glass-border);border-radius:20px;padding:1.5rem;display:flex;flex-direction:column;gap:.5rem;transition:all .3s ease}.result-stat-box:hover{background:var(--hover-bg);border-color:var(--glass-border);transform:translateY(-5px)}.result-stat-box.highlight{background:#6366f11a;border-color:#6366f133}.result-stat-box.accent{background:#a855f71a;border-color:#a855f733}.result-stat-box.premium{background:#f59e0b1a;border-color:#f59e0b33}.stat-label{font-size:.8rem;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.05em}.stat-main{display:flex;align-items:baseline;gap:.4rem}.stat-value{font-size:2.2rem;font-weight:800;color:var(--text-bright)}.stat-total{font-size:1.1rem;color:var(--text-muted)}.breakdown-container{width:100%;background:var(--card-bg);border:1px solid var(--glass-border);border-radius:20px;padding:2rem;display:flex;flex-direction:column;gap:1.5rem}.breakdown-container h3{font-size:1.4rem;color:var(--text-bright);margin:0;text-align:left}.breakdown-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem}.breakdown-item{display:flex;flex-direction:column;gap:.75rem}.lvl-name{font-weight:700;color:#818cf8;font-size:1rem}.lvl-stats{display:flex;justify-content:space-between;font-size:.9rem;margin-bottom:.25rem}.lvl-score{color:var(--text-muted)}.lvl-pts{color:var(--text-bright);font-weight:600}.lvl-progress-bg{height:8px;background:var(--hover-bg);border-radius:4px;overflow:hidden}.lvl-progress-fill{height:100%;background:linear-gradient(90deg,#6366f1,#a855f7);border-radius:4px;transition:width 1s cubic-bezier(.34,1.56,.64,1)}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.05);opacity:.8}}@media (max-width: 640px){.reading-results{padding:1.5rem!important}.stat-value{font-size:1.8rem}.breakdown-grid{grid-template-columns:1fr}.mode-toggle-group{width:100%;overflow-x:auto}.revision-item-card{padding:1.25rem 1.5rem}}.search-bar-wrapper{position:relative;width:100%;max-width:400px;margin-bottom:1.5rem}.search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}.search-input{width:100%;padding:.75rem 1rem .75rem 2.75rem;border-radius:12px;border:1px solid var(--glass-border);background:var(--card-bg);color:var(--text-main);font-size:.95rem;outline:none;transition:border-color .2s}.search-input:focus{border-color:var(--primary-color)}.search-input::placeholder{color:var(--text-muted)}.search-clear{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:1rem;padding:4px;line-height:0}.search-clear:hover{color:var(--text-main)}@media (max-width: 768px){.test-grid.has-many{display:flex;flex-wrap:nowrap;overflow-x:auto;gap:1rem;padding-bottom:1rem;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch}.test-grid.has-many .test-card{flex-shrink:0;width:280px;scroll-snap-align:start;margin-bottom:0}}@media (max-width: 640px){.reading-module,.reading-module>div,.reading-module .module-header,.reading-module .progress-section,.reading-module .reading-grid,.reading-module .passage-card,.reading-module .question-card{box-shadow:none!important}.reading-module{padding:0!important;height:100vh;display:flex;flex-direction:column;overflow:hidden;gap:0!important}.breadcrumb-nav,.module-header .title-section h1,.module-header .title-section .subtitle{display:none!important}.module-header{padding:.4rem .6rem 0!important;flex-direction:row!important;align-items:center!important;gap:.3rem!important;flex-shrink:0!important;margin-bottom:0!important}.module-header .title-section{flex-direction:row!important;align-items:center!important;gap:.5rem!important;flex:1!important}.module-header .title-section>div{display:flex!important;align-items:center!important;gap:.5rem!important}.back-circle-btn{display:flex!important;width:32px!important;height:32px!important;position:relative!important;top:auto!important;left:auto!important;background:var(--card-bg)!important;color:var(--text-main)!important;border:1px solid var(--glass-border)!important}.progress-section{flex-direction:row!important;align-items:center!important;gap:.75rem!important;flex-shrink:0!important}.progress-stats{flex-direction:row!important;align-items:center!important;gap:.5rem!important}.progress-stats>div{gap:.4rem!important}.progress-stats span{font-size:.78rem!important}.progress-bar-container{height:3px!important;margin:0!important}.navigator-toggle-btn{width:28px!important;height:28px!important}.reading-grid{flex:1!important;overflow-y:auto!important;gap:.5rem!important;padding:.4rem .6rem!important;grid-template-columns:1fr!important}.passage-card,.question-card{padding:.6rem!important;min-height:auto!important;margin-bottom:0!important;box-shadow:none!important}.passage-text p.fr-text{font-size:.85rem!important;line-height:1.5!important}.passage-text p.en-text{font-size:.8rem!important;line-height:1.4!important}.passage-text h3.passage-title{font-size:.9rem!important}.card-header{margin-bottom:.4rem!important}.card-header .badge{font-size:.7rem!important;padding:2px 6px!important}.action-buttons .icon-btn{width:28px!important;height:28px!important;display:flex!important;align-items:center!important;justify-content:center!important;padding:0!important}.options-grid{gap:.25rem!important}.option-btn{padding:.45rem .55rem!important;font-size:.82rem!important;border-radius:8px!important}.card-footer{padding-top:.65rem!important}.card-footer .btn-primary{padding:.55rem!important;font-size:.85rem!important;width:100%!important}.nav-buttons{display:flex!important;gap:.5rem!important;padding:.5rem 0!important}.nav-buttons .btn-prev,.nav-buttons .btn-next{flex:1!important;padding:.55rem!important;font-size:.85rem!important;display:flex!important;align-items:center!important;justify-content:center!important;gap:.35rem!important;border-radius:8px!important}.nav-buttons .btn-prev{background:var(--hover-bg)!important;border:1px solid var(--glass-border)!important;color:var(--text-main)!important}.question-navigator-container{position:fixed!important;top:0!important;right:0!important;bottom:0!important;left:0!important;z-index:100!important;background:#0009!important;display:flex!important;align-items:center!important;justify-content:center!important;padding:1rem!important}.question-navigator{max-width:320px!important;width:100%!important;max-height:80vh!important}.navigator-grid{grid-template-columns:repeat(5,1fr)!important}.feedback-section .nav-buttons{margin-top:.5rem!important}}@media (max-width: 640px){.test-grid{display:grid!important;grid-template-columns:repeat(auto-fill,minmax(60px,1fr))!important;gap:.5rem!important;overflow:visible!important;flex-wrap:wrap!important;padding-bottom:0!important}.test-grid.has-many{display:grid!important;flex-wrap:wrap!important;overflow:visible!important}.test-card{padding:.6rem .3rem!important;min-height:auto!important;width:auto!important;flex-shrink:1!important;border-radius:20px!important;align-items:center!important;text-align:center!important}.test-card-content{flex-direction:column!important;padding:0!important;gap:0!important;align-items:center!important}.test-card-icon,.test-card-info p,.test-card-footer{display:none!important}.test-card-info h3{font-size:.78rem!important;margin:0!important}.card-meta{display:none!important}}.listening-module{max-width:1200px;margin:0 auto;display:flex;flex-direction:column;gap:2.5rem;padding:2rem 1.5rem}.listening-selection{max-width:1100px;margin:0 auto;display:flex;flex-direction:column;gap:2rem;padding:2rem 1rem}.selection-breadcrumb{display:flex;align-items:center;gap:.5rem;color:var(--text-muted);font-size:.9rem;opacity:.8}.breadcrumb-nav{display:flex;align-items:center;gap:.75rem;margin-bottom:-.5rem}.breadcrumb-link{background:none;border:none;color:var(--text-muted);font-size:.9rem;display:flex;align-items:center;gap:.4rem;cursor:pointer;transition:color .2s;padding:0}.breadcrumb-link:hover{color:#6366f1}.separator{color:var(--text-dim)}.current-page{color:#6366f1;font-weight:500;font-size:.9rem}.selection-header{text-align:left;display:flex;flex-direction:column;gap:.5rem}.selection-header h1{font-size:2.2rem;background:var(--header-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;margin:0}.test-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:2rem;width:100%;padding-bottom:3rem}.test-card{display:flex;flex-direction:column;padding:0;cursor:pointer;transition:all .4s cubic-bezier(.23,1,.32,1);border:1px solid var(--glass-border);overflow:hidden;background:var(--card-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:20px;margin-bottom:.5rem;box-shadow:var(--glass-shadow)}.test-card-content{padding:1.5rem;display:flex;gap:1.25rem;flex:1}.test-card:hover{background:var(--hover-bg);border-color:#6366f166;transform:translateY(-8px);box-shadow:0 20px 40px -10px #6366f166}.test-card-icon{background:#6366f126;color:#818cf8;min-width:56px;height:56px;display:flex;align-items:center;justify-content:center;border-radius:20px}.test-card-info h3{font-size:1.3rem;margin-bottom:.5rem;color:var(--text-bright);font-weight:600}.card-meta{display:flex;gap:.75rem;margin-bottom:.75rem}.exam-flag{font-size:.7rem;font-weight:700;padding:.2rem .5rem;border-radius:4px;color:#f59e0b;background:#f59e0b26}.questions-badge{font-size:.7rem;font-weight:700;padding:.2rem .5rem;border-radius:4px;text-transform:uppercase;color:#818cf8;background:#6366f126}.test-card-footer{padding:1rem 1.5rem;border-top:1px solid var(--hover-bg);display:flex;justify-content:space-between;align-items:center;background:var(--card-bg)}.start-text{font-size:.85rem;font-weight:600;color:#6366f1;text-transform:uppercase;letter-spacing:.05em}.arrow-icon{color:#6366f1;transition:transform .3s}.test-card:hover .arrow-icon{transform:translate(5px)}.module-header{display:flex;justify-content:space-between;align-items:center;gap:2rem;flex-wrap:wrap}.title-section{display:flex;align-items:center;gap:1.5rem}.back-circle-btn{width:44px;height:44px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--hover-bg);border:1px solid var(--glass-border);color:var(--text-muted);cursor:pointer;transition:all .2s}.back-circle-btn:hover{background:var(--primary-color);color:var(--text-bright);transform:translate(-3px)}.subtitle{color:var(--text-muted);font-size:.9rem;margin-top:.15rem}.progress-section{flex:1;max-width:400px;min-width:250px}.progress-stats{display:flex;justify-content:space-between;margin-bottom:.5rem;font-size:.9rem;font-weight:500}.progress-bar-container{height:8px;background:var(--glass-border);border-radius:4px;overflow:hidden}.progress-bar-fill{height:100%;background:linear-gradient(90deg,#6366f1,#a855f7);transition:width .3s ease}.listening-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:3rem;align-items:start}@media (max-width: 968px){.listening-grid{grid-template-columns:1fr}}.audio-card,.question-card{display:flex;flex-direction:column;padding:1.25rem;min-height:450px;background:var(--card-bg);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid var(--glass-border);border-radius:20px;box-shadow:var(--glass-shadow)}.listening-module .audio-card{border-radius:20px}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.badge{display:flex;align-items:center;gap:.5rem;padding:.25rem .75rem;background:#6366f133;color:#818cf8;border-radius:99px;font-size:.8rem;font-weight:600;text-transform:uppercase}.action-buttons{display:flex;gap:.75rem}.icon-btn{background:var(--hover-bg);border:1px solid var(--glass-border);color:var(--text-muted);padding:.5rem;border-radius:8px;cursor:pointer;transition:all .2s}.icon-btn:hover{color:var(--text-main)}.icon-btn.active{background:var(--primary-color);color:var(--text-bright);border-color:var(--primary-color)}.audio-visual-container{display:flex;flex-direction:column;gap:2rem;margin-bottom:2rem}.listening-asset-image{max-width:100%;border-radius:12px;box-shadow:0 4px 12px #0000001a}.audio-playback-controls{display:flex;align-items:center;gap:1.5rem;padding:1.5rem;background:var(--hover-bg);border-radius:16px;border:1px solid var(--glass-border)}.play-btn-large{width:80px;height:80px;border-radius:50%;background:var(--primary-color);color:#fff;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;box-shadow:0 8px 16px #6366f14d}.play-btn-large:hover{transform:scale(1.05)}.audio-status h3{margin:0;font-size:1.2rem;color:var(--text-bright)}.audio-status p{margin:.25rem 0 0;color:var(--text-muted);font-size:.9rem}.audio-timeline-container{display:flex;align-items:center;gap:.75rem;flex:1;min-width:0}.audio-time{font-size:.8rem;font-weight:600;font-variant-numeric:tabular-nums;color:var(--text-muted);white-space:nowrap;min-width:3.5rem;text-align:center}.audio-progress-bar{flex:1;height:6px;background:var(--glass-border);border-radius:3px;cursor:pointer;position:relative;min-width:60px}.audio-progress-fill{height:100%;background:var(--primary-color);border-radius:3px;position:absolute;top:0;left:0;pointer-events:none;transition:width .1s linear}.audio-progress-thumb{width:14px;height:14px;border-radius:50%;background:var(--primary-color);position:absolute;top:50%;transform:translate(-50%,-50%);pointer-events:none;box-shadow:0 0 6px #6366f180}.transcript-section{margin-top:auto;border-top:1px solid var(--glass-border);padding-top:1.5rem}.transcript-toggle{background:none;border:none;color:#6366f1;font-weight:600;display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.9rem}.transcript-text{margin-top:1rem}.fr-text{font-size:1.1rem;line-height:1.6;color:var(--text-main);margin-bottom:.75rem}.en-text{font-size:.95rem;color:var(--text-muted);font-style:italic;border-left:2px solid #6366f1;padding-left:1rem}.question-header h3{color:var(--text-bright);font-size:1.4rem;margin-bottom:.5rem}.en-question{color:var(--text-muted);font-size:.95rem;margin-bottom:1.5rem}.options-list{display:flex;flex-direction:column;gap:.75rem;margin-bottom:2rem}.option-item{display:flex;align-items:center;gap:1rem;padding:1.1rem;background:var(--hover-bg);border:1px solid var(--glass-border);border-radius:12px;color:var(--text-main);cursor:pointer;text-align:left;transition:all .2s}.option-item:hover:not(:disabled){background:#6366f11a;border-color:#6366f14d}.option-item.selected{border-color:#6366f1;background:#6366f126}.option-item.correct{border-color:#10b981;background:#10b98126}.option-item.incorrect{border-color:#ef4444;background:#ef444426}.option-label{background:var(--glass-border);width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:6px;font-weight:700;color:var(--text-muted);font-size:.85rem}.selected .option-label{background:#6366f1;color:#fff}.correct .option-label{background:#10b981;color:#fff}.incorrect .option-label{background:#ef4444;color:#fff}.option-content{display:flex;flex-direction:column;flex:1}.fr-opt{font-size:1.05rem}.en-opt{font-size:.85rem;color:var(--text-muted)}.feedback-section{display:flex;flex-direction:column;gap:1rem}.feedback-banner{display:flex;align-items:center;gap:.75rem;padding:.8rem 1rem;border-radius:8px;font-weight:600}.feedback-banner.success{background:#10b98133;color:#10b981}.feedback-banner.error{background:#ef444433;color:#ef4444}.explanation{font-size:.95rem;color:var(--text-muted);line-height:1.6}.btn-next{background:var(--primary-color);color:#fff;border:none;padding:.8rem;border-radius:10px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.5rem}.feedback-actions{display:flex;gap:.5rem;flex-wrap:wrap}.feedback-actions .btn-next{flex:1}.btn-sm{padding:.5rem .9rem;font-size:.85rem;border-radius:8px;cursor:pointer;display:inline-flex;align-items:center;gap:.4rem;font-weight:500}.navigator-toggle-btn{background:#6366f11a;border:1px solid rgba(99,102,241,.2);color:#818cf8;border-radius:6px;padding:.4rem;cursor:pointer}.question-navigator{padding:1.5rem;background:var(--card-bg);border:1px solid rgba(99,102,241,.2);border-radius:16px;margin-bottom:1.5rem}.navigator-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(40px,1fr));gap:.75rem}.nav-btn{width:40px;height:40px;border-radius:8px;border:1px solid var(--glass-border);background:var(--hover-bg);color:var(--text-muted);font-weight:600;cursor:pointer;transition:all .2s}.nav-btn.active{background:#6366f1;color:#fff;border-color:#6366f1}.nav-btn.correct{background:#10b98133;color:#10b981}.nav-btn.incorrect{background:#ef444433;color:#ef4444}.listening-results{max-width:600px;margin:4rem auto;padding:3rem;text-align:center}.result-stat-box{background:var(--hover-bg);padding:1.5rem;border-radius:16px;border:1px solid var(--glass-border)}.stat-value{font-size:2.5rem;font-weight:700;color:#6366f1}.stat-total{font-size:1.2rem;color:var(--text-muted)}.result-actions{display:flex;gap:1rem;justify-content:center;margin-top:2rem}.btn-primary{background:var(--primary-color);color:#fff;padding:.8rem 1.5rem;border-radius:10px;font-weight:600;border:none;cursor:pointer}.btn-secondary{background:var(--hover-bg);color:var(--text-muted);padding:.8rem 1.5rem;border-radius:10px;font-weight:600;border:1px solid var(--glass-border);cursor:pointer}.listening-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:1rem;color:var(--text-muted)}@media (max-width: 640px){.listening-module,.listening-module>div,.listening-module .module-header,.listening-module .progress-section,.listening-module .listening-grid,.listening-module .audio-card,.listening-module .question-card{box-shadow:none!important}.listening-module{padding:0!important;height:100vh;display:flex;flex-direction:column;overflow:hidden;gap:0!important}.breadcrumb-nav,.module-header .title-section h1,.module-header .title-section .subtitle{display:none!important}.module-header{padding:.4rem .6rem 0!important;flex-direction:row!important;align-items:center!important;gap:.3rem!important;flex-shrink:0!important;margin-bottom:0!important}.module-header .title-section{flex-direction:row!important;align-items:center!important;gap:.5rem!important;flex:1!important}.module-header .title-section>div{display:flex!important;align-items:center!important;gap:.5rem!important}.back-circle-btn{display:flex!important;width:32px!important;background:var(--card-bg)!important;color:var(--text-main)!important;border:1px solid var(--glass-border)!important;height:32px!important}.progress-section{flex-direction:row!important;align-items:center!important;gap:.75rem!important;flex-shrink:0!important}.progress-stats{flex-direction:row!important;align-items:center!important;gap:.5rem!important}.progress-stats span{font-size:.78rem!important}.progress-bar-container{height:3px!important;margin:0!important}.listening-grid{flex:1!important;overflow-y:auto!important;gap:.5rem!important;padding:.4rem .6rem!important;grid-template-columns:1fr!important}.audio-card,.question-card{padding:.6rem!important;min-height:auto!important;margin-bottom:0!important;box-shadow:none!important;min-width:0!important;width:100%!important}.transcript-text{font-size:.85rem!important;line-height:1.5!important}.question-card h3{font-size:.9rem!important}.options-grid{gap:.35rem!important}.option-btn{padding:.55rem .65rem!important;font-size:.82rem!important;border-radius:8px!important}.card-header .badge{font-size:.7rem!important;padding:2px 6px!important}.card-header{margin-bottom:.4rem!important}.action-buttons .icon-btn{display:flex!important;align-items:center!important;justify-content:center!important;padding:0!important}.card-footer .btn-primary{padding:.55rem!important;font-size:.85rem!important;width:100%!important}.nav-buttons{display:flex!important;gap:.5rem!important;padding:.5rem 0!important}.nav-buttons .btn-prev,.nav-buttons .btn-next{flex:1!important;padding:.55rem!important;font-size:.85rem!important;display:flex!important;align-items:center!important;justify-content:center!important;gap:.35rem!important;border-radius:8px!important}.nav-buttons .btn-prev{background:var(--hover-bg)!important;border:1px solid var(--glass-border)!important;color:var(--text-main)!important}.question-navigator-container{position:fixed!important;top:0!important;right:0!important;bottom:0!important;left:0!important;z-index:100!important;background:#0009!important;display:flex!important;align-items:center!important;justify-content:center!important;padding:1rem!important}.question-navigator{max-width:320px!important;width:100%!important;max-height:80vh!important}.navigator-grid{grid-template-columns:repeat(5,1fr)!important}.audio-playback-controls{flex-wrap:wrap!important;padding:.75rem!important;gap:.5rem!important}.play-btn-large{width:44px!important;height:44px!important}.play-btn-large svg{width:24px!important;height:24px!important}.audio-status h3{font-size:.85rem!important}.audio-status p{font-size:.75rem!important}.audio-timeline-container{width:100%!important;flex:none!important;order:1!important}}@media (max-width: 640px){.test-grid{grid-template-columns:repeat(auto-fill,minmax(60px,1fr))!important;gap:.5rem!important}.test-card{padding:.6rem .3rem!important;min-height:auto!important;border-radius:10px!important;align-items:center!important;text-align:center!important}.test-card-content{flex-direction:column!important;padding:0!important;gap:0!important;align-items:center!important}.test-card-icon,.test-card-info p,.test-card-footer{display:none!important}.test-card-info h3{font-size:.78rem!important;margin:0!important}.card-meta{display:none!important}}.speaking-exam-idle{max-width:700px;margin:0 auto;padding:2rem 1rem}.exam-idle-content{display:flex;flex-direction:column;align-items:center;text-align:center;gap:2rem;margin-top:3rem}.exam-icon-wrapper{width:120px;height:120px;border-radius:50%;background:#6366f126;display:flex;align-items:center;justify-content:center}.exam-icon-pulse{color:#818cf8;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1);opacity:.7}50%{transform:scale(1.1);opacity:1}}.exam-idle-content h1{font-size:2rem;background:var(--header-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.exam-info-cards{display:flex;gap:1.5rem;flex-wrap:wrap;justify-content:center}.info-card{display:flex;align-items:center;gap:.5rem;padding:.6rem 1.2rem;background:var(--hover-bg);border:1px solid var(--glass-border);border-radius:20px;color:var(--text-muted);font-size:.9rem;font-weight:500}.exam-description{max-width:500px;color:var(--text-muted);line-height:1.6}.exam-start-btn{display:flex;align-items:center;gap:.6rem;padding:1rem 2.5rem;font-size:1.1rem}.mic-error-banner{display:flex;align-items:center;gap:.75rem;padding:1rem 1.5rem;background:#ef444426;border:1px solid rgba(239,68,68,.3);border-radius:12px;color:#ef4444;font-size:.9rem;max-width:500px;line-height:1.5}.speaking-exam-active{max-width:800px;margin:0 auto;padding:1rem;display:flex;flex-direction:column;gap:1.5rem;min-height:80vh}.exam-top-bar{display:flex;justify-content:space-between;align-items:center}.exam-timer{display:flex;align-items:center;gap:.5rem;font-size:1.4rem;font-weight:700;color:var(--text-bright);font-variant-numeric:tabular-nums}.timer-critical{color:#ef4444;animation:pulse .5s ease-in-out infinite}.exam-progress-bar{height:6px;background:var(--glass-border);border-radius:3px;overflow:hidden}.exam-progress-fill{height:100%;background:linear-gradient(90deg,#6366f1,#a855f7);transition:width 1s linear}.exam-main{flex:1;display:flex;flex-direction:column;gap:3rem;justify-content:center}.examiner-section{display:flex;align-items:flex-start;gap:1.5rem}.examiner-avatar{width:64px;height:64px;border-radius:50%;background:#6366f133;color:#818cf8;display:flex;align-items:center;justify-content:center;position:relative;flex-shrink:0}.speaking-indicator{position:absolute;bottom:0;right:0;width:16px;height:16px;border-radius:50%;background:#10b981;animation:pulse .8s ease-in-out infinite}.examiner-bubble{background:var(--hover-bg);border:1px solid var(--glass-border);border-radius:16px;padding:1.5rem;flex:1;position:relative}.examiner-bubble:before{content:"";position:absolute;left:-8px;top:20px;width:16px;height:16px;background:var(--hover-bg);border-left:1px solid var(--glass-border);border-bottom:1px solid var(--glass-border);transform:rotate(45deg)}.examiner-text{font-size:1.15rem;line-height:1.6;color:var(--text-bright)}.user-section{display:flex;flex-direction:column;align-items:center;gap:1.5rem}.user-indicator{display:flex;align-items:center;gap:.75rem;color:var(--text-muted);font-size:.95rem}.mic-status{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--hover-bg);border:2px solid var(--glass-border);transition:all .3s}.mic-status.recording{background:#ef444426;border-color:#ef4444;color:#ef4444;animation:pulse 1s ease-in-out infinite}.waveform-container{width:100%;max-width:400px;display:flex;justify-content:center}.waveform-canvas{width:100%;height:60px;border-radius:12px;background:#6366f114;border:1px solid rgba(99,102,241,.2)}.answer-timer-bar{width:100%;max-width:400px;height:8px;background:var(--glass-border);border-radius:4px;position:relative;overflow:hidden}.answer-timer-fill{height:100%;background:linear-gradient(90deg,#10b981,#f59e0b,#ef4444);transition:width 1s linear;border-radius:4px}.answer-timer-text{position:absolute;right:-3rem;top:-.25rem;font-size:.85rem;font-weight:600;color:var(--text-muted)}.exam-actions{display:flex;gap:1rem}.speaking-exam-review{max-width:700px;margin:0 auto;padding:2rem 1rem;display:flex;flex-direction:column;gap:2rem}.review-header{text-align:center}.review-header h1{font-size:1.8rem;margin-top:1rem;color:var(--text-bright)}.review-subtitle{color:var(--text-muted);margin-top:.5rem}.review-recording{background:var(--hover-bg);border:1px solid var(--glass-border);border-radius:16px;padding:1.5rem}.review-recording h3{margin-bottom:1rem;color:var(--text-bright)}.review-audio{width:100%}.review-questions{display:flex;flex-direction:column;gap:.75rem}.review-questions h3{color:var(--text-bright)}.review-question-card{background:var(--hover-bg);border:1px solid var(--glass-border);border-radius:20px;padding:.75rem 1rem;cursor:pointer}.review-question-card summary{display:flex;align-items:center;gap:.75rem;cursor:pointer;list-style:none}.review-question-card summary::-webkit-details-marker{display:none}.q-num{background:#6366f126;color:#818cf8;padding:.25rem .6rem;border-radius:6px;font-weight:700;font-size:.85rem;flex-shrink:0}.q-text{flex:1;font-weight:500;color:var(--text-main)}.check-icon{color:#10b981;flex-shrink:0}.review-q-detail{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--glass-border);display:flex;flex-direction:column;gap:.75rem}.review-answer-audio{width:100%}.review-actions{display:flex;gap:1rem;justify-content:center}.tense-module{max-width:1200px;margin:0 auto;padding:1.5rem 2rem}.tense-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:5rem;text-align:center;min-height:60vh;color:var(--text-muted)}.tense-top-nav{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.tense-top-nav button{display:flex;align-items:center;gap:.35rem;background:none;border:none;color:var(--accent);font-size:.85rem;font-weight:600;cursor:pointer;padding:0;white-space:nowrap}.tense-top-nav button:hover{opacity:.8}.tense-nav-pills{display:flex;gap:.35rem;flex-wrap:wrap;flex:1}.pill{padding:.35rem .75rem;border-radius:999px;font-size:.75rem;font-weight:600;border:none;cursor:pointer;transition:all .15s;white-space:nowrap}.pill-inactive{background:var(--glass-bg);border:1px solid var(--glass-border);color:var(--text-muted)}.pill-inactive:hover{background:var(--hover-bg);color:var(--text-bright)}.pill-active{background:var(--accent);color:#fff;border:1px solid var(--accent)}.tense-header{padding:1.5rem 2rem;background:var(--card-bg);border:1px solid var(--glass-border);border-radius:16px;margin-bottom:2rem}.tense-title-row{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.tense-icon{width:52px;height:52px;border-radius:14px;background:linear-gradient(135deg,var(--accent),var(--accent-secondary, #06b6d4));display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.tense-header h1{font-size:1.75rem;font-weight:800;margin:0;color:var(--text-bright);letter-spacing:-.02em}.tense-subtitle{font-size:.9rem;color:var(--text-muted);margin:0;font-weight:500}.tense-intro{font-size:.9rem;line-height:1.6;color:var(--text);margin:0;padding-top:1rem;border-top:1px solid var(--glass-border)}.tense-layout{display:grid;grid-template-columns:220px 1fr;gap:2rem;align-items:start}.tense-sidebar{position:sticky;top:1rem;display:flex;flex-direction:column;gap:.35rem;padding:.75rem;background:var(--card-bg);border:1px solid var(--glass-border);border-radius:12px}.tense-nav-item{display:flex;align-items:center;gap:.6rem;padding:.65rem .75rem;border-radius:8px;border:none;background:none;color:var(--text-muted);font-size:.82rem;font-weight:500;cursor:pointer;transition:all .15s;text-align:left;width:100%;position:relative}.tense-nav-item:hover{background:var(--hover-bg);color:var(--text-bright)}.nav-item-active{background:var(--accent-alpha, rgba(99, 102, 241, .12));color:var(--accent);font-weight:600}.nav-number{width:22px;height:22px;border-radius:6px;background:var(--glass-bg);border:1px solid var(--glass-border);display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:700;flex-shrink:0}.nav-item-active .nav-number{background:var(--accent);color:#fff;border-color:var(--accent)}.nav-arrow{margin-left:auto;opacity:.6}.tense-content{min-height:40vh}.section-content{display:flex;flex-direction:column;gap:1.5rem}.step-card{padding:1.5rem;background:var(--card-bg);border:1px solid var(--glass-border);border-radius:12px}.step-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.step-num{width:32px;height:32px;border-radius:8px;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:800;flex-shrink:0}.step-header h2{font-size:1.15rem;font-weight:700;margin:0;color:var(--text-bright)}.step-text{font-size:.9rem;line-height:1.6;color:var(--text);margin:0 0 1rem}.conj-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:.5rem}.conj-cell{padding:.75rem 1rem;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:8px;text-align:center;font-size:.9rem;font-weight:600;color:var(--text-bright);transition:background .15s}.conj-cell:hover{background:var(--hover-bg)}.subsections-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.subsection-card{padding:1.25rem;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:10px}.subsection-title{font-size:.95rem;font-weight:600;color:var(--text-bright);margin:0 0 .5rem}.subsection-text{font-size:.85rem;color:var(--text);margin:0 0 .75rem;line-height:1.5}.examples-list{display:flex;flex-direction:column;gap:.4rem}.example-row{display:flex;align-items:center;gap:.5rem;font-size:.85rem;flex-wrap:wrap}.example-fr{font-weight:600;color:var(--text-bright)}.example-pp{color:var(--accent);font-weight:500}.example-en{color:var(--text-muted);font-style:italic;font-size:.8rem}.note-box{margin-top:1rem;padding:.75rem 1rem;background:#f59e0b14;border:1px solid rgba(245,158,11,.2);border-radius:8px;font-size:.82rem;color:var(--text);line-height:1.5}.note-box strong{color:#f59e0b;text-transform:uppercase;font-size:.7rem;letter-spacing:.05em;display:block;margin-bottom:.25rem}.irregular-lists{margin-top:1.5rem}.list-group-title{font-size:.95rem;font-weight:700;color:var(--text-bright);margin:0 0 .75rem;display:flex;align-items:center;gap:.5rem}.verb-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.5rem}.verb-grid.wide{grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}.verb-card{padding:.6rem .75rem;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:8px;transition:all .15s}.verb-card:hover{border-color:var(--accent);background:var(--hover-bg)}.verb-card.with-ex{padding:.6rem .75rem}.verb-row{display:flex;align-items:center;gap:.4rem;font-size:.85rem}.verb-main{font-weight:700;color:var(--text-bright)}.verb-arrow{color:var(--accent);font-weight:700;opacity:.7}.verb-pp{font-weight:600;color:var(--accent)}.verb-eg{font-size:.8rem;color:var(--text-muted);font-style:italic;padding-top:.35rem;margin-top:.35rem;border-top:1px solid var(--glass-border)}.section-block{padding:1.5rem;background:var(--card-bg);border:1px solid var(--glass-border);border-radius:12px}.block-header{display:flex;align-items:center;gap:.6rem;margin-bottom:1rem;color:var(--text-bright)}.block-header h3{font-size:1.1rem;font-weight:700;margin:0}.sentences-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.sentence-card{padding:1rem 1.25rem;background:var(--glass-bg);border:1px solid var(--glass-border);border-left:4px solid var(--accent);border-radius:8px;transition:background .15s}.sentence-card:hover{background:var(--hover-bg)}.sentence-fr{font-size:.95rem;font-weight:600;color:var(--text-bright);margin:0 0 .25rem}.sentence-en{font-size:.85rem;color:var(--text-muted);font-style:italic;margin:0}.examples-vertical{display:flex;flex-direction:column;gap:.75rem}.example-card{padding:1rem 1.25rem;background:var(--glass-bg);border:1px solid var(--glass-border);border-left:4px solid var(--accent);border-radius:8px}.quiz-list{display:flex;flex-direction:column;gap:1.25rem}.quiz-item{padding-bottom:1.25rem;border-bottom:1px solid var(--glass-border)}.quiz-item:last-child{border-bottom:none;padding-bottom:0}.quiz-question{font-size:.92rem;font-weight:500;color:var(--text);margin:0 0 .6rem;line-height:1.5}.q-num{color:var(--accent);font-weight:700;margin-right:.25rem}.quiz-row{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.quiz-input{flex:1;min-width:200px;padding:.6rem 1rem;background:var(--glass-bg);border:2px solid var(--glass-border);border-radius:8px;color:var(--text-bright);font-size:.9rem;font-weight:500;transition:border-color .2s;outline:none}.quiz-input:focus{border-color:var(--accent)}.quiz-input.input-correct{border-color:#10b981;background:#10b9810f}.quiz-input.input-wrong{border-color:#ef4444;background:#ef44440f}.quiz-feedback{display:flex;align-items:center;gap:.4rem;font-size:.85rem;font-weight:700;white-space:nowrap}.feedback-correct{color:#10b981}.feedback-wrong{color:#ef4444}.quiz-actions{margin-top:.5rem}.btn-primary{padding:.7rem 1.5rem;background:var(--accent);color:#fff;border:none;border-radius:8px;font-size:.85rem;font-weight:700;cursor:pointer;transition:opacity .15s}.btn-primary:hover{opacity:.9}.btn-secondary{padding:.7rem 1.5rem;background:var(--glass-bg);color:var(--text-bright);border:1px solid var(--glass-border);border-radius:8px;font-size:.85rem;font-weight:700;cursor:pointer;display:inline-flex;align-items:center;gap:.4rem;transition:background .15s}.btn-secondary:hover{background:var(--hover-bg)}.agreement-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem}.agreement-card{padding:1.25rem;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:10px;text-align:center;border-bottom:3px solid var(--accent)}.agreement-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-weight:600;margin-bottom:.5rem}.agreement-suffix{font-size:2rem;font-weight:800;color:var(--text-bright);margin-bottom:.5rem}.agreement-example{font-size:.85rem;color:var(--accent);font-style:italic;font-weight:500}.verbs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.5rem}.home-verb-item{padding:.75rem;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:8px;transition:border-color .15s}.home-verb-item:hover{border-color:var(--accent)}.home-verb-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:.25rem}.home-verb-top strong{font-size:.95rem;color:var(--text-bright)}.home-pp{font-size:.75rem;font-weight:700;color:var(--accent);background:var(--accent-alpha, rgba(99, 102, 241, .12));padding:.15rem .5rem;border-radius:4px}.home-meaning{font-size:.8rem;color:var(--text-muted)}.table-wrap{overflow-x:auto;margin-bottom:1rem}.data-table{width:100%;border-collapse:collapse;font-size:.85rem;border-radius:8px;overflow:hidden}.data-table th{background:var(--accent-alpha, rgba(99, 102, 241, .12));color:var(--accent);font-weight:700;text-align:left;padding:.65rem .75rem;font-size:.8rem;text-transform:uppercase;letter-spacing:.03em;border-bottom:2px solid var(--glass-border)}.data-table td{padding:.6rem .75rem;border-bottom:1px solid var(--glass-border);color:var(--text);line-height:1.5}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:var(--hover-bg)}@media (max-width: 900px){.tense-layout{grid-template-columns:1fr}.tense-sidebar{position:static;flex-direction:row;overflow-x:auto;gap:.3rem;padding:.5rem}.tense-nav-item{white-space:nowrap;padding:.5rem .75rem;flex-shrink:0}.nav-number,.nav-arrow{display:none}.subsections-grid,.sentences-grid{grid-template-columns:1fr}.agreement-grid{grid-template-columns:1fr 1fr}.tense-header h1{font-size:1.4rem}.data-table{font-size:.78rem}.data-table th,.data-table td{padding:.5rem}}@media (max-width: 600px){.tense-module{padding:1rem}.tense-header{padding:1.25rem}.agreement-grid{grid-template-columns:1fr}.data-table{font-size:.72rem}.data-table th,.data-table td{padding:.4rem .35rem}}.vocab-module{display:flex;flex-direction:column;gap:2rem;max-width:1200px;margin:0 auto;padding:1rem}.vocab-header{padding:2rem;border-radius:20px;display:flex;flex-direction:column;gap:2rem}.header-top{display:flex;justify-content:space-between;align-items:center}.title-section{display:flex;align-items:center;gap:1rem}.title-icon{color:var(--accent-light);filter:drop-shadow(0 0 8px rgba(99,102,241,.5))}.title-section h2{font-size:1.75rem;margin:0;color:var(--text-main)}.btn-add{display:flex;align-items:center;gap:.75rem;padding:.75rem 1.5rem;border-radius:12px;background:var(--primary-color);color:#fff;font-weight:600;transition:all .3s ease;box-shadow:0 4px 15px rgba(var(--accent-rgb),.3)}.btn-add:hover{transform:translateY(-2px);box-shadow:0 6px 20px #6366f166}.btn-add.active{background:var(--hover-bg);border:1px solid var(--glass-border)}.add-vocab-form{overflow:hidden;background:var(--hover-bg);border-radius:16px;margin-top:1rem}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;padding:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.85rem;font-weight:500;color:var(--primary-light);text-transform:uppercase;letter-spacing:.05em}.form-group input{padding:.75rem 1rem;background:rgba(var(--bg-rgb),.3);border:1px solid var(--glass-border);border-radius:10px;color:var(--text-main);transition:all .3s ease}.form-group input:focus{border-color:var(--primary-color);outline:none;background:rgba(var(--bg-rgb),.5);box-shadow:0 0 0 3px rgba(var(--accent-rgb),.2)}.btn-save{width:100%;padding:1rem;background:rgba(var(--success-rgb),.1);border:1px solid rgba(var(--success-rgb),.3);color:var(--success-color);font-weight:700;display:flex;align-items:center;justify-content:center;gap:.75rem;transition:all .3s ease}.btn-save:hover{background:#10b98133}.btn-save:disabled{opacity:.5;cursor:not-allowed}.controls-section{display:flex;flex-direction:column;gap:1.5rem}.search-bar{position:relative;display:flex;align-items:center}.search-bar svg{position:absolute;left:1.25rem;color:var(--text-muted)}.search-bar input{width:100%;padding:1rem 1rem 1rem 3.5rem;background:var(--card-bg);border:1px solid var(--glass-border);border-radius:14px;color:var(--text-main);font-size:1rem;transition:all .3s ease}.search-bar input:focus{border-color:var(--primary-color);outline:none;box-shadow:0 0 20px rgba(var(--accent-rgb),.1)}.filter-section{display:flex;align-items:center;gap:1rem}.filter-section svg{color:var(--primary-light)}.category-chips{display:flex;gap:.75rem;flex-wrap:wrap}.cat-chip{padding:.5rem 1.25rem;border-radius:20px;background:var(--hover-bg);border:1px solid var(--glass-border);color:var(--text-muted);font-size:.875rem;transition:all .3s ease}.cat-chip:hover{background:#ffffff1a;color:var(--text-bright)}.cat-chip.active{background:var(--primary-color);border-color:var(--primary-color);color:#fff;box-shadow:0 4px 12px rgba(var(--accent-rgb),.3)}.vocab-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem}.vocab-card{padding:1.5rem;display:flex;flex-direction:column;gap:1.25rem;border:1px solid var(--glass-border);transition:all .3s cubic-bezier(.4,0,.2,1)}.vocab-card:hover{transform:translateY(-5px);border-color:rgba(var(--accent-rgb),.3);background:var(--hover-bg)}.card-header{display:flex;justify-content:space-between;align-items:center}.card-category{display:flex;align-items:center;gap:.5rem;font-size:.75rem;color:var(--primary-light);text-transform:uppercase;letter-spacing:.05em;background:rgba(var(--accent-rgb),.1);padding:.25rem .75rem;border-radius:100px}.card-actions{display:flex;gap:.5rem}.btn-icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;background:var(--hover-bg);color:var(--text-muted);transition:all .2s ease}.btn-icon:hover{background:#ffffff26;color:var(--text-bright)}.btn-icon.delete:hover{background:rgba(var(--error-rgb),.15);color:var(--error-color)}.card-main{display:flex;flex-direction:column;gap:1rem}.french-section h3{font-size:1.5rem;margin:0;color:var(--text-main);font-weight:700}.hints{display:flex;flex-wrap:wrap;gap:1rem;margin-top:.5rem}.hint{font-size:.9rem;color:var(--text-muted)}.hint.hindi:before{content:"🇮🇳 "}.hint.punjabi:before{content:"👳 "}.divider{height:1px;background:linear-gradient(90deg,var(--glass-border) 0%,transparent 100%)}.english-section p{font-size:1.125rem;color:var(--text-muted);margin:0;line-height:1.5}.no-vocab{padding:5rem 2rem;display:flex;flex-direction:column;align-items:center;gap:1.5rem;text-align:center;color:var(--text-muted)}.vocab-loader{display:flex;justify-content:center;padding:5rem;color:var(--accent-primary)}.spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width: 768px){.header-top{flex-direction:column;align-items:flex-start;gap:1.5rem}.btn-add{width:100%;justify-content:center}.vocab-grid{grid-template-columns:1fr}.filter-section{flex-direction:column;align-items:flex-start}}
