@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@media (prefers-reduced-motion:reduce){*,:after,:before{animation-duration:.01ms!important;transition-duration:.01ms!important}}html{scroll-behavior:smooth}.skip-link{position:absolute;top:-100%;left:1rem;background:#111;color:#fff;padding:.5rem 1rem;font-size:.85rem;font-weight:500;z-index:9999;text-decoration:none;border-radius:0 0 4px 4px;transition:top .1s}.skip-link:focus{top:0}body{font-family:var(--font-montserrat),"Montserrat","Segoe UI",Arial,sans-serif;background:#fff;color:#111;margin:0;padding:0;-webkit-font-smoothing:antialiased}.page-container{animation:fadeIn .4s ease-in-out;padding-bottom:4rem}.nav-menu{justify-content:flex-end;position:fixed;top:0;left:0;width:100%;background:#fff;z-index:200;padding:1.1rem 0;border-bottom:1px solid #e8e8e8;transition:transform .28s ease-in-out}.nav-home-link,.nav-menu{display:flex;align-items:center}.nav-home-link{margin-left:2.5rem;margin-right:auto}.nav-menu ul{display:flex;gap:2rem;list-style:none;margin:0;padding:0 2.5rem 0 0;transition:right .3s}.nav-menu a,.nav-menu li{display:inline-block}.nav-menu a{color:#111;font-weight:500;text-decoration:none;font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;padding:.3rem 0;transition:opacity .2s}.nav-menu a:hover{opacity:.5}.nav-menu ul a.active{border-bottom:1.5px solid #111}.nav-toggle{display:none;flex-direction:column;justify-content:center;align-items:center;background:none;border:none;cursor:pointer;margin-right:1.5rem;height:40px;width:40px;gap:5px}.hamburger{width:22px;height:1.5px;background:#111;border-radius:0;transition:all .25s ease}.nav-toggle--open .hamburger:first-child{transform:translateY(6.5px) rotate(45deg)}.nav-toggle--open .hamburger:nth-child(2){opacity:0;transform:scaleX(0)}.nav-toggle--open .hamburger:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}.banner{width:100%;min-height:60vh;background:#fff;color:#111;display:flex;align-items:center;justify-content:center;text-align:center;padding-top:6rem;padding-bottom:4rem;box-sizing:border-box;border-bottom:1px solid #e8e8e8}.banner .major h1{font-size:3.5rem;line-height:1.08;font-weight:800;color:#111;margin:0 0 1rem;letter-spacing:-.02em}.banner .major h1 span{font-size:1.8rem;margin-left:.4rem}.banner .content p{color:#6b6b6b;font-weight:400;font-size:.85rem;letter-spacing:.08em;text-transform:uppercase;margin-top:0}.project-section{padding:4rem 1.5rem;margin:0 auto;max-width:720px}.project-list{display:flex;flex-direction:column;gap:1rem;max-width:720px;margin:0 auto;width:100%}.project-card{border:none;border-radius:16px;margin:0;padding:2rem 2rem 1.75rem;width:100%;box-sizing:border-box;transition:transform .22s ease,box-shadow .22s ease;opacity:1;text-decoration:none;display:block}.project-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,.06)}.project-card-inner{display:flex;align-items:center;gap:1.1rem}.project-icon-wrap{flex-shrink:0;width:56px;height:56px;border-radius:14px;display:flex;align-items:center;justify-content:center;overflow:hidden}.project-text{flex:1}.project-arrow{font-size:1.2rem;color:#111;opacity:0;transform:translateX(-6px);transition:opacity .2s ease,transform .2s ease;flex-shrink:0;line-height:1}.project-card:hover .project-arrow{opacity:1;transform:translateX(0)}.project-img{display:none}.project-title{font-size:.85rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;margin:0 0 .3rem;color:#111}.project-desc{color:#4a4a4a;font-size:.85rem;font-weight:400;margin:0;line-height:1.6}.footer{position:fixed;bottom:0;left:0;right:0;text-align:center;padding:1rem;border-top:1px solid #e8e8e8;background:#fff;z-index:100}.footer-links{display:flex;justify-content:center;gap:2.5rem}.footer-links a{display:flex;align-items:center;gap:.4rem;color:#111;text-decoration:none;font-weight:500;font-size:.75rem;letter-spacing:.08em;text-transform:uppercase;transition:opacity .2s}.footer-links a:hover{opacity:.5}.footer-copy{margin-top:1.25rem;font-size:.7rem;color:#999;letter-spacing:.06em}.header{display:flex;flex-direction:column;align-items:center;gap:1rem;margin-bottom:3rem;padding-top:2rem}.header h1{font-size:2.2rem;font-weight:700;margin:.5rem 0 .2rem;color:#111}.header p{font-size:1rem;color:#767676;text-align:center;max-width:500px}.personal-project-card:hover{opacity:.75}.case-study-wrap{display:flex;max-width:1100px;margin:2rem auto 0;padding:0 1.5rem}.case-study-sidebar{width:220px;flex-shrink:0;padding:2rem 1.5rem 2rem 0;border-right:1px solid #e8e8e8;position:sticky;top:70px;height:fit-content}.case-study-back{display:block;font-size:.78rem;color:#6b6b6b;text-decoration:none;font-weight:500;letter-spacing:.04em;margin-bottom:1.5rem;text-transform:uppercase;transition:color .2s}.case-study-back:hover{color:#111}.case-study-toc-heading{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:#6b6b6b;margin:0 0 1rem}.case-study-toc-list{list-style:none;padding:0;margin:0}.case-study-toc-list li{margin-bottom:.5rem}.case-study-toc-list a{display:block;font-size:.85rem;color:#6b6b6b;text-decoration:none;padding:.35rem 0;transition:color .2s}.case-study-toc-list a:hover{color:#111}.case-study-main{flex:1;padding:0 0 4rem 3rem;max-width:760px}.case-study-meta{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;margin-top:4rem;margin-bottom:2.5rem;padding-bottom:2rem;border-bottom:1px solid #e8e8e8}.case-study-meta-item p:first-child{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#767676;margin:0 0 .3rem}.case-study-meta-item p:last-child{font-size:.9rem;color:#111;font-weight:500;margin:0}.case-study-title{font-size:2.2rem;font-weight:800;color:#111;margin:2rem 0 .75rem;letter-spacing:-.02em;line-height:1.15}.case-study-subtitle{font-size:1rem;color:#6b6b6b;margin:0 0 3rem;line-height:1.65;font-weight:400}.case-study-section-title{font-size:1.1rem;font-weight:700;color:#111;margin:3rem 0 1rem;letter-spacing:.01em}.case-study-body{margin-bottom:1.25rem}.case-study-body,.case-study-list{font-size:.95rem;line-height:1.85;color:#4a4a4a}.case-study-list{margin:0 0 1.25rem 1.25rem;list-style:disc}@media (max-width:700px){.case-study-wrap{flex-direction:column}.case-study-sidebar{width:100%;border-right:none;border-bottom:1px solid #e8e8e8;position:static;padding:1.5rem 0}.case-study-main{padding:0 0 3rem}.case-study-meta{grid-template-columns:repeat(2,1fr)}}.about-wrap{max-width:960px;margin:7rem auto 4rem;padding:0 2rem;display:flex;gap:3.5rem;align-items:flex-start}.about-avatar{flex-shrink:0;width:220px;height:220px;border-radius:50%;overflow:hidden;background:#f0f0f0}.about-content{flex:1}.about-name{font-size:2rem;font-weight:800;color:#111;margin:0 0 1rem;letter-spacing:-.02em}.about-body{font-size:.95rem;color:#4a4a4a;line-height:1.8;margin-bottom:1rem}.about-section-title{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:#6b6b6b;margin:2rem 0 .6rem}@media (max-width:700px){.about-wrap{flex-direction:column;margin-top:5rem}.about-avatar{width:140px;height:140px}}.photo-item{position:relative;overflow:hidden;border-radius:0;transition:opacity .25s ease;background:#f5f5f5}.photo-item .photo-img{display:block;width:100%;height:auto}.photo-item:hover{opacity:.85}.photo-overlay{position:absolute;left:0;right:0;bottom:0;padding:1rem;background:linear-gradient(180deg,rgba(0,0,0,0),rgba(0,0,0,.4));color:#fff;opacity:0;transform:translateY(6px);transition:opacity .22s ease,transform .22s ease;display:flex;align-items:flex-end;height:40%}.photo-item:focus-within .photo-overlay,.photo-item:hover .photo-overlay{opacity:1;transform:translateY(0)}.photo-caption{margin:0;font-size:.85rem;letter-spacing:.04em;line-height:1.3}.lightbox-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.92);z-index:1000;display:flex;align-items:center;justify-content:center}.lightbox-content{display:flex;flex-direction:column;align-items:center;gap:1rem}.lightbox-caption{color:#ccc;font-size:.8rem;letter-spacing:.08em;text-transform:uppercase;margin:0;font-weight:500}.lightbox-counter{color:#666;font-size:.75rem;letter-spacing:.06em;margin:0}.lightbox-close{position:absolute;top:1.25rem;right:1.5rem;background:none;border:none;color:#fff;font-size:1.3rem;cursor:pointer;line-height:1;padding:.25rem .5rem;opacity:.5;transition:opacity .2s}.lightbox-close:hover{opacity:1}.lightbox-arrow{position:absolute;top:50%;transform:translateY(-50%);background:none;border:none;color:#fff;font-size:2.5rem;line-height:1;cursor:pointer;padding:.5rem 1rem;opacity:.5;transition:opacity .2s;user-select:none}.lightbox-arrow:hover{opacity:1}.lightbox-arrow-left{left:1.5rem}.lightbox-arrow-right{right:1.5rem}@media (max-width:700px){.banner .major h1{font-size:2.4rem}.nav-menu ul{position:fixed;top:0;right:-100vw;height:100vh;width:70vw;max-width:320px;background:#fff;flex-direction:column;align-items:flex-start;gap:0;padding:5rem 2rem 2rem;border-left:1px solid #e8e8e8;transition:right .3s;z-index:200}.nav-menu ul:not(.open){visibility:hidden}.nav-menu ul.open{right:0;visibility:visible}.nav-menu li{width:100%;margin-bottom:1.5rem}.nav-menu a{font-size:.9rem;padding:.5rem 0}.nav-toggle{display:flex}.lightbox-arrow{font-size:1.8rem;padding:.4rem .6rem}.lightbox-arrow-left{left:.25rem}.lightbox-arrow-right{right:.25rem}}@media (max-width:600px){.project-list{max-width:100%;padding:0}.project-card{padding:1.5rem 1rem}}.blog-page-wrap{flex:1;max-width:760px;margin:9rem auto 5rem;padding:0 2rem;width:100%}.blog-page-header{margin-bottom:4rem;padding-bottom:3rem;border-bottom:1px solid #e8e8e8}.blog-page-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:#6b6b6b;margin:0 0 1.25rem}.blog-page-title{font-size:2.2rem;font-weight:800;color:#111;letter-spacing:-.03em;line-height:1.15;margin:0}.blog-empty{color:#767676;font-size:.95rem}.blog-list{display:flex;flex-direction:column}.blog-card{display:grid;grid-template-columns:2.5rem 1fr auto;align-items:start;gap:1.25rem;padding:2rem 0;border-bottom:1px solid #e8e8e8;text-decoration:none;color:inherit;transition:background .15s ease}.blog-card:first-child{border-top:1px solid #e8e8e8}.blog-card:hover .blog-card-title{opacity:.55}.blog-card:hover .blog-card-arrow{opacity:1;transform:translateX(0)}.blog-card-index{font-size:.72rem;font-weight:700;color:#ccc;letter-spacing:.05em;padding-top:.2rem}.blog-card-body{flex:1}.blog-card-title{font-size:1.1rem;font-weight:700;color:#111;margin:0 0 .4rem;letter-spacing:-.01em;line-height:1.35;transition:opacity .2s ease}.blog-card-excerpt{font-size:.875rem;color:#6b6b6b;margin:0;line-height:1.65}.blog-card-meta{display:flex;flex-direction:column;align-items:flex-end;gap:.5rem;padding-top:.15rem;min-width:4.5rem}.blog-card-date{font-size:.75rem;color:#6b6b6b;white-space:nowrap;letter-spacing:.04em;text-transform:uppercase}.blog-card-arrow{font-size:.95rem;color:#111;opacity:0;transform:translateX(-5px);transition:opacity .2s ease,transform .2s ease}@media (max-width:600px){.blog-page-title{font-size:1.7rem}.blog-card{grid-template-columns:2rem 1fr;gap:.75rem}.blog-card-excerpt,.blog-card-meta{display:none}}.blog-body{font-size:1rem;line-height:1.8;color:#2a2a2a}.notion-columns{display:flex;gap:1rem;margin:1.25rem 0}.notion-column{flex:1;min-width:0}.notion-column img{border-radius:4px}@media (max-width:600px){.notion-columns{flex-direction:column}}.blog-img{width:100%;height:auto;display:block;cursor:zoom-in;border-radius:4px}.blog-body h2{font-size:1.3rem;font-weight:700;color:#111;margin:2.5rem 0 .75rem;letter-spacing:-.01em}.blog-body h3{font-size:1.1rem;font-weight:600;color:#111;margin:2rem 0 .5rem}.blog-body p{margin:0 0 1.25rem}.blog-body a{color:#111;text-decoration:underline;text-underline-offset:3px}.blog-body ol,.blog-body ul{padding-left:1.5rem;margin:0 0 1.25rem}.blog-body li{margin-bottom:.4rem}.blog-body blockquote{border-left:3px solid #e5e5e5;margin:1.5rem 0;padding:.5rem 0 .5rem 1.25rem;color:#4a4a4a;font-style:italic}