:root{--green: #58cc02;--green-bg: rgba(88, 204, 2, .12);--green-shadow: #46a302;--accent: #4a9ef5;--accent-rgb: 74, 158, 245;--accent-shadow: #2f7fd0;--accent2: #8b6fd4;--yellow: #ffc800;--yellow-bg: rgba(255, 200, 0, .15);--red: #ff4b4b;--red-bg: rgba(255, 75, 75, .12);--bg: #f7f7f7;--surface: #ffffff;--surface2: #f0f0f0;--border: #e5e5e5;--text: #3c3c3c;--muted: #8e95a8;--sp-1: 4px;--sp-2: 8px;--sp-3: 12px;--sp-4: 16px;--sp-5: 20px;--sp-6: clamp(20px, 2.5vw, 28px);--sp-8: clamp(28px, 3.5vw, 40px);--radius: 16px;--radius-lg: 20px;--radius-pill: 999px;--fs-xs: 12px;--fs-sm: 14px;--fs-base: clamp(15px, 1.8vw, 17px);--fs-lg: clamp(17px, 2.1vw, 19px);--fs-xl: clamp(20px, 2.5vw, 24px);--fs-2xl: clamp(24px, 3.5vw, 32px);--fs-hero: clamp(28px, 5vw, 40px);--shadow-card: 0 2px 12px rgba(0, 0, 0, .08);--shadow-pop: 0 8px 28px rgba(0, 0, 0, .16);--w-wide: 1024px;--w-activity: 900px;--w-narrow: 100%;--w-auth-card: 560px;--topnav-h: 60px;--grid-col-min: 240px;--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px);--safe-left: env(safe-area-inset-left, 0px);--safe-right: env(safe-area-inset-right, 0px)}*,*:before,*:after{box-sizing:border-box}html,body{margin:0;background:var(--bg);color:var(--text);font-family:Nunito,PingFang SC,Hiragino Sans GB,Microsoft YaHei,system-ui,sans-serif;font-weight:500;-webkit-font-smoothing:antialiased;touch-action:manipulation}.pc-btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--sp-2);padding:12px 24px;border:none;border-radius:var(--radius);font-family:inherit;font-size:var(--fs-base);font-weight:800;cursor:pointer;transition:filter .15s,transform .05s,box-shadow .05s;-webkit-user-select:none;user-select:none}.pc-btn:disabled{opacity:.5;cursor:default;box-shadow:none;transform:none}.pc-btn--block{width:100%}.pc-btn--primary{background:var(--green);color:#fff;box-shadow:0 4px 0 var(--green-shadow)}.pc-btn--accent{background:var(--accent);color:#fff;box-shadow:0 4px 0 var(--accent-shadow)}.pc-btn--primary:not(:disabled):active,.pc-btn--accent:not(:disabled):active{transform:translateY(3px);box-shadow:0 1px 0 var(--green-shadow)}.pc-btn--primary:not(:disabled):hover,.pc-btn--accent:not(:disabled):hover{filter:brightness(1.04)}.pc-btn--secondary{background:var(--surface);color:var(--text);border:2px solid var(--border)}.pc-btn--secondary:not(:disabled):hover{border-color:var(--accent);color:var(--accent)}.pc-btn--ghost{background:none;color:var(--muted);font-weight:700;padding:8px 12px}.pc-btn--ghost:hover{color:var(--text)}.pc-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card)}.pc-input{width:100%;padding:12px 14px;font-family:inherit;font-size:var(--fs-base);font-weight:500;border:2px solid var(--border);border-radius:var(--radius);outline:none;color:var(--text)}.pc-input:focus{border-color:var(--accent)}.pc-chip{display:inline-block;font-size:var(--fs-xs);font-weight:700;background:var(--green-bg);color:var(--green-shadow);padding:2px 10px;border-radius:var(--radius-pill)}.pc-shell{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;padding-bottom:var(--safe-bottom)}.pc-topnav{height:var(--topnav-h);flex-shrink:0;display:flex;align-items:center;justify-content:space-between;padding:0 var(--sp-5);padding-top:var(--safe-top);background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100}.pc-topnav__brand{display:flex;align-items:center;gap:var(--sp-2);font-size:var(--fs-xl);font-weight:800;color:var(--text);text-decoration:none}.pc-topnav__nav{display:flex;align-items:center;gap:var(--sp-1)}.pc-topnav__link{padding:6px 14px;border-radius:var(--radius-pill);font-size:var(--fs-base);font-weight:700;color:var(--muted);text-decoration:none;white-space:nowrap;transition:background-color .15s,color .15s}.pc-topnav__link:hover{background:var(--surface2);color:var(--text)}.pc-topnav__link.is-active{background:rgba(var(--accent-rgb),.12);color:var(--accent)}.pc-topnav__user{display:flex;align-items:center;gap:var(--sp-3)}.pc-topnav__child{display:flex;align-items:center;gap:var(--sp-2);font-size:var(--fs-sm);color:var(--text);background:var(--surface2);padding:4px 12px;border-radius:var(--radius-pill)}.pc-main{flex:1;width:100%;max-width:var(--w-wide);margin:0 auto;padding:var(--sp-8) var(--sp-5)}.pc-center{min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:var(--sp-5)}.pc-center .pc-card{max-width:var(--w-auth-card);width:100%;padding:var(--sp-8) var(--sp-6)}.pc-narrow{width:100%}.pc-page{padding:var(--sp-5)}.pc-page--wide{padding:var(--sp-8) var(--sp-5)}.pc-page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--sp-4)}.pc-page-header__side{width:40px}.pc-hero{text-align:center;padding:var(--sp-8) 0 var(--sp-8)}.pc-hero__title{font-size:var(--fs-2xl);font-weight:800;margin:var(--sp-4) 0 var(--sp-2)}.pc-hero__sub{color:var(--muted);font-size:var(--fs-base);margin:0 0 var(--sp-6)}.pc-section-title{font-size:var(--fs-lg);font-weight:800;margin:0 0 var(--sp-5)}.pc-course-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(var(--grid-col-min),1fr));gap:var(--sp-4);align-content:start}.pc-lesson-card{display:flex;flex-direction:column;gap:var(--sp-2);text-align:left;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);padding:var(--sp-5);cursor:pointer;transition:transform .12s,box-shadow .12s;font-family:inherit}.pc-lesson-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-pop)}.pc-lesson-card__title{font-size:var(--fs-lg);font-weight:800;color:var(--text)}.pc-lesson-card__author{font-size:var(--fs-sm);color:var(--muted)}.pc-lesson-card__row{display:flex;align-items:center;justify-content:space-between;margin-top:auto;padding-top:var(--sp-2)}.pc-lesson-card__stars{font-size:var(--fs-base);letter-spacing:1px}.pc-lesson-card__times{font-size:var(--fs-xs);color:var(--muted)}.pc-child-pill{padding:8px 14px;background:var(--green-bg);color:var(--green-shadow);border-radius:var(--radius-pill);font-weight:700}.pc-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;align-items:center;justify-content:center;background:#00000080;padding:var(--sp-5)}.pc-activity-shell{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;height:100dvh;background:var(--bg);display:flex;flex-direction:column;overflow:hidden}.pc-activity-shell__top{position:relative;display:flex;align-items:center;gap:var(--sp-3);padding:0 var(--sp-4);height:40px;flex-shrink:0;border-bottom:1px solid var(--border);background:var(--surface)}.pc-activity-shell__top .pc-btn{margin-bottom:0;padding:6px 10px;font-size:var(--fs-sm)}.pc-activity-shell__title{flex:1;text-align:center;font-size:var(--fs-sm);color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pc-activity-shell__pct{font-size:var(--fs-xs);font-weight:700;color:var(--accent);min-width:40px;text-align:right}.pc-activity-shell__side{min-width:40px}.pc-activity-shell__progress{position:absolute;left:0;bottom:-1px;height:4px;z-index:1;background:var(--accent);border-radius:0 2px 2px 0;transition:width .2s}.pc-activity-shell__scroll{flex:1 1 0;min-height:0;overflow-y:auto;width:100%;display:flex;flex-direction:column}.pc-activity-content{width:100%;max-width:var(--w-activity);margin:0 auto;padding:var(--sp-5) var(--sp-4)}.pc-typing-lines{display:flex;flex-direction:column;gap:var(--sp-2);width:100%;max-width:var(--w-activity);margin:auto;padding:var(--sp-5) var(--sp-4)}.pc-activity-shell__bottom{flex-shrink:0;padding:0 var(--sp-4);padding-bottom:max(var(--sp-3),var(--safe-bottom));width:100%;max-width:var(--w-activity);margin:0 auto}.pc-practice-line{display:flex;flex-wrap:wrap;gap:6px 8px;align-items:flex-end;padding:10px 12px;border-radius:10px;opacity:.2;transition:opacity .4s ease,background-color .3s ease}.pc-practice-line.is-done{opacity:.25}.pc-practice-line.is-next{opacity:.4}.pc-practice-line.is-current{opacity:1;background:rgba(var(--accent-rgb),.06)}.pc-char-unit{display:flex;flex-direction:column;align-items:center;gap:4px;min-width:40px;max-width:72px}.pc-char-unit--punct{min-width:16px;max-width:28px;gap:0}.pc-char-pinyin{font-size:15px;min-height:22px;color:var(--muted);letter-spacing:-.02em;white-space:nowrap;text-align:center}.pc-char-pinyin .py-typed{color:var(--accent);font-weight:600}.pc-char-pinyin .py-typed.err{color:var(--red)}.pc-char-block{width:60px;height:60px;border-radius:12px;background:var(--surface);border:2px solid var(--border);box-shadow:0 3px #d1d5db;display:flex;align-items:center;justify-content:center;font-size:30px;font-weight:700;position:relative;transition:border-color .15s ease,box-shadow .15s ease,background-color .15s ease,transform .15s ease}.pc-char-block.state-current{border-color:var(--accent);box-shadow:0 0 0 4px rgba(var(--accent-rgb),.15);background:rgba(var(--accent-rgb),.05)}.pc-char-block.state-current:after{content:"";position:absolute;bottom:6px;left:50%;transform:translate(-50%);width:16px;height:3px;background:var(--accent);border-radius:2px;animation:pc-glow 1.5s ease-in-out infinite}.pc-char-block.state-correct{background:var(--green-bg);border-color:var(--green);color:var(--green);transform:translateY(-2px)}.pc-char-block.state-yellow{background:var(--yellow-bg);border-color:var(--yellow);color:var(--yellow);transform:translateY(-2px)}.pc-char-block.state-error{background:var(--red-bg);border-color:var(--red);color:var(--red);animation:pc-shake .3s ease}.pc-char-block--punct{width:28px;min-width:16px;background:transparent;border-color:transparent;box-shadow:none;color:var(--muted)}@keyframes pc-glow{0%,to{opacity:.3}50%{opacity:1}}@keyframes pc-shake{0%,to{transform:translate(0)}25%{transform:translate(-4px)}75%{transform:translate(4px)}}.pc-rotate-mask{display:none}@media (orientation: portrait){.pc-rotate-mask{display:flex;position:absolute;top:0;right:0;bottom:0;left:0;z-index:300;align-items:center;justify-content:center;text-align:center;padding:var(--sp-5);background:var(--bg);font-size:var(--fs-xl);font-weight:700}}.pc-landing-hero{text-align:center;padding:var(--sp-8) var(--sp-5);max-width:800px;margin:0 auto}.pc-landing-hero__title{font-size:var(--fs-hero);font-weight:800;margin:0 0 var(--sp-4);line-height:1.3}.pc-landing-hero__sub{font-size:var(--fs-base);color:var(--muted);line-height:1.7;max-width:580px;margin:0 auto var(--sp-6)}.pc-landing-section{padding:var(--sp-8) var(--sp-5);max-width:900px;margin:0 auto}.pc-landing-features{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--sp-4);margin-top:var(--sp-6)}.pc-landing-cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}.pc-landing-course-grid{text-align:center;margin-top:var(--sp-6)}@media (max-width: 767px){.pc-main{padding:var(--sp-4)}.pc-course-grid{grid-template-columns:1fr}.pc-topnav__brand span{display:none}}@media (min-width: 1280px){:root{--w-wide: 1100px;--grid-col-min: 280px}.pc-main{padding:var(--sp-8) var(--sp-6)}}.dev-hud{position:fixed;bottom:16px;left:16px;z-index:1000;display:flex;flex-direction:row;flex-wrap:wrap;gap:4px;align-items:center;max-width:70vw;cursor:pointer}.dev-pill{font-size:10px;font-weight:700;padding:3px 7px;border-radius:99px;border:1.5px solid;white-space:nowrap;background:var(--surface);font-family:ui-monospace,SFMono-Regular,Menlo,monospace}.dev-pill--red{color:var(--red);border-color:var(--red);background:#ff4b4b14}.dev-pill--purple{color:var(--accent2);border-color:var(--accent2);background:#8b6fd41a}.dev-pill--blue{color:var(--accent);border-color:var(--accent);background:#4a9ef514}.dev-pill--green{color:var(--green-shadow);border-color:var(--green);background:var(--green-bg)}.dev-pill--yellow{color:#a07800;border-color:var(--yellow);background:var(--yellow-bg)}.dev-hud__dot{position:fixed;bottom:16px;left:16px;z-index:1000;width:12px;height:12px;padding:0;border-radius:99px;border:1.5px solid var(--accent2);background:#8b6fd41a;cursor:pointer}
