.cpp-article{box-sizing:border-box;width:100%;max-width:46rem;margin:0 auto;padding:.75rem 1rem 4rem}.cpp-crumb{font-size:.7rem;text-transform:uppercase;letter-spacing:.16em;color:var(--muted);margin-top:1.5rem;font-variant-numeric:tabular-nums}.cpp-crumb-dot{margin:0 .45rem}.cpp-title{font-size:2rem;font-weight:600;line-height:1.18;letter-spacing:-.02em;margin:.6rem 0 .4rem;overflow-wrap:anywhere;word-break:break-word}.cpp-title-icon{font-size:1.5rem;margin-right:.4rem;display:inline-block;vertical-align:middle;line-height:1}.cpp-subtitle{color:var(--muted);font-size:1.05rem;margin:0 0 2rem;line-height:1.4}.cpp-prose{display:grid;gap:1rem;max-width:100%;min-width:0;font-size:.97rem;line-height:1.6;overflow-wrap:break-word}.cpp-prose h2{margin:0 0 .65rem;font-size:1.12rem;font-weight:600;letter-spacing:0;border-top:none;padding-top:0}.cpp-prose h2:first-of-type{border-top:none;padding-top:0}.lesson-section:not(.lesson-hook):not(.lesson-idea):not(.lesson-concepts):not(.lesson-takeaways) h2{display:flex;align-items:center;gap:.65rem;color:var(--fg)}.lesson-section:not(.lesson-hook):not(.lesson-idea):not(.lesson-concepts):not(.lesson-takeaways) h2:before{content:"";width:.45rem;height:1.55rem;border-radius:999px;background:var(--accent);opacity:.8;flex:0 0 auto}.cpp-prose h3{margin:1.6rem 0 .6rem;font-size:1.1rem;font-weight:600}.cpp-prose h4{margin:1.2rem 0 .4rem;font-size:.95rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}.cpp-prose p{margin:.8rem 0}.cpp-prose ul,.cpp-prose ol{margin:.8rem 0;padding-left:1.5rem}.cpp-prose li{margin:.3rem 0}.cpp-prose strong{color:var(--fg);font-weight:600}.cpp-prose code{font-family:var(--font-mono);background:var(--surface);padding:.1rem .35rem;border-radius:3px;font-size:.9em}.cpp-prose pre{box-sizing:border-box;max-width:100%;contain:inline-size;background:var(--surface-soft, var(--surface))!important;color:var(--fg)!important;border:1px solid var(--border);border-radius:8px;padding:1rem;overflow-x:auto;font-size:.85rem;line-height:1.5;margin:1rem 0}.cpp-prose pre code{display:block;width:max-content;min-width:100%;background:none!important;color:inherit!important;padding:0}.cpp-prose blockquote{border-left:3px solid var(--border);margin:1rem 0;padding:.1rem 0 .1rem 1rem;color:var(--muted);font-style:italic}.cpp-prose .cpp-demo-hook{margin:0 0 2rem;padding:.7rem .85rem;border-left:3px solid var(--accent);background:var(--surface-soft, var(--surface));border-radius:0 6px 6px 0;font-size:.92rem;line-height:1.55;color:var(--fg)}.cpp-prose .cpp-demo-hook strong{color:var(--accent)}.cpp-prose .cpp-demo-hook em{font-style:normal;font-weight:600}.lesson-section,.lesson-details{box-sizing:border-box;width:100%;min-width:0}.lesson-details,.lesson-hook,.lesson-idea,.lesson-concepts,.lesson-takeaways{border:1px solid var(--border);border-radius:8px;background:var(--surface)}.lesson-section{padding:.35rem 0 .15rem}.lesson-hook{padding:1rem;border-left:4px solid var(--accent);background:color-mix(in srgb,var(--accent) 8%,var(--surface))}.lesson-idea{padding:1rem;border-color:color-mix(in srgb,var(--accent) 32%,var(--border))}.lesson-concepts,.lesson-takeaways{padding:1rem;background:var(--surface-soft, var(--surface))}.concept-grid{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:minmax(0,1fr);gap:0;column-gap:1.5rem}@media(min-width:600px){.concept-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.concept-grid>.concept-card:nth-child(2){border-top:none}}.concept-card{display:block;padding:.5rem 0;border-top:1px solid var(--border);line-height:1.5}.concept-card:first-child{border-top:none}.concept-term{color:var(--accent);font-weight:650}.concept-card:has(.concept-detail) .concept-term:after{content:" — ";color:var(--muted);font-weight:400}.concept-detail{color:var(--muted);font-size:.92rem}.lesson-checklist{list-style:none;padding:0;margin:0}.lesson-checklist li{position:relative;padding:.65rem 0 .65rem 1.75rem;border-top:1px solid var(--border)}.lesson-checklist li:first-child{border-top:none}.lesson-checklist li:before{content:"✓";position:absolute;left:0;top:.65rem;color:var(--accent);font-weight:700}.lesson-details{overflow:clip}.lesson-details summary{cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.95rem 1rem;color:var(--fg);min-height:44px}.lesson-details summary::-webkit-details-marker{display:none}.lesson-details summary:after{content:"＋";color:var(--accent);font-weight:700}.lesson-details[open] summary{border-bottom:1px solid var(--border)}.lesson-details[open] summary:after{content:"−"}.lesson-details-title{font-size:1rem;font-weight:650}.lesson-details-body{padding:.85rem 1rem 1rem}.cpp-prose .mermaid{display:grid;place-items:center;background:var(--surface-soft, var(--surface));border:1px solid var(--border);border-radius:8px;padding:1rem;margin:1rem 0;overflow-x:auto;color:var(--fg);min-height:10rem;white-space:normal}.cpp-prose .mermaid svg{display:block;width:100%;max-width:42rem;height:auto}.cpp-prose .mermaid[data-render-error=true]{display:block;font-family:var(--font-mono);font-size:.78rem;color:var(--muted);white-space:pre}.cpp-prose table{width:100%;table-layout:fixed;border-collapse:collapse;margin:1rem 0 1.2rem;font-size:.92rem}.cpp-prose th,.cpp-prose td{border:1px solid var(--border);padding:.55rem .65rem;vertical-align:top;overflow-wrap:anywhere}.cpp-prose th{background:var(--surface);font-weight:600;text-align:left}.cpp-prose .cpp-demo-hook code{font-size:.86em}.cpp-nav{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin-top:3rem;padding-top:1.5rem;border-top:1px solid var(--border)}.cpp-nav-link{display:flex;gap:.6rem;align-items:center;padding:.85rem 1rem;border:1px solid var(--border);border-radius:8px;text-decoration:none;color:var(--fg);min-height:64px;transition:border-color .1s ease,background .1s ease}.cpp-nav-link:hover{border-color:var(--accent);background:var(--surface-soft, var(--surface))}.cpp-nav-next{justify-content:flex-end;text-align:right}.cpp-nav-arrow{color:var(--muted);font-size:1.1rem}.cpp-nav-eyebrow{display:block;font-size:.65rem;text-transform:uppercase;letter-spacing:.16em;color:var(--muted)}.cpp-nav-title{display:block;font-size:.85rem;font-weight:500;margin-top:.15rem}
