main.craft-doc.lesson article{font-size:14px;line-height:1.75;color:var(--ink)}main.craft-doc.lesson article p{margin:0 0 20px}main.craft-doc.lesson article p.tt-explain{margin-top:22px}main.craft-doc.lesson article em{font-style:italic;color:var(--ink)}main.craft-doc.lesson article strong{color:var(--ink);font-weight:600}main.craft-doc.lesson article a{color:inherit;text-decoration:underline;text-decoration-thickness:.5px;text-underline-offset:3px;text-decoration-color:color-mix(in oklch,var(--accent) 45%,transparent)}main.craft-doc.lesson article a:hover{color:var(--accent);text-decoration-color:currentColor}main.craft-doc.lesson article :not(pre)>code{background:color-mix(in oklch,var(--accent) 8%,var(--bg));color:var(--ink);padding:1px 6px;border-radius:3px;font-family:JetBrains Mono,ui-monospace,monospace;font-size:13px;border:1px solid color-mix(in oklch,var(--accent) 15%,transparent);overflow-wrap:anywhere}main.craft-doc.lesson article h2{margin:44px 0 16px;font-family:var(--font-display);font-weight:500;font-size:22px;letter-spacing:-.01em;color:var(--ink)}main.craft-doc.lesson article h3{margin:32px 0 10px;font-family:var(--font-display);font-weight:500;font-size:17px;letter-spacing:-.005em;color:var(--ink)}main.craft-doc.lesson article ul,main.craft-doc.lesson article ol{padding-left:22px;margin:0 0 22px}main.craft-doc.lesson article li{margin:6px 0}main.craft-doc.lesson article .note{margin:28px 0;padding:16px 18px 16px 42px;position:relative;background:color-mix(in oklch,var(--accent) 4%,var(--bg));border:1px solid color-mix(in oklch,var(--accent) 20%,var(--line));color:var(--mute);font-size:14px;border-radius:4px;line-height:1.7}main.craft-doc.lesson article .note:before{content:"▸";position:absolute;top:16px;left:18px;color:var(--accent);font-weight:600}main.craft-doc.lesson article .note strong{color:var(--accent);font-weight:600;letter-spacing:.04em;text-transform:uppercase;font-size:11px;margin-right:8px}main.craft-doc.lesson article .further-reading{margin:56px 0 0;padding:18px 20px;border:1px solid color-mix(in oklch,var(--accent) 20%,var(--line));border-radius:3px;background:color-mix(in oklch,var(--accent) 2.5%,transparent)}main.craft-doc.lesson article .further-reading h3{font-family:JetBrains Mono,ui-monospace,monospace;font-size:10px;font-weight:600;color:var(--mute-2);letter-spacing:.14em;text-transform:uppercase;margin:0 0 12px;padding:0;border:0}main.craft-doc.lesson article .further-reading ul{list-style:none;padding:0;margin:0}main.craft-doc.lesson article .further-reading li{padding:4px 0;line-height:1.55}main.craft-doc.lesson article .further-reading li .fr-desc{color:var(--mute);font-size:13px;margin-left:6px}main.craft-doc.lesson article .further-reading a{color:var(--ink);text-decoration:none;border-bottom:1px dotted color-mix(in oklch,var(--accent) 40%,transparent)}main.craft-doc.lesson article .further-reading a:hover{color:var(--accent);border-bottom-color:var(--accent)}main.craft-doc.lesson article .further-reading a:after{content:" ↗";color:var(--mute-2);font-size:10px;border:0}main.craft-doc.lesson .post-nav{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:56px;padding-top:24px;border-top:1px solid var(--line);font-size:13px}main.craft-doc.lesson .post-nav a{display:flex;flex-direction:column;gap:4px;color:inherit;text-decoration:none;min-width:0}main.craft-doc.lesson .post-nav a.next{align-items:flex-end;text-align:right}main.craft-doc.lesson .post-nav .dir{color:var(--mute-2);letter-spacing:.06em;text-transform:uppercase;font-size:10px;font-family:JetBrains Mono,ui-monospace,monospace}main.craft-doc.lesson .post-nav .title{color:var(--ink);font-family:var(--font-display);font-size:14px;font-weight:500}main.craft-doc.lesson .post-nav a:hover .title{color:var(--accent)}main.craft-doc.lesson .doc-head .meta .by{color:var(--mute);text-decoration:none}main.craft-doc.lesson .doc-head .meta .by:hover{color:var(--accent)}main.craft-doc.lesson .doc-head .meta{display:flex;flex-wrap:wrap;gap:8px;align-items:baseline;color:var(--mute);font-family:JetBrains Mono,ui-monospace,monospace;font-size:11.5px;letter-spacing:.02em;margin-bottom:14px}main.craft-doc.lesson .doc-head .meta .strong{color:var(--ink)}main.craft-doc.lesson .doc-head .meta .dot{color:var(--mute-2)}main.craft-doc.lesson h1{margin:4px 0 14px;font-family:var(--font-display);font-size:34px;font-weight:500;letter-spacing:-.02em;color:var(--ink)}main.craft-doc.lesson .kicker{margin:0 0 32px;color:var(--mute);font-size:16px;line-height:1.55;max-width:62ch}@media(max-width:560px){main.craft-doc.lesson .post-nav{grid-template-columns:1fr}main.craft-doc.lesson .post-nav a.next{align-items:flex-start;text-align:left}}.tch{margin:32px 0;padding:22px 22px 18px;border:1px solid var(--line);border-radius:6px;background:color-mix(in oklch,var(--accent) 2%,var(--bg))}.tch-title{font-family:JetBrains Mono,ui-monospace,monospace;font-weight:600;font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--mute-2);margin:0 0 10px;padding:0;border:0}.tch-intro{color:var(--ink);font-size:14px;line-height:1.65;margin:0 0 16px}.tch-progress{position:relative;height:3px;background:color-mix(in oklch,var(--accent) 10%,var(--line));border-radius:2px;margin:0 0 18px}.tch-progress-bar{position:absolute;left:0;top:0;bottom:0;background:var(--accent);border-radius:2px;width:0%;transition:width .26s ease-out}.tch-progress-label{position:absolute;right:0;top:8px;font-family:JetBrains Mono,ui-monospace,monospace;font-size:10px;letter-spacing:.08em;color:var(--mute-2);font-variant-numeric:tabular-nums}.tch-page[hidden]{display:none}.tch-caption{display:flex;align-items:center;gap:10px;padding:9px 14px;color:var(--mute);font-size:11.5px;letter-spacing:.04em;text-transform:lowercase;border:1px solid var(--line);border-bottom:0;border-radius:4px 4px 0 0;background:color-mix(in oklch,var(--ink) 4%,var(--bg));font-family:JetBrains Mono,ui-monospace,monospace}.tch-caption-mark{color:color-mix(in oklch,var(--accent) 70%,var(--mute-2));font-weight:600}.tch-caption-lang{margin-left:auto;color:var(--mute-2);letter-spacing:.1em}.tch-code{border-radius:4px;overflow:hidden;margin-bottom:18px;font-size:13px;border:1px solid var(--line)}.tch-caption+.tch-code{border-radius:0 0 4px 4px;border-top:0}.tch-code :global(pre.astro-code){margin:0;padding:14px 16px;font-family:JetBrains Mono,ui-monospace,monospace;line-height:1.55;overflow-x:auto}.tch-prompt{color:var(--ink);font-size:14px;line-height:1.65;margin:0 0 14px}.tch-options{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}.tch-option{display:flex;align-items:center;gap:12px;width:100%;text-align:left;font:inherit;padding:11px 14px;border:1px solid var(--line);background:var(--bg);border-radius:4px;cursor:pointer;color:var(--ink);line-height:1.45;transition:border-color .14s ease,background .14s ease}.tch-option:hover{border-color:color-mix(in oklch,var(--accent) 55%,var(--line))}.tch-option[aria-pressed=true]{border-color:var(--accent);background:color-mix(in oklch,var(--accent) 6%,var(--bg))}.tch-option[data-state=ok]{border-color:#019f68;background:color-mix(in oklch,oklch(62% .14 160) 10%,var(--bg))}.tch-option[data-state=no]{border-color:#de3b3d;background:color-mix(in oklch,oklch(60% .2 25) 8%,var(--bg))}.tch-option[disabled]{cursor:default}.tch-option code{font-family:JetBrains Mono,ui-monospace,monospace;font-size:13px;background:transparent;border:0;padding:0;color:inherit;flex:1;overflow-wrap:anywhere}.tch-option .tch-mark{font-family:JetBrains Mono,ui-monospace,monospace;font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--mute-2)}.tch-option[data-state=ok] .tch-mark:after{content:"correct";color:oklch(48% .14 160)}.tch-option[data-state=no] .tch-mark:after{content:"your pick";color:oklch(45% .2 25)}.tch-explain{margin:22px 0 0;padding:12px 14px;background:color-mix(in oklch,var(--accent) 5%,var(--bg));border:1px solid color-mix(in oklch,var(--accent) 18%,var(--line));color:var(--mute);font-size:13px;line-height:1.65;border-radius:4px}.tch-explain strong{color:var(--ink);font-weight:600;margin-right:4px}.tch-explain code{background:color-mix(in oklch,var(--accent) 10%,var(--bg));border:1px solid color-mix(in oklch,var(--accent) 18%,transparent);padding:1px 5px;border-radius:3px;font-family:JetBrains Mono,ui-monospace,monospace;font-size:12px}.tch-bar{margin-top:18px;display:flex;gap:10px;align-items:center}.tch-bar [data-tch-next]{margin-left:auto}.tch-btn{font:inherit;font-size:13px;padding:7px 14px;border-radius:4px;cursor:pointer;letter-spacing:.04em;transition:background .16s ease,color .16s ease,border-color .16s ease}.tch-btn-primary{background:var(--ink);color:var(--bg);border:1px solid var(--ink)}.tch-btn-primary:hover{background:var(--accent);border-color:var(--accent)}.tch-btn-primary[disabled]{opacity:.4;cursor:not-allowed;background:var(--mute-2);border-color:var(--mute-2)}.tch-btn-ghost{background:transparent;color:var(--mute);border:1px solid var(--line)}.tch-btn-ghost:hover{color:var(--accent);border-color:var(--accent)}.tch-btn-ghost[disabled]{opacity:.4;cursor:not-allowed}.tch-final{margin-top:18px;padding:14px 16px;border:1px solid color-mix(in oklch,var(--accent) 40%,transparent);border-radius:4px;background:color-mix(in oklch,var(--accent) 4%,var(--bg));display:grid;gap:4px}.tch-final-label{font-family:JetBrains Mono,ui-monospace,monospace;font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--mute-2)}.tch-final-score{font-family:var(--font-display, Georgia, serif);font-size:26px;color:var(--accent);font-weight:500}.tch-final-note{color:var(--mute);font-size:13px;line-height:1.55}.tvar{margin:32px 0;padding:18px 18px 14px;border:1px solid var(--line);border-radius:6px;background:color-mix(in oklch,var(--accent) 1.5%,var(--bg))}.tvar-title{font-family:JetBrains Mono,ui-monospace,monospace;font-weight:600;font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--mute-2);margin:0 0 10px;padding:0;border:0}.tvar-intro{color:var(--ink);font-size:14px;line-height:1.65;margin:0 0 14px}.tvar-tabs{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:12px;border-bottom:1px solid var(--line);padding-bottom:0}.tvar-tab{font:inherit;font-family:JetBrains Mono,ui-monospace,monospace;font-size:11.5px;letter-spacing:.04em;padding:8px 12px;border:1px solid transparent;border-bottom:0;background:transparent;color:var(--mute);cursor:pointer;border-radius:4px 4px 0 0;transition:color .14s ease,background .14s ease,border-color .14s ease;margin-bottom:-1px}.tvar-tab:hover{color:var(--accent)}.tvar-tab[aria-selected=true]{color:var(--ink);background:var(--bg);border-color:var(--line);border-bottom-color:var(--bg)}.tvar-pane[hidden]{display:none}.tvar-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}@media(max-width:720px){.tvar-grid{grid-template-columns:1fr}}.tvar-col{display:flex;flex-direction:column}.tvar-caption{display:flex;align-items:center;gap:10px;padding:9px 14px;color:var(--mute);font-size:11.5px;letter-spacing:.04em;text-transform:lowercase;border:1px solid var(--line);border-bottom:0;border-radius:4px 4px 0 0;background:color-mix(in oklch,var(--ink) 4%,var(--bg));font-family:JetBrains Mono,ui-monospace,monospace}.tvar-caption-mark{color:color-mix(in oklch,var(--accent) 70%,var(--mute-2));font-weight:600}.tvar-caption-lang{margin-left:auto;color:var(--mute-2);letter-spacing:.1em}.tvar-caption-right .tvar-caption-mark{color:var(--accent)}.tvar-code,.tvar-inferred{border:1px solid var(--line);border-radius:0 0 4px 4px;overflow:hidden;font-size:12.5px;flex:1;min-width:0}.tvar-inferred{background:color-mix(in oklch,var(--accent) 4%,var(--bg))}.tvar-code :global(pre.astro-code),.tvar-inferred :global(pre.astro-code){margin:0;padding:12px 14px;font-family:JetBrains Mono,ui-monospace,monospace;line-height:1.55;overflow-x:auto}.tvar-note{margin:10px 0 0;color:var(--mute);font-size:12.5px;line-height:1.6}.tvar-note code{font-family:JetBrains Mono,ui-monospace,monospace;font-size:11.5px;padding:1px 5px;border-radius:3px;background:color-mix(in oklch,var(--accent) 8%,var(--bg));border:1px solid color-mix(in oklch,var(--accent) 15%,transparent)}
