@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=Lato:wght@400;700&family=JetBrains+Mono:wght@400;500&display=swap";
:root{--color-bg:#fff;--color-bg-secondary:#fafafa;--color-bg-tertiary:#f5f5f5;--color-surface:#fff;--color-text-primary:#222;--color-text-secondary:#666;--color-text-tertiary:#999;--color-accent:#dc143c;--color-accent-hover:#b8102f;--color-accent-light:#fde8ec;--color-success:#2e7d32;--color-warning:#f57c00;--color-error:#c62828;--color-destructive:#c62828;--color-info:#1565c0;--color-primary:#dc143c;--color-link:#1565c0;--color-border:#e0e0e0;--color-divider:#eee;--font-primary:"Inter", -apple-system, BlinkMacSystemFont, sans-serif;--font-body:"Lato", "Inter", sans-serif;--font-mono:"JetBrains Mono", "Fira Code", monospace;--text-xs:.75rem;--text-sm:.875rem;--text-base:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:1.875rem;--text-4xl:2.25rem;--space-1:.25rem;--space-2:.5rem;--space-3:.75rem;--space-4:1rem;--space-5:1.5rem;--space-6:2rem;--space-7:2.5rem;--space-8:3rem;--space-10:4rem;--space-12:6rem;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--radius-full:9999px;--ease-default:cubic-bezier(.4, 0, .2, 1);--duration-fast:.15s;--duration-normal:.25s;--duration-slow:.4s;--bp-mobile:480px;--bp-tablet:768px;--bp-desktop:1024px;--bp-wide:1280px;--max-content-width:1440px;--article-max-width:680px;--sidebar-left-width:220px;--sidebar-right-width:260px;--header-height:64px;--header-height-editor:48px;--shadow-sm:0 1px 4px #0000000f;--shadow-md:0 4px 16px #00000014;--shadow-lg:0 8px 32px #0000001f;--shadow-toolbar:0 4px 12px #00000026}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}html,body{max-width:100vw;overflow-x:hidden}@media (max-width:768px){body{padding-bottom:calc(56px + env(safe-area-inset-bottom))}}body{font-family:var(--font-body);font-size:var(--text-base);letter-spacing:.01em;font-feature-settings:"kern", "liga";color:var(--color-text-primary);background:var(--color-bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.8}h1,h2,h3,h4,h5,h6{font-family:var(--font-primary);letter-spacing:-.01em;color:var(--color-text-primary);font-weight:700}h1{font-size:var(--text-3xl);line-height:1.3}h2{font-size:var(--text-2xl);line-height:1.35}h3{font-size:var(--text-xl);line-height:1.4}h4{font-size:var(--text-lg);line-height:1.5}h5{font-size:var(--text-base);line-height:1.6}h6{font-size:var(--text-sm);line-height:1.6}a{color:inherit;text-decoration:none}a:hover{text-decoration:underline}img{max-width:100%;height:auto;display:block}code,pre{font-family:var(--font-mono);font-size:var(--text-sm)}pre{background:var(--color-bg-tertiary);border-radius:var(--radius-md);padding:var(--space-4);overflow-x:auto}.article-body{font-family:var(--font-body);font-size:var(--text-base);color:var(--color-text-primary);line-height:1.8}.article-body p{max-width:var(--article-max-width);margin:0 auto var(--space-4)}.article-body h2,.article-body h3{max-width:var(--article-max-width);margin:var(--space-6) auto var(--space-3)}.article-body blockquote{max-width:var(--article-max-width);margin:var(--space-5) auto;padding:var(--space-3) var(--space-5);border-left:3px solid var(--color-border);color:var(--color-text-secondary);background:var(--color-bg-secondary);font-style:italic}.article-body img{max-width:var(--article-max-width);margin:var(--space-5) auto;border-radius:var(--radius-md)}.paywall{text-align:center;padding:var(--space-8) 0;margin:var(--space-6) 0;position:relative}.paywall:before{content:"";background:linear-gradient(to bottom, transparent, var(--color-bg));pointer-events:none;height:80px;position:absolute;top:0;left:0;right:0}@keyframes heartBeat{0%{transform:scale(1)}25%{transform:scale(1.3)}50%{transform:scale(.95)}to{transform:scale(1)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes pageEnter{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.page-enter{animation:pageEnter var(--duration-normal) var(--ease-default)}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px;border-radius:var(--radius-sm)}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-text-tertiary)}.iframe-embed-wrapper{width:100%;margin:var(--space-4) 0;border-radius:var(--radius-md);position:relative;overflow:hidden}.iframe-embed-wrapper iframe{border-radius:var(--radius-md);border:0;width:100%;min-height:320px;display:block}div[data-youtube-video]{width:100%;margin:var(--space-4) 0;border-radius:var(--radius-md);padding-bottom:56.25%;position:relative;overflow:hidden}div[data-youtube-video] iframe{border-radius:var(--radius-md);border:0;width:100%;height:100%;position:absolute;top:0;left:0}.toc-block{background:var(--color-background-alt,#f8f9fa);border:1px solid var(--color-border,#e5e7eb);border-radius:var(--radius-md);padding:var(--space-4) var(--space-5);margin:var(--space-4) 0}.toc-block ul{margin:var(--space-2) 0 0 0;padding:0;list-style:none}.toc-block li{color:var(--color-text-secondary,#555);border-bottom:1px solid var(--color-border-light,#f0f0f0);padding:4px 0;font-size:.9rem}.toc-block li:last-child{border-bottom:none}.toc-placeholder{color:var(--color-text-tertiary,#999);font-size:.85rem;font-style:italic}.paywall-divider{align-items:center;gap:var(--space-3,12px);margin:var(--space-6,24px) 0;-webkit-user-select:none;user-select:none;display:flex}.paywall-divider-line{background:linear-gradient(90deg, transparent, var(--color-primary,#f59e0b), transparent);flex:1;height:2px}.paywall-divider-label{color:var(--color-primary,#f59e0b);white-space:nowrap;border-radius:var(--radius-full,9999px);background:#f59e0b14;border:1px solid #f59e0b33;padding:4px 12px;font-size:.85rem;font-weight:600}
