:root{--bg:#faf6f2;--bg-warm:#f5ebe3;--surface:#fff;--text:#3f3c39;--text-strong:#1c1917;--muted:#6b6560;--border:#1c19171a;--accent:#c54b3c;--accent-2:#2f4f6f;--shadow:0 24px 60px #1c191714;--shadow-soft:0 12px 40px #1c19170f;--sans:ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, Arial, "Noto Sans", "Helvetica Neue", sans-serif;--mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;font-family:var(--sans);letter-spacing:.2px;background:var(--bg);color:var(--text);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px;line-height:1.55}html{scroll-behavior:smooth}body{cursor:url(/pen-cursor.svg) 6 28,crosshair;min-height:100svh;margin:0}a,button,[role=button],input,textarea,select,.carouselBtn,.carouselDot{cursor:url(/pen-cursor.svg) 6 28,crosshair}*,:before,:after{box-sizing:border-box}a{color:inherit}img{max-width:100%;display:block}#root{min-height:100svh}.page{isolation:isolate;min-height:100svh;position:relative}.cursorTrail{z-index:40;pointer-events:none;mix-blend-mode:multiply;position:fixed;inset:0}.page:before{content:"";z-index:-2;background:radial-gradient(ellipse 80% 50% at 15% 0%, #f5ebe3e6, transparent 55%), radial-gradient(ellipse 70% 45% at 85% 10%, #e8f0f88c, transparent 50%), linear-gradient(180deg, var(--bg) 0%, var(--bg-warm) 100%);pointer-events:none;position:fixed;inset:0}.page:after{content:"";z-index:-1;pointer-events:none;background-image:linear-gradient(#1c19170a 1px,#0000 1px),linear-gradient(90deg,#1c191709 1px,#0000 1px);background-size:100% 48px,48px 100%;position:fixed;inset:0;-webkit-mask-image:linear-gradient(#0000001f,#0000 65%);mask-image:linear-gradient(#0000001f,#0000 65%)}.container{width:min(1400px,100% - 48px);margin:0 auto}.topbar{z-index:50;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-bottom:1px solid var(--border);background:#faf6f2e0;justify-content:space-between;align-items:center;padding:14px 20px;display:flex;position:sticky;top:0}.brand{color:var(--text-strong);letter-spacing:.3px;text-transform:uppercase;align-items:center;gap:10px;font-size:13px;font-weight:700;text-decoration:none;display:inline-flex}.brandDot{background:linear-gradient(135deg, var(--accent), #e07a5f);border-radius:999px;width:10px;height:10px;box-shadow:0 0 0 4px #c54b3c26}.nav{gap:16px;display:flex}.nav a{color:var(--muted);letter-spacing:.28px;text-transform:uppercase;border-radius:10px;padding:8px 10px;font-size:13px;font-weight:600;text-decoration:none;transition:background .16s,color .16s}.nav a:hover{color:var(--text-strong);background:#1c19170d}.section{padding:92px 0}.heroSection{padding-top:82px}.heroGrid{flex-direction:column;gap:22px;width:min(1400px,100% - 48px);margin:0 auto;display:flex}.homeSplit{grid-template-columns:1.18fr .82fr;align-items:stretch;gap:28px;display:grid}.heroCopy{padding:18px 6px 18px 0;position:relative;overflow:visible}.eyebrow{color:var(--muted);letter-spacing:.5px;margin:0 0 10px;font-weight:600}.heroGif{object-fit:contain;pointer-events:none;width:360px;height:360px;animation:2.8s ease-in-out infinite ctaBuddyBob;position:absolute;top:20%;right:24px;transform:translateY(-50%)}.heroInsightMotionRoot{width:96px;position:relative}.heroInsightCanvas{border:1px solid var(--border);box-shadow:var(--shadow-soft);background:var(--surface);aspect-ratio:140/118;border-radius:18px;overflow:hidden}.heroInsightScene{width:100%;height:100%;display:block}.hi-mascot{transform-origin:70px 88px;transform-box:fill-box;animation:1.9s ease-in-out infinite hi-mascot-bounce}.hi-arm-wave{transform-origin:88px 76px;transform-box:fill-box;animation:.95s ease-in-out infinite hi-wave-arm}.hi-eye-l{transform-origin:60px 52px;transform-box:fill-box;animation:4.8s infinite hi-blink}.hi-eye-r{transform-origin:80px 52px;transform-box:fill-box;animation:4.8s 40ms infinite hi-blink}.hi-smile{transform-origin:70px 62px;transform-box:fill-box;animation:2.6s ease-in-out infinite hi-smile-wiggle}.hi-blush-l{animation:2.2s ease-in-out infinite hi-blush-pop}.hi-blush-r{animation:2.2s ease-in-out .35s infinite hi-blush-pop}.hi-star-a{transform-origin:24px 32px;transform-box:fill-box;animation:2.4s ease-in-out infinite hi-star-twinkle}.hi-star-b{transform-origin:120px 26px;transform-box:fill-box;animation:2.8s ease-in-out .5s infinite hi-star-twinkle}.hi-dot-pulse{animation:1.8s ease-in-out infinite hi-dot-pulse}.hi-shadow{animation:1.9s ease-in-out infinite hi-shadow-breathe}@media (prefers-reduced-motion:reduce){.ctaRowBuddy,.hi-mascot,.hi-arm-wave,.hi-eye-l,.hi-eye-r,.hi-smile,.hi-blush-l,.hi-blush-r,.hi-star-a,.hi-star-b,.hi-dot-pulse,.hi-shadow{animation:none}}@keyframes ctaBuddyBob{0%,to{transform:translateY(0)}50%{transform:translateY(-3px)}}@keyframes hi-mascot-bounce{0%,to{transform:translateY(0)rotate(-1deg)}50%{transform:translateY(-4px)rotate(1.5deg)}}@keyframes hi-wave-arm{0%,to{transform:rotate(-6deg)}50%{transform:rotate(22deg)}}@keyframes hi-blink{0%,92%,to{transform:scaleY(1)}94%{transform:scaleY(.12)}96%{transform:scaleY(1)}}@keyframes hi-smile-wiggle{0%,to{transform:scaleX(1)}50%{transform:scaleX(1.06)}}@keyframes hi-blush-pop{0%,to{opacity:.28}50%{opacity:.5}}@keyframes hi-star-twinkle{0%,to{opacity:.85;transform:scale(1)rotate(0)}50%{opacity:1;transform:scale(1.15)rotate(12deg)}}@keyframes hi-dot-pulse{0%,to{opacity:.4;transform:scale(1)}50%{opacity:.75;transform:scale(1.35)}}@keyframes hi-shadow-breathe{0%,to{opacity:.55;transform:scaleX(1)}50%{opacity:.85;transform:scaleX(1.08)}}.headline{letter-spacing:-1.5px;color:var(--text-strong);text-wrap:balance;margin:0 0 14px;font-size:clamp(40px,4.3vw,78px);line-height:1}.accent{background:linear-gradient(135deg, var(--accent), var(--accent-2));color:#0000;-webkit-background-clip:text;background-clip:text}.subhead{max-width:70ch;color:var(--muted);margin:0 0 18px;font-size:19px}.ctaRow{flex-wrap:wrap;align-items:center;gap:12px;display:flex}@media (width<=900px){.heroGif{display:none}}.btn{border:1px solid var(--border);background:var(--surface);color:var(--text-strong);box-shadow:var(--shadow-soft);border-radius:999px;justify-content:center;align-items:center;gap:10px;padding:10px 14px;font-weight:650;text-decoration:none;transition:transform .12s,background .16s,border-color .16s,box-shadow .16s;display:inline-flex}.btn:hover{background:#fffefb;border-color:#1c191724;transform:translateY(-1px)}.btn.primary{box-shadow:var(--shadow-soft);background:linear-gradient(135deg,#c54b3c1f,#2f4f6f14);border-color:#c54b3c59}.btn:focus-visible,.nav a:focus-visible,.link:focus-visible,.inlineLink:focus-visible{outline-offset:2px;outline:2px solid #c54b3c73}.meritWrap{display:inline-flex;position:relative}.meritLayer{pointer-events:none;position:absolute;inset:0}.meritToast{color:var(--text-strong);letter-spacing:.2px;text-shadow:0 4px 14px #faf6f2f2,0 2px 8px #1c19171f;-webkit-user-select:none;user-select:none;white-space:nowrap;font-weight:800;animation:.9s ease-out forwards merit-float;position:absolute;top:-6px;left:50%;transform:translate(-50%)}@keyframes merit-float{0%{opacity:0;filter:blur(.2px);transform:translate(-50%,8px)scale(.98)}20%{opacity:1;filter:blur();transform:translate(-50%,-2px)scale(1)}to{opacity:0;transform:translate(-50%,-26px)scale(1.02)}}.heroCard{border:1px solid var(--border);box-shadow:var(--shadow);background:linear-gradient(#fff 0%,#fdfaf7 100%);border-radius:22px;min-width:240px;padding:20px;position:relative;overflow:hidden}.heroCard:before{content:"";filter:blur(10px);pointer-events:none;background:radial-gradient(circle at 30% 30%,#c54b3c14,#0000 55%),radial-gradient(circle at 70% 10%,#2f4f6f0f,#0000 55%);height:220px;position:absolute;inset:-40% -40% auto}.avatar{border:1px solid var(--border);background:var(--bg-warm);z-index:1;border-radius:999px;width:132px;height:132px;margin:12px auto 10px;position:relative;overflow:hidden}.avatar img{object-fit:cover;width:100%;height:100%;display:block}.heroMeta{z-index:1;text-align:center;padding:6px 0 2px;position:relative}.metaName{color:var(--text-strong);font-weight:700}.metaTitle{color:var(--muted);margin-top:4px;font-size:14px;font-weight:600}.capabilityStack{grid-template-columns:1fr;gap:12px;display:grid}.capabilityCard{border:1px solid var(--border);background:var(--surface);box-shadow:var(--shadow-soft);border-radius:16px;padding:16px;text-decoration:none;transition:transform .16s,border-color .16s,background .16s,box-shadow .16s}.capabilityCard:hover{box-shadow:var(--shadow);background:#fffefb;border-color:#1c19171f;transform:translateY(-2px)}.capabilitySubtitle{color:var(--muted);text-transform:uppercase;letter-spacing:.16em;margin:0 0 8px;font-size:11px;font-weight:700}.capabilityTitle{color:var(--text-strong);letter-spacing:-.5px;margin:0 0 6px;font-size:24px;line-height:1.15}.capabilityDesc{color:var(--text);margin:0}.capabilityCard:focus-visible{outline-offset:2px;outline:2px solid #c54b3c73}.carousel{-webkit-backdrop-filter:none;backdrop-filter:none;background:0 0;border-radius:22px;position:relative;overflow:hidden}.carousel:before{content:"";pointer-events:none;opacity:1;background:radial-gradient(circle at 12% 20%,#f5ebe380,#0000 50%);position:absolute;inset:0}.carouselStage{z-index:1;will-change:transform;width:100%;transition:transform .62s cubic-bezier(.22,1,.36,1);display:flex;position:relative}.carouselSlide{flex:0 0 100%;grid-template-columns:1.02fr 1.18fr;align-items:stretch;gap:34px;min-height:430px;padding:10px 10px 0;display:grid}.carouselLeft{padding:34px 18px 28px 26px}.carouselEyebrow{color:var(--muted);letter-spacing:.14em;text-transform:uppercase;margin:0 0 14px;font-size:12px;font-weight:700}.carouselTitleLink{color:inherit;text-decoration:none}.carouselTitle{letter-spacing:-1.1px;color:var(--text-strong);text-wrap:balance;margin:0 0 14px;font-size:clamp(40px,3.6vw,66px);line-height:1.08}.carouselMeta{color:var(--muted);letter-spacing:.2px;margin:-4px 0 14px;font-size:16px;font-weight:650}.carouselDesc{color:var(--text);max-width:70ch;margin:0 0 18px;font-size:21px}.carouselCta{color:var(--text-strong);border-bottom:2px solid #c54b3c73;align-items:center;gap:10px;padding-bottom:3px;font-weight:700;text-decoration:none;display:inline-flex}.carouselCta:hover{border-bottom-color:var(--accent)}.carouselRight{border:1px solid var(--border);background:var(--surface);box-shadow:var(--shadow);border-radius:18px;display:block;position:relative;overflow:hidden}.carouselRight:after{content:"";pointer-events:none;background:linear-gradient(135deg,#ffffff1f 0%,#0000 40%);position:absolute;inset:0}.carouselImg{object-fit:cover;filter:saturate(1.03)contrast(1.02);width:100%;height:100%;transition:transform .55s;transform:scale(1.02)}.section[data-carousel-id=reading] .carouselSlide{grid-template-columns:1.14fr .86fr;gap:28px}.section[data-carousel-id=reading] .carouselRight{aspect-ratio:2/3;justify-self:end;max-width:360px}.section[data-carousel-id=reading] .carouselImg{object-fit:cover;background:0 0}.section[data-carousel-id=projects] .carouselSlide{grid-template-columns:1.14fr .86fr;gap:28px}.section[data-carousel-id=projects] .carouselRight{aspect-ratio:2/3;justify-self:end;max-width:360px}.section[data-carousel-id=projects] .carouselImg{object-fit:cover;background:0 0}.section[data-carousel-id=reading] .carouselRight,.section[data-carousel-id=projects] .carouselRight{background:0 0}.carouselRight:hover .carouselImg{transform:scale(1.06)}.carouselControls{z-index:1;justify-content:center;align-items:center;gap:14px;padding:18px 8px 0;display:flex;position:relative}.carouselBtn{border:1px solid var(--border);background:var(--surface);width:42px;height:42px;color:var(--text-strong);cursor:pointer;box-shadow:var(--shadow-soft);border-radius:999px;font-weight:800;transition:transform .12s,background .16s,border-color .16s,box-shadow .16s}.carouselBtn:hover{background:#fffefb;border-color:#1c191724;transform:translateY(-1px)}.carouselDots{align-items:center;gap:10px;display:inline-flex}.carouselDot{cursor:pointer;background:#1c191714;border:1px solid #1c19172e;border-radius:999px;width:10px;height:10px;transition:transform .12s,background .16s,border-color .16s}.carouselDot:hover{background:#1c191724;transform:scale(1.1)}.carouselDot.isActive{background:var(--accent);border-color:var(--accent)}.carouselBtn:focus-visible,.carouselDot:focus-visible,.carouselTitleLink:focus-visible,.carouselRight:focus-visible,.carouselCta:focus-visible{outline-offset:2px;outline:2px solid #c54b3c73}.srOnly{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.heroCtaBand{grid-template-columns:auto 1fr;gap:12px;display:grid}.ctaPanel{border:1px solid var(--border);box-shadow:var(--shadow-soft);background:linear-gradient(#fff 0%,#fdfaf7 100%);border-radius:22px;justify-content:space-between;align-items:center;gap:16px;padding:20px;display:flex}.ctaPanelEyebrow{color:var(--muted);text-transform:uppercase;letter-spacing:.16em;margin:0;font-size:11px;font-weight:700}.ctaPanelText{color:var(--text-strong);letter-spacing:-.2px;margin:0;font-size:19px;font-weight:620}.sectionFrame{border:1px solid var(--border);background:var(--surface);box-shadow:var(--shadow-soft);border-radius:24px;padding:28px}.sectionTitle{letter-spacing:-.8px;width:100%;color:var(--text-strong);text-wrap:balance;margin:0 0 12px;font-size:32px}.sectionTitle:before{content:"SECTION";letter-spacing:.22em;color:var(--muted);margin-bottom:8px;font-size:12px;font-weight:700;display:block}.sectionTitleAbout:before{content:"About me"}.sectionLead{width:100%;color:var(--muted);max-width:72ch;margin:0 0 18px}.noWrap{white-space:nowrap}@media (width>=900px){.sectionLeadAboutNoBreak{white-space:nowrap}}.chips{flex-wrap:wrap;gap:10px;width:100%;margin:0;display:flex}.chip{border:1px solid var(--border);color:var(--text);background:#ffffffbf;border-radius:12px;padding:8px 10px;font-size:14px;font-weight:600}.grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;width:100%;margin:22px 0 0;display:grid}.card{border:1px solid var(--border);background:var(--surface);box-shadow:var(--shadow-soft);border-radius:20px;transition:transform .16s,border-color .16s,background .16s,box-shadow .16s;overflow:hidden}.card:hover{box-shadow:var(--shadow);background:#fffefb;border-color:#1c19171f;transform:translateY(-2px)}.cardMedia{aspect-ratio:16/9;background:var(--bg-warm);border-bottom:1px solid var(--border);overflow:hidden}.cardMedia img{object-fit:cover;filter:saturate(1.05)contrast(1.04);width:100%;height:100%;transition:transform .45s}.card:hover .cardMedia img{transform:scale(1.04)}.cardBody{padding:14px 14px 16px}.cardTitle{color:var(--text-strong);letter-spacing:-.4px;margin:0 0 6px;font-size:25px;line-height:1.2}.cardDesc{color:var(--muted);margin:0 0 10px;font-size:14px}.tagRow{flex-wrap:wrap;gap:8px;margin:0 0 12px;display:flex}.tag{font-family:var(--mono);border:1px solid var(--border);color:var(--text);background:#f5ebe373;border-radius:10px;padding:6px 8px;font-size:12px}.linkRow{flex-wrap:wrap;gap:12px;display:flex}.link{color:var(--text-strong);border-bottom:2px solid #c54b3c59;padding-bottom:2px;font-size:16px;font-weight:650;text-decoration:none;transition:color .16s,border-color .16s}.link:hover{color:var(--accent);border-color:var(--accent)}.inlineLink{color:var(--text-strong);border-bottom:1px solid #1c191733;text-decoration:none}.inlineLink:hover{border-color:var(--accent)}.socialRow{flex-wrap:wrap;gap:12px;width:min(1400px,100% - 48px);margin:18px auto 0;display:flex}.footer{border-top:1px solid var(--border);color:var(--muted);padding:28px 0}.footerInner{justify-content:space-between;align-items:center;gap:12px;display:flex}[data-reveal]{opacity:0;will-change:opacity, transform;transition:opacity .6s,transform .6s;transform:translateY(10px)}[data-reveal][data-revealed=true]{opacity:1;transform:translateY(0)}@media (width>=1600px){.container,.heroGrid{width:min(1540px,100% - 56px)}}@media (width<=900px){.container,.heroGrid{width:min(100%,100% - 24px)}.heroGrid{gap:16px}.homeSplit,.heroCtaBand{grid-template-columns:1fr}.ctaPanel{flex-direction:column;align-items:flex-start}.carouselSlide{grid-template-columns:1fr;gap:16px;min-height:auto}.carouselLeft{padding:22px 12px 0}.carouselRight{border-radius:16px}.carouselControls{padding-top:14px}.nav{gap:6px}.nav a{padding:8px}.sectionFrame{border-radius:18px;padding:20px}.sectionTitle{font-size:28px}.section{padding:64px 0}.grid{grid-template-columns:1fr}.footerInner{flex-direction:column;align-items:flex-start}.section[data-carousel-id=reading] .carouselSlide,.section[data-carousel-id=projects] .carouselSlide{grid-template-columns:1fr;gap:16px}.section[data-carousel-id=reading] .carouselRight,.section[data-carousel-id=projects] .carouselRight{justify-self:center;width:100%;max-width:280px}}@media (width<=640px){:root{font-size:15px}.topbar{padding:10px 14px}.brandText{font-size:12px}.nav{gap:2px}.nav a{letter-spacing:.18px;padding:6px;font-size:12px}.container,.heroGrid{width:min(100%,100% - 20px)}.section{padding:44px 0}.heroSection{padding-top:36px}.heroCopy{padding:8px 0 4px}.headline{letter-spacing:-.8px;font-size:clamp(30px,9vw,44px);line-height:1.05}.subhead{margin:0 0 14px;font-size:16px}.ctaRow{gap:10px}.btn{padding:10px 14px;font-size:14px}.capabilityStack{gap:10px}.capabilityCard{border-radius:14px;padding:14px}.capabilityTitle{font-size:19px}.capabilityDesc{font-size:14px}.heroCard{border-radius:18px;min-width:0;padding:16px}.avatar{width:104px;height:104px;margin:6px auto 8px}.ctaPanel{border-radius:18px;gap:10px;padding:16px}.ctaPanelText{font-size:16px}.sectionFrame{border-radius:16px;padding:18px}.sectionTitle{letter-spacing:-.3px;font-size:22px}.sectionTitle:before{margin-bottom:6px;font-size:11px}.sectionLead{font-size:15px}.chip{padding:6px 10px;font-size:13px}.carousel{border-radius:18px}.carouselSlide{gap:14px;padding:8px 6px 0}.carouselLeft{padding:16px 8px 0}.carouselEyebrow{margin:0 0 10px;font-size:11px}.carouselTitle{letter-spacing:-.4px;margin:0 0 10px;font-size:clamp(24px,7.2vw,32px);line-height:1.15}.carouselMeta{margin:-2px 0 10px;font-size:14px}.carouselDesc{margin:0 0 14px;font-size:15px;line-height:1.6}.carouselCta{font-size:14px}.carouselRight{border-radius:14px}.section[data-carousel-id=reading] .carouselRight,.section[data-carousel-id=projects] .carouselRight{max-width:220px}.carouselBtn{width:38px;height:38px}.carouselControls{gap:10px;padding:14px 4px 0}.sectionLeadAboutNoBreak,.noWrap{white-space:normal}.footer{padding:20px 0}}@media (width<=380px){.headline{font-size:clamp(26px,8.6vw,34px)}.carouselTitle{font-size:clamp(22px,7vw,28px)}.nav a{padding:5px 4px;font-size:11px}.brand{gap:8px}}
