:root{--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:24px;--space-6:32px;--space-7:48px;--space-8:64px;--space-9:96px;--max-width:66rem;--content-padding:clamp(var(--space-5),5vw,var(--space-8));--section-gap:clamp(3.75rem,8vw,6rem);--nav-height:60px;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--font-serif:"Podkova","Iowan Old Style",Georgia,serif;--font-mono:"Atkinson Hyperlegible Mono",ui-monospace,"SF Mono",Menlo,monospace;--font-sans:"Atkinson Hyperlegible Next",system-ui,sans-serif;--ease-out:cubic-bezier(.2,.7,.2,1);--t-fast:.15s var(--ease-out);--t-base:.26s var(--ease-out);--t-slow:.42s var(--ease-out)}*{box-sizing:border-box;text-rendering:geometricPrecision;-webkit-text-size-adjust:100%;-moz-text-size-adjust:100%;text-size-adjust:100%}html{scroll-behavior:smooth;-webkit-tap-highlight-color:transparent;font-size:17px}body{font-family:var(--font-sans);letter-spacing:.005em;word-wrap:break-word;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background-color var(--t-slow),color var(--t-slow);margin:0;font-size:1rem;font-weight:400;line-height:1.7}body:before{content:"";z-index:0;pointer-events:none;opacity:var(--grain-opacity);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");position:fixed;inset:0}main{z-index:1;display:block;position:relative}h1,h2,h3,h4,h5,h6{margin:0;line-height:1.15}h1{font-family:var(--font-serif);letter-spacing:-.02em;color:var(--text-strong);text-wrap:balance;font-size:clamp(2.2rem,5vw,3rem);font-weight:700;line-height:1.06}h2{align-items:center;gap:var(--space-4);counter-increment:section;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.24em;color:var(--text-muted);margin-bottom:var(--space-6);font-size:.72rem;font-weight:400;display:flex}h2:before{content:counter(section,decimal-leading-zero);color:var(--accent);letter-spacing:.05em;font-variant-numeric:tabular-nums;font-size:.78rem}h2:after{content:"";background:var(--line);flex:1;height:1px}h3{font-family:var(--font-serif);letter-spacing:-.01em;color:var(--text-strong);text-wrap:balance;font-size:1.22rem;font-weight:700}p{text-wrap:pretty;margin:0}a{cursor:pointer;color:var(--accent);transition:color var(--t-fast);text-decoration:none}::selection{background:var(--accent);color:var(--bg)}:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:var(--radius-sm)}.resume{counter-reset:section;max-width:var(--max-width);padding:calc(var(--nav-height) + var(--space-8))var(--content-padding)var(--space-8);gap:var(--section-gap);flex-direction:column;margin:0 auto;display:flex}.section{scroll-margin-top:calc(var(--nav-height) + var(--space-5))}.fixed-nav{z-index:1000;background:var(--nav-bg-solid);border-bottom:1px solid var(--line);transition:background-color var(--t-slow),border-color var(--t-slow);position:fixed;top:0;left:0;right:0}@supports ((-webkit-backdrop-filter:blur(1px)) or (backdrop-filter:blur(1px))){.fixed-nav{background:var(--nav-bg);-webkit-backdrop-filter:blur(20px)saturate(150%);backdrop-filter:blur(20px)saturate(150%)}}.nav-bar{justify-content:space-between;align-items:center;gap:var(--space-4);max-width:var(--max-width);padding:0 var(--content-padding);height:var(--nav-height);margin:0 auto;display:flex}.nav-links{align-items:center;gap:clamp(var(--space-2),2vw,var(--space-5));scrollbar-width:none;display:flex}.nav-links::-webkit-scrollbar{display:none}.nav-link{appearance:none;cursor:pointer;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.16em;white-space:nowrap;padding:var(--space-2)2px;color:var(--text-muted);transition:color var(--t-fast);background:0 0;border:none;font-size:.72rem;font-weight:400;position:relative}.nav-link:after{content:"";background:var(--accent);width:0;height:2px;transition:width var(--t-base);border-radius:2px;position:absolute;bottom:-1px;left:50%;transform:translate(-50%)}.nav-link.active{color:var(--text-strong)}.nav-link.active:after{width:16px}@media (hover:hover) and (pointer:fine){.nav-link:hover{color:var(--text-strong)}}.theme-toggle{appearance:none;border-radius:var(--radius-sm);cursor:pointer;width:38px;height:38px;transition:background-color var(--t-fast),border-color var(--t-fast);background:0 0;border:1px solid #0000;flex-shrink:0;justify-content:center;align-items:center;display:flex}.theme-toggle img{opacity:.85;width:20px;height:20px;display:block}@media (hover:hover) and (pointer:fine){.theme-toggle:hover{background-color:var(--surface-2);border-color:var(--line)}}.hero{gap:var(--space-6);padding-top:var(--space-4);flex-direction:column;display:flex;position:relative}.hero:before{content:"";background:radial-gradient(closest-side,var(--glow)0%,transparent 100%);z-index:-1;pointer-events:none;width:min(100%,820px);height:480px;position:absolute;top:-170px;left:50%;transform:translate(-50%)}.header-section{gap:var(--space-4);flex-direction:column;display:flex}.hero-eyebrow{align-items:center;gap:var(--space-3);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.24em;color:var(--accent);font-size:.74rem;display:inline-flex}.hero-eyebrow:before{content:"";background:var(--accent);opacity:.7;width:28px;height:1px}.hero-meta{font-family:var(--font-mono);letter-spacing:.01em;color:var(--text-muted);font-size:.92rem}.about-block{align-items:center;gap:clamp(var(--space-5),4vw,var(--space-7));grid-template-columns:auto 1fr;display:grid}.about-photo-frame{flex-shrink:0;width:158px;height:158px;position:relative}.about-photo-button{appearance:none;z-index:1;border-radius:var(--radius-lg);cursor:zoom-in;background:0 0;border:0;width:100%;height:100%;padding:0;display:block;position:relative}.about-photo-frame:before{content:"";border:1px solid var(--accent);border-radius:var(--radius-lg);opacity:.35;transition:transform var(--t-base),opacity var(--t-base);z-index:0;position:absolute;inset:0;transform:translate(10px,10px)}.about-photo{z-index:1;border-radius:var(--radius-lg);object-fit:cover;cursor:zoom-in;border:1px solid var(--line-strong);background:var(--surface);width:100%;height:100%;box-shadow:0 10px 30px var(--shadow);transition:border-color var(--t-base),transform var(--t-base);position:relative}@media (hover:hover) and (pointer:fine){.about-photo-frame:hover:before{opacity:.6;transform:translate(14px,14px)}.about-photo-frame:hover .about-photo,.about-photo-button:focus-visible .about-photo{border-color:var(--accent);transform:translate(-2px,-2px)}}.about-text{gap:var(--space-5);flex-direction:column;display:flex}.about-text p{color:var(--text);max-width:46ch;font-size:1.14rem;line-height:1.65}.about-text p .accent{color:var(--text-strong);text-decoration:underline;-webkit-text-decoration-color:var(--accent);text-decoration-color:var(--accent);text-underline-offset:4px;text-decoration-thickness:2px}.hero-links{gap:var(--space-2)var(--space-5);flex-wrap:wrap;display:flex}.hero-link{font-family:var(--font-mono);letter-spacing:.02em;color:var(--text-muted);transition:color var(--t-fast);font-size:.85rem;position:relative}.hero-link:after{content:"";background:var(--accent);height:1px;transition:right var(--t-base);position:absolute;bottom:-3px;left:0;right:100%}@media (hover:hover) and (pointer:fine){.hero-link:hover{color:var(--text-strong)}.hero-link:hover:after{right:0}}.image-overlay{background:var(--overlay);-webkit-backdrop-filter:blur(8px);z-index:2000;animation:fadeIn var(--t-base);justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.image-overlay:focus-visible{outline:none}.image-overlay img{border-radius:var(--radius-md);max-width:90%;max-height:90%;box-shadow:0 30px 80px #00000080}.close-button{top:var(--space-5);right:var(--space-5);color:var(--text-strong);cursor:pointer;padding:var(--space-2);background:0 0;border:none;font-size:2rem;line-height:1;position:absolute}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.skills-categories{gap:var(--space-5);flex-direction:column;display:flex}.skill-group{align-items:baseline;gap:var(--space-4);padding-bottom:var(--space-5);border-bottom:1px solid var(--line);grid-template-columns:11rem 1fr;display:grid}.skill-group:last-child{border-bottom:none;padding-bottom:0}.skill-group-label{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.16em;color:var(--text-muted);white-space:nowrap;font-size:.74rem;font-weight:400}.skills-grid{gap:var(--space-2);flex-wrap:wrap;display:flex}.chip{font-family:var(--font-mono);border:1px solid var(--line-strong);border-radius:var(--radius-sm);background-color:var(--surface);color:var(--text);transition:border-color var(--t-fast),color var(--t-fast),background-color var(--t-fast),transform var(--t-fast),box-shadow var(--t-fast);-webkit-user-select:none;user-select:none;cursor:default;align-items:center;padding:5px 11px;font-size:.82rem;display:inline-flex}@media (hover:hover) and (pointer:fine){.chip:hover{border-color:var(--accent);color:var(--text-strong);background-color:var(--surface-2);box-shadow:0 2px 8px var(--shadow);transform:translateY(-1px)}}.experience-list{gap:var(--space-7);flex-direction:column;display:flex}.experience-card{padding-left:var(--space-6);border-left:1px solid var(--line-strong);position:relative}.experience-card:before{content:"";background:var(--accent);border-radius:50%;width:9px;height:9px;position:absolute;top:7px;left:-5px}.experience-card:first-child:before{box-shadow:0 0 0 4px var(--glow)}.experience-title{margin-bottom:var(--space-2)}.experience-meta{font-family:var(--font-mono);color:var(--text-muted);margin-bottom:var(--space-4);letter-spacing:.01em;font-size:.82rem}.experience-company{color:var(--text)}.experience-card ul{gap:var(--space-3);flex-direction:column;max-width:70ch;margin:0;padding:0;list-style:none;display:flex}.experience-card li{padding-left:var(--space-5);color:var(--text);line-height:1.6;position:relative}.experience-card li:before{content:"";background:var(--accent);border-radius:1.5px;width:5px;height:5px;position:absolute;top:.6em;left:0}.education-list,.certification-list{gap:var(--space-6);flex-direction:column;display:flex}.education-card,.certification-card{padding-left:var(--space-6);border-left:1px solid var(--line-strong);position:relative}.education-card:before,.certification-card:before{content:"";background:var(--accent);border-radius:50%;width:9px;height:9px;position:absolute;top:7px;left:-5px}.education-title,.certification-title{margin-bottom:var(--space-1)}.education-meta,.certification-meta{font-family:var(--font-mono);color:var(--text-muted);letter-spacing:.01em;font-size:.82rem}.certification-title a{color:var(--text-strong);transition:color var(--t-fast)}@media (hover:hover) and (pointer:fine){.certification-title a:hover{color:var(--accent)}}.projects-grid{gap:var(--space-4);grid-template-columns:repeat(2,1fr);display:grid}.project-card{padding:var(--space-5);background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-md);color:inherit;transition:border-color var(--t-base),transform var(--t-base),box-shadow var(--t-base),background-color var(--t-base);flex-direction:column;display:flex;position:relative;overflow:hidden}.project-card:before{content:"";background:var(--accent);transform-origin:0;height:2px;transition:transform var(--t-base);position:absolute;top:0;left:0;right:0;transform:scaleX(0)}.project-card:first-child{grid-column:1/-1}.project-card:first-child .project-card-name{font-size:1.45rem}.project-card:first-child .project-card-desc{max-width:60ch;font-size:.95rem}@media (hover:hover) and (pointer:fine){.project-card:hover{border-color:var(--line-strong);box-shadow:0 14px 34px var(--shadow);color:inherit;transform:translateY(-3px)}.project-card:hover:before{transform:scaleX(1)}}.project-card-header{justify-content:space-between;align-items:baseline;gap:var(--space-3);margin-bottom:var(--space-3);display:flex}.project-card-name{font-family:var(--font-serif);color:var(--text-strong);font-size:1.18rem;font-weight:700}.project-card-title-link{color:inherit;transition:color var(--t-fast)}.project-card-title-link:visited{color:inherit}.project-card-arrow{font-family:var(--font-mono);color:var(--text-faint);transition:color var(--t-base),transform var(--t-base);flex-shrink:0;font-size:.95rem}.project-card-arrow:visited{color:var(--text-faint)}@media (hover:hover) and (pointer:fine){.project-card:hover .project-card-title-link{color:var(--accent)}.project-card:hover .project-card-arrow{color:var(--accent);transform:translate(3px,-3px)}}.project-card-desc{color:var(--text-muted);flex-grow:1;font-size:.9rem;line-height:1.6}.project-card-links{gap:var(--space-3);margin-top:var(--space-4);font-family:var(--font-mono);flex-wrap:wrap;font-size:.8rem;display:flex}.project-card-link{color:var(--accent);letter-spacing:.01em}.project-card-link:before{content:"↗ ";opacity:.7}@media (hover:hover) and (pointer:fine){.project-card-link:hover{text-underline-offset:3px;text-decoration:underline}}.languages-grid{gap:var(--space-2);flex-wrap:wrap;display:flex}.language-item{align-items:baseline;gap:var(--space-2);padding:var(--space-2)var(--space-4);background:var(--surface);border-radius:var(--radius-sm);border:1px solid var(--line);font-family:var(--font-mono);color:var(--text);font-size:.85rem;display:inline-flex}.language-level{color:var(--text-muted);font-size:.72rem}.contact-intro{max-width:58ch;margin-top:calc(var(--space-6)*-.45);margin-bottom:var(--space-5);color:var(--text-muted)}.contact-grid{gap:var(--space-3);flex-wrap:wrap;display:flex}.contact-card{align-items:center;gap:var(--space-2);padding:var(--space-3)var(--space-5);border:1px solid var(--line-strong);border-radius:var(--radius-sm);color:var(--text);font-family:var(--font-mono);letter-spacing:.02em;transition:border-color var(--t-fast),color var(--t-fast),background-color var(--t-fast),transform var(--t-fast);background-color:#0000;font-size:.85rem;display:inline-flex}.contact-card:visited{color:var(--text)}.contact-card.contact-resume{border-color:var(--accent);background-color:var(--accent);color:var(--bg)}@media (hover:hover) and (pointer:fine){.contact-card:hover,.contact-card:visited:hover{border-color:var(--accent);color:var(--text-strong);background-color:var(--surface);transform:translateY(-2px)}.contact-card.contact-resume:hover{background-color:var(--accent);color:var(--bg);box-shadow:0 8px 22px var(--glow)}}.footer-section{font-family:var(--font-mono);text-align:center;padding-top:var(--space-6);border-top:1px solid var(--line);color:var(--text-muted);letter-spacing:.02em;font-size:.78rem;line-height:1.8}.footer-section p{margin:2px 0}.footer-badge{color:var(--text-muted)}.footer-badge:before{content:"● ";color:var(--accent);vertical-align:middle;font-size:.7em}.footer-section a{color:var(--text-muted);transition:color var(--t-fast)}@media (hover:hover) and (pointer:fine){.footer-section a:hover{color:var(--accent)}}.scroll-to-top{bottom:var(--space-6);right:var(--space-6);z-index:1000;background-color:var(--surface);border:1px solid var(--line-strong);border-radius:var(--radius-sm);box-shadow:0 6px 20px var(--shadow);transition:border-color var(--t-base),transform var(--t-base),box-shadow var(--t-base),opacity var(--t-base);opacity:.85;cursor:pointer;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;justify-content:center;align-items:center;width:42px;height:42px;padding:0;display:flex;position:fixed}@media (hover:hover) and (pointer:fine){.scroll-to-top:hover{opacity:1;border-color:var(--accent);box-shadow:0 10px 26px var(--shadow);transform:translateY(-2px)}}.scroll-to-top img{opacity:.85;width:22px;height:22px;display:block}.scroll-to-top.hidden{display:none}@keyframes rise{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}.reveal{opacity:0;animation:rise .75s var(--ease-out)both}.header-section .hero-eyebrow.reveal{animation-delay:40ms}.header-section h1.reveal{animation-delay:.12s}.header-section .hero-meta.reveal{animation-delay:.2s}.about-photo-button.reveal{animation-delay:.3s}.about-text.reveal{animation-delay:.38s}@supports (animation-timeline:view()){@media (prefers-reduced-motion:no-preference){.resume>section{opacity:0;animation:linear both rise;animation-timeline:view();animation-range:entry entry 32%}}}@media (max-width:720px){.about-block{justify-items:start;gap:var(--space-6);grid-template-columns:1fr}.skill-group{gap:var(--space-3);grid-template-columns:1fr}.projects-grid{grid-template-columns:1fr}.project-card:first-child .project-card-name{font-size:1.28rem}}@media (max-width:560px){.nav-bar{gap:var(--space-3);padding:0 var(--space-3)}.nav-links{gap:var(--space-3)}.nav-link{letter-spacing:.07em;font-size:.7rem}}@media (max-width:490px){html{font-size:15px}.about-photo-frame{width:132px;height:132px}}@media (max-width:430px){.nav-bar{gap:var(--space-2);padding:0 var(--space-2)}.nav-links{gap:var(--space-2);-webkit-overflow-scrolling:touch;overflow-x:auto}.nav-link{letter-spacing:.03em;font-size:.7rem}.theme-toggle{width:32px;height:32px}.theme-toggle img{width:18px;height:18px}}@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}.reveal{opacity:1;animation:none}*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}@media print{body:before,.hero:before,.fixed-nav,.scroll-to-top,.contact-card.contact-resume{display:none!important}.resume{padding-top:0}.reveal,.resume>section{opacity:1!important;animation:none!important}}