*,*:after,*:before{box-sizing:border-box}html{font-size:62.5%}body{margin:0;font-size:1.6em;font-weight:300;letter-spacing:.01em;line-height:1.6}h1,h2,h3,h4,h5,h6{font-weight:600;letter-spacing:-.05rem;margin-bottom:1.5rem;margin-top:0;color:var(--text-primary)}h1{font-size:3.2rem;line-height:1.25}h2{font-size:2.6rem;line-height:1.3}h3{font-size:2rem;line-height:1.35}h4{font-size:1.8rem;line-height:1.4}h5{font-size:1.6rem;line-height:1.5}h6{font-size:1.4rem;line-height:1.4}p{margin-top:0}b,strong{font-weight:700}a{color:var(--link-color);text-decoration:none}a:focus,a:hover{color:var(--text-primary)}img{max-width:100%}dl,ol,ul{margin-top:0;padding-left:2rem}ol{list-style:decimal}ul{list-style:disc}li{margin-bottom:.5rem}blockquote{border-left:3px solid var(--border-color);margin-left:0;margin-right:0;padding:.5rem 1.5rem;color:var(--text-secondary)}blockquote *:last-child{margin-bottom:0}code{background:var(--bg-tertiary);border-radius:6px;font-size:85%;padding:.2em .4em;font-family:var(--font-mono);color:var(--text-primary)}pre{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:8px;overflow-x:auto;margin-bottom:2rem}pre>code{background:transparent;border-radius:0;display:block;padding:1rem 1.5rem;white-space:pre;font-size:.85em;line-height:1.6}table{border-spacing:0;display:block;overflow-x:auto;text-align:left;width:100%;margin-bottom:2rem}td,th{border-bottom:1px solid var(--border-color);padding:.8rem 1rem}th{color:var(--text-primary);font-weight:600}hr{border:0;border-top:1px solid var(--border-color);margin:3rem 0}input[type=text],input[type=email],input[type=password],input[type=search],input[type=url],input[type=number],textarea,select{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);padding:.6rem 1rem;width:100%;font-family:inherit}input:focus,textarea:focus,select:focus{border-color:var(--link-color);outline:0}blockquote,dl,figure,form,ol,p,pre,table,ul{margin-bottom:2rem}:root{--bg-primary: #0d1117;--bg-secondary: #161b22;--bg-tertiary: #1c2128;--bg-overlay: rgba(13, 17, 23, .8);--text-primary: #e6edf3;--text-secondary: #8b949e;--text-muted: #6e7681;--border-color: #30363d;--border-subtle: #21262d;--link-color: #58a6ff;--font-mono: "SF Mono", "Monaco", "Inconsolata", "Fira Code", monospace;--font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Helvetica, Arial, sans-serif;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--space-3xl: 4rem;--radius-sm: 4px;--radius-md: 6px;--radius-lg: 8px;--transition: .15s ease}body{background:radial-gradient(ellipse at 20% 0%,var(--bg-secondary) 0%,transparent 50%),radial-gradient(ellipse at 80% 100%,var(--bg-secondary) 0%,transparent 50%),var(--bg-primary);background-attachment:fixed;color:var(--text-primary);font-family:var(--font-mono);font-size:18px;line-height:1.7;overflow-x:hidden}.container{position:relative;z-index:1;max-width:800px;margin:0 auto;padding:0 var(--space-xl)}.site-header{border-bottom:1px solid var(--border-color);padding:var(--space-md) 0;margin-bottom:var(--space-xl);background:var(--bg-overlay);position:sticky;top:0;z-index:100;backdrop-filter:blur(12px)}.site-header .container{max-width:1200px}.site-nav{display:flex;justify-content:space-between;align-items:center}.site-logo{font-size:1.4rem;font-weight:600;color:var(--text-primary);text-decoration:none;transition:color var(--transition)}.site-logo:hover{color:var(--link-color)}.nav-link{font-size:1.2rem;color:var(--text-secondary);text-decoration:none;transition:color var(--transition)}.nav-link:hover{color:var(--text-primary)}.alert{padding:var(--space-md);margin-bottom:var(--space-lg);border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--bg-secondary);font-size:.9rem}.alert-info{color:var(--text-secondary);border-color:var(--text-secondary)}.alert-warning{color:#e3b341;border-color:#e3b341}.alert-danger{color:#f85149;border-color:#f85149}.phx-no-feedback.invalid-feedback,.phx-no-feedback .invalid-feedback{display:none}.phx-click-loading{opacity:.5;transition:opacity 1s ease-out}.phx-loading{cursor:wait}.hero{text-align:center;padding:var(--space-3xl) 0 var(--space-2xl);margin-bottom:var(--space-2xl)}.hero-title{font-size:5rem;font-weight:700;margin:0 0 var(--space-lg);letter-spacing:-.03em}.hero-subtitle{font-size:1.4rem;color:var(--text-secondary);margin:0}.post-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:var(--space-xl);margin-bottom:var(--space-3xl);max-width:1200px;margin-left:auto;margin-right:auto}.post-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden;transition:border-color var(--transition),transform var(--transition)}.post-card:hover{border-color:var(--text-muted);transform:translateY(-2px)}.post-card-link{text-decoration:none;color:inherit;display:flex;flex-direction:column;height:100%}.post-card-image{width:100%;height:auto;display:block;border-bottom:1px solid var(--border-color)}.post-card-content{padding:var(--space-md);flex:1;display:flex;flex-direction:column}.post-card-title{font-size:1.8rem;font-weight:600;margin:0 0 var(--space-md);line-height:1.4;color:var(--text-primary)}.post-card-description{font-size:1.2rem;line-height:1.7;color:var(--text-secondary);margin:0 0 var(--space-lg);display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.post-card-meta{display:flex;flex-direction:column;gap:var(--space-sm);padding-top:var(--space-md);border-top:1px solid var(--border-subtle);margin-top:auto}.post-card-tags{display:flex;flex-wrap:nowrap;gap:var(--space-xs);overflow-x:auto;scrollbar-width:none}.post-card-tags::-webkit-scrollbar{display:none}.post-card-tags .tag-pill{font-size:1.15rem;padding:6px 14px;white-space:nowrap;flex-shrink:0}.post-card-reading-time{font-size:1.15rem;color:var(--text-muted);white-space:nowrap}.tag-pill{display:inline-block;padding:8px 16px;font-size:1.5rem;font-family:var(--font-mono);border-radius:var(--radius-sm);background:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border-color);text-transform:lowercase;letter-spacing:.02em}.post-tags{display:flex;flex-wrap:wrap;gap:var(--space-sm);margin-bottom:var(--space-lg)}.post-meta{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-lg)}.post-meta .post-tags{margin-bottom:0}.post-reading-time{font-size:1.5rem;color:var(--text-muted);white-space:nowrap}.post-content{max-width:720px;margin:0 auto}.post-footer{margin-top:var(--space-2xl);padding-top:var(--space-lg);border-top:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center;font-size:.85rem;color:var(--text-secondary)}.post-footer a{color:var(--text-secondary);transition:color var(--transition)}.post-footer a:hover{color:var(--text-primary)}.read-tag{position:fixed;left:0;width:32px;height:32px;border-radius:0 10px 10px 0;z-index:200;background:var(--text-muted);transition:top .3s ease;pointer-events:none}.read-tag--self{background:var(--text-secondary)}.dashboard-container{max-width:900px}.dashboard-header{text-align:left;padding:var(--space-2xl) 0 0;margin-bottom:var(--space-lg)}.dashboard-title{font-size:1.5rem;font-weight:700;margin:0 0 var(--space-xs)}.dashboard-subtitle{font-size:.85rem;color:var(--text-secondary);margin:0}.dashboard-panel{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-lg)}.dashboard-chart{width:100%;height:60vh;min-height:400px}.dashboard-chart .vega-embed{width:100%!important;height:100%!important}.back-link{font-size:.85rem;color:var(--text-secondary);text-decoration:none;transition:color var(--transition)}.back-link:hover{color:var(--text-primary)}@media (max-width: 768px){.post-grid{grid-template-columns:1fr;gap:var(--space-lg)}.hero-title{font-size:3rem}.hero-subtitle{font-size:1.1rem}.dashboard-panel{padding:var(--space-md)}.dashboard-chart{height:50vh;min-height:300px}.container{padding:0 var(--space-md)}}pre code.hljs{display:block;overflow-x:auto;padding:1em}code.hljs{padding:3px 5px}.hljs{color:#c9d1d9;background:#0d1117}.hljs-doctag,.hljs-keyword,.hljs-meta .hljs-keyword,.hljs-template-tag,.hljs-template-variable,.hljs-type,.hljs-variable.language_{color:#ff7b72}.hljs-title,.hljs-title.class_,.hljs-title.class_.inherited__,.hljs-title.function_{color:#d2a8ff}.hljs-attr,.hljs-attribute,.hljs-literal,.hljs-meta,.hljs-number,.hljs-operator,.hljs-variable,.hljs-selector-attr,.hljs-selector-class,.hljs-selector-id{color:#79c0ff}.hljs-regexp,.hljs-string,.hljs-meta .hljs-string{color:#a5d6ff}.hljs-built_in,.hljs-symbol{color:#ffa657}.hljs-comment,.hljs-code,.hljs-formula{color:#8b949e}.hljs-name,.hljs-quote,.hljs-selector-tag,.hljs-selector-pseudo{color:#7ee787}.hljs-subst{color:#c9d1d9}.hljs-section{color:#1f6feb;font-weight:700}.hljs-bullet{color:#f2cc60}.hljs-emphasis{color:#c9d1d9;font-style:italic}.hljs-strong{color:#c9d1d9;font-weight:700}.hljs-addition{color:#aff5b4;background-color:#033a16}.hljs-deletion{color:#ffdcd7;background-color:#67060c}
/*!
  Theme: GitHub Dark
  Description: Dark theme as seen on github.com
  Author: github.com
  Maintainer: @Hirse
  Updated: 2021-05-15

  Outdated base version: https://github.com/primer/github-syntax-dark
  Current colors taken from GitHub's CSS
*/
