:root{--bg:#fff3e6;--surface:#fff;--surface-soft:#fff8ef;--text:#381932;--text-muted:#6f4f67;--border:#e2cfbc;--divider:var(--border);--radius:16px;--radius-sm:10px;--shadow:0 10px 24px #38193214;--max-width:1024px;--page-gutter:clamp(1rem, 4.5vw, 1.75rem);--section-gap:clamp(1.25rem, 3.5vw, 1.5rem);--section-pad-y:clamp(1.5rem, 4vw, 2rem);--space-1:8px;--space-2:12px;--space-3:16px;--space-4:20px;--space-5:24px;--space-6:32px;--fs-body:1rem;--fs-small:.95rem;--fs-title:clamp(2rem, 7vw, 5rem);--fs-h2:1.95rem;--fs-h3:1.25rem}*{box-sizing:border-box}html,body,#root{min-height:100%;margin:0}html{scrollbar-gutter:stable;scroll-behavior:auto;overflow-x:clip}body{background:var(--bg);color:var(--text);font-family:Work Sans,sans-serif;font-size:var(--fs-body);letter-spacing:.005em;padding-bottom:env(safe-area-inset-bottom,0px);overscroll-behavior-y:auto;line-height:1.65;overflow-x:clip}h1,h2,h3{letter-spacing:-.01em;margin:0;font-family:Raleway,sans-serif;line-height:1.15}h2{font-size:var(--fs-h2)}h3{font-size:var(--fs-h3)}p{margin:0}a{color:inherit;text-decoration:none}button{font:inherit;color:inherit}.app-shell{padding:0 0 var(--section-pad-y)}.container{width:100%;max-width:var(--max-width);padding-left:max(var(--page-gutter), env(safe-area-inset-left,0px));padding-right:max(var(--page-gutter), env(safe-area-inset-right,0px));box-sizing:border-box;gap:var(--section-gap);margin-inline:auto;padding-block-start:0;display:grid}.page-section{min-height:100dvh;padding:0 0 var(--section-pad-y);flex-direction:column;justify-content:flex-start;align-items:stretch;display:flex}.page-section-hero{min-height:100dvh;padding-top:0}.scroll-progress{left:0;right:0;bottom:env(safe-area-inset-bottom,0px);background:var(--text);transform-origin:0;z-index:50;height:4px;position:fixed;top:auto}.section{gap:var(--section-gap);width:100%;min-width:0;padding-bottom:0;display:grid}.section-header{z-index:4;overflow-wrap:break-word;box-sizing:border-box;width:100dvw;max-width:100dvw;margin-top:0;margin-bottom:var(--space-5);padding-block:var(--space-4);background:repeating-linear-gradient(135deg, #fff3e614 0 2px, transparent 2px 6px), linear-gradient(180deg, color-mix(in srgb, var(--text) 94%, #000), var(--text));color:var(--bg);box-shadow:0 1px 0 var(--divider);border:0;border-radius:0;margin-inline:calc(50% - 50dvw);padding-inline:0;position:sticky;top:0;overflow:hidden}.section-header-inner{width:100%;max-width:var(--max-width);box-sizing:border-box;padding-inline:max(var(--page-gutter), env(safe-area-inset-left,0px)) max(var(--page-gutter), env(safe-area-inset-right,0px));gap:var(--space-2);text-align:start;justify-items:start;margin-inline:auto;display:grid}.section-header h2{color:var(--bg);font-size:var(--fs-h2);margin:0;line-height:1.12}.section-header-subtitle,.section-header p.section-header-subtitle{color:var(--bg);opacity:.88;max-height:none;margin:0}.stack-grid{gap:var(--section-gap);display:grid}.row-between{justify-content:space-between;align-items:center;gap:var(--space-2);flex-wrap:wrap;display:flex}@media (width>=840px){.stack-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.stack-grid--single{grid-template-columns:minmax(0,1fr)}}@supports not (width:100dvw){.section-header{width:100vw;max-width:100vw;margin-inline:calc(50% - 50vw)}}@media (width<=860px){.section-header{box-sizing:border-box;width:100dvw;max-width:100dvw;margin-inline:calc(50% - 50dvw)}.section-header-inner{width:100%;max-width:none;padding-inline:env(safe-area-inset-left,0px) env(safe-area-inset-right,0px);margin-inline:0}.section-header h2{margin:0}}.hero{gap:var(--space-3);display:grid}.eyebrow,.muted{color:var(--text-muted);opacity:.8}.hero-screen{align-items:center;gap:var(--space-6);min-height:min(100vh,100dvh);padding-block:var(--space-5);grid-template-columns:1.2fr .8fr;margin-bottom:0;padding-inline:0}.hero-content{gap:var(--space-5);display:grid}.hero-meta{justify-content:space-between;align-items:center;gap:var(--space-3);flex-wrap:wrap;display:flex}.top-skills-marquee{width:100dvw;max-width:100dvw;margin-top:var(--space-4);padding-block:var(--space-3);border-top:1px solid var(--divider);border-bottom:1px solid var(--divider);background:color-mix(in srgb, var(--surface-soft) 88%, var(--text) 5%);box-sizing:border-box;flex-shrink:0;margin-inline:calc(50% - 50dvw);padding-inline:0;overflow:hidden}.skills-marquee-track{gap:var(--space-4);will-change:transform;width:max-content;animation:32s linear infinite skills-marquee-scroll;display:flex}.marquee-item{font-size:var(--fs-small);letter-spacing:.04em;text-transform:uppercase;color:var(--text);opacity:.82;white-space:nowrap;font-weight:600}.meta-item{align-items:center;gap:var(--space-1);font-size:var(--fs-small);color:var(--text);display:inline-flex}.hero-name{font-size:var(--fs-title);white-space:nowrap;color:var(--text);line-height:.98}.hero-aside{gap:var(--space-3);justify-items:center;display:grid}.hero-image-plate{box-sizing:border-box;width:min(320px,62vw)}.hero-image-stack{aspect-ratio:1;isolation:isolate;border-radius:var(--radius);width:100%;box-shadow:var(--shadow);position:relative;overflow:visible}.hero-image-motion{border-radius:inherit;width:100%;height:100%;transform-style:preserve-3d;will-change:transform;overflow:hidden}.hero-image{object-fit:cover;border-radius:inherit;width:100%;height:100%;box-shadow:none;-webkit-user-select:none;user-select:none;-webkit-user-drag:none;border:none;display:block}.hero-image-corners{z-index:2;pointer-events:none;transform-style:preserve-3d;will-change:transform;position:absolute;inset:0}.hero-corner{border-color:color-mix(in srgb, var(--text) 88%, transparent);box-sizing:border-box;border-style:solid;border-width:0;width:1.75rem;height:1.75rem;position:absolute}.hero-corner--tl{border-top-width:2px;border-left-width:2px;border-top-left-radius:10px;top:.55rem;left:.55rem}.hero-corner--tr{border-top-width:2px;border-right-width:2px;border-top-right-radius:10px;top:.55rem;right:.55rem}.hero-corner--bl{border-bottom-width:2px;border-left-width:2px;border-bottom-left-radius:10px;bottom:.55rem;left:.55rem}.hero-corner--br{border-bottom-width:2px;border-right-width:2px;border-bottom-right-radius:10px;bottom:.55rem;right:.55rem}.hero-copy{max-width:720px;margin-top:var(--space-1);font-size:1.05rem}.stats-row,.social-row,.tags{gap:var(--space-2);flex-wrap:wrap;display:flex}.stat strong{margin-top:2px;display:block}.stat{gap:var(--space-1);font-size:var(--fs-small);align-items:baseline;padding:0;display:inline-flex}.chip-link,.pill,.tag{align-items:center;gap:var(--space-1);border-radius:var(--radius-sm);border:1px solid var(--divider);background:var(--surface-soft);color:var(--text);font-size:var(--fs-small);padding:7px 12px;display:inline-flex}.project-link{align-items:center;gap:var(--space-2);margin-top:var(--space-4);color:var(--text);font-weight:600;font-size:var(--fs-small);box-sizing:border-box;border-bottom:1px solid #0000;width:max-content;max-width:100%;padding:2px 0;line-height:1.45;text-decoration:none;display:inline-flex}.project-link:hover{border-bottom-color:var(--text)}.chip-link svg,.tag svg,.pill svg,.project-link svg{flex-shrink:0;font-size:.95rem}.symbol-list{align-items:stretch;gap:var(--space-2);flex-direction:column;margin:0;padding-left:0;list-style:none;display:flex}.symbol-list.project-points{gap:var(--space-3)}.experience-item{padding-block:var(--section-pad-y) var(--space-6);border-bottom:1px solid var(--divider);padding-inline:0}@media (width<=839px){.stack-grid .experience-item:last-child{border-bottom:none}}@media (width>=840px){.stack-grid .experience-item.experience-item--last-row{border-bottom:none}}.experience-role{letter-spacing:-.01em;color:var(--text);font-size:1.24rem;font-weight:700}.experience-company{margin:var(--space-1) 0 0;font-size:var(--fs-small);color:var(--text-muted);opacity:1;font-weight:600}.experience-item .symbol-list{margin-top:var(--space-3)}.symbol-list li:before{content:"◆";color:var(--text-muted);flex-shrink:0;margin-top:.2em;line-height:1.4}.symbol-list li{min-width:0;font-size:var(--fs-small);color:var(--text);opacity:.88;align-items:flex-start;gap:.5rem;margin:0;padding:0;font-weight:500;line-height:1.6;display:flex}.project-image{object-fit:cover;border:2px solid var(--divider);border-radius:999px;width:72px;height:72px;margin:10px 0}.project-card{min-width:0;padding-block:var(--section-pad-y) var(--space-6);border-bottom:1px solid var(--divider);flex-direction:column;align-items:stretch;padding-inline:0;display:flex}.project-card h3{margin:0 0 var(--space-4) 0;text-align:start}.project-card>p{text-align:start;margin:0}.project-card .project-points{margin-top:var(--space-3);margin-bottom:0}#projects .project-card h3,#personal-projects .project-card h3{color:#000;margin-bottom:var(--space-4)}#projects .project-card>p.muted,#personal-projects .project-card>p.muted{color:#000;opacity:1;margin-bottom:var(--space-4);font-weight:300}:is(#projects .project-card>p.muted:has(+ul.project-points),#personal-projects .project-card>p.muted:has(+ul.project-points)){margin-bottom:0}#projects .project-card .project-points li,#personal-projects .project-card .project-points li{color:#000;opacity:1;overflow-wrap:break-word;font-weight:300}#projects .project-card .project-points li:before,#personal-projects .project-card .project-points li:before{color:#000;font-weight:300}.project-card .tags{margin-top:var(--space-4);justify-content:flex-start}.project-card .project-image,.project-card .project-link{align-self:flex-start}.stack-grid--single .project-card:last-child{border-bottom:none}.skills-list{padding:var(--space-5) 0}.repel-card{--repel-x:0px;--repel-y:0px;--repel-rx:0deg;--repel-ry:0deg;transform:translate3d(var(--repel-x), var(--repel-y), 0) rotateX(var(--repel-rx)) rotateY(var(--repel-ry));transition:transform .18s,box-shadow .18s,border-color .18s}.education-grid{gap:var(--section-gap);perspective:1000px;grid-template-columns:repeat(auto-fit,minmax(min(100%,220px),1fr));display:grid}.edu-card{appearance:none;border:1px solid var(--divider);background:var(--surface);perspective:1000px;cursor:pointer;min-height:148px;box-shadow:var(--shadow);padding:0;position:relative;overflow:hidden;border-radius:var(--radius-sm)!important}.edu-card:hover{border-color:color-mix(in srgb, var(--text) 22%, var(--divider));box-shadow:0 14px 24px #3819321f}.edu-inner{width:100%;height:100%;min-height:148px;transform-style:preserve-3d;transition:transform .42s;position:relative}.edu-inner.is-rotated{transform:rotateY(180deg)}.edu-face,.edu-back{inset:var(--space-4);backface-visibility:hidden;gap:var(--space-2);align-content:center;display:grid;position:absolute}.edu-back{transform:rotateY(180deg)}.footer{gap:var(--section-gap);padding-block:var(--section-pad-y) 0;border-top:1px solid var(--divider);padding-inline:0;display:grid}.footer-education-grid{gap:var(--section-gap);grid-template-columns:repeat(auto-fit,minmax(min(100%,220px),1fr));display:grid}.footer-education-card{padding:var(--space-4);border:1px solid var(--divider);border-radius:var(--radius-sm);background:linear-gradient(180deg, color-mix(in srgb, var(--surface-soft) 92%, #fff), color-mix(in srgb, var(--bg) 78%, var(--surface-soft)));box-shadow:var(--shadow);gap:var(--space-1);display:grid}.footer-education-card h3{font-size:1.08rem}.scroll-top-btn{right:max(var(--space-4), env(safe-area-inset-right,0px));bottom:max(var(--space-4), env(safe-area-inset-bottom,0px));z-index:60;align-items:center;gap:var(--space-2);border:1px solid var(--divider);background:var(--text);color:var(--bg);border-radius:var(--radius-sm);font-size:var(--fs-small);cursor:pointer;padding:10px 14px;font-weight:700;display:inline-flex;position:fixed;box-shadow:0 8px 18px #38193240}.scroll-top-btn svg{flex-shrink:0;font-size:.95rem}.footer p{align-items:center;gap:var(--space-1);font-size:var(--fs-small);display:inline-flex}@media (width<=860px){.page-section:not(.page-section-hero),.page-section-hero{justify-content:flex-start}.page-section-hero .hero.hero-screen{text-align:center;justify-content:center;align-items:center;gap:var(--space-5);min-height:0;padding-block:var(--space-5) var(--space-6);flex-direction:column;flex:1;display:flex}.page-section-hero .hero-content{justify-items:center;width:100%;max-width:24rem;margin-inline:auto}.page-section-hero .hero-meta,.page-section-hero .social-row{justify-content:center}.page-section-hero .hero-name{white-space:normal;text-wrap:balance}.page-section-hero .hero-copy{max-width:100%;margin-inline:0}.page-section-hero .hero-aside{max-width:min(20rem,100%);margin-inline:auto}.page-section-hero .hero-image-plate{width:min(240px,70vw)}.page-section-hero .hero-aside .chip-link{text-align:center;justify-content:center}.page-section-hero .hero-aside .chip-link span{overflow-wrap:anywhere}.hero-screen{grid-template-columns:1fr}.experience-item .row-between{align-items:flex-start;gap:var(--space-2);flex-direction:column}.experience-item .pill{align-self:flex-start}.project-card h3{line-height:1.2}.experience-role,.footer-education-card h3,.hero-name,.edu-face h3{margin:0}}@supports not (width:100dvw){.top-skills-marquee{width:100vw;max-width:100vw;margin-inline:calc(50% - 50vw)}}@keyframes skills-marquee-scroll{0%{transform:translate(0)}to{transform:translate(-33.3333%)}}.top-skills-marquee--static .skills-marquee-track{width:100%;max-width:100%;padding:0 var(--space-4);box-sizing:border-box;justify-content:center;row-gap:var(--space-2);flex-wrap:wrap;animation:none}
