.article-modal[hidden]{display:none}.article-modal{position:fixed;inset:0;z-index:80;display:grid;place-items:stretch}.article-modal-backdrop{position:absolute;inset:0;background:hsl(var(--background) / .82);backdrop-filter:blur(10px)}.article-modal-panel{position:relative;width:min(100%,64rem);height:min(100dvh,calc(100dvh - 2rem));margin:1rem auto;overflow:auto;border:1px solid hsl(var(--border));background:hsl(var(--background));color:hsl(var(--foreground));box-shadow:0 24px 80px hsl(var(--foreground) / .12)}.article-modal-header{position:sticky;top:0;z-index:2;display:flex;align-items:center;justify-content:space-between;gap:1rem;min-height:4.25rem;padding:1rem 1.25rem;border-bottom:1px solid hsl(var(--border));background:hsl(var(--background) / .94);backdrop-filter:blur(12px)}.article-modal-meta{display:flex;align-items:center;flex-wrap:wrap;gap:.5rem .75rem;min-width:0;color:hsl(var(--muted-foreground));font-size:.875rem}.article-modal-close{display:inline-flex;align-items:center;justify-content:center;width:2.5rem;height:2.5rem;flex:0 0 auto;border:1px solid hsl(var(--border));border-radius:9999px;background:transparent;color:hsl(var(--foreground));cursor:pointer;transition:background-color .15s,border-color .15s}.article-modal-close:hover{border-color:hsl(var(--foreground));background:hsl(var(--secondary))}.article-modal-close:focus-visible{outline:2px solid hsl(var(--ring));outline-offset:3px}.article-modal-content-wrap{padding:3rem 1.25rem 4rem}.article-modal-copy{width:min(100%,44rem);margin:0 auto}.article-modal-title{font-family:Instrument Sans,Inter,system-ui,sans-serif;color:hsl(var(--foreground));font-size:clamp(2rem,6vw,3.75rem);font-weight:700;line-height:1.08;letter-spacing:0;margin:0 0 1rem}.article-modal-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:2.5rem}.article-modal-tag{display:inline-flex;align-items:center;border:1px solid hsl(var(--border));border-radius:9999px;padding:.125rem .625rem;color:hsl(var(--muted-foreground));font-size:.75rem;white-space:nowrap}.article-modal-loading,.article-modal-error{color:hsl(var(--muted-foreground));font-size:.9375rem;line-height:1.7}.article-body{color:hsl(var(--foreground));font-size:1.0625rem;line-height:1.8}.article-body>*+*{margin-top:1.25rem}.article-body h1,.article-body h2,.article-body h3,.article-body h4{font-family:Instrument Sans,Inter,system-ui,sans-serif;color:hsl(var(--foreground));font-weight:700;line-height:1.2;letter-spacing:0;margin-top:2.5rem}.article-body h1{font-size:2rem}.article-body h2{font-size:1.65rem}.article-body h3{font-size:1.3rem}.article-body h4{font-size:1.1rem}.article-body p,.article-body li{color:hsl(var(--foreground))}.article-body a{color:hsl(var(--foreground));text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:.22em}.article-body a:hover{color:hsl(var(--muted-foreground))}.article-body ul,.article-body ol{padding-left:1.5rem}.article-body ul{list-style:disc}.article-body ol{list-style:decimal}.article-body blockquote{border-left:2px solid hsl(var(--border));padding-left:1rem;color:hsl(var(--muted-foreground))}.article-body pre{overflow-x:auto;border:1px solid hsl(var(--border));background:hsl(var(--secondary));padding:1rem;font-size:.875rem;line-height:1.65}.article-body code{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:.9em}.article-body :not(pre)>code{border:1px solid hsl(var(--border));background:hsl(var(--secondary));padding:.125rem .25rem}.article-body table{width:100%;border-collapse:collapse;overflow-x:auto;display:block}.article-body th,.article-body td{border:1px solid hsl(var(--border));padding:.625rem;text-align:left}.article-body hr{border:0;border-top:1px solid hsl(var(--border));margin:2rem 0}.article-body img,.article-body picture,.article-body video,.article-body iframe{display:none!important}@media(max-width:768px){.article-modal-panel{width:100%;height:100dvh;margin:0;border-right:0;border-left:0}.article-modal-content-wrap{padding:2rem 1.25rem 3rem}.article-body{font-size:1rem;line-height:1.75}}.blog-h1,.blog-post-title{font-family:Instrument Sans,Inter,system-ui,sans-serif}.blog-hero{min-height:calc(100svh - 5rem);padding-top:5rem;display:flex;flex-direction:column;justify-content:center}@media(min-width:768px){.blog-h1{font-size:2.25rem}}@media(min-width:1024px){.blog-h1{font-size:3rem}}.blog-controls{display:flex;flex-wrap:wrap;align-items:center;gap:.75rem;margin-bottom:3rem}.blog-filter-buttons{display:flex;flex-wrap:wrap;gap:.5rem}.filter-btn,.tag-filter-toggle,.load-more-btn{display:inline-flex;align-items:center;justify-content:center;border:1px solid hsl(var(--border));border-radius:9999px;background:transparent;color:hsl(var(--muted-foreground));font-size:.875rem;font-weight:500;line-height:1;min-height:2.25rem;padding:.5rem 1rem;cursor:pointer;transition:color .15s,background-color .15s,border-color .15s}.filter-btn:hover,.tag-filter-toggle:hover,.load-more-btn:hover{color:hsl(var(--foreground));border-color:hsl(var(--foreground))}.filter-btn.active-filter:hover{color:hsl(var(--background))}.filter-btn:focus-visible,.tag-filter-toggle:focus-visible,.load-more-btn:focus-visible,.post-row:focus-visible,.tag-checkbox-row:focus-visible-within{outline:2px solid hsl(var(--ring));outline-offset:3px}.active-filter{background-color:hsl(var(--foreground));color:hsl(var(--background));border-color:hsl(var(--foreground))}.inactive-filter{background-color:transparent;color:hsl(var(--muted-foreground));border-color:hsl(var(--border))}.tag-filter{position:relative}.tag-filter-toggle{gap:.5rem}.tag-filter-toggle[aria-expanded=true]{color:hsl(var(--foreground));border-color:hsl(var(--foreground))}.tag-filter-count{min-width:1.25rem;height:1.25rem;display:inline-flex;align-items:center;justify-content:center;border-radius:9999px;background:hsl(var(--secondary));color:hsl(var(--secondary-foreground));font-size:.75rem}.tag-filter-menu{position:absolute;z-index:30;top:calc(100% + .5rem);left:0;width:min(20rem,calc(100vw - 3rem));max-height:min(23rem,calc(100vh - 11rem));overflow:auto;border:1px solid hsl(var(--border));background:hsl(var(--background));box-shadow:0 16px 40px hsl(var(--foreground) / .08)}.tag-filter-menu-inner{padding:.5rem}.tag-filter-options{display:grid;gap:.125rem}.tag-checkbox-row{display:flex;align-items:center;gap:.625rem;width:100%;padding:.625rem .5rem;color:hsl(var(--foreground));font-size:.875rem;cursor:pointer;transition:background-color .15s}.tag-checkbox-row:hover{background:hsl(var(--secondary))}.tag-checkbox-row input{width:1rem;height:1rem;accent-color:hsl(var(--foreground));flex-shrink:0}.tag-label{min-width:0;overflow-wrap:anywhere}.tag-filter-empty,.blog-state-message,.blog-fallback-links{color:hsl(var(--muted-foreground));font-size:.875rem;line-height:1.6}.blog-state-message{margin-bottom:1.5rem}.blog-fallback-links{display:flex;align-items:center;flex-wrap:wrap;gap:.75rem 1rem;margin-top:-.75rem;margin-bottom:2rem}.blog-fallback-links[hidden]{display:none}.blog-fallback-actions{display:flex;align-items:center;gap:.5rem}.blog-external-icon{display:inline-flex;align-items:center;justify-content:center;width:2.5rem;height:2.5rem;border:1px solid hsl(var(--border));border-radius:9999px;color:hsl(var(--foreground));text-decoration:none;transition:background-color .15s,border-color .15s,color .15s}.blog-external-icon:hover,.blog-external-icon:focus-visible{border-color:hsl(var(--foreground));background:hsl(var(--secondary))}.blog-external-icon:focus-visible{outline:2px solid hsl(var(--ring));outline-offset:3px}.blog-dev-icon{font-family:Instrument Sans,Inter,system-ui,sans-serif;font-size:.68rem;font-weight:800;letter-spacing:0}.blog-medium-icon{font-family:Georgia,Times New Roman,serif;font-size:1.35rem;font-weight:700;line-height:1}.post-row{display:block;width:100%;appearance:none;border:0;border-radius:0;background:transparent;color:inherit;text-align:left;text-decoration:none;padding:2rem 0;cursor:pointer}.post-row+.post-row{border-top:1px solid hsl(var(--border))}.post-row.first-post{padding-top:0}.post-row-inner{display:flex;flex-direction:column;gap:1rem;width:100%}.post-date-column{flex-shrink:0;color:hsl(var(--muted-foreground))}.post-meta-row{display:flex;align-items:center;flex-wrap:wrap;gap:.5rem .75rem;margin-bottom:.5rem;justify-content:flex-start}.blog-post-title{color:hsl(var(--foreground));font-size:1rem;font-weight:700;line-height:1.4;letter-spacing:0;margin-bottom:.5rem;transition:color .15s}.post-row:hover .blog-post-title{color:hsl(var(--muted-foreground))}.blog-badge,.blog-tag{display:inline-flex;align-items:center;border-radius:9999px;white-space:nowrap}.blog-badge{border:1px solid transparent;padding:.125rem .625rem;font-size:.75rem;font-weight:600;background-color:hsl(var(--secondary));color:hsl(var(--secondary-foreground))}.blog-tag{position:relative;border:1px solid hsl(var(--border));padding:.125rem .5rem;color:hsl(var(--muted-foreground));font-size:.75rem}.blog-tag[data-tooltip]:hover:before{content:"";position:absolute;z-index:10;left:50%;bottom:calc(100% + .25rem);transform:translate(-50%);border:.3125rem solid transparent;border-top-color:hsl(var(--foreground));pointer-events:none}.blog-tag[data-tooltip]:hover:after{content:attr(data-tooltip);position:absolute;z-index:10;left:50%;bottom:calc(100% + .875rem);width:max-content;max-width:min(18rem,calc(100vw - 2rem));transform:translate(-50%);border-radius:.375rem;background:hsl(var(--foreground));color:hsl(var(--background));padding:.5rem .625rem;font-size:.75rem;font-weight:500;line-height:1.4;text-align:left;white-space:normal;box-shadow:0 12px 32px hsl(var(--foreground) / .16);pointer-events:none}.post-arrow{display:none;color:hsl(var(--muted-foreground));transition:color .15s,transform .15s}.post-row:hover .post-arrow{color:hsl(var(--foreground));transform:translate(.25rem)}.line-clamp-2{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.blog-load-more-wrap{display:flex;flex-direction:column;align-items:flex-start;gap:1rem;margin-top:2.5rem}.load-more-btn{min-width:8rem}.load-more-btn:disabled{cursor:wait;opacity:.65}@media(min-width:768px){.post-row-inner{flex-direction:row;align-items:flex-start;gap:2rem}.post-date-column{width:8rem}.post-content-column{flex:1 1 auto;min-width:0}.post-arrow{display:block;flex-shrink:0;margin-top:.25rem;margin-left:auto}.blog-post-title{font-size:1.125rem}}@media(max-width:640px){.blog-controls{align-items:stretch}.blog-filter-buttons,.tag-filter,.tag-filter-toggle{width:100%}.filter-btn{flex:1 1 auto}.tag-filter-menu{position:fixed;top:auto;right:1rem;bottom:1rem;left:1rem;width:auto;max-height:min(28rem,70vh)}}
