.course-page{--reading-column: 720px;--sidebar-width: 260px;--gutter: 3rem;--accent: var(--accent);--accent-soft: var(--accent-tint);--accent-strong: var(--accent-ink)}.reading-progress{position:fixed;top:0;left:0;right:0;height:3px;background:transparent;z-index:60;pointer-events:none}.reading-progress__bar{height:100%;background:var(--accent);transform-origin:left;transform:scaleX(0);transition:transform 80ms linear}.course-hero{background:linear-gradient(135deg,var(--brand) 0%,var(--brand-deep) 100%);color:#fff;padding:56px 0 64px;position:relative;overflow:hidden}.course-hero:after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 85% 0%,rgba(188,107,60,.22),transparent 60%);pointer-events:none}.course-hero .container{position:relative;z-index:1}.course-hero__eyebrow{font-family:var(--mono);font-size:12px;letter-spacing:.16em;text-transform:uppercase;font-weight:500;color:var(--brand-tint);margin:0 0 12px}.course-hero__title{font-family:var(--display);font-size:clamp(36px,5.5vw,64px);font-weight:800;line-height:1;margin:0 0 18px;letter-spacing:-.03em;color:#fff}.course-hero__desc{font-family:var(--body);font-size:clamp(17px,1.6vw,19px);line-height:1.55;color:#ffffffdb;max-width:60ch;margin:0 0 28px}.course-hero__meta{display:flex;flex-wrap:wrap;gap:32px;font-family:var(--mono);font-size:11.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--brand-tint);border-top:1px solid rgba(255,255,255,.18);padding-top:22px}.course-hero__meta-item strong{display:block;font-family:var(--display);font-size:28px;font-weight:700;color:#fff;letter-spacing:-.02em;line-height:1;margin-bottom:4px}.course-layout{display:grid;grid-template-columns:1fr;gap:var(--space-2xl);max-width:1200px;margin:0 auto;padding:var(--space-3xl) var(--space-lg);min-height:0}@media(min-width:1024px){.course-layout{grid-template-columns:var(--sidebar-width) 1fr;gap:var(--gutter)}}.course-layout__main{min-width:0}.course-layout__sidebar{order:-1;min-height:0;max-height:320px;overflow-y:auto;scrollbar-gutter:stable}@media(min-width:1024px){.course-layout__sidebar{order:0;position:sticky;top:var(--header-height);align-self:start;height:calc(100vh - var(--header-height) - 1rem);max-height:calc(100vh - var(--header-height) - 1rem);overflow-y:auto;padding-right:var(--space-sm);scrollbar-width:thin;scrollbar-color:var(--line-2) transparent}.course-layout__sidebar::-webkit-scrollbar{width:8px}.course-layout__sidebar::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:4px}.course-layout__sidebar::-webkit-scrollbar-thumb:hover{background:var(--ink-3)}.course-layout__sidebar::-webkit-scrollbar-track{background:transparent}}.course-sidebar{font-size:var(--text-sm)}.course-sidebar__title{display:block;font-family:var(--mono);font-size:11.5px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-2);margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid var(--line)}.course-sidebar__list{list-style:none;margin:0;padding:0}.course-sidebar__item{margin:0}.course-sidebar__link{display:flex;align-items:flex-start;gap:10px;padding:7px 12px;border-radius:8px;color:var(--ink-2);text-decoration:none;border-left:2px solid transparent;margin-left:-2px;transition:all var(--transition-fast);line-height:1.35;font-family:var(--body)}.course-sidebar__link:hover{background:var(--brand-tint);color:var(--brand-ink)}.course-sidebar__link.is-current{background:var(--brand-tint);color:var(--ink);border-left-color:var(--brand);font-weight:500}.course-sidebar__num{flex-shrink:0;font-family:var(--mono);font-variant-numeric:tabular-nums;color:var(--ink-3);font-size:12px;min-width:1.75rem;padding-top:2px;font-weight:500}.course-sidebar__link.is-current .course-sidebar__num{color:var(--brand-ink);font-weight:600}.course-sidebar__title-text{flex:1;min-width:0}.course-sidebar__check{flex-shrink:0;color:var(--brand);font-size:14px;font-weight:700;line-height:1;padding-top:3px;opacity:0;transition:opacity var(--transition-fast)}.course-sidebar__item.is-read .course-sidebar__check{opacity:1}.course-sidebar__item.is-read .course-sidebar__link{color:var(--ink-3);text-decoration:line-through;text-decoration-color:var(--line-2)}.course-sidebar__item.is-read .course-sidebar__link.is-current{color:var(--ink);text-decoration:none}.course-sidebar__progress{margin-top:16px;padding-top:12px;border-top:1px solid var(--line);font-family:var(--mono);font-size:11px;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-3)}.course-sidebar__progress-bar{height:4px;background:var(--surface-2);border-radius:999px;overflow:hidden;margin-top:8px}.course-sidebar__progress-fill{height:100%;background:var(--accent);transition:width var(--transition-base)}.subtopic-article{max-width:var(--reading-column);font-family:var(--body);font-size:17px;line-height:1.65;color:var(--ink)}.subtopic-article .article-header{margin-bottom:var(--space-3xl);padding-bottom:var(--space-2xl);border-bottom:1px solid var(--line)}.subtopic-article .article-header__breadcrumb{display:flex;align-items:center;gap:8px;font-family:var(--mono);font-size:12px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-3);margin-bottom:18px}.subtopic-article .article-header__breadcrumb a{color:var(--ink-2);text-decoration:none;border-bottom:1px solid transparent;transition:all var(--transition-fast)}.subtopic-article .article-header__breadcrumb a:hover{color:var(--brand-ink);border-bottom-color:var(--brand)}.subtopic-article .article-header__breadcrumb-sep{color:var(--ink-3);opacity:.6}.subtopic-article .article-header__eyebrow{display:inline-block;font-family:var(--mono);font-size:12px;letter-spacing:.16em;text-transform:uppercase;font-weight:500;color:var(--accent-ink);margin-bottom:8px}.subtopic-article h1{font-family:var(--display);font-size:clamp(28px,4vw,44px);font-weight:800;line-height:1.08;letter-spacing:-.025em;margin:0 0 18px;color:var(--ink)}.subtopic-article .article-header__meta{display:flex;flex-wrap:wrap;gap:20px;font-family:var(--mono);font-size:12px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-3)}.subtopic-article .article-header__meta strong{color:var(--ink-2);font-weight:600}.syllabus{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:22px 24px;margin-bottom:var(--space-3xl);box-shadow:var(--shadow);font-family:var(--body)}.syllabus__title{display:block;font-family:var(--mono);font-size:12px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--brand-ink);margin-bottom:16px}.syllabus__list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:14px}.syllabus__item{display:flex;gap:14px;align-items:flex-start}.syllabus__num{flex-shrink:0;width:26px;height:26px;display:inline-flex;align-items:center;justify-content:center;border-radius:50%;background:var(--brand-tint);color:var(--brand-ink);font-family:var(--mono);font-size:12px;font-weight:600;margin-top:1px}.syllabus__title-text{font-weight:500;color:var(--ink);text-decoration:none;line-height:1.4;display:block;margin-bottom:4px;font-size:16px}.syllabus__title-text:hover{color:var(--brand-ink)}.syllabus__meta{font-family:var(--mono);font-size:11.5px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-3);line-height:1.5}.subtopic-article h2{font-family:var(--display);font-size:clamp(22px,2.5vw,28px);font-weight:700;line-height:1.2;letter-spacing:-.02em;margin:48px 0 14px;color:var(--ink)}.subtopic-article h2:first-child{margin-top:0}.subtopic-article h3{font-family:var(--display);font-size:20px;font-weight:600;line-height:1.3;letter-spacing:-.01em;margin:32px 0 10px;color:var(--ink)}.subtopic-article p{margin:0 0 18px}.subtopic-article p+p{margin-top:-2px}.subtopic-article ul,.subtopic-article ol{margin:0 0 22px;padding-left:1.5em}.subtopic-article li{margin-bottom:6px;line-height:1.65}.subtopic-article li::marker{color:var(--brand)}.subtopic-article blockquote{margin:28px 0;padding:18px 22px;border-left:3px solid var(--accent);background:var(--accent-tint);border-radius:0 var(--radius-md) var(--radius-md) 0;font-style:italic;color:var(--ink-2);font-size:16.5px}.subtopic-article blockquote p:last-child{margin-bottom:0}.subtopic-article code{font-family:var(--mono);font-size:.875em;background:var(--surface-2);border:1px solid var(--line);border-radius:4px;padding:.1em .4em;color:var(--brand-ink)}.subtopic-article pre{font-family:var(--mono);font-size:14px;line-height:1.6;background:var(--ink);color:#e7ecf1;padding:22px 24px;border-radius:var(--radius);overflow-x:auto;margin:22px 0}.subtopic-article pre code{background:none;border:none;padding:0;color:inherit;font-size:inherit}.subtopic-article iframe{display:block;width:100%;aspect-ratio:16 / 9;border:none;border-radius:var(--radius);margin:26px 0;background:#000}.subtopic-article a{color:var(--brand-ink);text-decoration:underline;text-decoration-color:#0c748059;text-underline-offset:3px;transition:text-decoration-color var(--transition-fast),color var(--transition-fast)}.subtopic-article a:hover{text-decoration-color:var(--brand-ink);color:var(--brand-deep)}.subtopic-article hr{border:none;border-top:1px solid var(--line);margin:32px 0}.subtopic-article strong{font-weight:600;color:var(--ink)}.subtopic-nav{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:64px;padding-top:32px;border-top:1px solid var(--line);font-family:var(--body)}.subtopic-nav__item{display:flex;flex-direction:column;gap:6px;padding:18px 20px;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);text-decoration:none;color:var(--ink-2);transition:all var(--transition-fast)}.subtopic-nav__item:hover{border-color:var(--brand);background:var(--brand-tint);color:var(--ink);transform:translateY(-1px);box-shadow:var(--shadow)}.subtopic-nav__item--next{text-align:right;align-items:flex-end}.subtopic-nav__label{font-family:var(--mono);font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3)}.subtopic-nav__title{font-family:var(--display);font-size:16px;font-weight:600;color:var(--ink);line-height:1.3;letter-spacing:-.01em}.subtopic-nav__item--all{grid-column:1 / -1;text-align:center;align-items:center;background:var(--surface-2)}.subtopic-list{list-style:none;margin:32px 0 0;padding:0;display:grid;gap:12px}.subtopic-list__item{margin:0}.subtopic-list__link{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:20px;padding:20px 24px;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);text-decoration:none;color:var(--ink);transition:all var(--transition-fast);font-family:var(--body)}.subtopic-list__link:hover{border-color:var(--brand);transform:translateY(-1px);box-shadow:var(--shadow-md)}.subtopic-list__num{font-family:var(--mono);font-size:22px;font-weight:700;color:var(--brand-ink);min-width:3rem;text-align:center;font-variant-numeric:tabular-nums;letter-spacing:-.01em}.subtopic-list__body{min-width:0}.subtopic-list__title{font-family:var(--display);font-size:18px;font-weight:600;margin:0 0 4px;line-height:1.3;letter-spacing:-.01em;color:var(--ink)}.subtopic-list__meta{display:flex;flex-wrap:wrap;gap:12px;font-family:var(--mono);font-size:11.5px;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-3)}.subtopic-list__kind{display:inline-block;font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-2);border:1px solid var(--line);padding:3px 8px;border-radius:999px;background:var(--surface-2)}.subtopic-list__kind--hands-on{color:var(--brand-ink);border-color:#c4e3e6;background:var(--brand-tint)}.subtopic-list__check{color:var(--brand);font-size:18px;font-weight:700;opacity:0;transition:opacity var(--transition-fast)}.subtopic-list__item.is-read .subtopic-list__check{opacity:1}.subtopic-list__item.is-read .subtopic-list__link{background:var(--surface-2);color:var(--ink-3)}.subtopic-list__item.is-read .subtopic-list__num{color:var(--ink-3)}.course-list-meta{display:flex;gap:var(--space-md);align-items:center;margin-bottom:var(--space-lg);font-family:var(--mono);font-size:11.5px;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-3)}
