:root{color-scheme:dark;--bg: #1f2023;--panel: #292a2e;--panel-soft: #242528;--text: #f5f1e8;--muted: #c4b9aa;--soft: #8f887f;--line: #3b3c40;--accent: #f59f45;--accent-soft: rgba(245, 159, 69, .14);--accent-line: rgba(245, 159, 69, .36);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}html{scroll-behavior:smooth;background:var(--bg);color:var(--text)}body{margin:0;min-width:320px;background:linear-gradient(180deg,rgba(245,159,69,.05),transparent 420px),var(--bg);font-size:16px;line-height:1.65}a{color:inherit;text-decoration-color:var(--accent-line);text-underline-offset:.2em}a:hover{color:var(--accent);text-decoration-color:var(--accent)}h1,h2,h3,p{margin-top:0}h1,h2,h3{line-height:1.12;letter-spacing:0}.site-shell{width:min(1180px,calc(100% - 40px));margin:0 auto}.site-header{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:26px 0}.brand{display:inline-flex;align-items:center;gap:10px;color:var(--text);font-weight:700;text-decoration:none}.brand-mark{display:grid;width:32px;height:32px;place-items:center;border:1px solid var(--line);border-radius:8px;background:var(--panel);color:var(--accent);font-size:.78rem}.nav{display:flex;align-items:center;gap:18px;color:var(--muted);font-size:.95rem}.portfolio-stack{display:flex;flex-direction:column;align-items:center;gap:clamp(36px,6vw,70px);padding:clamp(14px,3vw,34px) 0 clamp(52px,7vw,84px)}.intro-panel{display:grid;width:min(100%,1080px);grid-template-columns:280px minmax(0,1fr);gap:clamp(28px,5vw,64px);align-items:stretch}.identity-section{display:grid;width:280px;min-height:260px;grid-template-rows:auto auto auto;align-content:space-between;gap:18px;justify-items:center;align-self:stretch}.profile-photo{width:min(100%,260px);height:auto;aspect-ratio:1;border:1px solid var(--line);border-radius:8px;object-fit:cover;background:var(--panel)}.typing-name{width:13ch;max-width:100%;margin:0;justify-self:center;color:var(--text);font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:clamp(1.45rem,3vw,2.45rem);font-weight:800;line-height:1;white-space:nowrap}.typing-name span{display:inline-block;width:13ch;max-width:100%;overflow:hidden;border-right:.08em solid var(--accent);animation:typing 1.75s steps(13,end) .25s both,caret .85s step-end infinite}@keyframes typing{0%{width:0}to{width:13ch}}@keyframes caret{50%{border-color:transparent}}.profile-links{display:flex;width:100%;flex-wrap:wrap;justify-content:center;gap:9px}.profile-links a{display:inline-flex;flex:0 1 auto;min-height:40px;align-items:center;gap:8px;border:1px solid var(--line);border-radius:8px;padding:8px 13px;background:var(--panel);color:var(--text);font-weight:650;text-decoration:none}.profile-links svg{width:17px;height:17px;flex:0 0 auto;fill:none;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round;stroke-width:1.8}.profile-links a:hover{border-color:var(--accent-line);background:var(--accent-soft);color:var(--accent)}.section-jump{display:grid;width:42px;height:42px;place-items:center;border:1px solid var(--line);border-radius:999px;background:var(--panel);color:var(--muted);text-decoration:none}.section-jump:hover{border-color:var(--accent-line);background:var(--accent-soft);color:var(--accent)}.section-jump svg{width:20px;height:20px;fill:none;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round;stroke-width:1.9}.eyebrow{margin-bottom:8px;color:var(--accent);font-size:.78rem;font-weight:750;letter-spacing:.08em;text-transform:uppercase}.experience-panel{width:min(100%,760px);border-top:1px solid var(--line);padding-top:34px}.experience-header{margin-bottom:22px}.section-heading{text-align:center}.experience-panel h2,.section-heading h2{display:inline-block;margin:0 0 10px;border-bottom:2px solid var(--accent);padding-bottom:4px;color:var(--accent);font-size:clamp(1.35rem,2.4vw,2rem)}.experience-carousel-shell{display:grid;grid-template-columns:56px minmax(0,1fr) 56px;gap:12px;align-items:center}.carousel-arrow{display:grid;width:56px;height:56px;place-items:center;border:0;background:transparent;color:var(--soft);cursor:pointer;transition:color .16s ease,transform .16s ease,background-color .16s ease}.carousel-arrow:hover{background:transparent;color:var(--accent)}.carousel-arrow:disabled{visibility:hidden;color:#8f887f47;cursor:default;transform:none}.carousel-arrow:disabled:hover{color:#8f887f47;transform:none}.carousel-arrow-left:hover{transform:translate(-3px)}.carousel-arrow-right:hover{transform:translate(3px)}.carousel-arrow svg{width:46px;height:46px;fill:none;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round;stroke-width:1.15}.carousel-dots{display:flex;justify-content:center;gap:8px;margin-top:24px}.carousel-dots button{width:9px;height:9px;border:0;border-radius:999px;padding:0;background:var(--line);cursor:pointer}.carousel-dots button[aria-current]{width:24px;background:var(--accent)}.timeline{display:grid;gap:22px;overflow:hidden;transition:opacity .22s ease,transform .22s ease;will-change:opacity,transform}.timeline.is-slide-out-next{opacity:0;transform:translate(-36px)}.timeline.is-slide-out-prev{opacity:0;transform:translate(36px)}.timeline.is-slide-in-next{opacity:0;transform:translate(36px);transition:none}.timeline.is-slide-in-prev{opacity:0;transform:translate(-36px);transition:none}.timeline-item[hidden]{display:none}.timeline-item{display:grid;grid-template-columns:54px minmax(0,1fr);gap:15px;align-items:start}.logo-frame{display:grid;width:54px;height:54px;place-items:center;overflow:hidden;border:1px solid var(--line);border-radius:8px;background:var(--panel);color:var(--accent);font-size:.78rem;font-weight:800;text-decoration:none}.logo-frame img{width:100%;height:100%;object-fit:contain;padding:7px}.timeline-content{min-width:0;border-bottom:1px solid var(--line);padding-bottom:20px}.timeline-item:last-child .timeline-content{border-bottom:0;padding-bottom:0}.timeline-meta{display:flex;align-items:start;justify-content:space-between;gap:16px;margin-bottom:5px}.timeline-meta h3{margin-bottom:0;font-size:1rem}.company-line{display:flex;min-width:0;flex-wrap:wrap;align-items:center;gap:8px}.timeline-meta a{text-decoration:none}.timeline-side-meta{display:grid;justify-items:end;gap:3px;flex:0 0 auto}.timeline-side-meta span{color:var(--soft);font-size:.84rem}.role-line{display:flex;align-items:baseline;justify-content:space-between;gap:16px;margin-bottom:4px}.role-line span{flex:0 0 auto;color:var(--soft);font-size:.84rem}.current-pill{display:inline-flex;min-height:22px;align-items:center;border:1px solid rgba(74,222,128,.35);border-radius:999px;padding:2px 9px;background:#22c55e21;color:#86efac;font-size:.72rem;font-weight:750;line-height:1;text-transform:uppercase}.timeline-content p,.about-panel p{margin-bottom:0;color:var(--muted)}.role{color:var(--text)!important;font-weight:650;margin-bottom:0}.about-panel{display:flex;min-height:260px;flex-direction:column;justify-content:center;border:1px solid var(--line);border-radius:8px;background:var(--panel-soft);padding:clamp(26px,4vw,44px)}.about-panel h2{max-width:760px;margin-bottom:16px;font-size:clamp(1.85rem,3.6vw,3.65rem)}.about-panel p+p{margin-top:16px}.about-panel strong{color:var(--text);font-weight:750}.about-panel a{color:var(--accent);font-weight:700;text-decoration:none}.about-panel a:hover{text-decoration:underline}.lead{max-width:680px;margin-bottom:14px;color:var(--text)!important;font-size:clamp(1.08rem,2vw,1.24rem);line-height:1.55}.section{width:min(100%,900px);border-top:1px solid var(--line);padding-top:34px;scroll-margin-top:24px}.section .section-heading{margin-bottom:24px}.project-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:34px}.project-item{min-width:0}.project-card{display:grid;grid-template-rows:1fr auto;height:100%;overflow:hidden;border:1px solid var(--line);border-radius:8px;background:var(--panel-soft);color:inherit;text-decoration:none;transition:border-color .16s ease,transform .16s ease,background-color .16s ease}.project-card:hover{border-color:var(--accent-line);background:#f59f450f;color:inherit;transform:translateY(-2px)}.project-primary-link{display:grid;grid-template-rows:auto 1fr;color:inherit;text-decoration:none}.project-image-wrap{aspect-ratio:16 / 10;overflow:hidden;border-bottom:1px solid var(--line);background:var(--panel);padding:12px}.project-image-wrap img{width:100%;height:100%;display:block;object-fit:contain}.project-card-body{display:grid;grid-template-rows:auto minmax(5.4em,1fr) auto auto;gap:12px;padding:18px}.project-card-header{display:flex;align-items:start;justify-content:space-between;gap:14px}.project-card-header h3{margin:0;font-size:1.04rem;line-height:1.18}.project-card-header h3{display:inline-flex;align-items:center;gap:7px;color:inherit;text-decoration:none}.project-primary-link:hover .project-card-header h3{color:var(--accent)}.project-card-header svg{width:16px;height:16px;flex:0 0 auto;fill:none;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round;stroke-width:1.8}.project-card-body p{margin:0;color:var(--muted);align-self:start}.tech-list{display:flex;flex-wrap:wrap;justify-content:flex-start;gap:7px;margin:0;padding:0;list-style:none}.tech-list li{display:inline-flex;min-height:32px;align-items:center;justify-content:center;border:1px solid var(--line);border-radius:8px;padding:5px 10px;background:var(--panel);color:var(--muted);font-size:.82rem;line-height:1}.project-actions{display:flex;flex-wrap:wrap;gap:8px;padding:0 18px 18px}.project-actions a{display:inline-flex;min-height:34px;align-items:center;border:1px solid var(--accent-line);border-radius:8px;padding:6px 10px;color:var(--accent);font-size:.84rem;font-weight:700;text-decoration:none}.project-actions a:hover{background:var(--accent-soft)}.project-actions svg{width:17px;height:17px;fill:none;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round;stroke-width:1.8}.site-footer{display:flex;border-top:1px solid var(--line);padding:30px 0 44px;color:var(--muted);font-size:.94rem}.footer-links{display:flex;flex-wrap:wrap;align-items:center;gap:9px}.footer-links>*+*:before{content:"·";margin-right:9px;color:var(--soft)}@media(prefers-reduced-motion:reduce){.typing-name span{width:auto;animation:none}.timeline{transition:none}}@media(max-width:900px){.site-shell{width:min(100% - 28px,1180px)}.site-header{align-items:flex-start;flex-direction:column}.nav{width:100%;justify-content:space-between;gap:12px}.intro-panel,.project-item,.project-list{grid-template-columns:1fr}.intro-panel{justify-items:center}.identity-section{width:min(100%,280px)}.profile-photo{width:min(245px,72vw)}.experience-carousel-shell{grid-template-columns:1fr}.carousel-arrow{display:none}.timeline-meta{display:grid;gap:5px}.timeline-side-meta{justify-items:start}.role-line{display:grid;gap:3px}.tech-list{justify-content:flex-start}.site-footer{flex-direction:column}}@media(max-width:520px){.timeline-item{grid-template-columns:46px minmax(0,1fr);gap:14px}.logo-frame{width:46px;height:46px}}
