.v-ide{--bg: #0d1117;--panel: #161b22;--panel-2: #1c2330;--text: #c9d1d9;--muted: #8b949e;--line: #30363d;--accent: #58a6ff;--accent-soft: rgba(88, 166, 255, .12);background:var(--bg);color:var(--text);font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,sans-serif;font-size:1rem;line-height:1.7}.v-ide .eyebrow{margin:0 0 .7rem;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.74rem;letter-spacing:.04em;color:var(--accent)}.v-ide h1{margin:0;line-height:1.12;letter-spacing:-.015em}.v-ide code{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.9em;background:var(--panel-2);color:#e6edf3;border:1px solid var(--line);border-radius:5px;padding:.08rem .34rem}.v-ide .home-shell{width:min(72ch,100% - 2rem);margin:0 auto;padding:clamp(2.5rem,8vw,5rem) 0 4rem}.v-ide .home-intro h1{font-size:clamp(2.1rem,8.5vw,3.6rem)}.v-ide .home-lede{max-width:62ch;margin:1.1rem 0 1.8rem;color:var(--muted)}.v-ide .primary-link{display:inline-flex;align-items:center;min-height:44px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.9rem;font-weight:600;text-decoration:none;color:var(--bg);background:var(--accent);border-radius:6px;padding:0 1.1rem}.v-ide .primary-link:before{content:"›_ ";opacity:.7}.v-ide .chapter-list{margin-top:2.5rem}.v-ide .chapter-grid{list-style:none;margin:0;padding:0;display:grid;gap:.6rem}.v-ide .chapter-card{display:grid;grid-template-columns:2.5rem 1fr;gap:.1rem .9rem;padding:.95rem 1.1rem;background:var(--panel);border:1px solid var(--line);border-radius:8px;text-decoration:none}.v-ide .chapter-card em{grid-row:span 2;align-self:center;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-style:normal;font-weight:600;color:var(--accent)}.v-ide .chapter-card strong{font-size:1.05rem}.v-ide .chapter-card small{color:var(--muted)}.v-ide .chapter-card:hover{border-color:var(--accent);background:var(--panel-2)}.v-ide .lesson-nav-disclosure{background:var(--panel);border-bottom:1px solid var(--line)}.v-ide .lesson-nav-disclosure summary{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.85rem clamp(1rem,4vw,1.4rem);font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.86rem}.v-ide .lesson-nav-disclosure summary::-webkit-details-marker{display:none}.v-ide .nav-current{display:inline-flex;align-items:baseline;gap:.5rem;font-weight:600}.v-ide .nav-current em{font-style:normal;color:var(--accent)}.v-ide .nav-progress{color:var(--muted);font-variant-numeric:tabular-nums}.v-ide .lesson-sidebar{padding:.4rem clamp(1rem,4vw,1.4rem) 1.1rem}.v-ide .site-mark{display:block;font-weight:700;text-decoration:none}.v-ide .lesson-sidebar nav{display:grid;gap:.1rem;margin-top:.7rem}.v-ide .nav-link{display:grid;grid-template-columns:2rem 1fr;align-items:center;gap:.5rem;min-height:44px;padding:0 .6rem;border-radius:6px;font-size:.9rem;color:var(--muted);text-decoration:none}.v-ide .nav-link em{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-style:normal;font-size:.78rem}.v-ide .nav-link:hover{color:var(--text);background:var(--panel-2)}.v-ide .nav-link.active{color:var(--accent);background:var(--accent-soft)}.v-ide .lesson-main{width:min(74ch,100% - 2rem);margin:0 auto;padding:clamp(1.6rem,6vw,2.8rem) 0 3.5rem}.v-ide .lesson-header{padding-bottom:1.3rem;margin-bottom:1.5rem;border-bottom:1px solid var(--line)}.v-ide .lesson-header h1{font-size:clamp(1.8rem,6.5vw,2.8rem)}.v-ide .lesson-content h1{display:none}.v-ide .lesson-content h2{margin:2.1rem 0 .7rem;font-size:1.35rem;line-height:1.25}.v-ide .lesson-content h3{margin:1.5rem 0 .5rem;font-size:1.1rem}.v-ide .lesson-content a{color:var(--accent)}.v-ide .lesson-content li{margin:.3rem 0}.v-ide .lesson-content pre{border:1px solid var(--line);border-radius:8px;margin:1.3rem 0;padding:1rem;overflow-x:auto;-webkit-overflow-scrolling:touch}.v-ide .lesson-content pre code{font-size:.84rem;line-height:1.6;background:transparent;border:0;padding:0}.v-ide .pager{display:grid;gap:.7rem;margin-top:2.5rem;padding-top:1.4rem;border-top:1px solid var(--line)}.v-ide .pager a{display:block;padding:.9rem 1rem;background:var(--panel);border:1px solid var(--line);border-radius:8px;text-decoration:none}.v-ide .pager a:hover{border-color:var(--accent)}.v-ide .pager span{display:block;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.74rem;color:var(--muted)}.v-ide .pager strong{display:block;margin-top:.2rem;color:var(--accent)}@media(min-width:880px){.v-ide .lesson-shell{display:grid;grid-template-columns:17rem minmax(0,1fr);align-items:start}.v-ide .lesson-nav-disclosure summary{display:none}.v-ide .lesson-nav-disclosure{position:sticky;top:0;border-bottom:0;border-right:1px solid var(--line);background:var(--bg);height:100vh}.v-ide .lesson-sidebar{display:block;height:100vh;overflow-y:auto;padding:2rem 1.25rem}}.v-ide .curriculum-overview{width:min(78ch,100% - 2rem);margin:0 auto;padding:clamp(2.2rem,8vw,4.5rem) 0 4rem}.v-ide .overview-head h1{font-size:clamp(2.1rem,8.5vw,3.6rem)}.v-ide .overview-lede{max-width:64ch;margin:1.1rem 0 1.8rem;color:var(--muted);font-variant-numeric:tabular-nums}.v-ide .overview-note{max-width:64ch;margin:1.8rem 0 0;padding-top:1.2rem;border-top:1px solid var(--line);color:var(--muted);font-size:.92rem;line-height:1.6}.v-ide .overview-note a{color:var(--accent);text-decoration:none}.v-ide .overview-note a:hover{text-decoration:underline}.v-ide .overview-figure{margin:2rem 0 0}.v-ide .overview-figure img{display:block;width:100%;height:auto;border:1px solid var(--line);border-radius:12px}.v-ide .theme-list{list-style:none;margin:2.5rem 0 0;padding:0;display:grid;gap:1.5rem}.v-ide .theme-block{border:1px solid var(--line);border-radius:12px;background:var(--panel);padding:1.1rem 1.1rem .6rem}.v-ide .theme-head{display:grid;grid-template-columns:2.5rem 1fr;align-items:baseline;gap:.8rem;padding-bottom:.6rem;border-bottom:1px solid var(--line)}.v-ide .theme-head em{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-style:normal;font-size:1.1rem;color:var(--accent)}.v-ide .theme-head h2{margin:0;font-size:1.15rem;line-height:1.25}.v-ide .concept-list{list-style:none;margin:0;padding:.4rem 0}.v-ide .concept-row{display:grid;grid-template-columns:2.5rem 1fr auto;align-items:center;gap:.8rem;min-height:44px;padding:0 .4rem;border-radius:6px;text-decoration:none;color:var(--text)}.v-ide .concept-row:hover{background:var(--panel-2)}.v-ide .concept-no{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.82rem;color:var(--muted)}.v-ide .concept-row:hover .concept-name{color:var(--accent)}.v-ide .concept-count{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.74rem;color:var(--muted)}.v-ide .curriculum-nav{display:grid;gap:.1rem;margin-top:.7rem}.v-ide .nav-group+.nav-group{margin-top:.1rem}.v-ide .nav-group-title{display:grid;grid-template-columns:2rem 1fr;align-items:center;gap:.5rem;min-height:40px;padding:0 .6rem;border-radius:6px;font-size:.9rem;color:var(--text);text-decoration:none}.v-ide .nav-group-title em{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-style:normal;font-size:.76rem}.v-ide .nav-group-title:hover{color:var(--text);background:var(--panel-2)}.v-ide .nav-group.active>.nav-group-title{color:var(--text);font-weight:600}.v-ide .nav-chapters{display:grid;gap:.05rem;padding-left:2rem;border-left:1px solid var(--line);margin:.1rem 0 .4rem .95rem}.v-ide .nav-sublink{min-height:38px;display:flex;align-items:center;padding:0 .6rem;border-radius:6px;font-size:.86rem;color:var(--text);text-decoration:none}.v-ide .nav-sublink:hover{color:var(--text);background:var(--panel-2)}.v-ide .nav-sublink.active{color:var(--accent);background:var(--accent-soft)}.v-ide .chapter-section{scroll-margin-top:1.25rem}.v-ide .chapter-section+.chapter-section{margin-top:2.75rem}.v-ide .chapter-section-title{margin:0 0 .25rem;padding-top:1.5rem;border-top:1px solid var(--line)}.v-ide .chapter-section:first-of-type .chapter-section-title{border-top:0;padding-top:.5rem}.v-ide .chapter-section-kicker{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.78rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--accent)}.v-ide .chapter-section .lesson-content>h1:first-child{display:none}.v-ide .editor-comment-box{margin-top:3rem;padding:1.1rem;border:1px solid var(--line);border-radius:8px;background:var(--panel)}.v-ide .editor-comment-box h2{margin:0 0 .35rem;font-size:1.1rem;line-height:1.25}.v-ide .editor-comment-box p{margin:0;color:var(--muted);font-size:.92rem;line-height:1.55}.v-ide .editor-comment-form{display:grid;gap:.85rem;margin-top:1rem}.v-ide .editor-comment-form label{display:block;margin-bottom:.3rem;font-size:.85rem;font-weight:600}.v-ide .editor-comment-form select,.v-ide .editor-comment-form textarea{width:100%;border:1px solid var(--line);border-radius:6px;background:var(--bg);color:var(--text);font:inherit}.v-ide .editor-comment-form select{min-height:42px;padding:0 .75rem}.v-ide .editor-comment-form textarea{min-height:9rem;padding:.65rem .75rem;resize:vertical}.v-ide .editor-comment-form select:focus,.v-ide .editor-comment-form textarea:focus{outline:2px solid var(--accent);outline-offset:2px}.v-ide .editor-comment-form button{justify-self:start;min-height:42px;border:0;border-radius:6px;padding:0 1rem;background:var(--accent);color:var(--bg);cursor:pointer;font:inherit;font-size:.9rem;font-weight:700}.v-ide .editor-comment-form button:hover{filter:brightness(1.08)}.v-ide .editor-comment-form button:disabled{cursor:wait;opacity:.65}.v-ide #editor-comment-status{min-height:1.4rem}.v-ide #editor-comment-status a{color:var(--accent)}@media(min-width:880px){.v-ide .theme-head{grid-template-columns:3rem 1fr}}*,*:before,*:after{box-sizing:border-box}html{-webkit-text-size-adjust:100%;text-size-adjust:100%}body{margin:0;min-width:320px;padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left)}img{max-width:100%;height:auto}a{color:inherit}:where(button,a){-webkit-tap-highlight-color:transparent}.code-mobile{display:none}@media(max-width:879px){.code-desktop{display:none}.code-mobile{display:block}}
