:root{--lumen-cream: #F4EEE1;--lumen-cream-soft: #FAF6EB;--lumen-bg: #faf9f5;--lumen-ink: #1F3A2E;--lumen-ink-soft: #2A4D3F;--lumen-line: rgba(31, 58, 46, .14);--lumen-line-strong: rgba(31, 58, 46, .28);--lumen-mute: #6F7B72;--lumen-card: #FFFFFF;--lumen-error: #B0272D;--primary: #6366F1;--primary-light: #818CF8;--primary-dark: #4F46E5;--secondary: #8B5CF6;--secondary-light: #A78BFA;--accent: #F59E0B;--accent-light: #FBBF24;--success: #10B981;--success-light: #34D399;--error: #EF4444;--warning: #F59E0B;--shadow-sm: 0 2px 4px rgba(0, 0, 0, .02), 0 4px 8px rgba(0, 0, 0, .04);--shadow-md: 0 4px 6px rgba(0, 0, 0, .02), 0 8px 16px rgba(0, 0, 0, .04);--shadow-lg: 0 8px 12px rgba(0, 0, 0, .02), 0 16px 32px rgba(0, 0, 0, .08);--shadow-xl: 0 20px 60px rgba(0, 0, 0, .12);--shadow-glow: 0 0 20px rgba(99, 102, 241, .3);--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .4s ease;--transition-bounce: .5s cubic-bezier(.34, 1.56, .64, 1)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#fafbff;color:#1a1d26;line-height:1.6;min-height:100vh;-webkit-font-smoothing:antialiased}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#6366f133;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#6366f166}.glass{background:#ffffffb3;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border:1px solid rgba(255,255,255,.3)}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes glow{0%,to{box-shadow:0 0 5px #6366f14d}50%{box-shadow:0 0 20px #6366f199}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}@keyframes wiggle{0%,to{transform:rotate(0)}25%{transform:rotate(-3deg)}75%{transform:rotate(3deg)}}@keyframes heartbeat{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}@keyframes ripple{0%{transform:scale(0);opacity:1}to{transform:scale(4);opacity:0}}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-30px)}to{opacity:1;transform:translate(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(30px)}to{opacity:1;transform:translate(0)}}@keyframes zoomIn{0%{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}@keyframes slideInUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInScale{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes iconBounce{0%,to{transform:translateY(0)}50%{transform:translateY(-3px)}}@keyframes iconWiggle{0%,to{transform:rotate(0)}25%{transform:rotate(-10deg)}75%{transform:rotate(10deg)}}@keyframes iconPop{0%{transform:scale(1)}50%{transform:scale(1.3)}to{transform:scale(1)}}@keyframes iconShake{0%,to{transform:translate(0)}20%{transform:translate(-2px) rotate(-5deg)}40%{transform:translate(2px) rotate(5deg)}60%{transform:translate(-2px) rotate(-5deg)}80%{transform:translate(2px) rotate(5deg)}}@keyframes progressStripe{0%{background-position:0 0}to{background-position:40px 0}}@keyframes typing{0%{width:0}to{width:100%}}@keyframes blink{50%{border-color:transparent}}@keyframes morphIcon{0%,to{transform:scale(1)}25%{transform:scale(.9) rotate(-5deg)}75%{transform:scale(1.1) rotate(5deg)}}@keyframes sparkle{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}@keyframes iconRotate{0%{transform:rotate(0)}25%{transform:rotate(-15deg)}75%{transform:rotate(15deg)}to{transform:rotate(0)}}@keyframes breathe{0%,to{opacity:.6;transform:scale(1)}50%{opacity:1;transform:scale(1.05)}}@keyframes iconJump{0%,to{transform:translateY(0)}30%{transform:translateY(-8px)}50%{transform:translateY(-4px)}70%{transform:translateY(-6px)}}@keyframes successPop{0%{transform:scale(0)}50%{transform:scale(1.2)}to{transform:scale(1)}}@keyframes errorShake{0%,to{transform:translate(0)}10%,30%,50%,70%,90%{transform:translate(-4px)}20%,40%,60%,80%{transform:translate(4px)}}.login-container{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:20px;background:url(/imgs_cyberpunk_login_bg.png) center/cover no-repeat,linear-gradient(135deg,#6366f11a,#8b5cf61a);background-blend-mode:overlay}.login-box{background:#fff;border-radius:24px;padding:48px;width:100%;max-width:420px;box-shadow:var(--shadow-xl)}.login-header{text-align:center;margin-bottom:32px}.login-logo{width:80px;height:80px;border-radius:20px;display:flex;align-items:center;justify-content:center;font-size:40px;margin:0 auto 16px;background:url(/imgs_english_app_icon_v3.png) center/cover no-repeat;border:none}.login-title{font-size:28px;font-weight:800;margin-bottom:8px}.login-subtitle{font-size:14px;color:#6b7280}.login-form{display:flex;flex-direction:column;gap:16px}.form-input-icon{position:relative}.form-input-icon input{width:100%;padding:14px 14px 14px 48px;border:2px solid rgba(99,102,241,.1);border-radius:12px;font-size:15px;transition:all .3s}.form-input-icon input:focus{outline:none;border-color:var(--primary)}.form-input-icon .icon{position:absolute;left:16px;top:50%;transform:translateY(-50%);font-size:18px}.login-btn{padding:14px;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s;color:#fff}.login-btn:hover{transform:translateY(-2px);box-shadow:0 8px 20px #6366f14d}.login-options{display:flex;justify-content:space-between;align-items:center;margin-top:8px}.remember-me{display:flex;align-items:center;gap:8px;font-size:13px}.remember-me input{width:16px;height:16px}.forgot-link{font-size:13px;color:var(--primary);text-decoration:none}.forgot-link:hover{text-decoration:underline}.divider{display:flex;align-items:center;gap:16px;margin:24px 0}.divider:before,.divider:after{content:"";flex:1;height:1px;background:#6366f11a}.divider span{font-size:13px;color:#9ca3af}.social-login{display:flex;gap:12px}.social-btn{flex:1;padding:12px;border:2px solid rgba(99,102,241,.1);border-radius:12px;background:#fff;cursor:pointer;font-size:20px;transition:all .3s;display:flex;align-items:center;justify-content:center;gap:8px}.social-btn span{font-size:13px;color:#6b7280}.social-btn:hover{border-color:var(--primary);background:#6366f10d}.header{background:#fffffff2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid rgba(99,102,241,.08);padding:16px 20px;position:sticky;top:0;z-index:100;display:flex;justify-content:space-between;align-items:center}.page-title{font-size:20px;font-weight:700;display:flex;align-items:center;gap:12px}.header-right{display:flex;align-items:center;gap:12px}.xp-display{display:flex;align-items:center;gap:8px;background:#f59e0b1a;color:#f59e0b;padding:8px 16px;border-radius:999px;font-size:14px;font-weight:700}.header-btn{width:40px;height:40px;border-radius:12px;background:#f4f6fb;border:1px solid rgba(99,102,241,.08);font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .25s}.header-btn:hover{transform:translateY(-2px)}.main{min-height:calc(100vh - 72px);padding-bottom:100px}.content{padding:20px;max-width:1200px;margin:0 auto}.page-content{animation:fadeIn .3s}.hero-banner{border-radius:20px;padding:32px;margin-bottom:24px;color:#fff;position:relative;overflow:hidden;background:linear-gradient(135deg,var(--primary) 0%,var(--secondary) 50%,var(--accent) 100%)}.hero-banner:before{content:"";position:absolute;top:-50%;right:-20%;width:60%;height:200%;background:radial-gradient(circle,rgba(255,255,255,.1) 0%,transparent 70%);animation:float 6s ease-in-out infinite}.hero-content{position:relative;z-index:1;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:20px}.hero-title{font-size:24px;font-weight:800;margin-bottom:8px}.hero-desc{font-size:14px;opacity:.9;max-width:400px}.hero-points{text-align:center;background:#ffffff26;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:20px 32px;border-radius:16px;border:1px solid rgba(255,255,255,.2)}.hero-points-value{font-size:36px;font-weight:800;line-height:1}.hero-points-label{font-size:12px;opacity:.9;margin-top:4px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px}.stat-card{background:#fff;border-radius:16px;padding:20px;display:flex;align-items:center;gap:16px;box-shadow:var(--shadow-sm);border:1px solid rgba(99,102,241,.08);transition:all .25s;cursor:pointer}.stat-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}.stat-card:hover .stat-icon{animation:iconPop .4s ease}.stat-card.highlight{background:linear-gradient(135deg,var(--primary),var(--secondary));color:#fff;border:none}.stat-card.gold{background:linear-gradient(135deg,var(--accent),#F97316);color:#fff;border:none}.stat-card.success{background:linear-gradient(135deg,var(--success),#059669);color:#fff;border:none}.stat-icon{width:56px;height:56px;display:flex;align-items:center;justify-content:center;border-radius:14px;font-size:28px;background:#ffffff26}.stat-value{font-size:28px;font-weight:800;line-height:1.2}.stat-label{font-size:13px;margin-top:4px;opacity:.8}.section-title{font-size:18px;font-weight:700;margin-bottom:16px;display:flex;align-items:center;gap:8px}.api-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px}.api-card{background:#fff;border-radius:16px;padding:20px;box-shadow:var(--shadow-sm);border:1px solid rgba(99,102,241,.08);transition:all .25s;cursor:pointer}.api-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}.api-header{display:flex;align-items:center;gap:12px;margin-bottom:12px}.api-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:24px}.api-info h3{font-size:16px;font-weight:700;margin-bottom:4px}.badge{display:inline-flex;align-items:center;gap:4px;font-size:11px;padding:4px 10px;border-radius:999px}.badge.connected{background:#10b9811a;color:#10b981}.badge.disconnected{background:#ef44441a;color:#ef4444}.btn{width:100%;padding:12px;border:none;border-radius:12px;font-size:14px;font-weight:600;cursor:pointer;transition:all .25s;display:flex;align-items:center;justify-content:center;gap:8px}.btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.btn:active{transform:translateY(0)}.btn.primary{background:linear-gradient(135deg,var(--primary),var(--secondary));color:#fff}.btn.secondary{background:#f4f6fb;color:#1a1d26;border:1px solid rgba(99,102,241,.08)}.btn.accent{background:linear-gradient(135deg,var(--accent),#F97316);color:#fff}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-sm{padding:8px 16px;font-size:13px;width:auto}.translate-panel{background:#fff;border-radius:20px;padding:24px;box-shadow:var(--shadow-sm);border:1px solid rgba(99,102,241,.08);margin-bottom:20px}.panel-title{font-size:18px;font-weight:700;margin-bottom:16px;display:flex;align-items:center;gap:8px}.translate-header{display:flex;gap:12px;margin-bottom:16px;align-items:center;flex-wrap:wrap}.lang-select{flex:1;min-width:120px;padding:12px;border-radius:12px;border:2px solid rgba(99,102,241,.08);font-size:14px;background:#f4f6fb}.lang-select:focus{outline:none}.swap-btn{width:40px;height:40px;border-radius:12px;background:#6366f11a;border:none;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center}.swap-btn:hover{color:#fff;background:var(--primary)}.translate-textarea{width:100%;padding:14px;border-radius:12px;border:2px solid rgba(99,102,241,.08);font-size:15px;background:#f4f6fb;min-height:100px;resize:vertical;font-family:inherit}.translate-textarea:focus{outline:none}.translate-actions{display:flex;gap:12px;margin:16px 0;flex-wrap:wrap}.translate-actions .btn{flex:1;min-width:120px}.result-box{background:#f4f6fb;border-radius:12px;padding:16px;min-height:80px;margin-top:16px}.feature-panel{background:#fff;border-radius:20px;padding:24px;box-shadow:var(--shadow-sm);border:1px solid rgba(99,102,241,.08);margin-bottom:20px}.feature-header{display:flex;align-items:center;gap:16px;margin-bottom:20px}.feature-icon{width:56px;height:56px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:28px}.feature-title{font-size:18px;font-weight:700;margin-bottom:4px}.feature-desc{font-size:13px;color:#6b7280}.voice-btn{width:80px;height:80px;border-radius:50%;border:none;color:#fff;font-size:36px;cursor:pointer;margin:20px auto;display:flex;align-items:center;justify-content:center;transition:all .3s;position:relative}.voice-btn:before{content:"";position:absolute;width:100%;height:100%;border-radius:50%;background:inherit;animation:pulse 1.5s infinite;opacity:0}.voice-btn.recording:before{animation:pulse 1s infinite;opacity:.5}.voice-btn:hover{transform:scale(1.1)}.voice-status{text-align:center;padding:12px;border-radius:12px;margin-top:16px;font-size:14px}.voice-status.idle{background:#f4f6fb;color:#6b7280}.voice-status.listening{background:#10b9811a;color:#10b981}.voice-status.error{background:#ef44441a;color:#ef4444}.ai-chat{background:#fff;border-radius:20px;box-shadow:var(--shadow-sm);border:1px solid rgba(99,102,241,.08);overflow:hidden;margin-bottom:20px}.ai-header{color:#fff;padding:20px;display:flex;align-items:center;gap:12px;background:linear-gradient(135deg,var(--primary),var(--secondary))}.ai-icon{font-size:28px}.ai-title{font-size:16px;font-weight:700}.ai-subtitle{font-size:12px;opacity:.85}.ai-messages{padding:20px;max-height:350px;overflow-y:auto;display:flex;flex-direction:column;gap:16px}.ai-msg{display:flex;gap:12px;animation:slideUp .3s}.ai-msg.user{flex-direction:row-reverse}.ai-avatar{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px}.ai-content{max-width:75%;padding:12px 16px;border-radius:16px;font-size:14px;line-height:1.6}.ai-msg.bot .ai-content{background:#f4f6fb;border-bottom-left-radius:4px}.ai-msg.user .ai-content{color:#fff;background:linear-gradient(135deg,var(--primary),var(--secondary));border-bottom-right-radius:4px}.ai-input{padding:20px;border-top:1px solid rgba(99,102,241,.08);display:flex;gap:12px}.ai-input input{flex:1;padding:12px 16px;border:2px solid rgba(99,102,241,.08);border-radius:999px;font-size:14px;background:#f4f6fb}.ai-input input:focus{outline:none}.ai-send{width:44px;height:44px;border-radius:50%;border:none;color:#fff;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--primary),var(--secondary))}.ai-send:hover{transform:scale(1.1)}.content-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.content-card{background:#fff;border-radius:16px;padding:20px;box-shadow:var(--shadow-sm);border:1px solid rgba(99,102,241,.08);transition:all .25s;cursor:pointer}.content-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}.content-type{display:inline-block;padding:4px 12px;border-radius:999px;font-size:11px;font-weight:600;margin-bottom:12px}.content-type.vocabulary{background:#6366f11a;color:#6366f1}.content-type.grammar{background:#f59e0b1a;color:#f59e0b}.content-type.dialogue{background:#10b9811a;color:#10b981}.content-type.idiom{background:#ec48991a;color:#ec4899}.content-type.listening{background:#06b6d41a;color:#06b6d4}.content-question{background:#f4f6fb;padding:14px;border-radius:12px;margin-bottom:12px;font-size:14px;font-weight:500}.content-options{display:flex;flex-direction:column;gap:8px}.content-option{padding:12px;border:2px solid rgba(99,102,241,.08);border-radius:12px;cursor:pointer;font-size:14px;transition:all .2s}.content-option:hover{background:#6366f10d}.content-option.correct{border-color:#10b981;background:#10b9811a}.content-option.incorrect{border-color:#ef4444;background:#ef44441a}.content-option.disabled{pointer-events:none;opacity:.7}.stats-panel{background:#fff;border-radius:20px;padding:24px;box-shadow:var(--shadow-sm);border:1px solid rgba(99,102,241,.08);margin-bottom:20px}.stats-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;flex-wrap:wrap;gap:12px}.stats-header h3{font-size:18px;font-weight:700}.time-filter{display:flex;gap:8px}.time-btn{padding:8px 16px;border-radius:999px;border:2px solid rgba(99,102,241,.08);background:#f4f6fb;cursor:pointer;font-size:13px;transition:all .25s}.time-btn.active{border-color:var(--primary);background:#6366f11a;color:var(--primary)}.chart-container{margin-top:20px}.chart-placeholder{background:linear-gradient(135deg,#6366f10d,#8b5cf60d);border-radius:16px;padding:32px;text-align:center}.chart-bars{display:flex;align-items:flex-end;justify-content:center;gap:10px;height:160px;margin-top:16px}.chart-bar{width:36px;border-radius:8px 8px 0 0;transition:all .3s;position:relative;cursor:pointer;min-height:20px}.chart-bar:hover{opacity:.8;transform:scaleY(1.05)}.chart-bar-label{position:absolute;bottom:-20px;left:50%;transform:translate(-50%);font-size:10px;color:#6b7280}.progress-section{margin-top:24px}.progress-item{margin-bottom:16px}.progress-header{display:flex;justify-content:space-between;margin-bottom:8px}.progress-label{font-size:14px;font-weight:500}.progress-value{font-size:14px;font-weight:600}.progress-bar{height:10px;background:#f4f6fb;border-radius:999px;overflow:hidden}.progress-fill{height:100%;border-radius:999px;transition:width .5s ease;background:linear-gradient(90deg,var(--primary),var(--secondary))}.achievement-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px;margin-top:20px}.achievement-item{background:#f4f6fb;border-radius:14px;padding:16px;text-align:center;transition:all .3s;border:2px solid transparent;position:relative}.achievement-item:hover{transform:translateY(-4px)}.achievement-item.locked{opacity:.65}.achievement-item.locked .achievement-name,.achievement-item.locked .achievement-desc{color:#9ca3af}.achievement-item.unlocked{background:linear-gradient(135deg,#fff9e6,#fff)}.achievement-icon{font-size:36px;margin-bottom:8px}.achievement-name{font-size:12px;font-weight:600;margin-bottom:4px}.achievement-desc{font-size:10px;color:#6b7280;line-height:1.4}.achievement-progress{margin-top:6px}.vocab-panel{background:#fff;border-radius:20px;padding:24px;box-shadow:var(--shadow-sm);border:1px solid rgba(99,102,241,.08);margin-bottom:20px}.vocab-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;flex-wrap:wrap;gap:12px}.vocab-header h3{font-size:18px;font-weight:700}.vocab-filters{display:flex;gap:8px;flex-wrap:wrap}.vocab-filter{padding:8px 16px;border-radius:999px;border:2px solid rgba(99,102,241,.08);background:#f4f6fb;cursor:pointer;font-size:13px;transition:all .25s}.vocab-filter.active{border-color:var(--primary);background:#6366f11a;color:var(--primary)}.vocab-stats{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:20px}.vocab-stat{background:#f4f6fb;padding:12px 16px;border-radius:12px;text-align:center;min-width:80px}.vocab-stat-value{font-size:22px;font-weight:700}.vocab-stat-label{font-size:11px;color:#6b7280}.vocab-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.vocab-card{background:#f4f6fb;border-radius:14px;padding:16px;transition:all .25s}.vocab-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-sm)}.vocab-word{font-size:20px;font-weight:700;margin-bottom:6px}.vocab-phonetic{font-size:13px;color:#6b7280;margin-bottom:10px;display:flex;align-items:center;gap:8px}.speaker-btn{cursor:pointer;font-size:16px;transition:transform .2s}.speaker-btn:hover{transform:scale(1.2)}.vocab-translation{font-size:15px;color:var(--primary);margin-bottom:10px;font-weight:600}.vocab-example{font-size:13px;color:#6b7280;font-style:italic;border-left:3px solid var(--accent);padding-left:10px;margin-bottom:10px}.vocab-tags{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:10px}.vocab-tag{font-size:11px;padding:3px 10px;border-radius:999px;background:#6366f11a;color:var(--primary)}.vocab-tag.mastered{background:#10b9811a;color:#10b981}.vocab-tag.learning{background:#f59e0b1a;color:#f59e0b}.vocab-actions{display:flex;gap:8px;margin-top:10px}.vocab-action-btn{flex:1;padding:8px;border:none;border-radius:8px;cursor:pointer;font-size:12px;font-weight:600;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:4px}.vocab-action-btn.delete{background:#ef44441a;color:#ef4444}.vocab-action-btn.practice{background:#6366f11a;color:var(--primary)}.vocab-action-btn:hover{transform:scale(1.02)}.reminder-card{background:#f4f6fb;border-radius:14px;padding:16px;margin-bottom:12px;display:flex;align-items:center;gap:12px;transition:all .3s}.reminder-card:hover{background:#6366f10d}.reminder-time{font-size:20px;font-weight:700;min-width:70px;color:var(--primary)}.reminder-info{flex:1}.reminder-title{font-size:14px;font-weight:600;margin-bottom:4px}.reminder-desc{font-size:12px;color:#6b7280}.reminder-actions{display:flex;gap:8px}.reminder-btn{width:32px;height:32px;border-radius:50%;border:none;background:#fff;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;transition:all .25s}.reminder-btn:hover{transform:scale(1.1)}.toggle-switch{width:52px;height:28px;border-radius:999px;cursor:pointer;position:relative;transition:all .3s;display:flex;align-items:center;padding:4px;background:#e5e7eb}.toggle-switch:after{content:"";width:20px;height:20px;border-radius:50%;background:#fff;transition:all .3s;position:absolute;left:4px;box-shadow:0 2px 4px #0000001a}.toggle-switch.active{background:linear-gradient(135deg,var(--primary),var(--secondary))}.toggle-switch.active:after{left:calc(100% - 24px)}.history-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px}.history-item{background:#f4f6fb;padding:14px;border-radius:12px;transition:all .3s}.history-item:hover{background:#6366f10d}.history-time{font-size:11px;margin-bottom:6px;color:#6b7280}.history-original{font-size:13px;margin-bottom:4px}.history-translated{font-size:13px;font-weight:600;color:var(--primary)}.theme-panel{background:#fff;border-radius:20px;padding:24px;box-shadow:var(--shadow-sm);border:1px solid rgba(99,102,241,.08);margin-bottom:20px}.theme-section{margin-bottom:24px}.theme-section:last-child{margin-bottom:0}.theme-section-title{font-size:15px;font-weight:700;margin-bottom:12px;display:flex;align-items:center;gap:8px}.theme-presets{display:flex;gap:12px;flex-wrap:wrap}.theme-preset{width:90px;height:90px;border-radius:14px;cursor:pointer;border:3px solid transparent;transition:all .25s;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff;font-size:11px;font-weight:600}.theme-preset:hover{transform:scale(1.05)}.theme-preset.active{border-color:#1a1d26;box-shadow:0 4px 12px #0003}.theme-preset-icon{font-size:24px;margin-bottom:4px}.theme-toggle{display:flex;align-items:center;gap:12px;margin-bottom:16px}.config-panel{background:#fff;border-radius:20px;padding:24px;box-shadow:var(--shadow-sm);border:1px solid rgba(99,102,241,.08);margin-bottom:20px}.config-section{margin-bottom:24px;padding-bottom:24px;border-bottom:1px solid rgba(99,102,241,.08)}.config-section:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}.config-header{display:flex;align-items:center;gap:12px;margin-bottom:16px}.config-icon{width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:22px}.config-title{font-size:16px;font-weight:700}.config-status{font-size:12px;margin-top:4px}.config-form{display:flex;flex-direction:column;gap:12px}.form-group{display:flex;flex-direction:column;gap:6px}.form-label{font-size:13px;font-weight:500}.form-input{padding:12px 14px;border:2px solid rgba(99,102,241,.08);border-radius:12px;font-size:14px;background:#f4f6fb;transition:all .3s}.form-input:focus{outline:none;border-color:var(--primary)}.form-hint{font-size:12px;color:#9ca3af}.form-actions{display:flex;gap:12px;margin-top:12px}.user-profile{display:flex;align-items:center;gap:12px}.user-avatar{width:40px;height:40px;border-radius:10px;background:linear-gradient(135deg,var(--primary),var(--secondary));display:flex;align-items:center;justify-content:center;font-size:16px;color:#fff;font-weight:700}.user-info{flex:1;overflow:hidden}.user-name{font-size:14px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-email{font-size:12px;color:#6b7280;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bottom-nav{position:fixed;bottom:0;left:0;right:0;background:#fffffffa;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-top:1px solid rgba(99,102,241,.1);display:flex;justify-content:space-around;padding:8px 0;padding-bottom:max(8px,env(safe-area-inset-bottom));z-index:1000;box-shadow:0 -4px 20px #0000001a}.nav-item{display:flex;flex-direction:column;align-items:center;gap:2px;padding:6px 8px;min-width:60px;border:none;background:transparent;cursor:pointer;color:#9ca3af;transition:all .25s;border-radius:8px;position:relative}.nav-item:hover{background:#6366f10d}.nav-item.active{color:var(--primary)}.nav-item.active .nav-icon{animation:iconBounce .6s ease}.nav-icon{font-size:22px;transition:transform .3s ease}.nav-item:hover .nav-icon{transform:translateY(-2px)}.nav-item:active .nav-icon{transform:scale(.9)}.nav-label{font-size:10px;font-weight:600;transition:all .2s}.nav-item.active .nav-label{color:var(--primary)}.icon-animate-hover:hover{animation:iconWiggle .5s ease}.icon-animate-click:active{animation:iconPop .3s ease}.icon-animate-bounce{animation:iconBounce .5s ease infinite}.icon-animate-spin{animation:spin 1s linear infinite}.icon-animate-pulse{animation:heartbeat 1s ease infinite}.nav-item:after{content:"";position:absolute;top:4px;right:12px;width:6px;height:6px;background:var(--error);border-radius:50%;opacity:0;transition:all .3s}.nav-item.has-notification:after{opacity:1;animation:pulse 2s infinite}.toast{position:fixed;bottom:90px;left:50%;transform:translate(-50%) translateY(20px);background:#1a1d26;color:#fff;padding:12px 24px;border-radius:12px;font-size:14px;z-index:2000;opacity:0;transition:all .3s;box-shadow:0 10px 30px #0003}.toast.show{transform:translate(-50%) translateY(0);opacity:1}.toast.success{background:linear-gradient(135deg,var(--success),#059669)}.toast.error{background:linear-gradient(135deg,var(--error),#DC2626)}.app.dark{--primary: #818CF8;--secondary: #A78BFA;background:#0f172a;color:#f1f5f9}.app.dark .header{background:#0f172af2;border-color:#6366f133}.app.dark .stat-card,.app.dark .api-card,.app.dark .translate-panel,.app.dark .feature-panel,.app.dark .stats-panel,.app.dark .vocab-panel,.app.dark .theme-panel,.app.dark .config-panel,.app.dark .ai-chat{background:#1e293b;border-color:#6366f133}.app.dark .login-box{background:#1e293b}.app.dark .login-title{color:#f1f5f9}.app.dark .lang-select,.app.dark .translate-textarea,.app.dark .form-input,.app.dark .ai-input input,.app.dark .vocab-card,.app.dark .vocab-stat,.app.dark .reminder-card,.app.dark .history-item,.app.dark .content-question,.app.dark .achievement-item,.app.dark .chart-placeholder{background:#334155;border-color:#6366f133}.app.dark .bottom-nav{background:#0f172afa;border-color:#6366f133}@media (max-width: 768px){.hero-banner{padding:20px;border-radius:16px}.hero-title{font-size:18px}.hero-points{padding:16px 24px}.hero-points-value{font-size:28px}.stats-grid{grid-template-columns:repeat(2,1fr);gap:12px}.api-grid{grid-template-columns:1fr}.content,.page-content{padding:12px}.translate-header{flex-direction:column;gap:8px}.swap-btn{transform:rotate(90deg);align-self:center}.translate-actions{flex-direction:column}.ai-messages{max-height:280px}.vocab-stats{flex-direction:column}.vocab-stat{flex:1}.vocab-grid{grid-template-columns:1fr}.achievement-grid{grid-template-columns:repeat(2,1fr)}.theme-presets{justify-content:center}.bottom-nav{padding-bottom:max(8px,env(safe-area-inset-bottom))}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a80;display:flex;align-items:center;justify-content:center;z-index:3000;padding:16px;animation:fadeIn .15s ease}.modal{background:#fff;border-radius:16px;padding:24px;width:100%;max-width:400px;box-shadow:0 20px 60px #0003;animation:slideUp .2s ease}.app.dark .modal{background:#1e293b;color:#f1f5f9}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(16px);opacity:0}to{transform:translateY(0);opacity:1}}button:focus-visible,a:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,[role=button]:focus-visible{outline:2px solid var(--primary);outline-offset:2px}[role=button]{cursor:pointer}.learn-overview{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.learn-stat-card{background:linear-gradient(135deg,#6366f10f,#8b5cf60f);border-radius:12px;padding:12px 8px;text-align:center;border:1px solid rgba(99,102,241,.08)}.learn-stat-num{font-size:22px;font-weight:700;color:#1a1d26;line-height:1.2}.learn-stat-label{font-size:11px;color:#6b7280;margin-top:2px}.learn-filters{display:flex;flex-direction:column;gap:10px}.filter-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.filter-label{font-size:12px;font-weight:600;color:#6b7280;min-width:36px}.filter-chips{display:flex;flex-wrap:wrap;gap:6px;flex:1}.chip{display:inline-flex;align-items:center;padding:5px 12px;border-radius:999px;font-size:12px;font-weight:500;border:1px solid #E5E7EB;background:#fff;color:#4b5563;cursor:pointer;transition:all .15s;white-space:nowrap}.chip:hover{border-color:var(--primary);color:var(--primary)}.chip.active{background:var(--primary);color:#fff;border-color:var(--primary);box-shadow:0 2px 6px #6366f140}.explanation{animation:slideUp .25s ease}.app.dark .learn-stat-card{background:linear-gradient(135deg,#6366f11f,#8b5cf61f);border-color:#6366f133}.app.dark .learn-stat-num{color:#f3f4f6}.app.dark .chip{background:#1f2937;color:#d1d5db;border-color:#374151}.app.dark .chip.active{background:var(--primary);color:#fff;border-color:var(--primary)}.app.dark .achievement-item.unlocked{background:linear-gradient(135deg,#ffd70014,#ffffff08)}@media (max-width: 480px){.learn-stat-num{font-size:18px}.filter-chips{gap:4px}.chip{padding:4px 10px;font-size:11px}}.vocab-tabs{display:flex;gap:4px;padding:4px;background:#f4f6fb;border-radius:12px;margin-bottom:16px}.vocab-tab{flex:1;padding:10px 12px;background:transparent;border:none;border-radius:8px;font-size:13px;font-weight:600;color:#6b7280;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;justify-content:center;gap:6px;position:relative}.vocab-tab:hover{color:var(--primary)}.vocab-tab.active{background:#fff;color:var(--primary);box-shadow:0 2px 6px #0000000f}.tab-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:18px;padding:0 6px;border-radius:999px;background:#ef4444;color:#fff;font-size:10px;font-weight:700;line-height:1}.wrong-list{display:flex;flex-direction:column;gap:12px}.wrong-card{background:#fff;border:1px solid #F0F1F5;border-left:3px solid #EF4444;border-radius:12px;padding:14px;box-shadow:0 1px 3px #0000000a;transition:box-shadow .2s}.wrong-card:hover{box-shadow:0 4px 12px #00000014}.wrong-question{font-size:14px;font-weight:600;color:#1a1d26;background:#f4f6fb;padding:12px;border-radius:8px;margin-bottom:10px;line-height:1.5}.wrong-options{display:flex;flex-direction:column;gap:6px}.app.dark .vocab-tabs{background:#1f2937}.app.dark .vocab-tab{color:#9ca3af}.app.dark .vocab-tab.active{background:#111827;color:#a5b4fc}.app.dark .wrong-card{background:#1f2937;border-color:#374151;border-left-color:#ef4444}.app.dark .wrong-question{background:#111827;color:#f3f4f6}.lumen-shell{position:fixed;top:0;right:0;bottom:0;left:0;display:grid;grid-template-columns:1fr 1fr;background:var(--lumen-bg);color:var(--lumen-ink);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;overflow:auto;z-index:10}.lumen-side{position:relative;background:var(--lumen-cream);border-right:1px solid var(--lumen-line);display:flex;align-items:center;justify-content:center;padding:48px;overflow:hidden}.lumen-side:before{content:"";position:absolute;top:24px;right:24px;bottom:24px;left:24px;border:1px dashed var(--lumen-line-strong);border-radius:18px;pointer-events:none}.lumen-flip-stage{perspective:1400px;width:320px;height:380px;cursor:pointer;position:relative;transition:transform .3s ease}.lumen-flip-stage:hover{transform:scale(1.03)}.lumen-flip-card{position:relative;width:100%;height:100%;transform-style:preserve-3d;transition:transform 1s cubic-bezier(.45,.05,.25,1);will-change:transform}.lumen-flip-slot{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:20px;background:var(--lumen-cream-soft);border:1px solid var(--lumen-line);box-shadow:0 12px 30px #1f3a2e1a,0 2px 6px #1f3a2e0f;padding:36px 28px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;-webkit-backface-visibility:hidden;backface-visibility:hidden}.lumen-flip-front{transform:rotateY(0)}.lumen-flip-back{transform:rotateY(180deg)}.lumen-flip-mark{width:160px;height:160px;margin-bottom:18px;display:block}.lumen-flip-title{font-family:Georgia,Times New Roman,serif;font-weight:400;font-size:28px;margin:0 0 8px;color:var(--lumen-ink)}.lumen-flip-mark-label{margin-left:8px;font-family:-apple-system,BlinkMacSystemFont,sans-serif;font-size:11px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--lumen-mute);vertical-align:middle}.lumen-flip-tag{font-size:13px;color:var(--lumen-mute);margin:0;max-width:240px}.lumen-flip-quote{padding-top:28px}.lumen-flip-mark-quote{font-family:Georgia,Times New Roman,serif;font-size:80px;line-height:.6;color:var(--lumen-ink);opacity:.25;margin-bottom:6px}.lumen-flip-quote-text{font-family:Georgia,Times New Roman,serif;font-style:italic;font-size:19px;line-height:1.5;color:var(--lumen-ink-soft);margin:0 0 20px;max-width:260px}.lumen-flip-quote-author{font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--lumen-mute)}.lumen-flip-tip{align-items:flex-start;text-align:left;padding:38px 32px}.lumen-flip-tip-eyebrow{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--lumen-mute);margin-bottom:10px}.lumen-flip-tip-title{font-family:Georgia,Times New Roman,serif;font-weight:400;font-style:italic;font-size:24px;margin:0 0 18px;color:var(--lumen-ink)}.lumen-flip-tip-list{list-style:none;padding:0;margin:0;font-size:15px;line-height:2;color:var(--lumen-ink-soft)}.lumen-flip-dots{position:absolute;bottom:-24px;left:0;right:0;display:flex;justify-content:center;gap:6px}.lumen-flip-dot{width:6px;height:6px;border-radius:50%;background:var(--lumen-line-strong);transition:all .3s ease}.lumen-flip-dot.active{background:var(--lumen-ink);width:18px;border-radius:3px}.lumen-main{display:flex;align-items:center;justify-content:center;padding:48px 24px}.lumen-card{width:100%;max-width:420px;background:var(--lumen-card);border:1px solid var(--lumen-line);border-radius:16px;padding:36px 32px 28px;box-shadow:0 8px 24px #1f3a2e0f}.lumen-head{text-align:center;margin-bottom:24px}.lumen-logo{width:64px;height:64px;margin:0 auto 14px;display:block}.lumen-brand{font-family:Georgia,Times New Roman,serif;font-weight:400;color:var(--lumen-ink);font-size:30px;line-height:1.2;margin:0 0 6px;letter-spacing:-.01em}.lumen-brand-italic{font-style:italic}.lumen-brand-mark{margin-left:8px;font-style:normal;font-family:-apple-system,BlinkMacSystemFont,sans-serif;font-size:13px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--lumen-mute);vertical-align:middle}.lumen-tag{font-size:13px;color:var(--lumen-mute);margin:0}.lumen-tabs{display:grid;grid-template-columns:1fr 1fr;gap:4px;background:var(--lumen-cream);padding:4px;border-radius:999px;margin-bottom:24px}.lumen-tab{background:transparent;border:0;padding:9px 12px;font-size:13px;font-weight:500;color:var(--lumen-mute);border-radius:999px;cursor:pointer;transition:all .18s ease;font-family:inherit}.lumen-tab.active{background:var(--lumen-card);color:var(--lumen-ink);box-shadow:0 1px 3px #1f3a2e1a}.lumen-form{display:flex;flex-direction:column;gap:14px}.lumen-field{display:block}.lumen-label{display:block;font-size:12px;font-weight:500;color:var(--lumen-mute);letter-spacing:.04em;text-transform:uppercase;margin-bottom:6px}.lumen-field input{width:100%;padding:12px 14px;border:1px solid var(--lumen-line);border-radius:10px;background:var(--lumen-cream-soft);color:var(--lumen-ink);font-size:15px;font-family:inherit;transition:border-color .16s ease,background .16s ease,box-shadow .16s ease;-webkit-appearance:none;-moz-appearance:none;appearance:none}.lumen-field input::placeholder{color:#1f3a2e59}.lumen-field input:focus{outline:none;background:#fff;border-color:var(--lumen-ink);box-shadow:0 0 0 3px #1f3a2e14}.lumen-error{background:#fbe9ea;color:var(--lumen-error);font-size:13px;padding:8px 12px;border-radius:8px;border:1px solid rgba(176,39,45,.18)}.lumen-row{display:flex;align-items:center;justify-content:space-between;margin-top:2px}.lumen-check{display:inline-flex;align-items:center;gap:8px;font-size:13px;color:var(--lumen-ink-soft);cursor:pointer;-webkit-user-select:none;user-select:none}.lumen-check input{accent-color:var(--lumen-ink);width:16px;height:16px}.lumen-link{background:none;border:0;padding:0;color:var(--lumen-ink);font-size:13px;cursor:pointer;text-decoration:underline;text-underline-offset:3px;text-decoration-color:var(--lumen-line-strong);font-family:inherit}.lumen-link:hover{text-decoration-color:var(--lumen-ink)}.lumen-link-inline{color:var(--lumen-ink);text-decoration:underline;text-underline-offset:2px}.lumen-cta{margin-top:6px;width:100%;padding:13px 16px;background:var(--lumen-ink);color:#f4eee1;border:0;border-radius:10px;font-size:15px;font-weight:600;letter-spacing:.02em;cursor:pointer;transition:transform .12s ease,background .16s ease,box-shadow .16s ease;font-family:inherit}.lumen-cta:hover{background:#16312a;box-shadow:0 6px 16px #1f3a2e2e}.lumen-cta:active{transform:translateY(1px)}.lumen-divider{display:flex;align-items:center;gap:12px;margin:8px 0 4px;color:var(--lumen-mute);font-size:12px;letter-spacing:.06em;text-transform:uppercase}.lumen-divider:before,.lumen-divider:after{content:"";flex:1;height:1px;background:var(--lumen-line)}.lumen-socials{display:grid;grid-template-columns:1fr 1fr;gap:10px}.lumen-social{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:11px 12px;background:#fff;color:var(--lumen-ink);border:1px solid var(--lumen-line);border-radius:10px;font-size:14px;font-weight:500;cursor:pointer;transition:border-color .16s ease,background .16s ease;font-family:inherit}.lumen-social:hover{border-color:var(--lumen-line-strong);background:var(--lumen-cream-soft)}.lumen-guest{margin-top:4px;background:transparent;border:0;padding:8px;color:var(--lumen-mute);font-size:13px;cursor:pointer;text-decoration:underline;text-underline-offset:3px;font-family:inherit}.lumen-guest:hover{color:var(--lumen-ink)}.lumen-foot{margin-top:22px;text-align:center;font-size:12px;color:var(--lumen-mute);line-height:1.5}@media (max-width: 880px){.lumen-shell{grid-template-columns:1fr}.lumen-side{display:none}}@media (max-width: 480px){.lumen-card{border-radius:14px;padding:28px 22px 22px;box-shadow:none;border-color:transparent}.lumen-main{padding:24px 16px}.lumen-brand{font-size:26px}.lumen-socials{grid-template-columns:1fr}}.app.dark .lumen-shell{background:#14110c;color:#f4eee1}.app.dark .lumen-side{background:#1a1812;border-right-color:#f4eee114}.app.dark .lumen-side:before{border-color:#f4eee11f}.app.dark .lumen-flip-slot{background:#1f1b14;border-color:#f4eee11a;box-shadow:0 16px 40px #00000073,0 2px 8px #0000004d}.app.dark .lumen-flip-title{color:#f4eee1}.app.dark .lumen-flip-mark-label,.app.dark .lumen-flip-tag{color:#b7ac95}.app.dark .lumen-flip-mark{background:transparent}.app.dark .lumen-flip-mark-quote{color:#f4eee1;opacity:.32}.app.dark .lumen-flip-quote-text{color:#e5dcc8}.app.dark .lumen-flip-quote-author,.app.dark .lumen-flip-tip-eyebrow{color:#b7ac95}.app.dark .lumen-flip-tip-title{color:#f4eee1}.app.dark .lumen-flip-tip-list{color:#e5dcc8}.app.dark .lumen-flip-dot{background:#f4eee140}.app.dark .lumen-flip-dot.active{background:#f4eee1}.app.dark .lumen-card{background:#1f1b14;border-color:#f4eee11a}.app.dark .lumen-brand{color:#f4eee1}.app.dark .lumen-brand-mark,.app.dark .lumen-tag{color:#b7ac95}.app.dark .lumen-tabs{background:#14110c}.app.dark .lumen-tab.active{background:#1f1b14;color:#f4eee1;box-shadow:0 1px 3px #0000004d}.app.dark .lumen-field input{background:#14110c;color:#f4eee1;border-color:#f4eee11a}.app.dark .lumen-field input:focus{background:#14110c;border-color:#f4eee1;box-shadow:0 0 0 3px #f4eee114}.app.dark .lumen-cta{background:#f4eee1;color:#1f3a2e}.app.dark .lumen-cta:hover{background:#ece3cf}.app.dark .lumen-social{background:#1f1b14;color:#f4eee1;border-color:#f4eee11f}.app.dark .lumen-social:hover{background:#25201a}
