:root,[data-theme=dark]{color-scheme:dark;--bg: #13161d;--surface: #1b2029;--surface-2: #252b36;--border: #363e4c;--text: #eef1f5;--text-muted: #a9b2c0;--accent: #7dd3c0;--accent-hover: #b0ebdc;--accent-contrast: #06221c;--accent-subtle: rgba(125, 211, 192, .16);--accent-border: rgba(125, 211, 192, .38);--published-color: #9eb8fb;--github-color: #c0d0ff;--development-color: #ecc078;--hero-glow-a: rgba(125, 211, 192, .22);--hero-glow-b: rgba(125, 211, 192, .1);--timeline-mid: rgba(125, 211, 192, .3);--shadow: 0 20px 48px rgba(6, 8, 12, .38);--header-bg: rgba(19, 22, 29, .78);--header-bg-scrolled: rgba(19, 22, 29, .92);--card-hover-shadow: 0 18px 44px rgba(6, 8, 12, .32)}[data-theme=light]{color-scheme:light;--bg: #f6f7f9;--surface: #ffffff;--surface-2: #eef1f5;--border: #d8dee6;--text: #12151a;--text-muted: #5c6570;--accent: #0d6b5c;--accent-hover: #0a5247;--accent-contrast: #ffffff;--accent-subtle: rgba(13, 107, 92, .1);--accent-border: rgba(13, 107, 92, .35);--published-color: #1d4ed8;--github-color: #2563eb;--development-color: #b45309;--hero-glow-a: rgba(13, 107, 92, .1);--hero-glow-b: rgba(13, 107, 92, .04);--timeline-mid: rgba(13, 107, 92, .22);--shadow: 0 24px 48px rgba(18, 21, 26, .08);--header-bg: rgba(246, 247, 249, .85);--header-bg-scrolled: rgba(246, 247, 249, .96);--card-hover-shadow: 0 20px 40px rgba(18, 21, 26, .1)}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{font-family:"Source Sans 3",Source Sans Pro,system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text);line-height:1.65;overflow-x:hidden;font-size:1.0625rem;font-weight:400;-webkit-font-smoothing:antialiased}[data-theme=dark] body{background-color:var(--bg);background-image:radial-gradient(ellipse 120% 55% at 50% -18%,rgba(125,211,192,.085),transparent 52%)}.font-display{font-family:Fraunces,Georgia,serif;font-optical-sizing:auto}.container{max-width:1080px;margin:0 auto;padding:0 24px}.header{position:sticky;top:0;width:100%;background:var(--header-bg);backdrop-filter:blur(16px) saturate(1.2);-webkit-backdrop-filter:blur(16px) saturate(1.2);z-index:1000;padding:14px 0;border-bottom:1px solid var(--border);transition:background .25s ease}.header.is-scrolled{background:var(--header-bg-scrolled)}.nav{display:flex;align-items:center;gap:16px;flex-wrap:wrap}.nav-tools{display:flex;align-items:center;gap:10px;flex-shrink:0}.logo{font-family:Fraunces,Georgia,serif;font-size:1.4rem;font-weight:500;color:var(--text);letter-spacing:-.02em;text-decoration:none}.logo span{color:var(--accent)}.nav-links{display:flex;list-style:none;gap:26px;flex-wrap:wrap;padding:0;margin:0 0 0 auto}.nav-toggle{display:none;flex-direction:column;justify-content:center;align-items:center;gap:5px;width:44px;height:44px;padding:0;border:1px solid var(--border);background:var(--surface-2);color:var(--text);border-radius:12px;cursor:pointer;transition:border-color .2s ease,background .2s ease,transform .15s ease}.nav-toggle:hover{border-color:var(--accent-border);background:var(--surface)}.nav-toggle-bar{display:block;width:20px;height:2px;border-radius:1px;background:currentColor;transition:transform .25s ease,opacity .2s ease}.header.menu-open .nav-toggle .nav-toggle-bar:nth-child(1){transform:translateY(7px) rotate(45deg)}.header.menu-open .nav-toggle .nav-toggle-bar:nth-child(2){opacity:0}.header.menu-open .nav-toggle .nav-toggle-bar:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.nav-links a{color:var(--text-muted);text-decoration:none;font-size:.9375rem;font-weight:500;letter-spacing:.01em;transition:color .2s ease}.nav-links a:hover{color:var(--text)}.theme-toggle{flex-shrink:0;width:44px;height:44px;border-radius:12px;border:1px solid var(--border);background:var(--surface-2);color:var(--text);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:border-color .2s,background .2s,transform .15s}.theme-toggle:hover{border-color:var(--accent-border);background:var(--surface)}.theme-toggle:active{transform:scale(.96)}.theme-toggle svg{width:22px;height:22px}.theme-toggle .icon-sun,.theme-toggle .icon-moon{display:none}[data-theme=light] .theme-toggle .icon-moon,[data-theme=dark] .theme-toggle .icon-sun{display:block}.hero{min-height:calc(100vh - 76px);display:flex;align-items:center;padding:40px 0 72px;position:relative}.hero:before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 75% 55% at 85% -5%,var(--hero-glow-a),transparent 55%),radial-gradient(ellipse 55% 45% at 5% 105%,var(--hero-glow-b),transparent 50%);pointer-events:none}.hero-content{display:grid;grid-template-columns:1fr;gap:0;align-items:start;position:relative;z-index:1;max-width:40rem}.hero-text h1{font-family:Fraunces,Georgia,serif;font-size:clamp(2.6rem,5.5vw,3.85rem);font-weight:500;line-height:1.08;letter-spacing:-.03em;margin-bottom:14px;color:var(--text)}.hero-text .subtitle{font-size:1.125rem;font-weight:600;color:var(--accent);margin-bottom:20px;letter-spacing:.02em}.hero-text .description{font-size:1.08rem;color:var(--text-muted);margin-bottom:30px;max-width:36rem;line-height:1.7}.cta-buttons{display:flex;flex-wrap:wrap;gap:12px;align-items:center}.btn{padding:12px 22px;border-radius:10px;font-family:inherit;font-size:.9375rem;font-weight:600;cursor:pointer;transition:background .2s,color .2s,border-color .2s,transform .15s,box-shadow .2s;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;gap:8px;border:1px solid transparent}.btn-primary{background:var(--accent);color:var(--accent-contrast);box-shadow:0 2px 12px var(--accent-subtle)}.btn-primary:hover{background:var(--accent-hover);transform:translateY(-1px)}.btn-secondary{background:var(--surface);color:var(--text);border-color:var(--border)}.btn-secondary:hover{border-color:var(--text-muted);background:var(--surface-2)}.btn-ghost{background:transparent;color:var(--accent);border-color:var(--accent-border)}.btn-ghost:hover{background:var(--accent-subtle)}.hero-aside{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:28px 26px 22px;box-shadow:var(--shadow)}.hero-aside h3{font-family:Fraunces,Georgia,serif;font-size:1.35rem;font-weight:500;margin-bottom:18px;color:var(--text);letter-spacing:-.02em}.hero-meta{list-style:none}.hero-meta li{display:flex;gap:12px;padding:12px 0;border-bottom:1px solid var(--border);font-size:.94rem;color:var(--text-muted)}.hero-meta li:last-child{border-bottom:none}.hero-meta strong{color:var(--text);font-weight:600;min-width:5.5rem}.section{padding:84px 0}.section-title{font-family:Fraunces,Georgia,serif;font-size:clamp(2rem,4vw,2.75rem);font-weight:500;text-align:center;margin-bottom:12px;color:var(--text);letter-spacing:-.02em}.section-subtitle{text-align:center;color:var(--text-muted);margin-bottom:44px;font-size:1.08rem;max-width:38rem;margin-left:auto;margin-right:auto;line-height:1.65}.skills{background:var(--surface);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.projects-section{background:var(--surface)}.skills-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:18px}.skill-card{background:var(--surface-2);padding:24px;border-radius:14px;border:1px solid var(--border);transition:border-color .2s,box-shadow .2s}.skill-card:hover{border-color:var(--accent-border);box-shadow:var(--card-hover-shadow)}.skill-category{font-size:.72rem;text-transform:uppercase;letter-spacing:.11em;color:var(--accent);margin-bottom:14px;font-weight:700}.skill-list{list-style:none}.skill-list li{color:var(--text-muted);margin-bottom:8px;padding-left:16px;position:relative;font-size:.98rem}.skill-list li:before{content:"";position:absolute;left:0;top:.55em;width:5px;height:5px;border-radius:50%;background:var(--accent);opacity:.75}.projects-category{margin-bottom:60px}.projects-category:last-child{margin-bottom:0}.category-title{font-family:Fraunces,Georgia,serif;font-size:1.7rem;font-weight:500;margin-bottom:10px;text-align:center;color:var(--text);letter-spacing:-.02em}.github-projects .category-title{color:var(--github-color)}.published .category-title{color:var(--published-color)}.development .category-title{color:var(--development-color)}.category-description{text-align:center;color:var(--text-muted);margin-bottom:32px;font-size:1rem}.projects-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(330px,1fr));gap:22px}.project-card{background:var(--surface);border-radius:14px;overflow:hidden;border:1px solid var(--border);transition:border-color .2s,transform .2s,box-shadow .2s;display:flex;flex-direction:column}.project-card:hover{transform:translateY(-3px);border-color:var(--accent-border);box-shadow:var(--shadow)}.project-header{padding:24px 24px 14px;flex-grow:1}.project-title{font-family:Fraunces,Georgia,serif;font-size:1.22rem;font-weight:500;margin-bottom:12px;color:var(--text);letter-spacing:-.02em}.project-description{color:var(--text-muted);line-height:1.65;font-size:.96rem}.project-status{display:inline-block;padding:4px 10px;border-radius:8px;font-size:.68rem;font-weight:700;margin-bottom:12px;text-transform:uppercase;letter-spacing:.07em;background:var(--accent-subtle);color:var(--accent);border:1px solid var(--accent-border)}.status-github{background:color-mix(in srgb,var(--github-color) 14%,transparent);color:var(--github-color);border-color:color-mix(in srgb,var(--github-color) 28%,transparent)}.status-development{background:color-mix(in srgb,var(--development-color) 14%,transparent);color:var(--development-color);border-color:color-mix(in srgb,var(--development-color) 28%,transparent)}.status-live{background:color-mix(in srgb,var(--published-color) 14%,transparent);color:var(--published-color);border-color:color-mix(in srgb,var(--published-color) 28%,transparent)}.project-tech{padding:18px 24px 22px;border-top:1px solid var(--border)}.tech-stack{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}.tech-tag{background:var(--surface-2);color:var(--text-muted);padding:5px 11px;border-radius:8px;font-size:.78rem;border:1px solid var(--border);font-weight:500}.tech-tag:hover{color:var(--text);border-color:var(--text-muted)}.project-links{display:flex;gap:10px;flex-wrap:wrap}.project-link{color:var(--text-muted);text-decoration:none;font-weight:600;font-size:.9rem;display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border-radius:10px;border:1px solid var(--border);transition:color .2s,border-color .2s,background .2s}.project-link:hover{color:var(--accent);border-color:var(--accent);background:var(--accent-subtle)}.link-icon{font-size:.85rem}.blog-section{background:var(--bg);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.blog-card-list{list-style:none;display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px;margin-bottom:26px}.blog-card-list>li>a{display:block;height:100%;padding:22px;background:var(--surface-2);border:1px solid var(--border);border-radius:14px;text-decoration:none;color:inherit;transition:border-color .2s,box-shadow .2s}.blog-card-list>li>a:hover{border-color:var(--accent-border);box-shadow:var(--card-hover-shadow)}.blog-card-list h3{font-family:Fraunces,Georgia,serif;font-size:1.2rem;font-weight:500;margin-bottom:8px;color:var(--text);letter-spacing:-.02em}.blog-card-list .meta{font-size:.82rem;color:var(--accent);font-weight:600;margin-bottom:10px;display:flex;flex-wrap:wrap;align-items:center;gap:8px}.blog-card-list p{font-size:.94rem;color:var(--text-muted);line-height:1.55}.blog-home-cta{text-align:center}.blog-home-fallback{text-align:center;color:var(--text-muted);margin-bottom:20px;font-size:.98rem}.blog-home-fallback a{color:var(--accent);font-weight:700}.contact{background:var(--surface);border-top:1px solid var(--border)}.contact-content{text-align:center;max-width:520px;margin:0 auto}.contact-text{font-size:1.06rem;color:var(--text-muted);margin-bottom:26px;line-height:1.7}.social-links{display:flex;justify-content:center;gap:12px;margin-top:8px;flex-wrap:wrap}.social-link{color:var(--text);font-size:.94rem;font-weight:600;transition:color .2s,border-color .2s;text-decoration:none;padding:10px 16px;border-radius:10px;border:1px solid var(--border)}.social-link:hover{color:var(--accent);border-color:var(--accent)}.footer{padding:28px 0;text-align:center;color:var(--text-muted);font-size:.875rem;border-top:1px solid var(--border)}::-webkit-scrollbar{width:9px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:5px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.experience{background:var(--bg)}.experience-timeline{max-width:700px;margin:0 auto;position:relative;padding-left:28px}.experience-timeline:before{content:"";position:absolute;left:6px;top:6px;bottom:6px;width:2px;background:linear-gradient(180deg,var(--accent),var(--timeline-mid));border-radius:2px}.experience-item{position:relative;margin-bottom:36px;opacity:0;transform:translateY(24px);transition:all .45s ease}.experience-item:last-child{margin-bottom:0}.experience-dot{position:absolute;left:-26px;top:8px;width:14px;height:14px;background:var(--bg);border:3px solid var(--accent);border-radius:50%;z-index:2}.experience-content{background:var(--surface);padding:24px 26px;border-radius:14px;border:1px solid var(--border)}.experience-position{font-size:1.12rem;font-weight:700;color:var(--text);margin-bottom:4px}.experience-company{font-size:1rem;color:var(--accent);margin-bottom:6px;font-weight:600}.experience-date{font-size:.86rem;color:var(--text-muted);margin-bottom:12px}.experience-description{color:var(--text-muted);line-height:1.7;font-size:.96rem}.resume-minimal{padding:40px 0 48px;background:var(--bg);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.resume-lead{margin:0 auto;max-width:34rem;text-align:center;font-size:1.02rem;line-height:1.65;color:var(--text-muted)}.resume-strip{background:linear-gradient(180deg,var(--surface) 0%,var(--bg) 100%);border-bottom:1px solid var(--border);padding:68px 0}.resume-card{display:grid;grid-template-columns:1fr auto;gap:28px 36px;align-items:start;background:var(--surface-2);border:1px solid var(--border);border-radius:16px;padding:34px 36px;box-shadow:var(--shadow)}.eyebrow{display:block;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.14em;color:var(--accent);margin-bottom:10px}.resume-card__intro h2{font-family:Fraunces,Georgia,serif;font-size:1.8rem;font-weight:500;margin-bottom:12px;color:var(--text);letter-spacing:-.02em}.resume-card__intro p{color:var(--text-muted);max-width:38rem;font-size:1.02rem;line-height:1.65}.resume-card__actions{display:flex;flex-direction:column;gap:10px;align-items:stretch;min-width:196px}.resume-highlights{grid-column:1 / -1;list-style:none;display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:12px 20px;margin-top:8px;padding-top:22px;border-top:1px solid var(--border)}.resume-highlights li{font-size:.92rem;color:var(--text-muted);padding:12px 14px;background:var(--surface);border-radius:10px;border:1px solid var(--border);line-height:1.5}.resume-highlights strong{color:var(--accent);font-weight:700;display:block;font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;margin-bottom:4px}body.blog-body{display:flex;flex-direction:column;min-height:100vh}.blog-body main{flex:1;padding:44px 0 68px}.page-title{font-family:Fraunces,Georgia,serif;font-size:clamp(2rem,4vw,2.7rem);font-weight:500;margin-bottom:12px;letter-spacing:-.02em}.page-lead{color:var(--text-muted);max-width:40rem;margin-bottom:36px;font-size:1.06rem;line-height:1.65}.post-list{list-style:none;display:flex;flex-direction:column;gap:14px}.post-card{display:block;padding:22px 24px;background:var(--surface);border:1px solid var(--border);border-radius:14px;text-decoration:none;color:inherit;transition:border-color .2s,box-shadow .2s}.post-card:hover{border-color:var(--accent-border);box-shadow:var(--card-hover-shadow)}.post-card h2{font-family:Fraunces,Georgia,serif;font-size:1.32rem;font-weight:500;margin-bottom:8px;color:var(--text);letter-spacing:-.02em}.post-card .meta{font-size:.86rem;color:var(--accent);font-weight:600;margin-bottom:10px;display:flex;flex-wrap:wrap;align-items:center;gap:8px}.post-source{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);border:1px solid var(--border);padding:3px 8px;border-radius:6px}.post-card p{color:var(--text-muted);font-size:.98rem;line-height:1.6}.back-row{margin-bottom:26px}.back-link{color:var(--text-muted);text-decoration:none;font-size:.94rem;font-weight:600}.back-link:hover{color:var(--accent)}.article-header{margin-bottom:28px;padding-bottom:22px;border-bottom:1px solid var(--border)}.article-header h1{font-family:Fraunces,Georgia,serif;font-size:clamp(1.85rem,4vw,2.45rem);font-weight:500;line-height:1.15;margin-bottom:12px;letter-spacing:-.02em}.article-header time{font-size:.9rem;color:var(--text-muted);font-weight:500}.prose{max-width:42rem;font-size:1.05rem;color:var(--text-muted);line-height:1.75}.prose>*+*{margin-top:1.1em}.prose h2,.prose h3{font-family:Fraunces,Georgia,serif;color:var(--text);font-weight:500;margin-top:1.7em;margin-bottom:.45em;letter-spacing:-.02em}.prose h2{font-size:1.5rem}.prose h3{font-size:1.22rem}.prose a{color:var(--accent);font-weight:600;text-decoration:underline;text-underline-offset:3px}.prose a:hover{color:var(--accent-hover)}.prose ul,.prose ol{padding-left:1.35em}.prose li{margin-bottom:.35em}.prose strong{color:var(--text);font-weight:600}.prose blockquote{border-left:3px solid var(--accent);padding-left:1rem;color:var(--text-muted);font-style:italic}.prose img{max-width:100%;height:auto;border-radius:8px;border:1px solid var(--border)}.prose code{font-family:Source Code Pro,ui-monospace,monospace;font-size:.86em;background:var(--surface-2);padding:.15em .45em;border-radius:6px;border:1px solid var(--border);color:var(--text)}.prose pre{background:var(--surface-2);border:1px solid var(--border);border-radius:10px;padding:1rem 1.15rem;overflow-x:auto;overflow-y:hidden;font-size:.88rem;line-height:1.55}.prose .code-block-wrap{position:relative}.prose pre.pre--with-copy{padding-top:2.35rem;margin-top:0;margin-bottom:0}.prose .code-block-wrap .code-copy-btn{position:absolute;top:.45rem;right:.45rem;z-index:2;font-family:"Source Sans 3",system-ui,sans-serif;font-size:.72rem;font-weight:600;letter-spacing:.03em;text-transform:uppercase;padding:.28rem .55rem;border-radius:6px;border:1px solid var(--border);background:var(--surface);color:var(--text-muted);cursor:pointer;transition:color .15s ease,border-color .15s ease,background .15s ease}.prose .code-block-wrap .code-copy-btn:hover{color:var(--text);border-color:var(--accent);background:var(--surface-2)}.prose pre code{display:block;width:max-content;min-width:100%;box-sizing:border-box;background:none;border:none;padding:0;font-size:inherit}.prose pre code[class*=language-] .token.comment,.prose pre code[class*=language-] .token.prolog,.prose pre code[class*=language-] .token.doctype,.prose pre code[class*=language-] .token.cdata{color:var(--text-muted);font-style:italic}.prose pre code[class*=language-] .token.punctuation,.prose pre code[class*=language-] .token.operator{color:var(--text-muted)}.prose pre code[class*=language-] .token.property,.prose pre code[class*=language-] .token.tag,.prose pre code[class*=language-] .token.constant,.prose pre code[class*=language-] .token.symbol,.prose pre code[class*=language-] .token.deleted{color:var(--github-color)}.prose pre code[class*=language-] .token.boolean,.prose pre code[class*=language-] .token.number{color:var(--development-color)}.prose pre code[class*=language-] .token.selector,.prose pre code[class*=language-] .token.attr-name,.prose pre code[class*=language-] .token.string,.prose pre code[class*=language-] .token.char,.prose pre code[class*=language-] .token.builtin,.prose pre code[class*=language-] .token.inserted,.prose pre code[class*=language-] .token.regex,.prose pre code[class*=language-] .token.attr-value{color:var(--published-color)}.prose pre code[class*=language-] .token.atrule,.prose pre code[class*=language-] .token.keyword,.prose pre code[class*=language-] .token.important{color:var(--accent);font-weight:600}.prose pre code[class*=language-] .token.function,.prose pre code[class*=language-] .token.class-name{color:var(--accent-hover)}.prose pre code[class*=language-] .token.variable,.prose pre code[class*=language-] .token.parameter,.prose pre code[class*=language-] .token.this{color:var(--text)}.prose hr{border:none;border-top:1px solid var(--border);margin:2rem 0}.empty-state,.error-state{color:var(--text-muted);padding:2rem;text-align:center;border:1px dashed var(--border);border-radius:14px}.blog-body .footer{margin-top:auto}.site-wrap{min-height:100vh;display:flex;flex-direction:column}.site-main{flex:1}.page-section{padding:48px 0 72px}@media(max-width:768px){.nav-toggle{display:inline-flex}.nav{flex-wrap:wrap;row-gap:0}.logo{order:1}.nav-tools{order:2;margin-left:auto}.nav-links{order:3;margin-left:0;width:100%;flex-direction:column;align-items:stretch;gap:0;max-height:0;overflow:hidden;opacity:0;padding-top:0;margin-top:0;border-top:1px solid transparent;transition:max-height .35s ease,opacity .22s ease,padding-top .22s ease,margin-top .22s ease,border-color .22s ease}.nav-links li{border-bottom:1px solid var(--border)}.nav-links li:last-child{border-bottom:none}.nav-links a{display:block;padding:14px 4px;font-size:1rem}.header.menu-open .nav-links{max-height:min(70vh,360px);overflow-y:auto;opacity:1;padding-top:10px;margin-top:12px;border-top-color:var(--border)}.hero-content{grid-template-columns:1fr;gap:0;max-width:none}.cta-buttons{flex-direction:column;align-items:stretch}.skills-grid,.projects-grid{grid-template-columns:1fr}.tech-stack,.project-links{justify-content:flex-start}.experience-timeline{padding-left:24px}.experience-dot{left:-22px}.resume-card{grid-template-columns:1fr;padding:26px 20px}.resume-card__actions{flex-direction:row;flex-wrap:wrap}}.nav-links.svelte-1u3q4z5 a.active:where(.svelte-1u3q4z5){color:var(--text)}
