.menu-wrap{width:100%;height:100%;overflow:hidden}.menu{display:flex;flex-direction:column;height:100%;margin:0;padding:0}.menu__item{flex:1;position:relative;overflow:hidden;text-align:center;box-shadow:0 -1px #fff}.menu__item-link{display:flex;align-items:center;justify-content:center;height:100%;position:relative;cursor:pointer;text-transform:uppercase;text-decoration:none;white-space:nowrap;font-weight:600;color:#fff;font-size:4vh}.menu__item-link:hover{color:#060010}.menu__item-link:focus:not(:focus-visible){color:#fff}.marquee{position:absolute;top:0;left:0;overflow:hidden;width:100%;height:100%;pointer-events:none;background:#fff;transform:translate3d(0,101%,0);transition:transform .6s ease-expo}.marquee__inner-wrap{height:100%;width:200%;display:flex;transform:translate(0)}.marquee__inner{display:flex;align-items:center;position:relative;height:100%;width:200%;will-change:transform;animation:marquee 15s linear infinite}.marquee span{color:#060010;white-space:nowrap;text-transform:uppercase;font-weight:400;font-size:4vh;line-height:1.2;padding:1vh 4vw 0}.marquee__img{width:200px;height:7vh;margin:2em 2vw;padding:1em 0;border-radius:50px;background-size:cover;background-position:50% 50%}.menu__item-link:hover+.marquee{transform:translateZ(0)}@keyframes marquee{0%{transform:translate(0)}to{transform:translate(-50%)}}.project-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem 1rem 3rem}.project-layout{display:flex;flex-direction:row;align-items:center;justify-content:center;gap:3rem;max-width:1600px;width:100%;margin:0 auto}.project-gallery-scroll{display:flex;flex-direction:row;gap:3rem;overflow-x:auto;padding-bottom:1.5rem;scrollbar-width:thin;scrollbar-color:#888 #222;max-width:90vw;min-height:400px;align-items:center}.project-image-scroll{max-width:90vw;min-width:600px;min-height:400px;max-height:80vh;object-fit:cover;border-radius:0;box-shadow:none;background:none;display:block}.project-info{flex-basis:30%;display:flex;flex-direction:column;justify-content:center;align-items:flex-start;text-align:left;gap:1.5rem;min-width:220px}.project-title{font-size:2.5rem;font-weight:700;margin:0}.project-description{font-size:1.2rem;color:#ccc;margin:0}.project-stack{font-size:1.1rem;color:#aaa;margin:0}.project-page-vertical{max-width:1400px;margin:0 auto;padding:3rem 1rem 5rem;display:flex;flex-direction:column;gap:4rem;position:relative}.project-section-row{display:flex;flex-direction:row;align-items:center;gap:3rem;width:100%}.project-section-row.reversed{flex-direction:row-reverse}.project-section-image-wrap{flex-basis:70%;display:flex;align-items:center;justify-content:center}.project-section-image-wrap.double{display:flex;flex-direction:row;gap:2rem}.project-section-image{width:100%;max-width:1200px;min-width:600px;max-height:80vh;object-fit:cover;border-radius:0;box-shadow:none;background:none;display:block}.project-section-image.half{max-width:48%;min-width:0}.project-section-info{flex-basis:30%;display:flex;flex-direction:column;justify-content:center;align-items:flex-start;text-align:left;gap:1.5rem;min-width:220px}.project-header{text-align:center;margin-top:3.5rem;margin-bottom:5rem}.project-header-title{font-size:3rem;font-weight:800;margin-bottom:1.2rem}.project-header-description{font-size:1.3rem;color:#ccc;margin-bottom:.8rem}.project-header-stack{font-size:1.1rem;color:#aaa;margin-bottom:0}.project-back-btn{position:absolute;top:2rem;left:2rem;z-index:10;background:none;color:#fff;border-radius:0;padding:.7em 1.3em;font-size:1.1rem;font-weight:600;border:none;cursor:pointer;transition:color .2s,background .2s;opacity:.92;text-decoration:none;box-shadow:none;outline:none;text-transform:lowercase;letter-spacing:.04em}.project-back-btn:hover{background:#222;color:#fff;opacity:1}@media (max-width: 900px){.project-header-title{font-size:2rem}.project-header-description{font-size:1.05rem}.project-back-btn{top:1rem;left:1rem;font-size:1rem;padding:.5em 1em}}@media (max-width: 1200px){.project-image-scroll{min-width:400px;min-height:250px}.project-section-image{min-width:400px}}@media (max-width: 900px){.project-layout{flex-direction:column;gap:2rem}.project-info{align-items:center;text-align:center}.project-gallery-scroll{max-width:100vw;min-width:0;min-height:200px;gap:1.2rem}.project-image-scroll{min-width:220px;min-height:120px;max-width:100vw;max-height:40vh}.project-section-row,.project-section-row.reversed{flex-direction:column;gap:2rem}.project-section-image-wrap,.project-section-info{flex-basis:auto;width:100%;align-items:center;text-align:center}.project-section-image-wrap.double{flex-direction:column;gap:1rem}.project-section-image.half{max-width:100%;min-width:0}.project-section-image{min-width:220px;max-width:100vw;max-height:40vh}.project-section-info{align-items:center}.project-title{font-size:2rem}}.project-page-horizontal{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;position:relative;padding:2rem 1rem 3rem}.project-image-scroll-large{min-width:900px;max-width:1200px;min-height:500px;max-height:90vh;width:100%;object-fit:cover;border-radius:0;box-shadow:none;background:none;display:block}@media (max-width: 1200px){.project-image-scroll-large{min-width:400px;min-height:250px}}@media (max-width: 900px){.project-image-scroll-large{min-width:220px;min-height:120px;max-width:100vw;max-height:40vh}}.mobile-app-image{object-fit:contain;max-width:500px;max-height:60vh;min-width:0;min-height:0;width:100%;height:auto;display:block;border-radius:0;box-shadow:none;background:none;margin:0}@media (max-width: 900px){.mobile-app-image{max-width:90vw;max-height:40vh}}.scroll-hint{display:flex;align-items:center;justify-content:center;gap:.5em;margin-top:1.5rem;font-size:1.15rem;color:#aaa;opacity:.85;animation:scrollhint-fade 2s infinite alternate;-webkit-user-select:none;user-select:none}.scroll-hint-arrow{font-size:1.7em;animation:scrollhint-arrow-move 1.2s infinite alternate}@keyframes scrollhint-fade{0%{opacity:.5}to{opacity:1}}@keyframes scrollhint-arrow-move{0%{transform:translate(0)}to{transform:translate(18px)}}*{margin:0;padding:0;box-sizing:border-box}.inter-light{font-family:Inter,sans-serif;font-optical-sizing:auto;font-weight:300;font-style:normal}.inter-regular{font-family:Inter,sans-serif;font-optical-sizing:auto;font-weight:400;font-style:normal}.inter-medium{font-family:Inter,sans-serif;font-optical-sizing:auto;font-weight:500;font-style:normal}.inter-semibold{font-family:Inter,sans-serif;font-optical-sizing:auto;font-weight:600;font-style:normal}.inter-bold{font-family:Inter,sans-serif;font-optical-sizing:auto;font-weight:700;font-style:normal}.inter-black{font-family:Inter,sans-serif;font-optical-sizing:auto;font-weight:900;font-style:normal}html{scroll-behavior:smooth}body{font-family:Inter,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#000;color:#fff;line-height:1.6;min-height:100vh;overflow-x:hidden}#root{min-height:100vh}.app{min-height:100vh;max-width:1200px;margin:0 auto;padding:0 20px}.header{padding:3rem 0;text-align:center;border-bottom:1px solid #333}.header h1{font-size:3rem;margin-bottom:1rem;letter-spacing:-.02em}.main{padding:4rem 0}.hero{text-align:center;margin-bottom:6rem;padding:3rem 0}.hero h2{font-size:2.5rem;margin-bottom:2rem;color:#fff}.hero p{font-size:1.3rem;color:#ccc;max-width:700px;margin:0 auto;line-height:1.7}.content{max-width:800px;margin:0 auto;padding:2rem 0}.content h3{font-size:1.8rem;margin-bottom:1.5rem;margin-top:3rem;color:#fff}.content p{margin-bottom:2rem;color:#ccc;font-size:1.2rem;line-height:1.8}.content ul{list-style:none;padding-left:0;margin-bottom:2rem}.content li{color:#ccc;font-size:1.1rem;position:relative;padding:.8rem 0 .8rem 2rem}.content li:before{content:"→";position:absolute;left:0;color:#fff;font-weight:600}.skills-section{margin:4rem 0;padding:3rem 0;border-top:1px solid #333}.magic-bento-section{margin:4rem 0;padding:3rem 0;text-align:center;border-top:1px solid #333}.magic-bento-section h3{margin-bottom:1rem;color:#fff}.magic-bento-section p{margin-bottom:2rem;color:#ccc;max-width:600px;margin-left:auto;margin-right:auto}.flowing-menu-section{margin:4rem 0;padding:3rem 0;text-align:center;border-top:1px solid #333}.flowing-menu-section h3{margin-bottom:1rem;color:#fff}.flowing-menu-section p{margin-bottom:2rem;color:#ccc;max-width:600px;margin-left:auto;margin-right:auto}.flowing-menu-container{max-width:800px;height:400px;margin:0 auto;border-radius:20px;overflow:hidden;box-shadow:0 10px 30px #0000004d}.experience-section,.contact-section{margin:4rem 0;padding:3rem 0;border-top:1px solid #333}.skills-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem;margin-top:2rem}.skill-card{background:#111;padding:2rem;border-radius:8px;border:1px solid #333}.skill-card h4{margin-bottom:1rem;color:#fff}.experience-item{margin-bottom:3rem;padding:2rem;background:#111;border-radius:8px;border:1px solid #333}.experience-item h4{margin-bottom:.5rem;color:#fff}.experience-item .company{color:#888;margin-bottom:1rem}.contact-info{text-align:center;padding:2rem;background:#111;border-radius:8px;border:1px solid #333}.contact-info a{color:#fff;text-decoration:none;border-bottom:1px solid #333;transition:border-color .3s ease}.contact-info a:hover{border-color:#fff}.footer{padding:3rem 0;text-align:center;border-top:1px solid #333;margin-top:4rem}.footer p{color:#888;font-size:.9rem}@media (max-width: 768px){.header h1{font-size:2.2rem}.hero h2{font-size:2rem}.hero p{font-size:1.1rem}.app{padding:0 15px}.main{padding:2rem 0}.hero{margin-bottom:4rem;padding:2rem 0}.skills-grid{grid-template-columns:1fr}.content h3{font-size:1.5rem}}@media (max-width: 480px){.header h1{font-size:1.8rem}.hero h2{font-size:1.6rem}.content p{font-size:1rem}}
