@import url("https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,300;0,9..144,400;0,9..144,600;0,9..144,700;1,9..144,300;1,9..144,400&family=DM+Mono:ital,wght@0,300;0,400;0,500;1,300&display=swap");*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0a0a08;--surface:#111110;--border:#1e1e1c;--border-light:#2a2a28;--text:#e8e4dc;--text-muted:#7a7670;--text-subtle:#4a4844;--accent:#d4a843;--accent-dim:#a07c28;--accent-glow:rgba(212,168,67,.12);--red:#c0392b;--green:#27ae60;--font-display:"Fraunces",Georgia,serif;--font-mono:"DM Mono","Courier New",monospace;--radius:2px;--max-w:1100px}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--text);font-family:var(--font-mono);font-size:14px;line-height:1.7;-webkit-font-smoothing:antialiased;min-height:100vh}::selection{background:var(--accent);color:var(--bg)}a{color:inherit;text-decoration:none}img{max-width:100%;height:auto}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--border-light);border-radius:2px}::-webkit-scrollbar-thumb:hover{background:var(--accent-dim)}.nav{position:fixed;top:0;left:0;right:0;z-index:100;border-bottom:1px solid var(--border);background:rgba(10,10,8,.92);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.nav-inner{max-width:var(--max-w);margin:0 auto;padding:0 2rem;height:56px;justify-content:space-between}.nav-inner,.nav-logo{display:flex;align-items:center}.nav-logo{font-family:var(--font-display);font-size:1.1rem;font-weight:600;letter-spacing:-.02em;color:var(--text);gap:.5rem}.nav-logo span{color:var(--accent)}.nav-links{display:flex;align-items:center;gap:2rem;list-style:none}.nav-links a{font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);transition:color .2s}.nav-links a.active,.nav-links a:hover{color:var(--accent)}.hero{min-height:100vh;display:flex;flex-direction:column;justify-content:center;padding:8rem 2rem 4rem;max-width:var(--max-w);margin:0 auto;position:relative}.hero-eyebrow{font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:var(--accent);margin-bottom:1.5rem;display:flex;align-items:center;gap:.75rem}.hero-eyebrow:before{content:"";width:32px;height:1px;background:var(--accent)}.hero-title{font-family:var(--font-display);font-size:clamp(3rem,8vw,6rem);font-weight:300;line-height:1.05;letter-spacing:-.03em;color:var(--text);margin-bottom:1.5rem;max-width:14ch}.hero-title em{font-style:italic;color:var(--accent)}.hero-desc{color:var(--text-muted);max-width:52ch;font-size:14px;line-height:1.8;margin-bottom:2.5rem}.hero-actions{display:flex;gap:1rem;flex-wrap:wrap}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.7rem 1.4rem;font-family:var(--font-mono);font-size:12px;letter-spacing:.06em;text-transform:uppercase;border:1px solid var(--border-light);background:transparent;color:var(--text-muted);cursor:pointer;transition:all .2s;border-radius:var(--radius)}.btn:hover{color:var(--accent);background:var(--accent-glow)}.btn-primary,.btn:hover{border-color:var(--accent)}.btn-primary{background:var(--accent);color:var(--bg);font-weight:500}.btn-primary:hover{background:var(--accent-dim);border-color:var(--accent-dim);color:var(--bg)}.hero-grid{position:absolute;top:0;right:0;bottom:0;width:40%;pointer-events:none;opacity:.04;background-image:linear-gradient(var(--text) 1px,transparent 1px),linear-gradient(90deg,var(--text) 1px,transparent 1px);background-size:40px 40px;-webkit-mask-image:linear-gradient(270deg,rgba(0,0,0,.8),transparent);mask-image:linear-gradient(270deg,rgba(0,0,0,.8),transparent)}.section{padding:6rem 2rem;max-width:var(--max-w);margin:0 auto}.section-header{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:3rem;padding-bottom:1rem;border-bottom:1px solid var(--border)}.section-title{font-family:var(--font-display);font-size:2rem;font-weight:400;letter-spacing:-.02em;color:var(--text)}.section-count{font-size:11px;color:var(--text-subtle);letter-spacing:.1em}.posts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));grid-gap:1px;gap:1px;background:var(--border);border:1px solid var(--border)}.post-card{background:var(--bg);padding:2rem;display:flex;flex-direction:column;gap:1rem;transition:background .2s;cursor:pointer;position:relative;overflow:hidden}.post-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--accent);transform:scaleX(0);transform-origin:left;transition:transform .3s ease}.post-card:hover{background:var(--surface)}.post-card:hover:before{transform:scaleX(1)}.post-card-meta{display:flex;align-items:center;justify-content:space-between;font-size:11px;color:var(--text-subtle);letter-spacing:.06em}.post-card-date{font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.post-card-read{color:var(--text-subtle)}.post-card-title{font-family:var(--font-display);font-size:1.35rem;font-weight:400;letter-spacing:-.01em;line-height:1.3;color:var(--text);transition:color .2s}.post-card:hover .post-card-title{color:var(--accent)}.post-card-desc{font-size:13px;color:var(--text-muted);line-height:1.7;flex:1 1}.tags{display:flex;flex-wrap:wrap;gap:.4rem}.tag{font-size:10px;letter-spacing:.08em;text-transform:uppercase;padding:.2rem .6rem;border:1px solid var(--border-light);color:var(--text-subtle);border-radius:var(--radius)}.post-card-links{display:flex;gap:.75rem;padding-top:.5rem;border-top:1px solid var(--border)}.post-card-link{font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--text-subtle);display:flex;align-items:center;gap:.3rem;transition:color .2s}.post-card-link:hover{color:var(--accent)}.post-layout{display:grid;grid-template-columns:1fr min(680px,100%) 1fr;padding-top:6rem}.post-layout>*{grid-column:2}.post-header{padding:3rem 2rem 2rem;border-bottom:1px solid var(--border)}.post-back{display:inline-flex;align-items:center;gap:.5rem;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--text-subtle);margin-bottom:2rem;transition:color .2s}.post-back:hover{color:var(--accent)}.post-title{font-family:var(--font-display);font-size:clamp(2rem,5vw,3.5rem);font-weight:400;letter-spacing:-.025em;line-height:1.1;color:var(--text);margin-bottom:1.25rem}.post-meta-bar{flex-wrap:wrap;gap:1.5rem;font-size:12px;color:var(--text-subtle);margin-bottom:1.25rem}.post-meta-bar,.post-meta-item{display:flex;align-items:center}.post-meta-item{gap:.4rem}.post-action-links{display:flex;gap:.75rem;padding-top:1.25rem;border-top:1px solid var(--border)}.prose{padding:3rem 2rem 6rem;color:var(--text-muted);font-size:15px;line-height:1.85}.prose h1,.prose h2,.prose h3,.prose h4{font-family:var(--font-display);color:var(--text);font-weight:400;letter-spacing:-.02em;margin:2.5rem 0 1rem;line-height:1.2}.prose h1{font-size:2rem}.prose h2{font-size:1.5rem;padding-bottom:.5rem;border-bottom:1px solid var(--border)}.prose h3{font-size:1.15rem}.prose p{margin-bottom:1.4rem}.prose a{color:var(--accent);border-bottom:1px solid var(--accent-dim);transition:opacity .2s}.prose a:hover{opacity:.75}.prose code{font-family:var(--font-mono);font-size:.85em;padding:.1em .4em;color:var(--accent)}.prose code,.prose pre{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius)}.prose pre{padding:1.5rem;overflow-x:auto;margin:1.5rem 0}.prose pre code{background:none;border:none;padding:0;color:var(--text)}.prose blockquote{border-left:2px solid var(--accent);padding:.5rem 0 .5rem 1.5rem;margin:1.5rem 0;color:var(--text-muted);font-style:italic}.prose ol,.prose ul{padding-left:1.5rem;margin-bottom:1.4rem}.prose li{margin-bottom:.5rem}.prose img{width:100%;border:1px solid var(--border);margin:2rem 0}.prose table{width:100%;border-collapse:collapse;margin:1.5rem 0;font-size:13px}.prose th{text-align:left;padding:.6rem 1rem;border-bottom:1px solid var(--border-light);color:var(--text);font-weight:500}.prose td{padding:.6rem 1rem;border-bottom:1px solid var(--border)}.prose tr:last-child td{border-bottom:none}.prose hr{border:none;border-top:1px solid var(--border);margin:2.5rem 0}.empty-state{text-align:center;padding:6rem 2rem;border:1px dashed var(--border-light)}.empty-state-icon{font-size:2rem;margin-bottom:1rem;opacity:.4}.empty-state-title{font-family:var(--font-display);font-size:1.5rem;font-weight:400;margin-bottom:.75rem}.empty-state-desc{color:var(--text-muted);font-size:13px;max-width:40ch;margin:0 auto 1.5rem}.footer{border-top:1px solid var(--border);padding:2rem;text-align:center;font-size:12px;color:var(--text-subtle)}.about-layout{max-width:var(--max-w);margin:0 auto;padding:8rem 2rem 6rem;display:grid;grid-template-columns:1fr 2fr;grid-gap:4rem;gap:4rem;align-items:start}.about-sidebar{position:-webkit-sticky;position:sticky;top:5rem}.about-photo-wrap{width:120px;height:120px;margin-bottom:1.5rem;position:relative}.about-photo{width:120px;height:120px;object-fit:cover;border:1px solid var(--border-light);filter:grayscale(20%);transition:filter .3s;display:block}.about-photo:hover{filter:grayscale(0)}.about-photo-placeholder{width:120px;height:120px;border:1px dashed var(--border-light);background:var(--surface);flex-direction:column;align-items:center;justify-content:center;gap:.6rem;color:var(--text-subtle);font-size:10px;letter-spacing:.04em;text-align:center;line-height:1.5}.about-name{font-family:var(--font-display);font-size:2rem;font-weight:400;margin-bottom:.5rem}.about-role{color:var(--accent);font-size:12px;letter-spacing:.08em;text-transform:uppercase;margin-bottom:1.5rem}.about-links{display:flex;flex-direction:column;gap:.5rem}.about-link{font-size:12px;color:var(--text-subtle);display:flex;align-items:center;gap:.5rem;transition:color .2s}.about-link:hover{color:var(--accent)}.about-content h2{font-family:var(--font-display);font-size:1.5rem;font-weight:400;margin-bottom:1rem}.about-content p{color:var(--text-muted);margin-bottom:1.25rem;line-height:1.8}.skills-grid{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:2rem}.skill-badge{font-size:11px;padding:.3rem .8rem;border:1px solid var(--border-light);color:var(--text-muted);letter-spacing:.04em;transition:all .2s}.skill-badge:hover{border-color:var(--accent);color:var(--accent)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;background:var(--bg);position:relative;overflow:hidden}.login-page:before{content:"";position:absolute;inset:0;background-image:linear-gradient(var(--border) 1px,transparent 1px),linear-gradient(90deg,var(--border) 1px,transparent 1px);background-size:48px 48px;-webkit-mask-image:radial-gradient(ellipse 60% 60% at 50% 50%,#000,transparent);mask-image:radial-gradient(ellipse 60% 60% at 50% 50%,#000,transparent);pointer-events:none}.login-card{position:relative;width:100%;max-width:380px;border:1px solid var(--border-light);background:var(--surface);padding:2.5rem;display:flex;flex-direction:column;align-items:center;text-align:center;gap:0}.login-card:before{content:"";position:absolute;top:0;left:10%;right:10%;height:1px;background:linear-gradient(90deg,transparent,var(--accent),transparent)}.login-icon{width:56px;height:56px;border:1px solid var(--border-light);display:flex;align-items:center;justify-content:center;color:var(--accent);margin-bottom:1.5rem}.login-title{font-family:var(--font-display);font-size:1.5rem;font-weight:400;letter-spacing:-.02em;color:var(--text);margin-bottom:.6rem}.login-desc{font-size:13px;color:var(--text-muted);line-height:1.7;margin-bottom:2rem}.login-form{width:100%;gap:1rem;margin-bottom:1.5rem}.login-field,.login-form{display:flex;flex-direction:column}.login-field{gap:.4rem;text-align:left}.login-label{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--text-subtle)}.login-input{width:100%;background:var(--bg);border:1px solid var(--border-light);color:var(--text);font-family:var(--font-mono);font-size:14px;padding:.7rem 1rem;outline:none;border-radius:var(--radius);transition:border-color .2s;letter-spacing:.1em}.login-input:focus{border-color:var(--accent)}.login-input-error{border-color:var(--red)!important}.login-error{font-size:11px;color:var(--red);letter-spacing:.04em}.login-btn{width:100%;padding:.75rem;background:var(--accent);border:none;color:var(--bg);font-family:var(--font-mono);font-size:12px;letter-spacing:.08em;text-transform:uppercase;font-weight:500;cursor:pointer;border-radius:var(--radius);transition:background .2s}.login-btn:hover{background:var(--accent-dim)}.login-footer{font-size:12px;color:var(--text-subtle)}.login-footer a{color:var(--accent);border-bottom:1px solid var(--accent-dim);transition:opacity .2s}.login-footer a:hover{opacity:.7}.not-found{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:2rem}.not-found-code{font-family:var(--font-display);font-size:8rem;font-weight:300;line-height:1;color:var(--border-light);margin-bottom:1rem}@keyframes fadeUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.anim{animation:fadeUp .6s ease both}.anim-1{animation-delay:.1s}.anim-2{animation-delay:.2s}.anim-3{animation-delay:.3s}.anim-4{animation-delay:.4s}@media (max-width:768px){.about-layout{grid-template-columns:1fr}.about-sidebar{position:static}.nav-links{display:none}.posts-grid{grid-template-columns:1fr}.hero-title{font-size:2.8rem}}