@import url("https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:ital,wght@0,200..800;1,200..800&family=Inter+Tight:ital,wght@0,100..900;1,100..900&display=swap");:root{--bg:#FAFAF8;--bg-alt:#F3F3EF;--surface:#FFFFFF;--border:#E8E8E4;--text-primary:#1A1A1A;--text-secondary:#6B6B6B;--text-muted:#A0A0A0;--accent:#1A1A1A;--accent-hover:#404040;--tag-bg:#F0F0EC;--tag-text:#555;--font-heading:"Plus Jakarta Sans",-apple-system,BlinkMacSystemFont,sans-serif;--font-body:"Inter Tight",-apple-system,BlinkMacSystemFont,sans-serif;--max-w:800px;--max-w-wide:1000px}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:18px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-body);background-color:var(--bg);color:var(--text-primary);line-height:1.6;background:#fff}a{color:inherit;text-decoration:none}.post-card__layout{display:grid;grid-template-columns:1fr 180px;grid-template-areas:"meta thumb" "title thumb" "desc thumb" "tags thumb";grid-gap:.75rem 1.5rem;gap:.75rem 1.5rem;align-items:start}.post-card__meta{grid-area:meta;gap:.5rem}.post-card__title{grid-area:title}.post-card__desc{grid-area:desc}.post-card__tags{grid-area:tags;gap:.5rem}.post-card__thumb{grid-area:thumb;width:180px;height:180px;border-radius:12px;overflow:hidden;background:rgba(255,255,255,.05);flex-shrink:0}.post-card__thumb-img{width:100%;height:100%;object-fit:cover;display:block}.post-card__thumb-placeholder{width:100%;height:100%;background:rgba(255,255,255,.05)}@media (max-width:768px){.post-card__layout{grid-template-columns:1fr;grid-template-areas:"title" "meta" "tags" "thumb" "desc"}.post-card__thumb{width:100%;height:220px}}.notion-image--missing .notion-image__placeholder{padding:1rem;border-radius:12px;background:rgba(255,255,255,.05);color:#888;font-size:.95rem;text-align:center}.site-header{position:-webkit-sticky;position:sticky;top:0;z-index:100;background:rgba(255,255,255,.92);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--border);padding:0 1.5rem}.site-header__inner{max-width:var(--max-w-wide);margin:0 auto;height:60px;display:flex;align-items:center;justify-content:space-between}.site-logo{font-family:var(--font-heading);font-size:1.25rem;font-weight:700;letter-spacing:-.02em;color:var(--text-primary);transition:opacity .2s}.site-logo:hover{opacity:.65}.site-nav{display:flex;align-items:center;gap:1.75rem}.site-nav a{font-size:.875rem;font-weight:400;color:var(--text-secondary);transition:color .2s}.site-nav a:hover{color:var(--text-primary)}.page-wrapper{min-height:100vh}.container{max-width:var(--max-w)}.container,.container--wide{margin:0 auto;padding:0 1.5rem}.container--wide{max-width:var(--max-w-wide)}.home-hero{padding:4rem 0 3rem;border-bottom:1px solid var(--border);margin-bottom:3rem}.home-hero__eyebrow{font-size:.78rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);margin-bottom:1rem}.home-hero__title{font-family:var(--font-heading);font-size:clamp(2rem,5vw,3rem);font-weight:700;line-height:1.2;letter-spacing:-.03em;color:var(--text-primary);margin-bottom:1rem}.home-hero__desc{font-size:.9rem;color:var(--text-secondary);max-width:600px;line-height:1.7;font-style:italic}.post-list{display:flex;flex-direction:column;padding-bottom:5rem}.post-card{padding:2rem 0;border-bottom:1px solid var(--border);display:block;transition:none}.post-card:first-child{padding-top:0}.post-card__meta{display:flex;align-items:center;gap:.75rem;margin-bottom:.65rem}.post-card__date{font-weight:400}.post-card__date,.post-card__reading-time{font-size:.8rem;color:var(--text-muted)}.post-card__title{font-family:var(--font-heading);font-size:1.45rem;font-weight:700;line-height:1.3;letter-spacing:-.02em;color:var(--text-primary);margin-bottom:.5rem;transition:color .15s}.post-card:hover .post-card__title{color:var(--accent-hover)}.post-card__desc{font-size:16px;color:var(--text-secondary);line-height:1.65;margin-bottom:.85rem;display:-webkit-box;line-clamp:2;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.post-card__tags{display:flex;flex-wrap:wrap;gap:.4rem}.tag.notion-tag{text-transform:none;letter-spacing:0;font-size:.72rem;font-weight:500;padding:.22rem .65rem;border-radius:5px;border:none}.notion-tag--default{background:#e9e7e1;color:#4b4b4b}.notion-bookmark-card{display:grid;grid-template-columns:1fr 120px;grid-gap:1rem;gap:1rem;align-items:stretch;padding:1rem 1.1rem;border-radius:16px;border:1px solid var(--border);background:var(--surface);transition:border-color .2s ease,transform .2s ease,background .2s ease;text-decoration:none}.notion-bookmark-card:hover{border-color:#d8d8d2;transform:translateY(-1px);background:#fff}.notion-bookmark-card__content{display:flex;flex-direction:column;justify-content:center;gap:.45rem;min-width:0}.notion-bookmark-card__title{font-size:.96rem;font-weight:600;line-height:1.4;color:var(--text-primary);word-break:break-word}.notion-bookmark-card__desc{font-size:.82rem;line-height:1.5;color:var(--text-secondary);word-break:break-word;display:-webkit-box;line-clamp:2;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.notion-bookmark-card__meta{margin-top:.15rem}.notion-bookmark-card__site{display:inline-flex;align-items:center;font-size:.76rem;color:var(--text-muted)}.notion-bookmark-card__preview{display:flex;align-items:center;justify-content:center;min-height:96px;border-radius:12px;background:var(--bg-alt);overflow:hidden}.notion-bookmark-card__preview-badge{width:44px;height:44px;border-radius:999px;background:var(--surface);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:1.1rem;color:var(--text-secondary);box-shadow:0 6px 20px rgba(0,0,0,.04)}@media (max-width:640px){.notion-bookmark-card{grid-template-columns:1fr}.notion-bookmark-card__preview{min-height:72px}}.notion-image__clickable{cursor:zoom-in}.notion-lightbox{position:fixed;inset:0;z-index:9999;background:rgba(0,0,0,.82);display:flex;align-items:center;justify-content:center;padding:1.5rem}.notion-lightbox__content{position:relative;max-width:95vw;max-height:90vh}.notion-lightbox__image{display:block;max-width:95vw;max-height:90vh;width:auto;height:auto;border-radius:12px;object-fit:contain;box-shadow:0 20px 80px rgba(0,0,0,.35)}.notion-lightbox__close{position:absolute;top:-.75rem;right:-.75rem;width:2.25rem;height:2.25rem;border:none;border-radius:999px;background:white;color:black;font-size:1.4rem;line-height:1;cursor:pointer;box-shadow:0 10px 30px rgba(0,0,0,.2)}.notion-tag--gray{background:#9b9a97;color:white}.notion-tag--brown{background:#937264;color:white}.notion-tag--orange{background:#ffa344;color:white}.notion-tag--yellow{background:#ffdc49;color:#4b3b00}.notion-tag--green{background:#4dab7c;color:white}.notion-tag--blue{background:#529cca;color:white}.notion-tag--purple{background:#9a6dd7;color:white}.notion-tag--pink{background:#c14c8a;color:white}.notion-tag--red{background:#e25555;color:white}.notion-toc{margin:1.5rem 0;padding:1rem 1.25rem;border-radius:12px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08)}.notion-toc__title{font-weight:700;margin-bottom:.75rem}.notion-toc__list{list-style:none;padding:0;margin:0}.notion-toc__item{margin:.35rem 0}.notion-toc__item--level-1{padding-left:0}.notion-toc__item--level-2{padding-left:1rem}.notion-toc__item--level-3{padding-left:2rem}.notion-toc__link{color:var(--text-secondary);text-decoration:none;transition:color .2s ease}.notion-toc__link:hover{color:var(--text-primary)}.article-header{padding:3.5rem 0 0}.article-tags{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:1.25rem}.article-title{font-family:var(--font-heading);font-size:clamp(1.75rem,4.5vw,2.5rem);font-weight:700;line-height:1.2;letter-spacing:-.03em;color:var(--text-primary);margin-bottom:1rem}.article-desc{font-family:var(--font-body);font-size:1rem;color:var(--text-secondary);line-height:1.6;margin-bottom:1.5rem}.article-meta{display:flex;justify-content:flex-start;gap:.75rem;font-size:.82rem;color:var(--text-muted);padding-bottom:2rem;border-bottom:1px solid var(--border)}.article-meta-dot{width:2px;height:2px;border-radius:50%;background:var(--text-muted)}.notion-blocks{line-height:1.8}.notion-blocks p{margin:1rem 0}.notion-blocks h1,.notion-blocks h2,.notion-blocks h3{margin-top:2rem;margin-bottom:1rem;line-height:1.3}.notion-blocks h1{font-size:2rem;font-weight:700}.notion-blocks h2{font-size:1.5rem;font-weight:700}.notion-blocks h3{font-size:1.25rem;font-weight:600}.notion-blocks blockquote{margin:1.25rem 0;padding-left:1rem;border-left:4px solid #444;color:#aaa}.notion-blocks pre{margin:1.25rem 0;padding:1rem;border-radius:12px;overflow-x:auto;background:#111;color:#f5f5f5}.notion-blocks code{padding:.15rem .35rem;border-radius:6px;background:rgba(255,255,255,.08);font-family:monospace;font-size:.95em}.notion-blocks pre code{padding:0;background:transparent}.notion-blocks hr{margin:2rem 0;border:none;border-top:1px solid #333}.notion-list{margin:1rem 0 1rem 1.25rem}.notion-list li{margin:.5rem 0}.notion-todo{margin:.75rem 0}.notion-callout{display:flex;gap:.75rem;margin:1.25rem 0;padding:1rem;border-radius:12px;background:rgba(0 0 0/6%);border:1px solid rgba(255,255,255,.08)}.notion-callout-icon{font-size:1.25rem;line-height:1.4}.notion-callout-icon-image{width:1.5rem;height:1.5rem;object-fit:contain}.notion-callout-content{flex:1 1}.notion-toggle summary{cursor:pointer;font-weight:600;margin-bottom:.5rem}.notion-bookmark-link,.notion-file-link{display:block;padding:1rem;border-radius:12px;border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.04);text-decoration:none}.notion-bookmark-url{color:#60a5fa;word-break:break-all}.notion-bookmark-caption{margin-top:.35rem;color:#aaa;font-size:.95rem}.notion-file-block{margin:1rem 0}.notion-table-wrapper{overflow-x:auto;margin:1.5rem 0}.notion-table{width:100%;border-collapse:collapse}.notion-table td{border:1px solid rgba(255,255,255,.12);padding:.75rem;vertical-align:top}.notion-child-page,.notion-embed,.notion-equation,.notion-unsupported{padding:.85rem 1rem;border-radius:12px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08)}.notion-video video{display:block;width:100%;max-width:100%;border-radius:12px}.notion-media-caption{margin-top:.5rem;font-size:.9rem;color:#aaa;text-align:center}.notion-image{margin:1.5rem 0}.notion-image img{display:block;max-width:100%;height:auto;border-radius:12px}.notion-image figcaption{margin-top:.5rem;font-size:.9rem;color:#aaa;text-align:center}.notion-color-gray{color:#9ca3af}.notion-color-brown{color:#a16207}.notion-color-orange{color:#f97316}.notion-color-yellow{color:#eab308}.notion-color-green{color:#22c55e}.notion-color-blue{color:#3b82f6}.notion-color-purple{color:#a855f7}.notion-color-pink{color:#ec4899}.notion-color-red{color:#ef4444}.notion-bg-gray{background-color:rgba(156,163,175,.18)}.notion-bg-brown{background-color:rgba(161,98,7,.18)}.notion-bg-orange{background-color:rgba(249,115,22,.18)}.notion-bg-yellow{background-color:rgba(234,179,8,.18)}.notion-bg-green{background-color:rgba(34,197,94,.18)}.notion-bg-blue{background-color:rgba(59,130,246,.18)}.notion-bg-purple{background-color:rgba(168,85,247,.18)}.notion-bg-pink{background-color:rgba(236,72,153,.18)}.notion-bg-red{background-color:rgba(239,68,68,.18)}.notion-bg-blue,.notion-bg-brown,.notion-bg-gray,.notion-bg-green,.notion-bg-orange,.notion-bg-pink,.notion-bg-purple,.notion-bg-red,.notion-bg-yellow{padding:.1rem .3rem;border-radius:.35rem}.article-cover{margin:1.25rem 0 1.5rem;border-radius:16px;overflow:hidden;background:rgba(255,255,255,.05)}.article-cover__img{height:auto;display:block;max-height:420px;width:100%;object-fit:cover}.article-content{padding:2.5rem 0 5rem;font-family:var(--font-body);font-size:16px;line-height:1.85;color:var(--text-primary)}.article-content p{margin-bottom:1em;margin-top:1em}.article-content h1,.article-content h2,.article-content h3,.article-content h4{font-family:var(--font-heading);font-weight:700;letter-spacing:-.02em;line-height:1.3;margin:2.5em 0 .8em;color:var(--text-primary)}.article-content h1{font-size:1.6rem}.article-content h2{font-size:1.3rem}.article-content h3{font-size:1.1rem}.article-content h4{font-size:1rem}.article-content ol,.article-content ul{padding-left:1.5em}.article-content li{margin-bottom:.4em;margin-top:.4em}.article-content blockquote{border-left:3px solid var(--text-primary);margin:2em 0;padding:20px;font-size:16px;font-weight:600;color:#000;background:#ebebe9;border-radius:12px}.article-content blockquote p{margin-bottom:0}.article-content code{font-family:SF Mono,Fira Code,Cascadia Code,monospace;font-size:.85em;background:var(--tag-bg);padding:.15em .4em;border-radius:3px;color:var(--text-primary)}.article-content pre{background:#1A1A1A;border-radius:8px;padding:1.5em;overflow-x:auto;margin:2em 0}.article-content pre code{background:none;padding:0;color:#E8E8E8;font-size:.85rem;line-height:1.7}.article-content img{max-width:100%;border-radius:6px;margin:2em 0}.article-content a{color:#3e9b11;text-underline-offset:3px;-webkit-text-decoration-color:var(--border);text-decoration-color:var(--border);transition:-webkit-text-decoration-color .2s;transition:text-decoration-color .2s;transition:text-decoration-color .2s,-webkit-text-decoration-color .2s}.article-content a:hover{-webkit-text-decoration-color:var(--text-primary);text-decoration-color:var(--text-primary);color:#2b7008}.article-content hr{border:none;border-top:1px solid var(--border);margin:2.5em 0}.article-content table{width:100%;border-collapse:collapse;font-size:.9rem;font-family:var(--font-body);margin:2em 0}.article-content th{text-align:left;font-weight:600;padding:.75em 1em;border-bottom:2px solid var(--border);color:var(--text-primary)}.article-content td{padding:.75em 1em;border-bottom:1px solid var(--border);color:var(--text-secondary)}.back-link{display:inline-flex;align-items:center;gap:.4rem;font-size:.85rem;color:var(--text-muted);padding:1.5rem 0 0;transition:color .2s}.back-link:hover{color:var(--text-primary)}.empty-state{padding:4rem 0;font-size:.9rem}.empty-state,.site-footer{text-align:center;color:var(--text-muted)}.site-footer{border-top:1px solid var(--border);padding:2rem 1.5rem;font-size:.8rem}@media (max-width:640px){html{font-size:16px}.home-hero{padding:2.5rem 0 2rem}}