@import url(https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600&family=Syne:wght@600;700;800&family=JetBrains+Mono:wght@400;500&display=swap);:root{--bg:#fafafa;--fg:#141414;--surface:#f2f2f2;--primary:#1d66e8;--primary-fg:#f0f5ff;--accent:#3b82f6;--warm:#e3dac9;--warm-fg:#141414;--border:#e0e0e0;--muted:#f0f0f0;--muted-fg:#737373;--font-sans:"Inter",sans-serif;--font-hero:"Syne",sans-serif;--font-mono:"JetBrains Mono",monospace;--radius:12px;--transition:0.25s ease}html.dark{--bg:#0f0f0f;--fg:#f0f0f0;--surface:#1a1a1a;--primary:#60a5fa;--primary-fg:#f0f5ff;--accent:#7eb3fb;--warm:#e3dac9;--warm-fg:#0f0f0f;--border:#2e2e2e;--muted:#212121;--muted-fg:#8c8c8c}*,:after,:before{border-color:#e0e0e0;border-color:var(--border);box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#fafafa;background-color:var(--bg);background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='a'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.65' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23a)' opacity='.02'/%3E%3C/svg%3E");color:#141414;color:var(--fg);font-family:Inter,sans-serif;font-family:var(--font-sans);line-height:1.6;overflow-x:hidden;transition:background-color .25s ease,color .25s ease;transition:background-color var(--transition),color var(--transition)}h1,h2,h3,h4,h5,h6{font-family:Syne,sans-serif;font-family:var(--font-hero);font-weight:700;letter-spacing:-.03em;line-height:1.05}a{text-decoration:none}a,button{color:inherit}button{background:none;border:none;cursor:pointer;font-family:inherit}img{display:block;max-width:100%}::selection{background-color:#60a5fa4d}.container{margin:0 auto;max-width:1280px;padding-left:24px;padding-right:24px}@media (min-width:768px){.container{padding-left:48px;padding-right:48px}}.section-divider{border:none;border-top:1px solid #e0e0e0;border-top:1px solid var(--border);margin:0 auto;max-width:1280px;padding-left:24px;padding-right:24px}.section-padding{padding-bottom:96px;padding-top:96px}@media (min-width:768px){.section-padding{padding-bottom:128px;padding-top:128px}}.editorial-row{display:flex;flex-direction:column;gap:32px}@media (min-width:768px){.editorial-row{flex-direction:row;gap:0}}.editorial-label-col{flex-shrink:0}@media (min-width:768px){.editorial-label-col{width:25%}}.editorial-content-col{flex:1 1}.section-label{align-items:center;display:flex;gap:16px}.section-label-text{color:#737373;color:var(--muted-fg);font-family:JetBrains Mono,monospace;font-family:var(--font-mono);font-size:11px;font-weight:700;letter-spacing:.15em;text-transform:uppercase}.section-label-line{background-color:#737373;background-color:var(--muted-fg);display:block;height:1px;opacity:.3;width:32px}@media (max-width:480px){.container{padding-left:16px;padding-right:16px}.section-padding{padding-bottom:48px;padding-top:48px}}@keyframes heroFadeUp{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}.hero-text-animate{animation:heroFadeUp .8s cubic-bezier(.22,1,.36,1) forwards;opacity:0}@keyframes heroScaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.hero-avatar-animate{animation:heroScaleIn 1s cubic-bezier(.22,1,.36,1) .2s forwards;opacity:0}.fade-in-up{opacity:0;transform:translateY(40px);transition:opacity .8s cubic-bezier(.22,1,.36,1),transform .8s cubic-bezier(.22,1,.36,1)}.fade-in-up.visible{opacity:1;transform:translateY(0)}@keyframes ping{75%,to{opacity:0;transform:scale(2)}}.pulse-dot-wrapper{display:flex;flex-shrink:0;height:8px;position:relative;width:8px}.pulse-dot-ring{animation:ping 1.2s cubic-bezier(0,0,.2,1) infinite;inset:0;opacity:.75;position:absolute}.pulse-dot-core,.pulse-dot-ring{background-color:#1d66e8;background-color:var(--primary);border-radius:50%}.pulse-dot-core{height:8px;position:relative;width:8px}.perspective-1000{perspective:1000px}.transform-style-3d{transform-style:preserve-3d}.backface-hidden{backface-visibility:hidden;-webkit-backface-visibility:hidden}.rotate-y-180{transform:rotateY(180deg)}@keyframes blink{50%{opacity:0}}.cursor-blink:after{animation:blink .8s step-end infinite;background-color:#1d66e8;background-color:var(--primary);bottom:0;content:"";height:2px;left:0;position:absolute;width:100%}.theme-toggle{align-items:center;background-color:var(--surface);border:1px solid var(--border);border-radius:50%;color:var(--fg);cursor:pointer;display:flex;flex-shrink:0;height:40px;justify-content:center;overflow:hidden;position:relative;transition:background-color var(--transition);width:40px}.theme-toggle:hover{background-color:var(--muted)}.theme-icon{align-items:center;display:flex;justify-content:center;position:absolute;transition:transform .3s ease,opacity .3s ease}.theme-icon--visible{opacity:1;transform:translateY(0)}.theme-icon--hidden-up{opacity:0;transform:translateY(-30px)}.theme-icon--hidden-down{opacity:0;transform:translateY(30px)}.navbar{animation:navSlideDown .6s cubic-bezier(.22,1,.36,1) both;left:0;mix-blend-mode:difference;padding:24px 0;position:fixed;right:0;top:0;z-index:100}@keyframes navSlideDown{0%{opacity:0;transform:translateY(-50px)}to{opacity:1;transform:translateY(0)}}.navbar--scrolled{backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);background-color:#ffffff0d;border-bottom:1px solid var(--border)}.navbar__inner{align-items:center;display:flex;justify-content:space-between}.navbar__logo{background:none;border:none;color:var(--fg);color:#fff;cursor:pointer;font-family:var(--font-hero);font-size:20px;font-weight:800;letter-spacing:-.04em;mix-blend-mode:exclusion;transition:color var(--transition)}.navbar__dot{color:var(--primary)}.navbar__right{gap:32px;mix-blend-mode:exclusion}.navbar__links,.navbar__right{align-items:center;display:flex}.navbar__links{gap:24px}.navbar__links button{color:#fff;font-size:14px;font-weight:500;transition:color var(--transition)}.navbar__links button:hover{color:var(--primary)}@media (max-width:767px){.navbar__links{display:none}}.snake-wrap{flex-direction:column;height:100%;justify-content:center;padding:8px}.snake-score-bar,.snake-wrap{align-items:center;display:flex;width:100%}.snake-score-bar{justify-content:space-between;margin-bottom:12px;padding:0 8px}.snake-score{color:var(--primary);font-size:13px;font-weight:700}.snake-hi,.snake-score{font-family:var(--font-mono)}.snake-hi{align-items:center;color:var(--muted-fg);display:flex;font-size:11px;gap:4px}.snake-board{aspect-ratio:1;background-color:var(--bg);border:2px solid var(--border);border-radius:var(--radius);display:grid;max-width:300px;outline:none;overflow:hidden;position:relative;transition:border-color var(--transition);width:100%}.snake-board:focus{border-color:var(--primary)}.snake-cell{border:1px solid #ffffff08;height:100%;width:100%}.snake-cell--head{background-color:var(--primary);border-radius:2px;box-shadow:0 0 10px #60a5fa80;transform:scale(1.1);z-index:2}.snake-cell--body{background-color:var(--accent);border-radius:2px;opacity:.7}.snake-cell--food{animation:foodPulse .8s ease-in-out infinite alternate;background-color:var(--accent);border-radius:50%;box-shadow:0 0 8px #60a5facc;transform:scale(.75)}@keyframes foodPulse{0%{transform:scale(.7)}to{transform:scale(.9)}}.snake-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#0f0f0fd9;color:#f0f0f0;display:flex;flex-direction:column;gap:8px;inset:0;justify-content:center;padding:16px;position:absolute;text-align:center;z-index:10}.snake-overlay h4{font-family:var(--font-hero);font-size:1.25rem;font-weight:700}.snake-overlay p{font-size:12px;margin-bottom:8px;opacity:.7}.snake-gameover{color:#ef4444}.snake-final{font-family:var(--font-mono);font-size:13px}.game-btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:inline-flex;font-size:13px;font-weight:600;gap:8px;padding:8px 18px;transition:opacity var(--transition),transform .1s}.game-btn:active{transform:scale(.95)}.game-btn--primary{background-color:var(--primary);color:var(--primary-fg)}.game-btn--primary:hover{opacity:.9}.game-btn--accent{background-color:var(--accent);color:var(--primary-fg)}.game-btn--warm{background-color:var(--warm);color:var(--warm-fg)}.game-btn--dark{background-color:#f0f0f0;color:#141414}.game-btn--dark:hover{opacity:.9}.memory-wrap{align-items:center;display:flex;flex-direction:column;height:100%;justify-content:center;padding:8px;position:relative;width:100%}.memory-score-bar{display:flex;justify-content:space-between;margin-bottom:12px;padding:0 8px;width:100%}.memory-moves{color:var(--accent);font-family:var(--font-mono);font-size:13px;font-weight:700}.memory-grid{grid-gap:8px;aspect-ratio:4/3;display:grid;gap:8px;grid-template-columns:repeat(4,1fr);max-width:300px;position:relative;width:100%}.memory-card-wrap{aspect-ratio:1;cursor:pointer;perspective:1000px}.memory-card-inner{height:100%;position:relative;transition:transform .5s cubic-bezier(.4,0,.2,1);width:100%}.memory-card-face{align-items:center;border-radius:8px;display:flex;font-size:1.5rem;inset:0;justify-content:center;position:absolute}.memory-card--front{background-color:var(--muted);border:1px solid var(--border)}.memory-card--front:hover{background-color:var(--surface)}.memory-card-q{color:var(--muted-fg);font-size:11px;opacity:.3}.memory-card--back{background-color:var(--bg);border:1px solid var(--accent);opacity:.4}.memory-card--matched{background-color:#22c55e26;border-color:#22c55e80;opacity:1}.memory-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#1a1a1ad9;border-radius:var(--radius);color:#f0f0f0;display:flex;flex-direction:column;gap:8px;inset:-8px;justify-content:center;padding:16px;position:absolute;text-align:center;z-index:10}.memory-overlay h4{font-family:var(--font-hero);font-size:1.25rem;font-weight:700}.memory-overlay p{font-size:12px;margin-bottom:8px;opacity:.7}.memory-win{color:#22c55e}.memory-final{font-family:var(--font-mono);font-size:13px}.memory-overlay--win{background:linear-gradient(135deg,#22c55e26,#22c55e0d);border:1px solid #22c55e4d}.memory-message{color:var(--accent);font-size:13px;font-weight:600;margin:4px 0}.animate-scale-pulse{animation:scale-pulse .8s cubic-bezier(.4,0,.2,1)}@keyframes scale-pulse{0%{opacity:0;transform:scale(.8)}50%{transform:scale(1.1)}to{opacity:1;transform:scale(1)}}.typing-wrap{cursor:text;display:flex;flex-direction:column;height:100%;padding:16px;width:100%}.typing-header{justify-content:space-between;margin-bottom:24px}.typing-header,.typing-label{align-items:center;display:flex}.typing-label{color:var(--warm);gap:8px}.typing-label,.typing-wpm-small{font-family:var(--font-mono);font-size:13px;font-weight:700}.typing-wpm-small{color:var(--primary)}.typing-body{flex:1 1;justify-content:center}.typing-body,.typing-idle{align-items:center;display:flex}.typing-idle{flex-direction:column;gap:16px;text-align:center}.typing-idle p{color:var(--muted-fg);font-size:12px}.typing-result{align-items:center;display:flex;flex-direction:column;gap:8px}.typing-wpm{color:var(--primary);font-family:var(--font-hero);font-size:3rem;font-weight:800}.typing-wpm-label{color:var(--muted-fg);font-family:var(--font-mono);font-size:11px;letter-spacing:.12em;margin-bottom:8px;text-transform:uppercase}.typing-message{color:var(--accent);font-size:14px;font-weight:600;margin-bottom:16px;min-height:24px;text-align:center}.animate-bounce{animation:bounce .6s ease-in-out infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.typing-display{max-width:320px;position:relative;width:100%}.typing-input-hidden{cursor:default;inset:0;opacity:0;position:absolute;width:100%}.typing-chars{background-color:var(--bg);border:1px solid var(--border);border-radius:8px;font-family:var(--font-mono);font-size:.95rem;letter-spacing:.02em;line-height:1.8;padding:16px;-webkit-user-select:none;user-select:none;word-break:break-all}.char{position:relative;transition:color .05s}.char--pending{color:var(--muted-fg);opacity:.5}.char--correct{color:var(--primary);font-weight:600}.char--wrong{background-color:#ef444426;color:#ef4444}.char--cursor:after{animation:blink .8s step-end infinite;background-color:var(--primary);bottom:0;content:"";height:2px;left:0;position:absolute;width:100%}.app{background-color:var(--bg);color:var(--fg);font-family:var(--font-sans)}.app,.hero{min-height:100vh}.hero{display:flex;padding-bottom:clamp(24px,5vw,48px);padding-top:clamp(48px,10vw,96px)}.hero,.hero__grid{align-items:center}.hero__grid{grid-gap:48px;display:grid;gap:48px;grid-template-columns:1fr;width:100%}@media (min-width:1024px){.hero__grid{grid-template-columns:1fr 1fr}}.hero__text{align-items:flex-start;display:flex;flex-direction:column;order:2;z-index:2}@media (min-width:1024px){.hero__text{order:1}}.hero__badge{align-items:center;color:var(--primary);display:inline-flex;font-family:var(--font-mono);font-size:11px;font-weight:700;gap:8px;letter-spacing:.15em;margin-bottom:32px;text-transform:uppercase}.hero__name{color:var(--fg);font-family:var(--font-hero);font-size:clamp(2.5rem,9vw,5rem);font-weight:800;letter-spacing:-.04em;line-height:.9;margin-bottom:24px;text-transform:uppercase}.hero__name--muted{color:var(--muted-fg);opacity:.8}.hero__subtitle{color:var(--fg);font-size:clamp(1rem,1.5vw,1.5rem);line-height:1.6;margin-bottom:48px;max-width:520px;opacity:.8}.hero__ctas{align-items:center;display:flex;flex-wrap:wrap;gap:clamp(16px,4vw,32px)}.cta-link{align-items:center;display:inline-flex;font-size:13px;font-weight:600;gap:8px;letter-spacing:.08em;text-transform:uppercase;transition:color var(--transition)}.cta-link__label{border-bottom:1px solid;padding-bottom:2px;transition:border-color var(--transition)}.cta-link--primary{color:var(--fg)}.cta-link--primary:hover{color:var(--primary)}.cta-link--secondary{color:var(--muted-fg)}.cta-link--secondary:hover{color:var(--fg)}.cta-link--secondary .cta-link__label{border-color:#0000}.cta-link--secondary:hover .cta-link__label{border-color:var(--fg)}.cta-link--primary:hover .btn-icon{transform:translateY(3px)}.cta-link--secondary:hover .btn-icon{transform:translateX(3px)}.btn-icon{transition:transform var(--transition)}.hero__avatar-wrap{display:flex;height:clamp(200px,40vh,600px);justify-content:center;order:1;z-index:1}@media (min-width:1024px){.hero__avatar-wrap{height:auto;justify-content:flex-end;order:2}}.hero__avatar{filter:grayscale(20%) contrast(1.25) drop-shadow(0 24px 48px rgba(0,0,0,.3));max-width:480px;object-fit:contain;transition:filter .7s ease;width:100%}.hero__avatar:hover{filter:grayscale(0) contrast(1) drop-shadow(0 24px 48px rgba(0,0,0,.25))}.about__text{font-size:clamp(1rem,2vw,2rem);line-height:1.45;max-width:900px;opacity:.9}.about__text,.skills__text{color:var(--fg);font-weight:500}.skills__text{font-size:clamp(1rem,2vw,1.5rem);line-height:1.6;opacity:.8}.skills-carousel{background:linear-gradient(90deg,#ffffff0a,#fff0);border:1px solid var(--border);border-radius:var(--radius);display:block;overflow:hidden;padding:14px 0;position:relative;width:100%}.skills-carousel:after,.skills-carousel:before{bottom:0;content:"";pointer-events:none;position:absolute;top:0;width:40px;z-index:1}.skills-carousel:before{background:linear-gradient(to right,var(--bg),#0000);left:0}.skills-carousel:after{background:linear-gradient(to left,var(--bg),#0000);right:0}.skills-track{align-items:center;animation:skills-marquee 24s linear infinite;display:flex;gap:12px;white-space:nowrap}.skills-carousel:hover .skills-track,.skills-track:focus-within{animation-play-state:paused}.skill-chip{align-items:center;background-color:var(--surface);border:1px solid var(--border);border-radius:999px;color:var(--fg);display:inline-flex;font-size:.86rem;font-weight:600;justify-content:center;letter-spacing:.02em;padding:9px 16px;text-transform:none;transition:transform var(--transition),box-shadow var(--transition),border-color var(--transition)}.skill-chip:hover{border-color:var(--primary);box-shadow:0 8px 20px #0000001f;transform:translateY(-2px)}@keyframes skills-marquee{0%{transform:translateX(0)}to{transform:translateX(-50%)}}.exp__list{gap:64px}.exp__item,.exp__list{display:flex;flex-direction:column}.exp__item{gap:16px}@media (min-width:768px){.exp__item{align-items:baseline;flex-direction:row;gap:48px}}.exp__date{color:var(--muted-fg);flex-shrink:0;font-family:var(--font-mono);font-size:12px;max-width:130px}.exp__role{color:var(--fg);font-family:var(--font-hero);font-size:clamp(1.4rem,2.5vw,1.9rem);font-weight:700;margin-bottom:8px;transition:color var(--transition)}.exp__item:hover .exp__role{color:var(--primary)}.exp__company{color:var(--fg);font-size:1.1rem;margin-bottom:16px;opacity:.6}.exp__desc{color:var(--muted-fg);font-size:1rem;line-height:1.7;max-width:640px}.projects__list{display:flex;flex-direction:column}.project__row{border-bottom:1px solid var(--border);color:inherit;display:block;padding:32px 0;position:relative;text-decoration:none;transition:background-color var(--transition),padding-left .25s ease}.project__row:first-child{padding-top:0}.project__row:last-child{border-bottom:none}.project__row:hover{padding-left:0}@media (max-width:767px){.project__row:hover{background-color:#00000008;border-radius:var(--radius);margin-left:-16px;padding-left:16px}}.project__header{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}@media (min-width:768px){.project__header{align-items:flex-end;flex-direction:row;justify-content:space-between}}.project__title{align-items:center;color:var(--fg);display:inline-flex;font-family:var(--font-hero);font-size:clamp(1.75rem,3.5vw,2.5rem);font-weight:700;gap:16px;transition:color var(--transition)}.project__row:hover .project__title{color:var(--primary)}.project-arrow{flex-shrink:0;opacity:0;transform:translateX(-16px);transition:opacity .3s ease,transform .3s ease}.project__row:hover .project-arrow{opacity:1;transform:translateX(0)}.project__stack{color:var(--muted-fg);flex-shrink:0;font-family:var(--font-mono);font-size:12px}.project__desc{color:var(--muted-fg);font-size:1.1rem;line-height:1.7;max-width:720px}.edu__list{gap:48px}.edu__item,.edu__list{display:flex;flex-direction:column}.edu__item{border-bottom:1px solid var(--border);gap:8px;justify-content:space-between;padding-bottom:32px}@media (min-width:768px){.edu__item{align-items:baseline;flex-direction:row}}.edu__degree{color:var(--fg);font-family:var(--font-hero);font-size:1.4rem;font-weight:700}.edu__meta{align-items:flex-start;display:flex;flex-direction:column;gap:4px}@media (min-width:768px){.edu__meta{align-items:flex-end}}.edu__school{color:var(--fg);font-size:1.1rem;opacity:.8}.edu__year{color:var(--muted-fg);font-family:var(--font-mono);font-size:12px}.games__header{margin-bottom:48px}.games__title{color:var(--fg);font-family:var(--font-hero);font-size:clamp(2rem,4vw,3.5rem);font-weight:800;margin-bottom:12px}.games__subtitle{color:var(--muted-fg);font-size:1.1rem}.games__grid{grid-gap:clamp(16px,3vw,32px);display:grid;gap:clamp(16px,3vw,32px);grid-template-columns:1fr;max-width:900px}@media (min-width:768px){.games__grid{grid-template-columns:repeat(2,1fr)}}@media (min-width:1024px){.games__grid{grid-template-columns:repeat(2,1fr)}}.game-card{align-items:center;background-color:var(--surface);border:1px solid var(--border);border-radius:var(--radius);display:flex;height:auto;justify-content:center;min-height:300px;overflow:hidden;padding:24px;transition:border-color var(--transition)}.game-card--snake:hover{border-color:#60a5fa4d}.game-card--memory:hover{border-color:#7eb3fb4d}.game-card--typing:hover{border-color:#e3dac966}@media (min-width:768px){.game-card{min-height:500px}}.contact{padding-bottom:clamp(96px,20vw,256px);padding-top:clamp(64px,15vw,192px)}@media (min-width:768px){.contact{padding-bottom:256px;padding-top:192px}}.contact__heading{cursor:default;font-family:var(--font-hero);font-size:clamp(2rem,7vw,6rem);font-weight:800;letter-spacing:-.04em;line-height:.95;margin-bottom:32px;transition:color var(--transition)}.contact__heading:hover{color:var(--primary)}.contact__body{display:flex;flex-direction:column;gap:48px;margin-top:48px}@media (min-width:768px){.contact__body{align-items:flex-start;flex-direction:row;justify-content:space-between}}.contact__email{border-bottom:2px solid var(--fg);font-size:clamp(1.25rem,3vw,2.25rem);font-weight:500;padding-bottom:4px;transition:color var(--transition),border-color var(--transition)}.contact__email:hover{border-color:var(--primary);color:var(--primary)}.contact__socials{display:flex;flex-direction:column;gap:16px}.social-link{align-items:center;color:var(--muted-fg);display:flex;font-family:var(--font-mono);font-size:1rem;gap:8px;transition:color var(--transition)}.social-link:hover{color:var(--fg)}.social-link .btn-icon{opacity:0;transform:translateX(-8px);transition:opacity var(--transition),transform var(--transition)}.social-link:hover .btn-icon{opacity:1;transform:translateX(0)}.footer{border-top:1px solid var(--border);color:var(--muted-fg);font-family:var(--font-mono);font-size:13px;padding:32px 48px;text-align:center}
/*# sourceMappingURL=main.aae914f4.css.map*/