@import "https://fonts.googleapis.com/css2?family=DotGothic16&display=swap";:root{--bg:#f9f8f6;--bg-card:#fff;--text:#1a1a1a;--text-muted:#6b6965;--border:#1a1a1a;--accent:#2c4a73;--accent-blue:#4a90e2;--accent-green:#50c878;--accent-yellow:#f5d76e;--font-sans:"Outfit", sans-serif;--font-serif:"Newsreader", serif;--font-mono:"Space Mono", monospace;--font-pixel:"DotGothic16", sans-serif;--r:12px;--r-lg:20px;--max-w:1100px;--section-pad:120px;--nav-h:80px}[data-theme=dark]{--bg:#1a1a1a;--bg-card:#242424;--text:#f9f8f6;--text-muted:#a09e9a;--border:#404040}[data-theme=dark] body{background:var(--text)}::view-transition-group(root){animation-duration:.7s;animation-timing-function:cubic-bezier(.76,0,.24,1)}::view-transition-new(root){mix-blend-mode:normal;animation:none;display:block}::view-transition-old(root){mix-blend-mode:normal;animation:none;display:block}::view-transition-old(root){z-index:1}::view-transition-new(root){z-index:999999}.theme-transition,.theme-transition *,.theme-transition :before,.theme-transition :after{transition-behavior:allow-discrete;transition:background-color .5s,color .5s,border-color .5s,box-shadow .5s!important}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:16px}body{background:var(--accent);color:var(--text);font-family:var(--font-sans);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;padding:16px;padding-bottom:env(safe-area-inset-bottom,16px);font-weight:400;line-height:1.6;overflow-x:hidden}#root{background:var(--bg);min-height:calc(100svh - 32px - env(safe-area-inset-bottom,0px));border-radius:24px;position:relative;overflow:hidden;box-shadow:0 20px 40px #0003}#root:after{content:"";pointer-events:none;z-index:9998;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.04'/%3E%3C/svg%3E");position:absolute;inset:0}[data-theme=dark] #root:after{opacity:.08}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::selection{background:var(--accent-yellow);color:var(--text)}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}button{cursor:pointer;font-family:var(--font-sans);background:0 0;border:none}.cursor-dot{pointer-events:none;z-index:9999;border:1.5px solid var(--border);border-radius:50%;width:12px;height:12px;transition:width .2s,height .2s,background .2s;position:fixed;transform:translate(-50%,-50%)}.cursor-dot.hovering{border-color:var(--accent);background:#ff6b4a1a;width:32px;height:32px}@media (pointer:coarse){.cursor-dot{display:none}}.window-card{background:var(--bg-card);border:1.5px solid var(--border);border-radius:12px;transition:transform .4s cubic-bezier(.16,1,.3,1),box-shadow .4s cubic-bezier(.16,1,.3,1);overflow:hidden;box-shadow:4px 4px #2d2c2a26}.window-card:hover{transform:translate(-3px,-3px);box-shadow:8px 8px #2d2c2a33}.window-header{border-bottom:1.5px solid var(--border);background:#f9f8f680;gap:8px;padding:10px 14px;display:flex}.window-dot{border:1.5px solid var(--border);background:var(--bg-card);border-radius:50%;width:10px;height:10px;transition:background .3s}.window-card:hover .window-dot:first-child{background:var(--accent)}.window-card:hover .window-dot:nth-child(2){background:var(--accent-yellow)}.window-card:hover .window-dot:nth-child(3){background:var(--accent-green)}.window-body{padding:24px}.serif-italic{font-family:var(--font-serif);font-style:italic;font-weight:400}.mono{font-family:var(--font-mono);font-size:.85em}.dashed-line{border-top:2px dashed var(--border);opacity:.3;margin:40px 0}.nav-wrapper{z-index:100;pointer-events:none;justify-content:center;padding:0 24px;transition:transform .4s cubic-bezier(.16,1,.3,1);display:flex;position:fixed;top:24px;left:0;right:0}.nav-wrapper.hidden{transform:translateY(calc(-100% - 24px))}.nav{pointer-events:auto;background:var(--bg-card);border:1px solid var(--border);border-radius:100px;align-items:center;gap:32px;padding:12px 24px;transition:transform .3s,box-shadow .3s;display:flex;box-shadow:0 10px 30px #0000000d}.nav:hover{transform:translateY(-2px);box-shadow:0 15px 40px #00000014}.nav-logo{font-family:var(--font-sans);color:var(--text);align-items:center;gap:12px;font-size:.95rem;font-weight:500;display:flex}.nav-logo img{object-fit:cover;border-radius:50%;width:32px;height:32px}.nav-logo-text{white-space:nowrap;flex-direction:column;line-height:1.2;display:flex}.nav-logo-sub{color:var(--text-muted);font-size:.75rem}.nav-links{border-left:1px solid var(--border);border-right:1px solid var(--border);align-items:center;gap:24px;margin:0 24px;padding:0 24px;list-style:none;display:flex}.nav-links a{color:var(--text-muted);font-size:.9rem;font-weight:500;transition:color .2s;position:relative}.nav-links a:hover,.nav-links a.active{color:var(--text)}.nav-cta{font-family:var(--font-sans);background:var(--text);border-radius:100px;align-items:center;gap:8px;padding:10px 20px;font-weight:600;display:flex;color:var(--bg)!important;font-size:.85rem!important;transition:transform .2s,opacity .2s!important}.nav-cta:hover{opacity:.9;transform:scale(1.05)}.nav-cta:after{display:none!important}.nav-actions{align-items:center;gap:12px;display:flex}@media (width<=768px){.nav-links{display:none}.nav-wrapper{padding:0 25px}.nav{border-radius:100px;justify-content:space-between;gap:8px;width:100%;padding:10px 16px}.nav-logo{gap:8px}.nav-logo-text{font-size:.85rem}.nav-logo-sub{display:none}.nav-actions{gap:8px}.nav-cta{padding:8px 12px;font-size:.75rem!important}}.section{padding:var(--section-pad) 40px;max-width:var(--max-w);margin:0 auto}.section-label{font-family:var(--font-mono);color:var(--text-muted);align-items:center;gap:12px;margin-bottom:16px;font-size:.8rem;display:flex}.section-label:after{content:"";border-top:1px dashed var(--border);opacity:.3;flex:1;height:1px}.section-title{letter-spacing:-.5px;margin-bottom:40px;font-size:clamp(2rem,5vw,3rem);font-weight:600;line-height:1.1}.section-title .serif-italic{color:var(--accent)}.reveal{opacity:0;transition:opacity .8s,transform .8s;transform:translateY(20px)}.reveal.visible{opacity:1;transform:none}.reveal-delay-1{transition-delay:.1s}.reveal-delay-2{transition-delay:.2s}.reveal-delay-3{transition-delay:.3s}@media (width<=768px){.section{padding:80px 24px}}.btn{font-family:var(--font-mono);border:1.5px solid var(--border);background:var(--bg-card);color:var(--text);border-radius:8px;align-items:center;gap:8px;padding:12px 24px;font-size:.9rem;transition:transform .3s cubic-bezier(.16,1,.3,1),box-shadow .3s cubic-bezier(.16,1,.3,1),background .3s;display:inline-flex;box-shadow:3px 3px #2d2c2a26}.btn:hover{background:var(--accent-yellow);transform:translate(-2px,-2px);box-shadow:6px 6px #2d2c2a33}.btn-primary{background:var(--text);color:var(--bg);border-color:var(--text)}.btn-primary:hover{background:var(--text);color:var(--bg);box-shadow:6px 6px #2d2c2a4d}[data-theme=dark] .btn-primary:hover{box-shadow:6px 6px #00000080}[data-theme=dark] .btn{box-shadow:3px 3px #0000004d}[data-theme=dark] .btn:hover{background:var(--accent-yellow);color:#1a1a1a;border-color:var(--accent-yellow);box-shadow:6px 6px #00000080}.hero{align-items:center;min-height:calc(100svh - 32px);padding-top:0;padding-bottom:0;display:flex;position:relative}.hero-content{z-index:2;max-width:900px;position:relative}.hero-title{font-family:var(--font-pixel);letter-spacing:-1px;color:var(--text);margin-bottom:32px;font-size:clamp(2.5rem,8vw,6.5rem);font-weight:400;line-height:1.1}.hero-title .serif-italic{font-family:var(--font-serif);color:var(--accent);letter-spacing:-2px;font-size:1.1em;font-style:italic;font-weight:500}.hero-desc{font-family:var(--font-serif);color:var(--text);align-items:center;gap:8px;margin-bottom:0;font-size:clamp(1.2rem,2vw,1.5rem);display:flex}.hero-desc span{color:var(--accent);font-style:italic}.hero-actions{flex-wrap:wrap;gap:16px;display:flex}.about-grid{grid-template-columns:1fr 1fr;align-items:center;gap:80px;display:grid}.about-text p{color:var(--text-muted);margin-bottom:20px;font-size:1.1rem}.about-text strong{color:var(--text);font-weight:500}.photo-stack{aspect-ratio:3/4;perspective:1000px;width:100%;max-width:400px;margin:0 auto;position:relative}.photo-card{border:4px solid var(--bg-card);border-radius:16px;transition:all .6s cubic-bezier(.34,1.56,.64,1);position:absolute;inset:0;overflow:hidden;box-shadow:0 10px 30px #0000001a}.photo-card img{object-fit:cover;will-change:transform;width:100%;height:100%;transition:transform .4s cubic-bezier(.16,1,.3,1)}.photo-current{z-index:2;transform:rotate(-2deg)}.photo-stack:hover .photo-current{transform:rotate(0)}@media (width<=900px){.about-grid{grid-template-columns:1fr;gap:60px}}.timeline{padding-left:32px;position:relative}.timeline:before{content:"";border-left:2px dashed var(--border);opacity:.3;width:0;position:absolute;top:8px;bottom:8px;left:0}.timeline-item{padding-bottom:48px;position:relative}.timeline-item:last-child{padding-bottom:0}.timeline-dot{border:2px solid var(--border);background:var(--bg-card);border-radius:50%;width:12px;height:12px;transition:background .3s;position:absolute;top:6px;left:-37px}.timeline-item:hover .timeline-dot{background:var(--accent)}.timeline-card{padding:0}.timeline-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:16px;display:flex}.timeline-role{font-size:1.2rem;font-weight:600}.timeline-company{font-family:var(--font-serif);color:var(--text-muted);font-size:1.1rem;font-style:italic}.timeline-period{font-family:var(--font-mono);border:1px solid var(--border);border-radius:20px;padding:4px 10px;font-size:.8rem}.timeline-points{flex-direction:column;gap:10px;list-style:none;display:flex}.timeline-points li{color:var(--text-muted);padding-left:20px;font-size:.95rem;position:relative}.timeline-points li:before{content:"→";font-family:var(--font-mono);color:var(--border);position:absolute;left:0}.projects-grid{grid-template-columns:repeat(2,1fr);gap:32px;display:grid}.project-card{flex-direction:column;height:100%;display:flex}.project-img-wrap{border-bottom:2px solid var(--border);background-image:radial-gradient(#2d2c2a1a 1px,#0000 1px);background-size:20px 20px;justify-content:center;align-items:center;height:180px;font-size:3rem;display:flex}.project-info{flex-direction:column;flex:1;padding:24px;display:flex}.project-title{margin-bottom:8px;font-size:1.3rem;font-weight:600}.project-desc{color:var(--text-muted);flex:1;margin-bottom:24px;font-size:.95rem}.project-tags{flex-wrap:wrap;gap:8px;margin-bottom:20px;display:flex}.project-tag{font-family:var(--font-mono);border:1px solid var(--border);background:var(--bg);border-radius:4px;padding:4px 10px;font-size:.75rem}.project-link{font-family:var(--font-mono);align-self:flex-start;align-items:center;gap:6px;font-size:.85rem;font-weight:600;display:inline-flex;position:relative}.project-link:after{content:"";background:var(--border);transform-origin:100%;width:100%;height:1px;transition:transform .3s;position:absolute;bottom:-2px;left:0;transform:scaleX(0)}.project-link:hover:after{transform-origin:0;transform:scaleX(1)}@media (width<=768px){.projects-grid{grid-template-columns:1fr}}.skills-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:24px;display:grid}.skill-group{padding:24px}.skill-group-title{font-family:var(--font-serif);border-bottom:1px dashed var(--border);margin-bottom:16px;padding-bottom:8px;font-size:1.2rem;font-style:italic}.skill-list{flex-wrap:wrap;gap:8px;display:flex}.skill-item{font-family:var(--font-mono);border:1.5px solid var(--border);background:var(--bg);border-radius:20px;padding:6px 12px;font-size:.85rem;transition:transform .2s,background .2s}.skill-item:hover{background:var(--accent-yellow);transform:translateY(-2px)}.contact-wrapper{text-align:center;max-width:600px;margin:0 auto;padding:60px 0}.contact-wrapper h2{letter-spacing:-1px;margin-bottom:24px;font-size:clamp(2.5rem,6vw,4rem)}.contact-wrapper p{color:var(--text-muted);margin-bottom:40px;font-size:1.1rem}.social-links{flex-wrap:wrap;justify-content:center;gap:24px;display:flex}.social-link{font-family:var(--font-mono);border:2px solid var(--border);background:var(--bg-card);box-shadow:4px 4px 0px var(--border);border-radius:8px;align-items:center;gap:8px;padding:12px 24px;font-size:1rem;transition:transform .2s,box-shadow .2s;display:flex}.social-link:hover{box-shadow:6px 6px 0px var(--border);background:var(--accent-yellow);transform:translate(-2px,-2px)}.footer{border-top:2px solid var(--border);text-align:center;font-family:var(--font-mono);color:var(--text-muted);background:var(--bg-card);flex-direction:column;gap:12px;padding:40px;font-size:.85rem;display:flex}.pokemon-container{bottom:calc(0px + env(safe-area-inset-bottom,0px));z-index:9999;cursor:pointer;will-change:transform;justify-content:center;align-items:flex-end;width:60px;height:60px;display:flex;position:fixed;left:0}.pokemon-sprite{object-fit:contain;height:100%;image-rendering:pixelated;filter:drop-shadow(2px 4px 4px #00000026);transition:transform .2s}.pokemon-jump-wrapper{align-items:flex-end;height:100%;display:flex}.pokemon-jump-wrapper.reacting{animation:.5s cubic-bezier(.34,1.56,.64,1) pkmn-jump}@keyframes pkmn-jump{0%,to{transform:translateY(0)}50%{transform:translateY(-30px)}}.pokemon-heart{pointer-events:none;font-size:1.5rem;animation:1s ease-out forwards pkmn-heart-float;position:absolute;top:-20px}@keyframes pkmn-heart-float{0%{opacity:1;transform:translateY(0)scale(.8)}to{opacity:0;transform:translateY(-40px)scale(1.2)}}.konami-overlay{z-index:10000;background:var(--bg);justify-content:center;align-items:center;animation:.5s fade-in;display:flex;position:fixed;inset:0}.konami-content{text-align:center;max-width:600px;padding:40px}.konami-content h2{font-family:var(--font-serif);color:var(--accent);margin-bottom:16px;font-size:3rem;font-style:italic}.konami-content p{color:var(--text-muted);margin-bottom:32px;font-size:1.1rem}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.confetti-piece{background:var(--accent);z-index:9999;pointer-events:none;width:10px;height:10px;animation:3s linear forwards fall;position:fixed}@keyframes fall{0%{opacity:1;transform:translateY(-10vh)rotate(0)}to{opacity:0;transform:translateY(110vh)rotate(720deg)}}.bg-doodle{pointer-events:none;z-index:0;position:fixed}.doodle-float-1{animation:12s ease-in-out infinite organic-float-1}.doodle-float-2{animation:15s ease-in-out infinite reverse organic-float-2}.doodle-spin-slow{transform-origin:50%;animation:40s linear infinite organic-spin}.doodle-drift{animation:18s ease-in-out infinite alternate organic-drift}.doodle-pulse-soft{transform-origin:50%;animation:10s ease-in-out infinite organic-pulse}@keyframes organic-float-1{0%,to{transform:translate(0)rotate(0)}33%{transform:translate(15px,-25px)rotate(5deg)}66%{transform:translate(-10px,-15px)rotate(-3deg)}}@keyframes organic-float-2{0%,to{transform:translate(0)rotate(0)}50%{transform:translate(-20px,-30px)rotate(-8deg)}}@keyframes organic-spin{0%{transform:rotate(0)scale(1)}50%{transform:rotate(180deg)scale(1.05)}to{transform:rotate(360deg)scale(1)}}@keyframes organic-drift{0%{transform:translate(0)rotate(0)}to{transform:translate(-40px,30px)rotate(10deg)}}@keyframes organic-pulse{0%,to{transform:scale(1)rotate(0)}50%{transform:scale(1.15)rotate(5deg)}}
