@import"https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@300;400;500;600;700&family=Source+Serif+4:ital,opsz,wght@0,8..60,400;0,8..60,600;1,8..60,400&family=JetBrains+Mono:wght@400;500&display=swap";:root{--page: #ECEAE6;--surface: #FFFFFF;--surface2: #F3F2EF;--ink: #18192A;--accent: #E8442A;--blue: #2B5CE6;--muted: #8A8F9E;--border: #D8D5D0;--green: #2A7A52;--amber: #C47F17;--purple: #7C3AED;--font-display: "Space Grotesk", system-ui, sans-serif;--font-body: "Source Serif 4", Georgia, serif;--font-mono: "JetBrains Mono", "Fira Code", monospace}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background-color:var(--page);background-image:radial-gradient(circle,rgba(24,25,42,.12) 1px,transparent 1px);background-size:24px 24px;color:var(--ink);font-family:var(--font-body);font-size:1rem;line-height:1.75;-webkit-font-smoothing:antialiased}nav{position:sticky;top:0;z-index:100;background:#eceae6eb;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border);padding:0 2rem;height:52px;display:flex;align-items:center;gap:.75rem;font-family:var(--font-display);font-size:.875rem}nav a{color:var(--muted);text-decoration:none;transition:color .15s}nav a:hover{color:var(--ink)}nav .sep{color:var(--border)}nav .current{color:var(--ink);font-weight:600}.toc{position:fixed;top:52px;right:0;width:220px;height:calc(100vh - 52px);overflow-y:auto;padding:1.5rem 1.25rem;border-left:1px solid var(--border);background:var(--surface)}.toc h4{font-family:var(--font-display);font-size:.65rem;text-transform:uppercase;letter-spacing:2px;color:var(--muted);margin-bottom:.875rem;font-weight:600}.toc a{display:block;font-size:.8rem;color:var(--muted);text-decoration:none;padding:.3rem .6rem;border-left:2px solid transparent;transition:color .15s,border-color .15s;line-height:1.4;font-family:var(--font-display)}.toc a:hover,.toc a.active{color:var(--ink);border-left-color:var(--accent)}.sidebar{position:fixed;top:52px;left:0;width:240px;height:calc(100vh - 52px);overflow-y:auto;padding:1.5rem 1.25rem;border-right:1px solid var(--border);background:var(--surface)}.sidebar-back{display:block;font-family:var(--font-display);font-size:.8rem;color:var(--muted);text-decoration:none;margin-bottom:1.5rem;transition:color .15s}.sidebar-back:hover{color:var(--ink)}.sidebar h4{font-family:var(--font-display);font-size:.65rem;text-transform:uppercase;letter-spacing:2px;color:var(--muted);margin-bottom:.875rem;font-weight:600}.sidebar-link{display:block;font-size:.8rem;color:var(--muted);text-decoration:none;padding:.4rem .6rem;border-left:2px solid transparent;transition:color .15s,border-color .15s;line-height:1.4;font-family:var(--font-display)}.sidebar-link:hover,.sidebar-link.active{color:var(--ink);border-left-color:var(--accent)}article{max-width:clamp(780px,72vw,1200px);margin:0 220px 0 auto;padding:3rem 2.5rem 6rem;background:var(--surface);min-height:100vh;box-shadow:1px 0 0 var(--border),-1px 0 0 var(--border)}body:has(.sidebar) article{margin-left:240px;margin-right:220px;width:calc(100% - 460px)}h1{font-family:var(--font-display);font-size:2.5rem;font-weight:700;letter-spacing:-1.5px;line-height:1.15;color:var(--ink)}h1 em{color:var(--accent);font-style:normal}.subtitle{color:var(--muted);margin-top:.5rem;font-size:.875rem;font-family:var(--font-display);font-weight:400;letter-spacing:.01em}h2{font-family:var(--font-display);font-size:1.3rem;font-weight:600;margin-top:3rem;margin-bottom:.875rem;padding-bottom:.5rem;border-bottom:1px solid var(--border);scroll-margin-top:68px;color:var(--ink);letter-spacing:-.3px}h2 .emoji{margin-right:.35rem}h3{font-family:var(--font-display);font-size:.975rem;font-weight:600;margin-top:1.75rem;margin-bottom:.5rem;color:var(--blue)}p{margin-bottom:1rem}strong{font-weight:700;color:var(--ink)}em{color:var(--blue);font-style:italic}ul,ol{padding-left:1.5rem;margin-bottom:1rem}li{margin-bottom:.4rem}a{color:var(--blue)}.callout{border-left:3px solid var(--blue);background:#2b5ce60f;padding:1rem 1.25rem;border-radius:0 8px 8px 0;margin:1.5rem 0}.callout.tip{border-color:var(--green);background:#2a7a520f}.callout.warn{border-color:var(--amber);background:#c47f170f}.callout.analogy{border-color:var(--accent);background:#e8442a0f}.callout-title{font-family:var(--font-display);font-size:.7rem;text-transform:uppercase;letter-spacing:1.5px;font-weight:700;margin-bottom:.4rem;color:var(--blue)}.callout.tip .callout-title{color:var(--green)}.callout.warn .callout-title{color:var(--amber)}.callout.analogy .callout-title{color:var(--accent)}pre{background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:1.25rem 1.5rem;overflow-x:auto;margin:1rem 0 1.5rem;position:relative;font-size:.875rem;line-height:1.65;font-family:var(--font-mono)}.code-label{position:absolute;top:.75rem;right:1rem;font-size:.65rem;text-transform:uppercase;letter-spacing:1px;color:var(--muted);font-family:var(--font-display);font-weight:600}code{font-family:var(--font-mono)}p code,li code{background:#2b5ce617;color:var(--blue);padding:1px 5px;border-radius:3px;font-size:.875em}.kw{color:var(--purple);font-weight:500}.fn{color:#1d4ed8}.st{color:var(--green)}.cm{color:var(--muted);font-style:italic}.num{color:var(--accent)}.cls{color:var(--amber);font-weight:600}table{width:100%;border-collapse:collapse;margin:1rem 0 1.5rem;font-size:.875rem;font-family:var(--font-display)}th{text-align:left;padding:.6rem 1rem;background:var(--surface2);color:var(--muted);font-size:.7rem;text-transform:uppercase;letter-spacing:1px;font-weight:600}td{padding:.6rem 1rem;border-bottom:1px solid var(--border)}tr:last-child td{border-bottom:none}tr:hover td{background:var(--surface2)}.o-n{color:var(--accent);font-weight:700;font-family:var(--font-mono)}.o-1{color:var(--blue);font-weight:700;font-family:var(--font-mono)}.o-n2{color:var(--purple);font-weight:700;font-family:var(--font-mono)}.o-logn{color:var(--amber);font-weight:700;font-family:var(--font-mono)}.diagram-wrap{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:1.5rem;margin:1.5rem 0;overflow-x:auto}.diagram-title{font-family:var(--font-display);font-size:.7rem;text-transform:uppercase;letter-spacing:1.5px;color:var(--muted);margin-bottom:1rem;font-weight:600}svg text{font-family:var(--font-mono)}.memory-grid{display:flex;gap:3px;align-items:flex-end;margin:1rem 0;overflow-x:auto;padding-bottom:.5rem}.mem-cell{min-width:52px;height:52px;background:var(--surface2);border:1px solid var(--border);border-radius:6px;display:flex;flex-direction:column;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:.8rem;position:relative;transition:all .3s ease}.mem-cell.used{background:#2b5ce614;border-color:var(--blue)}.mem-cell.highlight{background:#2a7a521a;border-color:var(--green);transform:translateY(-4px);box-shadow:0 4px 12px #2a7a522e}.mem-addr{font-size:.6rem;color:var(--muted);margin-bottom:2px}.mem-val{font-size:.9rem;color:var(--ink);font-weight:700}.mem-idx{position:absolute;top:-22px;font-size:.65rem;color:var(--blue);font-weight:700}.demo-box{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:1.5rem;margin:1.5rem 0}.demo-box h4{font-family:var(--font-display);font-size:.7rem;text-transform:uppercase;letter-spacing:1.5px;color:var(--muted);margin-bottom:1rem;font-weight:600}.demo-controls{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:1rem}.btn{padding:.4rem 1rem;background:var(--surface2);border:1px solid var(--border);color:var(--ink);border-radius:6px;cursor:pointer;font-size:.85rem;font-family:var(--font-display);font-weight:500;transition:background .15s,border-color .15s,color .15s}.btn:hover,.btn.active{background:var(--ink);border-color:var(--ink);color:#fff}.demo-output{background:var(--surface2);border:1px solid var(--border);border-radius:6px;padding:.875rem 1rem;font-family:var(--font-mono);font-size:.85rem;min-height:52px;color:var(--green)}.demo-array{display:flex;gap:4px;margin:1rem 0;flex-wrap:wrap}.arr-cell{width:44px;height:44px;background:#2b5ce612;border:1px solid var(--blue);border-radius:5px;display:flex;flex-direction:column;align-items:center;justify-content:center;font-family:var(--font-mono);transition:all .25s ease;position:relative}.arr-cell .arr-idx{font-size:.6rem;color:var(--muted)}.arr-cell .arr-v{font-size:.9rem;font-weight:700;color:var(--ink)}.arr-cell.arr-hi{background:#2a7a521f;border-color:var(--green)}.arr-cell.arr-lo{background:#e8442a1a;border-color:var(--accent)}.arr-cell.arr-swap{background:#c47f171a;border-color:var(--amber)}.tp-wrap{margin:1rem 0}.tp-row{display:flex;gap:4px;margin-bottom:8px}.ptr-label{display:flex;gap:4px}.ptr{font-size:.75rem;font-weight:700;text-align:center;width:44px;color:transparent;font-family:var(--font-display)}.ptr.left{color:var(--green)}.ptr.right{color:var(--accent)}.hashmap-visual{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;margin:1rem 0}.hm-bucket{background:var(--surface2);border:1px solid var(--border);border-radius:6px;padding:.6rem .8rem;font-family:var(--font-mono);font-size:.82rem;display:flex;gap:.5rem;align-items:center;transition:background .25s,border-color .25s}.hm-bucket.active{border-color:var(--green);background:#2a7a5214}.hm-key{color:var(--accent)}.hm-arrow{color:var(--muted)}.hm-val{color:var(--green);font-weight:700}.problem-card{background:var(--surface);border:1px solid var(--border);border-left:3px solid var(--blue);border-radius:0 10px 10px 0;padding:1.25rem 1.5rem;margin:1.5rem 0}.problem-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.problem-title{font-weight:700;font-size:1rem;font-family:var(--font-display)}.difficulty{font-size:.7rem;padding:2px 10px;border-radius:99px;font-weight:700;font-family:var(--font-display)}.diff-easy{background:#2a7a521f;color:var(--green)}.diff-medium{background:#c47f171a;color:var(--amber)}.diff-hard{background:#e8442a1a;color:var(--accent)}.problem-desc{color:var(--muted);font-size:.9rem;line-height:1.65;font-family:var(--font-display)}.problem-link{display:inline-block;margin-top:.75rem;color:var(--blue);font-size:.875rem;text-decoration:none;font-family:var(--font-display);font-weight:500}.problem-link:hover{text-decoration:underline}.problem-header-right{display:flex;align-items:center;gap:.5rem}.problem-done-btn{padding:.2rem .6rem;border:1.5px solid var(--border);border-radius:20px;background:transparent;color:var(--muted);font-size:.72rem;font-weight:700;font-family:var(--font-display);cursor:pointer;transition:border-color .15s,color .15s,background .15s;white-space:nowrap}.problem-done-btn:hover{border-color:var(--green);color:var(--green)}.problem-done-btn.is-done{background:var(--green);border-color:var(--green);color:#fff}.problem-card--done{opacity:.5}.problem-card--done .problem-title{text-decoration:line-through}.hint-details{margin-top:.75rem;font-family:var(--font-display);font-size:.9rem}.hint-details summary{display:inline-flex;align-items:center;gap:.4rem;cursor:pointer;-webkit-user-select:none;user-select:none;color:var(--blue);font-weight:600;font-size:.8rem;text-transform:uppercase;letter-spacing:.8px;list-style:none}.hint-details summary::-webkit-details-marker{display:none}.hint-details summary:before{content:"▶";font-size:.6rem;transition:transform .15s}.hint-details[open] summary:before{transform:rotate(90deg)}.hint-details .hint-body{margin-top:.5rem;padding:.6rem .85rem;background:#2b5ce60f;border-left:2px solid var(--blue);border-radius:0 6px 6px 0;color:var(--muted);line-height:1.65}.solution-details{margin-top:.5rem;font-family:var(--font-display);font-size:.9rem}.solution-details summary{display:inline-flex;align-items:center;gap:.4rem;cursor:pointer;-webkit-user-select:none;user-select:none;color:var(--green);font-weight:600;font-size:.8rem;text-transform:uppercase;letter-spacing:.8px;list-style:none}.solution-details summary::-webkit-details-marker{display:none}.solution-details summary:before{content:"▶";font-size:.6rem;transition:transform .15s}.solution-details[open] summary:before{transform:rotate(90deg)}.solution-details pre{margin-top:.6rem}.solution-details .complexity-line{margin-top:.6rem;padding:.5rem .85rem;background:#2a7a5212;border-left:2px solid var(--green);border-radius:0 6px 6px 0;color:var(--muted);font-size:.85rem}.steps{counter-reset:step}.step{display:flex;gap:1rem;margin-bottom:1.25rem;counter-increment:step}.step:before{content:counter(step);flex-shrink:0;width:26px;height:26px;background:var(--ink);color:#fff;font-family:var(--font-display);font-size:.75rem;font-weight:700;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-top:4px}.step-content p{margin-bottom:0}.home-header{padding:4.5rem 2rem 2.5rem;max-width:680px;margin:0 auto}.home-header h1{font-family:var(--font-display);font-size:clamp(2.25rem,5vw,3.25rem);font-weight:700;letter-spacing:-2px;line-height:1.1;color:var(--ink)}.home-header p{color:var(--muted);font-family:var(--font-body);font-size:1.05rem;margin-top:.875rem;line-height:1.6}.home-main{max-width:680px;margin:0 auto;padding:0 2rem 6rem}.section-label{font-family:var(--font-display);font-size:.65rem;text-transform:uppercase;letter-spacing:2.5px;color:var(--muted);font-weight:600;margin-bottom:1.25rem;padding-bottom:.625rem;border-bottom:1px solid var(--border)}.chapter-list{display:flex;flex-direction:column;margin-bottom:3rem}.chapter-item{position:relative}.chapter-item:not(:last-child):after{content:"";display:block;width:1px;height:1.125rem;background:var(--border);margin-left:2.6rem}.chapter{display:flex;align-items:flex-start;gap:1.125rem;padding:1.125rem 1.375rem;background:var(--surface);border:1px solid var(--border);border-radius:10px;text-decoration:none;color:inherit;transition:box-shadow .15s,border-color .15s;position:relative}.chapter:focus-visible{outline:2px solid var(--blue);outline-offset:2px}.chapter:hover{border-color:var(--blue);box-shadow:0 2px 16px #2b5ce61a}.chapter--complete{border-left:3px solid var(--accent)}.chapter--next{border-left:3px solid var(--blue)}.chapter--locked{opacity:.5}.chapter-num{font-family:var(--font-display);font-size:.7rem;font-weight:700;color:var(--muted);min-width:1.5rem;padding-top:3px;letter-spacing:.5px;-webkit-user-select:none;user-select:none}.chapter--complete .chapter-num{color:var(--accent)}.chapter--next .chapter-num{color:var(--blue)}.chapter-body{flex:1}.chapter-body h3{font-family:var(--font-display);font-size:.95rem;font-weight:600;color:var(--ink);margin:0 0 .2rem}.chapter-body p{font-family:var(--font-display);font-size:.83rem;color:var(--muted);line-height:1.5;margin:0}.chapter-status{font-family:var(--font-display);font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;padding:3px 8px;border-radius:4px;white-space:nowrap;align-self:flex-start;margin-top:2px}.status-complete{background:#e8442a1a;color:var(--accent)}.status-next{background:#2b5ce61a;color:var(--blue)}.status-locked{background:var(--surface2);color:var(--muted)}.home-back{display:inline-block;font-family:var(--font-display);font-size:.8rem;color:var(--muted);text-decoration:none;margin-bottom:1rem}.home-back:hover{color:var(--ink)}.track-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem;margin-bottom:3rem}.track-card{display:flex;flex-direction:column;gap:.75rem;padding:1.75rem;background:var(--surface);border:1px solid var(--border);border-radius:12px;text-decoration:none;color:inherit;border-top:3px solid var(--accent);transition:box-shadow .15s,border-color .15s,transform .15s}.track-card:hover{border-color:var(--blue);box-shadow:0 4px 24px #2b5ce61f;transform:translateY(-2px)}.track-card:focus-visible{outline:2px solid var(--blue);outline-offset:2px}.track-card--locked{border-top-color:var(--border);opacity:.7}.track-card--locked:hover{border-color:var(--border);box-shadow:none;transform:none}.track-tag{font-family:var(--font-display);font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--muted)}.track-card h2{font-family:var(--font-display);font-size:1.4rem;font-weight:700;letter-spacing:-.5px;line-height:1.15;color:var(--ink)}.track-card p{font-family:var(--font-display);font-size:.85rem;color:var(--muted);line-height:1.55;flex:1}.track-cta{font-family:var(--font-display);font-size:.8rem;font-weight:600;color:var(--accent)}.track-card--locked .track-cta{color:var(--muted)}.empty-state{padding:2.5rem;text-align:center;background:var(--surface);border:1px solid var(--border);border-radius:12px}.empty-state p{color:var(--muted);font-family:var(--font-display);font-size:.9rem;margin-bottom:1rem}.empty-state .track-cta{display:inline-block}@media (max-width: 700px){.track-grid{grid-template-columns:1fr}}footer{text-align:center;padding:2.5rem 2rem;color:var(--muted);font-size:.8rem;font-family:var(--font-display);border-top:1px solid var(--border)}@media (max-width: 900px){.toc,.sidebar{display:none}body:has(.sidebar) article{margin-left:0;width:auto}article{margin-right:0}}@media (max-width: 600px){.home-header,.home-main{padding-left:1.25rem;padding-right:1.25rem}article{padding:2rem 1.25rem 4rem}.home-header h1{letter-spacing:-1.5px}.chapter{padding:1rem 1.125rem;gap:.875rem}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{transition:none!important;animation:none!important}html{scroll-behavior:auto}}
