*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#111;--bg-hover:#191919;--border:#222;--text:#e8e4de;--text-dim:#8a857e;--text-faint:#5a5650;--warm:#c9956b;--font:"Inter", -apple-system, BlinkMacSystemFont, sans-serif;--mono:"JetBrains Mono", monospace}html{scroll-behavior:smooth;font-size:16px}body{font-family:var(--font);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;line-height:1.6;overflow-x:hidden}a{color:inherit;text-decoration:none}ul,ol{list-style:none}img{max-width:100%;display:block}button{cursor:pointer;color:inherit;background:0 0;border:none;font-family:inherit}::selection{background:var(--warm);color:#111}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:#333;border-radius:3px}.section{padding:80px 0}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.animate-fade-in-up{opacity:0;animation:.6s forwards fadeInUp}.animate-fade-in-up.delay-1{animation-delay:.1s}.animate-fade-in-up.delay-2{animation-delay:.2s}.animate-fade-in-up.delay-3{animation-delay:.3s}.animate-fade-in-up.delay-4{animation-delay:.4s}.app-content{z-index:1;opacity:0;transition:opacity 1s;position:relative}.app-content--visible{opacity:1}.app-content--hidden{pointer-events:none}.nav{z-index:100;padding:20px 0;transition:all .3s;position:fixed;top:0;left:0;right:0}.nav--scrolled{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--border);background:#111111f2;padding:14px 0}.nav__inner{justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto;padding:0 48px;display:flex}.nav__logo{font-family:var(--mono);color:var(--text);font-size:.9rem}.nav__logo-dot{color:var(--warm)}.nav__links{gap:28px;display:flex}.nav__link{color:var(--text-faint);font-size:.85rem;transition:color .2s}.nav__link:hover{color:var(--text)}.nav__burger{flex-direction:column;gap:5px;padding:8px;display:none}.nav__burger span{background:var(--text);width:18px;height:1.5px;transition:all .3s}.nav__burger--open span:first-child{transform:rotate(45deg)translate(3px,3px)}.nav__burger--open span:last-child{transform:rotate(-45deg)translate(3px,-3px)}.hero{align-items:center;min-height:100vh;padding:100px 0 60px;display:flex}.hero__inner{grid-template-columns:1fr auto;align-items:center;gap:60px;width:100%;max-width:1200px;margin:0 auto;padding:0 48px;display:grid}.hero__left{max-width:560px}.hero__right{justify-content:center;align-items:center;display:flex}.hero__header{align-items:center;gap:20px;margin-bottom:28px;display:flex}.hero__photo{flex-shrink:0}.hero__photo-img{object-fit:cover;border:1px solid var(--border);border-radius:50%;width:110px;height:110px;display:block}.hero__photo-placeholder{background:#ffffff05;border:1px dashed #333;border-radius:50%;justify-content:center;align-items:center;width:110px;height:110px;display:none}.hero__photo-placeholder span{color:var(--text-faint);font-size:.65rem}.hero__name{letter-spacing:-.03em;color:var(--text);margin-bottom:2px;font-size:2rem;font-weight:600;line-height:1.15}.hero__role{color:var(--text-faint);font-size:.85rem}.hero__bio{color:var(--text-dim);margin-bottom:24px;font-size:1rem;line-height:1.85}.hero__contact{flex-wrap:wrap;align-items:center;gap:24px;margin-top:32px;display:flex}.hero__contact a,.hero__contact-loc{color:var(--text-faint);font-size:.875rem;text-decoration:none;transition:all .2s}.hero__contact a:hover{color:var(--warm)}.hero__cv-link{border-bottom:1px solid var(--warm);padding-bottom:2px;font-weight:600;color:var(--warm)!important}.hero__cv-link:hover{background:var(--warm);border-radius:2px;padding:2px 6px;color:var(--bg)!important}@media (width<=1024px){.hero__footer{flex-direction:column;gap:20px;margin-top:32px}.hero__divider{display:none}}.snakegame{transform-origin:top;flex-direction:column;align-items:center;gap:16px;margin-bottom:-98.56px;display:flex;transform:scale(.72)}.snakegame__card{border:1px solid var(--border);background:#0e0e0e;border-radius:12px;padding:12px;transition:border-color .3s;box-shadow:0 10px 30px #00000080}.snakegame__card:hover{border-color:#333}.snakegame__header{font-family:var(--mono);color:var(--text-faint);justify-content:space-between;align-items:center;margin-bottom:8px;font-size:.7rem;display:flex}.snakegame__score{color:var(--warm);letter-spacing:.05em}.snakegame__canvas{cursor:pointer;border-radius:6px;outline:none;display:block}.snakegame__collected{flex-wrap:wrap;justify-content:center;gap:8px;max-width:400px;margin-top:20px;animation:.5s fadeIn;display:flex}.snakegame__tag{color:var(--text-faint);font-size:.7rem;font-family:var(--mono);opacity:.4;background:#ffffff05;border:1px solid #ffffff0d;border-radius:6px;padding:4px 10px;transition:all .3s}.snakegame__tag--active{opacity:1;background:var(--bg-hover);border-color:var(--color);color:var(--color);box-shadow:0 0 10px var(--color)}.snakegame--playing{z-index:10;margin-bottom:0;transform:scale(1)}.snakegame__main-area{align-items:center;gap:32px;display:flex;position:relative}.snakegame__hint-panel{flex-direction:column;gap:12px;min-width:140px;animation:.5s fadeIn;display:flex}.hint-label{font-family:var(--mono);color:var(--text-faint);letter-spacing:.1em;font-size:.65rem}.hint-keys{flex-direction:column;gap:16px;display:flex}.hint-group{flex-direction:column;gap:6px;display:flex}.hint-sep{font-family:var(--mono);color:#333;letter-spacing:.1em;font-size:.55rem}.hint-row{justify-content:center;gap:6px;display:flex}.key{border:1px solid var(--border);width:28px;height:28px;font-size:.75rem;font-family:var(--mono);color:var(--text-dim);background:#ffffff08;border-radius:4px;justify-content:center;align-items:center;display:flex}.snakegame__close{border:1px solid var(--border);width:100%;color:var(--text-faint);font-family:var(--mono);letter-spacing:.1em;cursor:pointer;background:0 0;border-radius:4px;margin-top:16px;padding:8px;font-size:.7rem;transition:all .2s;display:block}.snakegame__close:hover{background:var(--warm);color:var(--bg);border-color:var(--warm)}.minigame__dpad{flex-direction:column;align-items:center;gap:8px;margin-top:24px;display:flex}.minigame__dpad-row{gap:8px;display:flex}.minigame__dpad-btn{border:1px solid var(--border);width:56px;height:56px;color:var(--text-dim);cursor:pointer;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;background:#ffffff08;border-radius:12px;justify-content:center;align-items:center;font-size:1.4rem;display:flex}.minigame__dpad-btn:active{background:var(--warm);color:var(--bg);border-color:var(--warm)}@media (width>=1025px){.minigame__dpad{display:none}}@media (width<=1024px){.snakegame{margin-bottom:0;transform:scale(.85)}.snakegame--playing{transform:scale(1)}.snakegame__main-area{flex-direction:column;gap:16px}.snakegame__hint-panel{display:none}}.container{max-width:1200px;margin:0 auto;padding:0 48px}.about__heading,.experience__heading,.skills__heading,.projects__heading,.footer__heading{letter-spacing:-.02em;color:var(--text);margin-bottom:32px;font-size:1.3rem;font-weight:600}.about__content{max-width:640px}.about__text p{color:var(--text-dim);margin-bottom:16px;font-size:.95rem;line-height:1.85}.about__text p:last-child{margin-bottom:0}.about__text strong{color:var(--text);font-weight:500}.experience__list{flex-direction:column;display:flex}.experience__item{border-top:1px solid var(--border);grid-template-columns:200px 1fr;gap:40px;padding:32px 0;display:grid}.experience__item:last-child{border-bottom:1px solid var(--border)}.experience__meta{flex-direction:column;gap:4px;display:flex}.experience__date,.experience__loc{color:var(--text-faint);font-size:.8rem}.experience__company{margin-bottom:2px;font-size:1.1rem;font-weight:600}.experience__role{color:var(--warm);margin-bottom:14px;font-size:.8rem}.experience__desc{color:var(--text-dim);margin-bottom:12px;font-size:.9rem;line-height:1.75}.experience__tech{color:var(--text-faint);font-size:.8rem}.skills__content{grid-template-columns:repeat(3,1fr);gap:0;display:grid}.skills__group{border-top:1px solid var(--border);padding:22px 0}.skills__group:nth-child(n+4){border-bottom:1px solid var(--border)}.skills__group:nth-child(3n+2){border-left:1px solid var(--border);border-right:1px solid var(--border);padding-left:36px;padding-right:36px}.skills__group-title{color:var(--text);margin-bottom:6px;font-size:.8rem;font-weight:600}.skills__group-items{color:var(--text-faint);font-size:.85rem;line-height:1.6}.projects__list{grid-template-columns:repeat(2,1fr);gap:32px;display:grid}.projects__item{background:var(--bg-offset);border:1px solid var(--border);cursor:pointer;border-radius:12px;padding:40px;transition:all .4s cubic-bezier(.16,1,.3,1);position:relative;overflow:hidden}.projects__item:hover{border-color:var(--warm);background:#161616;transform:translateY(-8px);box-shadow:0 20px 40px #0006}.projects__item-num{font-family:var(--mono);color:var(--warm);margin-bottom:24px;font-size:.75rem;display:block}.projects__item-title{color:var(--text);margin-bottom:12px;font-size:1.5rem;font-weight:700}.projects__item-desc{color:var(--text-dim);margin-bottom:32px;font-size:.95rem;line-height:1.6}.projects__item-footer{border-top:1px solid var(--border);justify-content:space-between;align-items:center;padding-top:24px;display:flex}.projects__item-tech{font-family:var(--mono);color:var(--text-faint);font-size:.7rem}.projects__item-more{color:var(--warm);letter-spacing:.05em;opacity:0;font-size:.7rem;font-weight:700;transition:all .3s;transform:translate(-10px)}.projects__item:hover .projects__item-more{opacity:1;transform:translate(0)}.project-modal{z-index:1000;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0a0a0af2;justify-content:center;align-items:center;padding:40px;animation:.4s fadeIn;display:flex;position:fixed;inset:0}.project-modal__content{border:1px solid var(--border);background:#111;border-radius:16px;width:100%;max-width:1000px;max-height:90vh;animation:.5s cubic-bezier(.16,1,.3,1) modalScale;position:relative;overflow-y:auto}@keyframes modalScale{0%{opacity:0;transform:scale(.95)translateY(20px)}to{opacity:1;transform:scale(1)translateY(0)}}.project-modal__close{color:var(--text-faint);z-index:10;font-size:2rem;transition:color .3s;position:absolute;top:24px;right:24px}.project-modal__close:hover{color:var(--text)}.project-modal__body{flex-direction:column;display:flex}.project-modal__image-wrapper{border-bottom:1px solid var(--border);background:#000;justify-content:center;align-items:center;width:100%;display:flex}.project-modal__image{object-fit:contain;max-width:100%;height:auto;max-height:500px}.project-modal__info{padding:48px}.project-modal__num{font-family:var(--mono);color:var(--warm);margin-bottom:16px;font-size:.8rem;display:block}.project-modal__title{margin-bottom:24px;font-size:2.5rem;font-weight:800}.project-modal__tech-tags{flex-wrap:wrap;gap:12px;margin-bottom:32px;display:flex}.project-modal__tag{font-family:var(--mono);border:1px solid var(--border);background:#ffffff0d;border-radius:4px;padding:6px 14px;font-size:.75rem}.project-modal__desc{color:var(--text-dim);margin-bottom:48px;font-size:1.1rem;line-height:1.8}.project-modal__actions{gap:24px;display:flex}@media (width>=900px){.project-modal__body{flex-direction:row}.project-modal__image-wrapper{border-bottom:none;border-right:1px solid var(--border);flex:1}.project-modal__info{flex:1;padding:64px}}@media (width<=768px){.projects__list{grid-template-columns:1fr}.project-modal{padding:0}.project-modal__content{border-radius:0;height:100%;max-height:100vh}.project-modal__title{font-size:1.8rem}.project-modal__info{padding:32px}}.footer{margin-top:20px;padding:60px 0 36px}.footer__main{border-bottom:1px solid var(--border);grid-template-columns:1fr 1fr;gap:60px;padding-bottom:48px;display:grid}.footer__text{color:var(--text-dim);font-size:.9rem;line-height:1.7}.footer__right{flex-direction:column;justify-content:center;gap:10px;display:flex}.footer__contact-link{color:var(--text-dim);width:fit-content;font-size:.9rem;transition:color .2s;display:inline-block}.footer__contact-link:hover{color:var(--warm)}.footer__social-row{gap:20px;margin-top:4px;display:flex}.footer__social-link{color:var(--text-faint);font-size:.85rem;transition:color .2s}.footer__social-link:hover{color:var(--text)}.footer__bottom{justify-content:space-between;padding-top:20px;display:flex}.footer__bottom span{color:var(--text-faint);font-size:.75rem}@media (width<=1024px){.hero__inner{text-align:center;grid-template-columns:1fr;gap:48px}.hero__contact{justify-content:center}.hero__photo-img,.hero__photo-placeholder{width:130px;height:130px}.projects__list{grid-template-columns:1fr}.footer__main{grid-template-columns:1fr;gap:32px}}@media (width<=768px){.nav__inner,.hero__inner,.container{padding:0 24px}.nav__links{background:#111111fa;flex-direction:column;justify-content:center;align-items:center;gap:24px;display:none;position:fixed;inset:0}.nav__links--open{display:flex}.nav__link{font-size:1.3rem}.nav__burger{display:flex}.hero{min-height:auto;padding-top:120px;padding-bottom:40px}.hero__name{font-size:2.2rem}.hero__photo-img,.hero__photo-placeholder{width:110px;height:110px}.experience__item{grid-template-columns:1fr;gap:6px}.skills__content{grid-template-columns:1fr}.skills__group:nth-child(3n+2){border-left:none;border-right:none;padding-left:0;padding-right:0}.footer__bottom{flex-direction:column;gap:4px}.section{padding:60px 0}}@media (width<=480px){.hero__name{font-size:1.8rem}.hero__contact{flex-direction:column;gap:8px}}.onboarding{background:var(--bg);z-index:9999;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.onboarding__content{text-align:center;animation:3s ease-in-out forwards splashFade}.onboarding__icon{object-fit:contain;width:20vmin;min-width:120px;max-width:240px;height:20vmin;margin-bottom:32px;margin-left:auto;margin-right:auto;display:block}.onboarding__title{font-family:var(--mono);letter-spacing:.35em;color:var(--warm);font-size:1.4rem;font-weight:700;animation:3s ease-in-out forwards titleScale}@keyframes titleScale{0%{opacity:0;transform:scale(.9)}15%{opacity:1;transform:scale(1)}85%{opacity:1;transform:scale(1.02)}to{opacity:0;transform:scale(1.05)}}@keyframes splashFade{0%{opacity:0;transform:scale(.95)}15%{opacity:1;transform:scale(1)}85%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(1.05)}}
