:root,[data-theme=dark]{color-scheme:dark;--bg: #0d1117;--surface: #0d1117;--surface-2: #161b22;--surface-hover: #1c2128;--border: #30363d;--border-subtle: #21262d;--text: #e6edf3;--muted: #8b949e;--subtle: #7d8590;--accent: #818cf8;--accent-2: #c084fc;--accent-soft: rgba(129, 140, 248, .15);--accent-shadow: rgba(129, 140, 248, .28);--accent-ink: #ffffff;--link: #6aa5f5;--success: #3fb950;--success-soft: rgba(63, 185, 80, .15);--danger: #f85149;--nav-bg: rgba(13, 17, 23, .82);--shadow: 0 1px 2px rgba(0, 0, 0, .4)}[data-theme=light]{color-scheme:light;--bg: #ffffff;--surface: #ffffff;--surface-2: #f6f8fa;--surface-hover: #eff2f5;--border: #d0d7de;--border-subtle: #d8dee4;--text: #1f2328;--muted: #59636e;--subtle: #8c959f;--accent: #4f46e5;--accent-2: #9333ea;--accent-soft: rgba(79, 70, 229, .1);--accent-shadow: rgba(79, 70, 229, .18);--accent-ink: #ffffff;--link: #0969da;--success: #1f883d;--success-soft: #dafbe1;--danger: #cf222e;--nav-bg: rgba(255, 255, 255, .85);--shadow: 0 1px 2px rgba(31, 35, 40, .08)}*,*:before,*:after{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body,#root{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,SF Pro Text,Inter,Segoe UI,Roboto,system-ui,sans-serif;font-size:16px;line-height:1.5;min-height:100vh;overscroll-behavior:none;-webkit-font-smoothing:antialiased}body{padding-bottom:calc(var(--safe-bottom, env(safe-area-inset-bottom, 0px)) + 72px)}a{color:var(--link);text-decoration:none}button{font-family:inherit;font-size:inherit;background:none;border:none;color:inherit;cursor:pointer;padding:0}:root{--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px);--max-width: 720px}.nav-bar{position:sticky;top:0;z-index:10;padding:calc(var(--safe-top) + 6px) 8px 6px;background:var(--nav-bg);-webkit-backdrop-filter:saturate(180%) blur(20px);backdrop-filter:saturate(180%) blur(20px);border-bottom:1px solid var(--border-subtle)}.nav-bar-inner{max-width:var(--max-width);margin:0 auto;display:flex;align-items:center;gap:4px;min-height:36px}.nav-bar .title{font-size:16px;font-weight:600;letter-spacing:-.01em;flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding:0 8px}.nav-bar .back{display:inline-flex;align-items:center;gap:2px;color:var(--accent);font-size:15px;padding:8px;border-radius:6px}.nav-bar .back:active{background:var(--surface-hover)}.icon-btn{width:36px;height:36px;display:inline-flex;align-items:center;justify-content:center;color:var(--muted);border-radius:8px;flex-shrink:0}.icon-btn:active{background:var(--surface-hover);color:var(--text)}.hero{padding:20px 16px 12px;max-width:var(--max-width);margin:0 auto}.hero h1{font-size:28px;font-weight:700;margin:0 0 4px;letter-spacing:-.025em;line-height:1.2}.hero .subtitle{color:var(--muted);font-size:14px;font-variant-numeric:tabular-nums;margin-bottom:12px}.progress-bar{width:100%;height:6px;background:var(--surface-2);border-radius:3px;overflow:hidden}.progress-bar-fill{height:100%;background:var(--accent);border-radius:3px;transition:width .5s cubic-bezier(.22,.61,.36,1)}.section-label{max-width:var(--max-width);margin:20px auto 4px;padding:0 16px;color:var(--muted);font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.list{max-width:var(--max-width);margin:0 auto 24px;border-top:1px solid var(--border-subtle)}.row{display:flex;align-items:center;gap:12px;padding:14px 16px;color:var(--text);background:var(--bg);border-bottom:1px solid var(--border-subtle);transition:background .1s ease}.row:active{background:var(--surface-2)}.row.is-empty{opacity:.45;cursor:not-allowed}.row.is-empty:active{background:var(--bg)}.row.is-done .row-title{color:var(--muted)}.row.is-done .row-title{text-decoration:line-through;text-decoration-thickness:1px;text-decoration-color:var(--border)}.row .leading{flex-shrink:0;width:28px;height:28px;display:flex;align-items:center;justify-content:center;color:var(--muted)}.row.is-done .leading{color:var(--success)}.row .done-dot{width:22px;height:22px;border-radius:50%;background:var(--success);color:#fff;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700}.row .body{flex:1;min-width:0;padding:2px 0}.row .row-title{font-weight:600;font-size:15px;line-height:1.35;margin:0 0 2px;letter-spacing:-.005em}.row .row-meta{color:var(--muted);font-size:13px;line-height:1.35;display:flex;gap:8px;align-items:center;flex-wrap:wrap}.row .row-meta .sep{color:var(--border)}.row .chevron{color:var(--subtle);flex-shrink:0;opacity:.6}.chip{display:inline-flex;align-items:center;gap:4px;background:var(--surface-2);color:var(--muted);border:1px solid var(--border-subtle);border-radius:2em;padding:1px 8px;font-size:12px;font-weight:600;white-space:nowrap}.lesson-page{max-width:var(--max-width);margin:0 auto;padding:12px 16px 96px}.lesson-hero{padding:12px 0 8px}.lesson-hero h1{font-size:26px;font-weight:700;letter-spacing:-.025em;line-height:1.2;margin:8px 0 0}.lesson-badge{display:inline-flex;align-items:center;gap:4px;background:var(--accent-soft);color:var(--accent);font-size:12px;font-weight:600;padding:3px 10px;border-radius:2em;text-transform:uppercase;letter-spacing:.03em}.section{margin:28px 0 0}.section-title{font-size:13px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;margin:0 0 10px}.check-list{list-style:none;padding:0;margin:0;background:var(--surface-2);border:1px solid var(--border-subtle);border-radius:12px;overflow:hidden}.check-list li{display:flex;gap:12px;padding:14px 16px;font-size:15px;line-height:1.4;border-bottom:1px solid var(--border-subtle)}.check-list li:last-child{border-bottom:0}.check-mark{color:var(--success);font-weight:700;flex-shrink:0;width:16px;text-align:center}.tiles{display:grid;grid-template-columns:1fr;gap:8px}@media (min-width: 480px){.tiles{grid-template-columns:1fr 1fr}}.tile{display:flex;align-items:center;gap:14px;background:var(--surface-2);border:1px solid var(--border-subtle);border-radius:12px;padding:14px 16px;color:var(--text);transition:all .15s ease}.tile:active{background:var(--surface-hover);transform:scale(.99)}.tile-icon{font-size:22px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--bg);border-radius:10px;flex-shrink:0}.tile-body{flex:1;min-width:0}.tile-label{font-weight:600;font-size:15px;letter-spacing:-.005em;line-height:1.3}.tile-hint{color:var(--muted);font-size:12px;margin-top:2px}.tile-chevron{color:var(--subtle);flex-shrink:0}.accordion-head{display:flex;align-items:center;gap:10px;width:100%;background:var(--surface-2);border:1px solid var(--border-subtle);border-radius:12px;padding:14px 16px;text-align:left;font-weight:600;font-size:15px;transition:background .1s ease}.accordion-head.open{border-bottom-left-radius:0;border-bottom-right-radius:0}.accordion-head:active{background:var(--surface-hover)}.accordion-icon{color:var(--muted);font-size:14px;width:12px}.accordion-title{flex:1}.accordion-meta{background:var(--bg);color:var(--muted);font-size:12px;padding:2px 8px;border-radius:2em;border:1px solid var(--border-subtle)}.accordion-body{background:var(--surface-2);border:1px solid var(--border-subtle);border-top:0;border-radius:0 0 12px 12px;padding:4px 16px 16px}.video-section,.recording-section{margin-top:28px}.video-caption,.section-note{color:var(--muted);font-size:13px;margin-top:8px}.video-player{background:#000;border-radius:10px;overflow:hidden;aspect-ratio:16 / 9;display:flex;align-items:center;justify-content:center;border:1px solid var(--border-subtle)}.video-player iframe,.video-player video{width:100%;height:100%;border:0;display:block}.video-player .placeholder{color:#8b949e;font-size:13px;text-align:center;padding:16px}.video-facade{position:relative;padding:0;border:1px solid var(--border-subtle);cursor:pointer}.video-facade img{width:100%;height:100%;object-fit:cover;display:block}.video-play-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;color:#fff;background:linear-gradient(to bottom,transparent 0%,rgba(0,0,0,.3) 100%);transition:background .15s ease}.video-facade:active .video-play-overlay{background:#0006}.video-play-overlay svg{filter:drop-shadow(0 2px 8px rgba(0,0,0,.6));opacity:.95}.video-fallback{display:inline-block;font-size:13px;color:var(--accent);margin-top:8px;font-weight:500}.intro-paragraph{margin:8px 0;line-height:1.55;color:var(--text);font-size:15px;white-space:pre-wrap}.schedule-list{display:flex;flex-direction:column;gap:10px;margin-bottom:16px}.schedule-item{display:flex;gap:14px;background:var(--surface-2);border:1px solid var(--border-subtle);border-radius:12px;padding:14px 16px}.schedule-emoji{font-size:22px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--bg);border-radius:10px;flex-shrink:0}.schedule-body{flex:1;min-width:0}.schedule-day{font-weight:600;font-size:15px}.schedule-label{color:var(--text);font-size:14px;margin-top:2px;line-height:1.4}.schedule-detail{color:var(--muted);font-size:13px;margin-top:4px;white-space:pre-line}.primary-cta{display:flex;align-items:center;justify-content:space-between;gap:10px;background:var(--surface-2);border:1px solid var(--border);border-radius:12px;padding:14px 16px;color:var(--text);font-weight:600;font-size:15px}.primary-cta:active{background:var(--surface-hover)}.primary-cta.accent{background:var(--accent);border-color:var(--accent);color:var(--accent-ink)}.primary-cta.accent:active{filter:brightness(.9)}.empty-state{text-align:center;padding:36px 24px;background:var(--surface-2);border:1px solid var(--border-subtle);border-radius:14px}.empty-icon{font-size:42px;margin-bottom:10px}.empty-state h2{font-size:18px;margin:0 0 6px;font-weight:600}.empty-state p{color:var(--muted);font-size:14px;line-height:1.5;margin:0 0 16px}.hero-sub{color:var(--muted);font-size:14px;margin-top:6px}.hero-emoji{margin-right:4px}.lesson-hero--action{padding:12px 0 0}.lesson-hero--action .hero-sub{margin:0 0 6px;font-size:12px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}.lesson-hero--action h1{margin:0;font-size:26px}.lesson-hero--action+.section{margin-top:16px}.checklist{list-style:none;padding:0;margin:0;background:var(--surface-2);border:1px solid var(--border-subtle);border-radius:12px;overflow:hidden}.checklist li{display:flex;gap:12px;padding:16px;min-height:48px;border-bottom:1px solid var(--border-subtle);align-items:flex-start;transition:background .12s ease;cursor:pointer;transition:background .1s ease;font-size:15px;line-height:1.5}.checklist li:last-child{border-bottom:0}.checklist li:active{background:var(--surface-hover)}.checklist li.done{color:var(--muted)}.checklist li.done .checklist-text{text-decoration:line-through;text-decoration-color:var(--border)}.checklist-box{flex-shrink:0;width:24px;height:24px;border-radius:7px;border:1.5px solid var(--border);transition:transform .15s cubic-bezier(.34,1.56,.64,1),background .15s ease,border-color .15s ease;display:flex;align-items:center;justify-content:center}.checklist li.done .checklist-box{background:var(--success);border-color:var(--success);color:#fff;transform:scale(1.05)}.checklist-text{flex:1;min-width:0;line-height:1.45}.action-empty{text-align:center;padding:40px 20px 20px}.action-empty h2{font-size:17px;margin:0 0 6px;font-weight:600}.action-empty p{color:var(--muted);font-size:14px}.done-button{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;margin-top:32px;background:var(--accent);color:var(--accent-ink);border:1px solid var(--accent);border-radius:12px;padding:14px;font-weight:700;font-size:15px;transition:transform .12s ease,filter .15s ease;letter-spacing:-.01em}.done-button:active{filter:brightness(.94);transform:scale(.98)}.done-button.done{background:var(--success-soft);color:var(--success);border-color:transparent}.done-button.done{background:var(--success-soft);color:var(--success);border-color:var(--success)}.done-check{width:18px}.block{margin:14px 0}.block.heading-1{font-size:19px;font-weight:600;margin:24px 0 8px;letter-spacing:-.01em}.block.heading-2{font-size:16px;font-weight:600;margin:20px 0 6px;letter-spacing:-.005em}.block.heading-3{font-size:14px;font-weight:600;margin:16px 0 4px;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}.block.paragraph{font-size:15px;line-height:1.6;color:var(--text)}.block.quote{border-left:3px solid var(--border);padding:2px 0 2px 12px;color:var(--muted)}.block.callout{background:var(--accent-soft);border:1px solid var(--border-subtle);border-radius:8px;padding:12px 14px;display:flex;gap:10px;align-items:flex-start;font-size:14px;line-height:1.5}.block.callout .emoji{font-size:16px;flex-shrink:0}.block.list ul,.block.list ol{padding-left:22px;margin:0}.block.list li{margin:4px 0;font-size:15px;line-height:1.55}.block.divider{height:1px;background:var(--border-subtle);margin:24px 0}.block.image img{width:100%;border-radius:6px;display:block;border:1px solid var(--border-subtle)}.block.image .caption{color:var(--muted);font-size:13px;margin-top:6px;text-align:center}.block.file,.block.link{display:flex;align-items:center;gap:10px;background:var(--surface-2);border:1px solid var(--border-subtle);border-radius:8px;padding:10px 12px;color:var(--text);font-size:14px;font-weight:500}.block.file:active,.block.link:active{background:var(--surface-hover)}.block.file .icon,.block.link .icon{color:var(--muted);flex-shrink:0}.block.link span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0;flex:1}.block.todo{display:flex;gap:10px;align-items:flex-start;font-size:15px;line-height:1.55}.block.todo .todo-check{color:var(--muted);flex-shrink:0;font-size:17px;line-height:1;margin-top:2px}.block.todo .todo-check.done{color:var(--accent)}.block.toggle{background:var(--surface-2);border:1px solid var(--border-subtle);border-radius:6px;padding:10px 12px}.block.toggle summary{cursor:pointer;font-weight:500;font-size:14px;list-style:none}.block.toggle summary::-webkit-details-marker{display:none}.block.toggle summary:before{content:"▸";display:inline-block;margin-right:6px;color:var(--muted)}.block.toggle[open] summary:before{transform:rotate(90deg)}.block.toggle[open] summary{margin-bottom:8px}.block.code{background:var(--surface-2);border:1px solid var(--border-subtle);border-radius:6px;padding:10px 12px;overflow-x:auto;font-family:ui-monospace,SF Mono,JetBrains Mono,Menlo,Consolas,monospace;font-size:13px;line-height:1.5}.block.code code{font-family:inherit;white-space:pre}.block.button-link{display:flex;align-items:center;gap:10px;background:var(--surface-2);border:1px solid var(--border);border-radius:10px;padding:12px 14px;color:var(--text);font-size:15px;font-weight:600}.block.button-link:active{background:var(--surface-hover)}.block.button-link .button-icon{font-size:18px}.block.button-link .button-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.block.button-link .button-hint{color:var(--muted);flex-shrink:0}.tab-bar{position:fixed;left:0;right:0;bottom:0;background:var(--nav-bg);-webkit-backdrop-filter:saturate(180%) blur(20px);backdrop-filter:saturate(180%) blur(20px);border-top:1px solid var(--border-subtle);padding-bottom:var(--safe-bottom);z-index:20}.tab-bar-inner{max-width:var(--max-width);margin:0 auto;display:flex;align-items:stretch}.tab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:8px 4px 6px;color:var(--muted);font-size:10px;font-weight:500}.tab.active{color:var(--accent)}.tab:active{opacity:.7}.profile-hero{max-width:var(--max-width);margin:0 auto;padding:24px 16px 8px;display:flex;flex-direction:column;align-items:center;text-align:center}.profile-avatar{width:84px;height:84px;border-radius:50%;background:var(--surface-2);border:1px solid var(--border-subtle);overflow:hidden;display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:30px;font-weight:600;letter-spacing:.02em}.profile-avatar img{width:100%;height:100%;object-fit:cover;display:block}.profile-avatar-initials{-webkit-user-select:none;user-select:none}.profile-name{font-size:22px;font-weight:700;margin:14px 0 2px;letter-spacing:-.015em}.profile-handle{color:var(--muted);font-size:14px;margin-bottom:8px}.home-hero{position:relative;padding:24px 16px 16px;max-width:var(--max-width);margin:0 auto;overflow:hidden}.home-hero-accent{position:absolute;top:-80px;left:-40px;width:280px;height:280px;background:radial-gradient(closest-side,var(--accent-soft),transparent 70%);pointer-events:none;z-index:0}.home-hero>*:not(.home-hero-accent){position:relative;z-index:1}.home-hero-badge{color:var(--accent);font-size:11px;font-weight:700;letter-spacing:.12em;margin-bottom:10px}.home-hero h1{font-size:30px;font-weight:700;margin:0 0 8px;letter-spacing:-.025em;line-height:1.15}.home-hero-meta{color:var(--muted);font-size:14px;margin-bottom:12px;font-variant-numeric:tabular-nums}.home-hero-meta strong{color:var(--text);font-weight:600}.continue-card{display:block;max-width:var(--max-width);margin:16px auto 0;padding:16px 18px 14px;background:linear-gradient(135deg,var(--accent) 0%,var(--accent-2) 100%);color:var(--accent-ink);border-radius:16px;box-shadow:0 8px 24px var(--accent-shadow);transition:transform .12s ease}.continue-card:active{transform:scale(.985)}.continue-card-label{font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;opacity:.72}.continue-card-title{font-size:20px;font-weight:700;margin:4px 0 2px;letter-spacing:-.015em;line-height:1.25}.continue-card-meta{font-size:13px;opacity:.7}.continue-card-cta{display:inline-flex;align-items:center;gap:2px;margin-top:10px;font-size:14px;font-weight:700}.list-muted .row-title{color:var(--muted)}.list-muted .row-meta{opacity:.8}.path{max-width:var(--max-width);margin:0 auto;padding:0 16px 8px}.path-step{display:flex;gap:14px;padding:10px 0;color:inherit}.path-step:active .path-dot{transform:scale(.95)}.path-marker{flex-shrink:0;width:32px;display:flex;flex-direction:column;align-items:center}.path-dot{width:32px;height:32px;border-radius:50%;background:var(--surface-2);border:1.5px solid var(--border);color:var(--muted);font-size:13px;font-weight:700;display:flex;align-items:center;justify-content:center;font-variant-numeric:tabular-nums;transition:transform .15s cubic-bezier(.34,1.56,.64,1),background .15s ease}.path-rail{width:2px;flex:1;background:var(--border-subtle);margin:4px 0 -10px;min-height:16px}.path-step.done .path-dot{background:var(--accent);border-color:var(--accent);color:var(--accent-ink)}.path-step.done .path-title{color:var(--muted);text-decoration:line-through;text-decoration-color:var(--border);text-decoration-thickness:1px}.path-step.locked{opacity:.5;cursor:not-allowed}.path-locked .path-dot{background:transparent}.path-body{flex:1;min-width:0;padding-top:4px}.path-title{font-weight:600;font-size:15px;line-height:1.3;letter-spacing:-.005em}.path-sub{color:var(--muted);font-size:13px;margin-top:2px}.action-sticky{position:sticky;bottom:calc(var(--safe-bottom) + 72px);z-index:5;margin:24px -16px 0;padding:10px 16px calc(10px + env(safe-area-inset-bottom,0px));background:linear-gradient(to bottom,transparent,var(--bg) 30%)}.action-sticky .done-button{margin-top:0}.row,.tile,.continue-card{transition:background .1s ease,transform .12s ease}.tile:active,.row:active{transform:scale(.985)}.row-button{width:100%;text-align:left;font:inherit;color:inherit;background:var(--bg);border:0;border-bottom:1px solid var(--border-subtle);cursor:pointer}.row-button:active{background:var(--surface-2)}.row-title.danger{color:var(--danger, #f85149)}.doc-section{margin-top:28px}.doc-content{line-height:1.6;font-size:15px}.doc-content h1,.doc-content h2,.doc-content h3{color:var(--text);font-weight:600;margin:24px 0 12px;line-height:1.3}.doc-content h1{font-size:24px;margin-top:32px}.doc-content h2{font-size:20px}.doc-content h3{font-size:18px}.doc-content p{margin:12px 0;color:var(--text);line-height:1.6}.doc-content ul,.doc-content ol{margin:12px 0;padding-left:24px}.doc-content li{margin:6px 0;color:var(--text)}.doc-content strong{font-weight:700;color:var(--text)}.doc-content em{font-style:italic;color:var(--text)}.doc-content a{color:var(--accent);text-decoration:underline}.doc-content a:hover{text-decoration:none}.doc-content table{width:100%;border-collapse:collapse;margin:16px 0;border:1px solid var(--border);border-radius:6px;overflow:hidden}.doc-content th,.doc-content td{padding:10px 12px;border-bottom:1px solid var(--border-subtle);border-right:1px solid var(--border-subtle);text-align:left;vertical-align:top}.doc-content th:last-child,.doc-content td:last-child{border-right:none}.doc-content tbody tr:nth-child(odd) td{background:var(--surface-2)}.doc-content th{background:var(--surface-2);font-weight:600;font-size:14px;color:var(--text)}.doc-content td{font-size:14px;color:var(--text)}.doc-content tr:last-child th,.doc-content tr:last-child td{border-bottom:none}.doc-content blockquote{margin:16px 0;padding:12px 16px;background:var(--surface-2);border-left:3px solid var(--accent);border-radius:4px;font-style:italic;color:var(--muted)}.doc-content code{background:var(--surface-2);color:var(--text);padding:2px 4px;border-radius:3px;font-family:SF Mono,Monaco,Cascadia Code,Roboto Mono,Consolas,Courier New,monospace;font-size:13px}.doc-content pre{background:var(--surface-2);color:var(--text);padding:12px;border-radius:6px;overflow-x:auto;margin:16px 0;font-family:SF Mono,Monaco,Cascadia Code,Roboto Mono,Consolas,Courier New,monospace;font-size:13px;line-height:1.4}.app-splash{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px;text-align:center;color:var(--text);background:var(--bg)}.app-splash__title{font-size:16px;margin:0}.app-splash__hint{font-size:13px;color:var(--muted);margin-top:8px;max-width:320px}
