@import "https://fonts.googleapis.com/css2?family=DM+Serif+Display:ital@0;1&family=DM+Sans:opsz,wght@9..40,300;9..40,400;9..40,500&family=DM+Mono:wght@400;500&display=swap";:root{--bg:#f5f3ee;--surface:#eceae4;--ink:#0f0f0d;--ink-2:#3a3a36;--ink-3:#7a7a74;--accent:#1a3a2a;--accent-light:#2d6b48;--accent-pale:#e8f0eb;--border:#d4d1c8;--serif:"DM Serif Display", Georgia, serif;--sans:"DM Sans", sans-serif;--mono:"DM Mono", monospace}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:var(--sans);background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;min-height:100vh;font-size:16px;line-height:1.6}body:before{content:"";opacity:.028;pointer-events:none;z-index:9999;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='1'/%3E%3C/svg%3E");position:fixed;inset:0}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:var(--sans);background:0 0;border:none}.container{max-width:1100px;margin:0 auto;padding:0 2rem}@keyframes fadeUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.fade-up{animation:.7s cubic-bezier(.22,1,.36,1) both fadeUp}.fade-up-2{animation:.7s cubic-bezier(.22,1,.36,1) .1s both fadeUp}.fade-up-3{animation:.7s cubic-bezier(.22,1,.36,1) .2s both fadeUp}.fade-up-4{animation:.7s cubic-bezier(.22,1,.36,1) .3s both fadeUp}.fade-up-5{animation:.7s cubic-bezier(.22,1,.36,1) .4s both fadeUp}.fade-up-6{animation:.7s cubic-bezier(.22,1,.36,1) .5s both fadeUp}.dialog-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:99999;background:#000000b3;justify-content:center;align-items:center;padding:1rem;animation:.2s ease-out fadeIn;display:flex;position:fixed;inset:0;overflow-y:auto}.dialog-content{background:var(--bg);border:1px solid var(--border);border-radius:8px;width:100%;max-width:500px;margin:auto;padding:2rem;animation:.3s ease-out slideUp;position:relative;box-shadow:0 20px 60px #0000004d}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.dialog-close{color:var(--ink-3);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;width:32px;height:32px;padding:0;font-size:1.5rem;transition:color .2s;display:flex;position:absolute;top:1.5rem;right:1.5rem}.dialog-close:hover{color:var(--ink)}.dialog-header{margin-bottom:2rem}.dialog-title{font-family:var(--serif);color:var(--ink);margin-bottom:.5rem;font-size:1.75rem;font-weight:400}.dialog-subtitle{color:var(--ink-3);font-size:.875rem;line-height:1.6}.contact-form{flex-direction:column;gap:1.5rem;display:flex}.form-group{flex-direction:column;gap:.5rem;display:flex}.form-group label{font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--ink-2);font-size:.75rem}.form-group input,.form-group textarea{border:1px solid var(--border);background:var(--surface);color:var(--ink);border-radius:4px;padding:.75rem;font-family:inherit;font-size:.875rem;transition:border-color .2s}.form-group input:focus,.form-group textarea:focus{border-color:var(--accent);outline:none}.form-group textarea{resize:vertical;min-height:100px}.submit-btn{background:var(--accent);color:var(--bg);font-family:var(--mono);letter-spacing:.06em;text-transform:uppercase;cursor:pointer;border:none;border-radius:4px;margin-top:.5rem;padding:.875rem 1.5rem;font-size:.8rem;transition:opacity .2s}.submit-btn:hover{opacity:.8}@media (width<=640px){.dialog-content{padding:1.5rem}.dialog-title{font-size:1.5rem}}.navbar{z-index:100;padding:1.4rem 0;transition:background .3s,padding .3s,box-shadow .3s;position:fixed;top:0;left:0;right:0}.navbar.scrolled{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 1px 0 var(--border);background:#f5f3eeeb;padding:1rem 0}.nav-inner{justify-content:space-between;align-items:center;max-width:1100px;margin:0 auto;padding:0 2rem;display:flex}.nav-logo{font-family:var(--mono);letter-spacing:.08em;color:var(--ink);align-items:center;gap:6px;font-size:1rem;font-weight:500;display:flex}.logo-dot{background:var(--accent);border-radius:50%;width:6px;height:6px}.nav-links{align-items:center;gap:2.5rem;display:flex}.nav-link{color:var(--ink-3);letter-spacing:.02em;font-size:.875rem;font-weight:400;transition:color .2s;position:relative}.nav-link:after{content:"";background:var(--accent);transform-origin:0;height:1px;transition:transform .25s cubic-bezier(.22,1,.36,1);position:absolute;bottom:-3px;left:0;right:0;transform:scaleX(0)}.nav-link:hover{color:var(--ink)}.nav-link:hover:after,.nav-link.active:after{transform:scaleX(1)}.nav-link.active{color:var(--ink)}.nav-cta{font-size:.8rem;font-family:var(--mono);letter-spacing:.06em;color:var(--accent);border:1px solid var(--accent);cursor:pointer;background:0 0;border-radius:2px;padding:.45rem 1.1rem;transition:background .2s,color .2s}.nav-cta:hover{background:var(--accent);color:var(--bg)}.nav-burger{flex-direction:column;gap:5px;display:none}.line{background:var(--ink);width:22px;height:1.5px;transition:transform .25s,opacity .25s;display:block}@media (width<=680px){.nav-burger{display:flex}.nav-links{background:var(--bg);z-index:50;flex-direction:column;justify-content:center;gap:2.5rem;font-size:1.2rem;transition:transform .35s cubic-bezier(.22,1,.36,1);position:fixed;inset:0;transform:translate(100%)}.nav-links.open{transform:translate(0)}.nav-link{font-size:1.1rem}.nav-cta{font-size:.9rem}}.footer{border-top:1px solid var(--border);margin-top:auto;padding:3rem 0 2rem}.footer-inner{justify-content:space-between;align-items:flex-start;gap:2rem;margin-bottom:2.5rem;display:flex}.footer-logo{font-family:var(--mono);letter-spacing:.1em;color:var(--ink);align-items:center;gap:5px;margin-bottom:.5rem;font-size:.9rem;font-weight:500;display:flex}.footer-dot{background:var(--accent);border-radius:50%;width:5px;height:5px}.footer-tagline{color:var(--ink-3);font-size:.8rem;font-family:var(--mono);letter-spacing:.04em}.footer-links{align-items:center;gap:2rem;display:flex}.footer-links a{font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);font-size:.75rem;transition:color .2s}.footer-links a:hover{color:var(--accent)}.footer-bottom{border-top:1px solid var(--surface);color:var(--ink-3);font-size:.75rem;font-family:var(--mono);letter-spacing:.04em;justify-content:space-between;align-items:center;padding-top:1.5rem;display:flex}.footer-built{opacity:.6}@media (width<=680px){.footer-inner{flex-direction:column}.footer-bottom{text-align:center;flex-direction:column;gap:.5rem}}.mono-tag{font-family:var(--mono);letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3);font-size:.72rem}.mono-tag.accent{color:var(--accent)}.mono-tag.muted{color:var(--ink-3)}.hero{flex-direction:column;justify-content:center;min-height:100vh;padding:8rem 0 4rem;display:flex;position:relative}.hero-eyebrow{align-items:center;gap:1rem;margin-bottom:2rem;display:flex}.hero-line{background:var(--border);flex:0 0 48px;height:1px}.hero-name{font-family:var(--serif);letter-spacing:-.02em;color:var(--ink);margin-bottom:2rem;font-size:clamp(3.5rem,9vw,7.5rem);line-height:1}.hero-name em{color:var(--accent);font-style:italic}.hero-sub{max-width:520px;color:var(--ink-2);margin-bottom:2.5rem;font-size:1rem;line-height:1.75}.hero-actions{align-items:center;gap:1.5rem;margin-bottom:3rem;display:flex}.btn-primary{background:var(--accent);color:var(--bg);font-size:.875rem;font-family:var(--mono);letter-spacing:.06em;border-radius:2px;align-items:center;padding:.75rem 1.75rem;transition:background .2s,transform .2s;display:inline-flex}.btn-primary:hover{background:var(--accent-light);transform:translateY(-1px)}.btn-primary.large{padding:.9rem 2rem;font-size:.95rem}.btn-ghost{color:var(--ink-2);font-size:.875rem;font-family:var(--mono);letter-spacing:.04em;transition:color .2s}.btn-ghost:hover{color:var(--accent)}.hero-meta{align-items:center;gap:.75rem;display:flex}.meta-link{font-family:var(--mono);letter-spacing:.06em;color:var(--ink-3);font-size:.75rem;transition:color .2s}.meta-link:hover{color:var(--accent)}.meta-sep{color:var(--border)}.hero-scroll-hint{flex-direction:column;align-items:center;gap:.75rem;display:flex;position:absolute;bottom:2.5rem;right:2rem}.scroll-line{background:linear-gradient(to bottom, var(--ink-3), transparent);width:1px;height:48px;animation:2s ease-in-out infinite scrollPulse}@keyframes scrollPulse{0%,to{opacity:.3}50%{opacity:1}}.section-header{flex-direction:column;gap:.5rem;margin-bottom:3.5rem;display:flex}.section-title{font-family:var(--serif);letter-spacing:-.01em;color:var(--ink);font-size:clamp(1.8rem,4vw,2.8rem);font-weight:400}.skills-section{border-top:1px solid var(--border);padding:6rem 0}.skills-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:2.5rem;display:grid}.skill-group{flex-direction:column;gap:1rem;display:flex}.skill-cat{font-family:var(--mono);letter-spacing:.1em;text-transform:uppercase;color:var(--accent);border-bottom:1px solid var(--border);padding-bottom:.75rem;font-size:.72rem}.skill-chips{flex-wrap:wrap;gap:.5rem;display:flex}.chip{color:var(--ink-2);background:var(--surface);border:1px solid var(--border);border-radius:2px;padding:.3rem .75rem;font-size:.8rem;transition:border-color .2s,color .2s}.chip:hover{border-color:var(--accent);color:var(--accent)}.projects-section{border-top:1px solid var(--border);padding:6rem 0}.projects-list{flex-direction:column;gap:0;display:flex}.project-card{border-bottom:1px solid var(--border);cursor:pointer;padding:2rem 0;transition:background .2s;display:block;position:relative}.project-card:first-child{border-top:1px solid var(--border)}.project-card:before{content:"";background:var(--accent-pale);opacity:0;z-index:0;margin:0 -2rem;padding:0 2rem;transition:opacity .25s;position:absolute;inset:0}.project-card:hover:before{opacity:1}.project-card>*{z-index:1;position:relative}.project-top{justify-content:space-between;align-items:flex-start;margin-bottom:.75rem;display:flex}.project-year{margin-bottom:.3rem;display:block}.project-name{font-family:var(--serif);color:var(--ink);margin-bottom:.2rem;font-size:1.4rem;font-weight:400}.project-role{color:var(--ink-3);font-size:.8rem;font-family:var(--mono);letter-spacing:.04em}.project-arrow{color:var(--ink-3);font-size:1.2rem;transition:color .2s,transform .2s}.project-card:hover .project-arrow{color:var(--accent);transform:translate(2px,-2px)}.project-desc{color:var(--ink-2);max-width:680px;margin-bottom:1rem;font-size:.9rem;line-height:1.7}.project-tags{flex-wrap:wrap;gap:.5rem;display:flex}.tag{font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--accent);background:var(--accent-pale);border:1px solid #1a3a2a26;border-radius:2px;padding:.2rem .6rem;font-size:.7rem}.cta-section{border-top:1px solid var(--border);padding:7rem 0}.cta-inner{flex-direction:column;align-items:flex-start;gap:2.5rem;display:flex}.cta-title{font-family:var(--serif);letter-spacing:-.02em;font-size:clamp(2.2rem,5vw,4rem);font-weight:400;line-height:1.1}.cta-title em{color:var(--accent);font-style:italic}@media (width<=680px){.hero{padding:7rem 0 3rem}.hero-scroll-hint{display:none}.skills-grid{grid-template-columns:1fr}.btn-primary.large{word-break:break-all;font-size:.8rem}}.resume-page{padding:8rem 0 6rem}.resume-header{border-bottom:1px solid var(--border);grid-template-columns:1fr 1fr;gap:3rem;margin-bottom:4rem;padding-bottom:4rem;display:grid}.rh-left{flex-direction:column;gap:1rem;display:flex}.resume-name{font-family:var(--serif);letter-spacing:-.02em;font-size:clamp(2.5rem,6vw,4.5rem);font-weight:400;line-height:1.05}.resume-name em{color:var(--accent);font-style:italic}.rh-right{flex-direction:column;justify-content:flex-end;gap:.75rem;display:flex}.contact-line{align-items:baseline;gap:1rem;display:flex}.contact-label{font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);min-width:68px;font-size:.7rem}.contact-val{color:var(--ink-2);font-size:.875rem;transition:color .2s}a.contact-val:hover{color:var(--accent)}.r-section{border-bottom:1px solid var(--border);margin-bottom:4rem;padding-bottom:4rem}.r-section:last-of-type{border-bottom:none}.r-section-title{font-family:var(--mono);letter-spacing:.12em;text-transform:uppercase;color:var(--accent);align-items:center;gap:1rem;margin-bottom:2rem;font-size:.72rem;display:flex}.r-section-title:after{content:"";background:var(--border);flex:1;height:1px}.r-skills{flex-direction:column;gap:1rem;display:flex}.r-skill-row{border-bottom:1px solid var(--surface);grid-template-columns:200px 1fr;align-items:baseline;gap:1.5rem;padding:.6rem 0;display:grid}.r-skill-cat{color:var(--ink-2);font-size:.8rem;font-weight:500}.r-skill-vals{color:var(--ink-3);font-size:.875rem;line-height:1.6}.r-job{margin-bottom:2.5rem}.r-job:last-child{margin-bottom:0}.r-job-header{justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1rem;display:flex}.r-job-role{font-family:var(--serif);color:var(--ink);margin-bottom:.2rem;font-size:1.25rem;font-weight:400}.r-job-company{color:var(--accent);font-size:.85rem;font-family:var(--mono);letter-spacing:.04em;margin-bottom:.15rem;display:block}.r-job-sub{color:var(--ink-3);font-size:.78rem;font-family:var(--mono);letter-spacing:.03em;display:block}.r-job-period{font-family:var(--mono);letter-spacing:.06em;color:var(--ink-3);white-space:nowrap;padding-top:.25rem;font-size:.75rem}.r-stack{font-family:var(--mono);color:var(--ink-3);letter-spacing:.04em;margin-bottom:1rem;font-size:.75rem}.r-bullets{flex-direction:column;gap:.75rem;list-style:none;display:flex}.r-bullet{color:var(--ink-2);padding-left:1.25rem;font-size:.875rem;line-height:1.75;position:relative}.r-bullet:before{content:"—";color:var(--border);font-size:.75rem;position:absolute;left:0}.bullet-label{color:var(--ink);font-weight:500}.resume-download-note{align-items:center;gap:1.5rem;padding-top:3rem;display:flex}.dl-link{font-family:var(--mono);letter-spacing:.06em;color:var(--accent);font-size:.8rem;transition:opacity .2s}.dl-link:hover{opacity:.7}@media (width<=680px){.resume-header{grid-template-columns:1fr;gap:2rem}.r-skill-row{grid-template-columns:1fr;gap:.35rem}.r-job-header{flex-direction:column;gap:.25rem}}.blog-page{padding:8rem 0 6rem}.mono-label{font-family:var(--mono);letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3);font-size:.72rem}.loading-msg{text-align:center;padding:3rem 0}.blog-header{margin-bottom:3.5rem}.blog-title{font-family:var(--serif);letter-spacing:-.02em;margin:.75rem 0 1.25rem;font-size:clamp(2.8rem,7vw,5.5rem);font-weight:400;line-height:1.05}.blog-title em{color:var(--accent);font-style:italic}.blog-sub{max-width:540px;color:var(--ink-2);font-size:.95rem;line-height:1.75}.blog-filters{flex-wrap:wrap;gap:.5rem;margin-bottom:3rem;display:flex}.filter-btn{font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);border:1px solid var(--border);background:0 0;border-radius:2px;padding:.4rem 1rem;font-size:.72rem;transition:all .2s}.filter-btn:hover{border-color:var(--accent);color:var(--accent)}.filter-btn.active{background:var(--accent);border-color:var(--accent);color:var(--bg)}.featured-grid{grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:1.5px;margin-bottom:1.5px;display:grid}.featured-card{background:var(--surface);cursor:pointer;border:1px solid var(--border);flex-direction:column;gap:1rem;padding:2.5rem;transition:background .25s;display:flex}.featured-card.hovered{background:var(--accent-pale);border-color:#1a3a2a33}.fc-top{justify-content:space-between;align-items:center;display:flex}.fc-category{font-family:var(--mono);letter-spacing:.1em;text-transform:uppercase;color:var(--accent);font-size:.68rem}.fc-featured-badge{font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);border:1px solid var(--border);border-radius:2px;padding:.15rem .5rem;font-size:.65rem}.fc-title{font-family:var(--serif);color:var(--ink);flex:1;font-size:1.35rem;font-weight:400;line-height:1.35}.fc-excerpt{color:var(--ink-2);font-size:.875rem;line-height:1.7}.fc-bottom{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:1rem;display:flex}.fc-tags{flex-wrap:wrap;gap:.4rem;display:flex}.btag{font-family:var(--mono);letter-spacing:.07em;text-transform:uppercase;color:var(--accent);background:var(--accent-pale);border:1px solid #1a3a2a1f;border-radius:2px;padding:.15rem .5rem;font-size:.65rem}.fc-meta{font-family:var(--mono);color:var(--ink-3);white-space:nowrap;align-items:center;gap:.4rem;font-size:.72rem;display:flex}.meta-dot{color:var(--border)}.posts-list{border-top:1px solid var(--border);flex-direction:column;display:flex}.post-row{border-bottom:1px solid var(--border);cursor:pointer;justify-content:space-between;gap:2rem;padding:2rem 0;transition:background .2s;display:flex;position:relative}.post-row:before{content:"";background:var(--accent-pale);opacity:0;z-index:0;margin:0 -2rem;transition:opacity .2s;position:absolute;inset:0}.post-row:hover:before{opacity:1}.post-row>*{z-index:1;position:relative}.pr-left{flex-direction:column;flex:1;gap:.6rem;display:flex}.pr-category{font-family:var(--mono);letter-spacing:.1em;text-transform:uppercase;color:var(--accent);font-size:.68rem}.pr-title{font-family:var(--serif);color:var(--ink);font-size:1.15rem;font-weight:400;line-height:1.35}.pr-excerpt{color:var(--ink-3);max-width:580px;font-size:.85rem;line-height:1.65}.pr-tags{flex-wrap:wrap;gap:.4rem;margin-top:.25rem;display:flex}.pr-right{flex-direction:column;flex-shrink:0;justify-content:space-between;align-items:flex-end;min-width:80px;display:flex}.pr-date{font-family:var(--mono);color:var(--ink-3);letter-spacing:.05em;font-size:.72rem}.pr-read{font-family:var(--mono);color:var(--ink-3);font-size:.7rem}.pr-arrow{color:var(--ink-3);font-size:1.1rem;transition:color .2s,transform .2s}.post-row:hover .pr-arrow{color:var(--accent);transform:translate(3px)}.no-posts{text-align:center;padding:4rem 0}.blog-note{flex-wrap:wrap;align-items:center;gap:1rem;padding-top:3rem;display:flex}.note-text{color:var(--ink-3);font-size:.875rem}.note-link{font-family:var(--mono);letter-spacing:.06em;color:var(--accent);font-size:.78rem;transition:opacity .2s}.note-link:hover{opacity:.7}@media (width<=680px){.featured-grid{grid-template-columns:1fr}.post-row{flex-direction:column;gap:1rem}.pr-right{flex-direction:row;justify-content:space-between;align-items:center}}.blog-post-page{min-height:100vh;padding:8rem 0 6rem}.blog-post-page .container{max-width:800px}.loading-state,.error-state{text-align:center;padding:4rem 0}.error-state h1{font-family:var(--serif);color:var(--ink-2);margin:1rem 0 2rem;font-size:2rem}.back-btn{font-family:var(--mono);letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3);cursor:pointer;background:0 0;border:none;align-items:center;gap:.5rem;margin-bottom:3rem;padding:.5rem 0;font-size:.75rem;transition:color .2s;display:inline-flex}.back-btn:hover{color:var(--accent)}.post-content{max-width:720px;margin:0 auto}.post-header{border-bottom:1px solid var(--border);margin-bottom:3rem;padding-bottom:2rem}.post-meta-top{align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}.post-category{font-family:var(--mono);letter-spacing:.1em;text-transform:uppercase;color:var(--accent);background:var(--accent-pale);border-radius:2px;padding:.35rem .85rem;font-size:.7rem}.post-featured-badge{font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);background:var(--surface);border-radius:2px;padding:.35rem .85rem;font-size:.7rem}.blog-post-page .post-title{font-family:var(--serif);letter-spacing:-.02em;color:var(--ink);margin-bottom:1.5rem;font-size:clamp(2rem,5vw,3rem);font-weight:400;line-height:1.15}.post-meta-info{color:var(--ink-3);flex-wrap:wrap;align-items:center;gap:.75rem;margin-bottom:1.5rem;font-size:.875rem;display:flex}.post-author{color:var(--ink-2);font-weight:500}.meta-dot{opacity:.5}.post-tags{flex-wrap:wrap;gap:.5rem;display:flex}.post-tag{font-family:var(--mono);letter-spacing:.04em;color:var(--ink-3);background:var(--surface);border:1px solid var(--border);border-radius:2px;padding:.3rem .75rem;font-size:.7rem}.post-excerpt{background:var(--surface);border-left:3px solid var(--accent);border-radius:2px;margin-bottom:3rem;padding:1.5rem}.post-excerpt p{color:var(--ink-2);margin:0;font-size:1.05rem;font-style:italic;line-height:1.75}.markdown-content{color:var(--ink-2);font-size:1.05rem;line-height:1.8}.markdown-content p{margin-bottom:1.5rem}.markdown-content h1{font-family:var(--serif);color:var(--ink);margin:3rem 0 1.25rem;font-size:2.25rem;font-weight:400;line-height:1.2}.markdown-content h1:first-child{margin-top:0}.markdown-content h2{font-family:var(--serif);color:var(--ink);margin:2.5rem 0 1rem;font-size:1.75rem;font-weight:400;line-height:1.25}.markdown-content h3{font-family:var(--serif);color:var(--ink);margin:2rem 0 .75rem;font-size:1.35rem;font-weight:400;line-height:1.3}.markdown-content h4{color:var(--ink);margin:1.75rem 0 .5rem;font-size:1.15rem;font-weight:500}.markdown-content h5,.markdown-content h6{color:var(--ink);margin:1.5rem 0 .5rem;font-size:1rem;font-weight:500}.markdown-content ul,.markdown-content ol{margin:1.5rem 0;padding-left:2rem}.markdown-content li{margin-bottom:.75rem}.markdown-content li>ul,.markdown-content li>ol{margin:.5rem 0}.markdown-content code{font-family:var(--mono);background:var(--surface);border:1px solid var(--border);color:var(--ink);border-radius:3px;padding:.2em .4em;font-size:.9em}.markdown-content pre{background:var(--surface);border:1px solid var(--border);border-radius:4px;margin:1.5rem 0;padding:1.5rem;overflow-x:auto}.markdown-content pre code{background:0 0;border:none;padding:0;font-size:.875rem}.markdown-content blockquote{border-left:3px solid var(--accent);color:var(--ink-3);margin:1.5rem 0;padding-left:1.5rem;font-style:italic}.markdown-content blockquote p{margin-bottom:.75rem}.markdown-content blockquote p:last-child{margin-bottom:0}.markdown-content a{color:var(--accent);text-decoration:underline;transition:opacity .2s}.markdown-content a:hover{opacity:.7}.markdown-content img{border:1px solid var(--border);border-radius:4px;max-width:100%;height:auto;margin:2rem 0}.markdown-content table{border-collapse:collapse;width:100%;margin:1.5rem 0;font-size:.95rem}.markdown-content table th,.markdown-content table td{border:1px solid var(--border);text-align:left;padding:.75rem}.markdown-content table th{background:var(--surface);color:var(--ink);font-weight:500}.markdown-content hr{border:none;border-top:1px solid var(--border);margin:3rem 0}.markdown-content strong{color:var(--ink);font-weight:600}.markdown-content em{font-style:italic}.post-body{color:var(--ink-2);font-size:1.05rem;line-height:1.8}@media (width<=768px){.blog-post-page .post-title{font-size:1.75rem}.post-excerpt p,.post-body{font-size:1rem}.post-meta-info{font-size:.8rem}}.admin-page{min-height:100vh;padding:8rem 0 4rem}.admin-container{max-width:1200px;margin:0 auto;padding:0 2rem}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:8px;max-width:400px;margin:4rem auto;padding:2.5rem}.login-card h1{font-family:var(--serif);text-align:center;margin-bottom:1.5rem;font-size:2rem}.admin-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1rem;display:flex}.admin-header h1{font-family:var(--serif);font-size:2.5rem;font-weight:400}.admin-actions{gap:1rem;display:flex}.error-msg{color:#c33;background:#fee;border:1px solid #fcc;border-radius:4px;margin-bottom:1rem;padding:.75rem 1rem;font-size:.875rem}.post-form-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:99999;background:#000000b3;justify-content:center;align-items:center;padding:2rem;display:flex;position:fixed;inset:0;overflow-y:auto}.post-form-card{background:var(--bg);border:1px solid var(--border);border-radius:8px;width:100%;max-width:800px;max-height:90vh;margin:auto;padding:2rem;overflow-y:auto}.post-form-card h2{font-family:var(--serif);margin-bottom:1.5rem;font-size:1.75rem}.form-group{margin-bottom:1.25rem}.form-group label{font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--ink-2);margin-bottom:.5rem;font-size:.75rem;display:block}.form-group input,.form-group textarea,.form-group select{border:1px solid var(--border);background:var(--surface);width:100%;color:var(--ink);border-radius:4px;padding:.75rem;font-family:inherit;font-size:.875rem;transition:border-color .2s}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{border-color:var(--accent);outline:none}.form-group textarea{resize:vertical}.form-row{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.form-checks{gap:2rem;margin-bottom:1.5rem;display:flex}.checkbox-label{color:var(--ink-2);cursor:pointer;align-items:center;gap:.5rem;font-size:.875rem;display:flex}.checkbox-label input{cursor:pointer;width:auto}.form-actions{border-top:1px solid var(--border);justify-content:flex-end;gap:1rem;margin-top:2rem;padding-top:1.5rem;display:flex}button{font-family:var(--mono);letter-spacing:.06em;text-transform:uppercase;cursor:pointer;border:none;border-radius:4px;padding:.75rem 1.5rem;font-size:.75rem;transition:opacity .2s}button:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent);color:var(--bg)}.btn-primary:hover:not(:disabled){opacity:.85}.btn-secondary{background:var(--surface);color:var(--ink-2);border:1px solid var(--border)}.btn-secondary:hover{background:var(--border)}.btn-edit{background:var(--accent-light);color:#fff;padding:.4rem .8rem;font-size:.7rem}.btn-delete{color:#fff;background:#c33;padding:.4rem .8rem;font-size:.7rem}.posts-table{background:var(--surface);border:1px solid var(--border);border-radius:8px;overflow:hidden}table{border-collapse:collapse;width:100%}thead{background:var(--border)}th{text-align:left;font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--ink-2);padding:1rem;font-size:.7rem;font-weight:500}td{border-top:1px solid var(--border);color:var(--ink-2);padding:1rem;font-size:.875rem}.post-title{color:var(--ink);word-wrap:break-word;max-width:500px;font-size:large;font-weight:500;line-height:1.4}.actions{gap:.5rem;display:flex}.status-badge{font-family:var(--mono);letter-spacing:.04em;text-transform:uppercase;border-radius:12px;padding:.25rem .75rem;font-size:.7rem;display:inline-block}.status-badge.published{background:var(--accent-pale);color:var(--accent)}.status-badge.draft{color:#666;background:#f0f0f0}.no-posts-msg{text-align:center;color:var(--ink-3);padding:3rem;font-size:.875rem}@media (width<=768px){.admin-header{flex-direction:column;align-items:flex-start;gap:1rem}.form-row{grid-template-columns:1fr}.posts-table{overflow-x:auto}table{min-width:600px}}
