.site-header{background:linear-gradient(to bottom, color-mix(in srgb, var(--surface) 60%, transparent), transparent 70%);width:100%;padding-block:clamp(5rem,9vw,7.5rem);position:relative}.site-header:after{content:"";background:linear-gradient(to right, transparent, var(--line), transparent);opacity:.45;width:min(68%,760px);height:1px;margin:clamp(2.75rem,5vw,3.5rem) auto 0;display:block}.header-inner{text-align:center;align-items:center;gap:clamp(2.25rem,4vw,3rem)}.header-avatar{aspect-ratio:1;object-fit:cover;background:var(--surface);width:clamp(120px,14vw,150px);box-shadow:0 0 0 1px var(--line), 0 10px 28px #1018200f;transition:transform var(--transition-fast), box-shadow var(--transition-fast);border-radius:50%;position:relative}.header-avatar:after{content:"";background:linear-gradient(135deg, color-mix(in srgb, var(--brand) 35%, transparent), transparent 60%);opacity:.25;pointer-events:none;border-radius:50%;position:absolute;inset:-2px}.header-avatar:hover{box-shadow:0 0 0 1px var(--line), 0 18px 44px #10182014;transform:translateY(-3px)}.header-intro{flex-direction:column;align-items:center;gap:.65rem;display:flex}.header-title{letter-spacing:-.03em;color:var(--text-strong);font-size:clamp(2.6rem,5vw,3.2rem);font-weight:600;line-height:1.04}.header-tagline{max-width:36ch;color:var(--text-muted);font-size:1.05rem;line-height:1.7}@media (width<=640px){.site-header{padding-block:clamp(4rem,12vw,6rem)}.header-inner{gap:1.75rem}.header-tagline{max-width:28ch;font-size:1rem}}.projects-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:clamp(1.5rem,2.5vw,2.25rem);display:grid}.project{flex-direction:column;justify-content:space-between;gap:1.4rem;min-height:100%;display:flex;position:relative;overflow:hidden}.project:before{content:"";background:radial-gradient(120px circle at 20% 0%, color-mix(in srgb, var(--brand) 12%, transparent), transparent 70%);opacity:0;transition:opacity var(--transition);position:absolute;inset:0}.project:hover:before{opacity:1}.project-content{flex-direction:column;gap:.6rem;display:flex}.project-title{color:var(--text-strong);font-size:1.12rem;font-weight:600;line-height:1.25}.project-description{color:var(--text);font-size:.94rem;line-height:1.7}.project-tech{flex-wrap:wrap;gap:.45rem;display:flex}.project-tech li{background:color-mix(in srgb, var(--surface-alt) 85%, transparent);color:var(--text-muted);border:1px solid var(--line);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);transition:background var(--transition-fast), border-color var(--transition-fast), transform var(--transition-fast);border-radius:999px;padding:.32rem .7rem;font-size:.7rem}.project-tech li:hover{background:var(--surface);border-color:color-mix(in srgb, var(--brand) 40%, var(--line));transform:translateY(-1px)}.skills-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:clamp(1.5rem,2.5vw,2.25rem);display:grid}.skill{flex-direction:column;gap:.75rem;min-height:100%;display:flex;position:relative;overflow:hidden}.skill:before{content:"";background:radial-gradient(100px circle at 0% 0%, color-mix(in srgb, var(--brand) 10%, transparent), transparent 70%);opacity:0;transition:opacity var(--transition);position:absolute;inset:0}.skill:hover:before{opacity:1}.skill-title{color:var(--text-strong);font-size:1.08rem;font-weight:600;line-height:1.3}.skill-description{color:var(--text);font-size:.94rem;line-height:1.7}.experience-timeline{gap:clamp(2rem,3.5vw,3rem);margin:0;padding:0;list-style:none;display:grid;position:relative}.experience-timeline:before{content:"";background:linear-gradient(to bottom, transparent, var(--line), transparent);opacity:.7;width:1px;position:absolute;top:.6rem;bottom:.6rem;left:5px}.experience-entry{padding-left:1.75rem;position:relative}.experience-marker{background:var(--surface);border:2px solid var(--brand);width:10px;height:10px;box-shadow:0 0 0 3px var(--bg-base), 0 2px 6px #10182014;transition:transform var(--transition-fast), box-shadow var(--transition-fast);border-radius:50%;position:absolute;top:.5rem;left:0}.experience-entry:hover .experience-marker{box-shadow:0 0 0 3px var(--bg-base), 0 6px 14px #1018201f;transform:scale(1.1)}.experience-content{flex-direction:column;gap:.45rem;max-width:58ch;display:flex}.experience-role{letter-spacing:-.01em;color:var(--text-strong);font-size:1.12rem;font-weight:600;line-height:1.3}.experience-meta{flex-wrap:wrap;align-items:baseline;gap:.6rem .9rem;display:flex}.experience-company{color:var(--text);font-size:.94rem;font-weight:500}.experience-period{color:var(--text-muted);font-size:.85rem}.contact-grid{font-style:normal}.contact-grid ul{gap:clamp(1.25rem,2.5vw,1.75rem);max-width:640px;margin:0;padding:0;list-style:none;display:grid}.contact-entry{border-bottom:1px solid color-mix(in srgb, var(--line) 85%, transparent);transition:transform var(--transition-fast), border-color var(--transition-fast);grid-template-columns:minmax(110px,140px) 1fr;align-items:baseline;column-gap:1.5rem;padding-bottom:1.1rem;display:grid;position:relative;overflow:hidden}.contact-entry:before{content:"";background:radial-gradient(120px circle at 0% 50%, color-mix(in srgb, var(--brand) 10%, transparent), transparent 70%);opacity:0;transition:opacity var(--transition);position:absolute;inset:0}.contact-entry:hover:before{opacity:1}.contact-entry:hover{border-color:color-mix(in srgb, var(--brand) 25%, var(--line));transform:translateY(-1px)}.contact-entry:last-child{border-bottom:none}.contact-label{letter-spacing:.14em;text-transform:uppercase;color:var(--text-muted);font-size:.66rem;font-weight:600}.contact-value{color:var(--text);word-break:break-word;font-size:.97rem;line-height:1.6}.contact-link{color:var(--brand);transition:color var(--transition-fast), opacity var(--transition-fast);font-size:.97rem;font-weight:500;text-decoration:none;position:relative}.contact-link:after{content:"";transform-origin:0;width:100%;height:1px;transition:transform var(--transition-fast);background:currentColor;position:absolute;bottom:-2px;left:0;transform:scaleX(0)}.contact-link:hover:after,.contact-link:focus-visible:after{transform:scaleX(1)}.contact-link:hover,.contact-link:focus-visible{color:var(--brand-strong);opacity:.95}.contact-link:focus-visible{outline:2px solid var(--brand);outline-offset:4px;border-radius:4px}@media (width<=640px){.contact-entry{grid-template-columns:1fr;row-gap:.25rem}}.footer{background:linear-gradient(to top, color-mix(in srgb, var(--surface) 60%, transparent), transparent 70%);margin-top:clamp(4rem,8vw,6rem);padding-block:clamp(2.75rem,5vw,3.75rem);position:relative}.footer:before{content:"";background:linear-gradient(to right, transparent, color-mix(in srgb, var(--line) 85%, transparent), transparent);opacity:.45;width:min(68%,760px);height:1px;margin:0 auto clamp(2rem,4vw,2.75rem);display:block}.footer-inner{text-align:center;flex-direction:column;align-items:center;gap:.75rem;max-width:640px;display:flex}.footer-message{max-width:38ch;color:var(--text);font-size:.95rem;font-weight:500;line-height:1.65}.footer-dedication{max-width:52ch;color:var(--text-muted);font-size:.88rem;line-height:1.7}.footer-credit{letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);opacity:.55;margin-top:.9rem;font-size:.72rem;line-height:1.4}@media (width<=640px){.footer{margin-top:clamp(3.5rem,10vw,5rem);padding-block:clamp(2.25rem,7vw,3.25rem)}.footer-inner{gap:.7rem}.footer-message{font-size:.92rem}.footer-dedication{font-size:.85rem}.footer-credit{letter-spacing:.08em;font-size:.68rem}}.site-main{flex-direction:column;flex:1;display:flex}.section{justify-content:center;width:100%;padding-block:clamp(4.5rem,8vw,7.5rem);display:flex}.section:first-of-type{padding-top:clamp(3.5rem,6vw,5rem)}.section:last-of-type{padding-bottom:clamp(4.5rem,8vw,7rem)}.container{flex-direction:column;gap:clamp(1.5rem,2.5vw,2.25rem);width:100%;max-width:1120px;margin-inline:auto;padding-inline:clamp(1.5rem,4vw,3rem);display:flex}@media (width<=768px){.section{padding-block:clamp(3.25rem,7vw,4.75rem)}.section:first-of-type{padding-top:clamp(2.75rem,6vw,3.5rem)}.section:last-of-type{padding-bottom:clamp(3.5rem,7vw,5rem)}.container{padding-inline:clamp(1.1rem,5vw,1.5rem)}}*,:before,:after{box-sizing:border-box}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{background:var(--bg-base);min-width:320px;min-height:100vh;color:var(--text);text-rendering:optimizelegibility;transition:background-color var(--transition), color var(--transition);margin:0;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,sans-serif;line-height:1.6}#root{isolation:isolate;flex-direction:column;min-height:100vh;display:flex}::selection{background:color-mix(in srgb, var(--brand) 28%, transparent);color:var(--text-strong)}img,svg,video,canvas{max-width:100%;display:block}img{height:auto}button,input,textarea,select{font:inherit}.skip-link{z-index:1000;border:1px solid var(--line);border-radius:var(--radius-sm);box-shadow:var(--shadow-sm);background:var(--surface);color:var(--text-strong);transition:transform .2s ease, box-shadow var(--transition-fast), border-color var(--transition-fast);padding:.7rem .95rem;font-weight:600;line-height:1;text-decoration:none;position:absolute;top:1rem;left:1rem;transform:translateY(-140%)}.skip-link:focus{transform:translateY(0)}.skip-link:focus-visible{box-shadow:var(--focus-ring);outline:none}body{letter-spacing:.01em;font-size:1rem}h1,h2,h3,h4{color:var(--text-strong);letter-spacing:-.02em;text-wrap:balance;margin:0;font-weight:600;line-height:1.1}h1{font-size:clamp(2.8rem,4vw,3.5rem)}h2{font-size:clamp(2rem,3vw,2.5rem)}h3{font-size:clamp(1.05rem,1.2vw,1.15rem);line-height:1.2}p{max-width:65ch;color:var(--text);text-wrap:pretty;margin:0;line-height:1.65}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);box-shadow:var(--shadow-sm);transition:border-color var(--transition), background-color var(--transition), transform var(--transition), box-shadow var(--transition)}.card:hover{border-color:color-mix(in srgb, var(--brand-strong) 16%, var(--line));box-shadow:var(--shadow-md);transform:translateY(-3px)}.card:active{box-shadow:var(--shadow-sm);transform:translateY(-1px)}a{color:var(--brand-strong);text-underline-offset:.18em;transition:color var(--transition-fast), opacity var(--transition-fast);text-decoration:none}a:hover{opacity:.82}a:focus-visible{box-shadow:var(--focus-ring);border-radius:4px;outline:none}.section-title{color:var(--text-strong);letter-spacing:-.025em;font-size:clamp(2rem,3vw,2.5rem);font-weight:600;line-height:1.08}.section-intro{color:var(--text-muted);font-size:1rem;line-height:1.7}.section-text{flex-direction:column;gap:clamp(1rem,1.8vw,1.5rem);display:flex}.section-lead{max-width:60ch;color:var(--text-strong);font-size:clamp(1.08rem,1.35vw,1.22rem);font-weight:500;line-height:1.65}@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}*,:before,:after{transition:none!important;animation:none!important}.section{opacity:1!important;transform:none!important}}.section-animate{opacity:0;animation:section-fade-up .7s 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 section-fade-up{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
