.site-header{background:linear-gradient(to bottom, color-mix(in srgb, var(--surface) 42%, transparent), transparent 74%);padding-block:clamp(5rem,9vw,7.25rem);position:relative;overflow:clip}.site-header:after{content:"";background:linear-gradient(to right, transparent, var(--line) 18%, var(--line) 82%, transparent);opacity:.7;width:min(720px,72%);height:1px;margin:clamp(2.5rem,5vw,3.25rem) auto 0;display:block}.header-inner{z-index:1;text-align:center;justify-items:center;gap:clamp(1.4rem,2vw,1.9rem);display:grid;position:relative}.header-avatar{aspect-ratio:1;object-fit:cover;border:1px solid color-mix(in srgb, var(--line) 82%, transparent);background:var(--surface);width:clamp(116px,14vw,144px);transition:transform var(--transition), box-shadow var(--transition), border-color var(--transition);border-radius:50%;transform:translateZ(0);box-shadow:0 18px 40px #1018200b,0 2px 10px #10182006}.header-avatar:hover{border-color:color-mix(in srgb, var(--brand) 18%, var(--line));transform:translateY(-2px);box-shadow:0 22px 52px #1018200f,0 2px 12px #10182008}.header-intro{justify-items:center;gap:.72rem;display:grid}.header-title{letter-spacing:-.055em;font-size:clamp(2.8rem,5vw,3.35rem);line-height:.94}.header-tagline{letter-spacing:.01em;max-width:36ch;color:var(--text-muted);font-size:1rem;font-weight:450;line-height:1.8}@media (width<=640px){.site-header{padding-block:clamp(4rem,12vw,5.5rem)}.header-inner{gap:1.25rem}.header-title{line-height:.98}.header-tagline{max-width:30ch;font-size:.96rem}}.project{isolation:isolate;justify-content:space-between;gap:clamp(1.35rem,2vw,1.7rem);min-height:100%;position:relative}.project:before{content:"";z-index:-1;pointer-events:none;background:radial-gradient(140% 140% at 0% 0%, color-mix(in srgb, var(--brand) 6%, transparent), transparent 54%);opacity:0;transition:opacity var(--transition);position:absolute;inset:0}.project:hover:before{opacity:1}.project .content-stack{gap:.72rem}.project .content-description{max-width:52ch}.tech-list{flex-wrap:wrap;gap:.55rem;margin-top:auto;padding-top:.2rem;display:flex}.tech-pill{border:1px solid color-mix(in srgb, var(--line) 84%, transparent);background:color-mix(in srgb, var(--surface-alt) 86%, transparent);min-height:2rem;color:var(--text-muted);letter-spacing:.015em;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:transform var(--transition-fast), border-color var(--transition-fast), background-color var(--transition-fast), color var(--transition-fast);border-radius:999px;justify-content:center;align-items:center;padding-inline:.82rem;font-size:.68rem;font-weight:500;line-height:1;display:inline-flex}.tech-pill:hover{border-color:color-mix(in srgb, var(--brand) 22%, var(--line));background:color-mix(in srgb, var(--surface) 96%, transparent);color:var(--text);transform:translateY(-1px)}@media (width<=640px){.project{gap:1.2rem}.tech-list{gap:.45rem}.tech-pill{min-height:1.9rem;padding-inline:.72rem}}.skill{isolation:isolate;justify-content:flex-start;min-height:100%;position:relative}.skill:before{content:"";z-index:-1;pointer-events:none;background:radial-gradient(120% 120% at 100% 0%, color-mix(in srgb, var(--brand) 5%, transparent), transparent 56%);opacity:0;transition:opacity var(--transition);position:absolute;inset:0}.skill:hover:before{opacity:1}.skill .content-stack{gap:.72rem}.skill .content-description{max-width:50ch}.experience-timeline{isolation:isolate;gap:clamp(2rem,3vw,2.8rem);display:grid;position:relative}.experience-timeline:before{content:"";inset-block:.55rem;background:linear-gradient(to bottom, transparent, color-mix(in srgb, var(--line) 88%, transparent), transparent);opacity:.62;width:1px;position:absolute;left:.31rem}.experience-entry{padding-left:clamp(1.8rem,2vw,2.1rem);position:relative}.experience-marker{aspect-ratio:1;background:var(--surface);border:2px solid color-mix(in srgb, var(--brand) 74%, white);width:10px;box-shadow:0 0 0 4px var(--bg-base), 0 2px 8px #1018200a;transition:transform var(--transition-fast), border-color var(--transition-fast), box-shadow var(--transition-fast);border-radius:50%;position:absolute;top:.42rem;left:0}.experience-entry:hover .experience-marker{border-color:color-mix(in srgb, var(--brand-strong) 86%, white);box-shadow:0 0 0 4px var(--bg-base), 0 4px 12px #1018200f;transform:scale(1.06)}.experience-content{gap:.52rem;max-width:58ch;display:grid}.experience-role{letter-spacing:-.02em;font-size:clamp(1.02rem,1.2vw,1.14rem);line-height:1.28}.experience-meta{flex-wrap:wrap;align-items:baseline;gap:.45rem .9rem;display:flex}.experience-company{color:var(--text);font-size:.95rem;font-weight:500}.experience-period{letter-spacing:.012em;color:var(--text-muted);font-size:.82rem;line-height:1.55}@media (width<=640px){.experience-timeline{gap:1.9rem}.experience-entry{padding-left:1.7rem}}.contact{font-style:normal}.contact-list{gap:clamp(1rem,2vw,1.45rem);width:min(100%,640px);display:grid}.contact-entry{border-bottom:1px solid color-mix(in srgb, var(--line) 80%, transparent);transition:border-color var(--transition-fast);grid-template-columns:minmax(112px,140px) 1fr;align-items:start;gap:.42rem 1.6rem;padding-bottom:1rem;display:grid;position:relative}.contact-entry:last-child{border-bottom:none;padding-bottom:0}.contact-entry:hover{border-color:color-mix(in srgb, var(--brand) 16%, var(--line))}.contact-label{letter-spacing:.13em;text-transform:uppercase;color:var(--text-muted);padding-top:.12rem;font-size:.64rem;font-weight:600}.contact-value,.contact-link{color:var(--text);word-break:break-word;font-size:.95rem;line-height:1.76}.contact-link{color:var(--brand-strong);transition:opacity var(--transition-fast), color var(--transition-fast);text-decoration:none}.contact-link:hover{opacity:.8}@media (width<=640px){.contact-entry{grid-template-columns:1fr;gap:.32rem}.contact-label{padding-top:0}}.footer{background:linear-gradient(to top, color-mix(in srgb, var(--surface) 42%, transparent), transparent 74%);margin-top:clamp(4.75rem,8vw,7rem);padding-block:clamp(3rem,5vw,4.25rem);position:relative;overflow:clip}.footer:before{content:"";background:linear-gradient(to right, transparent, var(--line) 18%, var(--line) 82%, transparent);opacity:.7;width:min(720px,72%);height:1px;margin:0 auto clamp(2.5rem,4vw,3rem);display:block}.footer:after{content:"";pointer-events:none;background:radial-gradient(circle, color-mix(in srgb, var(--brand) 8%, transparent), transparent 74%);opacity:.42;filter:blur(28px);width:min(48rem,90vw);height:18rem;position:absolute;inset:auto 50% -10rem;transform:translate(-50%)}.footer-inner{z-index:1;text-align:center;justify-items:center;gap:.9rem;width:min(100%,620px);margin-inline:auto;display:grid;position:relative}.footer-message{max-width:38ch;color:var(--text);font-size:.95rem;font-weight:500;line-height:1.72}.footer-dedication{letter-spacing:.01em;max-width:56ch;color:var(--text-muted);font-size:.84rem;line-height:1.8}.footer-credit{letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);opacity:.5;margin-top:.45rem;font-size:.68rem}@media (width<=640px){.footer{margin-top:clamp(3.5rem,10vw,5rem);padding-block:clamp(2.4rem,7vw,3.2rem)}.footer-inner{gap:.78rem}.footer-message{font-size:.91rem}.footer-dedication{font-size:.82rem}.footer-credit{font-size:.64rem}}.app-shell{flex-direction:column;min-height:100vh;display:flex}.site-main{flex:1;width:100%}.section{padding-block:clamp(4.25rem,7vw,6.25rem);position:relative}.section:first-of-type{padding-top:clamp(3rem,5vw,4.5rem)}.section:last-of-type{padding-bottom:clamp(4.5rem,8vw,6.5rem)}.container{width:min(1120px,100% - 2.5rem);margin-inline:auto}@media (width<=768px){.section{padding-block:clamp(3rem,8vw,4.5rem)}.section:first-of-type{padding-top:clamp(2.5rem,7vw,3.4rem)}.section:last-of-type{padding-bottom:clamp(3.25rem,8vw,4.75rem)}.container{width:min(1120px,100% - 1.5rem)}}*,:before,:after{box-sizing:border-box}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{letter-spacing:.01em;text-rendering:optimizelegibility;-webkit-tap-highlight-color:transparent;background:var(--bg-base);min-width:320px;min-height:100vh;color:var(--text);accent-color:var(--brand);transition:background-color var(--transition), color var(--transition);margin:0;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,sans-serif;font-size:1rem;line-height:1.7;overflow-x:clip}#root{isolation:isolate;min-height:100vh}img,svg,video,canvas{max-width:100%;display:block}img{height:auto}button,input,textarea,select{font:inherit}a{color:inherit;text-decoration:none}button{color:inherit;cursor:pointer;background:0 0;border:0;padding:0}::selection{background:color-mix(in srgb, var(--brand) 22%, transparent);color:var(--text-strong)}.skip-link{z-index:1000;border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--surface-strong);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);color:var(--text-strong);transition:transform var(--transition-fast), box-shadow var(--transition-fast), border-color var(--transition-fast);padding:.72rem 1rem;font-weight:600;position:fixed;top:1rem;left:1rem;transform:translateY(-140%)}.skip-link:focus{transform:translateY(0)}.skip-link:focus-visible{box-shadow:var(--focus-ring);outline:none}h1,h2,h3,h4{color:var(--text-strong);letter-spacing:-.035em;text-wrap:balance;margin:0;font-weight:620;line-height:1.04}h1{font-size:clamp(2.8rem,4vw,3.5rem)}h2{font-size:clamp(2rem,3vw,2.5rem)}h3{font-size:clamp(1.02rem,1.2vw,1.1rem);line-height:1.34}p{max-width:65ch;color:var(--text);text-wrap:pretty;margin:0;line-height:1.72}ul,ol{margin:0;padding:0;list-style:none}.card{padding:clamp(1.35rem, 2vw, var(--space-md));border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--surface);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);box-shadow:var(--shadow-sm);transition:transform var(--transition), border-color var(--transition), background-color var(--transition), box-shadow var(--transition);flex-direction:column;display:flex;position:relative;overflow:hidden}.card:hover{border-color:color-mix(in srgb, var(--brand-strong) 12%, var(--line));box-shadow:var(--shadow-md);transform:translateY(-2px)}.card:active{box-shadow:var(--shadow-sm);transform:translateY(0)}a[href]{transition:opacity var(--transition-fast), color var(--transition-fast)}a[href]:hover{opacity:.86}a[href]:focus-visible{box-shadow:var(--focus-ring);border-radius:.35rem;outline:none}.section-title{margin-bottom:.55rem}.section-intro{max-width:60ch;color:var(--text-muted);margin-bottom:clamp(1.65rem,2.5vw,2.1rem)}.section-text{gap:1rem;display:grid}.section-lead{max-width:60ch;color:var(--text-strong);font-size:clamp(1.04rem,1.25vw,1.16rem);font-weight:500;line-height:1.75}.content-grid{grid-template-columns:repeat(auto-fit,minmax(min(320px,100%),1fr));align-items:stretch;gap:clamp(1.35rem,2vw,1.9rem);display:grid}.content-card{flex-direction:column;gap:1.15rem;min-height:100%;display:flex}.content-stack{gap:.55rem;display:grid}.content-title{color:var(--text-strong);letter-spacing:-.015em;font-weight:600;line-height:1.34}.content-description{font-size:.94rem;line-height:1.72}.fade-up{opacity:0;will-change:transform, opacity;animation:fade-up .8s var(--ease) forwards;transform:translateY(10px)}.delay-1{animation-delay:40ms}.delay-2{animation-delay:80ms}.delay-3{animation-delay:.12s}.delay-4{animation-delay:.16s}.delay-5{animation-delay:.2s}.delay-6{animation-delay:.24s}@keyframes fade-up{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translate(0,0)}}@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}.fade-up{opacity:1!important;transform:none!important}}
