*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root,[data-theme=dark]{--color-bg:#0f1117;--color-surface:#1a1d27;--color-border:#2a2d3a;--color-text:#e2e8f0;--color-muted:#94a3b8;--color-accent:#7c3aed;--color-accent-light:#a78bfa;--color-code-bg:#12141e;--color-prose:#cbd5e1;font-size:16px}[data-theme=light]{--color-bg:#f8fafc;--color-surface:#fff;--color-border:#e2e8f0;--color-text:#1e293b;--color-muted:#64748b;--color-accent:#7c3aed;--color-accent-light:#6d28d9;--color-code-bg:#f1f5f9;--color-prose:#334155}body{background:var(--color-bg);color:var(--color-text);min-height:100vh;font-family:ui-sans-serif,system-ui,-apple-system,sans-serif;line-height:1.6;transition:background .2s,color .2s}a{color:inherit;text-decoration:none}.container{max-width:1100px;margin:0 auto;padding:0 1.5rem}.site-header{border-bottom:1px solid var(--color-border);background:var(--color-bg);z-index:10;padding:1rem 0;position:sticky;top:0}.site-header .container{align-items:center;gap:1rem;display:flex}.site-logo{color:var(--color-accent-light);letter-spacing:-.02em;font-size:1.25rem;font-weight:700}.home-hero{text-align:center;padding:3rem 0 2rem}.home-hero h1{letter-spacing:-.03em;background:linear-gradient(135deg, var(--color-accent-light), #38bdf8);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:.75rem;font-size:clamp(1.75rem,4vw,2.75rem);font-weight:800}.home-hero p{color:var(--color-muted);max-width:48ch;margin:0 auto;font-size:1.1rem}.posts-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.25rem;padding:2rem 0 4rem;display:grid}.post-card{background:var(--color-surface);border:1px solid var(--color-border);cursor:pointer;border-radius:12px;flex-direction:column;gap:.75rem;padding:1.5rem;transition:border-color .2s,transform .2s;display:flex}.post-card:hover{border-color:var(--color-accent);transform:translateY(-2px)}.post-card-date{color:var(--color-muted);letter-spacing:.03em;font-size:.8rem}.post-card h2{letter-spacing:-.01em;font-size:1.1rem;font-weight:700;line-height:1.4}.post-card p{color:var(--color-muted);flex:1;font-size:.9rem;line-height:1.6}.tags{flex-wrap:wrap;gap:.4rem;display:flex}.tag{letter-spacing:.04em;color:var(--color-accent-light);text-transform:uppercase;background:#7c3aed26;border:1px solid #7c3aed4d;border-radius:999px;padding:.2rem .6rem;font-size:.7rem;font-weight:600}.post-page{padding:2.5rem 0 5rem}.post-page .container{max-width:780px}.post-header{margin-bottom:2.5rem}.post-header .post-date{color:var(--color-muted);margin-bottom:.75rem;font-size:.85rem}.post-header h1{letter-spacing:-.03em;margin-bottom:1rem;font-size:clamp(1.5rem,3.5vw,2.25rem);font-weight:800;line-height:1.25}.post-content{color:var(--color-text)}.post-content h2{letter-spacing:-.02em;border-bottom:1px solid var(--color-border);margin:2rem 0 .75rem;padding-bottom:.4rem;font-size:1.35rem;font-weight:700}.post-content p{color:var(--color-prose);margin-bottom:1rem;line-height:1.75}.post-content ul,.post-content ol{margin:0 0 1rem 1.5rem}.post-content li{color:var(--color-prose);margin-bottom:.4rem;line-height:1.7}.post-content strong{color:var(--color-text)}.post-content em{color:var(--color-accent-light);font-style:italic}.post-content a{color:var(--color-accent-light);text-underline-offset:3px;-webkit-text-decoration:underline #a78bfa66;text-decoration:underline #a78bfa66;transition:text-decoration-color .2s}.post-content a:hover{-webkit-text-decoration-color:var(--color-accent-light);text-decoration-color:var(--color-accent-light)}.post-content pre{background:var(--color-code-bg);border:1px solid var(--color-border);border-radius:8px;margin:1.25rem 0;padding:1.25rem 1.5rem;overflow-x:auto}.post-content code{color:#a5f3fc;font-family:ui-monospace,Cascadia Code,Fira Code,monospace;font-size:.875rem;line-height:1.6}[data-theme=light] .post-content code{color:#0c6478}.post-content table{border-collapse:collapse;width:100%;margin:1.5rem 0;font-size:.875rem}.post-content th,.post-content td{text-align:left;border:1px solid var(--color-border);padding:.6rem 1rem}.post-content th{background:var(--color-surface);color:var(--color-accent-light);letter-spacing:.03em;font-weight:600}.post-content tr:nth-child(2n) td{background:#ffffff05}.post-content ol{margin:0 0 1rem 1.5rem}.post-content ol li{color:var(--color-prose);margin-bottom:.6rem;line-height:1.7}.post-content p code,.post-content li code{background:var(--color-code-bg);border:1px solid var(--color-border);color:#a5f3fc;border-radius:4px;padding:.1em .4em;font-size:.85em}[data-theme=light] .post-content p code,[data-theme=light] .post-content li code{color:#0c6478}.callout{border-left:3px solid;border-radius:8px;margin:1.5rem 0;padding:1rem 1.25rem}.callout p{margin-bottom:.5rem}.callout p:last-child{margin-bottom:0}.callout pre{margin:.75rem 0 0}.callout-label{text-transform:uppercase;letter-spacing:.08em;margin-bottom:.5rem;font-size:.7rem;font-weight:700;display:inline-block}.callout-note{background:#38bdf80f;border-color:#38bdf8}.callout-note .callout-label{color:#38bdf8}.post-nav{border-top:1px solid var(--color-border);justify-content:space-between;align-items:stretch;gap:1rem;margin-top:3.5rem;padding-top:2rem;display:flex}.nav-btn{background:var(--color-surface);border:1px solid var(--color-border);max-width:44%;color:var(--color-text);border-radius:10px;flex-direction:column;gap:.3rem;padding:.9rem 1.2rem;text-decoration:none;transition:border-color .2s,background .2s;display:flex}.nav-btn:hover{border-color:var(--color-accent);background:#7c3aed14}.nav-btn.prev{align-items:flex-start}.nav-btn.next{align-items:flex-end;margin-left:auto}.nav-label{text-transform:uppercase;letter-spacing:.08em;color:var(--color-muted);font-size:.7rem;font-weight:600}.nav-title{font-size:.9rem;font-weight:600;line-height:1.3}.nav-btn.next .nav-title{text-align:right}.header-controls{align-items:center;gap:.5rem;margin-left:auto;display:flex}.lang-toggle{border:1px solid var(--color-border);height:32px;color:var(--color-muted);cursor:pointer;letter-spacing:.05em;background:0 0;border-radius:8px;justify-content:center;align-items:center;padding:0 .6rem;font-size:.75rem;font-weight:700;transition:color .2s,border-color .2s,background .2s;display:inline-flex}.lang-toggle:hover{color:var(--color-text);border-color:var(--color-accent);background:#7c3aed14}.theme-toggle{border:1px solid var(--color-border);width:32px;height:32px;color:var(--color-muted);cursor:pointer;background:0 0;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;transition:color .2s,border-color .2s,background .2s;display:inline-flex}.theme-toggle:hover{color:var(--color-text);border-color:var(--color-accent);background:#7c3aed14}.home-btn{color:var(--color-muted);border:1px solid var(--color-border);border-radius:8px;align-items:center;gap:.4rem;padding:.4rem .9rem;font-size:.85rem;text-decoration:none;transition:color .2s,border-color .2s;display:inline-flex}.home-btn:hover{color:var(--color-text);border-color:var(--color-accent)}.home-section{margin-bottom:3.5rem}.section-heading{text-transform:uppercase;letter-spacing:.12em;color:var(--color-muted);align-items:center;gap:.75rem;margin-bottom:1.25rem;font-size:.75rem;font-weight:700;display:flex}.section-heading:after{content:"";background:var(--color-border);flex:1;height:1px}.tutorials-list{flex-direction:column;gap:1rem;display:flex}.tutorial-card{background:var(--color-surface);border:1px solid var(--color-border);color:var(--color-text);border-radius:12px;flex-direction:column;gap:.6rem;padding:1.5rem 1.75rem;text-decoration:none;transition:border-color .2s,transform .2s;display:flex;position:relative}.tutorial-card:hover{border-color:var(--color-accent);transform:translateY(-2px)}.tutorial-card-parts{letter-spacing:.08em;text-transform:uppercase;color:var(--color-accent-light);font-size:.72rem;font-weight:600}.tutorial-card h2{letter-spacing:-.02em;font-size:1.2rem;font-weight:800;line-height:1.3}.tutorial-card-subtitle{color:var(--color-accent-light);font-size:.9rem;font-style:italic}.tutorial-card p:not(.tutorial-card-subtitle){color:var(--color-muted);font-size:.9rem;line-height:1.6}.tutorial-card-cta{color:var(--color-accent-light);margin-top:.25rem;font-size:.85rem;font-weight:600}.series-page{padding:2.5rem 0 5rem}.series-page .container{max-width:780px}.series-hero{border-bottom:1px solid var(--color-border);margin-bottom:3rem;padding-bottom:2rem}.series-label{text-transform:uppercase;letter-spacing:.1em;color:var(--color-accent-light);margin-bottom:.75rem;font-size:.75rem;font-weight:600}.series-hero h1{letter-spacing:-.03em;margin-bottom:.4rem;font-size:clamp(1.5rem,3.5vw,2.25rem);font-weight:800;line-height:1.2}.series-subtitle{color:var(--color-accent-light);margin-bottom:.75rem;font-size:1rem;font-style:italic}.series-description{color:var(--color-muted);margin-bottom:1rem;line-height:1.7}.parts-heading{text-transform:uppercase;letter-spacing:.1em;color:var(--color-muted);margin-bottom:1rem;font-size:.75rem;font-weight:700}.parts-list{flex-direction:column;gap:.5rem;list-style:none;display:flex}.part-link{background:var(--color-surface);border:1px solid var(--color-border);color:var(--color-text);border-radius:10px;align-items:center;gap:1rem;padding:.9rem 1.2rem;text-decoration:none;transition:border-color .2s,background .2s;display:flex}.part-link:hover{border-color:var(--color-accent);background:#7c3aed0f}.part-number{color:var(--color-accent-light);min-width:2ch;font-family:ui-monospace,monospace;font-size:.75rem;font-weight:700}.part-title{flex:1;font-size:.95rem;font-weight:500}.part-arrow{color:var(--color-muted);font-size:.9rem;transition:transform .2s}.part-link:hover .part-arrow{color:var(--color-accent-light);transform:translate(4px)}.series-start{margin-top:2rem}.start-btn{background:var(--color-accent);color:#fff;border-radius:10px;align-items:center;padding:.75rem 1.5rem;font-size:.95rem;font-weight:600;text-decoration:none;transition:background .2s,transform .2s;display:inline-flex}.start-btn:hover{background:#6d28d9;transform:translateY(-1px)}.part-meta{flex-wrap:wrap;align-items:center;gap:.75rem;margin-bottom:.75rem;display:flex}.part-series-label{color:var(--color-accent-light);font-size:.8rem;font-weight:600}.part-series-label a{color:inherit;text-underline-offset:3px;-webkit-text-decoration:underline #a78bfa66;text-decoration:underline #a78bfa66}.part-series-label a:hover{-webkit-text-decoration-color:var(--color-accent-light);text-decoration-color:var(--color-accent-light)}.part-progress{color:var(--color-muted);background:var(--color-surface);border:1px solid var(--color-border);border-radius:999px;padding:.15rem .6rem;font-size:.75rem}.not-found{text-align:center;padding:6rem 1rem}.not-found h2{margin-bottom:.75rem;font-size:2rem;font-weight:700}.not-found p{color:var(--color-muted);margin-bottom:1.5rem}@media (width<=600px){.posts-grid{grid-template-columns:1fr}.post-nav{flex-direction:column;align-items:stretch}.nav-btn,.nav-btn.next{align-items:flex-start;max-width:100%;margin-left:0}.nav-btn.next .nav-title{text-align:left}}
