*,*:before,*:after{box-sizing:border-box}html,body{margin:0;padding:0}html{scroll-behavior:smooth}button{font:inherit;cursor:pointer}:root{--paper: #fafaf7;--paper-2: #ffffff;--ink: #161614;--ink-2: #4a4945;--mute: #898680;--rule: #e2dfd8;--card: #ffffff;--accent: oklch(58% .22 24);--accent-ink: #ffffff;--accent-soft: oklch(58% .22 24 / .16);--highlight: oklch(58% .22 24 / .22);--display: "Bricolage Grotesque", "PP Neue Machina", system-ui, sans-serif;--sans: "DM Sans", ui-sans-serif, system-ui, sans-serif;--mono: "JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;--hand: "Caveat", "Bradley Hand", cursive;--step--2: 11px;--step--1: 13px;--step-0: 15px;--step-1: 17px;--step-2: clamp(1.4rem, 1.2rem + .8vw, 1.9rem);--step-3: clamp(2rem, 1.6rem + 2vw, 3.2rem);--step-4: clamp(2.6rem, 2rem + 3vw, 4.2rem);--step-5: clamp(3.4rem, 2.2rem + 6vw, 6.6rem)}.theme-dark{--paper: #0e0e0c;--paper-2: #181815;--ink: #f4f1ea;--ink-2: #b3afa3;--mute: #6e6a5f;--rule: #26241e;--card: #181815;--accent: oklch(64% .22 24);--accent-ink: #0e0e0c;--highlight: oklch(64% .22 24 / .28)}body{font-family:var(--sans);color:var(--ink);background:var(--paper);font-size:var(--step-0);line-height:1.5;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}a{color:inherit;text-decoration:none}img{display:block;max-width:100%}.wrap{max-width:1080px;margin:0 auto;padding:0 40px}@media (max-width: 720px){.wrap{padding:0 22px}}.red{color:var(--accent)}.mono{font-family:var(--mono)}.hand{font-family:var(--hand)}.mark{background:linear-gradient(180deg,transparent 22%,var(--highlight) 22%,var(--highlight) 92%,transparent 92%);padding:0 .08em;font-style:normal;color:inherit;border-radius:2px;box-decoration-break:clone;-webkit-box-decoration-break:clone}.mark-solid{background:var(--accent);color:var(--accent-ink);padding:.02em .18em;font-style:normal;border-radius:3px;box-decoration-break:clone;-webkit-box-decoration-break:clone}.sticker{display:inline-flex;align-items:center;gap:6px;font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;padding:5px 10px;background:var(--accent);color:var(--accent-ink);border-radius:999px;transform:rotate(-2deg);font-weight:500;white-space:nowrap}.sticker.outline{background:transparent;color:var(--ink);border:1.5px solid var(--ink-2);transform:rotate(1deg)}.sticker .dot-w{width:6px;height:6px;border-radius:999px;background:currentColor;animation:pulse 1.8s infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.85)}}.nav{position:sticky;top:0;z-index:100;background:color-mix(in oklch,var(--paper) 90%,transparent);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-bottom:1px solid transparent;transition:border-color .25s}.nav.scrolled{border-bottom-color:var(--rule)}.nav-inner{display:flex;align-items:center;justify-content:space-between;padding:16px 40px;max-width:1080px;margin:0 auto;font-family:var(--mono);font-size:13px}.logo{display:inline-flex;align-items:center;gap:10px;font-family:var(--display);font-weight:700;font-size:20px;letter-spacing:-.02em;font-variation-settings:"wdth" 90}.logo svg{display:block}.logo .dot{color:var(--accent)}.nav-links{display:flex;gap:22px;color:var(--ink-2)}.nav-links a{transition:color .15s}.nav-links a:hover{color:var(--accent)}@media (max-width: 760px){.nav-links{display:none}.nav-inner{padding:14px 22px}}.hero{padding:72px 0 100px;position:relative;overflow:hidden}.hero-tag-row{display:flex;align-items:center;gap:12px;margin-bottom:28px;flex-wrap:wrap}.hero-title{font-family:var(--display);font-size:var(--step-5);font-weight:600;line-height:.96;letter-spacing:-.035em;margin:0;color:var(--ink);font-variation-settings:"wdth" 95}.hero-title .line{display:block;animation:fadeRise 1s cubic-bezier(.2,.8,.2,1) both}.hero-title .line:nth-child(2){animation-delay:.08s}.hero-title .line:nth-child(3){animation-delay:.16s}.hero-title .line:nth-child(4){animation-delay:.24s}.hero-title .light{font-weight:300;font-style:italic;font-variation-settings:"wdth" 100;color:var(--ink-2)}@keyframes fadeRise{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.hero-tag{margin-top:48px;display:flex;align-items:center;gap:24px;flex-wrap:wrap;animation:fadeIn 1s .4s ease both}.hero-face{width:72px;height:72px;position:relative;flex-shrink:0;background:var(--card);border-radius:50%;padding:4px;box-shadow:0 6px 20px -8px #00000080}.face-core{width:100%;height:100%;position:relative;animation:faceBob 5s 1s ease-in-out infinite}.face-core>img.face-base{width:100%;height:100%;display:block}img.face-smile{position:absolute;top:60%;left:50%;width:56%;height:auto;transform:translate(-50%);clip-path:inset(0 100% 0 0);animation:drawSmile 5s 1s ease-in-out infinite;margin-top:5px;margin-bottom:5px}@keyframes drawSmile{0%{clip-path:inset(0 100% 0 0)}20%{clip-path:inset(0 0 0 0)}78%{clip-path:inset(0 0 0 0)}92%{clip-path:inset(0 100% 0 0)}to{clip-path:inset(0 100% 0 0)}}@keyframes faceBob{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-2px) rotate(-3deg)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.hero-line{font-family:var(--sans);font-size:var(--step-1);color:var(--ink-2);max-width:38ch;line-height:1.45;margin:0}.hero-line strong{color:var(--ink);font-weight:600}.hero:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(circle,var(--rule) 1px,transparent 1px);background-size:26px 26px;opacity:.65;pointer-events:none;z-index:-1}@media (max-width: 760px){.hero{padding:48px 0 60px}}.section{padding:88px 0;position:relative}.section-head{display:flex;align-items:center;gap:16px;margin-bottom:40px}.section-num{font-family:var(--mono);font-size:11px;color:var(--accent);letter-spacing:.08em;text-transform:uppercase;padding:5px 10px;border:1.5px solid var(--accent);border-radius:999px;flex-shrink:0}@media (max-width: 720px){.section{padding:64px 0}}.about{display:grid;grid-template-columns:1fr 320px;gap:56px;align-items:start}.about-body{font-family:var(--display);font-size:var(--step-3);line-height:1.18;letter-spacing:-.022em;color:var(--ink);margin:0;font-weight:500;font-variation-settings:"wdth" 95;max-width:22ch}.about-card{background:var(--card);border:1px solid var(--rule);border-radius:14px;padding:22px 24px;transform:rotate(-.6deg);box-shadow:0 16px 40px -20px #0006;position:relative}.about-card:before{content:"";position:absolute;top:-10px;left:30px;width:64px;height:18px;background:var(--highlight);border-radius:1px;transform:rotate(-3deg)}.about-card dl{margin:0;display:flex;flex-direction:column;gap:0}.about-card .row{display:grid;grid-template-columns:70px 1fr;gap:16px;padding:10px 0;border-bottom:1px dashed var(--rule);font-size:14px}.about-card .row:last-child{border-bottom:none}.about-card .row dt{color:var(--mute);font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;padding-top:2px}.about-card .row dd{margin:0;color:var(--ink);font-weight:500}@media (max-width: 760px){.about{grid-template-columns:1fr;gap:36px}.about-card{transform:none;max-width:360px}}.projects{display:grid;grid-template-columns:1fr;gap:0;border-top:1.5px solid var(--ink-2)}.project{display:grid;grid-template-columns:56px 1fr auto auto;gap:24px;padding:22px 0;border-bottom:1px solid var(--rule);align-items:baseline;transition:padding .35s cubic-bezier(.2,.8,.2,1),background .25s}.project:hover{padding-left:16px;padding-right:16px;background:var(--card)}.project:hover .project-arrow{transform:translate(8px);color:var(--accent)}.project:hover .project-name{color:var(--accent)}.project-index{font-family:var(--mono);font-size:12px;color:var(--mute);letter-spacing:.04em}.project-name{font-family:var(--display);font-size:clamp(1.7rem,1.4rem + 1vw,2.4rem);font-weight:600;letter-spacing:-.025em;line-height:1;margin:0;transition:color .25s;font-variation-settings:"wdth" 95}.project-name .light{font-weight:300;color:var(--mute)}.project-meta{font-family:var(--mono);font-size:11px;color:var(--mute);letter-spacing:.06em;text-transform:uppercase}.project-arrow{font-family:var(--display);font-size:24px;font-weight:500;color:var(--ink-2);transition:transform .35s ease,color .25s;display:inline-block}@media (max-width: 760px){.project{grid-template-columns:40px 1fr auto;gap:14px;padding:18px 0}.project-meta{grid-column:2}.project-arrow{display:none}.project:hover{padding-left:0;padding-right:0}}.writing{display:grid;grid-template-columns:1fr 1fr;gap:0 32px;border-top:1.5px solid var(--ink-2)}.article{padding:20px 0;border-bottom:1px solid var(--rule);display:flex;flex-direction:column;gap:4px;transition:padding-left .25s}.article:hover{padding-left:10px}.article:hover .article-title{color:var(--accent)}.article-meta{font-family:var(--mono);font-size:11px;color:var(--mute);letter-spacing:.06em;text-transform:uppercase}.article-title{font-family:var(--display);font-size:var(--step-2);font-weight:500;line-height:1.15;letter-spacing:-.018em;margin:0;transition:color .2s;max-width:24ch;font-variation-settings:"wdth" 96}@media (max-width: 720px){.writing{grid-template-columns:1fr}}.contact{padding:96px 0 80px;position:relative}.contact-inner{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:end}.contact-title{font-family:var(--display);font-size:clamp(2.6rem,2rem + 5vw,6rem);font-weight:600;letter-spacing:-.035em;line-height:.95;margin:0;font-variation-settings:"wdth" 92}.contact-title .light{font-weight:300;color:var(--ink-2);font-style:italic;font-variation-settings:"wdth" 100}.contact-email{display:inline-block;font-family:var(--display);font-size:var(--step-2);font-weight:500;color:var(--ink);padding-bottom:4px;border-bottom:2px solid var(--accent);transition:color .2s}.contact-email:hover{color:var(--accent)}.contact-side{display:flex;flex-direction:column;gap:12px;font-family:var(--mono);font-size:13px}.contact-side a{display:flex;justify-content:space-between;padding:14px 16px;background:var(--card);border:1px solid var(--rule);border-radius:10px;transition:border-color .2s,transform .2s,color .2s}.contact-side a:hover{border-color:var(--accent);color:var(--accent);transform:translate(4px)}.contact-side a .arr{color:var(--mute);transition:color .2s,transform .2s}.contact-side a:hover .arr{color:var(--accent);transform:translate(4px)}.contact-sig{margin-top:40px;display:flex;justify-content:space-between;align-items:end}.contact-sig .sig{font-family:var(--hand);font-size:44px;color:var(--accent);line-height:1;transform:rotate(-3deg)}.contact-sig .from{font-family:var(--mono);font-size:11px;color:var(--mute);letter-spacing:.06em;text-transform:uppercase;text-align:right}@media (max-width: 760px){.contact-inner{grid-template-columns:1fr;gap:36px}.contact{padding:64px 0 60px}}.footer{border-top:1px solid var(--rule);padding:28px 0;font-family:var(--mono);font-size:11px;color:var(--mute);letter-spacing:.06em}.footer-inner{display:flex;justify-content:space-between;gap:24px;flex-wrap:wrap}.reveal{opacity:0;transform:translateY(20px);transition:opacity .8s cubic-bezier(.2,.8,.2,1),transform .8s cubic-bezier(.2,.8,.2,1)}.reveal.in{opacity:1;transform:translateY(0)}.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.theme-switch{position:fixed;bottom:24px;right:24px;width:44px;height:44px;background:var(--card);border:1px solid var(--rule);border-radius:50%;cursor:pointer;z-index:1000;display:flex;align-items:center;justify-content:center;color:var(--ink);transition:transform .2s,border-color .2s,box-shadow .2s;box-shadow:0 4px 12px #00000026}.theme-switch:hover{transform:scale(1.08);border-color:var(--accent);box-shadow:0 6px 20px #0003;color:var(--accent)}.theme-switch:active{transform:scale(.95)}.theme-switch svg{transition:transform .3s}.theme-switch:hover svg{transform:rotate(15deg)}@media (max-width: 540px){.theme-switch{bottom:16px;right:16px;width:40px;height:40px}}
