*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--font-sans:"Atkinson Hyperlegible", system-ui, sans-serif;--font-serif:"Libre Baskerville", Georgia, "Times New Roman", serif;--bg:#faf7f2;--bg-elevated:#fff;--text:#1c1b19;--text-muted:#5c5852;--border:#e3ddd4;--border-strong:#c9c2b8;--accent:#8b3a2a;--accent-hover:#6f2e22;--header-bg:#faf7f2eb;--shadow:0 1px 2px #1c1b190f;--radius:6px;--radius-lg:10px;--content-max:38rem;--header-h:3.25rem}[data-theme=dark]{--bg:#141312;--bg-elevated:#1c1a18;--text:#edeae4;--text-muted:#a39e96;--border:#2e2c29;--border-strong:#3f3c38;--accent:#d4a574;--accent-hover:#e4bc94;--header-bg:#141312eb;--shadow:0 1px 3px #00000059}html{scroll-behavior:smooth}@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}body{font-family:var(--font-sans);color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;min-height:100vh;font-size:1.0625rem;line-height:1.65}a{color:var(--accent);text-underline-offset:.2em;text-decoration-thickness:1px}a:hover{color:var(--accent-hover)}.portfolio{max-width:calc(var(--content-max) + 3rem);padding:calc(var(--header-h) + 2.5rem) 1.5rem 4rem;margin:0 auto}.site-section{border-top:1px solid var(--border);margin-top:1rem;padding-top:2.5rem}.site-section--hero{border-top:none;margin-top:0;padding-top:0}.section-inner{max-width:var(--content-max)}.site-header{z-index:100;background:var(--header-bg);border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);position:fixed;top:0;left:0;right:0}.navbar-inner{max-width:calc(var(--content-max) + 3rem);height:var(--header-h);justify-content:space-between;align-items:center;gap:1rem;margin:0 auto;padding:0 1.5rem;display:flex}.navbar-brand{font-family:var(--font-serif);color:var(--text);letter-spacing:-.02em;white-space:nowrap;text-overflow:ellipsis;cursor:pointer;text-align:left;background:0 0;border:none;padding:0;font-size:.95rem;font-weight:700;text-decoration:none;overflow:hidden}.navbar-brand:hover{color:var(--accent)}.navbar-brand:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:2px}.navbar-tabs{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);align-items:center;gap:.15rem;margin-left:auto;padding:.2rem;display:flex}.navbar-tab{color:var(--text-muted);border-radius:calc(var(--radius) - 2px);cursor:pointer;white-space:nowrap;background:0 0;border:none;padding:.4rem .75rem;font-family:inherit;font-size:.875rem;font-weight:500}.navbar-tab:hover{color:var(--text);background:color-mix(in srgb, var(--bg-elevated) 80%, transparent)}.navbar-tab--active{color:var(--text);background:var(--bg-elevated);box-shadow:var(--shadow)}.navbar-tab:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.theme-toggle{border:1px solid var(--border-strong);border-radius:var(--radius);background:var(--bg-elevated);width:2.25rem;height:2.25rem;color:var(--text-muted);cursor:pointer;flex-shrink:0;justify-content:center;align-items:center;padding:0;display:flex}.theme-toggle:hover{color:var(--text);border-color:var(--text-muted)}.theme-toggle svg{width:1rem;height:1rem}@media (width<=640px){.navbar-tab{padding:.35rem .55rem;font-size:.78rem}.navbar-brand{max-width:9rem;font-size:.82rem}}@keyframes tabFadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.tab-panel{animation:.35s cubic-bezier(.22,1,.36,1) tabFadeIn}@media (prefers-reduced-motion:reduce){.tab-panel{animation:none}}.tab-panel .site-section{border-top:none;margin-top:0;padding-top:0}@keyframes enterContent{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.hero-animate>*{animation:.55s cubic-bezier(.22,1,.36,1) backwards enterContent}.hero-animate>:first-child{animation-delay:40ms}.hero-animate>:nth-child(2){animation-delay:80ms}.hero-animate>:nth-child(3){animation-delay:.12s}.hero-animate>:nth-child(4){animation-delay:.16s}.hero-animate>:nth-child(5){animation-delay:.2s}.hero-animate>:nth-child(6){animation-delay:.24s}.hero-animate>:nth-child(7){animation-delay:.28s}.hero-animate>:nth-child(8){animation-delay:.32s}.skills-animate>.section-title,.skills-animate>.section-intro{animation:.48s cubic-bezier(.22,1,.36,1) backwards enterContent}.skills-animate>.section-title{animation-delay:50ms}.skills-animate>.section-intro{animation-delay:.1s}.skills-animate .skills-row{animation:.48s cubic-bezier(.22,1,.36,1) backwards enterContent;animation-delay:calc(.14s + (var(--skills-stagger,0) * 45ms))}.projects-animate>.section-title,.projects-animate>.section-intro{animation:.48s cubic-bezier(.22,1,.36,1) backwards enterContent}.projects-animate>.section-title{animation-delay:50ms}.projects-animate>.section-intro{animation-delay:.1s}.projects-animate .project-list>li{animation:.48s cubic-bezier(.22,1,.36,1) backwards enterContent;animation-delay:calc(.12s + (var(--project-stagger,0) * 35ms))}@media (prefers-reduced-motion:reduce){.hero-animate>*,.skills-animate>.section-title,.skills-animate>.section-intro,.skills-animate .skills-row,.projects-animate>.section-title,.projects-animate>.section-intro,.projects-animate .project-list>li{animation:none!important}}.lede{text-transform:uppercase;letter-spacing:.12em;color:var(--text-muted);margin-bottom:.75rem;font-size:.8125rem}.display-name{font-family:var(--font-serif);letter-spacing:-.02em;color:var(--text);margin-bottom:.35rem;font-size:clamp(2rem,6vw,2.75rem);font-weight:700;line-height:1.15}.display-title{color:var(--text-muted);max-width:32rem;font-size:1.05rem;font-weight:400}.display-meta{color:var(--text-muted);align-items:center;gap:.4rem;margin-top:1rem;font-size:.9375rem;display:flex}.display-meta svg{flex-shrink:0;width:.95rem;height:.95rem}.prose{max-width:36rem;color:var(--text);margin-top:1.5rem}.availability-line{color:var(--text-muted);margin-top:1rem;font-size:.9375rem}.contact-row{border-top:1px solid var(--border);flex-wrap:wrap;gap:.75rem 1.25rem;margin-top:2rem;padding-top:1.5rem;list-style:none;display:flex}.text-link,.text-link--button{color:var(--accent);cursor:pointer;background:0 0;border:none;align-items:center;gap:.4rem;padding:0;font-family:inherit;font-size:.9375rem;text-decoration:none;display:inline-flex}.text-link:hover,.text-link--button:hover{color:var(--accent-hover);text-decoration:underline}.text-link-icon svg{opacity:.85;width:1rem;height:1rem}.section-title{font-family:var(--font-serif);color:var(--text);margin-bottom:.35rem;font-size:1.5rem;font-weight:700}.section-intro{color:var(--text-muted);max-width:32rem;margin-bottom:1.75rem;font-size:.95rem}.skills-list{flex-direction:column;gap:0;display:flex}.skills-row{border-bottom:1px solid var(--border);grid-template-columns:minmax(7rem,10rem) 1fr;gap:1rem 1.5rem;padding:1.1rem 0;display:grid}.skills-row:first-of-type{padding-top:0}.skills-term{color:var(--text);font-size:.9rem;font-weight:600}.skills-level{letter-spacing:.04em;text-transform:uppercase;color:var(--text-muted);margin-top:.2rem;font-size:.7rem;font-weight:600;display:block}.skills-detail{margin:0}.skills-desc{color:var(--text-muted);margin-bottom:.35rem;font-size:.85rem;display:block}.skills-items{color:var(--text);font-size:.9rem}@media (width<=560px){.skills-row{grid-template-columns:1fr;gap:.25rem}}.project-list{border-top:1px solid var(--border);list-style:none}.project-row{text-align:left;width:100%;font-family:inherit;font-size:inherit;color:inherit;border:none;border-bottom:1px solid var(--border);cursor:pointer;background:0 0;flex-direction:column;gap:.35rem;padding:1.15rem 0;transition:background .15s;display:flex}.project-row:hover{background:color-mix(in srgb, var(--bg-elevated) 60%, transparent)}.project-row:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.project-row-main{flex-wrap:wrap;align-items:baseline;gap:.5rem .75rem;display:flex}.project-row-title{font-family:var(--font-serif);color:var(--text);font-size:1.05rem;font-weight:700}.project-row-company{color:var(--text-muted);font-size:.85rem}.project-row-desc{color:var(--text-muted);font-size:.92rem;line-height:1.55}.project-row-tech{color:var(--text-muted);font-size:.8rem}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-backdrop{z-index:2000;background:#1413128c;justify-content:center;align-items:center;padding:1.25rem;animation:.15s fadeIn;display:flex;position:fixed;inset:0}[data-theme=dark] .modal-backdrop{background:#000000a6}.modal-card{background:var(--bg-elevated);width:100%;max-width:32rem;max-height:min(85vh,36rem);color:var(--text);border:1px solid var(--border-strong);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:1.75rem 1.75rem 1.5rem;position:relative;overflow-y:auto}.modal-close{border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);width:2rem;height:2rem;color:var(--text-muted);cursor:pointer;justify-content:center;align-items:center;font-size:1.25rem;line-height:1;display:flex;position:absolute;top:.85rem;right:.85rem}.modal-close:hover{color:var(--text);border-color:var(--border-strong)}.modal-title{font-family:var(--font-serif);margin-bottom:.35rem;padding-right:2rem;font-size:1.35rem;font-weight:700}.modal-meta{color:var(--text-muted);margin-bottom:1rem;font-size:.875rem}.modal-company{color:var(--text);font-weight:600}.modal-period:before{content:"·";color:var(--text-muted);margin:0 .4rem}.modal-description{border-bottom:1px solid var(--border);margin-bottom:1rem;padding-bottom:1rem;font-size:.95rem;line-height:1.65}.modal-details{margin-bottom:1rem;list-style:none}.modal-details li{color:var(--text-muted);margin-bottom:.5rem;padding-left:1rem;font-size:.9rem;line-height:1.55;position:relative}.modal-details li:before{content:"–";color:var(--text-muted);position:absolute;left:0}.modal-tech-line{color:var(--text-muted);font-size:.85rem;line-height:1.6}.resume-modal .modal-title{margin-bottom:.25rem}.resume-modal-sub{color:var(--text-muted);margin-bottom:1rem;font-size:.9rem}.resume-options{flex-direction:column;gap:.5rem;display:flex}.resume-option{border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--text);flex-direction:column;gap:.15rem;padding:.85rem 1rem;text-decoration:none;transition:border-color .15s,background .15s;display:flex}.resume-option:hover{border-color:var(--border-strong);background:var(--bg-elevated);color:var(--text);text-decoration:none}.resume-option-lang{font-size:.95rem;font-weight:600}.resume-option-hint{color:var(--text-muted);font-size:.8rem}@keyframes chatAmbientPulse{0%,to{opacity:.2;transform:scale(.985)}50%{opacity:.5;transform:scale(1)}}@keyframes chatPanelGlow{0%,to{box-shadow:var(--shadow), 0 0 0 0 color-mix(in srgb, var(--accent) 0%, transparent)}50%{box-shadow:var(--shadow), 0 0 0 5px color-mix(in srgb, var(--accent) 10%, transparent)}}@keyframes chatInputRing{0%{box-shadow:0 0 0 0 color-mix(in srgb, var(--accent) 28%, transparent)}to{box-shadow:0 0 0 10px #0000}}.chat-widget{isolation:isolate;margin-top:2rem;position:relative}.chat-widget:not(.chat-widget--open):before{content:"";z-index:-1;border-radius:calc(var(--radius) + 6px);background:radial-gradient(ellipse 100% 80% at 50% 50%, color-mix(in srgb, var(--accent) 22%, transparent), transparent 72%);pointer-events:none;animation:2.75s ease-in-out infinite chatAmbientPulse;position:absolute;inset:-5px}.chat-widget-trigger{text-align:left;width:100%;color:var(--text);background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;box-shadow:var(--shadow);justify-content:space-between;align-items:center;gap:1rem;padding:.85rem 1rem;font-family:inherit;font-size:.9rem;transition:border-color .2s,transform .2s;display:flex}.chat-widget-trigger:hover{border-color:var(--border-strong);transform:translateY(-1px)}.chat-widget-trigger-label{flex:1;align-items:center;min-width:0;min-height:2.75em;display:flex}.chat-widget-trigger-rotating{color:var(--text-muted);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:.875rem;line-height:1.45;transition:opacity .35s;display:-webkit-box;overflow:hidden}.chat-widget-trigger-action{text-transform:uppercase;letter-spacing:.06em;color:var(--accent);flex-shrink:0;font-size:.8rem;font-weight:600}.chat-widget--open{margin-top:2rem}.chat-widget--open:before{content:"";z-index:-1;border-radius:calc(var(--radius-lg) + 10px);background:radial-gradient(ellipse 100% 90% at 50% 30%, color-mix(in srgb, var(--accent) 18%, transparent), transparent 68%);pointer-events:none;animation:3.2s ease-in-out infinite chatAmbientPulse;position:absolute;inset:-8px}@keyframes chatPanelIn{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}.chat-widget-panel{z-index:0;border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--bg-elevated);box-shadow:var(--shadow);animation:.4s cubic-bezier(.22,1,.36,1) backwards chatPanelIn,2.8s ease-in-out .45s infinite alternate chatPanelGlow;position:relative;overflow:hidden}.chat-widget-head{border-bottom:1px solid var(--border);background:var(--bg);justify-content:space-between;align-items:center;padding:.65rem .85rem;display:flex}.chat-widget-title{color:var(--text);font-size:.85rem;font-weight:600}.chat-widget-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:.15rem .35rem;font-size:1.25rem;line-height:1}.chat-widget-close:hover{color:var(--text)}.chat-widget-body{flex-direction:column;gap:.5rem;max-height:280px;padding:.85rem 1rem;display:flex;overflow-y:auto}.chat-widget-note{color:var(--text-muted);margin-bottom:.25rem;font-size:.8rem;line-height:1.5}.chat-widget-suggestions{flex-wrap:wrap;gap:.45rem;margin-bottom:.35rem;display:flex}.chat-widget-suggestion{text-align:left;border-radius:var(--radius);border:1px solid var(--border);background:var(--bg);color:var(--text-muted);cursor:pointer;padding:.45rem .7rem;font-family:inherit;font-size:.78rem;line-height:1.35;transition:border-color .15s,color .15s,background .15s}.chat-widget-suggestion:hover{border-color:var(--border-strong);color:var(--text);background:var(--bg-elevated)}.chat-widget-suggestion:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.chat-widget-msg{border-radius:var(--radius);white-space:pre-wrap;word-break:break-word;max-width:90%;padding:.5rem .75rem;font-size:.875rem;line-height:1.55;animation:.35s cubic-bezier(.22,1,.36,1) backwards enterContent}.chat-widget-msg--user{background:var(--text);color:var(--bg);align-self:flex-end}.chat-widget-msg--assistant{background:var(--bg);border:1px solid var(--border);color:var(--text);align-self:flex-start}.chat-widget-msg--typing{align-items:center;gap:.25rem;animation:none;display:flex}.chat-widget-dot{background:var(--text-muted);border-radius:50%;width:5px;height:5px;animation:1.2s ease-in-out infinite chatDot}.chat-widget-dot:nth-child(2){animation-delay:.15s}.chat-widget-dot:nth-child(3){animation-delay:.3s}@keyframes chatDot{0%,80%,to{opacity:.35;transform:translateY(0)}40%{opacity:1;transform:translateY(-3px)}}@media (prefers-reduced-motion:reduce){.chat-widget-dot{opacity:.6;animation:none}.chat-widget:not(.chat-widget--open):before,.chat-widget--open:before{opacity:.18;animation:none;transform:none}.chat-widget-panel,.chat-widget-msg{animation:none!important}.chat-widget-input--pulse{animation:none}.chat-widget-trigger{transition:border-color .2s}.chat-widget-trigger:hover{transform:none}}.chat-widget-foot{border-top:1px solid var(--border);background:var(--bg);align-items:flex-end;gap:.5rem;padding:.65rem;display:flex}.chat-widget-input--pulse{animation:.85s ease-out chatInputRing}.chat-widget-input{resize:none;min-height:2.5rem;max-height:120px;color:var(--text);background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius);flex:1;padding:.5rem .65rem;font-family:inherit;font-size:.875rem;line-height:1.45}.chat-widget-input:focus{outline:2px solid color-mix(in srgb, var(--accent) 35%, transparent);outline-offset:1px;border-color:var(--border-strong)}.chat-widget-send{color:var(--bg);background:var(--text);border:1px solid var(--text);border-radius:var(--radius);cursor:pointer;flex-shrink:0;padding:.45rem .75rem;font-family:inherit;font-size:.8rem;font-weight:600}.chat-widget-send:disabled{opacity:.4;cursor:not-allowed}.chat-widget-send:not(:disabled):hover{opacity:.92}[data-theme=light] .chat-widget-msg--user{background:var(--text);color:var(--bg)}[data-theme=dark] .chat-widget-msg--user{color:#141312;background:#edeae4}[data-theme=dark] .chat-widget-send{color:#141312;background:#edeae4;border-color:#edeae4}
