:root,[data-theme=dark]{--bg: #1a1a1a;--bg-secondary: #2d2d2d;--text: #f0f0f0;--text-muted: #a0a0a0;--road: #252525;--building: #1e1e1e;--building-accent: #3a3a3a;--fog: #1a1a1a;--panel-bg: rgba(10, 10, 10, .6);--tag-bg: rgba(255, 255, 255, .08);--hero-avatar-border: rgba(255, 255, 255, .15);--hero-avatar-shadow: rgba(0, 0, 0, .3)}[data-theme=light]{--bg: #e0e0e0;--bg-secondary: #d0d0d0;--text: #1a1a1a;--text-muted: #555555;--road: #b0b0b0;--building: #c8c8c8;--building-accent: #aaaaaa;--fog: #e0e0e0;--panel-bg: rgba(240, 240, 240, .65);--tag-bg: rgba(0, 0, 0, .08);--hero-avatar-border: rgba(0, 0, 0, .12);--hero-avatar-shadow: rgba(0, 0, 0, .1)}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;height:100%}body{font-family:system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}a:hover{text-decoration:underline}.experience-panel{position:absolute;top:0;bottom:0;width:30%;display:flex;align-items:center;background:var(--panel-bg);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:none;border-radius:0;box-shadow:none;z-index:1}.experience-panel--left{left:0;right:auto;justify-content:flex-start;border-right:1px solid rgba(255,255,255,.06)}.experience-panel--right{right:0;left:auto;justify-content:flex-end;border-left:1px solid rgba(255,255,255,.06)}.experience-panel-content{max-width:420px;padding:3rem;overflow-y:auto;max-height:80vh}.experience-panel--left .experience-panel-content{margin-left:3rem}.experience-panel--right .experience-panel-content{margin-right:3rem}.experience-panel-title{margin:0 0 .35rem;font-size:1.5rem;font-weight:600;color:#fff;text-shadow:0 0 12px rgba(255,255,255,.7),0 0 30px rgba(255,255,255,.4),0 0 60px rgba(255,255,255,.2),0 0 100px rgba(255,255,255,.1)}[data-theme=light] .experience-panel-title{color:var(--text);text-shadow:0 0 8px rgba(0,0,0,.15),0 0 20px rgba(0,0,0,.08)}.experience-panel-company{margin:0 0 .25rem;font-size:1rem;color:var(--text-muted)}.experience-panel-period{margin:0 0 1.25rem;font-size:.85rem;color:var(--text-muted)}.experience-panel-description{margin:0 0 1.25rem;font-size:.95rem;line-height:1.65;color:#aaa}[data-theme=light] .experience-panel-description{color:#555}.experience-panel-tags{display:flex;flex-wrap:wrap;gap:.45rem;margin-bottom:1.25rem}.experience-panel-tag{font-size:.75rem;padding:.25rem .55rem;background:var(--tag-bg);border-radius:4px;color:var(--text-muted)}.experience-panel-link{display:inline-block;font-size:.9rem;color:var(--text);opacity:.9}.experience-panel-link:hover{opacity:1}@media (max-width: 768px){.experience-panel{width:100%;top:auto;bottom:0;height:auto;max-height:40%;border-left:none!important;border-right:none!important;border-top:1px solid rgba(255,255,255,.08);align-items:flex-start}.experience-panel--left,.experience-panel--right{left:0;right:0;justify-content:center}.experience-panel-content{margin:0 auto;padding:1rem 1.25rem;max-height:100%;max-width:100%}.experience-panel--left .experience-panel-content,.experience-panel--right .experience-panel-content{margin-left:auto;margin-right:auto}.experience-panel-title{font-size:1.15rem;margin-bottom:.2rem}.experience-panel-company{font-size:.85rem}.experience-panel-period{font-size:.75rem;margin-bottom:.75rem}.experience-panel-description{font-size:.8rem;line-height:1.5;margin-bottom:.75rem}.experience-panel-tags{gap:.35rem;margin-bottom:.75rem}.experience-panel-tag{font-size:.65rem;padding:.2rem .45rem}}.header{position:absolute;top:0;left:0;right:0;display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;z-index:10}.header-brand{display:flex;align-items:center;gap:.15rem}.header-brand--with-avatar{gap:.75rem}.header-avatar{width:36px;height:36px;border-radius:50%;object-fit:cover;filter:grayscale(100%);border:1.5px solid var(--hero-avatar-border);will-change:transform,opacity;transform-origin:center center}.header-brand-text{display:flex;flex-direction:column;gap:.15rem}.header-name{font-size:1.25rem;font-weight:600;letter-spacing:.02em}.header-tagline{font-size:.8rem;color:var(--text-muted)}.header-nav{display:flex;gap:1.5rem;font-size:.9rem}.header-nav a{color:var(--text);opacity:.9}.header-nav a:hover{opacity:1}.theme-toggle{background:none;border:none;color:var(--text);cursor:pointer;padding:.35rem;font-size:1.1rem}.theme-icon{display:flex;align-items:center}@media (max-width: 768px){.header{flex-wrap:wrap;padding:.75rem 1rem;gap:.5rem}.header-brand{flex:1;min-width:0}.header-avatar{width:28px;height:28px}.header-name{font-size:1rem}.header-tagline{font-size:.65rem}.header-nav{order:3;width:100%;gap:1rem;font-size:.75rem;justify-content:center;padding-top:.25rem;border-top:1px solid rgba(128,128,128,.15)}.theme-toggle{padding:.25rem}}.hero-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:20;display:flex;align-items:center;justify-content:center}.hero-backdrop{position:absolute;top:0;right:0;bottom:0;left:0}.hero-content{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:1.25rem;will-change:transform,opacity}.hero-avatar-wrapper{width:160px;height:160px;border-radius:50%;border:3px solid var(--hero-avatar-border);box-shadow:0 4px 30px var(--hero-avatar-shadow);position:relative}.hero-avatar-wrapper--loading:after{content:"";position:absolute;top:-8px;right:-8px;bottom:-8px;left:-8px;border-radius:50%;border:2.5px solid transparent;border-top-color:var(--text-muted);border-right-color:var(--text-muted);animation:avatarSpin .8s linear infinite;pointer-events:none}.hero-avatar-wrapper--ready:after{content:"";position:absolute;top:-8px;right:-8px;bottom:-8px;left:-8px;border-radius:50%;border:2px solid var(--text-muted);opacity:0;animation:avatarRingFadeOut .6s ease forwards;pointer-events:none}@keyframes avatarSpin{to{transform:rotate(360deg)}}@keyframes avatarRingFadeOut{0%{opacity:.5}to{opacity:0}}.hero-avatar{width:100%;height:100%;border-radius:50%;object-fit:cover;filter:grayscale(100%)}.hero-text{text-align:center;will-change:opacity}.hero-name{margin:0;font-size:2rem;font-weight:600;color:var(--text);letter-spacing:.01em}.hero-title{margin:.35rem 0 0;font-size:1.05rem;color:var(--text-muted)}.hero-socials{display:flex;gap:1.25rem;will-change:opacity}.hero-socials a{color:var(--text-muted);transition:color .2s;display:flex}.hero-socials a:hover{color:var(--text);text-decoration:none}.hero-theme-toggle{position:absolute;top:1rem;right:1.5rem;z-index:2;background:none;border:none;color:var(--text);cursor:pointer;padding:.35rem;font-size:1.1rem}.hero-scroll-hint{position:absolute;bottom:2.5rem;left:50%;transform:translate(-50%) translateY(10px);display:flex;flex-direction:column;align-items:center;gap:.6rem;color:var(--text-muted);font-size:.85rem;z-index:1;will-change:opacity,transform;transition:opacity .5s ease,transform .5s ease}.hero-scroll-hint--visible{transform:translate(-50%) translateY(0)}.hero-scroll-hint p{margin:0}.hero-scroll-arrow{animation:scrollBounce 2s ease-in-out infinite}@keyframes scrollBounce{0%,to{transform:translateY(0);opacity:.5}30%{transform:translateY(14px);opacity:1}50%{transform:translateY(4px);opacity:.9}70%{transform:translateY(10px);opacity:1}}@media (max-width: 768px){.hero-avatar-wrapper{width:120px;height:120px}.hero-name{font-size:1.5rem}.hero-title{font-size:.9rem}}.portfolio-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:15;display:flex;align-items:flex-start;justify-content:center;overflow-y:auto;overscroll-behavior:contain;padding-top:3.5rem}.portfolio-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none}[data-theme=dark] .portfolio-backdrop{background:#141414eb}[data-theme=light] .portfolio-backdrop{background:#ebebebeb}.portfolio-hero-title{position:fixed;top:0;right:0;bottom:0;left:0;z-index:2;display:flex;align-items:center;justify-content:center;font-size:5rem;font-weight:700;color:var(--text);letter-spacing:-.02em;pointer-events:none;will-change:opacity,transform}.portfolio-content{position:relative;z-index:1;width:100%;max-width:1100px;padding:5rem 2rem 4rem;margin:0 auto;will-change:opacity}.portfolio-heading{margin:0 0 .35rem;font-size:2.2rem;font-weight:700;color:var(--text);letter-spacing:-.01em}.portfolio-subheading{margin:0 0 2.5rem;font-size:1rem;color:var(--text-muted)}.portfolio-grid{columns:2;column-gap:1rem}.portfolio-card{background:var(--bg-secondary);border:1px solid var(--tag-bg);border-radius:10px;overflow:hidden;display:flex;flex-direction:column;break-inside:avoid;margin-bottom:1rem;will-change:transform,opacity;transition:border-color .25s ease,box-shadow .25s ease}a.portfolio-card{text-decoration:none;color:inherit;cursor:pointer}.portfolio-card:hover{border-color:var(--text-muted);box-shadow:0 4px 20px #00000026}.portfolio-card-thumb{width:100%;overflow:hidden;flex-shrink:0}.portfolio-card-thumb img{width:100%;height:auto;display:block;filter:grayscale(100%);transition:filter .35s ease}.portfolio-card:hover .portfolio-card-thumb img{filter:grayscale(60%)}.portfolio-card-body{padding:1.25rem 1.5rem 1.5rem;display:flex;flex-direction:column;flex:1}.portfolio-card-title{margin:0 0 .5rem;font-size:1.05rem;font-weight:600;color:var(--text)}.portfolio-card--large .portfolio-card-title{font-size:1.25rem}.portfolio-card-desc{margin:0 0 1rem;font-size:.85rem;line-height:1.55;color:var(--text-muted);flex:1}.portfolio-card--large .portfolio-card-desc{font-size:.9rem}.portfolio-card-tags{display:flex;flex-wrap:wrap;gap:.4rem}.portfolio-card-tag{font-size:.7rem;padding:.2rem .5rem;background:var(--tag-bg);border-radius:4px;color:var(--text-muted)}.portfolio-card-link{display:inline-block;margin-top:.75rem;font-size:.85rem;color:var(--text);opacity:.8}.portfolio-card-link:hover{opacity:1}.portfolio-cta{margin-top:60vh;padding:3rem 0 4rem;text-align:center}.portfolio-cta-title{margin:0 0 .35rem;font-size:1.8rem;font-weight:700;color:var(--text);opacity:0;transform:translateY(20px);transition:opacity .6s ease,transform .6s ease}.portfolio-fireworks{position:relative;height:160px;width:100%;max-width:600px;margin:2rem auto;transition:height .6s ease,margin .6s ease,opacity .4s ease;overflow:hidden}.portfolio-fireworks--done{height:0;margin:.25rem auto;opacity:0}.firework{position:absolute;width:0;height:0}.firework--0{left:25%;top:50%}.firework--1{left:50%;top:35%}.firework--2{left:75%;top:55%}.firework-spark{position:absolute;width:4px;height:4px;border-radius:50%;background:var(--text-muted);opacity:0}.firework-spark--0{--angle: 0deg}.firework-spark--1{--angle: 30deg}.firework-spark--2{--angle: 60deg}.firework-spark--3{--angle: 90deg}.firework-spark--4{--angle: 120deg}.firework-spark--5{--angle: 150deg}.firework-spark--6{--angle: 180deg}.firework-spark--7{--angle: 210deg}.firework-spark--8{--angle: 240deg}.firework-spark--9{--angle: 270deg}.firework-spark--10{--angle: 300deg}.firework-spark--11{--angle: 330deg}.firework:before{content:"";position:absolute;width:2px;height:0;background:linear-gradient(to top,transparent,var(--text-muted));bottom:0;left:-1px;opacity:0}.portfolio-fireworks--active .firework--0:before{animation:fireworkTrail .5s ease-out .3s forwards}.portfolio-fireworks--active .firework--1:before{animation:fireworkTrail .5s ease-out .7s forwards}.portfolio-fireworks--active .firework--2:before{animation:fireworkTrail .5s ease-out 1s forwards}.portfolio-fireworks--active .firework--0 .firework-spark{animation:fireworkBurst .8s ease-out .8s forwards}.portfolio-fireworks--active .firework--1 .firework-spark{animation:fireworkBurst .8s ease-out 1.2s forwards}.portfolio-fireworks--active .firework--2 .firework-spark{animation:fireworkBurst .8s ease-out 1.5s forwards}@keyframes fireworkTrail{0%{height:0;opacity:0;transform:translateY(0)}50%{opacity:.8}to{height:50px;opacity:0;transform:translateY(-50px)}}@keyframes fireworkBurst{0%{opacity:1;transform:rotate(var(--angle)) translateY(0) scale(1)}30%{opacity:1}to{opacity:0;transform:rotate(var(--angle)) translateY(-50px) scale(.3)}}.portfolio-cta-subtitle{margin:0 0 2rem;font-size:1.1rem;color:var(--text-muted);opacity:0;transform:translateY(15px);transition:opacity .6s ease 1.6s,transform .6s ease 1.6s}.portfolio-calendly{width:100%;max-width:700px;margin:0 auto;border-radius:10px;overflow:hidden;border:none;background:transparent;opacity:0;transform:translateY(20px);transition:opacity .6s ease 2s,transform .6s ease 2s}.portfolio-cta-title.portfolio-cta--visible,.portfolio-cta-subtitle.portfolio-cta--visible,.portfolio-calendly.portfolio-cta--visible{opacity:1;transform:translateY(0)}.portfolio-calendly-scale{width:100%;max-width:700px;margin:0 auto;border-radius:12px;overflow:hidden;filter:grayscale(100%)}.portfolio-calendly-scale iframe{display:block;border:none;width:100%;height:700px}@media (max-width: 520px){.portfolio-grid{columns:1}.portfolio-content{padding:3rem 1.25rem}}.about-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:25;display:flex;align-items:center;justify-content:center;animation:aboutFadeIn .3s ease}@keyframes aboutFadeIn{0%{opacity:0}to{opacity:1}}.about-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);background:#00000073}[data-theme=light] .about-backdrop{background:#dcdcdc80}.about-content{position:relative;z-index:1;max-width:560px;width:90%;padding:2rem;animation:aboutSlideUp .35s ease}@keyframes aboutSlideUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.about-close{position:fixed;top:1.25rem;right:1.5rem;background:none;border:none;color:var(--text-muted);font-size:1.6rem;cursor:pointer;line-height:1;padding:.25rem;transition:color .2s;z-index:2}.about-close:hover{color:var(--text)}.about-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem}.about-avatar{width:64px;height:64px;border-radius:50%;object-fit:cover;filter:grayscale(100%);border:2px solid var(--hero-avatar-border)}.about-name{margin:0;font-size:1.4rem;font-weight:600;color:var(--text)}.about-role{margin:.15rem 0 0;font-size:.9rem;color:var(--text-muted)}.about-bio{margin:0 0 1.5rem;font-size:.95rem;line-height:1.65;color:var(--text)}.about-facts{list-style:none;margin:0 0 1.5rem;padding:0;display:flex;flex-direction:column;gap:.6rem}.about-facts li{font-size:.88rem;color:var(--text-muted);padding-left:1.2rem;position:relative}.about-facts li:before{content:"";position:absolute;left:0;top:.55em;width:6px;height:6px;border-radius:50%;background:var(--text-muted);opacity:.5}.about-links{display:flex;justify-content:center;gap:1.25rem}.about-links a{color:var(--text-muted);display:flex;transition:color .2s}.about-links a:hover{color:var(--text);text-decoration:none}@media (max-width: 520px){.about-content{padding:2rem 1.5rem}.about-name{font-size:1.2rem}}.app-wrap{position:relative;width:100%;height:100vh}.scroll-container{position:fixed;top:0;right:0;bottom:0;left:0;overflow-y:auto;overflow-x:hidden;overscroll-behavior:none;z-index:0;scroll-behavior:auto;background:transparent}.scroll-spacer{width:1px}.canvas-wrapper{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1;pointer-events:none}.canvas-wrapper canvas{display:block;width:100%;height:100%}.ui-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:2;pointer-events:none}.ui-overlay>*{pointer-events:auto}.site-footer{position:fixed;bottom:.75rem;right:1rem;z-index:3;font-size:.7rem;color:var(--text-muted);opacity:.4;pointer-events:none;letter-spacing:.02em}.fallback-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);color:var(--text);padding:2rem}.fallback-content{max-width:560px;text-align:center}.fallback-avatar{width:120px;height:120px;border-radius:50%;object-fit:cover;filter:grayscale(100%);margin-bottom:1.5rem;border:3px solid var(--hero-avatar-border)}.fallback-name{margin:0 0 .25rem;font-size:1.8rem;font-weight:600}.fallback-role{margin:0 0 1.5rem;font-size:.95rem;color:var(--text-muted)}.fallback-bio{margin:0 0 1rem;font-size:.95rem;line-height:1.6;color:var(--text)}.fallback-note{margin:0 0 1.5rem;font-size:.85rem;color:var(--text-muted);opacity:.7}.fallback-links{display:flex;gap:1.5rem;justify-content:center}.fallback-links a{font-size:.9rem;color:var(--text);opacity:.8}.fallback-links a:hover{opacity:1}
