*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--text: #111;--text-secondary: #555;--bg: #fff;--border: #eee;--accent: #333;--max-width-text: 680px;--max-width-wide: 1100px}html{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;color:var(--text);background:var(--bg);line-height:1.6;-webkit-font-smoothing:antialiased}body{min-height:100vh;display:flex;flex-direction:column}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}img{max-width:100%;height:auto}.container{width:100%;max-width:var(--max-width-text);margin:0 auto;padding:0 1.5rem}.container--wide{max-width:var(--max-width-wide)}.nav{padding:2rem 0;border-bottom:1px solid var(--border)}.nav__inner{display:flex;justify-content:space-between;align-items:center;max-width:var(--max-width-wide);margin:0 auto;padding:0 1.5rem}.nav__name{font-size:1.1rem;font-weight:600;color:var(--text);text-decoration:none}.nav__name:hover{text-decoration:none}.nav__links{display:flex;gap:2rem;list-style:none}.nav__link{font-size:.95rem;color:var(--text-secondary);text-decoration:none;letter-spacing:.01em}.nav__link:hover,.nav__link--active{color:var(--text)}.footer{margin-top:auto;padding:2rem 0;border-top:1px solid var(--border);text-align:center;font-size:.85rem;color:var(--text-secondary)}main{padding:3rem 0;flex:1}h1{font-size:2rem;font-weight:700;line-height:1.2;margin-bottom:.5rem}h2{font-size:1.4rem;font-weight:600;line-height:1.3;margin-top:2rem;margin-bottom:.75rem}h3{font-size:1.15rem;font-weight:600;margin-top:1.5rem;margin-bottom:.5rem}p{margin-bottom:1rem}ul,ol{margin-bottom:1rem;padding-left:1.5rem}li{margin-bottom:.35rem}.recipe-timeline{margin:1.5rem 0 2rem}.recipe-step{display:flex;gap:1.25rem;position:relative;padding-bottom:1.75rem}.recipe-step:last-child{padding-bottom:0}.recipe-step:not(:last-child):before{content:"";position:absolute;left:18px;top:40px;bottom:0;width:2px;background:var(--border)}.recipe-step__number{flex-shrink:0;width:38px;height:38px;border-radius:50%;background:var(--text);color:var(--bg);font-size:.85rem;font-weight:600;display:flex;align-items:center;justify-content:center;position:relative;z-index:1}.recipe-step__content{flex:1;min-width:0}.recipe-step__title{font-weight:600;font-size:1.05rem;line-height:1.4;min-height:38px;display:flex;align-items:center;flex-wrap:wrap;gap:.3rem;margin-bottom:.4rem}.recipe-step__time{font-weight:400;font-size:.85rem;color:var(--text-secondary)}.recipe-step__content p{font-size:1rem;line-height:1.6;color:var(--text);margin-bottom:0}.prose h2{margin-top:2.5rem}.prose blockquote{border-left:3px solid var(--border);padding-left:1rem;color:var(--text-secondary);margin:1.5rem 0}.prose a{color:#2563eb;text-decoration:underline}.prose em{font-style:italic}.prose strong{font-weight:600}.about__subtitle{font-size:1.15rem;color:var(--text-secondary);margin-bottom:2rem}.about__section{margin-bottom:2.5rem}.about__section h2{margin-top:0}.timeline-item{margin-bottom:1rem}.timeline-item__title{font-weight:600}.timeline-item__period{font-size:.9rem;color:var(--text-secondary)}.timeline-item__detail{font-size:.95rem;color:var(--text-secondary);margin-top:.15rem}.blog-list{list-style:none;padding:0}.blog-item{padding:1.5rem 0;border-bottom:1px solid var(--border)}.blog-item:first-child{padding-top:0}.blog-item__date{font-size:.85rem;color:var(--text-secondary);margin-bottom:.25rem}.blog-item__title{font-size:1.2rem;font-weight:600}.blog-item__title a{color:var(--text)}.blog-item__description{font-size:.95rem;color:var(--text-secondary);margin-top:.35rem}.post__date{font-size:.9rem;color:var(--text-secondary);margin-bottom:2rem}.project{margin-bottom:4rem}.project__header{margin-bottom:1.5rem}.project__title{font-size:1.6rem;margin-bottom:.35rem;margin-top:0}.project__desc{color:var(--text-secondary);font-size:1rem;margin-bottom:1rem}.project__links{display:flex;gap:1rem;flex-wrap:wrap}.project__link{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem 1rem;border:1px solid var(--border);border-radius:8px;font-size:.9rem;color:var(--text);transition:border-color .2s}.project__link:hover{border-color:var(--accent);text-decoration:none}.project__link--disabled{opacity:.5;pointer-events:none}.phone-frame{position:relative;width:280px;flex-shrink:0;background:#000;border-radius:40px;padding:12px;box-shadow:none}.phone-frame__screen{border-radius:30px;overflow:hidden;background:#000;aspect-ratio:9 / 19.5}.phone-frame__screen img,.phone-frame__screen video{width:100%;height:100%;object-fit:cover;display:block}.carousel-wrapper{margin:0}.carousel{display:flex;gap:1.25rem;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;padding-bottom:1rem;scrollbar-width:none}.carousel::-webkit-scrollbar{display:none}.carousel .phone-frame{scroll-snap-align:start}.project__media{display:flex;gap:2rem;align-items:flex-start;flex-wrap:wrap}.project__video-section{flex-shrink:0}.project__video-section h3{margin-top:0;margin-bottom:.75rem;font-size:.9rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.project__screenshots-section{flex:1;min-width:0;max-width:100%;overflow:hidden}.project__screenshots-section h3{margin-top:0;margin-bottom:.75rem;font-size:.9rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.contact-links{display:flex;gap:1.5rem;list-style:none;padding:0;margin-top:.5rem}.contact-links a{color:var(--text-secondary);font-size:.95rem}.contact-links a:hover{color:var(--text)}@media(max-width:768px){h1{font-size:1.6rem}.nav__inner{flex-direction:column;gap:.75rem}.nav__links{gap:1.5rem}.phone-frame{width:220px}.project__media{flex-direction:column}}
