:root{--color-primary:#667eea;--color-primary-hover:#5a67d8;--color-primary-light:#f0f4ff;--color-primary-50:#f0f4ff;--color-primary-100:#e0e9ff;--color-primary-500:#667eea;--color-primary-600:#5a67d8;--color-primary-700:#4c51bf;--color-text-primary:#1e293b;--color-text-secondary:#475569;--color-text-muted:#64748b;--color-text-light:#94a3b8;--color-bg-primary:#ffffff;--color-bg-secondary:#f8fafc;--color-bg-tertiary:#f1f5f9;--color-border:#e2e8f0;--color-border-light:#f1f5f9;--color-border-focus:#667eea;--cefr-a1:#22c55e;--cefr-a2:#84cc16;--cefr-b1:#eab308;--cefr-b2:#f97316;--cefr-c1:#ef4444;--cefr-c2:#dc2626;--color-success:#16a34a;--color-success-light:#dcfce7;--color-success-text:#15803d;--color-error:#dc2626;--color-error-light:#fef2f2;--color-error-border:#fecaca;--color-error-button:#f87171;--color-warning:#f59e0b;--color-accent:#f97316;--color-accent-hover:#ea580c;--color-accent-light:#fff7ed;--color-accent-bg:#fef3c7;--color-beginner:#16a34a;--color-beginner-bg:#dcfce7;--color-intermediate:#ea580c;--color-intermediate-bg:#fff7ed;--color-advanced:#dc2626;--color-advanced-bg:#fef2f2;--shadow-xs:0 1px 2px rgba(0,0,0,0.05);--shadow-sm:0 2px 8px rgba(0,0,0,0.08);--shadow-md:0 4px 16px rgba(0,0,0,0.1);--shadow-lg:0 8px 24px rgba(0,0,0,0.12);--radius-sm:4px;--radius-md:6px;--radius-lg:8px;--radius-xl:12px;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-8:32px;--space-10:40px;--space-12:48px;--space-16:64px;--space-20:80px;--space-24:96px;--z-content:1;--z-sticky:100;--z-dropdown:200;--z-overlay:400;--z-modal:500;--z-toast:900;--text-xs:0.75rem;--text-sm:0.8125rem;--text-base:0.875rem;--text-md:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:2rem;--transition-fast:0.15s ease-out;--transition-normal:0.2s ease-out;--transition-slow:0.3s ease-out}*{margin:0;padding:0;box-sizing:border-box}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}html{line-height:1.5}:where(button,input,optgroup,select,textarea){font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}:where(button,[type=button],[type=reset],[type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none;border-width:0;border-style:solid}:where(button,select){text-transform:none}body,html{max-width:100vw;overflow-x:hidden}html{height:100%}body{min-height:100%;display:flex;flex-direction:column;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--color-bg-secondary);color:var(--color-text-primary)}a{color:inherit;text-decoration:none}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}audio{display:block;width:100%}audio::-webkit-media-controls{display:flex!important}audio::-webkit-media-controls-panel{display:flex!important;width:100%;opacity:1!important}audio::-webkit-media-controls-enclosure{width:100%;max-width:none}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@keyframes navSlideDown{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.spinner{width:40px;height:40px;border:3px solid #e0e0e0;border-top:3px solid var(--color-primary);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:var(--space-4)}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;height:300px;color:var(--color-text-secondary)}.loading-container p{margin:0;color:var(--color-text-secondary)}.error-banner{background:var(--color-error-light);border:1px solid var(--color-error-border);border-radius:var(--radius-lg);padding:var(--space-4);margin-bottom:var(--space-6);display:flex;align-items:center;justify-content:space-between}.error-banner p{color:var(--color-error);margin:0}.error-banner button{padding:var(--space-2) var(--space-4);background:var(--color-error-button);color:white;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:opacity var(--transition-normal)}.error-banner button:hover{opacity:.9}.empty-state{text-align:center;padding:var(--space-12) var(--space-5)}.empty-icon{font-size:64px;margin-bottom:var(--space-4)}.empty-state h3{font-size:1.5rem;color:var(--color-text-primary);margin-bottom:var(--space-2)}.empty-state p{color:var(--color-text-secondary);margin-bottom:var(--space-6)}.btn-primary{display:inline-block;padding:var(--space-3) var(--space-6);background:var(--color-primary);color:white;text-decoration:none;border:none;border-radius:var(--radius-lg);font-size:14px;font-weight:600;cursor:pointer;transition:background var(--transition-normal)}.btn-primary:hover{background:var(--color-primary-hover)}.btn-cancel{padding:10px var(--space-5);background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:14px;cursor:pointer;transition:background var(--transition-normal)}.btn-cancel:hover:not(:disabled){background:var(--color-bg-tertiary)}.btn-save{padding:10px var(--space-5);background:var(--color-primary);border:none;border-radius:var(--radius-lg);color:white;font-size:14px;font-weight:600;cursor:pointer;transition:background var(--transition-normal)}.btn-save:hover:not(:disabled){background:var(--color-primary-hover)}.btn-save:disabled{background:var(--color-border);cursor:not-allowed}.badge{display:inline-block;padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);font-size:12px;font-weight:500}.badge.difficulty{background:var(--color-primary-light);color:var(--color-primary)}.badge.difficulty.cefr-a1{background:color-mix(in srgb,var(--cefr-a1) 15%,#fff);color:color-mix(in srgb,var(--cefr-a1) 72%,#000)}.badge.difficulty.cefr-a2{background:color-mix(in srgb,var(--cefr-a2) 15%,#fff);color:color-mix(in srgb,var(--cefr-a2) 72%,#000)}.badge.difficulty.cefr-b1{background:color-mix(in srgb,var(--cefr-b1) 15%,#fff);color:color-mix(in srgb,var(--cefr-b1) 72%,#000)}.badge.difficulty.cefr-b2{background:color-mix(in srgb,var(--cefr-b2) 15%,#fff);color:color-mix(in srgb,var(--cefr-b2) 72%,#000)}.badge.difficulty.cefr-c1{background:color-mix(in srgb,var(--cefr-c1) 15%,#fff);color:color-mix(in srgb,var(--cefr-c1) 72%,#000)}.badge.difficulty.cefr-c2{background:color-mix(in srgb,var(--cefr-c2) 15%,#fff);color:color-mix(in srgb,var(--cefr-c2) 72%,#000)}.badge.difficulty.clickable{cursor:pointer;transition:opacity .2s ease}.badge.difficulty.clickable:hover{opacity:.8}.badge.duration{background:#f3e5f5;color:#7b1fa2}.badge.words{background:#e3f2fd;color:#1565c0}.badge.topic-badge{background:#f0f0ff;color:#667eea}.badge.accent-badge,.badge.topic-badge{font-size:.7rem;padding:2px 8px;border-radius:10px;font-weight:500}.badge.accent-badge{background:#fef3c7;color:#92400e}.badge.content-type-badge{background:#e0e7ff;color:#3730a3}.badge.content-tag-badge,.badge.content-type-badge{font-size:.7rem;padding:2px 8px;border-radius:10px;font-weight:500}.badge.content-tag-badge{background:#dcfce7;color:#166534}.course-stats{display:flex;gap:var(--space-4)}.stat{display:flex;align-items:center;gap:var(--space-1);font-size:13px;color:var(--color-text-muted)}.stat-icon{font-size:14px}.rating-stat{color:var(--color-warning);font-weight:500}.rating-count{font-size:11px;color:var(--color-text-light);margin-left:2px}.App{min-height:100vh;display:flex;flex-direction:column;width:100%}.App-header{background:white;padding:0;color:var(--color-text-primary);z-index:100;border-bottom:1px solid var(--color-border)}main{flex:1 1;background:var(--color-bg-secondary)}.main-nav{display:flex;align-items:center;gap:6px;padding:0 24px;height:56px;max-width:1400px;margin:0 auto;width:100%}.nav-brand a{color:var(--color-text-primary);text-decoration:none;font-size:20px;font-weight:800;letter-spacing:-.5px;margin-right:8px;display:inline-flex;align-items:center;gap:8px}.nav-brand a:hover{opacity:.8}.nav-desktop-links{gap:2px;flex:1 1}.nav-desktop-links,.nav-link{display:flex;align-items:center}.nav-link{color:var(--color-text-muted);text-decoration:none;padding:6px 12px;border-radius:var(--radius-md);font-size:14px;font-weight:500;transition:color .15s,background .15s;white-space:nowrap;background:none;border:none;cursor:pointer;gap:4px}.nav-link:hover{color:var(--color-text-primary);background:var(--color-bg-tertiary)}.nav-link--active{color:var(--color-primary);font-weight:600}.nav-creator-dropdown{position:relative}.nav-link--dropdown svg{transition:transform .2s}.nav-creator-menu{position:absolute;top:calc(100% + 6px);left:0;background:white;border-radius:var(--radius-lg);box-shadow:0 8px 30px rgba(0,0,0,.12);border:1px solid var(--color-border);min-width:160px;padding:4px;z-index:var(--z-dropdown,200);animation:dropdownFadeIn .15s ease}.nav-creator-menu__item{display:block;padding:8px 14px;color:var(--color-text-secondary);text-decoration:none;font-size:14px;font-weight:500;border-radius:var(--radius-md);transition:background .15s}.nav-creator-menu__item:hover{background:var(--color-bg-tertiary);color:var(--color-text-primary)}.nav-creator-menu__item--cta{color:var(--color-primary);font-weight:600}.nav-auth{display:flex;align-items:center;gap:6px;margin-left:auto}.nav-auth .nav-token-balance{display:flex;align-items:center;gap:5px;padding:4px 10px;background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:16px;color:var(--color-text-secondary);font-size:13px;font-weight:600;text-decoration:none;transition:all .15s ease;cursor:pointer}.nav-auth .nav-token-balance:hover{background:var(--color-bg-secondary);border-color:var(--color-text-light);color:var(--color-text-primary)}.nav-auth .nav-token-balance svg{color:var(--color-success)}.nav-user-dropdown{position:relative}.nav-user-btn{display:flex;align-items:center;gap:var(--space-2);background:transparent;border:none;color:var(--color-text-primary);padding:6px 10px;border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease}.nav-user-btn:hover{background-color:var(--color-bg-tertiary)}.nav-user-avatar{width:32px;height:32px;border-radius:50%;object-fit:cover}.nav-user-avatar-placeholder{width:30px;height:30px;border-radius:50%;background:var(--color-primary);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;color:white}.nav-user-name{font-size:14px;font-weight:500;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.nav-user-chevron{transition:transform .2s ease;opacity:.7}.nav-user-chevron.open{transform:rotate(180deg)}.nav-user-menu-dropdown{position:absolute;top:calc(100% + 8px);right:0;background:white;border-radius:10px;box-shadow:0 10px 40px rgba(0,0,0,.2);min-width:180px;padding:6px;z-index:200;animation:dropdownFadeIn .15s ease}.nav-menu-item{display:flex;align-items:center;gap:10px;width:100%;padding:10px 14px;border:none;background:transparent;color:#374151;font-size:14px;font-weight:500;text-decoration:none;border-radius:6px;cursor:pointer;transition:all .15s ease}.nav-menu-item:hover{background-color:#f3f4f6}.nav-menu-item svg{color:#6b7280}.nav-user-menu-dropdown a.nav-menu-item{color:#374151}.nav-user-menu-dropdown a.nav-menu-item:hover{color:#374151;background-color:#f3f4f6}.nav-menu-logout{color:#dc2626;margin-top:var(--space-1);border-top:1px solid #e5e7eb;padding-top:10px;border-radius:0 0 6px 6px}.nav-menu-logout:hover{background-color:#fef2f2}.nav-menu-logout svg{color:#dc2626}.nav-login-btn{background:var(--color-primary);color:white!important;padding:7px 16px!important;border-radius:var(--radius-md)!important;font-size:13px!important;font-weight:600!important;transition:background .15s ease!important;text-decoration:none}.nav-login-btn:hover{background:var(--color-primary-hover)!important}.nav-hamburger{display:none;flex-direction:column;justify-content:center;align-items:center;gap:5px;width:36px;height:36px;padding:6px;background:transparent;border:none;cursor:pointer;border-radius:var(--radius-md);transition:background .15s ease}.nav-hamburger:hover{background:var(--color-bg-tertiary)}.nav-hamburger span{display:block;width:20px;height:2px;background:var(--color-text-secondary);border-radius:2px;transition:all .3s ease;transform-origin:center}.nav-hamburger.open span:first-child{transform:translateY(7px) rotate(45deg)}.nav-hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0)}.nav-hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.nav-mobile-menu{display:none}@media (max-width:768px){.main-nav{flex-wrap:wrap;padding:0 16px;height:auto;min-height:52px;gap:0;position:relative}.nav-brand,.nav-hamburger{display:flex}.nav-brand{position:absolute;left:50%;top:0;height:52px;align-items:center;transform:translateX(-50%)}.nav-desktop-links{display:none}.nav-auth{margin-left:auto}.nav-mobile-menu{width:100%;flex-direction:column;align-items:stretch;gap:2px;padding:8px 0 12px;border-top:1px solid var(--color-border)}.nav-mobile-menu--open{display:flex;animation:navSlideDown .2s ease-out}.nav-mobile-menu a{display:block;padding:10px 14px;border-radius:var(--radius-md);font-size:15px;font-weight:500;color:var(--color-text-secondary);text-decoration:none;transition:background .15s}.nav-mobile-menu a:hover{background:var(--color-bg-tertiary);color:var(--color-text-primary)}.nav-mobile-menu__mode-tabs{display:flex;gap:4px;padding:4px;margin-bottom:6px;background:var(--color-bg-secondary);border-radius:var(--radius-lg)}.nav-mobile-menu__mode-tab{flex:1 1;text-align:center;padding:8px 12px;border-radius:var(--radius-md);border:none;font-size:14px;font-weight:500;color:var(--color-text-muted);background:transparent;cursor:pointer;transition:all .15s ease}.nav-mobile-menu__mode-tab:hover{color:var(--color-text-primary);background:var(--color-bg-tertiary)}.nav-mobile-menu__mode-tab.active{color:white;background:var(--color-primary)}.nav-mobile-menu__divider{height:1px;background:var(--color-border);margin:4px 0}.nav-user-chevron,.nav-user-name{display:none}}@media (max-width:480px){.main-nav{padding:0 12px}.nav-brand a{font-size:18px}.nav-auth .nav-token-balance{padding:3px 8px;font-size:12px}.nav-auth .nav-token-balance svg{width:12px;height:12px}}.site-footer{background:#1e293b;color:white;padding:48px 0 0}.footer-content{max-width:1200px;margin:0 auto;padding:0 24px}.footer-main{display:flex;justify-content:space-between;gap:60px;padding-bottom:36px;border-bottom:1px solid rgba(255,255,255,.12)}.footer-brand{flex:1 1;max-width:380px}.footer-logo{font-size:24px;font-weight:800;color:white;text-decoration:none;display:inline-flex;align-items:center;gap:10px;margin-bottom:12px;transition:color .2s ease}.footer-logo:hover{color:#a5b4fc}.footer-description{font-size:15px;color:rgba(255,255,255,.65);line-height:1.7;margin-bottom:20px}.footer-cta{display:inline-flex;align-items:center;gap:6px;color:#a5b4fc;font-size:15px;font-weight:600;text-decoration:none;transition:all .2s ease}.footer-cta:hover{color:white;gap:10px}.footer-cta svg{transition:transform .2s ease}.footer-cta:hover svg{transform:translateX(3px)}.footer-links{display:flex;flex-direction:column;gap:20px;padding-top:4px}.footer-nav-links{display:flex;gap:28px}.footer-nav-links a{font-size:15px;color:rgba(255,255,255,.7);text-decoration:none;font-weight:500;transition:color .2s ease}.footer-nav-links a:hover{color:white}.footer-legal-links{display:flex;align-items:center;gap:8px}.footer-legal-links a{font-size:13px;color:rgba(255,255,255,.45);text-decoration:none;transition:color .2s ease}.footer-legal-links a:hover{color:rgba(255,255,255,.8)}.footer-link-sep{color:rgba(255,255,255,.25);font-size:13px}.footer-bottom{padding:20px 0;display:flex;align-items:center;justify-content:space-between}.footer-copyright{font-size:13px;color:rgba(255,255,255,.4);margin:0}@media (max-width:900px){.footer-main{flex-direction:column;gap:32px;align-items:center;text-align:center}.footer-brand{max-width:100%}.footer-cta{justify-content:center}.footer-links{align-items:center}.footer-nav-links{flex-wrap:wrap;justify-content:center}}@media (max-width:600px){.site-footer{padding:36px 0 0}.footer-nav-links{display:none}.footer-main{gap:24px;padding-bottom:24px}.footer-description{font-size:14px}.footer-bottom{flex-direction:column;gap:12px;text-align:center;padding:16px 0}}.loopy-mark{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;vertical-align:middle}.loopy-mark img{width:100%;height:100%;object-fit:contain;-webkit-user-select:none;user-select:none;pointer-events:none}.courses-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--space-6)}.course-card{position:relative;display:flex;flex-direction:column;background:white;border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);overflow:hidden;cursor:pointer;transition:transform var(--transition-normal),box-shadow var(--transition-normal);color:inherit;text-decoration:none}.course-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.course-card .course-info{display:flex;flex-direction:column;flex:1 1;padding:var(--space-4)}.course-cover{height:160px;background-size:cover;background-position:50%;background-color:var(--color-bg-secondary)}.course-cover.placeholder{display:flex;align-items:center;justify-content:center;background:var(--color-primary)}.course-cover.placeholder span{font-size:48px}.course-title{font-size:1.1rem;font-weight:600;color:var(--color-text-primary);margin-bottom:var(--space-2);line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.course-meta{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-bottom:var(--space-3)}.course-topic-badges{display:flex;flex-wrap:wrap;gap:4px;margin-top:4px}.course-card-footer{display:flex;justify-content:space-between;align-items:center;padding-top:var(--space-3);margin-top:auto;border-top:1px solid var(--color-border-light)}@media (prefers-reduced-motion:reduce){*,:after,:before{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}[class*=spinner]{animation-duration:4s!important;animation-iteration-count:infinite!important}}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.about-page{min-height:100vh;background:var(--color-bg-secondary);padding:clamp(40px,6vw,72px) 20px clamp(64px,8vw,96px)}.about-wrap{max-width:760px;margin:0 auto}.about-hero{text-align:center;margin:0 0 clamp(32px,4vw,48px)}.about-hero__title{font-size:clamp(24px,3.6vw,36px);font-weight:700;color:var(--color-text-primary);letter-spacing:-.02em;line-height:1.32;margin:0;text-wrap:balance}.about-card{background:white;border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:clamp(22px,3vw,32px);margin:0 0 clamp(16px,2vw,20px);box-shadow:var(--shadow-xs)}.about-card__heading{position:relative;padding-left:14px;font-size:clamp(17px,1.8vw,19px);font-weight:700;color:var(--color-text-primary);letter-spacing:-.01em;margin:0 0 16px}.about-card__heading:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:16px;background:var(--color-primary);border-radius:2px}.about-card__body{font-size:clamp(15px,1.4vw,16px);line-height:1.75;color:var(--color-text-secondary);margin:0}.about-card__body+.about-card__body{margin-top:14px}.about-pullquote{font-size:clamp(15px,1.5vw,17px);font-weight:500;line-height:1.65;color:var(--color-text-primary);background:var(--color-primary-50);border-left:3px solid var(--color-primary);border-radius:0 var(--radius-lg) var(--radius-lg) 0;padding:14px 18px;margin:0 0 clamp(20px,2.6vw,28px);text-wrap:balance}.about-principles{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:4px}.about-principles__item{display:grid;grid-template-columns:36px 1fr;gap:16px;padding:16px 0;border-top:1px solid var(--color-border-light)}.about-principles__item:first-child{border-top:none;padding-top:4px}.about-principles__num{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;background:var(--color-primary-50);color:var(--color-primary);font-size:13px;font-weight:700;line-height:1;font-feature-settings:lining-nums tabular-nums;font-variant-numeric:lining-nums tabular-nums}.about-principles__text{min-width:0}.about-principles__title{font-size:clamp(15px,1.4vw,16px);font-weight:600;line-height:1.4;color:var(--color-text-primary);margin:0 0 6px}.about-principles__body{font-size:clamp(14px,1.3vw,15px);line-height:1.7;color:var(--color-text-secondary);margin:0}.about-close{background:white;border:1px solid var(--color-border);border-left:3px solid var(--color-primary);border-radius:var(--radius-xl);padding:clamp(20px,2.6vw,28px);margin:0 0 clamp(16px,2vw,20px);display:flex;flex-direction:column;align-items:flex-start;gap:14px}.about-close__body{font-size:clamp(15px,1.4vw,16px);line-height:1.7;color:var(--color-text-secondary);margin:0}.about-close__email{color:var(--color-primary);text-decoration:none;font-weight:500;border-bottom:1px solid transparent;transition:border-color var(--transition-fast)}.about-close__email:hover{border-bottom-color:var(--color-primary)}.about-close__form-link{font-size:14px;color:var(--color-text-secondary);text-decoration:none;border-bottom:1px solid transparent;transition:color var(--transition-fast),border-color var(--transition-fast)}.about-close__form-link:hover{color:var(--color-primary);border-bottom-color:var(--color-primary)}.about-close__cta{display:inline-flex;align-items:center;gap:8px;padding:11px 22px;background:var(--color-primary);color:white;border-radius:var(--radius-lg);font-size:14px;font-weight:600;text-decoration:none;box-shadow:var(--shadow-xs);transition:background-color var(--transition-fast),box-shadow var(--transition-fast),transform var(--transition-fast)}.about-close__cta:hover{background:var(--color-primary-hover);box-shadow:var(--shadow-md);transform:translateY(-1px)}.about-close__cta:active{transform:translateY(0);box-shadow:var(--shadow-xs)}.about-credit{font-size:13px;color:var(--color-text-muted);text-align:center;margin-top:clamp(24px,3vw,32px);padding-top:20px;border-top:1px solid var(--color-border)}@media (min-width:640px){.about-close{flex-direction:row;align-items:center;justify-content:space-between;gap:20px}.about-close__body{flex:1 1}.about-close__cta{flex-shrink:0}.about-principles__item{grid-template-columns:44px 1fr;gap:20px}.about-principles__num{width:32px;height:32px;font-size:14px}}@media (prefers-reduced-motion:reduce){.about-close__cta,.about-close__email{transition:none;transform:none!important}}.faq-page{min-height:100vh;background:var(--color-bg-secondary);padding:clamp(40px,6vw,72px) 20px clamp(64px,8vw,96px)}.faq-wrap{max-width:760px;margin:0 auto}.faq-hero{text-align:center;margin:0 0 clamp(32px,4vw,48px)}.faq-hero__title{font-size:clamp(24px,3.6vw,36px);font-weight:700;color:var(--color-text-primary);letter-spacing:-.02em;line-height:1.32;margin:0;text-wrap:balance}.faq-card{background:white;border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:clamp(22px,3vw,32px);margin:0 0 clamp(16px,2vw,20px);box-shadow:var(--shadow-xs)}.faq-card__heading{position:relative;padding-left:14px;font-size:clamp(17px,1.8vw,19px);font-weight:700;color:var(--color-text-primary);letter-spacing:-.01em;margin:0 0 18px}.faq-card__heading:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:16px;background:var(--color-primary);border-radius:2px}.faq-list{margin:0;padding:0}.faq-item{padding:16px 0;border-top:1px solid var(--color-border-light)}.faq-item:first-child{border-top:none;padding-top:4px}.faq-item:last-child{padding-bottom:4px}.faq-item__q{font-size:clamp(15px,1.5vw,16px);font-weight:600;line-height:1.5;color:var(--color-text-primary);margin:0 0 8px;text-wrap:balance}.faq-item__q:before{content:"Q";display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;margin-right:10px;border-radius:50%;background:var(--color-primary-50);color:var(--color-primary);font-size:11px;font-weight:700;vertical-align:2px}.faq-item__a{font-size:clamp(14px,1.3vw,15px);line-height:1.75;margin:0;color:var(--color-text-secondary);padding-left:30px;position:relative}.faq-item__a:before{content:"A";position:absolute;left:0;top:1px;display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;background:var(--color-bg-tertiary);color:var(--color-text-muted);font-size:11px;font-weight:700}.faq-contact{background:white;border:1px solid var(--color-border);border-left:3px solid var(--color-primary);border-radius:var(--radius-xl);padding:clamp(20px,2.6vw,28px);margin:0 0 clamp(16px,2vw,20px);display:flex;flex-direction:column;align-items:flex-start;gap:14px}.faq-contact__body{font-size:clamp(15px,1.4vw,16px);line-height:1.7;color:var(--color-text-secondary);margin:0}.faq-contact__email{color:var(--color-primary);text-decoration:none;font-weight:500;border-bottom:1px solid transparent;transition:border-color var(--transition-fast)}.faq-contact__email:hover{border-bottom-color:var(--color-primary)}.faq-contact__form-link{display:inline-flex;align-items:center;gap:6px;padding:10px 18px;border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-bg-primary);font-size:14px;font-weight:600;color:var(--color-text-primary);text-decoration:none;transition:background-color var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast)}.faq-contact__form-link:hover{background:var(--color-primary-50);border-color:var(--color-primary);color:var(--color-primary)}.faq-credit{font-size:13px;color:var(--color-text-muted);text-align:center;margin-top:clamp(24px,3vw,32px);padding-top:20px;border-top:1px solid var(--color-border)}@media (min-width:640px){.faq-contact{flex-direction:row;align-items:center;justify-content:space-between;gap:20px}.faq-contact__body{flex:1 1}.faq-contact__form-link{flex-shrink:0}}@media (max-width:480px){.faq-item__a{padding-left:0}.faq-item__a:before{position:static;display:inline-flex;margin-right:8px;vertical-align:2px}}@media (prefers-reduced-motion:reduce){.faq-contact__email,.faq-contact__form-link{transition:none}}.contact-page{min-height:100vh;background:var(--color-bg-secondary);padding:clamp(40px,6vw,72px) 20px clamp(64px,8vw,96px)}.contact-wrap{max-width:620px;margin:0 auto}.contact-hero{text-align:center;margin:0 0 clamp(24px,3.5vw,40px)}.contact-hero__title{font-size:clamp(24px,3.6vw,36px);font-weight:700;color:var(--color-text-primary);letter-spacing:-.02em;line-height:1.32;margin:0 0 12px;text-wrap:balance}.contact-hero__subtitle{font-size:clamp(15px,1.4vw,16px);line-height:1.7;color:var(--color-text-secondary);margin:0;text-wrap:balance}.contact-helpline{margin:0 0 clamp(16px,2vw,20px);display:flex;flex-direction:column;gap:4px;text-align:center}.contact-helpline__faq{font-size:14px;line-height:1.6;color:var(--color-text-secondary);margin:0}.contact-helpline__meta{display:inline-flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:8px;font-size:13px;color:var(--color-text-light);margin:0}.contact-helpline__time{display:inline-flex;align-items:center;gap:6px}.contact-helpline__time svg{flex-shrink:0;color:var(--color-primary)}.contact-helpline__sep{color:var(--color-text-light);-webkit-user-select:none;user-select:none}.contact-helpline__link{color:var(--color-primary);text-decoration:none;font-weight:500;border-bottom:1px solid transparent;transition:border-color var(--transition-fast)}.contact-helpline__link:hover{border-bottom-color:var(--color-primary)}.contact-card{background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:clamp(22px,3vw,32px);box-shadow:var(--shadow-xs)}.contact-error-banner{display:flex;align-items:flex-start;gap:10px;background:var(--color-error-light);border:1px solid var(--color-error-border);border-radius:var(--radius-lg);color:var(--color-error);font-size:14px;line-height:1.5;padding:12px 14px;margin-bottom:20px}.contact-error-banner svg{flex-shrink:0;margin-top:1px}.contact-error-banner span{flex:1 1}.contact-error-dismiss{background:none;border:none;color:inherit;cursor:pointer;font-size:18px;line-height:1;padding:0 2px;flex-shrink:0;opacity:.7;transition:opacity var(--transition-fast)}.contact-error-dismiss:hover{opacity:1}.contact-form{gap:18px}.contact-field,.contact-form{display:flex;flex-direction:column}.contact-field{gap:6px}.contact-label{color:var(--color-text-primary);font-size:14px;font-weight:600}.contact-required{color:var(--color-error);margin-left:2px}.contact-optional{color:var(--color-text-light);font-weight:400;font-size:13px;margin-left:4px}.contact-input,.contact-select,.contact-textarea{width:100%;padding:10px 14px;border:1px solid var(--color-border);border-radius:var(--radius-lg);font-size:15px;color:var(--color-text-primary);background:var(--color-bg-primary);transition:border-color var(--transition-fast),box-shadow var(--transition-fast);box-sizing:border-box;font-family:inherit;appearance:none}.contact-input:focus,.contact-select:focus,.contact-textarea:focus{outline:none;border-color:var(--color-border-focus);box-shadow:0 0 0 3px rgba(102,126,234,.14)}.contact-input::placeholder,.contact-textarea::placeholder{color:var(--color-text-light)}.contact-input:disabled,.contact-select:disabled,.contact-textarea:disabled{background:var(--color-bg-tertiary);color:var(--color-text-muted);cursor:not-allowed}.contact-select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:38px;cursor:pointer}.contact-textarea{resize:vertical;min-height:130px;line-height:1.6}.contact-field--error .contact-input,.contact-field--error .contact-textarea{border-color:var(--color-error)}.contact-field--error .contact-input:focus,.contact-field--error .contact-textarea:focus{box-shadow:0 0 0 3px rgba(220,38,38,.14)}.contact-field-error{color:var(--color-error);font-size:13px;font-weight:500}.contact-btn-submit{display:inline-flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:12px 22px;border:none;border-radius:var(--radius-lg);background:var(--color-primary);color:#fff;font-size:15px;font-weight:600;cursor:pointer;box-shadow:var(--shadow-xs);transition:background-color var(--transition-fast),box-shadow var(--transition-fast),transform var(--transition-fast);margin-top:4px;font-family:inherit}.contact-btn-submit svg{flex-shrink:0}.contact-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;display:inline-block;flex-shrink:0;animation:contact-spin .7s linear infinite}@keyframes contact-spin{to{transform:rotate(1turn)}}.contact-btn-submit:hover:not(:disabled){background:var(--color-primary-hover);box-shadow:var(--shadow-md);transform:translateY(-1px)}.contact-btn-submit:active:not(:disabled){transform:translateY(0);box-shadow:var(--shadow-xs)}.contact-btn-submit:disabled{opacity:.6;cursor:not-allowed}.contact-success{display:flex;flex-direction:column;align-items:center;text-align:center;padding:clamp(36px,5vw,52px) clamp(24px,3vw,40px);background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-xs);animation:contact-fade-in .3s ease}.contact-success-icon{color:var(--color-primary);background:var(--color-primary-50);border-radius:50%;padding:14px;width:56px;height:56px;box-sizing:content-box;margin-bottom:20px}.contact-success-title{color:var(--color-text-primary);font-size:clamp(20px,2.4vw,24px);font-weight:700;letter-spacing:-.01em;margin:0 0 10px}.contact-success-message{color:var(--color-text-secondary);font-size:15px;line-height:1.7;margin:0 0 28px;max-width:380px}.contact-success-actions{display:flex;flex-direction:column;align-items:center;gap:14px}.contact-btn-primary{display:inline-flex;align-items:center;justify-content:center;padding:11px 22px;border:1px solid var(--color-primary);border-radius:var(--radius-lg);background:transparent;color:var(--color-primary);font-size:14px;font-weight:600;cursor:pointer;transition:background-color var(--transition-fast),color var(--transition-fast);font-family:inherit}.contact-btn-primary:hover{background:var(--color-primary);color:#fff}.contact-success-link{font-size:13px;color:var(--color-text-secondary);text-decoration:none;border-bottom:1px solid transparent;transition:color var(--transition-fast),border-color var(--transition-fast)}.contact-success-link:hover{color:var(--color-primary);border-bottom-color:var(--color-primary)}.contact-success-secondary{display:flex;align-items:center;gap:12px;font-size:13px;color:var(--color-text-light)}.contact-success-sep{color:var(--color-text-light);-webkit-user-select:none;user-select:none}@keyframes contact-fade-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@media (prefers-reduced-motion:reduce){.contact-btn-primary,.contact-btn-submit,.contact-input,.contact-select,.contact-textarea{transition:none}.contact-success{animation:none}.contact-btn-submit:hover:not(:disabled){transform:none}}.cefr-guide-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:500;padding:20px;animation:cefrGuideFadeIn .2s ease}@keyframes cefrGuideFadeIn{0%{opacity:0}to{opacity:1}}.cefr-guide-modal{position:relative;width:100%;max-width:680px;max-height:85vh;background:#fff;border-radius:16px;padding:32px;overflow-y:auto;animation:cefrGuideSlideUp .3s ease}@keyframes cefrGuideSlideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.cefr-guide-close{position:absolute;top:16px;right:16px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:#f3f4f6;border:none;border-radius:50%;cursor:pointer;color:#6b7280;transition:all .2s ease}.cefr-guide-close:hover{background:#e5e7eb;color:#1f2937}.cefr-guide-modal h2{font-size:1.5rem;font-weight:700;color:#1f2937;margin:0 0 12px;padding-right:40px}.cefr-guide-intro{font-size:.9375rem;color:#6b7280;line-height:1.6;margin:0 0 24px}.cefr-guide-table{width:100%;border-collapse:separate;border-spacing:0;font-size:.875rem}.cefr-guide-table thead th{background:#f9fafb;color:#6b7280;font-weight:600;font-size:.8125rem;text-align:left;padding:10px 12px;border-bottom:2px solid #e5e7eb;white-space:nowrap}.cefr-guide-table thead th:first-child{border-radius:8px 0 0 0}.cefr-guide-table thead th:last-child{border-radius:0 8px 0 0}.cefr-guide-table tbody td{padding:10px 12px;color:#374151;border-bottom:1px solid #f3f4f6;vertical-align:middle}.cefr-guide-table tbody tr:last-child td{border-bottom:none}.cefr-guide-table tbody tr:hover{background:#f9fafb}.cefr-guide-level-cell{display:flex;align-items:center;gap:8px}.cefr-guide-badge{display:inline-flex;align-items:center;justify-content:center;min-width:36px;height:24px;padding:0 8px;border-radius:12px;font-size:.75rem;font-weight:700;color:#fff;flex-shrink:0}.cefr-guide-badge--A1{background-color:#22c55e}.cefr-guide-badge--A2{background-color:#84cc16}.cefr-guide-badge--B1{background-color:#eab308}.cefr-guide-badge--B2{background-color:#f97316}.cefr-guide-badge--C1{background-color:#ef4444}.cefr-guide-badge--C2{background-color:#dc2626}.cefr-guide-level-name{font-weight:500;color:#1f2937;font-size:.8125rem}.cefr-guide-dash{color:#d1d5db}@media (max-width:640px){.cefr-guide-modal{padding:20px;max-height:90vh;max-width:100%}.cefr-guide-modal h2{font-size:1.25rem}.cefr-guide-table{font-size:.8125rem}.cefr-guide-table tbody td,.cefr-guide-table thead th{padding:8px}.cefr-guide-badge{min-width:32px;height:22px;font-size:.6875rem}.cefr-guide-level-name{display:none}}.cefr-guide-page{min-height:calc(100vh - 140px);background:#fafafa;padding:40px 20px}.cefr-guide-page__container{max-width:900px;margin:0 auto;background:#fff;border-radius:16px;padding:40px;box-shadow:0 1px 3px rgba(0,0,0,.05)}.cefr-guide-page__header{margin-bottom:32px}.cefr-guide-page__title{font-size:2rem;font-weight:700;color:#1f2937;margin:0 0 16px;line-height:1.3}.cefr-guide-page__intro{font-size:1rem;color:#6b7280;line-height:1.7;margin:0}.cefr-guide-page__section{margin-bottom:48px}.cefr-guide-page__descriptions{display:flex;flex-direction:column;gap:16px}.cefr-guide-page__level-card{padding:20px 24px;border-radius:12px;background:#f9fafb;border:1px solid #f3f4f6;scroll-margin-top:24px}.cefr-guide-page__level-card:target{background:#fef3c7;border-color:#fde68a}.cefr-guide-page__level-name{font-weight:600;color:#1f2937;font-size:1rem}.cefr-guide-page__level-desc{font-size:.9375rem;color:#4b5563;line-height:1.7;margin:12px 0 0}@media (max-width:640px){.cefr-guide-page{padding:20px 12px}.cefr-guide-page__container{padding:24px 20px}.cefr-guide-page__title{font-size:1.5rem}.cefr-guide-page__intro{font-size:.9375rem}.cefr-guide-page__level-card{padding:16px 18px}}.legal-page{min-height:100vh;background:linear-gradient(135deg,#f8fafc,#e2e8f0);padding:40px 20px 80px}.legal-container{max-width:800px;margin:0 auto;background:white;border-radius:16px;box-shadow:0 4px 24px rgba(0,0,0,.08);overflow:hidden}.legal-header{background:linear-gradient(135deg,#6366f1,#4f46e5);padding:48px 40px;text-align:center}.legal-header h1{color:white;font-size:32px;font-weight:700;margin:0 0 12px}.legal-updated{color:rgba(255,255,255,.8);font-size:14px;margin:0}.legal-content{padding:40px}.legal-section{margin-bottom:32px}.legal-section:last-child{margin-bottom:0}.legal-section h2{color:#1e293b;font-size:20px;font-weight:600;margin:0 0 16px;padding-bottom:8px;border-bottom:2px solid #e2e8f0}.legal-section h3{color:#334155;font-size:16px;font-weight:600;margin:20px 0 12px}.legal-section p{color:#475569;font-size:15px;line-height:1.8;margin:0 0 12px}.legal-section ul{margin:12px 0;padding-left:24px}.legal-section li{color:#475569;font-size:15px;line-height:1.8;margin-bottom:8px}.legal-section li:last-child{margin-bottom:0}.legal-email{display:inline-block;background:#f1f5f9;color:#6366f1;font-weight:500;padding:8px 16px;border-radius:8px;margin-top:8px}.legal-footer{display:flex;justify-content:center;gap:24px;padding:24px 40px;background:#f8fafc;border-top:1px solid #e2e8f0}.legal-link{color:#6366f1;text-decoration:none;font-size:15px;font-weight:500;padding:10px 20px;border-radius:8px;transition:all .2s}.legal-link:hover{background:#eef2ff;color:#4f46e5}@media (max-width:768px){.legal-page{padding:20px 16px 60px}.legal-container{border-radius:12px}.legal-header{padding:32px 24px}.legal-header h1{font-size:26px}.legal-content{padding:24px}.legal-section h2{font-size:18px}.legal-section li,.legal-section p{font-size:14px}.legal-footer{flex-direction:column;align-items:center;gap:12px;padding:20px 24px}.legal-link{width:100%;text-align:center}}.pricing-page{min-height:100vh;background:var(--color-bg-secondary);padding:clamp(40px,6vw,72px) 20px clamp(64px,8vw,96px)}.pricing-wrap{max-width:760px;margin:0 auto}.pricing-hero{text-align:center;margin:0 0 clamp(32px,4vw,48px)}.pricing-hero__title{font-size:clamp(28px,4vw,40px);font-weight:700;color:var(--color-text-primary);letter-spacing:-.02em;line-height:1.2;margin:0 0 12px}.pricing-hero__subtitle{font-size:clamp(15px,1.5vw,17px);color:var(--color-text-secondary);line-height:1.6;margin:0}.pricing-status{display:flex;align-items:center;flex-wrap:wrap;gap:12px 16px;padding:16px 20px;margin:0 0 clamp(24px,3vw,32px);background:white;border:1px solid var(--color-border);border-left:3px solid var(--color-primary);border-radius:var(--radius-xl)}.pricing-status__badge{font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--color-success-text);padding:4px 10px;background:var(--color-success-light);border-radius:999px}.pricing-status__meta{font-size:14px;color:var(--color-text-secondary)}.pricing-status__meta.is-urgent{color:var(--color-error);font-weight:500}.pricing-status__manage{margin-left:auto;display:inline-flex;align-items:center;gap:8px;padding:8px 16px;background:transparent;color:var(--color-text-primary);border:1px solid var(--color-border);border-radius:var(--radius-lg);font-size:14px;font-family:inherit;cursor:pointer;transition:border-color var(--transition-fast),color var(--transition-fast),background-color var(--transition-fast)}.pricing-status__manage:hover:not(:disabled){border-color:var(--color-primary);color:var(--color-primary);background:var(--color-primary-50)}.pricing-status__manage:disabled{opacity:.55;cursor:not-allowed}.pricing-toast{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 16px;margin:0 0 20px;font-size:14px;border-radius:var(--radius-lg);border:1px solid transparent}.pricing-toast.is-error{color:var(--color-error);background:var(--color-error-light);border-color:var(--color-error-border)}.pricing-toast.is-success{color:var(--color-success-text);background:var(--color-success-light);border-color:#a7f3d0}.pricing-toast button{background:transparent;border:none;font-size:18px;color:inherit;cursor:pointer;opacity:.6;padding:0 4px;line-height:1}.pricing-toast button:hover{opacity:1}.pricing-toggle{display:inline-flex;gap:4px;margin:0 0 clamp(20px,2.4vw,28px);padding:4px;background:var(--color-bg-tertiary);border-radius:999px}.pricing-toggle__tab{display:inline-flex;align-items:center;gap:6px;font-family:inherit;font-size:14px;font-weight:500;color:var(--color-text-muted);background:transparent;border:none;padding:8px 18px;cursor:pointer;border-radius:999px;transition:color var(--transition-fast),background-color var(--transition-fast)}.pricing-toggle__tab.is-active{color:var(--color-text-primary);background:white;box-shadow:var(--shadow-xs)}.pricing-toggle__tab:hover:not(.is-active){color:var(--color-text-secondary)}.pricing-toggle__save{font-size:11px;font-weight:600;color:var(--color-primary);background:var(--color-primary-50);padding:2px 8px;border-radius:999px;letter-spacing:.02em}.pricing-toggle__tab.is-active .pricing-toggle__save{background:var(--color-primary-100)}.pricing-summary{display:grid;grid-template-columns:1fr;gap:14px;margin:0 0 clamp(20px,2.4vw,28px)}@media (min-width:720px){.pricing-summary{grid-template-columns:1fr 1.15fr;gap:18px;align-items:stretch}}.pricing-summary__card{position:relative;display:flex;flex-direction:column;background:white;border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:clamp(20px,2.4vw,28px);box-shadow:var(--shadow-xs)}.pricing-summary__card.is-premium{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-50),var(--shadow-md);background:linear-gradient(180deg,color-mix(in oklab,var(--color-primary-50) 55%,white) 0,white 40%)}.pricing-summary__badge{position:absolute;top:-12px;left:clamp(20px,2.4vw,28px);display:inline-flex;align-items:center;gap:4px;padding:5px 12px;font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:white;background:var(--color-primary);border-radius:999px;box-shadow:var(--shadow-xs)}.pricing-summary__header{margin-bottom:16px;padding-bottom:16px;border-bottom:1px dashed var(--color-border-light)}.pricing-summary__plan{display:block;font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--color-text-muted);margin-bottom:6px}.pricing-summary__card.is-premium .pricing-summary__plan{color:var(--color-primary)}.pricing-summary__price{display:flex;align-items:baseline;gap:1px;color:var(--color-text-primary);font-feature-settings:lining-nums tabular-nums;font-variant-numeric:lining-nums tabular-nums;white-space:nowrap;margin-bottom:8px}.pricing-summary__approx{font-size:15px;color:var(--color-text-muted);margin-right:3px}.pricing-summary__sym{font-size:16px;color:var(--color-text-secondary);font-weight:600}.pricing-summary__amt{font-size:40px;font-weight:800;line-height:1;letter-spacing:-.02em}.pricing-summary__card.is-premium .pricing-summary__amt{color:var(--color-primary)}.pricing-summary__per{font-size:13px;color:var(--color-text-muted);margin-left:4px}.pricing-summary__tagline{font-size:13px;color:var(--color-text-secondary);line-height:1.5;margin:0}.pricing-summary__save{color:var(--color-primary);font-weight:600}.pricing-summary__list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px;flex:1 1}.pricing-summary__item{display:grid;grid-template-columns:18px 1fr;gap:10px;align-items:start;font-size:14px;line-height:1.55;color:var(--color-text-primary)}.pricing-summary__item.is-primary{color:var(--color-text-primary);font-weight:500}.pricing-summary__bullet,.pricing-summary__item.is-muted{color:var(--color-text-muted)}.pricing-summary__bullet{width:16px;height:16px;margin-top:2px;flex-shrink:0}.pricing-summary__card.is-premium .pricing-summary__item.is-primary .pricing-summary__bullet{color:var(--color-primary)}.pricing-summary__bullet.is-muted{color:var(--color-text-light)}.pricing-summary__note{margin:16px 0 0;padding:10px 12px;font-size:12px;line-height:1.5;color:var(--color-text-secondary);background:var(--color-primary-50);border-radius:var(--radius-lg)}.pricing-summary__cta{margin-top:16px;width:100%;padding:12px 20px;background:var(--color-primary);color:white;border:none;border-radius:var(--radius-lg);font-family:inherit;font-size:15px;font-weight:600;cursor:pointer;transition:background .15s ease,transform .15s ease,box-shadow .15s ease}.pricing-summary__cta:hover{background:var(--color-primary-hover);box-shadow:var(--shadow-md);transform:translateY(-1px)}.pricing-summary__cta:active{transform:translateY(0);box-shadow:var(--shadow-xs)}@media (prefers-reduced-motion:reduce){.pricing-summary__cta{transition:none;transform:none!important}}.pricing-summary__compare-link{text-align:center;margin:0 0 clamp(16px,2vw,20px)}.pricing-summary__compare-link a{font-size:13px;color:var(--color-text-muted);text-decoration:none;border-bottom:1px dashed transparent;transition:color var(--transition-fast),border-color var(--transition-fast)}.pricing-summary__compare-link a:hover{color:var(--color-primary);border-bottom-color:var(--color-primary)}.pricing-compare{display:grid;grid-template-columns:minmax(0,1fr) 64px 108px;background:white;border:1px solid var(--color-border);border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-xs);margin:0 0 clamp(24px,3vw,32px)}@media (min-width:640px){.pricing-compare{grid-template-columns:minmax(0,1.5fr) 140px 180px}}.pricing-compare__header-cell{padding:18px 12px;border-bottom:1px solid var(--color-border);display:flex;flex-direction:column;justify-content:flex-end}.pricing-compare__header-cell.is-spacer{background:white}.pricing-compare__header-cell.is-free,.pricing-compare__header-cell.is-premium{align-items:center;text-align:center;gap:6px}.pricing-compare__header-cell.is-premium{background:var(--color-primary-50);box-shadow:inset 0 3px 0 0 var(--color-primary)}@media (min-width:640px){.pricing-compare__header-cell{padding:24px 16px}}.pricing-compare__plan-name{font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--color-text-muted)}.pricing-compare__header-cell.is-premium .pricing-compare__plan-name{color:var(--color-primary)}.pricing-compare__plan-price{display:flex;align-items:baseline;gap:1px;color:var(--color-text-primary);font-feature-settings:lining-nums tabular-nums;font-variant-numeric:lining-nums tabular-nums;white-space:nowrap}.pricing-compare__approx{font-size:13px;color:var(--color-text-muted);margin-right:2px}.pricing-compare__sym{font-size:13px;color:var(--color-text-secondary);font-weight:600}.pricing-compare__amt{font-size:24px;font-weight:700;line-height:1;letter-spacing:-.015em}.pricing-compare__per{font-size:12px;color:var(--color-text-muted);margin-left:2px}@media (min-width:640px){.pricing-compare__sym{font-size:15px}.pricing-compare__amt{font-size:34px}.pricing-compare__per{font-size:13px}.pricing-compare__approx{font-size:15px}}.pricing-compare__billed{font-size:11px;color:var(--color-primary);font-weight:500;margin-top:2px}.pricing-compare__section-title{grid-column:1/-1;position:relative;padding:14px 16px 10px 24px;font-size:13px;font-weight:700;color:var(--color-text-primary);background:var(--color-bg-secondary);border-top:1px solid var(--color-border);border-bottom:1px solid var(--color-border)}.pricing-compare__section-title:before{content:"";position:absolute;left:14px;top:50%;transform:translateY(-50%);width:3px;height:14px;background:var(--color-primary);border-radius:2px}.pricing-compare__section-title:first-of-type{border-top:none}@media (min-width:640px){.pricing-compare__section-title{padding:18px 24px 12px 30px;font-size:14px}.pricing-compare__section-title:before{left:18px}}.pricing-compare__feature{padding:12px 14px 12px 24px;border-bottom:1px solid var(--color-border-light);display:flex;flex-direction:column;justify-content:center;gap:2px;min-height:52px}.pricing-compare__feature-label{font-size:14px;color:var(--color-text-primary);line-height:1.35}.pricing-compare__feature-sub{font-size:11px;color:var(--color-text-muted);line-height:1.2}@media (min-width:640px){.pricing-compare__feature{padding:14px 20px 14px 30px}.pricing-compare__feature-label{font-size:15px}.pricing-compare__feature-sub{font-size:12px}}.pricing-compare__cell{padding:12px 6px;border-bottom:1px solid var(--color-border-light);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;min-height:52px}.pricing-compare__cell.is-premium-cell{background:color-mix(in oklab,var(--color-primary-50) 70%,white)}.pricing-compare>.pricing-compare__cell:last-of-type,.pricing-compare>.pricing-compare__cell:nth-last-of-type(2),.pricing-compare>.pricing-compare__feature:last-of-type{border-bottom:none}.pricing-compare__check-subtle{width:16px;height:16px;color:var(--color-text-light)}.pricing-compare__ad-icon{width:24px;height:24px}.pricing-compare__ad-label{font-size:10px;color:#7c3aed;line-height:1;letter-spacing:.02em;font-weight:500}.pricing-compare__check-premium{width:22px;height:22px}.pricing-compare__note{font-size:11px;font-weight:600;color:var(--color-primary);text-align:center;line-height:1.3}@media (min-width:640px){.pricing-compare__check-subtle{width:18px;height:18px}.pricing-compare__ad-icon{width:28px;height:28px}.pricing-compare__check-premium{width:26px;height:26px}.pricing-compare__ad-label{font-size:11px}.pricing-compare__note{font-size:12px}}.pricing-cta-block{display:flex;flex-direction:column;align-items:center;gap:10px;margin:0 0 clamp(28px,4vw,40px);text-align:center}.pricing-offer__cta{display:inline-flex;align-items:center;gap:10px;padding:13px 32px;background:var(--color-primary);color:white;border:none;border-radius:var(--radius-lg);font-family:inherit;font-size:15px;font-weight:600;cursor:pointer;transition:background-color var(--transition-fast),box-shadow var(--transition-fast),transform var(--transition-fast);box-shadow:var(--shadow-xs)}.pricing-offer__cta:hover:not(:disabled){background:var(--color-primary-hover);box-shadow:var(--shadow-md);transform:translateY(-1px)}.pricing-offer__cta:active:not(:disabled){transform:translateY(0);box-shadow:var(--shadow-xs)}.pricing-offer__cta:disabled{opacity:.55;cursor:not-allowed}.pricing-offer__guarantee{font-size:13px;color:var(--color-text-muted);margin:0}.pricing-switch{display:flex;align-items:center;gap:20px;flex-wrap:wrap;margin:0 0 clamp(24px,3vw,32px);padding:16px 20px;background:white;border:1px solid var(--color-border);border-left:3px solid var(--color-primary);border-radius:var(--radius-xl)}.pricing-switch__info{display:flex;align-items:flex-start;gap:12px;flex:1 1 260px}.pricing-switch__icon{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;color:var(--color-primary);flex-shrink:0;margin-top:2px}.pricing-switch__title{display:block;font-size:15px;font-weight:600;color:var(--color-text-primary);margin-bottom:4px}.pricing-switch__detail{font-size:13px;color:var(--color-text-secondary);line-height:1.5}.pricing-switch__btn{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border:1px solid var(--color-border);background:transparent;font-family:inherit;font-size:14px;font-weight:500;color:var(--color-text-primary);cursor:pointer;border-radius:var(--radius-lg);transition:all var(--transition-fast)}.pricing-switch__btn:hover:not(:disabled){border-color:var(--color-primary);color:var(--color-primary);background:var(--color-primary-50)}.pricing-switch__btn.is-upgrade:hover:not(:disabled){border-color:var(--color-success);color:var(--color-success-text);background:var(--color-success-light)}.pricing-switch__btn:disabled{opacity:.55;cursor:not-allowed}.pricing-modal{position:fixed;inset:0;background:rgba(15,23,42,.5);display:flex;align-items:center;justify-content:center;padding:24px;z-index:var(--z-modal);animation:pricing-modal-fade .16s ease}.pricing-modal__panel{background:white;max-width:440px;width:100%;padding:clamp(24px,3vw,32px);border-radius:var(--radius-xl);border-top:3px solid var(--color-primary);font-family:inherit;box-shadow:var(--shadow-lg)}.pricing-modal__panel h3{font-size:20px;font-weight:700;margin:0 0 14px;color:var(--color-text-primary)}.pricing-modal__panel p{font-size:15px;line-height:1.6;color:var(--color-text-secondary);margin:0 0 12px}.pricing-modal__note{font-size:13px;color:var(--color-text-muted);border-left:2px solid var(--color-border);padding-left:12px;margin:16px 0 24px!important}.pricing-modal__actions{display:flex;gap:10px;justify-content:flex-end}.pricing-modal__cancel,.pricing-modal__confirm{padding:10px 20px;border:1px solid var(--color-border);background:transparent;font-family:inherit;font-size:14px;font-weight:500;border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast)}.pricing-modal__cancel{color:var(--color-text-secondary)}.pricing-modal__cancel:hover{border-color:var(--color-text-muted);color:var(--color-text-primary)}.pricing-modal__confirm{background:var(--color-primary);color:white;border-color:var(--color-primary)}.pricing-modal__confirm:hover{background:var(--color-primary-hover);border-color:var(--color-primary-hover)}.pricing-faq-link{margin:clamp(32px,4vw,48px) 0 0;text-align:center}.pricing-faq-link a{font-size:15px;font-weight:500;color:var(--color-primary);text-decoration:none;padding-bottom:2px;border-bottom:1px solid transparent;transition:border-color var(--transition-fast)}.pricing-faq-link a:hover{border-bottom-color:var(--color-primary)}.pricing-credit{font-size:13px;color:var(--color-text-muted);text-align:center;margin-top:clamp(32px,4vw,48px);padding-top:20px;border-top:1px solid var(--color-border)}.pricing-spinner{width:16px;height:16px;animation:pricing-spin .9s linear infinite}@keyframes pricing-spin{to{transform:rotate(1turn)}}@keyframes pricing-modal-fade{0%{opacity:0}to{opacity:1}}@media (max-width:640px){.pricing-switch{flex-direction:column;align-items:stretch}.pricing-switch__btn{align-self:flex-start}.pricing-modal__actions{flex-direction:column-reverse}.pricing-modal__cancel,.pricing-modal__confirm{width:100%}}@media (prefers-reduced-motion:reduce){.pricing-modal,.pricing-spinner{animation:none}.pricing-faq-link a,.pricing-modal__cancel,.pricing-modal__confirm,.pricing-offer__cta,.pricing-status__manage,.pricing-switch__btn,.pricing-toggle__tab{transition:none;transform:none!important}}.home-page{min-height:100vh;background:#f8fafc;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Noto Sans TC,PingFang TC,Microsoft JhengHei,sans-serif}.home-page .section-header{text-align:center;margin-bottom:var(--space-12)}.home-page .section-header h2{font-size:32px;font-weight:700;color:#1e293b;margin-bottom:var(--space-3)}.home-page .section-header p{font-size:18px;color:#475569;max-width:600px;margin:0 auto}.hero-section{display:flex;align-items:center;justify-content:space-between;padding:var(--space-16) var(--space-12);max-width:1200px;margin:0 auto;gap:var(--space-12)}.hero-content{flex:1 1;max-width:560px}.hero-title{font-size:48px;font-weight:800;color:#1e293b;line-height:1.2;margin-bottom:var(--space-5)}.hero-subtitle{font-size:20px;color:#475569;line-height:1.7;margin-bottom:var(--space-8)}.hero-subtitle .desktop-separator,.hero-subtitle .subtitle-line{display:inline}.hero-actions{display:flex;gap:var(--space-4)}.hero-visual{flex:1 1;align-items:center}.hero-static-demo,.hero-visual{display:flex;justify-content:center}.hero-static-demo{width:100%}.hero-static-demo__card{width:100%;max-width:420px;background:white;border-radius:20px;padding:28px 24px;box-shadow:0 12px 40px rgba(15,23,42,.1);border:1px solid #e2e8f0}.hero-static-demo__en{font-size:20px;font-weight:600;color:#1e293b;margin:0 0 12px;line-height:1.4}.hero-static-demo__zh{font-size:16px;color:#64748b;margin:0;line-height:1.5}.placement-prompt-section{max-width:900px;margin:0 auto var(--space-6);padding:0 var(--space-4)}.placement-prompt-card{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);background:linear-gradient(135deg,#f0f4ff,#e8f0fe);border:1px solid #d0daf0;border-radius:12px;padding:var(--space-4) var(--space-5);margin-top:var(--space-6)}.placement-prompt-content h3{font-size:18px;font-weight:600;color:var(--text-primary,#1a1a2e);margin:0 0 4px}.placement-prompt-content p{font-size:14px;color:var(--text-secondary,#555);margin:0;line-height:1.5}.placement-prompt-cta{white-space:nowrap;flex-shrink:0}.modes-section{padding:var(--space-16) var(--space-12);background:#f1f5f9}.modes-section .modes-grid,.modes-section .section-header{max-width:1200px;margin-left:auto;margin-right:auto}.modes-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-6)}.mode-card{background:white;border-radius:16px;padding:28px var(--space-5);box-shadow:0 4px 20px rgba(0,0,0,.06);transition:all .2s ease;position:relative;overflow:hidden}.mode-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px}.mode-comprehension:before{background:#22c55e}.mode-vocabulary:before{background:#3b82f6}.mode-dictation:before{background:#f59e0b}.mode-shadowing:before{background:#ec4899}.mode-quiz:before{background:#8b5cf6}.mode-conversation:before{background:#06b6d4}.mode-card:hover{transform:translateY(-3px);box-shadow:0 8px 30px rgba(0,0,0,.1)}.mode-icon-wrap{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;margin-bottom:var(--space-4)}.mode-dictation .mode-icon-wrap{background:rgba(245,158,11,.1);color:#f59e0b}.mode-shadowing .mode-icon-wrap{background:rgba(236,72,153,.1);color:#ec4899}.mode-comprehension .mode-icon-wrap{background:rgba(34,197,94,.1);color:#22c55e}.mode-vocabulary .mode-icon-wrap{background:rgba(59,130,246,.1);color:#3b82f6}.mode-quiz .mode-icon-wrap{background:rgba(139,92,246,.1);color:#8b5cf6}.mode-conversation .mode-icon-wrap{background:rgba(6,182,212,.1);color:#06b6d4}.mode-card h3{font-size:18px;font-weight:700;color:#1e293b;margin-bottom:10px}.mode-card p{font-size:15px;color:#475569;line-height:1.7}.popular-courses-section{padding:var(--space-16) var(--space-12)}.popular-courses-inner,.popular-courses-section{max-width:1200px;margin:0 auto}.popular-courses-header{text-align:center;margin-bottom:var(--space-12)}.popular-courses-header h2{font-size:32px;font-weight:700;color:#1e293b;margin-bottom:var(--space-3)}.popular-courses-header p{font-size:18px;color:#475569}.popular-courses-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-6);margin-bottom:var(--space-8)}.popular-courses-footer{text-align:center}.how-it-works-section{padding:var(--space-16) var(--space-12);background:#f1f5f9}.how-it-works-section .section-header,.how-it-works-section .steps-grid{max-width:1200px;margin-left:auto;margin-right:auto}.steps-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-8)}.step-card{background:white;border-radius:16px;padding:36px var(--space-8);box-shadow:0 4px 20px rgba(0,0,0,.06);text-align:center}.step-number{width:48px;height:48px;border-radius:50%;background:#667eea;color:white;font-size:20px;font-weight:700}.step-icon,.step-number{display:flex;align-items:center;justify-content:center;margin:0 auto var(--space-5)}.step-icon{width:64px;height:64px;background:rgba(102,126,234,.08);border-radius:16px;color:#667eea}.step-card h3{font-size:20px;font-weight:700;color:#1e293b;margin-bottom:var(--space-3)}.step-card p{font-size:16px;color:#475569;line-height:1.7}.trial-cta-section{padding:var(--space-16) var(--space-12)}.trial-cta-inner{max-width:720px;margin:0 auto;text-align:center;background:linear-gradient(135deg,#667eea,#5a67d8);border-radius:20px;padding:48px 40px;color:white}.trial-cta-inner h2{font-size:28px;font-weight:700;margin-bottom:var(--space-3)}.trial-cta-subtitle{font-size:17px;opacity:.9;margin-bottom:var(--space-8)}.trial-cta-features{display:flex;flex-wrap:wrap;justify-content:center;gap:12px 24px;margin-bottom:var(--space-8)}.trial-cta-feature{display:inline-flex;align-items:center;gap:8px;font-size:15px;font-weight:500}.trial-cta-feature svg{flex-shrink:0}.trial-cta-actions .btn-primary{background:white;color:#667eea;box-shadow:0 4px 14px rgba(0,0,0,.15)}.trial-cta-actions .btn-primary:hover{box-shadow:0 6px 20px rgba(0,0,0,.25)}.cta-section{text-align:center;padding:var(--space-16) var(--space-12);background:#1e293b;color:white}.cta-section h2{font-size:36px;font-weight:700;margin-bottom:var(--space-4)}.cta-section p{font-size:18px;color:rgba(255,255,255,.95);margin-bottom:var(--space-8)}.cta-actions{display:flex;justify-content:center;gap:var(--space-4)}.cta-section .btn-outline{background:transparent;color:white;border:2px solid rgba(255,255,255,.5)}.cta-section .btn-outline:hover{background:white;color:#1e293b;border-color:white}@media (max-width:1200px){.hero-section{padding:var(--space-12) var(--space-10)}.hero-title{font-size:40px}.popular-courses-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:900px){.hero-section{flex-direction:column;text-align:center;padding:var(--space-12) var(--space-6)}.hero-content{max-width:100%}.hero-actions{justify-content:center}.cta-section,.how-it-works-section,.modes-section,.popular-courses-section,.trial-cta-section{padding:var(--space-12) var(--space-6)}.modes-grid{grid-template-columns:repeat(2,1fr)}.mode-dictation{order:1}.mode-shadowing{order:2}.mode-comprehension{order:3}.mode-quiz{order:4}.mode-vocabulary{order:5}.mode-conversation{order:6}.steps-grid{grid-template-columns:1fr}.popular-courses-grid{grid-template-columns:repeat(2,1fr)}.trial-cta-inner{padding:36px 24px}}@media (max-width:600px){.hero-title{font-size:32px}.hero-actions{flex-direction:column}.modes-grid{grid-template-columns:repeat(2,1fr)}.modes-grid .mode-card:last-child:nth-child(odd){grid-column:1/-1;max-width:280px;margin:0 auto}.hero-subtitle .subtitle-line{display:block}.hero-subtitle .desktop-separator{display:none}.placement-prompt-card{flex-direction:column;text-align:center;gap:var(--space-3);padding:var(--space-4)}.popular-courses-grid{grid-template-columns:1fr}.cta-actions,.trial-cta-features{flex-direction:column}.trial-cta-features{align-items:center}.trial-cta-inner h2{font-size:24px}}@media (max-width:400px){.hero-section{padding:var(--space-8) var(--space-4);gap:var(--space-8)}.hero-title{font-size:28px}.hero-subtitle{font-size:16px}.cta-section,.how-it-works-section,.modes-section,.popular-courses-section,.trial-cta-section{padding:var(--space-12) var(--space-4)}.home-page .section-header{margin-bottom:var(--space-8)}.home-page .section-header h2{font-size:24px}.home-page .section-header p{font-size:15px}.step-card{padding:var(--space-6) var(--space-5)}.cta-section h2{font-size:28px}}.course-list-page{max-width:1400px;margin:0 auto;padding:var(--space-5)}.course-list-header{margin-bottom:var(--space-6)}.course-list-title{font-size:clamp(28px,4vw,40px);font-weight:700;color:var(--color-text-primary);margin:0 0 var(--space-2);line-height:1.2}.course-list-subtitle{color:var(--color-text-muted);margin:0;font-size:1rem;max-width:60ch}.course-filters-bar{display:flex;flex-wrap:wrap;gap:var(--space-3);align-items:center;padding:var(--space-3) var(--space-4);background:var(--color-bg-secondary);border-radius:var(--radius-lg);margin-bottom:var(--space-5)}.course-filters-search{flex:1 1 280px;min-width:0;padding:10px var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:14px;background:white;color:var(--color-text-primary)}.course-filters-search:focus-visible{outline:2px solid var(--color-primary);outline-offset:1px}.course-filters-field{display:inline-flex;align-items:center;gap:var(--space-2);font-size:13px;color:var(--color-text-muted)}.course-filters-label{font-weight:600}.course-filters-select{font-size:14px}.course-filters-clear,.course-filters-select{padding:8px var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-md);background:white;color:var(--color-text-primary);cursor:pointer}.course-filters-clear{margin-left:auto;font-size:13px;font-weight:500}.course-filters-clear:hover{background:var(--color-bg-secondary)}.search-results-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-3) var(--space-4);background:var(--color-bg-tertiary,var(--color-bg-secondary));border-radius:var(--radius-lg);margin-bottom:var(--space-5);font-size:14px;color:var(--color-text-muted)}.search-results-header .result-count{color:var(--color-text-light,var(--color-text-muted))}.courses-grid[aria-busy=true]{opacity:.6;transition:opacity var(--transition-fast)}.load-more-container{display:flex;flex-direction:column;padding:var(--space-6) 0 var(--space-4)}.load-more-btn,.load-more-container{align-items:center;gap:var(--space-2)}.load-more-btn{display:inline-flex}.load-more-count{font-size:13px;color:var(--color-text-light,var(--color-text-muted))}.load-more-spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.4);border-top-color:white;border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}@media (max-width:768px){.course-list-page{padding:var(--space-4)}.courses-grid{grid-template-columns:1fr}.course-filters-bar{flex-direction:column;align-items:stretch}.course-filters-clear{margin-left:0}}.topics-page{max-width:960px;margin:0 auto;padding:40px 24px}.topics-header{text-align:center;margin-bottom:40px}.topics-header h1{font-size:1.75rem;font-weight:700;color:var(--color-text-primary);margin-bottom:8px}.topics-subtitle{color:var(--color-text-muted);font-size:1rem}.topics-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.topic-card{position:relative;display:flex;flex-direction:column;align-items:flex-start;padding:24px 24px 24px 28px;background:var(--topic-bg,var(--color-bg-primary));border:1px solid var(--color-border);border-radius:var(--radius-xl);cursor:pointer;transition:background .2s,border-color .2s,box-shadow .2s;text-align:left;font-family:inherit;color:inherit;overflow:hidden;text-decoration:none}.topic-card:hover{background:var(--topic-bg-hover,var(--color-bg-tertiary));border-color:var(--topic-color,var(--color-primary));box-shadow:var(--shadow-md)}.topic-card:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.topic-accent{position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--topic-color,var(--color-primary));border-radius:4px 0 0 4px}.topic-icon-wrapper{display:flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:12px;background:var(--topic-bg-hover,var(--color-bg-tertiary));margin-bottom:12px;flex-shrink:0}.topic-icon-svg{width:22px;height:22px}.topic-name{font-size:1.05rem;font-weight:600;color:var(--color-text-primary);margin:0 0 6px;line-height:1.4}.topic-count-label{font-size:.8rem;color:var(--color-text-light)}.topics-page .empty-state{text-align:center;padding:64px 32px}.topics-page .empty-state h3{color:var(--color-text-primary);margin-bottom:8px}.topics-page .empty-state p{color:var(--color-text-muted)}@media (max-width:860px){.topics-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:640px){.topics-page{padding:24px 16px}.topics-header h1{font-size:1.375rem}.topics-grid{grid-template-columns:repeat(2,1fr);gap:12px}.topic-card{padding:20px 20px 20px 24px}.topic-name{font-size:.95rem}.topic-icon-wrapper{width:38px;height:38px;border-radius:10px;margin-bottom:10px}.topic-icon-svg{width:18px;height:18px}}.blog-page{min-height:100vh;background:linear-gradient(135deg,#f8fafc,#e2e8f0);padding-bottom:80px}.blog-hero{background:#667eea;padding:48px 20px;text-align:center}.blog-hero h1{color:white;font-size:36px;font-weight:800;margin:0 0 12px}.blog-hero p{color:rgba(255,255,255,.85);font-size:17px;margin:0}.blog-container{max-width:1100px;margin:0 auto;padding:32px 20px}.blog-tags-filter{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:24px}.blog-tag-btn{padding:6px 16px;border:1px solid #e2e8f0;border-radius:20px;background:white;color:#64748b;font-size:14px;cursor:pointer;transition:all .2s;text-decoration:none;display:inline-block}.blog-tag-btn:hover{border-color:#6366f1;color:#6366f1}.blog-tag-btn.active{background:#6366f1;color:white;border-color:#6366f1}.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}.blog-card{background:white;border-radius:12px;overflow:hidden;box-shadow:0 2px 12px rgba(0,0,0,.06);text-decoration:none;transition:transform .2s,box-shadow .2s;display:flex;flex-direction:column}.blog-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px rgba(0,0,0,.12)}.blog-card-image{width:100%;height:180px;overflow:hidden}.blog-card-image img{width:100%;height:100%;object-fit:cover;transition:transform .3s}.blog-card:hover .blog-card-image img{transform:scale(1.05)}.blog-card-content{padding:20px;flex:1 1;display:flex;flex-direction:column}.blog-card-meta{display:flex;align-items:center;gap:12px;margin-bottom:8px}.blog-card-date,.blog-card-views{color:#94a3b8;font-size:13px}.blog-card-title{color:#1e293b;font-size:18px;font-weight:600;margin:0 0 8px;line-height:1.4;-webkit-line-clamp:2}.blog-card-excerpt,.blog-card-title{display:-webkit-box;-webkit-box-orient:vertical;overflow:hidden}.blog-card-excerpt{color:#64748b;font-size:14px;line-height:1.6;margin:0 0 12px;flex:1 1;-webkit-line-clamp:3}.blog-card-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:auto}.blog-tag{display:inline-block;padding:2px 10px;background:#f1f5f9;color:#6366f1;font-size:12px;font-weight:500;border-radius:12px}.blog-loading{text-align:center;padding:80px 0}.blog-spinner{width:40px;height:40px;border:3px solid #e2e8f0;border-top-color:#6366f1;border-radius:50%;margin:0 auto 16px;animation:blog-spin .8s linear infinite}@keyframes blog-spin{to{transform:rotate(1turn)}}.blog-empty p,.blog-error p,.blog-loading p{color:#64748b;font-size:16px}.blog-empty,.blog-error{text-align:center;padding:80px 0}.blog-empty svg{margin-bottom:16px}.blog-pagination{display:flex;justify-content:center;align-items:center;gap:16px;margin-top:32px;flex-wrap:wrap}.blog-page-btn{padding:8px 20px;border:1px solid #e2e8f0;border-radius:8px;background:white;color:#6366f1;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;text-decoration:none;display:inline-block}.blog-page-btn:hover:not([aria-disabled=true]){background:#6366f1;color:white;border-color:#6366f1}.blog-page-btn[aria-disabled=true]{opacity:.4;cursor:not-allowed}.blog-page-info{color:#64748b;font-size:14px}.blog-page-numbers{display:flex;gap:6px;flex-wrap:wrap}.blog-page-num,.blog-page-numbers{align-items:center;justify-content:center}.blog-page-num{min-width:38px;height:38px;padding:0 8px;display:inline-flex;border:1px solid #e2e8f0;border-radius:8px;background:white;color:#6366f1;font-size:14px;font-weight:500;text-decoration:none;cursor:pointer;transition:all .2s}.blog-page-num.is-active,.blog-page-num:hover{background:#6366f1;color:white;border-color:#6366f1}.blog-page-num.is-active{cursor:default;pointer-events:none}.blog-page-ellipsis{min-width:24px;text-align:center;color:#94a3b8;font-size:14px;-webkit-user-select:none;user-select:none}.blog-detail-cover{width:100%;max-height:400px;overflow:hidden}.blog-detail-cover img{width:100%;height:100%;object-fit:cover}.blog-detail-container{max-width:800px;margin:0 auto;padding:32px 20px 80px}.blog-back-link{display:inline-flex;align-items:center;gap:6px;color:#6366f1;text-decoration:none;font-size:14px;font-weight:500;margin-bottom:24px;transition:color .2s}.blog-back-link:hover{color:#4f46e5}.blog-post-nav{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:32px}.blog-post-nav__link{display:flex;flex-direction:column;gap:6px;padding:16px 20px;background:white;border:1px solid var(--color-border,#e5e7eb);border-radius:var(--radius-lg,12px);text-decoration:none;transition:border-color .2s,box-shadow .2s}.blog-post-nav__link:hover{border-color:var(--color-primary);box-shadow:0 4px 16px rgba(0,0,0,.06)}.blog-post-nav__link--next{grid-column:2;text-align:right;align-items:flex-end}.blog-post-nav__label{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:var(--color-primary)}.blog-post-nav__title{font-size:15px;font-weight:600;line-height:1.4;color:var(--color-text-primary,#1e293b);display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}@media (max-width:640px){.blog-post-nav{grid-template-columns:1fr}.blog-post-nav__link--next{grid-column:1;text-align:left;align-items:flex-start}}.blog-article{background:white;border-radius:16px;box-shadow:0 4px 24px rgba(0,0,0,.08);overflow:hidden}.blog-article-header{padding:40px 40px 0}.blog-article-header h1{color:#1e293b;font-size:32px;font-weight:800;line-height:1.3;margin:0 0 16px}.blog-article-meta{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-bottom:16px}.blog-article-author{color:#1e293b;font-weight:600;font-size:14px}.blog-article-date,.blog-article-views{color:#94a3b8;font-size:14px}.blog-article-tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:8px}.blog-article-content{padding:32px 40px 40px;color:#334155;font-size:16px;line-height:1.8}.blog-article-content h1{font-size:28px;font-weight:700;color:#1e293b;margin:32px 0 16px}.blog-article-content h2{font-size:24px;font-weight:700;color:#1e293b;margin:28px 0 14px;padding-bottom:8px;border-bottom:2px solid #e2e8f0}.blog-article-content h3{font-size:20px;font-weight:600;color:#1e293b;margin:24px 0 12px}.blog-article-content p{margin:0 0 16px}.blog-article-content ol,.blog-article-content ul{margin:0 0 16px;padding-left:24px}.blog-article-content li{margin-bottom:8px}.blog-article-content blockquote{border-left:4px solid #6366f1;margin:16px 0;padding:12px 20px;background:#f8fafc;border-radius:0 8px 8px 0;color:#475569}.blog-article-content code{background:#f1f5f9;padding:2px 6px;border-radius:4px;font-size:14px;color:#e11d48}.blog-article-content pre{background:#1e293b;border-radius:8px;padding:20px;overflow-x:auto;margin:16px 0}.blog-article-content pre code{background:none;color:#e2e8f0;padding:0;font-size:14px}.blog-article-content img{max-width:100%;border-radius:8px;margin:16px 0}.blog-article-content table{width:100%;border-collapse:collapse;margin:16px 0}.blog-article-content td,.blog-article-content th{border:1px solid #e2e8f0;padding:10px 14px;text-align:left}.blog-article-content th{background:#f8fafc;font-weight:600;color:#1e293b}.blog-article-content a{color:#6366f1;text-decoration:underline}.blog-article-content a:hover{color:#4f46e5}@media (max-width:768px){.blog-hero{padding:32px 16px}.blog-hero h1{font-size:28px}.blog-container{padding:24px 16px}.blog-grid{grid-template-columns:1fr;gap:16px}.blog-detail-container{padding:20px 16px 60px}.blog-article-header{padding:24px 24px 0}.blog-article-header h1{font-size:24px}.blog-article-content{padding:20px 24px 24px;font-size:15px}.blog-article-content h2{font-size:20px}.blog-article-content h3{font-size:18px}}@media (min-width:769px) and (max-width:1024px){.blog-grid{grid-template-columns:repeat(2,1fr)}}.course-tabs{display:flex;gap:4px;border-bottom:1px solid #e5e7eb;margin-bottom:20px;overflow-x:auto}.course-tab-btn{background:transparent;padding:10px 16px;font-size:14px;font-weight:500;color:#6b7280;cursor:pointer;border:none;border-bottom:2px solid transparent;transition:color .15s ease,border-color .15s ease;white-space:nowrap}.course-tab-btn:hover{color:#374151}.course-tab-btn.active{color:var(--color-primary,#667eea);border-bottom-color:var(--color-primary,#667eea)}.audio-player-island audio{width:100%}.course-start-btn{display:inline-flex;align-items:center;gap:6px;padding:10px 22px;border-radius:999px;background:var(--color-primary,#667eea);color:#fff;font-size:14px;font-weight:600;border:none;text-decoration:none;cursor:pointer;transition:background-color .15s ease,transform .15s ease}.course-start-btn:hover{background:#5a67d8;transform:translateY(-1px)}.auth-shell{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:3rem 1rem;background:#f9fafb;position:relative}.auth-shell__card{width:100%;max-width:28rem;display:flex;flex-direction:column;gap:2rem}.auth-shell__brand{text-align:center}.auth-shell__brand-link{display:inline-flex;align-items:center;gap:.75rem;color:#667eea;text-decoration:none;transition:color .15s ease}.auth-shell__brand-link:hover{color:#5a67d8}.auth-shell__brand-name{font-size:2.25rem;line-height:2.5rem;font-weight:700;letter-spacing:-.025em}.auth-shell__title{margin:1rem 0 0;font-size:1.5rem;line-height:2rem;font-weight:600;color:#111827}.auth-shell__subtitle{margin:.5rem 0 0;font-size:.875rem;line-height:1.25rem;color:#6b7280}.auth-shell__lang{position:absolute;top:1rem;right:1rem;z-index:10}.auth-callback-shell{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#f9fafb;padding:1rem}.auth-callback-content{text-align:center;max-width:24rem}.auth-callback-content__icon{width:4rem;height:4rem;margin:0 auto 1rem;display:flex;align-items:center;justify-content:center}.auth-callback-content__icon--error{color:#ef4444}.auth-callback-content__icon--processing{color:#5a67d8}.auth-callback-content__title{margin:0 0 .5rem;font-size:1.25rem;line-height:1.75rem;font-weight:600;color:#111827}.auth-callback-content__body{margin:0;font-size:1rem;color:#4b5563}.auth-callback-content__hint{margin:.5rem 0 0;font-size:.875rem;color:#6b7280}@keyframes auth-spin{to{transform:rotate(1turn)}}.auth-callback-content__spinner{width:100%;height:100%;animation:auth-spin 1s linear infinite}.auth-form{background:#ffffff;border:1px solid #e5e7eb;border-radius:.75rem;box-shadow:0 1px 2px 0 rgba(0,0,0,.05);padding:2rem;display:flex;flex-direction:column}.auth-form__alert{background:#fef2f2;border:1px solid #fecaca;color:#b91c1c;border-radius:.5rem;padding:.75rem 1rem;font-size:.875rem;margin-bottom:1rem}.auth-form__alert--success{background:#f0fdf4;border-color:#bbf7d0;color:#15803d}.auth-form__alert-hint{margin-top:.5rem;font-size:.8125rem;color:#475569}.auth-form__field{display:block;margin-bottom:1rem}.auth-form__label{display:block;font-size:.875rem;font-weight:500;color:#374151;margin-bottom:.25rem}.auth-form__input{width:100%;padding:.75rem 1rem;border:1px solid #d1d5db;border-radius:.5rem;font-size:1rem;background:#ffffff;color:#111827;transition:border-color .2s ease,box-shadow .2s ease}.auth-form__input::placeholder{color:#9ca3af}.auth-form__input:hover:not(:disabled):not(.auth-form__input--error){border-color:#9ca3af}.auth-form__input:focus{outline:none;border-color:transparent;box-shadow:0 0 0 2px #667eea}.auth-form__input--error{border-color:#ef4444;background:#fef2f2}.auth-form__input--error:focus{box-shadow:0 0 0 2px #ef4444}.auth-form__input:disabled{background:#f3f4f6;cursor:not-allowed;opacity:.6}.auth-form__helper{margin:.25rem 0 0;font-size:.875rem;color:#6b7280}.auth-form__error{display:block;margin:.25rem 0 0;font-size:.875rem;color:#dc2626}.auth-form__password-wrap{position:relative}.auth-form__password-toggle{position:absolute;top:50%;right:.75rem;transform:translateY(-50%);background:transparent;border:none;padding:0;cursor:pointer;color:#9ca3af;display:inline-flex;align-items:center;justify-content:center;line-height:1}.auth-form__password-toggle:hover{color:#4b5563}.auth-form__row{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.75rem;margin-bottom:1.5rem}.auth-form__checkbox{display:inline-flex;align-items:center;font-size:.875rem;color:#4b5563;cursor:pointer}.auth-form__checkbox input[type=checkbox]{width:1rem;height:1rem;margin-right:.5rem;border:1px solid #d1d5db;border-radius:.25rem;accent-color:#667eea}.auth-form__checkbox--parental{align-items:flex-start}.auth-form__checkbox--parental input[type=checkbox]{margin-top:3px;flex-shrink:0}.auth-form__submit{width:100%;padding:.75rem 1.5rem;background:#667eea;color:#ffffff;border:none;border-radius:.5rem;font-size:1rem;font-weight:600;cursor:pointer;box-shadow:0 1px 2px 0 rgba(0,0,0,.05);transition:background-color .2s ease,box-shadow .2s ease;display:inline-flex;align-items:center;justify-content:center}.auth-form__submit:hover:not(:disabled){background:#5a67d8;box-shadow:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -1px rgba(0,0,0,.06)}.auth-form__submit:disabled{opacity:.6;cursor:not-allowed}.auth-form__submit--outline{background:transparent;color:#667eea;border:2px solid #667eea;box-shadow:none;display:inline-flex;align-items:center;justify-content:center;text-decoration:none}.auth-form__submit--outline:hover:not(:disabled){background:#f0f4ff;color:#5a67d8}.auth-form__divider{display:flex;align-items:center;color:#6b7280;font-size:.875rem;margin:1.5rem 0}.auth-form__divider:after,.auth-form__divider:before{content:"";flex:1 1;border-top:1px solid #d1d5db}.auth-form__divider>span{padding:0 1rem}.auth-form__oauth{display:flex;flex-direction:column;gap:.75rem}.auth-form__oauth-btn{width:100%;display:inline-flex;align-items:center;justify-content:center;gap:.75rem;padding:.75rem 1rem;border:1px solid #d1d5db;border-radius:.5rem;background:#ffffff;color:#374151;font-size:1rem;font-weight:500;text-decoration:none;cursor:pointer;transition:background-color .2s ease,border-color .2s ease}.auth-form__oauth-btn:hover{background:#f9fafb}.auth-form__oauth-btn--github{background:#111827;color:#ffffff;border-color:#111827}.auth-form__oauth-btn--github:hover{background:#1f2937;border-color:#1f2937}.auth-form__oauth-btn[aria-disabled=true]{opacity:.5;pointer-events:none}.auth-form__oauth-icon{display:inline-flex;align-items:center;flex-shrink:0}.auth-form__footer,.auth-form__terms{margin:1.5rem 0 0;text-align:center;font-size:.875rem;color:var(--color-text-secondary,#475569)}.auth-form__terms{font-size:.75rem;color:var(--color-text-muted,#64748b)}.auth-form__link{color:var(--color-primary,#667eea);text-decoration:none;font-weight:500}.auth-form__link:hover{color:var(--color-primary-hover,#5a67d8);text-decoration:underline}.auth-form__link--muted{font-weight:400;font-size:.8125rem}.auth-form__back-link{display:inline-flex;align-items:center;gap:.25rem;color:#4b5563;font-size:.875rem;text-decoration:none}.auth-form__back-link:hover{color:#111827}.auth-form__regulation-note{background:var(--color-primary-50,#f0f4ff);border:1px solid var(--color-primary-100,#e0e9ff);border-radius:var(--radius-md,6px);padding:var(--space-2) var(--space-3);margin:0;font-size:.75rem;color:var(--color-primary-700,#4c51bf)}.auth-form__parental{background:#fffbeb;border:1px solid #fde68a;border-radius:var(--radius-md,6px);padding:var(--space-4);display:flex;flex-direction:column;gap:var(--space-3)}.auth-form__parental-title{margin:0;font-size:.875rem;font-weight:600;color:#92400e}.auth-form__parental-intro{margin:0;font-size:.75rem;color:#78350f}.auth-form--success{text-align:center;align-items:center}.auth-form__success-icon{width:64px;height:64px;border-radius:50%;background:var(--color-success-light,#dcfce7);color:var(--color-success-text,#15803d);display:inline-flex;align-items:center;justify-content:center;margin-bottom:var(--space-2)}.auth-form__success-title{margin:0;font-size:1.125rem;font-weight:600;color:var(--color-text-primary,#1e293b)}.auth-form__success-body{margin:0;font-size:.875rem;color:var(--color-text-secondary,#475569)}.auth-form__success-hint{margin:0;font-size:.75rem;color:var(--color-text-muted,#64748b)}.course-list-page .btn-primary,.home-page .btn-primary{background:#2563EB}.course-list-page .btn-primary:hover,.home-page .btn-primary:hover{background:#1D4ED8;box-shadow:0 4px 12px rgba(37,99,235,.25)}.home-page .trial-cta-actions .btn-primary{background:white;color:#667eea;box-shadow:0 4px 14px rgba(0,0,0,.15)}.home-page .trial-cta-actions .btn-primary:hover{background:#f9fafb;box-shadow:0 6px 18px rgba(0,0,0,.18)}.notifications-page{min-height:100vh;background-color:var(--color-bg-secondary,#f8fafc)}.notifications-container{max-width:768px;margin:0 auto;padding:2rem 1rem}.notifications-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}.notifications-header h1{font-size:1.5rem;font-weight:700;color:var(--color-text-primary,#1e293b);margin:0}.notifications-mark-all{background:none;border:none;font-size:.875rem;font-weight:500;color:var(--color-primary,#667eea);cursor:pointer;padding:4px 8px}.notifications-mark-all:hover{color:var(--color-primary-700,#4c51bf)}.notifications-list-wrapper{background:#ffffff;border-radius:8px;box-shadow:0 1px 3px rgba(0,0,0,.06);overflow:hidden}.notifications-list{list-style:none;padding:0;margin:0}.notification-row{display:flex;align-items:flex-start;gap:12px;padding:12px 16px;border-bottom:1px solid #f1f5f9;cursor:pointer;transition:background-color .15s ease;position:relative}.notification-row:last-child{border-bottom:0}.notification-row:hover{background:#f8fafc}.notification-row--unread{background:rgba(102,126,234,.06)}.notification-link{display:contents;color:inherit;text-decoration:none}.notification-icon{flex-shrink:0;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--color-primary-100,#e0e9ff);color:var(--color-primary,#667eea)}.notification-icon.priority-high{background:#fed7aa;color:#ea580c}.notification-icon.priority-urgent{background:#fecaca;color:#dc2626}.notification-content{flex:1 1;min-width:0}.notification-title{margin:0;font-size:.875rem;color:var(--color-text-secondary,#475569)}.notification-title--unread{color:var(--color-text-primary,#1e293b);font-weight:500}.notification-message{margin:2px 0 0;font-size:.875rem;color:var(--color-text-muted,#64748b);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.notification-time{margin:4px 0 0;font-size:.75rem;color:var(--color-text-light,#94a3b8)}.notification-unread-dot{position:absolute;top:14px;right:44px;width:8px;height:8px;border-radius:50%;background:var(--color-primary,#667eea)}.notification-dismiss{flex-shrink:0;background:none;border:none;padding:4px;color:var(--color-text-light,#94a3b8);cursor:pointer;border-radius:50%;display:flex;align-items:center;justify-content:center}.notification-dismiss:hover{background:var(--color-bg-tertiary,#f1f5f9);color:var(--color-text-secondary,#475569)}.notification-action-label{display:inline-block;margin:4px 0 0 48px;font-size:.75rem;font-weight:500;color:var(--color-primary,#667eea);text-decoration:none}.notification-action-label:hover{color:var(--color-primary-700,#4c51bf);text-decoration:underline}.notifications-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:64px 16px;color:var(--color-text-muted,#64748b);text-align:center}.notifications-empty svg{color:#cbd5e1;margin-bottom:16px}.notifications-empty h3{margin:0 0 8px;font-size:1.125rem;font-weight:500;color:var(--color-text-primary,#1e293b)}.notifications-empty p{margin:0;font-size:.875rem}.notifications-load-more-row{padding:16px;border-top:1px solid #f1f5f9}.notifications-load-more{width:100%;padding:8px 16px;background:none;border:none;font-size:.875rem;font-weight:500;color:var(--color-primary,#667eea);cursor:pointer;border-radius:6px;transition:background-color .15s ease}.notifications-load-more:hover:not(:disabled){background:var(--color-primary-50,#f0f4ff)}.notifications-load-more:disabled{opacity:.5;cursor:not-allowed}.messages-page-wrapper{height:calc(100vh - 64px);display:flex;background:#ffffff}.messages-sidebar{width:100%;max-width:380px;border-right:1px solid #e2e8f0;background:#ffffff;display:flex;flex-direction:column}.messages-sidebar--mobile-hidden{display:none}@media (min-width:768px){.messages-sidebar--mobile-hidden{display:flex}}.messages-sidebar__header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid #e2e8f0}.messages-sidebar__header h1{margin:0;font-size:1.125rem;font-weight:600;color:var(--color-text-primary,#1e293b)}.messages-sidebar__list{flex:1 1;overflow-y:auto}.messages-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 16px;color:var(--color-text-muted,#64748b);text-align:center}.messages-empty svg{color:#cbd5e1;margin-bottom:16px}.messages-empty h3{margin:0 0 8px;font-size:1.125rem;font-weight:500;color:var(--color-text-primary,#1e293b)}.messages-empty p{margin:0;font-size:.875rem}.messages-conversation{display:flex;align-items:center;gap:12px;padding:12px 16px;border-bottom:1px solid #f1f5f9;cursor:pointer;text-decoration:none;color:inherit}.messages-conversation:hover{background:#f8fafc}.messages-conversation--active{background:var(--color-primary-50,#f0f4ff)}.messages-conversation__avatar{flex-shrink:0;width:40px;height:40px;border-radius:50%;background:var(--color-primary-100,#e0e9ff);color:var(--color-primary,#667eea);display:flex;align-items:center;justify-content:center;font-weight:600}.messages-conversation__avatar img{width:100%;height:100%;border-radius:50%;object-fit:cover}.messages-conversation__body{flex:1 1;min-width:0}.messages-conversation__name{font-weight:600;color:var(--color-text-primary,#1e293b);font-size:.9375rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.messages-conversation__preview{font-size:.8125rem;color:var(--color-text-muted,#64748b);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}.messages-conversation__unread{width:22px;height:22px;border-radius:50%;background:var(--color-primary,#667eea);color:#ffffff;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:600}.messages-main{flex:1 1;display:flex;flex-direction:column;min-width:0;background:#f8fafc}.messages-main--placeholder{display:flex;align-items:center;justify-content:center}.messages-main__header{padding:12px 16px;border-bottom:1px solid #e2e8f0;background:#ffffff;display:flex;align-items:center;gap:12px}.messages-main__back{background:none;border:none;color:var(--color-primary,#667eea);cursor:pointer;padding:4px;display:inline-flex;align-items:center}.messages-main__title{font-weight:600;color:var(--color-text-primary,#1e293b);margin:0;font-size:1rem}.messages-main__body{flex:1 1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:8px}.messages-main__footer{padding:12px 16px;border-top:1px solid #e2e8f0;background:#ffffff;display:flex;gap:8px}.messages-main__footer input{flex:1 1;padding:10px 14px;border:1px solid #e2e8f0;border-radius:9999px;font-size:.9375rem;outline:none}.messages-main__footer input:focus{border-color:var(--color-primary,#667eea)}.messages-main__footer button{padding:8px 18px;background:var(--color-primary,#667eea);color:#ffffff;border:none;border-radius:9999px;font-size:.9375rem;font-weight:600;cursor:pointer}.messages-main__footer button:disabled{opacity:.5;cursor:not-allowed}.message-bubble{max-width:75%;padding:10px 14px;border-radius:18px;font-size:.9375rem;line-height:1.4}.message-bubble--mine{align-self:flex-end;background:var(--color-primary,#667eea);color:#ffffff;border-bottom-right-radius:4px}.message-bubble--theirs{align-self:flex-start;background:#ffffff;color:var(--color-text-primary,#1e293b);border:1px solid #e2e8f0;border-bottom-left-radius:4px}.messages-new-ai-btn{display:inline-flex;align-items:center;gap:4px;padding:6px 12px;background:var(--color-primary,#667eea);color:#ffffff;border:none;border-radius:9999px;font-size:.75rem;font-weight:500;cursor:pointer;text-decoration:none}.messages-new-ai-btn:hover{background:var(--color-primary-600,#5a67d8)}.utility-page-loading{min-height:calc(100vh - 64px);display:flex;align-items:center;justify-content:center;flex-direction:column;gap:12px;color:var(--color-text-muted,#64748b)}.utility-page-loading .spinner{width:32px;height:32px;border-radius:50%;border:3px solid var(--color-primary-100,#e0e9ff);border-top-color:var(--color-primary,#667eea);animation:utility-spinner .8s linear infinite}@keyframes utility-spinner{to{transform:rotate(1turn)}}.profile-input,.profile-select{width:100%;padding:10px 14px;border:1px solid var(--color-border);border-radius:var(--radius-lg);font-size:14px;line-height:1.6;color:var(--color-text-primary);background:var(--color-bg-primary);transition:border-color .2s}.profile-input:focus,.profile-select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(102,126,234,.15)}.profile-input:disabled,.profile-select:disabled{background:var(--color-bg-secondary);cursor:not-allowed;opacity:.6}.profile-input::placeholder{color:var(--color-text-light)}.profile-section-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:16px}button.profile-subscription-manage{background:none;border:none;padding:0;cursor:pointer}button.profile-subscription-manage:disabled{cursor:wait;opacity:.6}.notification-bell-wrapper{position:relative}.notification-bell-dropdown{position:absolute;top:100%;right:0;margin-top:8px;width:384px;max-width:calc(100vw - 16px);max-height:80vh;background:var(--color-bg-primary,#fff);border:1px solid var(--color-border,#e5e7eb);border-radius:var(--radius-lg,12px);box-shadow:0 10px 25px rgba(0,0,0,.08),0 4px 6px rgba(0,0,0,.05);z-index:50;display:flex;flex-direction:column;overflow:hidden}.notification-bell-dropdown-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--color-border,#e5e7eb);background:var(--color-bg-secondary,#f9fafb)}.notification-bell-dropdown-title{font-size:16px;font-weight:600;color:var(--color-text-primary,#111827);margin:0}.notification-bell-mark-all{background:none;border:none;font-size:13px;font-weight:500;color:var(--color-primary,#667eea);cursor:pointer}.notification-bell-mark-all:hover{color:var(--color-primary-600,#5a67d8)}.notification-bell-list{flex:1 1 auto;overflow-y:auto}.notification-bell-loading{padding:32px 0}.notification-bell-empty,.notification-bell-loading{display:flex;align-items:center;justify-content:center}.notification-bell-empty{flex-direction:column;padding:48px 16px;color:var(--color-text-muted,#6b7280);text-align:center}.notification-bell-empty svg{width:48px;height:48px;margin-bottom:12px;color:var(--color-text-light,#d1d5db)}.notification-bell-empty p{font-size:14px;margin:0}.notification-bell-item{display:flex;align-items:flex-start;gap:12px;padding:12px 16px;cursor:pointer;transition:background .15s;border-bottom:1px solid var(--color-border-subtle,#f3f4f6);position:relative}.notification-bell-item:last-child{border-bottom:none}.notification-bell-item:hover{background:var(--color-bg-secondary,#f9fafb)}.notification-bell-item--unread{background:rgba(102,126,234,.06)}.notification-bell-item-icon{flex-shrink:0;width:36px;height:36px;border-radius:50%;background:var(--color-primary-100,#e0e7ff);color:var(--color-primary,#667eea);display:flex;align-items:center;justify-content:center}.notification-bell-item-icon-svg{width:20px;height:20px}.notification-bell-item-body{flex:1 1 auto;min-width:0}.notification-bell-item-title{font-size:14px;color:var(--color-text-primary,#111827);font-weight:600;margin:0 0 4px;line-height:1.4}.notification-bell-item--unread .notification-bell-item-title{font-weight:600}.notification-bell-item:not(.notification-bell-item--unread) .notification-bell-item-title{font-weight:500;color:var(--color-text-secondary,#4b5563)}.notification-bell-item-message{font-size:13px;color:var(--color-text-muted,#6b7280);margin:0;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.notification-bell-item-time{font-size:12px;color:var(--color-text-light,#9ca3af);margin:4px 0 0}.notification-bell-item-dismiss{flex-shrink:0;background:none;border:none;padding:4px;border-radius:50%;color:var(--color-text-light,#9ca3af);cursor:pointer;align-self:flex-start}.notification-bell-item-dismiss:hover{background:var(--color-bg-tertiary,#f3f4f6);color:var(--color-text-secondary,#4b5563)}.notification-bell-item-dismiss svg{width:16px;height:16px}.notification-bell-item-unread-dot{position:absolute;top:18px;right:36px;width:8px;height:8px;border-radius:50%;background:var(--color-primary,#667eea)}.notification-bell-dropdown-footer{border-top:1px solid var(--color-border,#e5e7eb);background:var(--color-bg-secondary,#f9fafb)}.notification-bell-view-all{display:block;padding:12px 16px;text-align:center;font-size:14px;font-weight:500;color:var(--color-primary,#667eea);text-decoration:none}.notification-bell-view-all:hover{background:var(--color-bg-tertiary,#f3f4f6);color:var(--color-primary-600,#5a67d8)}@media (max-width:480px){.notification-bell-dropdown{position:fixed;top:64px;right:8px;left:8px;width:auto}}.sentences-toolbar{margin-top:12px}.vocabulary-modal .context-definition{background:var(--color-primary-light);border-left:4px solid var(--color-primary)}.vocabulary-modal .context-definition h4{color:var(--color-primary-hover)}.vocabulary-modal .context-example{background:var(--color-bg-tertiary);border-left:4px solid var(--color-border)}.vocabulary-modal .context-example h4,.vocabulary-modal .context-text{color:var(--color-text-secondary)}.vocabulary-modal .cefr-badge{color:inherit}.vocabulary-modal .cefr-badge--A1{background:#dcfce7;color:#15803d}.vocabulary-modal .cefr-badge--A2{background:#ecfccb;color:#4d7c0f}.vocabulary-modal .cefr-badge--B1{background:#fef9c3;color:#a16207}.vocabulary-modal .cefr-badge--B2{background:#ffedd5;color:#c2410c}.vocabulary-modal .cefr-badge--C1{background:#fee2e2;color:#b91c1c}.vocabulary-modal .cefr-badge--C2{background:#fecaca;color:#991b1b}.vocab-card.clickable:after{content:none}.vocab-card-hover-hint{position:absolute;bottom:8px;right:12px;font-size:11px;color:#2563EB;opacity:0;transition:opacity .2s ease;pointer-events:none}.vocab-card.clickable:focus-visible .vocab-card-hover-hint,.vocab-card.clickable:hover .vocab-card-hover-hint{opacity:1}.notes-panel{display:flex;flex-direction:column;height:100%;background:white}.notes-panel__title{margin:0;font-size:15px;font-weight:600;color:var(--color-text-primary);flex:1 1}.notes-panel__header-actions{display:flex;align-items:center;gap:8px;margin-left:auto}.notes-panel__new-btn{background:var(--color-primary);color:white;border:none;border-radius:var(--radius-md);padding:6px 12px;font-size:13px;cursor:pointer;transition:background var(--transition-fast);display:inline-flex;align-items:center;gap:4px}.notes-panel__new-btn:hover{background:var(--color-primary-hover)}.notes-panel__close-btn{background:none;border:1px solid var(--color-border);border-radius:var(--radius-md);padding:4px 6px;color:var(--color-text-muted);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:color var(--transition-fast),background var(--transition-fast)}.notes-panel__close-btn:hover{color:var(--color-text-primary);background:var(--color-bg-tertiary)}.notes-panel__error,.notes-panel__loading{padding:14px 16px;font-size:13px;color:var(--color-text-muted)}.notes-panel__error{color:var(--color-error)}ul.notes-panel__list{list-style:none;margin:0}.graph-modal__sentence{background:var(--color-primary-light);border-bottom:2px solid var(--color-primary)}.vocabulary-item__phonetic-inline{font-size:13px;color:var(--color-text-muted,#64748b);font-style:italic;margin-left:4px}.vocabulary-item__body{display:flex;align-items:flex-end;gap:12px}.vocabulary-item__body .vocabulary-item__definition{flex:1 1;min-width:0}.vocabulary-item__collect-btn{flex-shrink:0;font-size:12px;font-weight:500;color:var(--color-primary,#667eea);border:1px solid var(--color-primary,#667eea);border-radius:6px;padding:4px 10px;cursor:pointer;white-space:nowrap;transition:background .15s ease,color .15s ease}.vocabulary-item__collect-btn:hover{background:var(--color-primary,#667eea);color:white}.input-mode-toggle--pill{display:inline-flex;border-radius:6px;background:var(--color-bg-tertiary,#f1f5f9);padding:2px;gap:1px;flex-shrink:0}.input-mode-pill__option{padding:4px 10px;border:none;border-radius:5px;font-size:12px;font-weight:500;color:var(--color-text-muted,#64748b);cursor:pointer;transition:background .15s ease,color .15s ease;white-space:nowrap;line-height:1.2;outline:none}.input-mode-pill__option:focus-visible{box-shadow:0 0 0 2px var(--color-primary,#667eea)}.input-mode-pill__option:hover:not(.input-mode-pill__option--active){color:var(--color-text-secondary,#475569);background:rgba(102,126,234,.08)}.input-mode-pill__option--active{background:var(--color-primary,#667eea);color:white;cursor:default}.word-practice-modal__hint{margin:8px 0 0;font-size:13px;color:var(--color-text-muted,#64748b);text-align:center}.word-practice-modal{background:linear-gradient(135deg,var(--color-primary-light,#f0f4ff) 0,#e8eeff 100%);border-color:var(--color-primary,#667eea)}.word-practice-modal__title{color:var(--color-primary-hover,#5a6fd0)}.status-page{display:flex;align-items:center;justify-content:center;min-height:60vh;padding:48px 20px;text-align:center}.status-page__inner{max-width:420px}.status-page__code{font-size:64px;font-weight:800;line-height:1;margin:0 0 8px;color:var(--color-primary,#667eea);letter-spacing:.02em}.status-page__title{font-size:22px;font-weight:700;margin:0 0 10px;color:var(--color-text-primary,#1f2937)}.status-page__desc{font-size:15px;line-height:1.6;margin:0 0 24px;color:var(--color-text-secondary,#475569)}.status-page__actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.status-page__btn{display:inline-flex;align-items:center;justify-content:center;padding:10px 20px;border-radius:8px;font-size:14px;font-weight:600;line-height:1.5;text-decoration:none;cursor:pointer;border:1px solid var(--color-border,#e2e8f0);background:var(--color-bg-secondary,#f1f5f9);color:var(--color-text-secondary,#475569);transition:background .15s ease,color .15s ease}.status-page__btn:hover{background:var(--color-bg-tertiary,#e2e8f0)}.status-page__btn--primary{background:var(--color-primary,#667eea);border-color:var(--color-primary,#667eea);color:#fff}.status-page__btn--primary:hover{background:var(--color-primary-hover,#5a6fd0)}.course-card--interactive{position:relative}.course-card__overlay-link{position:absolute;inset:0;z-index:1;border-radius:inherit}.course-card--interactive .course-actions{position:relative;z-index:2}.vocab-practice-page .recall-rate-actions{display:flex;justify-content:center;gap:var(--space-3);margin-top:var(--space-6)}.vocab-practice-page .learning-mode-header .vp-exit-btn{display:inline-flex;align-items:center;gap:var(--space-2);border:none;background:transparent;color:var(--color-text-muted);border-radius:var(--radius-md);cursor:pointer;transition:color .15s ease,background .15s ease}.vocab-practice-page .learning-mode-header .vp-exit-btn:hover{color:var(--color-primary);background:var(--color-bg-tertiary)}.vocab-practice-page .flashcard-face{overflow:hidden}.vocab-practice-page .flashcard-back .card-content{overflow-y:auto}.morph-ref__example--link{text-decoration:none;cursor:pointer;transition:background .15s ease,color .15s ease}.morph-ref__example--link:focus-visible,.morph-ref__example--link:hover{background:color-mix(in srgb,var(--color-primary,#667eea) 14%,white);color:var(--color-primary,#667eea);outline:none}.action-success{background:#f0fdf4;border:1px solid #bbf7d0;color:#16a34a;padding:.75rem 1rem;border-radius:8px;font-size:.9rem}.course-content-editor{margin-top:28px}.course-manage-loading{padding:24px;color:var(--color-text-secondary,#64748b)}.phrase-card__edit input,.phrase-card__edit textarea{width:100%;padding:6px 8px;margin-bottom:6px;border:1px solid var(--color-border,#e2e8f0);border-radius:6px;font:inherit}.phrase-card__actions{display:flex;gap:8px;justify-content:flex-end}.vocab-pos{color:var(--color-text-secondary,#94a3b8);font-size:12px}.vocab-def{color:var(--color-text-secondary,#64748b)}.course-meta-editor__tags{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.course-meta-editor__tags input{border:1px solid var(--color-border,#e2e8f0);border-radius:6px;padding:4px 8px;min-width:80px}.course-meta-editor__tags .meta-badge button{border:none;background:none;cursor:pointer;margin-left:4px;color:inherit}.course-content-editor .content-empty{color:var(--color-text-secondary,#94a3b8);padding:24px 4px;font-size:14px}.cse-overlay{position:fixed;inset:0;z-index:1000;background:rgba(15,23,42,.45);display:flex;align-items:center;justify-content:center;padding:20px;animation:cse-fade .15s ease}@keyframes cse-fade{0%{opacity:0}to{opacity:1}}.cse-modal{background:#fff;border-radius:16px;width:100%;max-width:640px;max-height:88vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 24px 60px rgba(15,23,42,.28)}.cse-header{display:flex;align-items:center;justify-content:space-between;padding:18px 24px;border-bottom:1px solid var(--color-border,#e2e8f0);flex-shrink:0}.cse-header h2{margin:0;font-size:18px;font-weight:700;color:var(--color-text,#1e293b)}.cse-close{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;border:none;cursor:pointer;background:var(--color-surface,#f1f5f9);color:var(--color-text-secondary,#64748b)}.cse-close:hover{background:#e2e8f0;color:var(--color-text,#1e293b)}.cse-tabs{display:flex;gap:2px;padding:0 16px;border-bottom:1px solid var(--color-border,#e2e8f0);overflow-x:auto;flex-shrink:0}.cse-tab{display:inline-flex;align-items:center;gap:6px;white-space:nowrap;padding:12px 14px;background:none;cursor:pointer;font-size:14px;color:var(--color-text-secondary,#64748b);border:none;border-bottom:2px solid transparent;margin-bottom:-1px}.cse-tab:hover{color:var(--color-text,#334155)}.cse-tab.active{color:var(--color-primary,#667eea);border-bottom-color:var(--color-primary,#667eea);font-weight:600}.cse-tab__icon{display:inline-flex}.cse-error{margin:12px 24px 0;padding:10px 12px;border-radius:8px;background:var(--color-error-light,#fef2f2);color:var(--color-error-text,#b91c1c);font-size:13px}.cse-body{padding:20px 24px;overflow-y:auto;flex:1 1}.cse-section{display:flex;flex-direction:column;gap:16px}.cse-section__head{display:flex;align-items:center;justify-content:space-between;gap:12px}.cse-section__head h3{margin:0;font-size:15px;font-weight:700;color:var(--color-text,#1e293b)}.cse-subhead{margin:4px 0 0;font-size:13px;font-weight:600;color:var(--color-text-secondary,#64748b)}.cse-field{display:flex;flex-direction:column;gap:6px}.cse-field>label{font-size:13px;font-weight:600;color:var(--color-text,#334155)}.cse-field input,.cse-field textarea,.cse-vocab__row input{width:100%;border:1px solid var(--color-border,#e2e8f0);border-radius:8px;padding:9px 12px;font-size:14px;font-family:inherit;color:var(--color-text,#1e293b);background:#fff;resize:vertical}.cse-field input:focus,.cse-field textarea:focus,.cse-vocab__row input:focus{outline:none;border-color:var(--color-primary,#667eea);box-shadow:0 0 0 3px rgba(102,126,234,.12)}.cse-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.cse-card{border:1px solid var(--color-border,#e2e8f0);border-radius:10px;padding:14px;display:flex;flex-direction:column;gap:12px;background:var(--color-surface,#f8fafc)}.cse-card__head{display:flex;align-items:center;justify-content:space-between}.cse-card__num{font-weight:700}.cse-add,.cse-card__num{font-size:13px;color:var(--color-primary,#667eea)}.cse-add{display:inline-flex;align-items:center;gap:5px;cursor:pointer;border:1px solid var(--color-primary,#667eea);background:#fff;border-radius:8px;padding:6px 12px;font-weight:600}.cse-add:hover{background:#eef0fb}.cse-remove{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:6px;border:none;cursor:pointer;background:none;color:var(--color-text-secondary,#94a3b8);flex-shrink:0}.cse-remove:hover{background:var(--color-error-light,#fef2f2);color:var(--color-error-text,#dc2626)}.cse-empty{margin:0;padding:18px;text-align:center;color:var(--color-text-secondary,#94a3b8);font-size:13px;background:var(--color-surface,#f8fafc);border-radius:8px}.cse-vocab{display:flex;flex-direction:column;gap:8px}.cse-vocab__row{gap:8px}.cse-footer,.cse-vocab__row{display:flex;align-items:center}.cse-footer{justify-content:flex-end;gap:10px;padding:16px 24px;border-top:1px solid var(--color-border,#e2e8f0);flex-shrink:0}.cse-btn-cancel{border:1px solid var(--color-border,#e2e8f0);background:#fff;color:var(--color-text,#475569);border-radius:8px;padding:9px 18px;font-size:14px;font-weight:600;cursor:pointer}.cse-btn-cancel:hover{background:var(--color-surface,#f8fafc)}.cse-btn-save{border:none;background:var(--color-primary,#667eea);color:#fff;border-radius:8px;padding:9px 20px;font-size:14px;font-weight:600;cursor:pointer}.cse-btn-save:hover{filter:brightness(.96)}.cse-btn-cancel:disabled,.cse-btn-save:disabled{opacity:.6;cursor:default}@media (max-width:560px){.cse-row{grid-template-columns:1fr}}.welcome-page{background:var(--color-bg-secondary)}.welcome-title{color:var(--color-text-primary)}.welcome-subtitle{color:var(--color-text-secondary)}.welcome-referral-badge{background:var(--color-primary)}.welcome-hero-actions .btn-primary{background:var(--color-primary);box-shadow:0 4px 14px rgba(102,126,234,.35)}.welcome-hero-actions .btn-primary:hover{background:var(--color-primary-hover);box-shadow:0 6px 20px rgba(102,126,234,.45)}.welcome-hero-actions .btn-outline{color:var(--color-primary);border-color:var(--color-primary)}.welcome-hero-actions .btn-outline:hover{background:var(--color-primary);color:#fff}.welcome-section-title{color:var(--color-text-primary)}.welcome-benefit-card .benefit-icon{background:var(--color-primary-light);color:var(--color-primary)}.welcome-benefit-card h3{color:var(--color-text-primary)}.welcome-cta{background:var(--color-primary-hover)}.welcome-cta .btn-xl{color:var(--color-primary)}.welcome-reward-content{background:var(--color-accent-bg)}.dictionary-popover .examples-loading{display:flex;align-items:center;gap:8px;padding:4px 0;font-size:13px;color:var(--color-text-muted)}.dictionary-page .example-header,.dictionary-popover .example-header{align-items:flex-start}.dictionary-page .example-pos,.dictionary-popover .example-pos{flex-shrink:0;white-space:nowrap;line-height:1.5}@media (min-width:641px){.dictionary-popover-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:var(--z-overlay,400);animation:dictBackdropFadeIn .2s ease-out}@keyframes dictBackdropFadeIn{0%{opacity:0}to{opacity:1}}.dictionary-popover{position:fixed;left:50%;top:50%;transform:translate(-50%,-50%);min-width:360px;max-width:480px;width:calc(100vw - 64px);max-height:85vh;animation:dictModalIn .2s ease-out}@keyframes dictModalIn{0%{opacity:0;transform:translate(-50%,-50%) scale(.97)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}}.course-title.bilingual-title--card{display:block;-webkit-line-clamp:none;overflow:visible}.course-title.bilingual-title--card .bilingual-title__en{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.course-card .course-card-creator{display:flex;align-items:center;gap:6px;font-size:13px;line-height:1.4;color:var(--color-text-muted);margin-top:8px;margin-bottom:var(--space-2);min-width:0}.course-card .course-card-creator__icon{flex-shrink:0;opacity:.75}.course-card .course-card-creator .creator-link{color:var(--color-text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sw-review{max-width:640px;margin:0 auto;padding:24px 16px 64px}.sw-review__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.sw-review__back{color:var(--color-primary,#6366f1);font-size:14px;font-weight:500;text-decoration:none}.sw-review__back:hover{text-decoration:underline}.sw-review__progress{font-size:14px;color:var(--color-text-secondary,#64748b);font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.sw-review__center{text-align:center;padding:64px 16px;color:var(--color-text-secondary,#64748b);gap:16px}.sw-review__card,.sw-review__center{display:flex;flex-direction:column;align-items:center}.sw-review__card{background:var(--color-surface,#fff);border:1px solid var(--color-border,#e2e8f0);border-radius:16px;padding:32px 24px;gap:18px;box-shadow:0 1px 3px rgba(0,0,0,.06)}.sw-review__instruction{font-size:14px;color:var(--color-text-secondary,#64748b);margin:0}.sw-review__audio,.sw-review__mic{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:none;cursor:pointer;color:#fff;background:var(--color-primary,#6366f1);border-radius:999px;transition:filter .15s,transform .15s}.sw-review__audio{width:56px;height:56px;padding:0}.sw-review__audio:hover,.sw-review__mic:hover{filter:brightness(1.05)}.sw-review__mic{padding:12px 22px;font-size:15px;font-weight:600}.sw-review__mic.is-recording{background:#ef4444;animation:sw-pulse 1.1s ease-in-out infinite}@keyframes sw-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.04)}}.sw-review__sentence{font-size:20px;line-height:1.6;text-align:center;color:var(--color-text-primary,#1e293b);margin:0}.sw-review__translation{font-size:15px;color:var(--color-text-secondary,#64748b);margin:0}.sw-review__word{font-size:30px;font-weight:700;color:var(--color-text-primary,#1e293b);margin:0}.sw-review__gloss{font-size:16px;color:var(--color-text-secondary,#475569);margin:0}.sw-review__input{width:100%;max-width:320px;padding:12px 16px;font-size:18px;text-align:center;border:2px solid var(--color-border,#e2e8f0);border-radius:10px;outline:none;transition:border-color .15s}.sw-review__input:focus{border-color:var(--color-primary,#6366f1)}.sw-review__input.is-correct{border-color:#22c55e;background:#f0fdf4}.sw-review__input.is-wrong{border-color:#ef4444;background:#fef2f2}.sw-review__record{display:flex;justify-content:center;min-height:48px}.sw-review__feedback{display:flex;flex-wrap:wrap;align-items:baseline;justify-content:center;gap:10px;width:100%;padding:12px 16px;border-radius:10px;font-size:15px}.sw-review__feedback.is-correct{background:var(--color-success-light,#f0fdf4);color:var(--color-success-text,#166534)}.sw-review__feedback.is-wrong{background:#fef2f2;color:#991b1b}.sw-review__answer{font-weight:700}.sw-review__pron{margin-left:auto;font-feature-settings:"tnum";font-variant-numeric:tabular-nums;font-weight:600;opacity:.7}.sw-review__footer{width:100%;display:flex;justify-content:center;margin-top:4px}.sw-review__btn{padding:10px 28px;border:1px solid var(--color-border,#e2e8f0);border-radius:10px;background:#fff;color:var(--color-primary,#6366f1);font-size:15px;font-weight:600;cursor:pointer;transition:all .15s}.sw-review__btn:hover:not(:disabled){background:#f5f3ff}.sw-review__btn:disabled{opacity:.5;cursor:not-allowed}.sw-review__btn--primary{background:var(--color-primary,#6366f1);color:#fff;border-color:var(--color-primary,#6366f1)}.sw-review__btn--primary:hover:not(:disabled){filter:brightness(1.05);background:var(--color-primary,#6366f1)}.sw-review__score{font-size:40px;font-weight:700;color:var(--color-primary,#6366f1);margin:0}.sw-review__summary{gap:12px}.sw-review__actions{display:flex;flex-direction:column;align-items:center;gap:12px}.sw-review .lp-progress{display:none}.sw-review__toggle{display:flex;justify-content:center;margin-bottom:12px}.sw-review .sp-card__target{background:none;border-left:none;padding:4px 0;font-size:1.9rem;font-weight:700}.sw-review .dt-card__text-input:focus,.sw-review .dt-card__text-input:focus-visible{outline:none;border-color:var(--color-primary)}.sight-words__intro-actions{display:flex;flex-wrap:wrap;gap:10px;align-items:center}.sight-words__stats-cta{display:inline-flex;align-items:center;gap:6px;margin-top:14px;padding:10px 22px;background:#fff;color:var(--color-primary,#6366f1);border:1.5px solid var(--color-primary,#6366f1);border-radius:10px;font-size:15px;font-weight:600;text-decoration:none;transition:background .15s,color .15s}.sight-words__stats-cta:hover{background:var(--color-primary-50,#eef2ff)}.sw-stats{max-width:720px;margin:0 auto;padding:24px 16px 64px}.sw-stats__center{min-height:240px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--color-text-secondary,#64748b)}.sw-stats__header{margin-bottom:20px}.sw-review__back,.sw-stats__back{display:inline-block;color:var(--color-primary,#6366f1);text-decoration:none;font-size:14px;font-weight:600}.sw-stats__title{margin:8px 0 0;font-size:1.5rem;font-weight:800;color:var(--color-text,#1e293b)}.sw-stats__totals{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:10px;margin-bottom:28px}.sw-stats__stat{background:var(--color-surface,#fff);border:1px solid var(--color-border,#e2e8f0);border-radius:12px;padding:14px 10px;text-align:center;display:flex;flex-direction:column;gap:4px}.sw-stats__stat-num{font-size:1.6rem;font-weight:800;color:var(--color-primary,#6366f1);line-height:1.1}.sw-stats__stat-num--date{font-size:1rem;font-weight:700;color:var(--color-text,#1e293b)}.sw-stats__stat-label{font-size:12px;color:var(--color-text-secondary,#64748b)}.sw-stats__section{margin-bottom:30px}.sw-stats__section-title{font-size:1rem;font-weight:700;color:var(--color-text,#1e293b);margin:0 0 14px}.sw-stats__snapshot{display:flex;align-items:center;gap:24px;flex-wrap:wrap}.sw-stats__donut{width:140px;height:140px;flex-shrink:0}.sw-stats__donut-num{font-size:26px;font-weight:800;fill:var(--color-text,#1e293b)}.sw-stats__donut-den{font-size:13px;fill:var(--color-text-secondary,#64748b)}.sw-stats__legend{list-style:none;margin:0;padding:0;flex:1 1;min-width:200px;display:flex;flex-direction:column;gap:8px}.sw-stats__legend-row{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--color-text,#1e293b)}.sw-stats__legend-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.sw-stats__legend-name{flex:1 1}.sw-stats__legend-count{font-weight:700}.sw-stats__levels{display:flex;flex-direction:column;gap:12px}.sw-stats__level-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:5px}.sw-stats__level-name{font-size:13px;font-weight:600;color:var(--color-text,#1e293b)}.sw-stats__level-count{font-size:12px;color:var(--color-text-secondary,#64748b)}.sw-stats__bar{display:flex;height:12px;border-radius:6px;overflow:hidden;background:#f1f5f9}.sw-stats__bar-seg{height:100%}.sw-stats__timeline{display:flex;align-items:flex-end;gap:3px;height:96px;padding:8px 0}.sw-stats__timeline-col{flex:1 1;height:100%;display:flex;align-items:flex-end}.sw-stats__timeline-bar{position:relative;width:100%;height:100%;display:flex;align-items:flex-end;justify-content:center}.sw-stats__timeline-fill{position:absolute;bottom:0;left:0;width:100%;border-radius:3px 3px 0 0}.sw-stats__timeline-fill--wrong{background:#fca5a5}.sw-stats__timeline-fill--correct{background:#22c55e}.sw-stats__timeline-empty{font-size:14px;color:var(--color-text-secondary,#64748b);padding:16px 0}.sw-stats__timeline-caption{display:flex;align-items:center;gap:6px;margin-top:8px;font-size:12px;color:var(--color-text-secondary,#64748b)}.sw-stats__cta{margin-top:10px;text-align:center}.sw-stats__note{margin:-6px 0 12px;font-size:12px;color:var(--color-text-secondary,#64748b)}.sw-stats__sessions{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.sw-stats__session{display:grid;grid-template-columns:88px 1fr auto;align-items:center;gap:12px;font-size:13px}.sw-stats__session-date{color:var(--color-text-secondary,#64748b)}.sw-stats__session-bar{height:8px;border-radius:4px;background:#f1f5f9;overflow:hidden}.sw-stats__session-fill{display:block;height:100%;background:#22c55e;border-radius:4px}.sw-stats__session-score{font-weight:700;color:var(--color-text,#1e293b);white-space:nowrap}.sw-stats__session-pct{font-weight:600;color:var(--color-text-secondary,#64748b)}.sw-stats__reviews{list-style:none;margin:0;padding:0;display:flex;flex-direction:column}.sw-stats__review{display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:1px solid var(--color-border,#e2e8f0);font-size:14px}.sw-stats__review:last-child{border-bottom:none}.sw-stats__review-mark{width:22px;height:22px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.sw-stats__review--correct .sw-stats__review-mark{background:var(--color-success-light,#dcfce7);color:var(--color-success-text,#15803d)}.sw-stats__review--hint .sw-stats__review-mark{background:#fef3c7;color:#b45309}.sw-stats__review--wrong .sw-stats__review-mark{background:#fee2e2;color:#b91c1c}.sw-stats__review-word{font-weight:600;color:var(--color-text,#1e293b)}.sw-stats__review-hint{font-size:11px;font-weight:600;color:#b45309;background:#fef3c7;padding:1px 7px;border-radius:999px}.sw-stats__review-meta{margin-left:auto;display:flex;align-items:center;gap:12px;color:var(--color-text-secondary,#64748b);font-size:12px}.sw-stats__review-time{font-feature-settings:"tnum";font-variant-numeric:tabular-nums}@media (max-width:520px){.sw-stats__session{grid-template-columns:72px 1fr auto;gap:8px}}.question-card .quiz-option{opacity:1}.kf-stats{max-width:720px;margin:0 auto;padding:24px 16px 64px}.kf-stats__header{margin-bottom:20px}.kf-stats__back{display:inline-block;color:var(--color-primary,#6366f1);text-decoration:none;font-size:14px;font-weight:600}.kf-stats__title{margin:8px 0 0;font-size:1.5rem;font-weight:800;color:var(--color-text,#1e293b)}.kf-stats__center{min-height:240px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--color-text-secondary,#64748b)}.kf-stats-cta-row{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-top:14px}.kf-stats-cta{display:inline-flex;align-items:center;gap:6px;padding:10px 22px;background:#fff;color:var(--color-primary,#6366f1);border:1.5px solid var(--color-primary,#6366f1);border-radius:10px;font-size:15px;font-weight:600;text-decoration:none;transition:background .15s,color .15s}.kf-stats-cta:hover{background:var(--color-primary-50,#eef2ff)}.kf-trainer-note{margin:10px 0 0;font-size:.85rem;color:var(--color-text-muted)}.phonics-ref__cta-row,.prosody-ref__cta-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:16px}.phonics-ref__review-cta,.prosody-ref__review-cta{display:inline-flex;align-items:center;gap:6px;padding:10px 22px;background:var(--color-primary,#667eea);color:#fff;border:1.5px solid transparent;border-radius:10px;font-size:15px;font-weight:600;text-decoration:none;transition:filter .15s}.phonics-ref__review-cta:hover,.prosody-ref__review-cta:hover{filter:brightness(1.05)}.phonics-ref__train-cta{display:inline-flex;align-items:center;gap:6px;padding:10px 22px;background:#fff;color:var(--color-primary,#667eea);border:1.5px solid var(--color-primary,#667eea);border-radius:10px;font-size:15px;font-weight:600;text-decoration:none;transition:background .15s}.phonics-ref__train-cta:hover{background:var(--color-primary-50,#f0f4ff)}.ph-review{max-width:720px;margin:0 auto;padding:24px 16px 64px}.ph-review__header{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:20px}.ph-review__back{color:var(--color-primary,#667eea);text-decoration:none;font-size:14px;font-weight:600}.ph-review__back:hover{text-decoration:underline}.ph-review__progress{font-size:14px;font-weight:600;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.ph-review__center,.ph-review__progress{color:var(--color-text-secondary,#64748b)}.ph-review__center{min-height:240px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;text-align:center}.ph-review__center-title{margin:0;font-size:1.1rem;font-weight:700;color:var(--color-text,#1e293b)}.ph-review__intro{display:flex;flex-direction:column;align-items:center;gap:12px;background:#fff;border:1px solid var(--color-border,#e2e8f0);border-radius:16px;padding:36px 24px;text-align:center}.ph-review__intro-title{margin:0;font-size:1.5rem;font-weight:800;color:var(--color-text,#1e293b)}.ph-review__badge{display:inline-flex;padding:4px 14px;border-radius:999px;background:var(--color-primary-50,#f0f4ff);color:var(--color-primary,#667eea);font-size:13px;font-weight:700}.ph-review__intro p{margin:0;max-width:460px;font-size:15px;line-height:1.7;color:var(--color-text-secondary,#64748b)}.ph-review__primary-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:12px 28px;background:var(--color-primary,#667eea);color:#fff;border:none;border-radius:10px;font-size:15px;font-weight:700;cursor:pointer;transition:filter .15s}.ph-review__primary-btn:hover:not(:disabled){filter:brightness(1.05)}.ph-review__primary-btn:disabled{opacity:.6;cursor:not-allowed}.ph-review__ghost-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:12px 28px;background:#fff;color:var(--color-primary,#667eea);border:1.5px solid var(--color-primary,#667eea);border-radius:10px;font-size:15px;font-weight:700;text-decoration:none;transition:background .15s}.ph-review__ghost-btn:hover{background:var(--color-primary-50,#f0f4ff)}.ph-review__prompt{margin:0 0 14px;text-align:center;font-size:15px;color:var(--color-text-secondary,#64748b)}.ph-review__audio-row{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:20px}.ph-review__speaker-badge{padding:5px 12px;border-radius:999px;background:var(--color-bg-secondary,#f8fafc);border:1px solid var(--color-border,#e2e8f0);font-size:13px;font-weight:600;color:var(--color-text-secondary,#64748b)}.ph-review__replay-btn,.ph-review__slow-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;min-height:44px;padding:8px 16px;background:#fff;color:var(--color-primary,#667eea);border:1.5px solid var(--color-primary,#667eea);border-radius:999px;font-size:14px;font-weight:600;cursor:pointer;transition:background .15s}.ph-review__replay-btn:hover:not(:disabled),.ph-review__slow-btn:hover:not(:disabled){background:var(--color-primary-50,#f0f4ff)}.ph-review__replay-btn:disabled,.ph-review__slow-btn:disabled{opacity:.5;cursor:not-allowed}.ph-review__slow-btn{align-self:flex-start}.ph-review__options{display:grid;grid-template-columns:1fr 1fr;gap:14px}.ph-review__option{display:flex;flex-direction:column;align-items:center;gap:6px;padding:26px 12px;background:#fff;border:2px solid var(--color-border,#e2e8f0);border-radius:14px;font:inherit;cursor:pointer;transition:border-color .15s,background .15s,transform .15s}.ph-review__option:hover:not(:disabled){border-color:var(--color-primary,#667eea);transform:translateY(-1px)}.ph-review__option:disabled{cursor:default}.ph-review__option--waiting:disabled{opacity:.65;cursor:wait}.ph-review__option--correct{border-color:var(--color-success-text,#15803d);background:var(--color-success-light,#dcfce7)}.ph-review__option--wrong{border-color:var(--color-error-border,#fecaca);background:var(--color-error-light,#fef2f2)}.ph-review__option-text{font-size:26px;font-weight:800;color:var(--color-text,#1e293b)}.ph-review__option-text--big{font-size:40px}.ph-review__option-ipa{font-size:15px;color:var(--color-text-secondary,#64748b)}.ph-review__option-gloss{font-size:13px;color:var(--color-text-secondary,#64748b)}.ph-review__tick{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:20px;color:var(--color-success-text,#15803d);font-size:16px;font-weight:700;animation:ph-review-pop .3s ease}@keyframes ph-review-pop{0%{transform:scale(.85);opacity:0}to{transform:scale(1);opacity:1}}@media (prefers-reduced-motion:reduce){.ph-review__tick{animation:none}.ph-review__option{transition:none}}.ph-review__rulecard{display:flex;flex-direction:column;gap:12px;margin-top:20px;padding:18px;background:var(--color-bg-secondary,#f8fafc);border:1px solid var(--color-border,#e2e8f0);border-radius:14px}.ph-review__rulecard-title{margin:0;font-size:15px;font-weight:700;color:var(--color-text,#1e293b)}.ph-review__figure{margin:0;align-self:center;display:flex;flex-direction:column;align-items:center;gap:4px}.ph-review__diagram{width:100%;max-width:320px;border-radius:10px}.ph-review__diagram-caption{font-size:12px;color:var(--color-text-secondary,#64748b)}.ph-review__tip{margin:0;font-size:14px;line-height:1.7;color:var(--color-text,#1e293b)}.ph-review__chips{display:flex;flex-wrap:wrap;gap:8px}.ph-review__chip{padding:4px 12px;border-radius:999px;background:var(--color-primary-50,#f0f4ff);color:var(--color-primary,#667eea);font-size:14px;font-weight:700}.ph-review__chip--contrast{background:#fff;color:var(--color-text-secondary,#64748b);border:1px solid var(--color-border,#e2e8f0)}.ph-review__next-btn{width:100%;margin-top:16px}.ph-review__summary{display:flex;flex-direction:column;gap:24px}.ph-review__score-card{padding:28px;background:#fff;border:1px solid var(--color-border,#e2e8f0);border-radius:16px;text-align:center}.ph-review__score{font-size:48px;font-weight:800;line-height:1;color:var(--color-primary,#667eea)}.ph-review__score-label{margin-top:8px}.ph-review__reaction,.ph-review__score-label{font-size:14px;color:var(--color-text-secondary,#64748b)}.ph-review__reaction{margin-top:10px;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.ph-review__section-title{margin:0 0 10px;font-size:15px;font-weight:700;color:var(--color-text,#1e293b)}.ph-review__cat-row,.ph-review__unit-row{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:10px 14px;margin-bottom:8px;background:#fff;border:1px solid var(--color-border,#e2e8f0);border-radius:10px;font-size:14px;color:var(--color-text,#1e293b);text-decoration:none}.ph-review__cat-row:hover{border-color:var(--color-primary,#667eea)}.ph-review__cat-count{font-weight:700;color:var(--color-text-secondary,#64748b);font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.ph-review__unit-meta{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--color-text-secondary,#64748b);font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.ph-review__mastered{padding:2px 10px;border-radius:999px;background:var(--color-success-light,#dcfce7);color:var(--color-success-text,#15803d);font-size:12px;font-weight:700}.ph-review__actions{flex-wrap:wrap}.mp-unit-head,.ph-review__actions{display:flex;justify-content:center;gap:12px}.mp-unit-head{align-items:center;margin-bottom:16px}.mp-unit-head__meaning{font-size:15px;color:var(--color-text-secondary,#475569)}.mp-tile{display:inline-flex;align-items:center;justify-content:center;padding:8px 14px;border-radius:10px;font-size:18px;font-weight:700;font-feature-settings:none;font-variant-ligatures:none;letter-spacing:.02em;background:var(--color-bg-tertiary,#f1f5f9);color:var(--color-text-primary,#1e293b);border:1.5px solid var(--color-border,#e2e8f0)}.mp-tile--affix{background:var(--color-primary-100,#e0e9ff);color:var(--color-primary-700,#4c51bf);border-color:var(--color-primary-100,#e0e9ff)}.mp-tile--root{background:var(--color-bg-tertiary,#f1f5f9)}.mp-tile--lg{font-size:24px;padding:10px 20px}.mp-tile--slot{min-width:84px;min-height:46px;border-style:dashed;color:var(--color-text-light,#94a3b8)}.mp-tile--slot.is-filled{border-style:solid;color:var(--color-text-primary,#1e293b)}.mp-tile--btn{cursor:pointer;transition:transform .15s,filter .15s}.mp-tile--btn:hover:not(:disabled){filter:brightness(.97);transform:translateY(-1px)}.mp-tile--btn:disabled{opacity:.35;cursor:default}.mp-tile-row{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:10px}.mp-tile-row--bank{margin-top:4px}.mp-tile-plus{font-size:18px;color:var(--color-text-muted,#64748b)}.mp-build-slots{display:flex;justify-content:center;gap:10px;margin:6px 0 10px}.mp-clear-btn{align-self:center;margin-top:8px;background:none;border:none;color:var(--color-text-muted,#64748b);font-size:13px;cursor:pointer;text-decoration:underline}.mp-word-display{display:flex;gap:8px;font-size:30px;font-weight:800;color:var(--color-text-primary,#1e293b);margin:4px 0}.mp-audio-btn,.mp-word-display{align-items:center;justify-content:center}.mp-audio-btn{display:inline-flex;width:32px;height:32px;padding:0;border:none;border-radius:50%;background:var(--color-primary-50,#f0f4ff);color:var(--color-primary,#667eea);cursor:pointer;transition:filter .15s}.mp-audio-btn:hover{filter:brightness(.95)}.mp-pretest-note{font-size:13px;color:var(--color-text-muted,#64748b);text-align:center;margin:0 0 6px}.mp-question{font-size:16px;text-align:center;color:var(--color-text-primary,#1e293b);margin:6px 0 10px}.mp-taught-list{display:flex;flex-direction:column;gap:8px;width:100%;max-width:360px;margin:0 auto 6px}.mp-taught-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:8px 12px;border-radius:10px;background:var(--color-bg-secondary,#f8fafc)}.mp-taught-word{display:inline-flex;align-items:center;gap:6px;font-weight:700;font-size:17px}.mp-taught-gloss{font-size:14px;color:var(--color-text-secondary,#475569);text-align:right}.mp-options{display:flex;flex-direction:column;gap:8px;width:100%;max-width:420px;margin:0 auto}.mp-option{padding:12px 16px;border-radius:12px;border:1.5px solid var(--color-border,#e2e8f0);background:var(--color-surface,#fff);font-size:15px;text-align:left;cursor:pointer;transition:border-color .15s,background .15s}.mp-option:hover:not(:disabled){border-color:var(--color-primary,#667eea);background:var(--color-primary-50,#f0f4ff)}.mp-option:disabled{cursor:default}.mp-option.is-correct{border-color:var(--color-success-text,#15803d);background:var(--color-success-light,#dcfce7);color:var(--color-success-text,#15803d);font-weight:600}.mp-option.is-wrong{border-color:var(--color-error-border,#fecaca);background:var(--color-error-light,#fef2f2);color:var(--color-error,#dc2626)}.mp-segment{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;margin:8px 0 4px}.mp-segment__cell{display:inline-flex;align-items:center}.mp-segment__letter{font-size:28px;font-weight:800;padding:4px 2px}.mp-segment__gap{width:14px;height:40px;margin:0 1px;padding:0;border:none;border-radius:6px;background:transparent;cursor:pointer;position:relative;transition:background .15s}.mp-segment__gap:after{content:"";position:absolute;left:50%;top:6px;bottom:6px;width:2px;transform:translateX(-50%);border-radius:2px;background:var(--color-border,#e2e8f0)}.mp-segment__gap:hover{background:var(--color-primary-50,#f0f4ff)}.mp-segment__gap.is-active:after,.mp-segment__gap:hover:after{background:var(--color-primary,#667eea)}.mp-summary__title{font-size:22px;font-weight:800;margin:4px 0 18px;text-align:center}.mp-summary__section{background:var(--color-surface,#fff);border:1px solid var(--color-border,#e2e8f0);border-radius:16px;padding:18px 20px;margin-bottom:14px}.mp-summary__section h2{font-size:15px;font-weight:700;margin:0 0 12px;color:var(--color-text-secondary,#475569)}.mp-summary__compare{display:flex;align-items:center;gap:10px;padding:6px 0;flex-wrap:wrap}.mp-summary__word{font-size:17px}.mp-summary__phase{font-size:14px;color:var(--color-text-secondary,#475569);font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.mp-summary__arrow{color:var(--color-text-light,#94a3b8)}.mp-summary__note{font-size:13px;color:var(--color-text-muted,#64748b);margin:8px 0 0}.mp-summary__unlock{font-size:15px;margin:0 0 10px}.mp-summary__chips{display:flex;flex-wrap:wrap;gap:8px}.mp-chip{padding:6px 12px;border-radius:999px;border:1px solid var(--color-primary-100,#e0e9ff);background:var(--color-primary-50,#f0f4ff);color:var(--color-primary-700,#4c51bf);font-size:14px;cursor:pointer;transition:filter .15s}.mp-chip:hover{filter:brightness(.97)}.mp-chip--ghost{cursor:default;background:var(--color-bg-secondary,#f8fafc);border-color:var(--color-border,#e2e8f0);color:var(--color-text-secondary,#475569)}.mp-summary__actions{margin-top:8px;justify-content:center;display:flex;gap:12px;flex-wrap:wrap;align-items:center}@media (max-width:480px){.mp-word-display{font-size:24px}.mp-segment__letter{font-size:22px}.mp-tile{font-size:16px;padding:7px 11px}}@media (prefers-reduced-motion:reduce){.mp-audio-btn,.mp-chip,.mp-option,.mp-segment__gap,.mp-tile--btn{transition:none}.mp-tile--btn:hover:not(:disabled){transform:none}}.mp-growth{margin-top:16px}.mp-growth__title{font-size:16px;font-weight:700;margin:0 0 4px}.mp-growth__subtitle{font-size:13px;color:var(--color-text-muted,#64748b);margin:0 0 14px}.mp-growth__chart{display:flex;align-items:flex-end;gap:8px;height:140px;padding:4px 0 0;margin-bottom:14px}.mp-growth__col{flex:1 1;display:flex;flex-direction:column;align-items:center;gap:4px;height:100%;min-width:0}.mp-growth__bar-area{flex:1 1;display:flex;align-items:flex-end;width:100%;justify-content:center}.mp-growth__bar{width:60%;max-width:36px;background:var(--color-primary-100,#e0e9ff);border-radius:6px 6px 0 0;display:flex;flex-direction:column;justify-content:flex-end;overflow:hidden}.mp-growth__bar-correct{background:var(--color-primary,#667eea)}.mp-growth__pct{font-size:12px;font-weight:700;color:var(--color-primary-700,#4c51bf);font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.mp-growth__week{font-size:11px;color:var(--color-text-light,#94a3b8);font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.mp-growth__affixes{display:flex;flex-direction:column;gap:8px;margin-bottom:14px}.mp-growth__affix-row{display:flex;align-items:center;gap:10px}.mp-growth__affix-row .mp-tile{font-size:14px;padding:4px 10px;min-width:64px}.mp-growth__affix-bar{flex:1 1;height:8px;border-radius:999px;background:var(--color-bg-tertiary,#f1f5f9);overflow:hidden}.mp-growth__affix-fill{height:100%;border-radius:999px;background:var(--color-primary,#667eea)}.mp-growth__affix-num{font-size:12px;color:var(--color-text-secondary,#475569);font-feature-settings:"tnum";font-variant-numeric:tabular-nums;min-width:44px;text-align:right}.mp-growth__cta{margin-top:4px}.pt{--pt-curve:var(--color-primary,#667eea);--pt-learner:#14b8a6;--pt-stress:var(--color-warning,#f59e0b);--pt-weak:var(--color-border,#e2e8f0);--pt-day1:#b9bdd8;max-width:520px}.pt-day-chip{font-size:12px;color:var(--color-text-muted);background:var(--color-surface,#fff);border:1px solid var(--color-border,#e2e8f0);border-radius:999px;padding:4px 12px;white-space:nowrap}.pt-stages{display:flex;gap:6px;margin:4px 0 14px}.pt-stage-pill{flex:1 1;text-align:center;font-size:11px;color:var(--color-text-muted);padding:7px 0;border-radius:10px;background:var(--color-surface,#fff);border:1.5px solid transparent;transition:all .3s}.pt-stage-pill__num{display:block;font-weight:700;font-size:13px;color:var(--pt-weak)}.pt-stage-pill.is-active{border-color:var(--pt-curve);color:var(--color-text-primary);font-weight:700}.pt-stage-pill.is-active .pt-stage-pill__num{color:var(--pt-curve)}.pt-stage-pill.is-done{background:var(--pt-curve);color:#fff}.pt-stage-pill.is-done .pt-stage-pill__num{color:#fff;opacity:.85}.pt-screen{display:flex;flex-direction:column;animation:pt-fadein .35s}@keyframes pt-fadein{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}@media (prefers-reduced-motion:reduce){.pt-screen{animation:none}.pt *,.pt :after,.pt :before{transition:none!important;animation-duration:.01s!important}}.pt-eyebrow{font-size:12px;font-weight:700;letter-spacing:2px;color:var(--pt-curve);margin-bottom:6px}.pt-title{font-size:24px;font-weight:800;line-height:1.3;margin:0 0 6px}.pt-sub{font-size:14px;color:var(--color-text-secondary);line-height:1.65;margin:0 0 18px}.pt-card{background:var(--color-surface,#fff);border:1px solid var(--color-border-light,#f1f5f9);border-radius:14px;box-shadow:0 4px 16px rgba(30,33,72,.06);padding:18px;margin-bottom:14px}.pt-btn{display:flex;align-items:center;justify-content:center;gap:7px;width:100%;border:none;border-radius:12px;background:var(--color-primary,#667eea);color:#fff;font-family:inherit;font-size:16px;font-weight:700;padding:14px;cursor:pointer;transition:transform .12s,filter .15s}.pt-btn:hover:not(:disabled){filter:brightness(1.05)}.pt-btn:active{transform:scale(.97)}.pt-btn:disabled{opacity:.4;cursor:default}.pt-btn--ghost{background:var(--color-surface,#fff);color:var(--color-primary,#667eea);border:1.5px solid var(--color-primary,#667eea)}.pt-btn--small{font-size:14px;padding:11px;border-radius:10px}.pt-btn--inline{display:inline-flex;width:auto;padding:10px 22px}.pt-btn--link{text-decoration:none}.pt-btn.is-recording{background:var(--color-error,#dc2626)}.pt-btn-row{display:flex;gap:10px;margin-top:12px}.pt-btn-row .pt-btn{flex:1 1}.pt-why{margin-top:16px;padding-top:14px;font-size:12px;color:var(--color-text-muted);line-height:1.6;border-top:1px dashed var(--pt-weak)}.pt-center{margin:8px 0}.pt-center,.pt-center-text{text-align:center}.pt-sentence{display:flex;flex-wrap:wrap;gap:6px 10px;justify-content:center;align-items:flex-end;margin:10px 0 4px}.pt-word{display:flex;flex-direction:column;align-items:center;gap:5px}.pt-word__dot{width:9px;height:9px;border-radius:50%;background:var(--pt-weak)}.pt-word.is-strong .pt-word__dot{width:16px;height:16px;background:var(--pt-stress)}.pt-word__w{font-size:17px;color:var(--color-text-secondary);transition:all .15s}.pt-word.is-strong .pt-word__w{font-weight:700;font-size:19px;color:var(--color-text-primary)}.pt-word.is-now .pt-word__w{color:var(--pt-curve);font-weight:700;transform:translateY(-3px)}.pt-translation{text-align:center;font-size:13px;color:var(--color-text-muted);margin:6px 0 2px}.pt-sent-line{text-align:center;font-size:14px;color:var(--color-text-secondary);margin:8px 0 0}.pt-ab-row{display:flex;gap:12px;margin:14px 0 4px}.pt-ab{flex:1 1;background:var(--color-surface,#fff);border:2px solid var(--pt-weak);border-radius:14px;padding:16px 10px;text-align:center;cursor:pointer;transition:all .2s;display:flex;flex-direction:column;align-items:center;gap:6px;font-family:inherit}.pt-ab__icon{color:var(--pt-curve)}.pt-ab__lbl{font-weight:700;font-size:16px;color:var(--color-text-primary)}.pt-ab.is-playing{border-color:var(--pt-curve);box-shadow:0 0 0 4px rgba(102,126,234,.15)}.pt-ab.is-right{border-color:var(--color-success,#16a34a);background:var(--color-success-light,#dcfce7)}.pt-ab.is-wrong{border-color:var(--color-error,#dc2626);background:var(--color-error-light,#fef2f2)}.pt-choice-words{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin:14px 0 10px}.pt-choice{font-family:inherit;font-size:16px;font-weight:600;border:2px solid var(--pt-weak);background:var(--color-surface,#fff);border-radius:10px;padding:10px 14px;cursor:pointer;transition:all .15s;color:var(--color-text-primary)}.pt-choice:disabled{cursor:default;opacity:.85}.pt-choice.is-sel{border-color:var(--pt-stress);background:#fff7e8;font-weight:700;transform:translateY(-3px)}.pt-choice.is-right{border-color:var(--color-success,#16a34a);background:var(--color-success-light,#dcfce7);font-weight:700}.pt-choice.is-wrong{border-color:var(--color-error,#dc2626);background:var(--color-error-light,#fef2f2)}.pt-feedback{min-height:24px;font-size:14px;line-height:1.6;text-align:center;margin:10px 0 0;font-weight:500;color:var(--color-text-secondary)}.pt-feedback.is-good{color:var(--color-success-text,#15803d)}.pt-feedback.is-bad{color:var(--color-error,#dc2626)}.pt-beat-row{display:flex;justify-content:center;align-items:center;gap:13px;margin:16px 0 8px;min-height:40px}.pt-beat{width:13px;height:13px;border-radius:50%;background:var(--pt-weak);transition:all .15s}.pt-beat.is-strong{width:30px;height:30px;background:var(--pt-stress)}.pt-beat.is-lit{transform:scale(1.45);box-shadow:0 0 0 6px rgba(245,158,11,.25)}.pt-beat.is-good{background:var(--color-success,#16a34a)!important}.pt-beat.is-ok{background:#e8b931!important}.pt-beat.is-miss{background:var(--color-error,#dc2626)!important}.pt-beat-words{display:flex;justify-content:center;gap:8px;font-size:11px;color:var(--color-text-muted);flex-wrap:wrap;margin-bottom:8px}.pt-beat-words .is-strong{font-weight:700;color:var(--color-text-primary)}.pt-tap-pad{margin:16px auto 4px;width:170px;height:170px;border-radius:50%;border:none;background:var(--color-primary,#667eea);color:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;font-family:inherit;font-weight:800;font-size:18px;cursor:pointer;-webkit-user-select:none;user-select:none;box-shadow:0 10px 30px rgba(102,126,234,.35);transition:transform .08s,opacity .2s;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.pt-tap-pad:active{transform:scale(.94)}.pt-tap-pad.is-idle{filter:grayscale(.6);opacity:.55}.pt-tap-pad small{font-weight:500;font-size:12px;opacity:.85;margin-top:4px}.pt-curve-box{padding:10px 6px 4px}.pt-legend{display:flex;gap:14px;justify-content:center;font-size:11px;color:var(--color-text-muted);padding-bottom:8px;flex-wrap:wrap}.pt-legend i{display:inline-block;width:18px;height:3px;border-radius:2px;vertical-align:middle;margin-right:5px}.pt-legend__dot{width:8px!important;height:8px!important;border-radius:50%!important;background:var(--pt-stress)}.pt-rec-dot{display:inline-block;width:10px;height:10px;border-radius:50%;background:var(--color-error,#dc2626);margin-right:6px;animation:pt-blink 1s infinite}@keyframes pt-blink{50%{opacity:.2}}.pt-privacy{font-size:11px;color:var(--color-text-light,#94a3b8);text-align:center;margin:6px 0 0}.pt-score-big{font-weight:700;font-size:34px;text-align:center;color:var(--pt-curve)}.pt-score-lbl{text-align:center;font-size:12px;color:var(--color-text-muted);margin-bottom:10px}.pt-tip-card{background:#fff7e8;border:1.5px solid var(--pt-stress);border-radius:12px;padding:13px 15px;font-size:14px;line-height:1.6}.pt-scenario{background:var(--color-text-primary,#1e293b);color:#fff;border-radius:14px;padding:16px 18px;margin-bottom:14px}.pt-scenario__tag{font-size:11px;letter-spacing:2px;color:var(--pt-stress);font-weight:700}.pt-scenario p{font-size:15px;line-height:1.7;margin:6px 0 0}.pt-compare-row{padding:0 8px 10px}.pt-delta-grid{display:flex;flex-direction:column;gap:13px}.pt-delta-item__top{display:flex;justify-content:space-between;font-size:13px;font-weight:700;margin-bottom:6px}.pt-delta-item__chip{color:var(--color-success-text,#15803d);font-weight:700}.pt-delta-item__chip.is-down{color:var(--color-error,#dc2626)}.pt-bar{display:block;height:9px;border-radius:6px;background:var(--color-border-light,#f1f5f9);overflow:hidden;position:relative}.pt-bar__was{background:var(--pt-weak)}.pt-bar__now,.pt-bar__was{position:absolute;height:100%;border-radius:6px}.pt-bar__now{background:var(--color-primary,#667eea);transition:width 1.2s cubic-bezier(.2,.8,.2,1)}.pt-day1note{font-size:12px;color:var(--color-text-muted);text-align:center;margin:12px 0 0;line-height:1.6}.rc-type-new{background:rgba(139,92,246,.14);color:#7c3aed}.knl-guide-page,.knl-hub{max-width:960px;margin:0 auto;padding:24px 16px 64px}.knl-hub__header{margin-bottom:24px}.knl-hub__title{font-size:1.5rem;font-weight:700;color:var(--color-text,#0f172a);margin:0 0 6px}.knl-hub__subtitle{color:var(--color-text-muted,#475569);margin:0;line-height:1.6}.knl-hub__section{margin-top:28px}.knl-hub__section-title{font-size:1.05rem;font-weight:700;color:var(--color-text,#0f172a);margin:0 0 12px}.knl-hub__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px}.kg-guide-card--memory{border-left:3px solid #0d9488}.kg-guide-card--memory svg{color:#0d9488}.kg-guide-card--syntax{border-left:3px solid #db2777}.kg-guide-card--syntax svg{color:#db2777}.kg-guides-entry{display:flex;align-items:center;gap:14px;padding:14px 16px;border-radius:12px;border:1px solid var(--color-border,#e2e8f0);background:var(--color-surface,#fff);text-decoration:none;transition:transform .15s,box-shadow .15s}.kg-guides-entry:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,.1)}.kg-guides-entry__icon{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:10px;background:rgba(102,126,234,.12);color:var(--color-primary,#667eea);flex-shrink:0}.kg-guides-entry__body{display:flex;flex-direction:column;gap:2px;flex:1 1;min-width:0}.kg-guides-entry__title{font-weight:700;color:var(--color-text,#0f172a)}.kg-guides-entry__desc{font-size:.85rem;color:var(--color-text-muted,#475569)}.kg-guides-entry__chevron{color:var(--color-text-muted,#94a3b8);flex-shrink:0}.rc-health__learn-more{display:inline-block;margin-top:12px;font-size:.85rem;font-weight:600;color:var(--color-primary,#667eea);text-decoration:none}.rc-health__learn-more:hover{text-decoration:underline}.sw-scope__backdrop{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:16px;background:rgba(15,23,42,.45)}.sw-scope{width:100%;max-width:440px;max-height:90vh;overflow-y:auto;background:var(--color-surface,#fff);border-radius:16px;box-shadow:0 20px 48px rgba(0,0,0,.24);padding:20px}.sw-scope__head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}.sw-scope__title{font-size:1.15rem;font-weight:700;color:var(--color-text,#0f172a);margin:0}.sw-scope__toggle-all{background:none;border:none;cursor:pointer;font-size:.85rem;font-weight:600;color:var(--color-primary,#667eea);padding:4px 6px}.sw-scope__toggle-all:hover{text-decoration:underline}.sw-scope__list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.sw-scope__row{display:flex;align-items:center;gap:12px;padding:12px;border:1px solid var(--color-border,#e2e8f0);border-radius:12px;cursor:pointer;transition:background .15s,border-color .15s}.sw-scope__row.is-checked{border-color:var(--color-primary,#667eea);background:rgba(102,126,234,.06)}.sw-scope__check{width:20px;height:20px;flex-shrink:0;accent-color:var(--color-primary,#667eea);cursor:pointer}.sw-scope__num{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:8px;font-weight:700;font-size:.85rem;flex-shrink:0}.sw-scope__row--1 .sw-scope__num{background:#dcfce7;color:#166534}.sw-scope__row--2 .sw-scope__num{background:#dbeafe;color:#1e40af}.sw-scope__row--3 .sw-scope__num{background:#fef3c7;color:#92400e}.sw-scope__row--4 .sw-scope__num{background:#ede9fe;color:#5b21b6}.sw-scope__row--5 .sw-scope__num{background:#fee2e2;color:#991b1b}.sw-scope__body{display:flex;flex-direction:column;gap:2px;min-width:0}.sw-scope__name{font-weight:600;color:var(--color-text,#0f172a)}.sw-scope__meta{font-size:.8125rem;color:var(--color-text-muted,#475569)}.sw-scope__actions{display:flex;justify-content:flex-end;gap:10px;margin-top:18px}.sw-scope__cancel{padding:10px 18px;border-radius:10px;border:1px solid var(--color-border,#e2e8f0);background:var(--color-surface,#fff);color:var(--color-text,#0f172a);font-weight:600;cursor:pointer}.sw-scope__start{padding:10px 22px;border-radius:10px;border:none;background:var(--color-primary,#667eea);color:#fff;font-weight:700;cursor:pointer}.sw-scope__start:disabled{opacity:.5;cursor:not-allowed}.sw-review__milestones{display:flex;flex-direction:column;gap:8px;margin:14px 0 4px}.sw-review__milestone{padding:10px 16px;border-radius:10px;background:var(--color-success-light,#dcfce7);color:var(--color-success-text,#166534);font-weight:700;font-size:.95rem}.nav-group-dropdown{position:relative;display:inline-flex;align-items:center}.nav-group-menu{position:absolute;top:calc(100% + 6px);left:0;background:var(--color-surface,#fff);border-radius:var(--radius-lg,12px);box-shadow:0 8px 30px rgba(0,0,0,.12);border:1px solid var(--color-border,#e2e8f0);min-width:180px;padding:4px;z-index:var(--z-dropdown,200);opacity:0;visibility:hidden;transform:translateY(-8px);transition:opacity .15s ease,transform .15s ease,visibility .15s}.nav-group-menu:before{content:"";position:absolute;top:-6px;left:0;right:0;height:6px}.nav-group-dropdown:focus-within .nav-group-menu,.nav-group-dropdown:hover .nav-group-menu{opacity:1;visibility:visible;transform:translateY(0)}.nav-group-dropdown:focus-within .nav-link--dropdown svg,.nav-group-dropdown:hover .nav-link--dropdown svg{transform:rotate(180deg)}.nav-group-menu__item{display:block;padding:8px 14px;color:var(--color-text-secondary,#475569);text-decoration:none;font-size:14px;font-weight:500;border-radius:var(--radius-md,8px);white-space:nowrap;transition:background .15s,color .15s}.nav-group-menu__item:hover{background:var(--color-bg-tertiary,#f3f4f6);color:var(--color-text-primary,#0f172a)}.nav-menu-section{padding:8px 14px 4px;font-size:11px;font-weight:700;letter-spacing:.03em;color:var(--color-text-muted,#94a3b8)}.nav-menu-section:first-child{padding-top:4px}.nav-menu-divider{height:1px;background:var(--color-border,#e2e8f0);margin:6px 8px}.scan-result__scaled-score{margin:0 0 2px;font-size:24px;font-weight:800;color:var(--color-primary,#667eea);letter-spacing:.5px}