@import "https://fonts.googleapis.com/css2?family=Outfit:wght@400;500;600;700;800&family=Noto+Sans+TC:wght@400;500;700&display=swap";:root{--font-sans:"Outfit", -apple-system, BlinkMacSystemFont, sans-serif;--font-hanzi:"Noto Sans TC", sans-serif;--color-bg-base:#faf8f2;--color-bg-card:#fff;--color-border-subtle:#efece3;--color-border:#e0dbd0;--color-blue-primary:#3a86c8;--color-blue-hover:#2e71ac;--color-blue-dark:#204a73;--color-blue-light:#eaf3fc;--color-blue-xlight:#f0f7ff;--color-text-title:#204a73;--color-text-body:#4a545e;--color-text-muted:#8a9099;--color-accent:#ff8f2b;--color-accent-hover:#e57a1b;--color-accent-light:#fff0e0;--color-accent-xlight:#fffaf4;--color-success:#2ec4b6;--color-success-light:#e8faf8;--color-error:#e71d36;--color-error-light:#fdeef0;--color-warning:#f9c846;--space-1:.25rem;--space-2:.5rem;--space-3:.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--space-16:4rem;--space-20:5rem;--radius-sm:6px;--radius-md:12px;--radius-lg:16px;--radius-xl:24px;--radius-full:9999px;--shadow-xs:0 1px 2px #0000000a;--shadow-sm:0 2px 8px #0000000f;--shadow-md:0 4px 16px #00000014;--shadow-lg:0 8px 32px #0000001a;--shadow-blue:0 4px 16px #3a86c840;--shadow-accent:0 4px 16px #ff8f2b4d;--transition-fast:all .15s ease;--transition-normal:all .25s ease;--transition-slow:all .4s ease}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:16px}body{font-family:var(--font-sans);background-color:var(--color-bg-base);color:var(--color-text-body);-webkit-font-smoothing:antialiased;line-height:1.6}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:var(--font-sans);border:none;outline:none}img{max-width:100%;display:block}h1,h2,h3,h4,h5,h6{color:var(--color-text-title);font-weight:700;line-height:1.25}.container{max-width:1200px;padding:0 var(--space-6);margin:0 auto}.card{background:var(--color-bg-card);border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:var(--transition-normal)}.card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.btn{align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);border-radius:var(--radius-full);transition:var(--transition-fast);cursor:pointer;font-size:.95rem;font-weight:600;font-family:var(--font-sans);white-space:nowrap;border:none;display:inline-flex}.btn-primary{background:var(--color-blue-primary);color:#fff;box-shadow:var(--shadow-blue)}.btn-primary:hover{background:var(--color-blue-hover);transform:translateY(-1px)}.btn-accent{background:var(--color-accent);color:#fff;box-shadow:var(--shadow-accent)}.btn-accent:hover{background:var(--color-accent-hover);transform:translateY(-1px)}.btn-outline{color:var(--color-blue-primary);border:2px solid var(--color-blue-primary);background:0 0}.btn-outline:hover{background:var(--color-blue-light)}.btn-ghost{color:var(--color-text-body);background:0 0}.btn-ghost:hover{background:var(--color-border-subtle)}.badge{border-radius:var(--radius-full);align-items:center;gap:4px;padding:4px 10px;font-size:.78rem;font-weight:600;display:inline-flex}.badge-blue{background:var(--color-blue-light);color:var(--color-blue-dark)}.badge-accent{background:var(--color-accent-light);color:var(--color-accent-hover)}.badge-success{background:var(--color-success-light);color:var(--color-success)}.progress-bar{background:var(--color-border-subtle);border-radius:var(--radius-full);width:100%;height:10px;overflow:hidden}.progress-fill{background:linear-gradient(90deg, var(--color-blue-primary), #58a8e8);border-radius:var(--radius-full);height:100%;transition:width .8s}.progress-fill-accent{background:linear-gradient(90deg, var(--color-accent), #ffb347)}.tag{border-radius:var(--radius-full);background:var(--color-blue-light);color:var(--color-blue-dark);padding:2px 10px;font-size:.75rem;font-weight:500;display:inline-block}.section{padding:var(--space-20) 0}.section-sm{padding:var(--space-12) 0}.text-title{color:var(--color-text-title)}.text-muted{color:var(--color-text-muted)}.text-accent{color:var(--color-accent)}.text-blue{color:var(--color-blue-primary)}.gradient-text{background:linear-gradient(135deg, var(--color-blue-dark), var(--color-blue-primary));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.hanzi{font-family:var(--font-hanzi);color:var(--color-text-title);font-size:2rem;line-height:1}.pinyin{color:var(--color-blue-primary);letter-spacing:.05em;font-size:.9rem;font-weight:500}.grid-2{gap:var(--space-6);grid-template-columns:repeat(2,1fr);display:grid}.grid-3{gap:var(--space-6);grid-template-columns:repeat(3,1fr);display:grid}.grid-4{gap:var(--space-6);grid-template-columns:repeat(4,1fr);display:grid}@media (width<=768px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}.container{padding:0 var(--space-4)}}@media (width<=1024px){.grid-4,.grid-3{grid-template-columns:repeat(2,1fr)}}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--color-bg-base)}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:999px}::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}.header{z-index:100;-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--color-border-subtle);box-shadow:var(--shadow-xs);background:#ffffffeb;position:sticky;top:0}.header-inner{align-items:center;gap:var(--space-6);height:64px;display:flex}.header-logo{align-items:center;gap:var(--space-2);flex-shrink:0;text-decoration:none;display:flex}.logo-icon{background:linear-gradient(135deg, var(--color-blue-primary), var(--color-blue-dark));color:#fff;border-radius:var(--radius-md);width:38px;height:38px;font-family:var(--font-hanzi);box-shadow:var(--shadow-blue);justify-content:center;align-items:center;font-size:1.3rem;font-weight:700;display:flex}.logo-text{flex-direction:row;align-items:baseline;line-height:1;display:flex}.logo-name{color:var(--color-text-title);font-size:1.15rem;font-weight:800}.logo-domain{color:var(--color-blue-primary);font-size:.9rem;font-weight:600}.header-nav{align-items:center;gap:var(--space-1);flex:1;display:flex}.nav-link{padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);color:var(--color-text-body);transition:var(--transition-fast);white-space:nowrap;align-items:center;gap:6px;font-size:.875rem;font-weight:500;text-decoration:none;display:flex}.nav-link:hover{background:var(--color-blue-light);color:var(--color-blue-primary)}.nav-link.active{background:var(--color-blue-light);color:var(--color-blue-primary);font-weight:600}.header-actions{align-items:center;gap:var(--space-2);margin-left:auto;display:flex}.stat-chip{border-radius:var(--radius-full);align-items:center;gap:5px;padding:6px 12px;font-size:.85rem;font-weight:700;display:flex}.streak-chip{background:var(--color-accent-light);color:var(--color-accent-hover)}.flame-icon{color:var(--color-accent)}.xp-chip{background:var(--color-blue-light);color:var(--color-blue-dark)}.avatar-btn{border-radius:var(--radius-full);background:var(--color-blue-light);width:36px;height:36px;color:var(--color-blue-primary);transition:var(--transition-fast);border:2px solid var(--color-border-subtle);justify-content:center;align-items:center;text-decoration:none;display:flex}.avatar-btn:hover{background:var(--color-blue-primary);color:#fff;border-color:var(--color-blue-primary)}.menu-toggle{border-radius:var(--radius-md);background:var(--color-bg-base);width:36px;height:36px;color:var(--color-text-body);border:1px solid var(--color-border-subtle);transition:var(--transition-fast);justify-content:center;align-items:center;display:flex}.menu-toggle:hover{background:var(--color-border-subtle)}.mobile-menu{border-top:1px solid var(--color-border-subtle);padding:var(--space-3);gap:var(--space-1);background:#fff;flex-direction:column;display:flex}.mobile-nav-link{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);color:var(--color-text-body);transition:var(--transition-fast);font-size:.95rem;font-weight:500;text-decoration:none;display:flex}.mobile-nav-link:hover,.mobile-nav-link.active{background:var(--color-blue-light);color:var(--color-blue-primary);font-weight:600}.desktop-only{display:flex}.mobile-only{display:none}@media (width<=768px){.desktop-only{display:none!important}.mobile-only{display:flex!important}.stat-chip span{display:none}}.home-page{background:var(--color-bg-base)}.hero-section{padding:var(--space-20) 0 var(--space-16);background:linear-gradient(160deg, #f0f7ff 0%, var(--color-bg-base) 60%);border-bottom:1px solid var(--color-border-subtle)}.hero-section .container{gap:var(--space-12);grid-template-columns:1fr 1fr;align-items:center;display:grid}.hero-badge{background:var(--color-blue-light);color:var(--color-blue-dark);border:1px solid var(--color-blue-primary);border-radius:var(--radius-full);margin-bottom:var(--space-5);align-items:center;gap:6px;padding:6px 14px;font-size:.8rem;font-weight:600;display:inline-flex}.hero-title{color:var(--color-text-title);margin-bottom:var(--space-5);font-size:3rem;font-weight:800;line-height:1.15}.accent-text{color:var(--color-accent)}.blue-text{color:var(--color-blue-primary)}.hero-subtitle{color:var(--color-text-body);margin-bottom:var(--space-8);max-width:480px;font-size:1.1rem;line-height:1.7}.hero-cta{gap:var(--space-3);margin-bottom:var(--space-6);flex-wrap:wrap;display:flex}.hero-btn-main{padding:var(--space-4) var(--space-8);font-size:1.05rem}.hero-checklist{gap:var(--space-2);flex-direction:column;display:flex}.hero-check-item{align-items:center;gap:var(--space-2);color:var(--color-text-body);font-size:.9rem;display:flex}.hero-check-item svg{color:var(--color-success);flex-shrink:0}.hero-visual{justify-content:center;display:flex}.dashboard-preview{width:100%;max-width:340px;padding:var(--space-6);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);border:1px solid var(--color-border-subtle);background:#fff}.preview-header{margin-bottom:var(--space-4);justify-content:space-between;align-items:center;display:flex}.preview-day{color:var(--color-text-title);font-size:.85rem;font-weight:600}.preview-streak{background:var(--color-accent-light);color:var(--color-accent-hover);border-radius:var(--radius-full);padding:4px 10px;font-size:.8rem;font-weight:700}.preview-progress{margin-bottom:var(--space-4)}.preview-label{color:var(--color-text-body);justify-content:space-between;margin-bottom:6px;font-size:.8rem;font-weight:600;display:flex}.preview-pct{color:var(--color-blue-primary)}.preview-tasks{gap:var(--space-2);margin-bottom:var(--space-4);flex-direction:column;display:flex}.preview-task{border-radius:var(--radius-md);padding:8px 12px;font-size:.83rem;font-weight:500}.preview-task.done{background:var(--color-success-light);color:var(--color-success)}.preview-task.pending{background:var(--color-bg-base);color:var(--color-text-muted);border:1px solid var(--color-border-subtle)}.preview-xp{text-align:center}.preview-xp-label{background:var(--color-blue-light);color:var(--color-blue-dark);border-radius:var(--radius-md);padding:8px;font-size:.85rem;font-weight:700}.stats-section{padding:var(--space-10) 0;border-bottom:1px solid var(--color-border-subtle);background:#fff}.stats-grid{gap:var(--space-4);grid-template-columns:repeat(4,1fr);display:grid}.stat-card{text-align:center;padding:var(--space-6);border-radius:var(--radius-lg)}.stat-icon{color:var(--color-blue-primary);margin-bottom:var(--space-3);justify-content:center;display:flex}.stat-value{color:var(--color-text-title);margin-bottom:4px;font-size:1.6rem;font-weight:800}.stat-label{color:var(--color-text-muted);font-size:.85rem;font-weight:500}.section-header{text-align:center;margin-bottom:var(--space-12)}.section-tag{background:var(--color-accent-light);color:var(--color-accent-hover);border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-3);padding:4px 14px;font-size:.8rem;font-weight:700;display:inline-block}.section-header h2{margin-bottom:var(--space-3);font-size:2rem}.section-header p{color:var(--color-text-body);max-width:540px;margin:0 auto;font-size:1rem}.journey-section{background:var(--color-bg-base)}.stages-timeline{flex-direction:column;gap:0;display:flex}.stage-item{gap:var(--space-4);grid-template-columns:48px 1fr;display:grid;position:relative}.stage-num{border-radius:var(--radius-full);background:var(--stage-color,var(--color-blue-primary));color:#fff;z-index:1;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:1.2rem;font-weight:800;display:flex;box-shadow:0 4px 12px #00000026}.stage-body{padding:var(--space-5);margin-bottom:var(--space-3)}.stage-months{background:var(--color-blue-light);color:var(--color-blue-dark);border-radius:var(--radius-full);margin-bottom:var(--space-2);padding:3px 10px;font-size:.78rem;font-weight:600;display:inline-block}.stage-name{margin-bottom:var(--space-2);font-size:1.15rem}.stage-book{color:var(--color-blue-primary);margin-bottom:var(--space-2);font-size:.85rem;font-weight:500}.stage-desc{color:var(--color-text-body);margin-bottom:var(--space-3);font-size:.9rem}.stage-goals{flex-direction:column;gap:6px;display:flex}.stage-goal{color:var(--color-success);align-items:center;gap:8px;font-size:.85rem;display:flex}.stage-connector{background:var(--color-border);z-index:0;width:2px;height:calc(100% - 24px);position:absolute;top:48px;left:24px}.journey-cta{text-align:center;margin-top:var(--space-8)}.features-section{background:#fff}.feature-card{padding:var(--space-6)}.feature-icon{margin-bottom:var(--space-3);font-size:2rem}.feature-card h3{margin-bottom:var(--space-2);font-size:1.1rem}.feature-card p{color:var(--color-text-body);font-size:.9rem;line-height:1.6}.testimonials-section{background:var(--color-bg-base)}.testimonial-card{padding:var(--space-6);gap:var(--space-4);flex-direction:column;display:flex}.testimonial-text{color:var(--color-text-body);flex:1;font-size:.92rem;font-style:italic;line-height:1.7}.testimonial-footer{padding-top:var(--space-3);border-top:1px solid var(--color-border-subtle);justify-content:space-between;align-items:flex-end;display:flex}.testimonial-name{color:var(--color-text-title);font-size:.9rem;font-weight:700}.testimonial-school{color:var(--color-text-muted);font-size:.78rem}.testimonial-streak{background:var(--color-accent-light);color:var(--color-accent-hover);border-radius:var(--radius-full);padding:4px 10px;font-size:.8rem;font-weight:700}.cta-section{background:linear-gradient(135deg, var(--color-blue-dark), var(--color-blue-primary))}.cta-box{text-align:center;color:#fff;padding:var(--space-12) var(--space-6)}.cta-hanzi{font-family:var(--font-hanzi);margin-bottom:var(--space-4);opacity:.8;font-size:4rem}.cta-box h2{color:#fff;margin-bottom:var(--space-3);font-size:2rem}.cta-box p{opacity:.85;margin-bottom:var(--space-8);font-size:1.05rem}.cta-btn{padding:var(--space-4) var(--space-10);margin-bottom:var(--space-6);font-size:1.1rem}.cta-tagline{justify-content:center;align-items:center;gap:var(--space-2);opacity:.75;font-size:.9rem;display:flex}@media (width<=768px){.hero-section .container{gap:var(--space-8);grid-template-columns:1fr}.hero-title{font-size:2rem}.hero-visual{order:-1}.stats-grid{grid-template-columns:repeat(2,1fr)}.features-grid.grid-2{grid-template-columns:1fr}}.about-page{padding:var(--space-8) 0 var(--space-16);background:var(--color-bg-base)}.about-page .container{gap:var(--space-6);flex-direction:column;max-width:780px;display:flex}.about-hero{padding:var(--space-10);text-align:center;background:linear-gradient(135deg, var(--color-blue-xlight), white)}.about-hanzi{font-family:var(--font-hanzi);color:var(--color-blue-primary);margin-bottom:var(--space-4);font-size:3rem}.about-hero h1{margin-bottom:var(--space-3);font-size:1.8rem}.about-lead{color:var(--color-text-body);font-size:1rem;line-height:1.7}.about-story,.about-philosophy{padding:var(--space-6) var(--space-8)}.about-story h2,.about-philosophy h2,.about-values h2{margin-bottom:var(--space-4);font-size:1.2rem}.about-story p{color:var(--color-text-body);margin-bottom:var(--space-3);font-size:.95rem;line-height:1.8}.philosophy-quotes{gap:var(--space-4);flex-direction:column;display:flex}blockquote{border-left:4px solid var(--color-accent);padding:var(--space-3) var(--space-5);color:var(--color-text-title);background:var(--color-accent-xlight);border-radius:0 var(--radius-md) var(--radius-md) 0;margin:0;font-size:1.1rem;font-style:italic}.values-grid{gap:var(--space-4);grid-template-columns:repeat(2,1fr);display:grid}.value-card{padding:var(--space-5)}.value-icon{margin-bottom:var(--space-3);font-size:2rem}.value-card h3{margin-bottom:var(--space-2);font-size:1rem}.value-card p{color:var(--color-text-muted);font-size:.85rem;line-height:1.6}.about-cta{padding:var(--space-10);text-align:center;align-items:center;gap:var(--space-4);flex-direction:column;display:flex}.about-cta h2{font-size:1.4rem}.roadmap-page{padding:var(--space-10) 0 var(--space-16);background:var(--color-bg-base)}.roadmap-header{text-align:center;margin-bottom:var(--space-10)}.roadmap-header h1{margin:var(--space-3) 0;font-size:2rem}.roadmap-header p{color:var(--color-text-muted);max-width:560px;margin:0 auto}.overview-bar{padding:var(--space-5) var(--space-6);margin-bottom:var(--space-8)}.overview-label{color:var(--color-text-muted);margin-bottom:var(--space-3);font-size:.85rem;font-weight:600}.overview-track{border-radius:var(--radius-full);gap:3px;height:28px;display:flex;overflow:hidden}.overview-seg{color:#fff;border-radius:4px;justify-content:center;align-items:center;font-size:.72rem;font-weight:700;display:flex}.overview-labels{margin-top:var(--space-2);display:flex}.overview-seg-label{color:var(--color-text-muted);text-align:center;font-size:.7rem;font-weight:500}.stages-accordion{gap:var(--space-3);margin-bottom:var(--space-8);flex-direction:column;display:flex}.stage-accordion-item{transition:var(--transition-normal);overflow:hidden}.stage-accordion-header{width:100%;padding:var(--space-5) var(--space-6);cursor:pointer;font-family:var(--font-sans);text-align:left;justify-content:space-between;align-items:center;gap:var(--space-4);background:0 0;border:none;display:flex}.stage-accordion-header:hover{background:var(--color-bg-base)}.stage-acc-left{align-items:center;gap:var(--space-4);display:flex}.stage-acc-num{border-radius:var(--radius-full);color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:1.3rem;font-weight:800;display:flex}.stage-acc-name{color:var(--color-text-title);font-size:1.05rem;font-weight:700}.stage-acc-months{color:var(--color-text-muted);margin-top:2px;font-size:.8rem}.stage-acc-right{align-items:center;gap:var(--space-3);color:var(--color-text-muted);display:flex}.stage-accordion-body{padding:0 var(--space-6) var(--space-6);border-top:1px solid var(--color-border-subtle)}.stage-detail-grid{gap:var(--space-6);padding-top:var(--space-5);grid-template-columns:1fr 1fr;display:grid}.stage-detail-grid h4{color:var(--color-blue-dark);margin-bottom:var(--space-3);align-items:center;gap:6px;font-size:.9rem;display:flex}.stage-detail-grid p{color:var(--color-text-body);font-size:.88rem;line-height:1.6}.stage-goal-list{gap:var(--space-2);flex-direction:column;list-style:none;display:flex}.stage-goal-list li{color:var(--color-text-body);align-items:flex-start;gap:8px;font-size:.85rem;display:flex}.stage-goal-list li svg{color:var(--color-success);flex-shrink:0;margin-top:2px}.grammar-tags{gap:var(--space-2);flex-wrap:wrap;display:flex}.textbook-box{background:var(--color-blue-xlight);border:1px solid var(--color-blue-light);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4)}.textbook-name{color:var(--color-blue-dark);margin-bottom:var(--space-2);font-size:.88rem;font-weight:700}.textbook-note{color:var(--color-text-muted);font-size:.78rem;line-height:1.5}.roadmap-target{text-align:center;padding:var(--space-10) var(--space-8)}.target-icon{margin-bottom:var(--space-4);font-size:3.5rem}.roadmap-target h2{margin-bottom:var(--space-3);font-size:1.6rem}.roadmap-target>p{color:var(--color-text-body);max-width:580px;margin:0 auto var(--space-8);font-size:.95rem;line-height:1.7}.target-skills{gap:var(--space-4);grid-template-columns:repeat(4,1fr);display:grid}.target-skill{align-items:flex-start;gap:var(--space-3);background:var(--color-bg-base);padding:var(--space-4);border-radius:var(--radius-md);text-align:left;display:flex}.target-skill-icon{font-size:1.5rem}.target-skill strong{color:var(--color-text-title);margin-bottom:2px;font-size:.9rem;display:block}@media (width<=768px){.stage-detail-grid{grid-template-columns:1fr}.target-skills{grid-template-columns:repeat(2,1fr)}.overview-seg span{display:none}}.dashboard-page{padding:var(--space-8) 0 var(--space-16);background:var(--color-bg-base);min-height:calc(100vh - 64px)}.dash-greeting{margin-bottom:var(--space-8);justify-content:space-between;align-items:flex-start;display:flex}.dash-greeting h1{margin-bottom:var(--space-1);font-size:1.8rem}.dash-subtitle{color:var(--color-text-muted);font-size:.9rem}.dash-date{color:var(--color-text-muted);border-radius:var(--radius-full);border:1px solid var(--color-border-subtle);background:#fff;padding:8px 16px;font-size:.85rem;font-weight:500}.dash-stats{gap:var(--space-4);margin-bottom:var(--space-8);grid-template-columns:repeat(4,1fr);display:grid}.dash-stat-card{padding:var(--space-5);text-align:center;transition:var(--transition-normal)}.dash-stat-value{color:var(--color-text-title);margin:var(--space-2) 0 4px;font-size:1.8rem;font-weight:800}.dash-stat-label{color:var(--color-text-muted);font-size:.78rem;font-weight:500}.stat-icon-streak{color:var(--color-accent)}.stat-icon-xp{color:var(--color-blue-primary)}.stat-icon-progress{color:var(--color-success)}.stat-icon-forecast{color:#8b5cf6}.dash-main-grid{gap:var(--space-6);grid-template-columns:1fr 380px;align-items:start;display:grid}.dash-col-left,.dash-col-right{gap:var(--space-5);flex-direction:column;display:flex}.dash-checklist-card{padding:var(--space-6)}.card-header{margin-bottom:var(--space-5);justify-content:space-between;align-items:flex-start;display:flex}.card-header h2{font-size:1.2rem}.dash-task-count{color:var(--color-text-muted);margin-top:2px;font-size:.83rem}.dash-progress-ring{flex-shrink:0;width:56px;height:56px}.dash-progress-ring svg{width:100%;height:100%}.today-tasks{gap:var(--space-3);flex-direction:column;display:flex}.today-task{padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);border:1.5px solid var(--color-border-subtle);background:var(--color-bg-base);transition:var(--transition-fast);justify-content:space-between;align-items:center;display:flex}.today-task.done{background:var(--color-success-light);border-color:var(--color-success);opacity:.8}.task-left{align-items:center;gap:var(--space-3);display:flex}.task-icon{text-align:center;width:36px;font-size:1.3rem}.task-name{color:var(--color-text-title);font-size:.9rem;font-weight:600}.task-sub{color:var(--color-text-muted);font-size:.75rem}.task-right{align-items:center;gap:var(--space-3);display:flex}.task-xp{background:var(--color-blue-light);color:var(--color-blue-dark);border-radius:var(--radius-full);padding:2px 8px;font-size:.75rem;font-weight:600}.task-check.done{color:var(--color-success)}.task-check-empty{border-radius:var(--radius-full);border:2px solid var(--color-border);width:22px;height:22px}.dash-activity-card{padding:var(--space-5)}.dash-activity-card h3{margin-bottom:var(--space-4);font-size:1rem}.activity-bars{gap:var(--space-2);align-items:flex-end;height:80px;display:flex}.activity-col{flex-direction:column;flex:1;align-items:center;gap:6px;display:flex}.activity-bar-wrap{background:var(--color-border-subtle);border-radius:var(--radius-sm);flex-direction:column;flex:1;justify-content:flex-end;width:100%;display:flex;overflow:hidden}.activity-bar{background:linear-gradient(180deg, var(--color-blue-primary), var(--color-blue-dark));border-radius:var(--radius-sm);transition:height .8s}.activity-day{color:var(--color-text-muted);font-size:.7rem;font-weight:600}.dash-forecast-card{padding:var(--space-5)}.dash-forecast-card h3{margin-bottom:var(--space-3);font-size:1rem}.forecast-bar-wrap{align-items:center;gap:var(--space-3);margin-bottom:var(--space-3);display:flex}.forecast-bar{flex:1;height:12px}.forecast-pct{color:var(--color-accent);min-width:40px;font-size:1rem;font-weight:800}.forecast-details{gap:var(--space-2);flex-direction:column;display:flex}.forecast-detail{color:var(--color-text-body);align-items:center;gap:8px;font-size:.82rem;display:flex}.forecast-detail svg{color:var(--color-text-muted);flex-shrink:0}.dash-timeline-card{padding:var(--space-5)}.dash-timeline-card h3{margin-bottom:var(--space-4);font-size:1rem}.timeline-stages{gap:var(--space-3);flex-direction:column;display:flex}.timeline-stage{align-items:center;gap:var(--space-3);padding:var(--space-2);border-radius:var(--radius-md);transition:var(--transition-fast);display:flex}.timeline-stage.current{background:var(--color-blue-xlight)}.timeline-dot{border-radius:var(--radius-full);flex-shrink:0;width:12px;height:12px}.timeline-info{flex:1}.timeline-name{color:var(--color-text-title);font-size:.83rem;font-weight:600}.timeline-months{color:var(--color-text-muted);font-size:.72rem}.timeline-check{color:var(--color-success)}.timeline-badge{background:var(--color-blue-light);color:var(--color-blue-primary);border-radius:var(--radius-full);padding:2px 8px;font-size:.7rem;font-weight:700}.dash-quick-card{padding:var(--space-5)}.dash-quick-card h3{margin-bottom:var(--space-3);font-size:1rem}.quick-links{gap:var(--space-2);flex-direction:column;display:flex}.quick-link{align-items:center;gap:var(--space-3);padding:var(--space-3);border-radius:var(--radius-md);color:var(--color-text-body);transition:var(--transition-fast);border:1px solid #0000;font-size:.88rem;font-weight:500;text-decoration:none;display:flex}.quick-link:hover{background:var(--color-blue-light);color:var(--color-blue-primary);border-color:var(--color-blue-light)}.quick-link-icon{font-size:1.2rem}.quick-link svg{color:var(--color-text-muted);margin-left:auto}.w-full{width:100%}@media (width<=1024px){.dash-main-grid{grid-template-columns:1fr}}@media (width<=768px){.dash-stats{grid-template-columns:repeat(2,1fr)}.dash-greeting{gap:var(--space-3);flex-direction:column}}.today-page{padding:var(--space-8) 0 var(--space-16);background:var(--color-bg-base);min-height:calc(100vh - 64px)}.today-header{margin-bottom:var(--space-6);justify-content:space-between;align-items:center;display:flex}.today-header h1{font-size:1.8rem}.today-progress{align-items:center;gap:var(--space-3);color:var(--color-text-muted);font-size:.85rem;font-weight:600;display:flex}.today-nav{gap:var(--space-2);margin-bottom:var(--space-8);padding-bottom:4px;display:flex;overflow-x:auto}.today-nav-item{padding:var(--space-2) var(--space-4);border-radius:var(--radius-full);color:var(--color-text-body);border:1.5px solid var(--color-border-subtle);cursor:pointer;transition:var(--transition-fast);white-space:nowrap;background:#fff;align-items:center;gap:6px;font-size:.85rem;font-weight:600;display:flex}.today-nav-item.active{background:var(--color-blue-primary);color:#fff;border-color:var(--color-blue-primary)}.today-nav-item.done{background:var(--color-success-light);color:var(--color-success);border-color:var(--color-success)}.today-content{max-width:680px;margin:0 auto}.section-content{gap:var(--space-6);flex-direction:column;display:flex}.section-intro h2{margin-bottom:var(--space-2);font-size:1.4rem}.section-intro p{color:var(--color-text-muted);font-size:.9rem}.vocab-counter{text-align:center;color:var(--color-text-muted);font-size:.85rem;font-weight:600}.vocab-card-flip{perspective:1000px;cursor:pointer;height:240px}.vocab-card-front,.vocab-card-back{backface-visibility:hidden;border-radius:var(--radius-xl);width:100%;height:240px;padding:var(--space-8);box-shadow:var(--shadow-md);flex-direction:column;justify-content:center;align-items:center;transition:transform .6s;display:flex;position:absolute}.vocab-card-front{background:linear-gradient(135deg, white, var(--color-blue-xlight));border:2px solid var(--color-border-subtle);transform:rotateY(0)}.vocab-card-flip.flipped .vocab-card-front{transform:rotateY(-180deg)}.vocab-card-back{background:linear-gradient(135deg, var(--color-blue-light), white);border:2px solid var(--color-blue-primary);transform:rotateY(180deg)}.vocab-card-flip.flipped .vocab-card-back{transform:rotateY(0)}.vocab-hint{margin-top:var(--space-4);color:var(--color-text-muted);font-size:.75rem}.vocab-meaning{color:var(--color-blue-dark);text-align:center;font-size:2rem;font-weight:800}.vocab-actions{justify-content:space-between;align-items:center;gap:var(--space-3);flex-wrap:wrap;display:flex}.vocab-nav{gap:var(--space-2);display:flex}.vocab-list-mini{gap:var(--space-2);grid-template-columns:repeat(5,1fr);display:grid}.vocab-mini-item{text-align:center;padding:var(--space-2) var(--space-1);border-radius:var(--radius-md);border:1px solid var(--color-border-subtle);cursor:pointer;transition:var(--transition-fast);background:#fff;font-size:.75rem}.vocab-mini-item.active{background:var(--color-blue-light);border-color:var(--color-blue-primary)}.vocab-mini-item.done{background:var(--color-success-light);border-color:var(--color-success);opacity:.7}.listening-card,.reading-card,.writing-card{padding:var(--space-6)}.listening-title,.reading-title{color:var(--color-text-title);margin-bottom:var(--space-4);padding-bottom:var(--space-3);border-bottom:1px solid var(--color-border-subtle);font-size:1rem;font-weight:700}.listening-player{align-items:center;gap:var(--space-3);background:var(--color-bg-base);padding:var(--space-4);border-radius:var(--radius-lg);margin-bottom:var(--space-4);display:flex}.player-icon{font-size:2rem}.player-info{flex:1}.player-title{color:var(--color-text-title);font-size:.88rem;font-weight:600}.player-duration{color:var(--color-text-muted);font-size:.75rem}.listening-transcript{background:var(--color-accent-xlight);border:1px solid var(--color-accent-light);border-radius:var(--radius-md);padding:var(--space-4);margin-bottom:var(--space-4);font-size:.88rem}.transcript-text{margin-top:var(--space-2);line-height:2}.listening-question{color:var(--color-text-title);font-size:.9rem;font-weight:600}.listening-answers{gap:var(--space-2);margin-top:var(--space-3);flex-direction:column;display:flex}.reading-text{background:var(--color-bg-base);padding:var(--space-5);border-radius:var(--radius-md);margin-bottom:var(--space-4);line-height:2}.reading-question{color:var(--color-text-title);font-size:.9rem;font-weight:600}.writing-prompt{background:var(--color-blue-xlight);border:1px solid var(--color-blue-light);border-radius:var(--radius-md);padding:var(--space-4);color:var(--color-text-body);font-size:.9rem}.writing-example{color:var(--color-text-body);font-size:.88rem}.writing-textarea{border:2px solid var(--color-border-subtle);border-radius:var(--radius-md);width:100%;padding:var(--space-4);font-family:var(--font-sans);color:var(--color-text-title);resize:vertical;transition:var(--transition-fast);background:#fff;outline:none;font-size:.95rem}.writing-textarea:focus{border-color:var(--color-blue-primary);box-shadow:0 0 0 3px var(--color-blue-light)}.quiz-progress{align-items:center;gap:var(--space-3);color:var(--color-text-muted);font-size:.85rem;font-weight:600;display:flex}.quiz-option{align-items:center;gap:var(--space-3);padding:var(--space-4);border-radius:var(--radius-md);border:2px solid var(--color-border-subtle);text-align:left;font-size:.95rem;font-family:var(--font-sans);color:var(--color-text-body);cursor:pointer;transition:var(--transition-fast);background:#fff;display:flex}.done-section{text-align:center;padding:var(--space-12) 0;align-items:center}.done-fireworks{font-size:5rem;animation:1s infinite bounce}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-16px)}}.done-section h2{color:var(--color-text-title);margin-bottom:var(--space-8);font-size:1.6rem}.done-stats{gap:var(--space-8);margin-bottom:var(--space-8);justify-content:center;display:flex}.done-stat{align-items:center;gap:var(--space-2);flex-direction:column;display:flex}.done-stat-value{color:var(--color-text-title);font-size:2rem;font-weight:800}.done-stat-label{color:var(--color-text-muted);font-size:.8rem;font-weight:600}.done-quote{color:var(--color-text-muted);max-width:480px;font-size:.95rem;font-style:italic;line-height:1.7}@media (width<=768px){.vocab-list-mini{grid-template-columns:repeat(4,1fr)}.today-header{gap:var(--space-3);flex-direction:column}}.speaking-card{padding:var(--space-8);align-items:center;gap:var(--space-6);text-align:center;flex-direction:column;display:flex}.speaking-prompt-box{background:var(--color-blue-xlight);border:1px solid var(--color-blue-light);border-radius:var(--radius-xl);padding:var(--space-6) var(--space-8);width:100%}.speaking-hanzi{font-family:var(--font-hanzi);color:var(--color-text-title);margin-bottom:var(--space-2);font-size:2.8rem;font-weight:700}.speaking-pinyin{color:var(--color-blue-primary);margin-bottom:var(--space-1);font-size:1.2rem;font-weight:600}.speaking-meaning{color:var(--color-text-muted);font-size:.95rem}.speaking-actions{gap:var(--space-4);justify-content:center;align-items:center;width:100%;display:flex}.mic-btn{align-items:center;gap:var(--space-2);padding:10px 24px;display:flex}.speech-result-box{background:var(--color-bg-base);border-radius:var(--radius-lg);padding:var(--space-4);border:1px solid var(--color-border-subtle);width:100%;animation:.3s slideDown}.speech-text{color:var(--color-text-title);margin:var(--space-2) 0;font-size:1.2rem;font-weight:700;font-family:var(--font-hanzi)}.speech-score{margin-top:var(--space-2);justify-content:center;font-size:.9rem;font-weight:600;display:flex}.badge-match{color:var(--color-success);background:var(--color-success-light);border-radius:var(--radius-full);align-items:center;gap:6px;padding:4px 12px;display:flex}.badge-mismatch{color:var(--color-error);background:var(--color-error-light);border-radius:var(--radius-full);align-items:center;gap:6px;padding:4px 12px;display:flex}.speaking-nav{width:100%;margin-top:var(--space-4);border-top:1px solid var(--color-border-subtle);padding-top:var(--space-4);justify-content:space-between;display:flex}.writing-prompt-box{background:var(--color-bg-base);border-radius:var(--radius-lg);padding:var(--space-5);margin-bottom:var(--space-4);border-left:4px solid var(--color-accent)}.prompt-title{text-transform:uppercase;color:var(--color-accent);letter-spacing:.5px;margin-bottom:var(--space-1);font-size:.75rem;font-weight:700}.prompt-text{color:var(--color-text-title);margin-bottom:var(--space-1);font-size:1.15rem;font-weight:700}.prompt-hint{color:var(--color-text-muted);font-size:.85rem}.writing-input-area{gap:var(--space-3);margin-top:var(--space-5);display:flex}.writing-input{border:2px solid var(--color-border-subtle);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);font-size:1.1rem;font-family:var(--font-sans);color:var(--color-text-title);transition:all var(--transition-fast);background:#fff;outline:none;flex:1}.writing-input:focus{border-color:var(--color-blue-primary);box-shadow:0 0 0 3px var(--color-blue-light)}.writing-input:disabled{background:var(--color-bg-base);cursor:not-allowed}.check-btn{padding:0 var(--space-6);font-weight:600}.writing-feedback{margin-top:var(--space-4);padding:var(--space-4);border-radius:var(--radius-md);animation:.3s slideDown}.writing-feedback.success{background:var(--color-success-light);border:1px solid var(--color-success)}.writing-feedback.error{background:var(--color-error-light);border:1px solid var(--color-error)}.feedback-status{align-items:center;gap:8px;font-weight:700;display:flex}.reading-toggles{gap:var(--space-2);margin-bottom:var(--space-4);justify-content:flex-end;display:flex}.reading-text-box{border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg);padding:var(--space-6);margin-bottom:var(--space-6);background:#fff;box-shadow:0 2px 10px #00000005}.dialogue-flow{gap:var(--space-4);flex-direction:column;display:flex}.dialogue-line{align-items:flex-start;gap:var(--space-3);display:flex}.dialogue-line .speaker{color:var(--color-blue-primary);text-align:right;flex-shrink:0;width:75px;padding-top:6px;font-size:.9rem;font-weight:700}.dialogue-line .bubble{background:var(--color-bg-base);border-radius:var(--radius-lg);padding:10px var(--space-4);border:1px solid var(--color-border-subtle);flex:1}.animate-fade-in{animation:.4s ease-in-out fadeIn}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.text-success{color:var(--color-success)!important}.text-danger{color:var(--color-error)!important}.lesson-badge-header{letter-spacing:.8px;background:var(--color-accent-light);color:var(--color-accent-dark);border-radius:var(--radius-full);margin-bottom:4px;padding:2px 8px;font-size:.65rem;font-weight:800;display:inline-block}.lessons-page{padding:var(--space-8) 0 var(--space-16);background:var(--color-bg-base)}.lessons-header{margin-bottom:var(--space-6)}.lessons-header h1{margin-bottom:6px;font-size:1.8rem}.lessons-header p{color:var(--color-text-muted);font-size:.9rem}.lessons-search{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-5);margin-bottom:var(--space-6);display:flex}.lessons-search svg{color:var(--color-text-muted);flex-shrink:0}.lessons-search input{font-family:var(--font-sans);color:var(--color-text-title);background:0 0;border:none;outline:none;flex:1;font-size:.95rem}.search-results{margin-bottom:var(--space-8)}.search-results h3{margin-bottom:var(--space-4);font-size:1rem}.vocab-search-grid{gap:var(--space-3);grid-template-columns:repeat(5,1fr);display:grid}.vocab-result-card{padding:var(--space-4);text-align:center;align-items:center;gap:var(--space-1);flex-direction:column;display:flex}.lessons-filter{margin-bottom:var(--space-6)}.filter-tabs{gap:var(--space-2);margin-bottom:var(--space-4);display:flex}.tab-btn{padding:var(--space-2) var(--space-5);border-radius:var(--radius-full);color:var(--color-text-body);border:1.5px solid var(--color-border-subtle);cursor:pointer;transition:var(--transition-fast);font-size:.9rem;font-weight:600;font-family:var(--font-sans);background:#fff}.tab-btn.active{background:var(--color-blue-primary);color:#fff;border-color:var(--color-blue-primary)}.month-selector,.topic-selector{gap:var(--space-2);flex-wrap:wrap;display:flex}.month-btn,.topic-btn{border-radius:var(--radius-full);border:1.5px solid var(--color-border-subtle);cursor:pointer;transition:var(--transition-fast);font-size:.82rem;font-weight:600;font-family:var(--font-sans);color:var(--color-text-body);background:#fff;padding:6px 14px}.month-btn.active,.topic-btn.active{background:var(--color-blue-light);color:var(--color-blue-primary);border-color:var(--color-blue-primary)}.lessons-grid{gap:var(--space-4);grid-template-columns:repeat(3,1fr);display:grid}.lesson-card{padding:var(--space-5);gap:var(--space-3);flex-direction:column;display:flex}.lesson-card.done{opacity:.85}.lesson-card-top{justify-content:space-between;align-items:center;display:flex}.lesson-stage-badge{border-radius:var(--radius-full);padding:3px 10px;font-size:.72rem;font-weight:700}.lesson-title{font-size:.95rem;line-height:1.4}.lesson-meta{gap:var(--space-3);color:var(--color-text-muted);flex-wrap:wrap;font-size:.75rem;display:flex}.lesson-btn{width:100%;padding:var(--space-2) var(--space-4);justify-content:center;font-size:.85rem}@media (width<=1024px){.lessons-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=768px){.lessons-grid,.vocab-search-grid{grid-template-columns:1fr}.vocab-search-grid{grid-template-columns:repeat(2,1fr)}}.assessment-page{padding:var(--space-8) 0 var(--space-16);background:var(--color-bg-base)}.assessment-header{margin-bottom:var(--space-6)}.assessment-header h1{margin-bottom:6px;font-size:1.8rem}.assessment-header p{color:var(--color-text-muted);font-size:.9rem}.assessment-tabs{gap:var(--space-2);margin-bottom:var(--space-8);display:flex}.assess-tab{padding:var(--space-3) var(--space-5);border-radius:var(--radius-full);color:var(--color-text-body);border:1.5px solid var(--color-border-subtle);cursor:pointer;transition:var(--transition-fast);font-size:.9rem;font-weight:600;font-family:var(--font-sans);background:#fff}.assess-tab.active{background:var(--color-blue-primary);color:#fff;border-color:var(--color-blue-primary)}.assess-content{max-width:700px;margin:0 auto}.quiz-start-card{padding:var(--space-10);text-align:center;align-items:center;gap:var(--space-4);flex-direction:column;display:flex}.quiz-start-icon{font-size:4rem}.quiz-start-card h2{font-size:1.6rem}.quiz-start-card p{color:var(--color-text-muted);font-size:.95rem;line-height:1.6}.quiz-info-chips{gap:var(--space-3);flex-wrap:wrap;justify-content:center;display:flex}.chip{background:var(--color-bg-base);border:1px solid var(--color-border-subtle);border-radius:var(--radius-full);color:var(--color-text-body);align-items:center;gap:6px;padding:6px 14px;font-size:.8rem;font-weight:600;display:flex}.last-score{background:var(--color-success-light);color:var(--color-success);border-radius:var(--radius-full);align-items:center;gap:6px;padding:8px 16px;font-size:.85rem;font-weight:600;display:flex}.quiz-active{gap:var(--space-5);flex-direction:column;display:flex}.quiz-prog-bar{align-items:center;gap:var(--space-3);color:var(--color-text-muted);font-size:.85rem;font-weight:600;display:flex}.quiz-prog-bar .progress-bar{flex:1}.quiz-card{padding:var(--space-6)}.quiz-question{color:var(--color-text-title);margin-bottom:var(--space-5);font-size:1.1rem;font-weight:700;line-height:1.5}.quiz-options{gap:var(--space-3);flex-direction:column;display:flex}.quiz-option{align-items:center;gap:var(--space-3);padding:var(--space-4);border-radius:var(--radius-md);border:2px solid var(--color-border-subtle);font-size:.95rem;font-family:var(--font-sans);color:var(--color-text-body);cursor:pointer;transition:var(--transition-fast);text-align:left;background:#fff;display:flex}.quiz-option:hover:not(:disabled){border-color:var(--color-blue-primary);background:var(--color-blue-xlight)}.quiz-option.correct{border-color:var(--color-success);background:var(--color-success-light);color:var(--color-success);font-weight:600}.quiz-option.wrong{border-color:var(--color-error);background:var(--color-error-light);color:var(--color-error)}.quiz-opt-letter{border-radius:var(--radius-full);background:var(--color-bg-base);flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:.8rem;font-weight:700;display:flex}.quiz-result{padding:var(--space-10);text-align:center;align-items:center;gap:var(--space-4);flex-direction:column;display:flex}.result-icon{font-size:4rem}.quiz-result h2{font-size:1.8rem}.quiz-result p{color:var(--color-text-muted);font-size:.95rem}.result-correct{background:var(--color-blue-light);color:var(--color-blue-dark);border-radius:var(--radius-full);padding:8px 20px;font-size:.9rem;font-weight:700}.monthly-header{margin-bottom:var(--space-6)}.monthly-header h2{margin-bottom:6px;font-size:1.4rem}.monthly-header p{color:var(--color-text-muted);font-size:.88rem}.skills-grid{gap:var(--space-4);margin-bottom:var(--space-6);grid-template-columns:repeat(4,1fr);display:grid}.skill-card{padding:var(--space-5);text-align:center;align-items:center;gap:var(--space-1);flex-direction:column;display:flex}.skill-icon{margin-bottom:var(--space-2);font-size:1.8rem}.skill-name{color:var(--color-text-muted);font-size:.85rem;font-weight:600}.skill-score{font-size:2.2rem;font-weight:800;line-height:1}.skill-max{color:var(--color-text-muted);margin-top:-4px;font-size:.8rem}.skill-level{margin-top:var(--space-2);font-size:.75rem;font-weight:600}.skill-card .progress-bar{width:100%}.monthly-insight,.monthly-rec{align-items:flex-start;gap:var(--space-3);padding:var(--space-4) var(--space-5);margin-bottom:var(--space-4);font-size:.88rem;line-height:1.6;display:flex}.monthly-insight{border-left:3px solid var(--color-accent)}.monthly-rec{border-left:3px solid var(--color-success)}.monthly-insight strong,.monthly-rec strong{color:var(--color-text-title);font-size:.9rem}.mock-start-card{padding:var(--space-8);text-align:center;align-items:center;gap:var(--space-5);flex-direction:column;display:flex}.mock-icon{font-size:4rem}.mock-start-card h2{font-size:1.6rem}.mock-start-card>p{color:var(--color-text-muted);max-width:500px;font-size:.95rem;line-height:1.6}.mock-sections{gap:var(--space-3);flex-direction:column;width:100%;max-width:440px;display:flex}.mock-section{align-items:center;gap:var(--space-4);padding:var(--space-4) var(--space-5);text-align:left;display:flex}.mock-section-icon{font-size:1.8rem}.mock-section-name{color:var(--color-text-title);font-size:.92rem;font-weight:700}.mock-section-meta{color:var(--color-text-muted);font-size:.78rem}.mock-note{align-items:flex-start;gap:var(--space-2);background:var(--color-accent-light);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);color:var(--color-accent-hover);text-align:left;max-width:440px;font-size:.82rem;font-weight:500;display:flex}.mock-note svg{flex-shrink:0;margin-top:2px}@media (width<=768px){.skills-grid{grid-template-columns:repeat(2,1fr)}.assessment-tabs{flex-wrap:wrap}}.rewards-page{padding:var(--space-8) 0 var(--space-16);background:var(--color-bg-base)}.rewards-header{margin-bottom:var(--space-6);justify-content:space-between;align-items:center;display:flex}.rewards-header h1{font-size:1.8rem}.rewards-xp-chip{align-items:center;gap:var(--space-2);background:var(--color-blue-light);color:var(--color-blue-dark);padding:var(--space-2) var(--space-5);border-radius:var(--radius-full);font-size:.9rem;display:flex}.rewards-xp-chip svg{color:var(--color-blue-primary)}.notification-banner{background:var(--color-success);color:#fff;padding:var(--space-3) var(--space-5);border-radius:var(--radius-md);margin-bottom:var(--space-5);text-align:center;font-weight:600;animation:.3s slideDown}.rewards-tabs{gap:var(--space-2);margin-bottom:var(--space-8);border-bottom:2px solid var(--color-border-subtle);padding-bottom:var(--space-2);display:flex}.rewards-tab{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-5);border-radius:var(--radius-full);color:var(--color-text-body);cursor:pointer;transition:var(--transition-fast);font-size:.9rem;font-weight:600;font-family:var(--font-sans);background:0 0;border:none;display:flex}.rewards-tab:hover{background:var(--color-border-subtle)}.rewards-tab.active{background:var(--color-blue-light);color:var(--color-blue-primary)}.tab-desc{color:var(--color-text-muted);margin-bottom:var(--space-6);font-size:.88rem}.badges-grid{gap:var(--space-4);grid-template-columns:repeat(4,1fr);display:grid}.badge-card{padding:var(--space-5);text-align:center;align-items:center;gap:var(--space-2);flex-direction:column;display:flex}.badge-card.locked{opacity:.55;filter:grayscale(.5)}.badge-card.earned{border:2px solid var(--color-success)}.badge-icon{font-size:2.5rem}.badge-name{color:var(--color-text-title);font-size:.9rem;font-weight:700}.badge-desc{color:var(--color-text-muted);font-size:.75rem;line-height:1.4}.badge-progress-mini{width:100%}.badge-xp-need{color:var(--color-text-muted);margin-top:4px;font-size:.7rem;font-weight:500;display:block}.rewards-grid{gap:var(--space-5);grid-template-columns:repeat(3,1fr);display:grid}.reward-card{padding:var(--space-5);gap:var(--space-3);flex-direction:column;display:flex}.reward-card.redeemed{opacity:.7}.reward-icon{font-size:2.5rem}.reward-name{color:var(--color-text-title);font-size:1rem;font-weight:700}.reward-desc{color:var(--color-text-muted);flex:1;font-size:.82rem;line-height:1.5}.reward-cost{color:var(--color-blue-primary);align-items:center;gap:5px;font-size:.88rem;font-weight:700;display:flex}.reward-cost svg{color:var(--color-accent)}.reward-btn{justify-content:center;width:100%;font-size:.85rem}.leaderboard-list{gap:var(--space-3);flex-direction:column;display:flex}.leaderboard-row{align-items:center;gap:var(--space-4);padding:var(--space-4) var(--space-5);display:flex}.leaderboard-row.is-user{border:2px solid var(--color-blue-primary);background:var(--color-blue-xlight)}.lb-rank{text-align:center;min-width:40px;color:var(--color-text-muted);font-size:1.2rem;font-weight:800}.lb-avatar{font-size:1.8rem}.lb-info{flex:1}.lb-name{color:var(--color-text-title);align-items:center;gap:var(--space-2);font-size:.95rem;font-weight:700;display:flex}.lb-streak{color:var(--color-text-muted);margin-top:2px;font-size:.78rem}.lb-xp{color:var(--color-blue-dark);align-items:center;gap:5px;font-size:.9rem;font-weight:700;display:flex}.lb-xp svg{color:var(--color-accent)}@media (width<=1024px){.badges-grid{grid-template-columns:repeat(3,1fr)}}@media (width<=768px){.badges-grid,.rewards-grid{grid-template-columns:repeat(2,1fr)}.rewards-header{align-items:flex-start;gap:var(--space-3);flex-direction:column}}.profile-page{padding:var(--space-8) 0 var(--space-16);background:var(--color-bg-base)}.profile-hero{align-items:center;gap:var(--space-6);padding:var(--space-6) var(--space-8);margin-bottom:var(--space-8);background:linear-gradient(135deg, var(--color-blue-xlight), white);flex-wrap:wrap;display:flex}.profile-avatar-wrap{flex-shrink:0;position:relative}.profile-avatar{border-radius:var(--radius-full);background:var(--color-blue-light);border:3px solid var(--color-blue-primary);justify-content:center;align-items:center;width:80px;height:80px;font-size:2.5rem;display:flex}.edit-avatar-btn{border-radius:var(--radius-full);background:var(--color-blue-primary);color:#fff;cursor:pointer;border:2px solid #fff;justify-content:center;align-items:center;width:26px;height:26px;display:flex;position:absolute;bottom:0;right:0}.profile-info{flex:1}.profile-info h1{margin-bottom:var(--space-2);font-size:1.4rem}.profile-goal{margin-bottom:var(--space-3)}.profile-meta{flex-direction:column;gap:4px;display:flex}.profile-meta-item{color:var(--color-text-muted);align-items:center;gap:6px;font-size:.82rem;display:flex}.profile-stats-row{align-items:center;gap:var(--space-5);border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg);padding:var(--space-4) var(--space-6);background:#fff;display:flex}.profile-stat{text-align:center;flex-direction:column;align-items:center;gap:4px;display:flex}.profile-stat-val{color:var(--color-text-title);font-size:1.4rem;font-weight:800}.profile-stat-lbl{color:var(--color-text-muted);white-space:nowrap;font-size:.72rem;font-weight:500}.profile-stat-divider{background:var(--color-border-subtle);width:1px;height:40px}.stat-flame{color:var(--color-accent)}.stat-star{color:var(--color-blue-primary)}.profile-grid{gap:var(--space-6);grid-template-columns:1fr 360px;align-items:start;display:grid}.profile-col-left,.profile-col-right{gap:var(--space-5);flex-direction:column;display:flex}.profile-section{padding:var(--space-5) var(--space-6)}.profile-section h2{margin-bottom:var(--space-4);font-size:1rem}.progress-info{color:var(--color-text-muted);margin-bottom:var(--space-2);justify-content:space-between;font-size:.85rem;font-weight:600;display:flex}.progress-pct{color:var(--color-blue-primary)}.milestone-list{gap:var(--space-3);margin-top:var(--space-5);flex-direction:column;display:flex}.milestone-item{align-items:center;gap:var(--space-3);padding:var(--space-2);border-radius:var(--radius-md);display:flex}.milestone-item.current{background:var(--color-blue-xlight)}.milestone-dot{border-radius:var(--radius-full);flex-shrink:0;width:10px;height:10px}.milestone-info{flex:1}.milestone-name{color:var(--color-text-title);font-size:.82rem;font-weight:600}.milestone-months{color:var(--color-text-muted);font-size:.72rem}.milestone-badge{border-radius:var(--radius-full);padding:3px 8px;font-size:.7rem;font-weight:700}.milestone-badge.done{background:var(--color-success-light);color:var(--color-success)}.milestone-badge.current{background:var(--color-blue-light);color:var(--color-blue-primary)}.skills-list{gap:var(--space-4);flex-direction:column;display:flex}.skill-row{align-items:center;gap:var(--space-3);grid-template-columns:80px 1fr 60px;display:grid}.skill-row-label{color:var(--color-text-body);align-items:center;gap:6px;font-size:.85rem;font-weight:600;display:flex}.skill-row-score{text-align:right;color:var(--color-text-muted);font-size:.8rem;font-weight:700}.today-status{text-align:center;padding:var(--space-2) 0}.today-status-value{color:var(--color-text-title);font-size:2.5rem;font-weight:800;line-height:1}.today-status-label{color:var(--color-text-muted);margin-top:4px;font-size:.85rem}.section-title-row{margin-bottom:var(--space-4);justify-content:space-between;align-items:center;display:flex}.section-title-row h2{margin:0}.profile-badges{gap:var(--space-3);margin-bottom:var(--space-4);flex-wrap:wrap;display:flex}.profile-badge-item{text-align:center}.profile-badge-icon{font-size:2rem}.profile-badge-name{color:var(--color-text-muted);font-size:.7rem;font-weight:600}.locked-badge-row{align-items:center;gap:var(--space-3);padding:var(--space-2) 0;border-bottom:1px solid var(--color-border-subtle);display:flex}.locked-badge-row:last-child{border:none}.profile-settings{flex-direction:column;gap:0;display:flex}.setting-row{padding:var(--space-3) 0;border-bottom:1px solid var(--color-border-subtle);justify-content:space-between;align-items:center;font-size:.85rem;display:flex}.setting-row:last-child{border:none}.setting-label{color:var(--color-text-body)}.setting-value{color:var(--color-text-title);font-weight:600}@media (width<=1024px){.profile-grid{grid-template-columns:1fr}}@media (width<=768px){.profile-hero{text-align:center;flex-direction:column}.profile-stats-row{flex-wrap:wrap;justify-content:center}.profile-meta{align-items:center}}.login-modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#0006;justify-content:center;align-items:center;width:100vw;height:100vh;display:flex;position:fixed;top:0;left:0}.login-modal{width:90%;max-width:450px;padding:var(--space-8);border-radius:var(--radius-xl);box-shadow:var(--shadow-2xl);background:#fff;animation:.3s modalFadeIn}@keyframes modalFadeIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.pinyin-page{padding:var(--space-8) 0 var(--space-16);background:var(--color-bg-base)}.pinyin-header{padding:var(--space-8);margin-bottom:var(--space-8);background:linear-gradient(135deg, var(--color-blue-xlight), white);border-left:5px solid var(--color-blue-primary)}.pinyin-badge{background:var(--color-blue-light);color:var(--color-blue-primary);border-radius:var(--radius-full);margin-bottom:var(--space-3);text-transform:uppercase;letter-spacing:.5px;align-items:center;gap:6px;padding:4px 12px;font-size:.75rem;font-weight:700;display:inline-flex}.pinyin-header h1{color:var(--color-text-title);margin-bottom:var(--space-3);font-size:1.8rem;font-weight:850}.pinyin-header p{color:var(--color-text-muted);max-width:800px;font-size:.95rem;line-height:1.6}.pinyin-tabs{gap:var(--space-3);margin-bottom:var(--space-6);padding-bottom:var(--space-2);display:flex;overflow-x:auto}.pinyin-tab-btn{border-radius:var(--radius-lg);border:1px solid var(--color-border-subtle);color:var(--color-text-body);cursor:pointer;white-space:nowrap;background:#fff;padding:10px 18px;font-size:.88rem;font-weight:600;transition:all .2s}.pinyin-tab-btn:hover{background:var(--color-blue-xlight);color:var(--color-blue-primary)}.pinyin-tab-btn.active{background:var(--color-blue-primary);color:#fff;border-color:var(--color-blue-primary);box-shadow:0 4px 12px #2096ff33}.pinyin-grid{gap:var(--space-6);grid-template-columns:350px 1fr;align-items:start;display:grid}@media (width<=900px){.pinyin-grid{grid-template-columns:1fr}}.pinyin-list-card{padding:var(--space-6)}.pinyin-list-card h2{margin-bottom:var(--space-4);color:var(--color-text-title);font-size:1rem}.pinyin-sounds-grid{grid-template-columns:repeat(auto-fill,minmax(65px,1fr));gap:8px;display:grid}.pinyin-sound-btn{border-radius:var(--radius-md);border:1px solid var(--color-border-subtle);cursor:pointer;background:#fff;flex-direction:column;justify-content:center;align-items:center;padding:10px 6px;transition:all .15s;display:flex}.pinyin-sound-btn:hover{border-color:var(--color-blue-primary);background:var(--color-blue-xlight)}.pinyin-sound-btn.active{border-color:var(--color-blue-primary);background:var(--color-blue-primary);color:#fff}.sound-text{font-size:1.25rem;font-weight:700}.sound-ipa{opacity:.8;margin-top:2px;font-size:.68rem}.pinyin-practice-card{padding:var(--space-8)}.practice-header{border-bottom:1px solid var(--color-border-subtle);padding-bottom:var(--space-4);margin-bottom:var(--space-5);justify-content:space-between;align-items:center;gap:var(--space-2);flex-wrap:wrap;display:flex}.practice-indicator{text-transform:uppercase;color:var(--color-accent);align-items:center;gap:4px;font-size:.72rem;font-weight:700;display:flex}.practice-header h2{margin:0;font-size:1.15rem}.practice-target{color:var(--color-blue-primary);font-size:2.2rem;font-weight:850;font-family:var(--font-hanzi);margin-left:6px}.practice-guide{gap:var(--space-3);background:var(--color-bg-base);padding:var(--space-5);border-radius:var(--radius-lg);margin-bottom:var(--space-6);border:1px solid var(--color-border-subtle);flex-direction:column;display:flex}.guide-row{font-size:.88rem;line-height:1.5;display:flex}.guide-label{width:140px;color:var(--color-text-muted);flex-shrink:0;font-weight:600}.guide-val{color:var(--color-text-title);font-weight:700}.guide-val.description-text{color:var(--color-text-body);font-weight:500}.hanzi-example{font-family:var(--font-hanzi);color:var(--color-accent);margin-right:4px;font-size:1.15rem}.example-meaning{color:var(--color-text-muted);font-weight:500}.speak-btn{justify-content:center;width:100%;padding:12px;font-weight:700}.recording-section{border-top:1px dashed var(--color-border);margin-top:var(--space-8);padding-top:var(--space-6);text-align:center}.recording-section h3{margin-bottom:var(--space-5);color:var(--color-text-muted);font-size:.9rem}.mic-container{width:74px;height:74px;margin:0 auto var(--space-3);position:relative}.mic-button{border-radius:var(--radius-full);background:var(--color-accent);color:#fff;cursor:pointer;z-index:2;border:3px solid #fff;justify-content:center;align-items:center;width:70px;height:70px;transition:all .2s;display:flex;position:relative;box-shadow:0 4px 15px #ff8a0066}.mic-button:hover{transform:scale(1.05)}.mic-button:active{transform:scale(.95)}.mic-button.recording{background:#ff3b30;box-shadow:0 4px 15px #ff3b3080}.pulse-ring{border-radius:var(--radius-full);z-index:1;border:2px solid #ff3b30;width:78px;height:78px;animation:1.5s ease-out infinite pulseMic;position:absolute;top:-4px;left:-4px}@keyframes pulseMic{0%{opacity:.8;transform:scale(1)}to{opacity:0;transform:scale(1.4)}}.mic-status-text{color:var(--color-text-muted);margin-bottom:var(--space-5);font-size:.78rem;font-weight:600}.eval-result-box{border-radius:var(--radius-lg);padding:var(--space-5);text-align:left;border:1px solid;animation:.3s cubic-bezier(.16,1,.3,1) resultIn}@keyframes resultIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.eval-result-box.perfect{background:var(--color-success-light);border-color:var(--color-success);color:#1e4620}.eval-result-box.good{background:var(--color-blue-xlight);border-color:var(--color-blue-primary);color:#153c5e}.eval-result-box.try_again{border-color:var(--color-accent);color:#613600;background:#fff8f0}.eval-result-header{margin-bottom:var(--space-2);font-size:.9rem;font-weight:750}.eval-score-row{align-items:center;gap:8px;font-size:.85rem;display:flex}.score-val{font-size:1.1rem;font-weight:850}.scholarships-page{padding:var(--space-8) 0 var(--space-16);background:var(--color-bg-base);min-height:calc(100vh - 120px)}.scholarships-header{margin-bottom:var(--space-8);text-align:center;max-width:700px;margin-left:auto;margin-right:auto}.scholarships-header h1{margin-bottom:var(--space-2);background:linear-gradient(135deg, var(--color-blue-primary), #6366f1);-webkit-text-fill-color:transparent;-webkit-background-clip:text;font-size:2.2rem;font-weight:800}.scholarships-header p{color:var(--color-text-muted);font-size:1rem;line-height:1.6}.filter-search-container{padding:var(--space-5);margin-bottom:var(--space-8);gap:var(--space-4);border-radius:var(--radius-lg);background:#fff;flex-direction:column;display:flex;box-shadow:0 4px 20px -2px #0000000d}.filter-search-container .search-bar{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-5);background:var(--color-bg-base);border-radius:var(--radius-md);border:1px solid var(--color-border-subtle);display:flex}.filter-search-container .search-bar svg{color:var(--color-text-muted)}.filter-search-container .search-bar input{font-family:var(--font-sans);color:var(--color-text-title);background:0 0;border:none;outline:none;flex:1;font-size:.95rem}.filter-chips{gap:var(--space-2);flex-wrap:wrap;display:flex}.filter-chips .chip{border-radius:var(--radius-full);background:var(--color-bg-base);color:var(--color-text-body);border:1px solid var(--color-border-subtle);cursor:pointer;transition:all var(--transition-fast);font-size:.85rem;font-weight:600;font-family:var(--font-sans);padding:6px 16px}.filter-chips .chip:hover{background:var(--color-border-subtle)}.filter-chips .chip.active{background:var(--color-blue-primary);color:#fff;border-color:var(--color-blue-primary)}.category-badge{border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.5px;align-items:center;gap:6px;padding:4px 10px;font-size:.72rem;font-weight:700;display:inline-flex}.category-badge.cat-timeline{background:var(--color-blue-light);color:var(--color-blue-primary)}.category-badge.cat-scholarship{color:#a855f7;background:#f3e8ff}.category-badge.cat-university{color:#0284c7;background:#e0f2fe}.category-badge.cat-experience{color:#d97706;background:#fef3c7}.articles-grid{gap:var(--space-6);grid-template-columns:repeat(3,1fr);display:grid}.article-card{padding:var(--space-6);gap:var(--space-3);cursor:pointer;border-radius:var(--radius-lg);transition:transform var(--transition-fast), box-shadow var(--transition-fast);background:#fff;flex-direction:column;display:flex;box-shadow:0 4px 15px -3px #0000000a}.article-card:hover{transform:translateY(-4px);box-shadow:0 10px 25px -5px #00000014}.article-card .card-top{justify-content:space-between;align-items:center;display:flex}.article-card .read-time{color:var(--color-text-muted);font-size:.75rem}.article-card .card-title{color:var(--color-text-title);margin:var(--space-1) 0;font-size:1.15rem;font-weight:700;line-height:1.4}.article-card .card-summary{color:var(--color-text-body);-webkit-line-clamp:3;text-overflow:ellipsis;margin-bottom:var(--space-2);-webkit-box-orient:vertical;font-size:.88rem;line-height:1.5;display:-webkit-box;overflow:hidden}.article-card .card-bottom{border-top:1px solid var(--color-border-subtle);padding-top:var(--space-4);justify-content:space-between;align-items:center;margin-top:auto;display:flex}.article-card .author{color:var(--color-text-muted);font-size:.78rem;font-weight:500}.article-card .read-more{color:var(--color-blue-primary);padding:4px 8px;font-size:.8rem;font-weight:600}.article-detail-container{max-width:800px;margin:0 auto}.back-btn{margin-bottom:var(--space-6);align-items:center;gap:8px;padding:8px 16px;font-size:.9rem;display:inline-flex}.article-content-card{padding:var(--space-8) var(--space-10);border-radius:var(--radius-lg);background:#fff;box-shadow:0 4px 25px -5px #0000000d}.article-title{color:var(--color-text-title);margin:var(--space-4) 0 var(--space-3);font-size:2.2rem;font-weight:800;line-height:1.3}.article-meta{gap:var(--space-4);color:var(--color-text-muted);border-bottom:1px solid var(--color-border-subtle);padding-bottom:var(--space-5);margin-bottom:var(--space-6);font-size:.85rem;display:flex}.article-meta .meta-item{align-items:center;gap:6px;display:flex}.article-body{color:var(--color-text-body);font-size:1.05rem;line-height:1.75}.md-h2{color:var(--color-text-title);margin-top:var(--space-8);margin-bottom:var(--space-3);border-bottom:2px solid var(--color-bg-base);padding-bottom:6px;font-size:1.4rem;font-weight:700}.md-h3{color:var(--color-text-title);margin-top:var(--space-6);margin-bottom:var(--space-2);font-size:1.15rem;font-weight:700}.md-p{margin-bottom:var(--space-4)}.md-ul{margin-bottom:var(--space-6);padding-left:var(--space-6)}.md-li{margin-bottom:var(--space-2);list-style-type:disc}.md-li strong{color:var(--color-text-title)}.table-responsive{width:100%;margin:var(--space-6) 0;border-radius:var(--radius-md);border:1px solid var(--color-border-subtle);overflow-x:auto}.md-table{border-collapse:collapse;text-align:left;width:100%;font-size:.95rem}.md-table th{background:var(--color-bg-base);color:var(--color-text-title);padding:var(--space-3) var(--space-4);border-bottom:2px solid var(--color-border-subtle);font-weight:700}.md-table td{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border-subtle);color:var(--color-text-body)}.md-table tr:last-child td{border-bottom:none}.md-table tr:nth-child(2n){background:#00000003}.no-results{text-align:center;padding:var(--space-12);color:var(--color-text-muted);grid-column:1/-1}@media (width<=1024px){.articles-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=768px){.articles-grid{grid-template-columns:1fr}.article-content-card{padding:var(--space-5) var(--space-6)}.article-title{font-size:1.6rem}.scholarships-header h1{font-size:1.8rem}}.app-root{flex-direction:column;min-height:100vh;display:flex}.app-main{flex:1}.app-footer{background:var(--color-text-title);color:#ffffffb3;padding:var(--space-8) 0;margin-top:auto}.footer-inner{align-items:center;gap:var(--space-3);text-align:center;flex-direction:column;display:flex}.footer-logo{align-items:center;gap:var(--space-2);color:#fff;font-size:1.1rem;font-weight:700;display:flex}.footer-hanzi{font-family:var(--font-hanzi);font-size:1.5rem}.app-footer p{opacity:.6;font-size:.8rem}.footer-links{gap:var(--space-5);display:flex}.footer-links a{color:#fff9;font-size:.85rem;text-decoration:none;transition:color .2s}.footer-links a:hover{color:#fff}
