:root{--text:#3f463f;--text-muted:#5f685f;--text-h:#1f2a20;--white:#fff;--bg:#f3efe5;--bg-alt:#e9e2d3;--surface:#ffffffe0;--surface-soft:#f6f3eb;--border:#d2c8b8;--code-bg:#ece5d6;--accent:#4f6f45;--accent-strong:#385931;--accent-border:#4f6f4561;--overlay:#f5f0e7a8;--success-border:#3859314d;--success-bg:#4f6f451a;--error-border:#ac583842;--error-bg:#ac58381a;--ambient-top:#f7f2e8;--ambient-mid:#efe7d7;--ambient-bottom:#e7ddcb;--grid-accent:#4f6f451f;--grid-neutral:#3d493c14;--shadow-color:#3943326b;--shadow:0 20px 40px -28px var(--shadow-color);--shadow-soft:0 16px 34px -24px #48523e52;--sans:Inter, system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;--heading:Inter, system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;font:17px/150% var(--sans);letter-spacing:.08px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;color:var(--text-muted);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:0 0}@media (width<=1024px){:root{font-size:16px}}*{box-sizing:border-box}body{min-height:100svh;color:var(--text);background:0 0;margin:0}#root{text-align:center;z-index:1;background:0 0;flex-direction:column;width:min(1280px,100%);min-height:100svh;margin:0 auto;display:flex;position:relative}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:600}h1{letter-spacing:-.03em;margin:20px 0;font-size:clamp(2.1rem,6vw,3.4rem)}h2{letter-spacing:-.02em;margin:0 0 8px;font-size:1.48rem;line-height:1.2}p{margin:0}code{font-family:var(--mono);color:var(--text-h);background:var(--code-bg);border-radius:6px;padding:4px 8px;font-size:.9rem;line-height:1.35;display:inline-flex}.portfolio{text-align:left;z-index:1;gap:0;padding:30px 28px 0;display:grid;position:relative}.page-section{min-height:100svh}.page-section:last-of-type{min-height:auto}.portfolio section p,.portfolio section li{line-height:1.7}.content-section{background:0 0;border-radius:18px;padding:28px;scroll-margin-top:90px}.hero{text-align:left;grid-template-columns:minmax(0,1.3fr) minmax(280px,.9fr);grid-template-areas:"aside main";align-items:center;gap:28px;padding-top:36px;padding-bottom:36px;display:grid}.hero-main{flex-direction:column;grid-area:main;align-items:flex-start;gap:12px;display:flex}.hero-actions{flex-wrap:wrap;justify-content:flex-start;gap:12px;margin-top:8px;display:flex}.hero h1{margin-top:6px}.hero-profile{max-width:62ch;margin:0}.hero-aside{grid-area:aside;justify-items:center;gap:18px;display:grid}.hero-headshot-wrap{justify-content:center;width:100%;margin:0;display:flex}.hero-headshot{aspect-ratio:1;object-fit:cover;border-radius:999px;width:min(100%,240px);height:auto;display:block}.hero-skill-panel{border:1px solid var(--border);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);width:100%;box-shadow:var(--shadow-soft);background:#ffffff5c;border-radius:22px;padding:18px 20px}.hero-skill-title{letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted);margin:0;font-size:.82rem;font-weight:700}.hero-headshot-placeholder{color:var(--text-muted);letter-spacing:.04em;background:0 0;justify-content:center;align-items:center;font-weight:600;display:inline-flex}.eyebrow{color:var(--accent);text-transform:uppercase;letter-spacing:.12em;font-size:.78rem;font-weight:600}.inline-section-title{margin-top:22px}.section-jump-nav{z-index:14;scrollbar-width:none;flex-wrap:nowrap;justify-content:flex-end;gap:8px;max-width:none;display:flex;position:fixed;top:16px;right:22px;overflow-x:auto}.section-jump-nav::-webkit-scrollbar{display:none}.section-jump-button{border:1px solid var(--accent-border);color:var(--text-h);font:inherit;cursor:pointer;background:0 0;border-radius:999px;padding:7px 12px;font-size:.84rem;transition:transform .2s,border-color .2s,box-shadow .2s,background-color .2s;animation:4.8s ease-in-out infinite buttonFloat}.section-jump-button:nth-child(2n){animation-delay:.3s}.section-jump-button:nth-child(3n){animation-delay:.55s}.section-jump-button:hover{border-color:var(--accent);box-shadow:var(--shadow-soft);background:#4f6f4514;transform:translateY(-2px)scale(1.01)}.section-jump-button:active{transform:translateY(0)}.section-jump-button:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.button{color:var(--white);background:var(--accent);border:1px solid var(--accent);border-radius:999px;margin-top:22px;padding:10px 16px;font-weight:600;text-decoration:none;transition:transform .18s,background-color .18s,border-color .18s;display:inline-block}.button:hover{background:var(--accent-strong);border-color:var(--accent-strong);transform:translateY(-1px)}.button:focus-visible{outline:2px solid var(--accent);outline-offset:2px}button.button{cursor:pointer;font:inherit}.button-secondary{color:var(--accent-strong);border-color:var(--accent-border);background:0 0}.button-secondary:hover{border-color:var(--accent);color:var(--accent-strong);background:#4f6f4512}.tags,.projects,.interests{margin:18px 0 0;padding:0;list-style:none}.tags{flex-wrap:wrap;justify-content:flex-start;gap:10px;display:flex}.tags li{color:var(--text-h);border:1px solid var(--border);background:0 0;border-radius:999px;padding:6px 12px;font-size:.88rem}.projects{gap:14px;display:grid}.projects li{background:0 0;border-radius:16px;padding:0;transition:transform .2s,box-shadow .2s,border-color .2s,background-color .2s}.projects h3{color:var(--text-h);margin:0 0 8px}.project-trigger{width:100%;color:inherit;text-align:left;cursor:pointer;font:inherit;background:0 0;border:0;border-radius:16px;justify-content:space-between;align-items:flex-start;gap:16px;padding:18px;transition:background-color .2s;display:flex}.projects li:hover{border-color:var(--accent-border);background:var(--surface-soft);box-shadow:var(--shadow-soft);transform:translateY(-2px)}.projects li:hover .project-trigger{background:#4f6f450f}.project-trigger:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.projects h3,.projects h4{color:var(--text-h);margin:0 0 8px}.projects h4{font-size:1.15rem;font-weight:600}.portfolio-page{flex-direction:column;justify-content:flex-start;gap:18px;min-height:100svh;padding-top:28px;padding-bottom:84px;display:flex}.portfolio-page-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:18px;display:flex}.portfolio-page-description{max-width:60ch;color:var(--text-muted);margin-top:8px}.content-switcher{flex-wrap:wrap;justify-content:flex-end;gap:10px;display:flex}.content-switcher-button{border:1px solid var(--border);color:var(--text-h);font:inherit;cursor:pointer;background:0 0;border-radius:999px;padding:8px 14px;transition:transform .18s,border-color .18s,background-color .18s}.content-switcher-button:hover{border-color:var(--accent-border);transform:translateY(-1px)}.content-switcher-button.is-active{background:var(--accent);color:var(--white);border-color:var(--accent)}.content-switcher-button:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.portfolio-page-body{flex:1;min-height:0;padding-bottom:32px;display:flex}.content-view-transition{width:100%;animation:.32s contentViewIn}.view-panel{flex-direction:column;gap:16px;width:100%;display:flex}.view-panel-compact{min-height:calc(100svh - 230px);padding-bottom:72px}.view-panel-compact .projects,.view-panel-compact .detail-groups,.view-panel-compact .interests{margin-bottom:0}.view-panel-heading{display:none}.detail-groups{gap:14px;margin-top:16px;display:grid}.detail-card{background:0 0;border-radius:14px;padding:0;transition:box-shadow .2s;overflow:hidden}.detail-card.is-open{box-shadow:none}.detail-card-trigger{width:100%;color:inherit;cursor:pointer;font:inherit;text-align:left;background:0 0;border:0;justify-content:space-between;align-items:center;gap:12px;padding:16px;display:flex}.detail-card h3{color:var(--text-h);margin:0;font-weight:500}.detail-card-icon{border:1px solid var(--border);width:1.8rem;height:1.8rem;color:var(--text-h);background:0 0;border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;font-size:1rem;line-height:1;transition:transform .26s;display:inline-flex}.detail-card-trigger:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.detail-card.is-open .detail-card-icon{transform:rotate(180deg)}.detail-card-content{opacity:0;max-height:0;transition:max-height .28s,opacity .24s}.detail-card.is-open .detail-card-content{opacity:1;max-height:920px}.detail-card ul{margin:0;padding:0 16px 16px 36px}.detail-card li+li,.interests li+li{margin-top:8px}.interests{gap:8px;display:grid}.interests li{padding-left:4px}.portfolio-footer{z-index:1;justify-content:flex-end;padding:20px 28px 28px;display:flex;position:relative}.footer-linkedin{color:var(--accent);align-items:center;gap:10px;font-weight:600;text-decoration:none;transition:transform .2s,color .2s;display:inline-flex}.footer-linkedin svg{fill:currentColor;width:1.2rem;height:1.2rem}.footer-linkedin:hover{color:var(--accent-strong);transform:translateY(-1px)}.footer-linkedin:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.project-modal-backdrop,.contact-modal-backdrop{background:var(--overlay);z-index:20;justify-content:center;align-items:center;padding:24px;animation:.24s modalBackdropIn;display:flex;position:fixed;inset:0}.contact-modal-backdrop{z-index:21}.project-modal,.contact-modal{background:var(--bg);width:min(920px,100%);max-height:90svh;color:var(--text);border-radius:18px;grid-template-rows:auto 1fr;animation:.34s cubic-bezier(.22,1,.36,1) modalIn;display:grid;overflow:hidden}.project-modal-backdrop.is-closing,.contact-modal-backdrop.is-closing{animation:.22s forwards modalBackdropOut}.project-modal.is-closing,.contact-modal.is-closing{animation:.22s forwards modalOut}.contact-modal{width:min(760px,100%)}.project-modal-header,.contact-modal-header{justify-content:space-between;align-items:flex-start;gap:16px;padding:20px;display:flex}.project-modal-header h2,.contact-modal-header h2{margin:6px 0 0}.project-modal-close{border:1px solid var(--border);color:var(--text-h);font:inherit;cursor:pointer;background:0 0;border-radius:999px;padding:8px 12px}.project-modal-close:hover{border-color:var(--accent-border)}.project-modal-close:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.project-modal-content,.contact-modal-content{gap:14px;padding:20px;display:grid;overflow-y:auto}.project-modal-summary,.contact-modal-summary{color:var(--text-h);margin:0;font-weight:500}.contact-form{gap:14px;display:grid}.contact-field{gap:6px;display:grid}.contact-field span{color:var(--text-h);font-weight:600}.contact-field input,.contact-field textarea{box-sizing:border-box;background:var(--surface-soft);border:1px solid var(--border);width:100%;color:var(--text-h);font:inherit;appearance:none;box-shadow:none;border-radius:12px;padding:12px 14px}.contact-field textarea{resize:vertical;min-height:160px}.contact-field input:focus,.contact-field textarea:focus{outline:2px solid var(--accent);outline-offset:2px}.contact-field input::placeholder,.contact-field textarea::placeholder{color:var(--text-muted)}.contact-honeypot{width:1px;height:1px;position:absolute;left:-9999px;overflow:hidden}.contact-actions{flex-wrap:wrap;justify-content:flex-end;gap:12px;display:flex}.contact-submit{margin-top:0}.contact-success,.contact-error{border-radius:12px;padding:12px 14px}.contact-success{background:var(--success-bg);color:var(--text-h)}.contact-error{background:var(--error-bg);color:var(--text-h)}.project-photos{grid-template-columns:repeat(2,minmax(0,1fr));align-items:stretch;gap:12px;display:grid}.project-photos img{aspect-ratio:4/3;object-fit:contain;object-position:center;background:var(--bg);border-radius:12px;width:100%;display:block}.project-photos img:only-child{grid-column:1/-1;justify-self:center;max-width:min(100%,420px)}.ambient-background{z-index:0;pointer-events:none;background:linear-gradient(180deg, var(--ambient-top) 0%, var(--ambient-mid) 52%, var(--ambient-bottom) 100%);position:fixed;inset:0;overflow:hidden}.ambient-grid{position:absolute;inset:0}.ambient-grid:before{content:"";background-image:linear-gradient(to right, var(--grid-accent) 1px, transparent 1px), linear-gradient(to bottom, var(--grid-accent) 1px, transparent 1px), linear-gradient(to right, var(--grid-neutral) 1px, transparent 1px), linear-gradient(to bottom, var(--grid-neutral) 1px, transparent 1px);background-position:50%;background-size:56px 56px,56px 56px,14px 14px,14px 14px;animation:34s linear infinite drift;position:absolute;inset:0;-webkit-mask-image:linear-gradient(#0000008f,#0000 78%);mask-image:linear-gradient(#0000008f,#0000 78%)}.ambient-particles{opacity:1;position:absolute;inset:0}.ambient-particles .particles-js-canvas-el{width:100%;height:100%;position:absolute;inset:0}@keyframes drift{0%{transform:translate(0,0)}to{transform:translateY(42px)}}@keyframes buttonFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-2px)}}@keyframes modalBackdropIn{0%{opacity:0}to{opacity:1}}@keyframes modalIn{0%{opacity:0;transform:translateY(12px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes modalBackdropOut{0%{opacity:1}to{opacity:0}}@keyframes modalOut{0%{opacity:1;transform:translateY(0)scale(1)}to{opacity:0;transform:translateY(10px)scale(.98)}}@keyframes contentViewIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@media (width<=1024px){.portfolio{gap:0;padding:16px}.page-section{min-height:auto}.content-section{padding:22px 20px}.hero{text-align:center;grid-template-columns:1fr;grid-template-areas:"main""aside";padding-top:24px;padding-bottom:24px}.hero-main{align-items:center}.hero-actions{justify-content:center;width:100%}.hero-aside{justify-items:center}.hero-profile{max-width:68ch}.section-jump-nav{z-index:6;background:0 0;justify-content:flex-start;max-width:none;padding:8px 10px;position:sticky;top:8px;right:auto}.portfolio-footer{justify-content:center;padding:16px 20px 22px}.project-modal-backdrop,.contact-modal-backdrop{padding:12px}.project-modal-header,.project-modal-content,.contact-modal-header,.contact-modal-content{padding:16px}.project-photos{grid-template-columns:1fr}.portfolio-page{justify-content:flex-start;padding-top:20px;padding-bottom:64px}.portfolio-page-header{align-items:flex-start}.portfolio-page-body{padding-bottom:20px}.view-panel-compact{min-height:calc(100svh - 210px);padding-bottom:52px}.content-switcher{justify-content:flex-start}.ambient-grid:before{background-size:42px 42px,42px 42px,12px 12px,12px 12px}.ambient-particles{opacity:.92}}@media (prefers-reduced-motion:reduce){.ambient-grid:before,.section-jump-button,.detail-card-content,.detail-card-icon,.project-modal,.contact-modal,.project-modal-backdrop,.contact-modal-backdrop,.content-view-transition{transition:none;animation:none}.ambient-particles{display:none}}
