:root{color-scheme:light;font-family:PingFang SC,Hiragino Sans GB,Microsoft YaHei UI,Microsoft YaHei,ui-sans-serif,system-ui,sans-serif;line-height:1.6;font-weight:400;color:#18222d;background:#eef3f1;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;--bg: #eef3f1;--paper: #fffffb;--paper-strong: #ffffff;--ink: #18222d;--ink-soft: #3f4f5e;--muted: #6f796f;--line: #d2dbd7;--line-strong: #a7b7b0;--pine: #1f6a55;--pine-dark: #124b3c;--indigo: #2f5485;--amber: #b66d1f;--red: #a94843;--mint: #d9eadf;--sky: #d9e7f6;--sand: #e4e9e4;--code-bg: #121826;--code-line: #253044;--shadow: 0 18px 44px rgba(49, 43, 31, .13);--shadow-light: 0 10px 26px rgba(49, 43, 31, .09);--display-font: "Songti SC", "Noto Serif CJK SC", "Source Han Serif SC", Georgia, serif;--mono-font: "SFMono-Regular", "Cascadia Code", Consolas, "Liberation Mono", Menlo, monospace}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;min-width:320px;min-height:100vh;background:linear-gradient(rgba(31,106,85,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(47,84,133,.035) 1px,transparent 1px),radial-gradient(circle at 18px 18px,rgba(47,84,133,.045) 1.2px,transparent 1.4px),var(--bg);background-size:28px 28px,28px 28px,84px 84px,auto}body.image-preview-open{overflow:hidden}button,input{font:inherit}button,a{color:inherit}::selection{background:#cfe2d5;color:var(--pine-dark)}.app-shell{display:grid;grid-template-columns:304px minmax(0,1fr);min-height:100vh}.app-main{min-width:0;padding:30px}.course-sidebar{position:sticky;top:0;height:100vh;overflow:hidden;border-right:1px solid var(--line);background:linear-gradient(180deg,#fffffbf5,#eff5f2f5),var(--paper);display:flex;flex-direction:column}.brand{display:flex;align-items:center;gap:12px;min-height:82px;padding:18px 20px 16px;text-decoration:none;border-bottom:1px solid var(--line)}.brand span{display:grid;place-items:center;width:42px;height:42px;border-radius:8px;background:#162c28;color:#f7c873;box-shadow:inset 0 0 0 1px #f7c87347}.brand strong{display:grid;gap:1px;font-family:var(--display-font);font-size:19px;line-height:1.1;color:var(--ink)}.brand small{font-family:inherit;font-size:12px;font-weight:700;color:var(--muted)}.sidebar-progress{padding:14px 18px 16px;border-bottom:1px solid var(--line)}.sidebar-progress>div:first-child{display:flex;justify-content:space-between;align-items:center;margin-bottom:9px;color:var(--muted);font-size:12px;font-weight:800}.sidebar-progress strong{color:var(--pine-dark);font-family:var(--mono-font)}.sidebar-progress-track{height:9px;overflow:hidden;border-radius:999px;background:#1f6a551f}.sidebar-progress-track span{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--pine),var(--amber))}.sidebar-scroll{overflow-y:auto;padding:14px 12px 28px}.sidebar-stage{margin-bottom:18px}.sidebar-stage h2{margin:14px 10px 8px;color:var(--muted);font-size:12px;font-weight:900}.lesson-link{position:relative;display:grid;grid-template-columns:42px minmax(0,1fr) 18px;align-items:center;min-height:42px;gap:8px;margin:3px 0;padding:6px 8px;border:1px solid transparent;border-radius:8px;text-decoration:none;color:#2b3944;transition:transform .14s ease,border-color .14s ease,background-color .14s ease}.lesson-link:hover,.lesson-link.active{border-color:#1f6a552e;background:#fffffbbd;color:var(--pine-dark);transform:translate(2px)}.lesson-link.active:before{position:absolute;left:-12px;top:8px;bottom:8px;width:4px;border-radius:999px;background:var(--amber);content:""}.day-pill{display:inline-flex;justify-content:center;align-items:center;height:28px;border-radius:7px;background:#e4decf;color:#3f4a52;font-family:var(--mono-font);font-size:12px;font-weight:900}.lesson-link.active .day-pill{background:var(--pine);color:#fffffb}.mobile-menu-button,.mobile-close,.mobile-sidebar{display:none}.home-page,.resources-page{max-width:1200px;margin:0 auto}.home-hero{position:relative;display:grid;grid-template-columns:minmax(0,1.35fr) 360px;gap:24px;align-items:stretch;min-height:388px;padding:42px;border:1px solid var(--line);border-radius:8px;background:linear-gradient(135deg,#fffffbf7,#e6efebe6),var(--paper);box-shadow:var(--shadow);overflow:hidden}.home-hero:before{position:absolute;inset:18px;pointer-events:none;border:1px dashed rgba(31,106,85,.24);border-radius:8px;content:""}.home-hero:after{position:absolute;right:36px;top:26px;color:#124b3c1f;font-family:var(--mono-font);font-size:70px;font-weight:900;line-height:1;content:">>> "}.hero-copy{position:relative;z-index:1;display:flex;flex-direction:column;justify-content:center}.section-kicker{display:inline-flex;align-items:center;gap:7px;width:fit-content;color:var(--pine-dark);font-size:13px;font-weight:900}.muted{color:var(--muted)}.home-hero h1,.page-header h1,.lesson-hero h1{margin:12px 0 14px;max-width:780px;color:var(--ink);font-family:var(--display-font);font-size:56px;font-weight:800;line-height:1.08;letter-spacing:0}.home-hero p,.page-header p,.lesson-hero p{max-width:760px;margin:0;color:var(--ink-soft);font-size:17px}.hero-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:30px}.primary-button,.secondary-button{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:44px;padding:0 17px;border:1px solid transparent;border-radius:8px;text-decoration:none;cursor:pointer;font-weight:900;transition:transform .14s ease,box-shadow .14s ease,background-color .14s ease}.primary-button{background:#172d29;color:#fffffb;box-shadow:0 10px 22px #172d2929}.primary-button:hover{background:var(--pine-dark);transform:translateY(-1px)}.primary-button.done{background:var(--mint);border-color:#aac9b6;color:var(--pine-dark);box-shadow:none}.secondary-button{background:#fffffbdb;border-color:var(--line);color:var(--ink)}.secondary-button:hover{border-color:var(--line-strong);transform:translateY(-1px)}.study-panel{position:relative;z-index:1;align-self:center;padding:24px;border-left:4px solid var(--amber);border-radius:8px;background:#fffffbc7;box-shadow:var(--shadow-light)}.study-panel-top{display:flex;justify-content:space-between;align-items:end;gap:18px}.study-panel-top span,.next-lesson-card span{color:var(--muted);font-size:12px;font-weight:900}.study-panel-top strong{font-family:var(--mono-font);font-size:40px;line-height:1}.next-lesson-card{margin-top:18px;padding-top:16px;border-top:1px solid var(--line)}.next-lesson-card strong{display:block;margin-top:4px;font-size:18px}.next-lesson-card p{margin-top:7px;color:var(--muted);font-size:14px}.hero-metrics{display:flex;flex-wrap:wrap;gap:8px;margin-top:16px}.hero-metrics span{display:inline-flex;align-items:center;gap:6px;min-height:30px;padding:0 10px;border-radius:999px;background:#e5ece8;color:#3d4d48;font-size:12px;font-weight:900}.progress-meter{display:grid;grid-template-columns:minmax(0,1fr) 48px;align-items:center;gap:12px;margin:18px 0 0}.progress-meter-track{height:10px;overflow:hidden;border-radius:999px;background:#1f6a5521}.progress-meter-track span{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--pine),var(--indigo),var(--amber))}.progress-meter strong{color:var(--pine-dark);font-family:var(--mono-font)}.search-band{margin:28px 0}.search-box{display:flex;align-items:center;gap:10px;min-height:56px;padding:0 17px;border:1px solid var(--line);border-radius:8px;background:#fffffbe6;box-shadow:0 10px 24px #312b1f12}.search-box:focus-within{border-color:var(--pine);box-shadow:0 0 0 4px #1f6a551a}.search-box input{width:100%;border:0;outline:0;background:transparent;color:var(--ink)}.lesson-grid-section{margin-top:32px}.section-heading{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:12px}.section-heading>div{display:flex;align-items:baseline;gap:10px}.section-heading h2{margin:0;font-family:var(--display-font);font-size:26px;line-height:1.1}.section-heading span{color:var(--muted)}.section-number{color:var(--amber);font-family:var(--mono-font);font-size:13px;font-weight:900}.lesson-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}.lesson-card,.resource-card,.toc-panel,.exercise-panel,.warning-box,.lesson-hero,.markdown-content{border:1px solid var(--line);border-radius:8px;background:#fffffbeb}.lesson-card{position:relative;display:flex;flex-direction:column;min-height:246px;padding:18px;text-decoration:none;box-shadow:0 8px 20px #312b1f0f;transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease}.lesson-card:before{position:absolute;top:0;left:18px;right:18px;height:3px;border-radius:0 0 999px 999px;background:var(--sand);content:""}.lesson-card:hover{border-color:var(--line-strong);box-shadow:0 16px 34px #312b1f1f;transform:translateY(-3px)}.lesson-card.completed{background:#f4faf4f0}.lesson-card.completed:before{background:var(--pine)}.lesson-card-top,.lesson-card-meta{display:flex;align-items:center;justify-content:space-between;gap:12px;color:var(--pine-dark);font-family:var(--mono-font);font-size:12px;font-weight:900}.lesson-card h3{margin:16px 0 8px;font-family:var(--display-font);font-size:24px;line-height:1.15}.lesson-card p{flex:1;margin:0;color:var(--muted);font-size:14px}.lesson-card-goals{display:flex;flex-wrap:wrap;gap:6px;margin-top:14px}.lesson-card-goals span{max-width:100%;padding:3px 8px;border:1px solid rgba(47,84,133,.14);border-radius:999px;background:#d9e7f694;color:#354f70;font-size:12px;font-weight:800}.lesson-card-meta{margin-top:16px;color:var(--muted);font-family:inherit}.lesson-card-meta span{display:inline-flex;align-items:center;gap:5px}.lesson-layout{display:grid;grid-template-columns:minmax(0,900px) 270px;align-items:start;justify-content:center;gap:24px}.lesson-article{min-width:0}.lesson-hero{position:relative;display:flex;justify-content:space-between;gap:20px;align-items:flex-start;padding:36px;background:linear-gradient(135deg,#fffffbfa,#e5efeaeb),var(--paper);box-shadow:var(--shadow);overflow:hidden}.lesson-hero:after{position:absolute;right:26px;bottom:-8px;color:#1f6a5514;font-family:var(--mono-font);font-size:92px;font-weight:900;content:"</>"}.lesson-hero>*{position:relative;z-index:1}.lesson-hero h1{font-size:48px}.lesson-stats,.goal-strip{display:flex;flex-wrap:wrap;gap:10px;margin-top:14px}.lesson-stats span,.goal-strip span,.goal-strip strong{display:inline-flex;align-items:center;gap:7px;min-height:36px;padding:0 13px;border-radius:999px;border:1px solid var(--line);color:#3f4d5a;background:#fffffbdb}.lesson-stats span{font-family:var(--mono-font);font-size:12px;font-weight:900}.goal-strip{padding:13px;border:1px solid var(--line);border-radius:8px;background:#fffffba8}.goal-strip strong{background:#172d29;color:#fffffb;font-weight:900}.goal-strip span{background:var(--mint);color:var(--pine-dark);font-weight:800}.warning-box{display:grid;grid-template-columns:24px minmax(0,1fr);gap:10px;margin:18px 0;padding:16px;background:#fff2db;border-color:#e7c276;color:#65420f}.warning-box p{margin:4px 0 0}.markdown-content{margin-top:24px;padding:38px;box-shadow:0 12px 28px #312b1f0f}.markdown-content.compact{margin-top:18px;padding:0;border:0;background:transparent;box-shadow:none}.markdown-content h2{scroll-margin-top:24px;margin:42px 0 13px;padding-top:8px;color:var(--ink);font-family:var(--display-font);font-size:30px;line-height:1.25}.markdown-content h2:first-child{margin-top:0}.markdown-content h2:before{display:inline-block;width:18px;height:3px;margin-right:9px;vertical-align:middle;border-radius:999px;background:var(--amber);content:""}.markdown-content h3{scroll-margin-top:24px;margin:30px 0 10px;color:#243542;font-size:21px}.markdown-content h4{margin:22px 0 8px;font-size:17px}.markdown-content p,.markdown-content li{color:#2f3b47}.markdown-content p{margin:13px 0}.markdown-content ul,.markdown-content ol{padding-left:24px}.markdown-content li::marker{color:var(--amber);font-weight:900}.markdown-content a{display:inline-flex;align-items:center;gap:4px;color:var(--indigo);font-weight:800;text-decoration-thickness:1px;text-underline-offset:3px}.markdown-image-button{position:relative;display:block;width:fit-content;max-width:100%;margin:20px auto;padding:0;border:1px solid var(--line);border-radius:8px;background:#f8faf7;box-shadow:0 12px 28px #312b1f17;cursor:zoom-in;overflow:hidden}.markdown-image-button img{display:block;max-width:100%;height:auto;margin:0;border:0;border-radius:0;background:transparent;box-shadow:none}.markdown-image-button span{position:absolute;right:10px;bottom:10px;display:inline-flex;align-items:center;gap:6px;min-height:30px;padding:0 10px;border-radius:999px;background:#122b27db;color:#fffffb;font-size:12px;font-weight:900;opacity:0;transform:translateY(6px);transition:opacity .14s ease,transform .14s ease}.markdown-image-button:hover span,.markdown-image-button:focus-visible span{opacity:1;transform:translateY(0)}.image-preview-backdrop{position:fixed;inset:0;z-index:120;display:grid;place-items:center;padding:26px;background:#081016c7;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.image-preview-shell{position:relative;display:grid;place-items:center;max-width:min(1120px,96vw);max-height:92vh;padding:14px;border:1px solid rgba(255,255,255,.18);border-radius:8px;background:#fffffbf5;box-shadow:0 30px 80px #00000061}.image-preview-shell img{display:block;max-width:calc(96vw - 28px);max-height:calc(92vh - 76px);width:auto;height:auto;border-radius:6px}.image-preview-shell p{margin:10px 36px 0;color:var(--muted);font-size:13px;text-align:center}.image-preview-close{position:absolute;right:10px;top:10px;z-index:1;display:inline-grid;place-items:center;width:36px;height:36px;border:1px solid rgba(18,34,45,.1);border-radius:8px;background:#fffffbe6;color:var(--ink);cursor:pointer}.markdown-content table{display:block;width:100%;overflow-x:auto;border-collapse:collapse;margin:18px 0}.markdown-content th,.markdown-content td{padding:10px 12px;border:1px solid var(--line);text-align:left}.markdown-content th{background:var(--mint);color:var(--pine-dark)}.markdown-content blockquote{margin:18px 0;padding:12px 16px;border-left:4px solid var(--amber);background:#f7edd9;color:#4f493d}.markdown-content :not(pre)>code{padding:2px 6px;border-radius:6px;background:#eee4d2;color:#8d3432;font-family:var(--mono-font);font-size:.92em}.code-frame{overflow:hidden;margin:20px 0;border:1px solid #27334a;border-radius:8px;background:var(--code-bg);color:#e5eef7;box-shadow:0 16px 34px #1218262e}.code-toolbar{display:flex;justify-content:space-between;align-items:center;min-height:40px;padding:0 10px 0 14px;border-bottom:1px solid var(--code-line);background:#182033;color:#b8c4d6;font-family:var(--mono-font);font-size:12px;font-weight:900}.code-frame pre{margin:0;padding:18px;overflow-x:auto}.code-frame code{font-family:var(--mono-font);font-size:14px;line-height:1.7}.icon-button{display:inline-grid;place-items:center;width:30px;height:30px;border:0;border-radius:6px;cursor:pointer}.icon-button.subtle{background:#ffffff14;color:#dbe7f3}.icon-button.subtle:hover{background:#ffffff29}.exercise-panel{margin-top:24px;padding:24px;background:linear-gradient(90deg,#d9eadf8a,#fffffbf0),var(--paper-strong)}.exercise-panel.done{border-color:#a9c3b4}.exercise-header{display:flex;justify-content:space-between;align-items:flex-start;gap:18px}.exercise-header h2{margin:8px 0 0;font-family:var(--display-font);font-size:28px}.lesson-pager{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:24px}.lesson-pager a{display:flex;align-items:center;justify-content:space-between;gap:14px;min-height:82px;padding:16px;border:1px solid var(--line);border-radius:8px;background:#fffffbeb;text-decoration:none;transition:transform .14s ease,border-color .14s ease}.lesson-pager a:hover{border-color:var(--line-strong);transform:translateY(-2px)}.lesson-pager span{display:grid;color:var(--muted);font-size:13px}.lesson-pager strong{color:var(--ink);font-size:17px}.source-note{margin:24px 0 40px;color:var(--muted);font-size:14px}.source-note a{color:var(--indigo);font-weight:900}.toc-panel{position:sticky;top:24px;padding:18px;background:#fffffbe6;box-shadow:0 10px 22px #312b1f0f}.toc-panel h2{margin:0 0 12px;font-family:var(--display-font);font-size:18px}.toc-panel p{color:var(--muted)}.toc-panel ol{display:grid;gap:7px;margin:0;padding:0;list-style:none}.toc-panel li.indent{padding-left:12px}.toc-panel li{position:relative;border-radius:7px}.toc-panel li.active{background:#1f6a5517}.toc-panel li.active:before{position:absolute;left:-8px;top:6px;bottom:6px;width:3px;border-radius:999px;background:var(--amber);content:""}.toc-panel button{display:block;width:100%;padding:4px 6px;border:0;background:transparent;color:#465767;text-decoration:none;font-size:14px;text-align:left;cursor:pointer}.toc-panel li.active button{color:var(--pine-dark);font-weight:900}.toc-panel button:hover{color:var(--pine-dark)}.page-header{padding:34px 0 22px}.resource-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}.resource-card{padding:20px;box-shadow:0 10px 24px #312b1f12}.resource-card-head{display:flex;gap:12px;align-items:flex-start}.resource-card h2{margin:0 0 6px;font-family:var(--display-font);font-size:22px}.resource-card p{margin:0;color:var(--muted)}.resource-card ul{display:grid;gap:8px;margin:18px 0 0;padding:0;list-style:none}.resource-card a{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:9px 10px;border-radius:8px;background:#e6ece9;color:var(--indigo);text-decoration:none;font-weight:800;overflow-wrap:anywhere}@media(max-width:1180px){.app-shell{grid-template-columns:1fr}.app-shell>.course-sidebar{display:none}.app-main{padding:68px 18px 24px}.mobile-menu-button{position:fixed;top:14px;left:14px;z-index:50;display:inline-grid;place-items:center;width:42px;height:42px;border:1px solid var(--line);border-radius:8px;background:var(--paper-strong);color:var(--ink);box-shadow:0 6px 18px #1f2c381f}.mobile-sidebar{position:fixed;inset:0 auto 0 0;z-index:60;display:block;width:min(340px,88vw);transform:translate(-105%);transition:transform .18s ease;box-shadow:var(--shadow)}.mobile-sidebar.open{transform:translate(0)}.mobile-sidebar .course-sidebar{display:flex;width:100%}.mobile-close{position:absolute;top:12px;right:12px;z-index:70;display:inline-grid;place-items:center;width:36px;height:36px;border:1px solid var(--line);border-radius:8px;background:var(--paper-strong);color:var(--ink)}.home-hero,.lesson-layout{grid-template-columns:1fr}.toc-panel{position:static;order:-1}.lesson-grid,.resource-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:720px){.app-main{padding-inline:12px}.home-hero,.lesson-hero,.markdown-content{padding:22px}.home-hero h1,.page-header h1,.lesson-hero h1{font-size:38px}.home-hero,.lesson-hero,.exercise-header{display:flex;flex-direction:column}.home-hero:after{font-size:42px;right:20px}.study-panel{width:100%}.lesson-grid,.resource-grid,.lesson-pager{grid-template-columns:1fr}.lesson-card{min-height:0}.lesson-stats span,.goal-strip span,.goal-strip strong{width:100%;justify-content:flex-start}}
