:root{--color-bg: #faf7f2;--color-bg-card: #ffffff;--color-bg-code: #1e1e2e;--color-text: #2c2420;--color-text-secondary: #6b5d52;--color-text-muted: #9b8e83;--color-primary: #c2410c;--color-primary-light: #ea580c;--color-primary-bg: #fff7ed;--color-border: #e7e0d8;--color-border-light: #f0ebe4;--color-accent: #0891b2;--color-success: #16a34a;--color-error: #dc2626;--color-warning: #d97706;--font-serif: "Noto Serif SC", "Source Serif 4", Georgia, "Songti SC", serif;--font-sans: "Noto Sans SC", system-ui, -apple-system, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", "Cascadia Code", "SF Mono", Consolas, monospace;--sidebar-width: 280px;--content-max-width: 820px;--radius: 8px;--shadow-sm: 0 1px 2px rgba(44, 36, 32, .06);--shadow-md: 0 4px 12px rgba(44, 36, 32, .08);--shadow-lg: 0 12px 32px rgba(44, 36, 32, .12)}[data-theme=dark]{--color-bg: #1a1614;--color-bg-card: #242020;--color-bg-code: #11111b;--color-text: #e8e0d8;--color-text-secondary: #b0a499;--color-text-muted: #7a6e64;--color-primary: #f97316;--color-primary-light: #fb923c;--color-primary-bg: #2a1f18;--color-border: #3a3430;--color-border-light: #2e2826;--color-accent: #22d3ee;--color-success: #4ade80;--color-error: #f87171;--color-warning: #fbbf24;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 12px rgba(0, 0, 0, .4);--shadow-lg: 0 12px 32px rgba(0, 0, 0, .5)}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth;font-size:16px;-webkit-text-size-adjust:100%;-moz-text-size-adjust:100%;text-size-adjust:100%}body{font-family:var(--font-serif);background-color:var(--color-bg);color:var(--color-text);line-height:1.85;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background-color .3s ease,color .3s ease;overflow-x:hidden;word-break:break-word;-webkit-overflow-scrolling:touch}a{color:var(--color-primary);text-decoration:none;transition:color .2s ease}a:hover{color:var(--color-primary-light)}.site-wrapper{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-width);height:100vh;position:sticky;top:0;overflow-y:auto;background-color:var(--color-bg-card);border-right:1px solid var(--color-border);flex-shrink:0;z-index:100}.sidebar-header{padding:1.5rem 1.5rem 1rem;border-bottom:1px solid var(--color-border-light)}.sidebar-logo{font-family:var(--font-sans);font-size:1.25rem;font-weight:800;color:var(--color-text);display:flex;align-items:center;gap:.5rem}.sidebar-logo .coffee{font-size:1.5rem}.sidebar-subtitle{font-size:.75rem;color:var(--color-text-muted);margin-top:.25rem;font-family:var(--font-sans)}.sidebar-nav{padding:.75rem 0}.stage-group{margin-bottom:.5rem}.stage-title{font-family:var(--font-sans);font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted);padding:.75rem 1.5rem .35rem}.nav-item{display:block;font-family:var(--font-sans);font-size:.875rem;color:var(--color-text-secondary);padding:.4rem 1.5rem .4rem 1.75rem;line-height:1.5;border-left:3px solid transparent;transition:all .15s ease}.nav-item:hover{color:var(--color-primary);background-color:var(--color-primary-bg);border-left-color:var(--color-primary-light)}.nav-item.active{color:var(--color-primary);font-weight:600;background-color:var(--color-primary-bg);border-left-color:var(--color-primary)}.nav-item .chapter-num{display:inline-block;width:1.75rem;color:var(--color-text-muted);font-size:.75rem;font-weight:500}.main-area{flex:1;min-width:0;display:flex;flex-direction:column}.top-bar{height:56px;position:sticky;top:0;background-color:var(--color-bg);border-bottom:1px solid var(--color-border-light);display:flex;align-items:center;padding:0 2rem;gap:1rem;z-index:50;backdrop-filter:blur(12px);background-color:#faf7f2d9}[data-theme=dark] .top-bar{background-color:#1a1614d9}.top-bar-search{flex:1;max-width:400px}.top-bar-search input{width:100%;padding:.4rem .85rem;font-family:var(--font-sans);font-size:.85rem;border:1px solid var(--color-border);border-radius:20px;background-color:var(--color-bg-card);color:var(--color-text);outline:none;transition:border-color .2s ease}.top-bar-search input:focus{border-color:var(--color-primary)}.theme-toggle{background:none;border:1px solid var(--color-border);border-radius:50%;width:36px;height:36px;cursor:pointer;font-size:1.1rem;display:flex;align-items:center;justify-content:center;color:var(--color-text-secondary);transition:all .2s ease}.theme-toggle:hover{border-color:var(--color-primary);color:var(--color-primary)}.lang-toggle{background:none;border:1px solid var(--color-border);border-radius:6px;padding:.3rem .6rem;cursor:pointer;font-family:var(--font-sans);font-size:.8rem;font-weight:700;color:var(--color-text-secondary);transition:all .2s ease;min-width:36px}.lang-toggle:hover{border-color:var(--color-primary);color:var(--color-primary);background-color:var(--color-primary-bg)}.content-wrapper{max-width:var(--content-max-width);margin:0 auto;padding:2.5rem 2rem 5rem;flex:1}.article-header{margin-bottom:2.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--color-border-light)}.article-stage-badge{display:inline-block;font-family:var(--font-sans);font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--color-primary);background-color:var(--color-primary-bg);padding:.25rem .65rem;border-radius:4px;margin-bottom:.75rem}.article-title{font-family:var(--font-sans);font-size:2.25rem;font-weight:800;line-height:1.3;color:var(--color-text);margin-bottom:.75rem}.article-description{font-size:1.05rem;color:var(--color-text-secondary);line-height:1.7}.article-body{font-size:1.0625rem;line-height:1.9}.article-body h2{font-family:var(--font-sans);font-size:1.6rem;font-weight:700;color:var(--color-text);margin:2.5rem 0 1rem;padding-bottom:.5rem;border-bottom:2px solid var(--color-border-light);scroll-margin-top:80px}.article-body h3{font-family:var(--font-sans);font-size:1.25rem;font-weight:600;color:var(--color-text);margin:2rem 0 .75rem;scroll-margin-top:80px}.article-body h4{font-family:var(--font-sans);font-size:1.05rem;font-weight:600;color:var(--color-text);margin:1.5rem 0 .5rem}.article-body p{margin-bottom:1.1rem}.article-body ul,.article-body ol{margin:1rem 0 1.1rem 1.5rem}.article-body li{margin-bottom:.4rem}.article-body ul>li{list-style-type:disc}.article-body ol>li{list-style-type:decimal}.article-body blockquote{border-left:4px solid var(--color-primary);background-color:var(--color-primary-bg);padding:.85rem 1.25rem;margin:1.5rem 0;border-radius:0 var(--radius) var(--radius) 0;color:var(--color-text-secondary)}.article-body blockquote p{margin-bottom:0}.article-body strong{font-weight:700;color:var(--color-text)}.article-body code:not(pre code){font-family:var(--font-mono);font-size:.875em;background-color:var(--color-primary-bg);color:var(--color-primary);padding:.15em .4em;border-radius:4px;font-weight:500}.article-body table{width:100%;border-collapse:collapse;margin:1.5rem 0;font-size:.9rem;font-family:var(--font-sans);display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}.article-body th{background-color:var(--color-bg-card);border:1px solid var(--color-border);padding:.6rem .85rem;text-align:left;font-weight:600}.article-body td{border:1px solid var(--color-border);padding:.6rem .85rem}.article-body hr{border:none;border-top:1px solid var(--color-border-light);margin:2.5rem 0}.article-body pre{margin:1.5rem 0;border-radius:var(--radius);overflow-x:auto;overflow-y:hidden;box-shadow:var(--shadow-md);position:relative;max-width:100%}.article-body pre code{font-family:var(--font-mono);font-size:.875rem;line-height:1.7;display:block;padding:1rem 1.25rem;white-space:pre}.code-runner{margin:1.5rem 0;border-radius:var(--radius);overflow:hidden;border:1px solid var(--color-border);box-shadow:var(--shadow-md)}.code-runner-toolbar{display:flex;align-items:center;justify-content:space-between;padding:.5rem .85rem;background-color:var(--color-bg-code);border-bottom:1px solid rgba(255,255,255,.08)}.code-runner-label{font-family:var(--font-sans);font-size:.75rem;color:#94a3b8;display:flex;align-items:center;gap:.4rem}.code-runner-label .dot{width:8px;height:8px;border-radius:50%;background:var(--color-success)}.code-runner-actions{display:flex;gap:.5rem}.run-btn{font-family:var(--font-sans);font-size:.75rem;font-weight:600;padding:.35rem .85rem;border:none;border-radius:5px;cursor:pointer;display:flex;align-items:center;gap:.35rem;transition:all .2s ease}.run-btn-execute{background:var(--color-success);color:#fff}.run-btn-execute:hover{background:#15803d;transform:translateY(-1px)}.run-btn-execute:disabled{background:var(--color-text-muted);cursor:not-allowed;transform:none}.run-btn-copy{background:#ffffff1a;color:#cbd5e1}.run-btn-copy:hover{background:#fff3}.code-runner textarea{width:100%;min-height:200px;padding:1rem 1.25rem;font-family:var(--font-mono);font-size:.875rem;line-height:1.7;background-color:var(--color-bg-code);color:#e2e8f0;border:none;outline:none;resize:vertical;tab-size:2}.code-runner-output{background-color:#0f0f1a;border-top:1px solid rgba(255,255,255,.08)}.code-runner-output-header{font-family:var(--font-sans);font-size:.75rem;color:#64748b;padding:.5rem .85rem;border-bottom:1px solid rgba(255,255,255,.05);text-transform:uppercase;letter-spacing:.05em}.code-runner-output pre{margin:0;border-radius:0;box-shadow:none}.code-runner-output pre code{padding:.85rem 1.25rem;font-size:.85rem;color:#a3e635;white-space:pre-wrap;word-break:break-word}.code-runner-output .error{color:var(--color-error)}.code-runner-loading{display:flex;align-items:center;gap:.5rem;padding:.85rem 1.25rem;font-family:var(--font-sans);font-size:.85rem;color:#64748b}.code-runner-loading .spinner{width:16px;height:16px;border:2px solid rgba(148,163,184,.2);border-top-color:var(--color-accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.article-nav{display:flex;justify-content:space-between;margin-top:3rem;padding-top:2rem;border-top:1px solid var(--color-border-light);gap:1rem}.article-nav a{display:flex;flex-direction:column;font-family:var(--font-sans);font-size:.8rem;color:var(--color-text-muted);padding:.75rem 1rem;border:1px solid var(--color-border);border-radius:var(--radius);max-width:48%;transition:all .2s ease}.article-nav a:hover{border-color:var(--color-primary);color:var(--color-primary);background-color:var(--color-primary-bg)}.article-nav a .nav-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.05em}.article-nav a .nav-title{font-size:.95rem;font-weight:600;color:var(--color-text);margin-top:.2rem}.article-nav a:hover .nav-title{color:var(--color-primary)}.article-nav .nav-next{text-align:right;margin-left:auto}.home-hero{text-align:center;padding:5rem 2rem 4rem;max-width:720px;margin:0 auto}.home-hero .coffee-icon{font-size:4rem;margin-bottom:1rem;display:block}.home-hero h1{font-family:var(--font-sans);font-size:3rem;font-weight:900;color:var(--color-text);margin-bottom:1rem;letter-spacing:-.02em}.home-hero .tagline{font-size:1.25rem;color:var(--color-text-secondary);line-height:1.7;margin-bottom:2rem}.home-hero .badges{display:flex;justify-content:center;gap:.75rem;flex-wrap:wrap}.home-hero .badge{font-family:var(--font-sans);font-size:.8rem;font-weight:600;padding:.35rem .85rem;border-radius:20px;background-color:var(--color-bg-card);border:1px solid var(--color-border);color:var(--color-text-secondary)}.home-hero .badge.highlight{background-color:var(--color-primary-bg);border-color:var(--color-primary);color:var(--color-primary)}.stages-grid{max-width:1000px;margin:0 auto;padding:0 2rem 4rem;display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.25rem}.stage-card{background-color:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius);padding:1.5rem;transition:all .2s ease;box-shadow:var(--shadow-sm)}.stage-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-md);transform:translateY(-2px)}.stage-card .stage-num{font-family:var(--font-sans);font-size:.7rem;font-weight:700;color:var(--color-primary);text-transform:uppercase;letter-spacing:.08em}.stage-card h3{font-family:var(--font-sans);font-size:1.1rem;font-weight:700;color:var(--color-text);margin:.35rem 0 .5rem}.stage-card p{font-size:.85rem;color:var(--color-text-secondary);line-height:1.6}.stage-card .chapter-count{font-family:var(--font-sans);font-size:.75rem;color:var(--color-text-muted);margin-top:.75rem}.sidebar-toggle{display:none;background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--color-text);padding:0 .5rem}.sidebar-overlay{display:none;position:fixed;inset:0;background:#0006;z-index:99}@media (max-width: 900px){.sidebar{position:fixed;left:-100%;width:var(--sidebar-width);transition:left .3s ease}.sidebar.open{left:0}.sidebar-toggle,.sidebar-overlay.show{display:block}.top-bar{padding:0 1rem;gap:.5rem}.top-bar-search{max-width:none}.content-wrapper{padding:1.5rem 1.25rem 4rem;max-width:100%}.article-title{font-size:1.75rem}.home-hero h1{font-size:2.25rem}.article-nav{flex-direction:column;gap:.75rem}.article-nav a{max-width:100%}.article-nav .nav-next{text-align:left;margin-left:0}}@media (max-width: 640px){:root{--sidebar-width: 260px}html{font-size:15px}.top-bar{height:52px;padding:0 .75rem;gap:.4rem}.sidebar-toggle{font-size:1.3rem}.top-bar-search input{padding:.35rem .75rem;font-size:.8rem}.theme-toggle,.lang-toggle{width:32px;height:32px;min-width:32px;font-size:.75rem;padding:.3rem}.content-wrapper{padding:1.25rem 1rem 3rem}.article-header{margin-bottom:1.75rem;padding-bottom:1rem}.article-title{font-size:1.5rem;line-height:1.35}.article-description{font-size:.95rem}.article-stage-badge{font-size:.65rem;padding:.2rem .5rem}.article-body{font-size:1rem;line-height:1.85}.article-body h2{font-size:1.35rem;margin:2rem 0 .85rem}.article-body h3{font-size:1.15rem;margin:1.5rem 0 .6rem}.article-body h4{font-size:1rem}.article-body p{margin-bottom:1rem}.article-body ul,.article-body ol{margin:.85rem 0 1rem 1.25rem}.article-body blockquote{padding:.7rem 1rem;margin:1.25rem 0}.article-body pre{margin:1.25rem 0}.article-body pre code{font-size:.8rem;padding:.85rem 1rem}.article-body code:not(pre code){font-size:.85em;padding:.1em .3em}.article-body table{font-size:.82rem}.article-body th,.article-body td{padding:.5rem .65rem}.home-hero{padding:3rem 1rem 2.5rem}.home-hero .coffee-icon{font-size:3rem}.home-hero h1{font-size:1.85rem}.home-hero .tagline{font-size:1.05rem}.home-hero .badges{gap:.5rem}.home-hero .badge{font-size:.72rem;padding:.3rem .7rem}.stages-grid{grid-template-columns:1fr;gap:1rem;padding:0 1rem 3rem}.stage-card{padding:1.15rem}.code-runner textarea{font-size:.8rem;padding:.85rem 1rem;min-height:160px}.code-runner-output pre code{font-size:.78rem;padding:.7rem 1rem}.run-btn{font-size:.7rem;padding:.3rem .7rem}.article-nav{margin-top:2rem;padding-top:1.5rem}.article-nav a{padding:.6rem .85rem}.article-nav a .nav-title{font-size:.88rem}}@media (max-width: 380px){html{font-size:14px}.article-title{font-size:1.35rem}.home-hero h1{font-size:1.65rem}.top-bar-search{display:none}.top-bar{justify-content:space-between}}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-bg)}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}
