@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/2c55a0e60120577a-s.2a48534a.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/9c72aa0f40e4eef8-s.18a48cbc.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/ad66f9afd8947f86-s.7a40eb73.woff2)format("woff2");unicode-range:U+1F??}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/5476f68d60460930-s.c995e352.woff2)format("woff2");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/2bbe8d2671613f1f-s.76dcb0b2.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/1bffadaabf893a1e-s.7cd81963.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/83afe278b6a6bb3c-s.p.3a6ba036.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Inter Fallback;src:local(Arial);ascent-override:90.44%;descent-override:22.52%;line-gap-override:0.0%;size-adjust:107.12%}.inter_5972bc34-module__OU16Qa__className{font-family:Inter,Inter Fallback;font-style:normal}
:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;--bg:#fff;--text:#0c0c0c;--muted:#5a5a5a;--border:#e6e6e6;--accent:#c3ddfd;--accent-strong:#2b5cc4;--accent-hover:#c3ddfd4d;--shadow:0 12px 30px #0c0c0c14;--radius:18px;--radius-sm:12px;--max-width:1040px;--page-pad:24px}@media (max-width:600px){:root{--page-pad:16px}}*,:before,:after{box-sizing:border-box}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--text);margin:0;line-height:1.6}img{max-width:100%;display:block}a{color:inherit;text-decoration:none}button{font:inherit;color:inherit;background:0 0;border:none;padding:0}:focus-visible{outline:2px solid var(--accent-strong);outline-offset:3px}@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}.page{min-height:100vh}.container{max-width:var(--max-width);padding:0 var(--page-pad);margin:0 auto}.section{padding:96px 0;scroll-margin-top:90px}@media (max-width:800px){.section{padding:72px 0}}.section-title{letter-spacing:-.02em;margin:0 0 28px;font-size:2rem}.muted{color:var(--muted)}.navbar{z-index:10;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--border);background:#ffffffe6;position:sticky;top:0}.navbar-inner{justify-content:space-between;align-items:center;min-height:72px;display:flex}.brand{align-items:center;gap:10px;font-weight:600;display:inline-flex}.nav-links{align-items:center;gap:20px;display:flex}.nav-link{border-bottom:2px solid #0000;padding:8px 4px;font-size:.95rem;transition:color .2s,border-color .2s}.nav-link.active{border-bottom-color:var(--accent);color:var(--text)}.nav-link:not(.active):hover{border-bottom-color:#c3ddfd99}.menu-button{border:1px solid var(--border);border-radius:999px;justify-content:center;align-items:center;width:40px;height:40px;display:none}@media (max-width:820px){.nav-links{display:none}.menu-button{display:inline-flex}}.mobile-menu{flex-direction:column;gap:12px;padding:12px 0 20px;display:none}.mobile-menu.open{display:flex}.hero{padding-top:88px}.hero h1{letter-spacing:-.03em;max-width:520px;margin:0 0 14px;font-size:clamp(2.1rem,3.4vw,3rem);line-height:1.04}.hero p{max-width:560px;margin:0 0 20px;font-size:1.02rem}.hero-grid{justify-content:flex-start;align-items:center;gap:64px;display:flex}.hero-text{flex:60%;max-width:560px}.hero-photo{flex:0 0 40%;justify-content:center;align-items:center;display:flex}.hero-photo img{border:2px solid #c3ddfd59;border-radius:20px;box-shadow:0 10px 24px #0c0c0c14}.hero-subcopy{white-space:pre-line;line-height:1.45}.hero-title{display:block}.hero-subtitle{color:var(--muted);margin-top:6px;font-size:1.1rem;font-weight:500;line-height:1.3;display:block}@media (max-width:820px){.hero-grid{text-align:center;flex-direction:column;gap:16px}.hero-photo{order:-1}.hero-actions{justify-content:center}}.hero-actions{flex-wrap:wrap;gap:8px;margin-top:4px;display:flex}.hero-actions .button{width:140px;min-height:44px}.contact-wrap{justify-content:center;align-items:center;gap:18px;margin-top:24px;display:flex}.contact-actions{flex-direction:column;align-items:flex-start;gap:10px;display:flex}.contact-actions .button{width:180px;min-height:44px}.contact-photo img{border-radius:var(--radius-sm);border:1px solid #c3ddfd80;box-shadow:0 10px 24px #0c0c0c14}.section.contact-section .container{text-align:center;flex-direction:column;align-items:center;display:flex}@media (max-width:820px){.contact-wrap{flex-direction:column}.contact-actions{align-items:center}}.grid-3{grid-template-columns:repeat(3,minmax(0,1fr));gap:20px;display:grid}.grid-5{grid-template-columns:repeat(2,minmax(0,1fr));align-items:stretch;gap:20px;display:grid}@media (max-width:900px){.grid-3,.grid-5{grid-template-columns:1fr}}.card{border:1px solid var(--border);border-radius:var(--radius);background:#fff;padding:24px}.card-title{margin:0 0 12px;font-size:1.2rem}.badge-row{flex-wrap:wrap;gap:8px;display:flex}.badge{border:1px solid var(--accent);background:var(--accent-hover);border-radius:999px;padding:6px 12px;font-size:.85rem}.button{border:1px solid var(--accent);background:var(--accent);color:#0c0c0c;border-radius:999px;justify-content:center;align-items:center;gap:8px;padding:10px 18px;font-weight:600;transition:transform .2s,box-shadow .2s;display:inline-flex}.button.secondary{background:0 0}.button:hover{background:var(--accent-hover);transform:translateY(-2px);box-shadow:0 10px 22px #0c0c0c14}.button-icon{align-items:center;display:inline-flex}.accordion{flex-direction:column;gap:16px;display:flex}.accordion-item{border:1px solid var(--border);border-radius:var(--radius);padding:16px 20px}.accordion-trigger{text-align:left;justify-content:space-between;align-items:flex-start;gap:16px;width:100%;display:flex}.accordion-content{margin-top:16px}.experience-title{align-items:center;gap:10px;display:inline-flex}.experience-logo{object-fit:contain;border-radius:6px}.experience-meta{color:var(--muted);flex-wrap:wrap;gap:12px;font-size:.95rem;display:flex}.list{margin:12px 0 14px;padding-left:18px}.list li{margin:6px 0}.project-card{cursor:pointer;text-align:left;width:100%;height:100%;display:block}.project-card .card{flex-direction:column;height:100%;min-height:220px;transition:box-shadow .24s ease-out;display:flex}.project-card:hover .card{box-shadow:0 12px 24px #0c0c0c1a}.project-title{justify-content:space-between;align-items:flex-start;gap:10px;display:flex}.project-title-main{align-items:center;gap:10px;display:inline-flex}.project-title-main img{border-radius:6px}.project-hint-icon{color:var(--muted);opacity:.58;font-size:.95rem;line-height:1;transition:opacity .2s ease-out,transform .2s ease-out;transform:translateY(0)}.project-card:hover .project-hint-icon{opacity:.88;transform:translateY(-1px)}.project-preview-button{cursor:pointer;background:0 0;border:0;border-radius:10px;margin:0;padding:0;display:block;position:relative;overflow:hidden}.project-preview-image{object-fit:cover;border:1px solid var(--border);border-radius:10px;width:100%;height:140px;transition:transform .24s ease-out}.project-card:hover .project-preview-image{transform:scale(1.03)}.modal-overlay{z-index:50;overscroll-behavior:none;background:#0c0c0c99;justify-content:center;align-items:center;padding:24px;animation:.2s ease-out modal-overlay-fade;display:flex;position:fixed;inset:0}.modal{border-radius:var(--radius);border:1px solid var(--border);width:min(780px,100%);max-height:85vh;box-shadow:var(--shadow);background:#fff;flex-direction:column;animation:.25s ease-out modal-enter;display:flex;overflow:hidden}.modal-header{border-bottom:1px solid var(--border);flex:none;justify-content:space-between;align-items:center;gap:16px;padding:20px 22px;display:flex}.modal-body{overscroll-behavior:contain;-webkit-overflow-scrolling:touch;flex:auto;padding:18px 22px 22px;overflow:auto}.modal-body>:first-child{margin-top:0}.modal-body>:last-child{margin-bottom:0}.modal-title{align-items:center;gap:10px;display:flex}.modal-title h3{letter-spacing:-.01em;margin:0;font-size:1.2rem;font-weight:650}.modal-title-icon img{border-radius:6px}.modal-close{border:1px solid var(--border);background:#c3ddfd38;border-radius:999px;justify-content:center;align-items:center;width:40px;height:40px;transition:transform .18s,box-shadow .18s,background .18s;display:inline-flex}.modal-close:hover{background:#c3ddfd52;transform:translateY(-1px);box-shadow:0 10px 22px #0c0c0c14}.modal-project-image{object-fit:contain;border:1px solid var(--border);background:#0c0c0c08;border-radius:12px;width:100%;height:auto;max-height:320px;margin:0 0 14px}.modal-gallery{margin-bottom:14px}.modal-gallery-main{position:relative}.modal-gallery-main .modal-project-image{margin-bottom:10px}.modal-gallery-count{color:#fff;background:#0c0c0c9e;border-radius:999px;padding:4px 8px;font-size:.75rem;line-height:1;position:absolute;top:10px;right:10px}.modal-thumbs{-webkit-overflow-scrolling:touch;gap:10px;padding-bottom:2px;display:flex;overflow-x:auto}.modal-thumb{border:1px solid var(--border);opacity:.72;cursor:pointer;background:#fff;border-radius:10px;flex:none;padding:0;transition:opacity .2s ease-out,border-color .2s ease-out;overflow:hidden}.modal-thumb img{object-fit:cover;width:100px;height:60px;display:block}.modal-thumb.active{border-color:var(--accent);opacity:1}@keyframes modal-overlay-fade{0%{opacity:0}to{opacity:1}}@keyframes modal-enter{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@media (max-width:640px){.modal-overlay{padding:12px}.modal{width:100%}.project-preview-image{height:128px}}.blog-hero{padding-top:88px}.blog-hero-inner{flex-direction:column;gap:10px;display:flex}.blog-title,.blog-detail-title{letter-spacing:-.02em;margin:0;font-size:clamp(2rem,3vw,2.6rem)}.blog-intro{max-width:640px}.blog-crumb{font-size:.9rem}.blog-featured-grid,.blog-related-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:20px;display:grid}@media (max-width:900px){.blog-featured-grid,.blog-related-grid{grid-template-columns:1fr}}.blog-list{gap:18px;display:grid}.blog-card{flex-direction:column;gap:12px;display:flex}.blog-link-title{color:inherit}.blog-meta,.blog-detail-meta{color:var(--muted);flex-wrap:wrap;gap:12px;font-size:.9rem;display:flex}.blog-card-actions{margin-top:6px}.tag-filter{flex-wrap:wrap;gap:8px;margin-bottom:16px;display:flex}.tag-button{cursor:pointer;background:0 0;border:0;padding:0}.tag-button .badge{transition:border-color .2s,background .2s}.tag-button.active .badge{border-color:var(--accent-strong);background:var(--accent)}.blog-detail{padding-top:96px}.blog-back{margin-bottom:12px}.blog-detail-tags{margin-bottom:18px}.mdx-content{flex-direction:column;gap:16px;display:flex}.mdx-h1{margin:18px 0 8px;font-size:2rem}.mdx-h2{margin:18px 0 6px;font-size:1.5rem}.mdx-h3{margin:16px 0 6px;font-size:1.2rem}.mdx-p{margin:0}.mdx-ul,.mdx-ol{margin:0;padding-left:20px}.mdx-li{margin:6px 0}.mdx-pre{border:1px solid var(--border);background:#f7f7f7;border-radius:12px;padding:14px;overflow-x:auto}.mdx-code{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:.95rem}.mdx-blockquote{border-left:3px solid var(--accent);color:var(--muted);margin:0;padding-left:16px}.blog-related{margin-top:48px}.footer{border-top:1px solid var(--border);padding:5px 0}
