:root{color-scheme:dark;--background: #000000;--foreground: #ededed;--muted: #1a1a1a;--muted-foreground: #ffffff;--card: #0a0a0a;--card-foreground: #ededed;--border: #2e2e2e;--border-strong: #454545;--primary: #ededed;--primary-foreground: #000000;--accent: #0090ff;--accent-muted: #0062cc;--ring: #0090ff;--header-bg: rgba(0, 0, 0, .78);--surface-alpha: rgba(10, 10, 10, .82);--surface-alpha-soft: rgba(255, 255, 255, .05);--badge-foreground: #51aeff;--badge-bg: rgba(0, 144, 255, .1);--badge-border: rgba(0, 144, 255, .35);--button-outline-bg: rgba(255, 255, 255, .05);--wall-texture: url(/wall-texture-dark.webp);--wall-opacity: 0;--wall-vignette: rgba(0, 0, 0, .46);--code-bg: #0a0a0a;--preview-bg: #0a0a0a;--portrait-filter: none;--radius: 8px;--shadow: 0 20px 60px rgba(0, 0, 0, .22);--page-gutter: clamp(1rem, 3vw, 3rem);--header-height: 70px;--section-y: clamp(4.25rem, 8vw, 5.5rem);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--background);color:var(--foreground);font-synthesis:none;line-height:1.5;text-rendering:optimizeLegibility}html[data-theme=light]{color-scheme:light;--background: #ffffff;--foreground: #171717;--muted: #f2f2f2;--muted-foreground: #000000;--card: #ffffff;--card-foreground: #171717;--border: #eaeaea;--border-strong: #d0d0d0;--primary: #171717;--primary-foreground: #ffffff;--accent: #0070f7;--accent-muted: #b3d4ff;--ring: #0070f7;--header-bg: rgba(255, 255, 255, .8);--surface-alpha: rgba(255, 255, 255, .85);--surface-alpha-soft: rgba(0, 0, 0, .03);--badge-foreground: #0070f7;--badge-bg: rgba(0, 112, 247, .07);--badge-border: rgba(0, 112, 247, .25);--button-outline-bg: rgba(0, 0, 0, .03);--wall-texture: url(/wall-texture-light.webp);--wall-opacity: 0;--wall-vignette: rgba(255, 255, 255, .3);--code-bg: #0a0a0a;--preview-bg: #0a0a0a;--portrait-filter: none;--shadow: 0 18px 55px rgba(41, 33, 25, .08)}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;min-width:320px;min-height:100vh;background:var(--background)}body:before{position:fixed;top:0;right:0;bottom:0;left:0;z-index:-1;pointer-events:none;content:"";opacity:var(--wall-opacity);background-image:var(--wall-texture);background-size:512px 512px}body:after{position:fixed;top:0;right:0;bottom:0;left:0;z-index:-1;pointer-events:none;content:"";background:radial-gradient(circle at 76% 18%,transparent 0,transparent 26rem,var(--wall-vignette) 60rem),radial-gradient(circle at 18% 82%,transparent 0,transparent 22rem,var(--wall-vignette) 58rem)}a{color:inherit;text-decoration:none}img,svg{max-width:100%}button,input,textarea,select{font:inherit}button{border:0}::selection{color:var(--primary-foreground);background:var(--primary)}#root{width:100%}.site-header{position:sticky;top:0;z-index:20;display:grid;width:min(1490px,calc(100% - (var(--page-gutter) + var(--page-gutter))));min-height:var(--header-height);grid-template-columns:1fr auto 1fr;align-items:center;gap:16px;margin:0 auto;padding:14px 0;background:var(--header-bg);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.menu-button,.theme-toggle{display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;border-radius:var(--radius)}.header-spacer{min-width:1px}.desktop-nav{display:flex;align-items:center;gap:18px;justify-self:center}.desktop-nav a,.mobile-nav a{border-radius:var(--radius);color:var(--muted-foreground);font-size:.92rem;font-weight:560}.desktop-nav a{padding:10px 4px}.desktop-nav a:hover,.mobile-nav a:hover{color:var(--foreground);background:transparent}.header-actions{display:flex;align-items:center;justify-self:end;gap:10px}.menu-button,.theme-toggle{width:38px;height:38px;border:1px solid var(--border);color:var(--foreground);background:var(--button-outline-bg);cursor:pointer}.menu-button{display:none}.mobile-nav{position:absolute;top:calc(100% + 8px);right:0;left:0;display:grid;gap:4px;padding:8px;border:1px solid var(--border);border-radius:calc(var(--radius) + 8px);background:var(--card);box-shadow:var(--shadow)}.mobile-nav a{padding:12px}main,.site-footer{width:min(1490px,calc(100% - (var(--page-gutter) + var(--page-gutter))));margin-inline:auto}.section{padding:var(--section-y) 0;scroll-margin-top:calc(var(--header-height) + 30px)}.split-section,#projects,.blog-section,.contact-section{min-height:100svh}#projects,.blog-section{display:flex;flex-direction:column;justify-content:center}.split-section,.contact-section{align-content:center}.reveal{opacity:0;transform:translateY(18px);transition:opacity .65s cubic-bezier(.22,1,.36,1),transform .65s cubic-bezier(.22,1,.36,1);will-change:opacity,transform}.reveal.is-visible{opacity:1;transform:none}.reveal-delay{transition-delay:.12s}.hero{display:grid;min-height:calc(100svh - 70px);grid-template-columns:minmax(0,1.05fr) minmax(360px,.95fr);align-items:center;gap:clamp(28px,4vw,56px);padding-top:20px;padding-bottom:44px}.hero-copy{display:grid;gap:22px;max-width:720px;padding-left:4px}.badge{display:inline-flex;width:fit-content;max-width:100%;align-items:center;gap:8px;padding:8px 10px;border:1px solid var(--badge-border);border-radius:999px;color:var(--badge-foreground);background:var(--badge-bg);font-size:.86rem;font-weight:600;line-height:1}.hero h1,.section-heading h2,.split-section h2,.contact-section h2{margin:0;color:var(--foreground);font-weight:720;line-height:.98;letter-spacing:0;overflow-wrap:break-word;text-wrap:balance}.hero h1{max-width:760px;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:clamp(2.35rem,4.1vw,3.65rem);font-weight:650;line-height:1.06;text-wrap:wrap}.signature-mark{display:block;width:min(254px,68vw);height:auto;overflow:visible;color:var(--accent);opacity:.96;pointer-events:none;-webkit-user-select:none;user-select:none}.hero-summary p,.about-intro p,.contact-section p{margin:0;color:var(--muted-foreground);font-size:clamp(1rem,1.25vw,1.08rem);line-height:1.75;text-wrap:pretty}.about-intro{display:grid;gap:14px}.hero-summary p,.about-intro p,.contact-section p{color:var(--muted-foreground);font-weight:600}.hero-summary{display:grid;gap:10px;max-width:720px}.contact-actions,.social-links{display:flex;flex-wrap:wrap;align-items:center;gap:10px}.button{display:inline-flex;align-items:center;justify-content:center;gap:9px;border-radius:var(--radius);font-weight:650;line-height:1;white-space:nowrap;transition:transform .18s ease,border-color .18s ease,background .18s ease,color .18s ease}.button:hover{transform:translateY(-1px)}.button:focus-visible,a:focus-visible,button:focus-visible{outline:2px solid var(--ring);outline-offset:3px}.button-md{min-height:44px;padding:0 16px;font-size:.95rem}.button-sm{min-height:36px;padding:0 12px;font-size:.88rem}.button-icon{width:40px;height:40px;padding:0}.button-default{color:var(--primary-foreground);background:var(--primary)}.button-outline{border:1px solid var(--border-strong);color:var(--foreground);background:var(--button-outline-bg)}.button-ghost{color:var(--muted-foreground);background:transparent}.button-ghost:hover{color:var(--foreground)}.card,.post-reader,.post-list{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface-alpha);box-shadow:var(--shadow)}.card,.blog-detail,.blog-modal,.contact-card-link{min-width:0}.hero-visual{position:relative;display:flex;min-height:680px;align-items:center;justify-content:center;overflow:hidden}.hero-visual img{position:relative;z-index:1;width:min(620px,100%);height:auto;max-height:min(720px,calc(100svh - 130px));margin:0;filter:var(--portrait-filter);mix-blend-mode:normal;object-fit:contain}.project-title-row,.post-reader-meta,.site-footer{display:flex;align-items:center;justify-content:space-between;gap:12px}.project-title-row>div,.contact-card-link>span{min-width:0}.project-title-row p,.card-content p{margin:0;color:var(--muted-foreground)}.project-title-row p{color:var(--accent);font-weight:600}.card-content p{color:var(--muted-foreground);font-weight:600}.split-section{display:grid;grid-template-columns:minmax(0,.8fr) minmax(0,1fr);gap:54px;border-top:1px solid var(--border)}.split-section h2,.section-heading h2,.contact-section h2{margin-top:18px;font-size:clamp(2.8rem,5.2vw,4.3rem)}.about-content{display:grid;gap:28px}.principles{display:grid;gap:10px}.principle-item{display:flex;align-items:flex-start;gap:10px;color:var(--muted-foreground);min-width:0}.principle-item svg{flex:0 0 auto;margin-top:3px;color:var(--accent)}.skills-panel{display:grid;gap:14px}.skill-tabs{display:flex;flex-wrap:wrap;gap:8px}.skill-tabs button{min-height:38px;padding:0 12px;border:1px solid var(--border);border-radius:var(--radius);color:var(--foreground);background:var(--button-outline-bg);font-size:.88rem;font-weight:650;cursor:pointer}.skill-tabs button.active,.skill-tabs button:hover{color:var(--primary-foreground);border-color:var(--primary);background:var(--primary)}.skill-panel-body{display:grid;gap:16px;padding:18px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface-alpha)}.skill-panel-body p{margin:0;color:var(--muted-foreground);line-height:1.72}.stack-list,.project-tags{display:flex;flex-wrap:wrap;gap:8px}.stack-list span,.project-tags span{border:1px solid var(--badge-border);border-radius:999px;color:var(--badge-foreground);background:var(--badge-bg);font-size:.86rem;font-weight:600;line-height:1}.stack-list span{padding:9px 11px}.section-heading{max-width:780px;margin-bottom:34px}.card{overflow:hidden}.card-header,.card-content{display:grid;gap:18px;padding:18px}.card-title{margin:4px 0 0;font-size:1.7rem;line-height:1.15}.project-card{min-height:100%}.project-feature-card{display:grid;grid-template-columns:minmax(0,1.45fr) minmax(360px,.78fr);min-height:560px}.project-showcase{position:relative;display:grid;overflow:hidden;border-right:1px solid var(--border);background:var(--preview-bg)}.project-showcase img{display:block}.project-shot-main{width:100%;height:100%;min-height:560px;object-fit:cover}.project-shot-mobile{position:absolute;right:24px;bottom:24px;width:min(178px,28%);max-height:calc(100% - 48px);border:1px solid rgba(255,255,255,.22);border-radius:var(--radius);box-shadow:0 22px 54px #00000059;object-fit:cover}.project-feature-content{display:grid;align-content:center}.project-feature-card .card-header,.project-feature-card .card-content{padding:24px}.project-feature-card .card-content{gap:22px}.project-feature-list{display:grid;gap:10px}.project-title-row a{display:inline-flex;width:38px;height:38px;align-items:center;justify-content:center;flex:0 0 auto;border:1px solid var(--border);border-radius:var(--radius);color:var(--foreground);background:var(--card)}.project-tags span{padding:8px 10px}.blog-layout{display:grid;grid-template-columns:minmax(240px,.4fr) minmax(0,1fr);gap:16px;align-items:stretch}.blog-sidebar{display:grid;gap:10px;align-content:start;padding:12px;border:1px solid var(--border);border-radius:calc(var(--radius) + 4px);background:var(--surface-alpha)}.blog-search{display:flex;align-items:center;gap:8px;padding:0 12px;border:1px solid var(--border);border-radius:var(--radius);color:var(--muted-foreground);background:var(--background)}.blog-search input{width:100%;min-height:40px;border:0;color:var(--foreground);background:transparent;outline:none}.blog-search input::placeholder{color:var(--muted-foreground)}.blog-post-list{display:grid;gap:4px}.blog-post-list button{display:grid;gap:6px;width:100%;padding:12px 14px;border:1px solid transparent;border-radius:var(--radius);color:var(--muted-foreground);background:transparent;text-align:left;cursor:pointer;transition:background .16s ease,border-color .16s ease,color .16s ease}.blog-post-list button:hover{color:var(--foreground);background:var(--muted)}.blog-post-list button.active{color:var(--foreground);border-color:var(--border);background:var(--muted)}.blog-post-list button span{font-weight:600;line-height:1.3}.blog-post-list button small{display:inline-flex;align-items:center;gap:6px;color:var(--muted-foreground);font-size:.78rem}.blog-empty{margin:0;padding:12px 14px;color:var(--muted-foreground);font-size:.9rem}.blog-detail{display:flex;flex-direction:column;gap:16px;min-height:min(560px,70vh);padding:28px;border:1px solid var(--border);border-radius:calc(var(--radius) + 4px);background:var(--surface-alpha);box-shadow:var(--shadow);animation:blog-fade .2s ease}.blog-detail-meta{display:flex;flex-wrap:wrap;gap:16px;color:var(--muted-foreground);font-size:.82rem}.blog-detail-meta span{display:inline-flex;align-items:center;gap:6px}.blog-detail h3{margin:0;color:var(--foreground);font-size:1.9rem;line-height:1.15}.blog-topics{display:flex;flex-wrap:wrap;gap:8px}.blog-topics span{padding:6px 10px;border:1px solid var(--badge-border);border-radius:999px;color:var(--badge-foreground);background:var(--badge-bg);font-size:.8rem;font-weight:600}.blog-detail-summary{margin:0;max-width:62ch;color:var(--muted-foreground);font-size:1.05rem;line-height:1.7;text-wrap:pretty}.blog-detail .read-more-bar{width:fit-content;min-width:200px;margin-top:auto}.blog-modal-heading small{display:inline-flex;align-items:center;gap:6px;color:var(--muted-foreground);font-size:.8rem}.read-more-bar{display:flex;align-items:center;justify-content:space-between;width:100%;padding:12px 16px;border:1px solid var(--badge-border);border-radius:var(--radius);color:var(--accent);background:var(--badge-bg);font-size:.92rem;font-weight:600;cursor:pointer;transition:background .18s ease,border-color .18s ease,transform .18s ease}.read-more-bar:hover{border-color:var(--accent);transform:translateY(-1px)}.blog-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;display:flex;align-items:center;justify-content:center;padding:24px;background:#0000009e;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:blog-fade .16s ease}.blog-modal{display:flex;flex-direction:column;width:min(840px,100%);max-height:min(88vh,960px);overflow:hidden;border:1px solid var(--border);border-radius:calc(var(--radius) + 6px);background:var(--card);box-shadow:var(--shadow);animation:blog-rise .2s ease}.blog-modal-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:20px 24px;border-bottom:1px solid var(--border);background:var(--card)}.blog-modal-heading{display:grid;gap:8px}.blog-modal-heading h2{margin:0;color:var(--foreground);font-size:1.5rem;line-height:1.2}.blog-modal-close{display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;width:38px;height:38px;border:1px solid var(--border);border-radius:var(--radius);color:var(--foreground);background:var(--button-outline-bg);cursor:pointer}.blog-modal-close:hover{border-color:var(--border-strong)}.blog-modal-body{overflow-y:auto;padding:24px}@keyframes blog-fade{0%{opacity:0}}@keyframes blog-rise{0%{opacity:0;transform:translateY(8px)}}.post-list{display:grid;align-content:start;gap:6px;padding:8px;box-shadow:none}.post-list button{display:grid;gap:8px;width:100%;padding:14px;border:1px solid transparent;border-radius:var(--radius);color:var(--muted-foreground);background:transparent;text-align:left;cursor:pointer}.post-list button.active,.post-list button:hover{border-color:var(--border);color:var(--foreground);background:var(--muted)}.post-list span{font-weight:680}.post-list small{display:flex;align-items:center;gap:6px;color:inherit;font-size:.78rem}.post-reader{min-width:0;padding:24px}.post-reader-meta{justify-content:flex-start;margin-bottom:22px;padding-bottom:18px;border-bottom:1px solid var(--border);color:var(--muted-foreground)}.markdown-body{display:grid;gap:16px}.markdown-body h1,.markdown-body h2,.markdown-body h3,.markdown-body p,.markdown-body ul{margin:0}.markdown-body h1{font-size:3.25rem;line-height:1.04}.markdown-body h2{margin-top:12px;font-size:1.45rem;line-height:1.2}.markdown-body h3{margin-top:8px;font-size:1.1rem}.markdown-body p,.markdown-body li{color:var(--muted-foreground);line-height:1.78}.markdown-body ul{display:grid;gap:8px;padding-left:20px}.markdown-body code{border:1px solid var(--border);border-radius:5px;padding:.12rem .32rem;color:var(--foreground);background:var(--muted);font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:.92em}.markdown-body pre,.mermaid-frame{overflow-x:auto;border:1px solid var(--border);border-radius:var(--radius);background:var(--code-bg)}.markdown-body pre{margin:0;padding:16px}.markdown-body pre code{display:block;border:0;padding:0;color:var(--primary);background:transparent;font-size:.84rem;line-height:1.72}.mermaid-frame{background:var(--card)}.mermaid-frame p,.mermaid-frame pre{margin:0;padding:16px;color:var(--muted-foreground)}.mermaid-frame svg{display:block;width:100%;min-width:520px;height:auto;padding:12px}.contact-section{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:32px;align-items:end;margin:60px 0 88px;padding:36px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.contact-section h2{max-width:740px}.contact-section p{max-width:640px;margin-top:18px}.contact-actions{display:grid;justify-items:end}.contact-card-link{display:grid;width:min(420px,100%);grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:14px;padding:16px;border:1px solid var(--border);border-radius:calc(var(--radius) + 4px);color:var(--foreground);background:var(--surface-alpha);box-shadow:var(--shadow)}.contact-card-link small,.footer-copy{color:var(--muted-foreground)}.contact-card-link small{display:block;margin-bottom:2px;font-size:.76rem;font-weight:680;text-transform:uppercase}.contact-card-link strong{display:block;font-size:1.12rem;line-height:1.2;word-break:break-word}.contact-card-icon{display:inline-flex;width:42px;height:42px;align-items:center;justify-content:center;border:1px solid var(--border);border-radius:var(--radius);color:var(--primary-foreground);background:var(--primary)}.social-links a{display:inline-flex;align-items:center;gap:8px;min-height:38px;padding:0 11px;border:1px solid var(--border);border-radius:var(--radius);color:var(--muted-foreground);background:var(--button-outline-bg);font-size:.88rem;font-weight:620}.social-links a:hover{color:var(--foreground);border-color:var(--border-strong)}.site-footer{min-height:74px;color:var(--muted-foreground);font-size:.88rem}.footer-copy{display:inline-flex;flex-wrap:wrap;align-items:center;gap:10px}.footer-glyphs{color:var(--accent);font-size:1rem;letter-spacing:.12em}.site-footer a{display:inline-flex;align-items:center;gap:7px;color:var(--foreground);font-weight:650}@media(max-width:900px){.hero,.split-section,.blog-layout,.contact-section{grid-template-columns:1fr}.split-section,#projects,.blog-section,.contact-section{min-height:auto}.hero{min-height:auto;gap:clamp(2rem,6vw,4rem);padding-top:clamp(3rem,7vw,5rem)}.hero-copy{max-width:820px}.hero-visual{min-height:0;justify-content:center}.hero-visual img{width:min(540px,78vw);max-height:none}.project-feature-card{grid-template-columns:1fr;min-height:auto}.project-showcase{border-right:0;border-bottom:1px solid var(--border)}.project-shot-main{min-height:0;aspect-ratio:16 / 10}.contact-actions{justify-items:start}.blog-detail{min-height:auto}}@media(max-width:680px){:root{--page-gutter: 12px;--section-y: 64px}.site-header,main,.site-footer{width:min(100% - 24px,1490px)}.site-header{grid-template-columns:1fr auto;min-height:64px;padding:10px 0}.header-spacer,.desktop-nav{display:none}.menu-button{display:inline-flex}.section{padding:var(--section-y) 0;scroll-margin-top:84px}.reveal{opacity:1;transform:none;transition:none}.hero{gap:26px;padding-top:44px}.hero h1{font-size:clamp(2rem,8.6vw,2.42rem);line-height:1.06}.hero-summary p,.about-intro p,.contact-section p{font-size:1rem;line-height:1.62}.signature-mark{width:min(214px,64vw)}.contact-card-link{width:100%}.post-reader{padding:16px}.hero-visual{min-height:0;margin-top:4px}.hero-visual img{width:min(360px,100%)}.split-section{gap:26px}.split-section h2,.section-heading h2,.contact-section h2{font-size:clamp(2.2rem,9.6vw,2.65rem);line-height:1.04}.project-shot-main{aspect-ratio:16 / 11}.project-shot-mobile{right:12px;bottom:12px;width:clamp(88px,28vw,116px);max-height:calc(100% - 24px)}.project-feature-card .card-header,.project-feature-card .card-content{padding:18px}.post-list{overflow-x:auto;grid-auto-columns:minmax(236px,1fr);grid-auto-flow:column}.blog-layout{gap:16px}.blog-sidebar{padding:10px}.blog-detail{gap:14px;padding:20px}.blog-detail h3{font-size:clamp(1.65rem,7vw,2rem)}.blog-modal-overlay{align-items:stretch;padding:10px}.blog-modal{width:100%;max-height:calc(100svh - 20px)}.blog-modal-header{padding:16px}.blog-modal-body{padding:18px}.markdown-body h1{font-size:clamp(1.8rem,8vw,2.2rem)}.contact-section{gap:24px;margin:44px 0 64px;padding:32px 0}.social-links{width:100%}.site-footer{flex-direction:column;align-items:flex-start;justify-content:center;gap:12px;min-height:auto;padding:18px 0}}@media(max-width:380px){:root{--page-gutter: 10px;--section-y: 56px}.site-header,main,.site-footer{width:min(100% - 20px,1490px)}.menu-button,.theme-toggle{width:36px;height:36px}.hero h1{font-size:clamp(1.9rem,9vw,2.05rem)}.split-section h2,.section-heading h2,.contact-section h2{font-size:clamp(2rem,9.4vw,2.2rem)}.project-feature-card .card-header,.project-feature-card .card-content,.blog-detail{padding:16px}.contact-card-link{grid-template-columns:auto minmax(0,1fr)}.contact-card-link>svg{display:none}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}.reveal{opacity:1;transform:none}}
