@import "https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700;800&family=Sora:wght@500;600;700&display=swap";:root{--bg:oklch(14% .014 260);--surface:oklch(18% .014 260);--surface-text:oklch(95% .015 95);--text:oklch(82% .018 260);--muted:oklch(61% .016 260);--muted-strong:oklch(72% .018 250);--line:oklch(30% .025 250);--accent:oklch(76% .13 235);--elevated:oklch(11% .012 255);--button-text:oklch(13% .015 252);--shadow-strong:#00000038;--shadow-soft:#0000002e;--font-sans:"Manrope", "Segoe UI", sans-serif;--font-display:"Sora", "Segoe UI", sans-serif;color:var(--text);background:radial-gradient(circle at top, #37496f33, transparent 30%), linear-gradient(180deg, oklch(12% .01 250) 0%, var(--bg) 100%);font-family:var(--font-sans);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;font-size:16px;font-weight:500;line-height:1.6}:root[data-theme=light]{--bg:oklch(96.5% .01 240);--surface:oklch(94.5% .014 245);--surface-text:oklch(23% .02 250);--text:oklch(34% .02 248);--muted:oklch(52% .018 248);--muted-strong:oklch(43% .028 242);--line:oklch(84% .018 245);--accent:oklch(58% .13 242);--elevated:oklch(99% .008 245);--button-text:oklch(24% .02 250);--shadow-strong:#3a4c7229;--shadow-soft:#3a4c721f;color:var(--text);background:radial-gradient(circle at top, #6984bf1f, transparent 32%), linear-gradient(180deg, oklch(98.5% .008 245) 0%, var(--bg) 100%);--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light}*{box-sizing:border-box}html{scroll-behavior:smooth}body{background:var(--bg);min-width:320px;min-height:100vh;color:var(--text);margin:0;transition:background-color .22s,color .22s}body:before{content:"";pointer-events:none;background-color:#0000;background-image:linear-gradient(90deg,#6883c50b 1px,#0000 1px),linear-gradient(#6883c508 1px,#0000 1px);background-position:0 0,0 0;background-repeat:repeat,repeat;background-size:6.5rem 6.5rem;background-attachment:scroll,scroll;background-origin:padding-box,padding-box;background-clip:border-box,border-box;transition:opacity .22s;position:fixed;inset:0;-webkit-mask-image:linear-gradient(#00000073,#0000 78%);mask-image:linear-gradient(#00000073,#0000 78%)}:root[data-theme=light] body:before{opacity:.72;background:linear-gradient(90deg,#4c6aae0b 1px,#0000 1px),linear-gradient(#4c6aae08 1px,#0000 1px)}a,button{-webkit-tap-highlight-color:transparent}a:focus-visible,button:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:.35rem}#root{min-height:100vh}h1,h2,h3,p{margin:0}h1,h2,h3{color:var(--surface-text)}h1,h2{font-family:var(--font-display);letter-spacing:-.03em}h1{font-size:clamp(1.8rem,4vw,2.25rem);line-height:1.1}h2{font-size:clamp(1.18rem,2vw,1.38rem);line-height:1.15}h3{font-size:1rem;line-height:1.3}p{font-size:.96rem}@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}.portfolio-shell{--ease-out-quart:cubic-bezier(.25, 1, .5, 1);--ease-out-expo:cubic-bezier(.16, 1, .3, 1);width:min(100%,76rem);margin:0 auto;padding:clamp(1.5rem,3vw,2.75rem) clamp(1.2rem,3vw,2.5rem) clamp(2rem,4vw,3rem)}.motion-enter{opacity:0;transition:opacity .52s var(--ease-out-expo), transform .52s var(--ease-out-expo);transition-delay:var(--enter-delay,0s);transform:translateY(.9rem)}.is-ready .motion-enter{opacity:1;transform:translate(0,0)}.section-transition{animation:section-fade .32s var(--ease-out-quart)}@keyframes section-fade{0%{opacity:0;transform:translateY(.65rem)}to{opacity:1;transform:translate(0,0)}}.topbar,.page,.footer{max-width:55.5rem;margin:0 auto}.topbar{justify-content:space-between;align-items:center;margin-bottom:clamp(2rem,6vw,4.1rem);display:flex}.topnav{color:var(--muted);gap:1rem;font-size:.92rem;display:inline-flex}.topnav a{min-height:2rem;color:inherit;transition:color .18s var(--ease-out-quart), opacity .18s var(--ease-out-quart), transform .18s var(--ease-out-quart);align-items:center;padding-bottom:.22rem;text-decoration:none;display:inline-flex;position:relative}.topnav a:after{content:"";background:var(--accent);opacity:0;height:1px;transition:opacity .18s var(--ease-out-quart), transform .18s var(--ease-out-quart);position:absolute;bottom:0;left:0;right:0;transform:scaleX(.8)}.topnav a:hover,.topnav a:focus-visible,.topnav .active{color:var(--accent)}.topnav a:hover,.topnav a:focus-visible{transform:translateY(-1px)}.topnav .active:after{opacity:1;transform:scaleX(1)}.topnav a:focus-visible,.resume-button:focus-visible,.social-row a:focus-visible,.project-item a:focus-visible,.footer-links a:focus-visible,.contact-row a:focus-visible{outline:2px solid color-mix(in oklab, var(--accent) 70%, white 30%);outline-offset:2px}.theme-toggle{border:1px solid color-mix(in oklab, var(--line) 86%, white 14%);background:color-mix(in oklab, var(--surface) 78%, var(--bg) 22%);min-height:2.4rem;color:var(--muted-strong);cursor:pointer;transition:background-color .18s var(--ease-out-quart), border-color .18s var(--ease-out-quart), color .18s var(--ease-out-quart), transform .18s var(--ease-out-quart), box-shadow .18s var(--ease-out-quart);border-radius:999px;align-items:center;gap:.55rem;padding:.38rem .72rem .38rem .46rem;display:inline-flex;box-shadow:inset 0 1px oklab(100% 0 5.96046e-8/.12)}.theme-toggle:hover,.theme-toggle:focus-visible{color:var(--surface-text);border-color:color-mix(in oklab, var(--accent) 28%, var(--line));background:color-mix(in oklab, var(--surface) 88%, var(--bg) 12%);box-shadow:inset 0 1px 0 oklab(100% 0 5.96046e-8/.16), 0 .5rem 1.4rem var(--shadow-soft);transform:translateY(-1px)}.theme-toggle[aria-pressed=true]{color:var(--accent)}.theme-toggle__icon{background:color-mix(in oklab, var(--accent) 18%, var(--surface));width:1.5rem;height:1.5rem;color:color-mix(in oklab, var(--surface-text) 84%, var(--accent) 16%);transition:transform .22s var(--ease-out-quart), background-color .22s var(--ease-out-quart), color .22s var(--ease-out-quart);border-radius:999px;place-items:center;display:grid}.theme-toggle:hover .theme-toggle__icon,.theme-toggle:focus-visible .theme-toggle__icon{background:color-mix(in oklab, var(--accent) 24%, var(--surface));transform:rotate(10deg)scale(1.04)}.theme-toggle__icon svg{width:.94rem;height:.94rem;display:block}.theme-toggle__label{letter-spacing:.06em;text-transform:uppercase;font-size:.76rem;font-weight:700}.page{gap:3rem;display:grid}.panel{border-left:1px solid var(--line);border-right:1px solid var(--line)}.panel-heading{border-bottom:1px solid var(--line);padding:.05rem .8rem .45rem}.panel-heading p{color:var(--muted);font-size:.83rem}.panel-heading h2{letter-spacing:.01em}.intro-grid{grid-template-columns:minmax(0,1.55fr) minmax(13rem,.9fr);align-items:center;gap:clamp(1.5rem,3vw,2rem);padding:.85rem .8rem 0;display:grid}.intro-copy{max-width:36rem}.intro-copy p+p{margin-top:1.35rem}.intro-copy a{color:var(--text)}.contact-row{color:var(--muted);flex-wrap:wrap;gap:.55rem;margin-top:1rem;font-size:.83rem;display:flex}.contact-row a{color:inherit;text-decoration:none}.contact-row a:hover,.contact-row a:focus-visible{color:var(--surface-text)}.social-row{flex-wrap:wrap;align-items:center;gap:.8rem;margin-top:1.35rem;display:flex}.social-row a{width:1.4rem;height:1.4rem;color:var(--muted-strong);transition:color .18s var(--ease-out-quart), transform .18s var(--ease-out-quart);justify-content:center;align-items:center;display:inline-flex}.social-row a:hover,.social-row a:focus-visible{color:var(--text);transform:translateY(-1px)}.social-label{color:var(--muted);letter-spacing:.02em;font-size:.8rem}.social-text-link{color:var(--muted);font-size:.82rem;text-decoration:none;transition:color .18s}.social-text-link:hover,.social-text-link:focus-visible{color:var(--surface-text)}.social-row svg{width:100%;height:100%}.intro-copy .resume-button{border:1px solid color-mix(in oklab, white 88%, var(--line) 12%);background:linear-gradient(180deg, color-mix(in oklab, white 96%, var(--surface) 4%), color-mix(in oklab, white 90%, var(--surface) 10%));min-width:6.9rem;color:var(--button-text);letter-spacing:.01em;box-shadow:0 .5rem 1.6rem var(--shadow-strong);transition:transform .18s var(--ease-out-quart), box-shadow .18s var(--ease-out-quart), background-position .24s var(--ease-out-quart);background-position:50% 0;background-size:100% 160%;border-radius:999px;justify-content:center;align-items:center;margin-top:1rem;padding:.62rem 1rem;font-size:.82rem;font-weight:600;text-decoration:none;display:inline-flex}.intro-copy .resume-button:hover,.intro-copy .resume-button:focus-visible{box-shadow:0 .8rem 2rem color-mix(in srgb, var(--shadow-strong) 115%, transparent);color:var(--button-text);background-position:50% 100%;transform:translateY(-2px)}.portrait-card{justify-content:center;padding-bottom:.8rem;display:flex}.portrait-orb{aspect-ratio:1;border:1px solid color-mix(in oklab, var(--accent) 34%, var(--line));width:clamp(10rem,24vw,12rem);transition:transform .28s var(--ease-out-expo), box-shadow .28s var(--ease-out-expo), border-color .28s var(--ease-out-expo);will-change:transform;background:radial-gradient(circle at 30% 30%,#a8c47bf2,#0000 34%),radial-gradient(circle at 72% 28%,#607ebad1,#0000 20%),radial-gradient(circle at 62% 72%,#eed6aa99,#0000 18%),linear-gradient(145deg,#6e8653 0%,#aab67a 38%,#607a53 66%,#2f3844 100%);border-radius:999px;place-items:center;display:grid;box-shadow:0 0 0 .35rem #6181991a,0 1rem 2.5rem #00000052}.portrait-card:hover .portrait-orb,.portrait-card:focus-within .portrait-orb{border-color:color-mix(in oklab, var(--accent) 46%, var(--line));transform:translateY(-.25rem)scale(1.01);box-shadow:0 0 0 .35rem #6181991a,0 1.25rem 3rem #0000005c}.portrait-core{aspect-ratio:1;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);color:#faf4e6f5;width:52%;font-family:var(--font-display);letter-spacing:.06em;background:#11141a57;border:1px solid #f5f2e973;border-radius:999px;place-items:center;font-size:clamp(2rem,4vw,2.7rem);display:grid}.portrait-image{border-radius:inherit;object-fit:cover;width:100%;height:100%}.content-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:1.35rem;display:grid}.content-grid .projects-section{grid-column:1/-1}.project-list,.timeline{padding:.8rem}.project-list{grid-template-columns:1fr;gap:.9rem;display:grid}.project-item+.project-item{margin-top:0}.project-item{border:1px solid color-mix(in oklab, var(--line) 90%, white 10%);background:var(--elevated);transition:border-color .2s var(--ease-out-quart), transform .2s var(--ease-out-quart), box-shadow .2s var(--ease-out-quart);border-radius:.62rem;padding:.85rem .9rem}.project-item:hover{border-color:color-mix(in oklab, var(--accent) 32%, var(--line));box-shadow:0 .8rem 2rem var(--shadow-soft);transform:translateY(-2px)}.project-title{justify-content:space-between;align-items:baseline;gap:1rem;display:flex}.project-title span{color:var(--muted);border:1px solid color-mix(in oklab, var(--line) 86%, white 14%);border-radius:999px;padding:.12rem .45rem;font-size:.8rem}.project-item h3,.timeline-copy h3{margin:0;font-size:1rem}.project-stack{color:var(--muted-strong);margin-top:.22rem;font-size:.82rem}.project-item p{max-width:none;margin-top:.28rem;line-height:1.5}.project-item a{border-bottom:1px solid color-mix(in oklab, var(--line) 78%, white 22%);color:var(--surface-text);transition:color .18s var(--ease-out-quart), border-color .18s var(--ease-out-quart), transform .18s var(--ease-out-quart);margin-top:.55rem;padding-bottom:.04rem;font-size:.84rem;font-weight:600;text-decoration:none;display:inline-flex}.project-item a:hover,.project-item a:focus-visible{color:var(--accent);border-color:color-mix(in oklab, var(--accent) 44%, var(--line));transform:translate(.18rem)}.timeline{gap:1.2rem;display:grid;position:relative}.timeline:before{content:"";background:color-mix(in oklab, var(--surface-text) 45%, var(--line) 55%);width:2px;position:absolute;top:1rem;bottom:1rem;left:1rem}.timeline-item{grid-template-columns:2.15rem minmax(0,1fr);gap:.9rem;display:grid;position:relative}.timeline-marker{z-index:1;border:1px solid var(--line);background:var(--surface);width:1.7rem;height:1.7rem;color:var(--muted-strong);border-radius:.45rem;place-items:center;margin-top:.08rem;margin-left:.08rem;display:grid;position:relative}.timeline-marker svg{width:.82rem;height:.82rem;display:block;transform:translate(-.01rem,-.03rem)}.timeline-role{color:var(--text);font-weight:600}.timeline-copy p{margin-top:.2rem}.content-grid--lower{gap:1.35rem}.skills-list{flex-wrap:wrap;align-content:flex-start;gap:.55rem;padding:.8rem;display:flex}.skill-chip{border:1px solid color-mix(in oklab, var(--line) 92%, white 8%);color:color-mix(in oklab, var(--text) 86%, var(--surface-text) 14%);background:var(--elevated);letter-spacing:.01em;transition:border-color .18s var(--ease-out-quart), color .18s var(--ease-out-quart), transform .18s var(--ease-out-quart), background-color .18s var(--ease-out-quart);border-radius:999px;align-items:center;padding:.4rem .68rem;font-size:.78rem;line-height:1;display:inline-flex}.skill-chip:hover{border-color:color-mix(in oklab, var(--accent) 30%, var(--line));color:var(--surface-text);background-color:color-mix(in oklab, var(--elevated) 88%, var(--accent) 12%);transform:translateY(-1px)}.resume-button:active,.social-row a:active,.topnav a:active,.project-item a:active{transform:translateY(0)}.footer{border-top:1px solid var(--line);color:var(--muted);grid-template-columns:auto 1fr auto;align-items:center;gap:1rem;margin-top:4.2rem;padding-top:1.2rem;font-size:.78rem;display:grid}.footer-mark{border:1px solid var(--line);width:1.45rem;height:1.45rem;color:var(--surface-text);border-radius:999px;place-items:center;font-size:.74rem;font-weight:700;display:grid}.footer-links{justify-self:end;align-items:center;gap:.65rem;display:flex}.footer-links a{color:inherit;text-decoration:none}.footer-links a:hover,.footer-links a:focus-visible{color:var(--text)}@media (width<=820px){.topbar{flex-wrap:wrap;gap:.7rem;margin-bottom:1.7rem}.content-grid,.intro-grid,.footer{grid-template-columns:1fr}.portrait-card{justify-content:center;padding-bottom:.35rem}.portrait-orb{width:clamp(9.6rem,36vw,11.3rem)}.content-grid{gap:1rem}.project-list{grid-template-columns:1fr}.footer-links{justify-self:start}}@media (prefers-reduced-motion:reduce){.motion-enter,.section-transition,.topnav a,.topnav a:after,.theme-toggle,.theme-toggle__ring,.social-row a,.resume-button,.portrait-orb,.project-item,.project-item a,.skill-chip{transition-duration:.01ms!important;transition-delay:0s!important;animation:none!important;transform:none!important}.motion-enter{opacity:1!important}}@media (width<=560px){.portfolio-shell{padding-inline:.95rem}.topnav{flex-wrap:wrap;gap:.8rem;font-size:.87rem}.topnav a{align-items:center;min-height:2.6rem;padding-bottom:.12rem;display:inline-flex}.panel-heading h1{font-size:clamp(2rem,9vw,2.35rem)}.intro-copy{text-align:center;max-width:100%}.intro-copy p{font-size:1rem;line-height:1.56}.intro-copy p+p{margin-top:1.1rem}.contact-row,.social-row{justify-content:center;margin-top:.9rem}.resume-button{min-width:8rem;margin-inline:auto}.social-text-link{font-size:.86rem}.portrait-orb{width:min(56vw,11rem)}.project-title{flex-direction:column;gap:.2rem}.panel-heading,.project-list,.timeline,.intro-grid{padding-left:.7rem;padding-right:.7rem}.footer{grid-template-columns:1fr;gap:.55rem}.footer-links,.footer p{justify-self:start}}
