:root{font-family:Manrope,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:var(--bg-dark);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{width:100%;min-height:100dvh}#modal-root{position:fixed;inset:0;z-index:10000;pointer-events:none}#modal-root>*{pointer-events:auto}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}a{font-weight:500;color:var(--text-accent);text-decoration:inherit}a:hover{color:var(--text-accent)}body{margin:0;color:var(--text-main);min-width:320px;min-height:100dvh;width:100%;overflow-x:hidden;overflow-x:clip}h1{font-size:3.2em;line-height:1.1}@media(prefers-color-scheme:light){:root{color:var(--text-main)}a:hover{color:var(--text-accent)}button{background-color:var(--bg-light)}}html{scrollbar-width:auto;scrollbar-color:var(--text-accent) var(--bg-dark)}::-webkit-scrollbar{width:10px}::-webkit-scrollbar-track{background:var(--bg-dark)}::-webkit-scrollbar-thumb{background:var(--text-accent);border-radius:5px}::-webkit-scrollbar-thumb:hover{background:var(--text-main)}@media(max-width:768px){body{width:100%;max-width:100%}}html.lenis,html.lenis body{height:auto}.lenis:not(.lenis-autoToggle).lenis-stopped{overflow:clip}.lenis [data-lenis-prevent],.lenis [data-lenis-prevent-wheel],.lenis [data-lenis-prevent-touch]{overscroll-behavior:contain}.lenis.lenis-smooth iframe{pointer-events:none}.lenis.lenis-autoToggle{transition-property:overflow;transition-duration:1ms;transition-behavior:allow-discrete}.aboutme{display:flex;justify-content:center;align-items:center;width:100%;box-sizing:border-box}.aboutme-container{width:100%;max-width:1200px;display:flex;gap:clamp(1.5rem,4vw,3rem);align-items:center;box-sizing:border-box;margin:0 auto}.aboutme-left{flex:1;display:flex;justify-content:center;min-width:0}.aboutme-photo{width:100%;max-width:280px;aspect-ratio:3/4;border-radius:16px;overflow:hidden;position:relative;background:rgba(var(--text-main-rgb),.05);box-shadow:0 10px 30px #0000001a;min-width:6.25rem;min-height:12rem}.aboutme-photo img{width:100%;height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.4,0,.2,1);will-change:transform}.aboutme-photo:hover img{transform:scale(1.05)}.aboutme-photo-placeholder{width:100%;height:100%;background:linear-gradient(90deg,rgba(var(--text-main-rgb),.05) 25%,rgba(var(--text-accent-rgb),.1),rgba(var(--text-main-rgb),.05) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;will-change:background-position}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.aboutme-photo-error{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:2rem;color:var(--text-disabled);background:rgba(var(--text-main-rgb),.1)}.aboutme-right{flex:1.5;min-width:0;display:flex;flex-direction:column;align-items:flex-start;gap:1.2rem}.aboutme-title{margin:0;font-size:clamp(1.8rem,5vw,2.4rem);font-weight:900;line-height:1.2;width:100%}.aboutme-text{margin:0;max-width:100%;opacity:.85;line-height:1.7;font-size:clamp(.9rem,2.5vw,1rem);color:var(--text-main)}.aboutme-stats{display:flex;gap:clamp(1rem,3vw,2rem);margin-top:1rem;flex-wrap:wrap;width:100%}.stat{display:flex;flex-direction:column;align-items:center;flex:1;min-width:70px;color:var(--text-muted)}.stat-number{font-size:clamp(1.4rem,3vw,1.8rem);font-weight:800;color:var(--text-accent);line-height:1.2}.stat-label{font-size:clamp(.75rem,2vw,.9rem);opacity:.7;margin-top:.25rem;text-align:center;text-transform:uppercase;letter-spacing:.5px}@media(min-width:1200px){.aboutme-container{padding-right:2rem}.aboutme-photo{max-width:300px}}@media(max-width:900px){.aboutme-container{flex-direction:column;text-align:center;gap:2rem}.aboutme-right{align-items:center;text-align:center}.aboutme-text{max-width:90%}.aboutme-stats{justify-content:center}.aboutme-photo{max-width:250px}}@media(max-width:768px){.aboutme-container{gap:1.8rem}.aboutme-text{max-width:95%;font-size:.95rem}.aboutme-stats{gap:1.2rem}.stat{min-width:60px}.stat-number{font-size:1.5rem}.stat-label{font-size:.8rem}}@media(max-width:480px){.aboutme-container{gap:1.5rem}.aboutme-photo{max-width:220px}.aboutme-title{font-size:2rem}.aboutme-text{font-size:.9rem;line-height:1.5;max-width:100%}.aboutme-stats{gap:.8rem}.stat{min-width:55px}.stat-number{font-size:1.3rem}.stat-label{font-size:.7rem}}@media(max-width:360px){.aboutme-photo{max-width:180px}.aboutme-title{font-size:1.6rem}.aboutme-stats{flex-direction:column;gap:1rem;align-items:center}.stat{min-width:80px}}@media(max-height:600px)and (orientation:landscape){.aboutme-container{flex-direction:row;gap:1.5rem}.aboutme-photo{max-width:180px}.aboutme-right{align-items:flex-start;text-align:left}.aboutme-text{max-width:100%}}.contact-container{display:flex;flex-direction:column;gap:clamp(18px,2vw,28px);width:100%;max-width:100%;box-sizing:border-box}.contact-header{display:flex;flex-direction:column;gap:12px}.contact-title{margin:0;font-size:clamp(1.3rem,2.2vw,1.6rem);font-weight:700;color:var(--text-main)}.contact-subtitle{margin:0;font-size:clamp(.92rem,1.3vw,1rem);color:var(--text-main);opacity:.75;line-height:1.6;max-width:62ch}.contact-methods{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:clamp(12px,1.4vw,16px);width:100%}.contact-card{--method-color: var(--text-accent);display:flex;flex-direction:column;gap:10px;min-height:clamp(160px,18vw,178px);padding:clamp(14px,1.6vw,18px);background:rgba(var(--text-accent-rgb),.03);border:1px solid rgba(var(--text-accent-rgb),.12);border-radius:12px;text-decoration:none;transition:transform .24s cubic-bezier(.4,0,.2,1),box-shadow .24s cubic-bezier(.4,0,.2,1),border-color .24s ease;position:relative;overflow:hidden;color:inherit}.contact-card--button{width:100%;text-align:left;cursor:pointer;appearance:none;font:inherit}.contact-card:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(var(--text-accent-rgb),.32),transparent)}.contact-card:hover,.contact-card:focus-visible{background:rgba(var(--text-accent-rgb),.06);border-color:rgba(var(--text-accent-rgb),.2);transform:translateY(-3px);box-shadow:0 10px 26px rgba(var(--text-accent-rgb),.08)}.contact-card:focus-visible{outline:2px solid var(--text-accent);outline-offset:2px}.contact-card-header{display:flex;align-items:center;gap:10px}.contact-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:10px;flex-shrink:0;color:#fff;font-size:1.24rem;background:var(--method-color);box-shadow:inset 0 1px #fff3;transition:transform .22s ease}.contact-card:hover .contact-icon{transform:scale(1.05)}.contact-method-title{margin:0;font-size:1rem;font-weight:700;color:var(--text-main)}.contact-description{margin:0;font-size:clamp(.84rem,1.1vw,.9rem);color:var(--text-main);opacity:.75;line-height:1.45;flex:1}.contact-value{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:start;gap:8px;margin-top:auto;padding-top:8px;border-top:1px solid rgba(var(--text-accent-rgb),.1)}.contact-value-text{font-size:.82rem;font-weight:600;color:var(--text-accent);line-height:1.4;overflow-wrap:anywhere;word-break:break-word}.contact-arrow{color:var(--text-disabled);margin-left:8px;flex-shrink:0;transition:transform .2s ease,color .2s ease}.contact-card:hover .contact-arrow{color:var(--text-accent);transform:translate(3px)}.contact-footer{display:flex;justify-content:center;padding:16px;background:rgba(var(--text-accent-rgb),.02);border:1px solid rgba(var(--text-accent-rgb),.08);border-radius:12px}.contact-footer-text{margin:0;font-size:clamp(.86rem,1.2vw,.92rem);color:var(--text-main);opacity:.8;line-height:1.5;text-align:center;max-width:64ch}@media(max-width:900px){.contact-methods{grid-template-columns:1fr}.contact-card{min-height:initial}}@media(max-width:768px){.contact-container{gap:20px}.contact-title{font-size:1.3rem}.contact-subtitle{font-size:.95rem}.contact-methods{grid-template-columns:1fr}.contact-card{padding:14px}.contact-icon{width:36px;height:36px;font-size:1.1rem}.contact-method-title{font-size:.98rem}.contact-value-text{font-size:.8rem}}@media(max-width:480px){.contact-container{gap:16px}.contact-header{gap:10px}.contact-title{font-size:1.2rem}.contact-subtitle{font-size:.9rem;line-height:1.5}.contact-card{padding:12px;border-radius:10px;gap:8px}.contact-icon{width:34px;height:34px;font-size:1rem;border-radius:8px}.contact-method-title{font-size:.94rem}.contact-description{font-size:.8rem}.contact-footer{padding:12px;border-radius:10px}.contact-footer-text{font-size:.84rem}}@media(max-width:360px){.contact-card{padding:10px}.contact-value{gap:6px}.contact-arrow{margin-left:4px}}@media(hover:none){.contact-card:hover{transform:none;box-shadow:none}.contact-card:active{background:rgba(var(--text-accent-rgb),.06);border-color:rgba(var(--text-accent-rgb),.2)}.contact-card:hover .contact-icon,.contact-card:hover .contact-arrow{transform:none}}@media(prefers-reduced-motion:reduce){.contact-card,.contact-icon,.contact-arrow{transition:none}}.projects-section{display:flex;flex-direction:column;gap:24px;width:100%;max-width:100%;overflow-x:hidden;box-sizing:border-box}.projects-header{display:flex;justify-content:space-between;padding:0 8px 0 0;align-items:center;flex-wrap:wrap;gap:16px}.projects-title{margin:0;font-size:1.5rem;font-weight:700;color:var(--text-main);word-break:break-word}.projects-link{display:inline-flex;align-items:center;gap:4px;font-size:.9rem;font-weight:500;color:var(--text-disabled);text-decoration:none;transition:all .3s cubic-bezier(.4,0,.2,1);padding:8px 12px;border-radius:6px;white-space:nowrap;flex-shrink:0}.projects-link:hover{color:var(--text-accent);background:rgba(var(--text-accent-rgb),.06);transform:translate(2px)}.projects{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;width:100%;max-width:920px;margin:0 auto;padding-left:0;box-sizing:border-box}@media(max-width:480px){.projects-header{flex-direction:column;align-items:flex-start}.projects-link{align-self:flex-start}.projects{gap:12px;grid-template-columns:1fr}}@media(min-width:481px)and (max-width:768px){.projects{gap:12px;grid-template-columns:1fr}}@media(min-width:769px)and (max-width:1024px){.projects{gap:14px;grid-template-columns:repeat(2,minmax(0,1fr));max-width:100%}}@media(min-width:769px)and (max-width:777px){.projects{grid-template-columns:1fr}}@media(max-height:890px)and (orientation:landscape){.projects{gap:16px}}.work-container,.work-container *{box-sizing:border-box}.work-container{display:flex;flex-direction:column;gap:24px;width:100%;max-width:100%;overflow-x:hidden}.work-title{margin:0;font-size:1.5rem;font-weight:700;color:var(--text-main);word-wrap:break-word}.work-experience{display:flex;flex-direction:row;gap:40px;width:100%;max-width:100%}.work-nav{display:flex;flex-direction:column;gap:12px;flex-shrink:0;min-width:180px;background:none;border:none;border-radius:0}.work-nav button,.work-nav .work-nav-button{white-space:nowrap;text-align:left;max-width:100%;overflow:hidden;text-overflow:ellipsis}.work-details{display:flex;flex-direction:column;gap:20px;flex:1;min-width:0;padding:24px;background:rgba(var(--text-accent-rgb),.03);border:1px solid rgba(var(--text-accent-rgb),.1);border-radius:12px;animation:fadeIn .3s ease-in-out;width:100%;word-wrap:break-word}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.work-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;flex-wrap:wrap;width:100%}.work-position{margin:0;font-size:1.25rem;font-weight:700;color:var(--text-accent);word-wrap:break-word}.work-company{margin:4px 0 0;font-size:.95rem;color:var(--text-main);opacity:.8;font-weight:500;word-wrap:break-word}.work-header-right{display:flex;flex-direction:column;align-items:flex-end;gap:8px;flex-shrink:0;max-width:100%}.work-location{display:flex;align-items:center;gap:6px;font-size:.9rem;color:var(--text-disabled);font-weight:500;white-space:nowrap}.work-period{font-size:.9rem;color:var(--text-disabled);font-weight:500;white-space:nowrap}.work-description{margin:0;font-size:.95rem;line-height:1.6;color:var(--text-main);opacity:.85;word-wrap:break-word}.work-section{display:flex;flex-direction:column;gap:12px;width:100%}.work-section-title{margin:0;font-size:.95rem;font-weight:700;color:var(--text-accent);text-transform:uppercase;letter-spacing:.5px;word-wrap:break-word}.work-list{margin:0;padding-left:20px;list-style:none;width:100%}.work-list li{position:relative;margin-bottom:10px;font-size:.9rem;line-height:1.5;color:var(--text-main);opacity:.85;word-wrap:break-word}.work-list li:before{content:"→";position:absolute;transform:translate(-20px);color:var(--text-accent);font-weight:600}.tech-badges{display:flex;flex-wrap:wrap;gap:10px;width:100%}@media(max-width:768px){.work-experience{flex-direction:column;gap:24px}.work-nav{flex-direction:row;gap:8px;min-width:unset;overflow-x:auto;flex-wrap:nowrap;-webkit-overflow-scrolling:touch;padding-bottom:8px;scrollbar-width:thin;width:100%}.work-nav button,.work-nav .work-nav-button{flex-shrink:0;white-space:nowrap;max-width:none}.work-details{padding:20px;max-width:100%}.work-header{flex-direction:column;align-items:stretch}.work-header-right{align-items:flex-start;width:100%;flex-shrink:1}.work-location,.work-period{white-space:normal;word-break:break-word;width:100%}.work-location svg{flex-shrink:0}.work-position{font-size:1.1rem}.tech-badges{justify-content:flex-start;gap:8px}.tech-badges>*{max-width:100%}}@media(max-width:480px){.work-details{padding:16px}.work-title{font-size:1.3rem}.work-list{padding-left:16px}.work-list li{font-size:.85rem}}.tech-stack{display:flex;flex-direction:column;align-items:start;gap:24px;width:100%;max-width:920px;margin:0 auto}.tech-stack__list{display:flex;flex-direction:column;width:100%;padding-left:0;gap:8px}.front,.back,.tools{display:flex;flex-direction:row;flex-wrap:wrap;width:100%;gap:8px;justify-content:start}@media(max-width:768px){.tech-stack__list{gap:16px;padding-left:0;padding-right:0}.front,.back,.tools{gap:5px;justify-content:center}}@media(max-width:1024px){.tech-stack{max-width:100%}}@media(max-width:768px)and (orientation:landscape){.tech-stack__list{gap:12px;flex-wrap:wrap}.front,.back,.tools{flex:1 1 calc(33.333% - 10px);align-items:center;min-width:120px;gap:4px}}@media(max-width:400px){.tech-stack__list{gap:14px}.front,.back,.tools{gap:4px}}@media(min-width:481px)and (max-width:768px){.front,.back,.tools{gap:8px;justify-content:flex-start}}.home-content{max-width:800px;text-align:center;z-index:2}.home-content .title{margin:0;font-size:clamp(2rem,7vw,3.4rem);line-height:1.15;text-wrap:balance}.home-content .subtitle{margin-left:auto;margin-right:auto;font-size:clamp(.95rem,2.2vw,1.15rem);line-height:1.5;text-wrap:balance}.home-content .subtitle--location{max-width:36ch}.home-content .subtitle--pitch{width:100%;max-width:clamp(44ch,58vw,56ch);text-wrap:pretty;-webkit-hyphens:none;hyphens:none}.home-content .title .accented{white-space:nowrap}.home-location:hover{color:var(--text-accent);cursor:pointer}.scroll-arrow{position:absolute;bottom:7%;transform:translate(-50%);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;z-index:100;animation:bounce 2s infinite;opacity:.6;transition:opacity .3s ease;color:var(--text-accent);background:rgba(var(--text-main-rgb),.1);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:50%;padding:8px;border:1px solid rgba(var(--text-main-rgb),.2);width:2.2rem;height:2.2rem;appearance:none;font:inherit}.scroll-arrow:hover{opacity:1}.scroll-arrow:focus-visible{outline:2px solid var(--text-accent);outline-offset:2px}@keyframes bounce{0%,20%,50%,80%,to{transform:translate(-50%) translateY(0)}40%{transform:translate(-50%) translateY(-10px)}60%{transform:translate(-50%) translateY(-5px)}}@media(max-width:768px){.home-content .title{font-size:clamp(1.9rem,8.8vw,2.5rem)}.home-content .subtitle{font-size:clamp(.95rem,4vw,1.05rem);line-height:1.45}.home-content .subtitle--pitch{max-width:min(92vw,40ch);-webkit-hyphens:auto;hyphens:auto}.scroll-arrow{display:none}}@media(max-width:360px){.home-content .title{font-size:clamp(1.65rem,9vw,2.05rem)}.home-content .subtitle{font-size:.92rem}}.nav-desktop,.nav-compact,.nav-mobile{display:flex;background:rgba(var(--bg-main-rgb),.01);backdrop-filter:blur(15px);-webkit-backdrop-filter:blur(15px);border-radius:12px}.nav-desktop a,.nav-compact a,.nav-mobile a{text-decoration:none;color:var(--text-main);font-size:.9rem;font-weight:500}.nav-desktop{flex-direction:column;justify-content:center;gap:8px;position:fixed;left:0;top:0;transform:translate(max(2vw,20px)) translateY(3.5vh);margin:0;padding:12px 8px;width:max-content;max-width:calc(100vw - 40px);height:max-content;z-index:9999;box-sizing:border-box}.anchor-tab{cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;padding:10px 14px 10px 20px;border-radius:8px;min-width:160px;display:block;background:rgba(var(--bg-main-rgb),.03);will-change:transform,background-color;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;box-sizing:border-box}.anchor-tab:hover{background:rgba(var(--bg-main-rgb),.08);transform:translate(2px);color:var(--text-accent)}.anchor-tab.active{background:rgba(var(--text-accent-rgb),.1);color:var(--text-accent);font-weight:600;border-left:3px solid var(--text-accent);padding-left:17px;box-shadow:0 2px 10px rgba(var(--text-accent-rgb),.15);animation:borderSlide .3s ease-out}.anchor-tab:focus-visible{outline:2px solid var(--text-accent);outline-offset:2px;box-shadow:0 0 0 3px rgba(var(--bg-main-rgb),.12)}@keyframes borderSlide{0%{border-left-width:0;padding-left:20px}to{border-left-width:3px;padding-left:17px}}.nav-compact{flex-direction:column;justify-content:center;gap:12px;position:fixed;left:0;top:0;transform:translate(max(2vw,15px)) translateY(3.5vh);margin:0;padding:12px 8px;width:max-content;z-index:9999;box-sizing:border-box;background:rgba(var(--bg-main-rgb),.02);backdrop-filter:blur(15px);-webkit-backdrop-filter:blur(15px);border-radius:12px;border:1px solid rgba(var(--bg-main-rgb),.1)}.nav-compact .anchor-tab-compact{display:flex;align-items:center;justify-content:center;padding:10px;border-radius:8px;color:var(--text-main);transition:all .3s ease;position:relative;box-sizing:border-box}.nav-compact .anchor-tab-compact:hover{background:rgba(var(--bg-main-rgb),.08);color:var(--text-accent);transform:translate(2px)}.nav-compact .anchor-tab-compact.active{color:var(--text-accent);background:rgba(var(--text-accent-rgb),.1);border-left:3px solid var(--text-accent);padding-left:7px}.nav-compact svg{width:22px;height:22px;fill:currentColor}.nav-compact .anchor-tab-compact{position:relative}.nav-compact .anchor-tab-compact:after{content:attr(data-tooltip);position:absolute;left:calc(100% + 12px);top:50%;transform:translateY(-50%);background:rgba(var(--bg-main-rgb),.85);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(8px);color:var(--text-main);font-size:.8rem;font-weight:500;white-space:nowrap;padding:8px 14px;border-radius:12px;border:1px solid rgba(var(--text-accent-rgb),.15);box-shadow:0 8px 20px #0000001f;pointer-events:none;opacity:0;transition:opacity .2s ease,transform .2s ease;z-index:10000;line-height:1.2;letter-spacing:.3px;text-transform:uppercase}.nav-compact .anchor-tab-compact:before{content:"";position:absolute;left:calc(100% + 4px);top:50%;transform:translateY(-50%);border-width:6px;border-style:solid;border-color:transparent rgba(var(--bg-main-rgb),.85) transparent transparent;pointer-events:none;opacity:0;transition:opacity .2s ease;z-index:10000}.nav-compact .anchor-tab-compact:hover:after,.nav-compact .anchor-tab-compact:hover:before{opacity:1}.nav-compact .anchor-tab-compact:hover:after{transform:translateY(-50%) translate(4px)}.nav-compact .anchor-tab-compact.active:hover:after{background:rgba(var(--text-accent-rgb),.9);color:var(--bg-main);border-color:rgba(var(--bg-main-rgb),.3)}.nav-compact .anchor-tab-compact.active:hover:before{border-color:transparent rgba(var(--text-accent-rgb),.9) transparent transparent}.nav-mobile{display:none;z-index:9999;background:rgba(var(--bg-main-rgb),.5);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(var(--bg-main-rgb),.1);border-radius:12px 12px 0 0;position:fixed;left:0;right:0;bottom:-1px;transform:none;padding:12px 10px calc(12px + env(safe-area-inset-bottom));align-items:flex-start;box-sizing:border-box;width:100%;max-width:100vw;overflow-x:auto;-webkit-overflow-scrolling:touch;display:flex;flex-direction:row;justify-content:space-around;gap:4px}.mobile-tab{cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:8px;transition:all .3s ease;position:relative;flex:1 1 auto;gap:4px;min-width:40px;color:var(--text-main)}.mobile-tab.active{color:var(--text-accent)}.mobile-tab-line{width:24px;height:3px;background-color:var(--text-accent);opacity:1;border-radius:2px;transform:scaleX(1.2);box-shadow:0 0 8px rgba(var(--text-accent-rgb),.5);animation:pulseLine 2s ease-in-out infinite}.mobile-tab svg{width:20px;height:20px;fill:currentColor;transition:color .3s ease}@keyframes pulseLine{0%,to{transform:scaleX(1.2)}50%{transform:scaleX(1.5)}}@media(min-width:1301px){.nav-desktop{display:flex}.nav-compact,.nav-mobile{display:none}}@media(min-width:769px)and (max-width:1300px){.nav-desktop{display:none}.nav-compact{display:flex}.nav-mobile{display:none}.nav-compact{transform:translate(max(1vw,10px)) translateY(3vh);padding:10px 6px;gap:10px}.nav-compact .anchor-tab-compact{padding:8px}.nav-compact svg{width:20px;height:20px}}@media(max-width:768px){.nav-desktop,.nav-compact{display:none}.nav-mobile{display:flex}.nav-mobile{padding:10px 8px calc(10px + env(safe-area-inset-bottom))}}@media(max-width:480px){.nav-mobile{padding:8px 4px calc(8px + env(safe-area-inset-bottom));border-radius:10px 10px 0 0}.mobile-tab{padding:6px 4px;gap:3px}.mobile-tab svg{width:18px;height:18px}.mobile-tab-line{width:20px;height:2.5px}}@media(max-width:360px){.mobile-tab svg{width:16px;height:16px}.mobile-tab-line{width:18px;height:2px}}@media(max-height:600px)and (orientation:landscape){.nav-mobile{padding:8px 10px calc(8px + env(safe-area-inset-bottom));background:rgba(var(--bg-main-rgb),.7)}.mobile-tab{padding:4px 6px}.mobile-tab svg{width:18px;height:18px}.mobile-tab-line{width:20px;height:2px}}.project{display:flex;width:100%;max-width:none;height:100%;padding:16px;gap:8px;background:rgba(var(--text-accent-rgb),.03);border:1px solid rgba(var(--text-accent-rgb),.12);flex-direction:column;border-radius:12px;justify-content:space-between;transition:all .3s cubic-bezier(.4,0,.2,1);box-sizing:border-box;overflow:hidden;position:relative;cursor:pointer}.project-trigger{position:absolute;inset:0;z-index:2;border:0;background:transparent;cursor:pointer;padding:0}.project-trigger:focus-visible{outline:2px solid var(--text-accent);outline-offset:2px}.project>*:not(.project-trigger){position:relative;z-index:1;pointer-events:none}.project:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(var(--text-accent-rgb),.3),transparent)}.project:hover{background:rgba(var(--text-accent-rgb),.06);border-color:rgba(var(--text-accent-rgb),.2);transform:translateY(-4px);box-shadow:0 10px 30px rgba(var(--text-accent-rgb),.08)}.project:focus-within{background:rgba(var(--text-accent-rgb),.06);border-color:rgba(var(--text-accent-rgb),.2);transform:translateY(-4px);box-shadow:0 10px 30px rgba(var(--text-accent-rgb),.08)}.project-img{display:flex;align-items:center;justify-content:center;width:100%;border-radius:8px;background:rgba(var(--text-main-rgb),.08);color:var(--text-disabled);font-size:.9rem;flex-shrink:0;overflow:hidden;transition:all .3s cubic-bezier(.4,0,.2,1);aspect-ratio:4/3}.project-img img{width:100%;height:100%;object-fit:cover;transition:transform .3s cubic-bezier(.4,0,.2,1)}.project:hover .project-img img{transform:scale(1.05)}.project-footer{display:flex;flex-direction:column;gap:8px;flex:1;justify-content:flex-end}.project-info{display:flex;flex-direction:column;gap:4px}.project-name{margin:0;color:var(--text-accent);font-size:1.25rem;font-weight:700;line-height:1.3;word-break:break-word}.project-desc{display:-webkit-box;color:var(--text-main);-webkit-box-orient:vertical;-webkit-line-clamp:3;line-clamp:3;overflow:hidden;font-size:.85rem;line-height:1.5;opacity:.8;margin:0;word-break:break-word}.project-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}@media(max-width:480px){.project{padding:12px;gap:6px}.project-img{border-radius:6px}.project-footer{gap:6px}.project-info{gap:2px}.project-name{font-size:1rem;line-height:1.2}.project-desc{font-size:.75rem;line-height:1.4;-webkit-line-clamp:2;line-clamp:2}.project-tags{gap:6px;margin-top:2px}}@media(min-width:481px)and (max-width:768px){.project{padding:14px;gap:7px}.project-footer{gap:7px}.project-info{gap:3px}.project-name{font-size:1.1rem}.project-desc{font-size:.8rem;-webkit-line-clamp:2;line-clamp:2}}@media(min-width:769px)and (max-width:1024px){.project-footer{gap:8px}.project-info{gap:4px}}@media(max-height:900px)and (orientation:landscape){.project{padding:12px;gap:6px}.project-footer{gap:6px}.project-info{gap:2px}.project-name{font-size:1rem}.project-desc{font-size:.75rem;-webkit-line-clamp:2;line-clamp:2}}.tech-badge{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.5rem 1rem;font-weight:700;font-size:.875rem;line-height:1;cursor:default;transition:all .2s ease;-webkit-user-select:none;user-select:none;border-width:1px;border-style:solid;font-family:inherit;text-decoration:none;appearance:none}button.tech-badge{background:transparent}.tech-badge--compact{padding:.3rem .5rem;font-size:.75rem;position:relative}.tech-badge--small{padding:.25rem .75rem;font-size:.75rem}.tech-badge--medium{padding:.5rem 1rem;font-size:.875rem}.tech-badge--large{padding:.75rem 1.25rem;font-size:1rem}.tech-badge--solid{background-color:color-mix(in srgb,var(--badge-color, #3b82f6) 80%,transparent);color:#fff;border-color:var(--badge-color, #3b82f6)}.tech-badge--outline{background-color:var(--bg-badge-color);color:var(--badge-color, #3b82f6);border-color:var(--badge-color, #3b82f6)}.tech-badge--soft{background-color:color-mix(in srgb,var(--badge-color, #3b82f6) 24%,transparent);color:var(--badge-color, #3b82f6);border-color:color-mix(in srgb,var(--badge-color, #3b82f6) 35%,transparent);border-width:1px}.tech-badge--round{border-radius:50px}.tech-badge--semi-round{border-radius:8px}.tech-badge--square{border-radius:0}.tech-badge--none{border:none}.tech-badge--solid-border{border-style:solid}.tech-badge--dashed{border-style:dashed}.tech-badge__icon{font-size:1.1em;display:flex;align-items:center}.tech-badge__tooltip{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);background:var(--text-main);color:var(--bg-main);padding:6px 10px;border-radius:6px;font-size:.75rem;font-weight:600;white-space:nowrap;z-index:1000;pointer-events:none;opacity:0;animation:tooltipFadeIn .2s ease-out forwards;box-shadow:0 4px 12px rgba(var(--text-main-rgb),.15)}.tech-badge__tooltip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);width:0;height:0;border-left:4px solid transparent;border-right:4px solid transparent;border-top:4px solid var(--text-main)}@keyframes tooltipFadeIn{0%{opacity:0;transform:translate(-50%) translateY(4px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.tech-badge--interactive{cursor:pointer}@media(hover:none){.tech-badge--outline{color:var(--badge-color, #3b82f6);border-color:var(--badge-color, #3b82f6)}}@media(hover:hover){.tech-badge--interactive:hover{transform:translateY(-2px);box-shadow:0 4px 8px rgba(var(--text-main-rgb),.1)}.tech-badge--interactive:focus-visible{outline:2px solid var(--badge-color, #3b82f6);outline-offset:2px}.tech-badge--solid.tech-badge--interactive:hover{opacity:.9;color:#fff}.tech-badge--outline.tech-badge--interactive:hover{background-color:color-mix(in srgb,var(--badge-color, #3b82f6) 10%,transparent);color:var(--badge-color, #3b82f6);border-color:var(--badge-color, #3b82f6)}.tech-badge--soft.tech-badge--interactive:hover{background-color:color-mix(in srgb,var(--badge-color, #3b82f6) 38%,transparent);color:var(--badge-color, #3b82f6);border-color:color-mix(in srgb,var(--badge-color, #3b82f6) 50%,transparent)}}@media(prefers-color-scheme:dark)and (hover:hover){.tech-badge--outline.tech-badge--interactive:hover{background-color:color-mix(in srgb,var(--badge-color, #3b82f6) 20%,transparent)}}@media(max-width:768px){.tech-badge--large{padding:.5rem 1rem;font-size:.875rem}}@media(max-width:768px){.tech-badge{font-size:.85em;padding:6px 10px}.tech-badge svg{width:16px;height:16px}}@media(max-width:768px)and (orientation:landscape){.tech-badge{padding:4px 8px;font-size:.8em}}.work-nav-button{display:flex;flex-direction:column;gap:4px;padding:12px 16px;border:1px solid rgba(var(--text-main-rgb),.2);background:rgba(var(--text-main-rgb),.03);border-radius:8px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);text-align:left;color:var(--text-main);font-size:.85rem;font-weight:500;min-width:140px;position:relative;overflow:hidden}.work-nav-button:hover{background:rgba(var(--text-accent-rgb),.08);border-color:rgba(var(--text-accent-rgb),.3);transform:translate(4px)}.work-nav-button.active{background:rgba(var(--text-accent-rgb),.12);border-color:var(--text-accent);color:var(--text-accent);font-weight:600}.work-nav-button.active:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--text-accent);animation:slideIn .3s cubic-bezier(.4,0,.2,1)}@keyframes slideIn{0%{height:0;top:50%}to{height:100%;top:0}}.company-name{display:block;font-size:.8rem;opacity:.7;text-transform:uppercase;letter-spacing:.5px}.position-name{display:block;font-size:.9rem;font-weight:600}.work-nav-button.active .company-name{opacity:1}.language-switcher{position:relative;display:inline-block}.ls-toggle{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);padding:4px 8px;border-radius:6px;color:var(--text-main);cursor:pointer;min-width:40px;display:inline-flex;align-items:center;gap:6px;font-size:.95rem;background:none;border:none}.ls-toggle{transition:transform .15s ease,background-color .15s ease,border-color .15s ease,outline .15s ease}.ls-toggle:hover{transform:translateY(-2px)}.ls-toggle:active{transform:translateY(0)}.ls-toggle:focus-visible{outline:2px solid var(--text-accent);outline-offset:2px;box-shadow:0 0 0 3px rgba(var(--text-main-rgb),.12)}.ls-menu{position:absolute;right:0;top:calc(100% + 8px);background:var(--bg-panel, rgba(var(--text-main-rgb), .03));border:1px solid rgba(var(--text-main-rgb),.06);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);padding:6px;border-radius:8px;z-index:100;opacity:0;transform:translateY(-8px);transition:opacity .22s cubic-bezier(.2,.9,.2,1),transform .22s cubic-bezier(.2,.9,.2,1),max-height .26s cubic-bezier(.2,.9,.2,1);pointer-events:none;overflow:hidden;max-height:0}.ls-menu.open{opacity:1;transform:translateY(0);pointer-events:auto;max-height:420px}.ls-menu.closing{opacity:0;transform:translateY(-8px);pointer-events:none;max-height:0}.ls-menu li{list-style:none;margin:0;transform:translateY(-6px);opacity:0;transition:transform .2s ease,opacity .2s ease}.ls-menu.open li{transform:translateY(0);opacity:1}.ls-menu.open li:nth-child(1){transition-delay:40ms}.ls-menu.open li:nth-child(2){transition-delay:80ms}.ls-menu.open li:nth-child(3){transition-delay:.12s}.ls-menu.open li:nth-child(4){transition-delay:.16s}.ls-menu.open li:nth-child(5){transition-delay:.2s}.ls-menu.open li:nth-child(6){transition-delay:.24s}.ls-menu li{list-style:none;margin:0}.ls-menu button{display:flex;align-items:center;gap:8px;background:transparent;border:none;padding:6px 10px;border-radius:6px;color:var(--text-main);cursor:pointer;width:100%;text-align:left}.ls-menu button .ls-icon{width:16px;height:12px;object-fit:cover;border-radius:2px;flex:0 0 16px}.ls-toggle .ls-icon{width:16px;height:12px;object-fit:cover;border-radius:2px;display:inline-block}.ls-toggle .ls-icon,.ls-menu .ls-icon{pointer-events:none;vertical-align:middle;cursor:inherit}.ls-menu button.active{background:var(--text-accent);color:#fff}.ls-menu button:focus-visible{outline:2px solid var(--text-accent);outline-offset:2px}.ls-toggle .code{font-weight:600}.theme-switcher{display:flex;align-items:center;justify-content:center;gap:4px;padding:8px 12px;background:none;border:none;border-radius:8px;cursor:pointer;color:var(--text-main);font-size:1rem;transition:all .22s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.theme-switcher:hover{transform:translateY(-2px)}.theme-switcher:active{transform:translateY(0);box-shadow:none}.theme-switcher:focus-visible{outline:2px solid var(--text-accent);outline-offset:2px}.project-modal-overlay{position:fixed;inset:0;z-index:10000;display:flex;align-items:center;justify-content:center;padding:16px;background:#0009;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);animation:project-modal-fade-in .25s ease-out}.project-modal-content{position:relative;width:100%;max-width:1200px;max-height:92vh;overflow-y:auto;background:var(--bg-main);border:1px solid rgba(var(--text-accent-rgb),.15);border-radius:24px;box-shadow:0 25px 50px -12px #0006;animation:project-modal-slide-up .3s ease-out}.project-modal-close{position:absolute;top:16px;right:16px;width:40px;height:40px;padding:0;display:flex;align-items:center;justify-content:center;border-radius:50%;background:rgba(var(--text-main-rgb),.08);border:1px solid rgba(var(--text-accent-rgb),.2);color:var(--text-main);font-size:24px;line-height:1;cursor:pointer;z-index:10;transition:background .2s ease,color .2s ease,transform .2s ease}.project-modal-close:hover{background:rgba(var(--text-accent-rgb),.15);color:var(--text-accent);transform:scale(1.05)}.project-modal-close:focus-visible{outline:2px solid var(--text-accent);outline-offset:2px}.project-modal-layout{display:flex;flex-direction:row;gap:40px;padding:40px}.project-modal-preview{flex:0 0 44%;border-radius:16px;overflow:hidden;background:rgba(var(--text-main-rgb),.05);aspect-ratio:4/3}.project-modal-image{width:100%;height:100%;object-fit:cover}.project-modal-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--text-disabled);font-size:1rem;background:rgba(var(--text-main-rgb),.1)}.project-modal-details{flex:1;display:flex;flex-direction:column;gap:20px;min-width:0}.project-modal-title{margin:0;color:var(--text-accent);font-size:2rem;font-weight:700;line-height:1.25}.project-modal-description{margin:0;color:var(--text-main);font-size:1.05rem;line-height:1.7;opacity:.9}.project-modal-section{display:flex;flex-direction:column;gap:12px}.project-modal-section-title{margin:0;color:var(--text-main);font-size:.9rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;opacity:.7}.project-modal-tags{display:flex;flex-wrap:wrap;gap:10px}.project-modal-links{display:flex;flex-wrap:wrap;gap:12px;margin-top:auto;padding-top:8px}.project-modal-link{display:inline-flex;align-items:center;padding:12px 24px;background:rgba(var(--text-accent-rgb),.03);border:1px solid rgba(var(--text-accent-rgb),.12);border-radius:12px;color:var(--text-accent);text-decoration:none;font-size:.95rem;font-weight:600;transition:all .3s cubic-bezier(.4,0,.2,1)}.project-modal-link:hover{background:rgba(var(--text-accent-rgb),.06);border-color:rgba(var(--text-accent-rgb),.2);transform:translateY(-4px);box-shadow:0 10px 30px rgba(var(--text-accent-rgb),.08)}.project-modal-link:focus-visible{outline:2px solid var(--text-accent);outline-offset:2px}@keyframes project-modal-fade-in{0%{opacity:0}to{opacity:1}}@keyframes project-modal-slide-up{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.project-modal-overlay{padding:12px;align-items:flex-start}.project-modal-content{max-height:95vh}.project-modal-layout{flex-direction:column;gap:24px;padding:28px}.project-modal-preview{flex:none;width:100%;aspect-ratio:16/9}.project-modal-title{font-size:1.6rem}.project-modal-close{top:12px;right:12px;width:36px;height:36px;font-size:20px}.project-modal-links{flex-direction:column}.project-modal-link{justify-content:center}}@media(max-width:480px){.project-modal-layout{padding:20px}.project-modal-title{font-size:1.3rem}.project-modal-description{font-size:.9rem}}.cv-modal-content{max-width:760px}.cv-modal-layout{gap:18px;padding:28px}.cv-modal-details{gap:14px}.cv-modal-description{margin:0;color:var(--text-main);font-size:.96rem;line-height:1.55;opacity:.88}.cv-modal-file-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}.cv-modal-file-row{display:flex;flex-wrap:wrap;justify-content:space-between;gap:10px;padding-top:8px;border-top:1px solid rgba(var(--text-accent-rgb),.12)}.cv-modal-language{display:inline-flex;align-items:center;font-size:.94rem;font-weight:600;color:var(--text-main)}.cv-modal-file-actions{margin-top:0;padding-top:0;gap:8px}.cv-modal-file-actions .project-modal-link{padding:9px 16px;font-size:.86rem;border-radius:10px}@media(max-width:768px){.cv-modal-content{max-width:100%}.cv-modal-layout{padding:22px;gap:14px}.cv-modal-details{gap:12px}.cv-modal-file-row{flex-direction:column;align-items:flex-start}.cv-modal-file-actions{width:100%}.cv-modal-file-actions .project-modal-link{width:100%;justify-content:center}}@media(max-width:480px){.cv-modal-layout{padding:18px;gap:12px}.cv-modal-language{font-size:.88rem}.cv-modal-description{font-size:.9rem}.cv-modal-file-actions .project-modal-link{padding:8px 14px;font-size:.8rem}}:root{--text-accent: #5a9b4d;--text-disabled: #9ca3af;--text-main-rgb: 50, 50, 50;--text-accent-rgb: 90, 155, 77;--border-color: #52525b;--bg-dark: #1a1f1c}:root[theme=dark]{--bg-dark: oklch(17.146% .00259 145.811);--bg-main: oklch(14.182% .00422 165.385);--bg-light: oklch(22% .018 155);--bg-badge-color: oklch(24% .02 155);--bg-main-rgb: 28, 36, 32;--text-main: oklch(.97 .012 155);--text-accent: oklch(.78 .12 150);--text-disabled: oklch(.5 .02 155 / .6);--text-main-rgb: 248, 250, 248;--text-accent-rgb: 140, 220, 130;--highlight: oklch(.45 .04 155);--border: oklch(.35 .03 155);--border-muted: oklch(.28 .025 155);--secondary: oklch(.72 .14 320);--danger: oklch(.65 .12 25);--warning: oklch(.78 .13 95);--success: oklch(.72 .12 155);--info: oklch(.7 .1 255)}:root[theme=light]{--bg-dark: oklch(.91 .012 155);--bg-main: oklch(.98 .008 155);--bg-light: oklch(1 .006 155);--bg-badge-color: oklch(.88 .02 155);--bg-main-rgb: 248, 250, 246;--text-main: oklch(.32 .02 155);--text-accent: oklch(.48 .14 150);--text-disabled: oklch(.45 .02 155 / .55);--text-main-rgb: 55, 65, 58;--text-accent-rgb: 45, 130, 70;--highlight: oklch(.98 .015 155);--border: oklch(.55 .03 155);--border-muted: oklch(.65 .02 155);--secondary: oklch(.45 .12 320);--danger: oklch(.5 .15 25);--warning: oklch(.62 .14 95);--success: oklch(.5 .12 155);--info: oklch(.5 .1 255)}*,*:before,*:after{box-sizing:border-box}.app-wrapper{display:flex;flex-direction:column;align-items:center;width:100%;max-width:100vw}.sections{display:flex;flex-direction:column;gap:8px;width:100%;max-width:100vw;overflow-x:hidden}.screens{padding-left:clamp(16px,25vw,320px);width:100%}.screen{height:max-content;width:90%;max-width:1200px;display:flex;padding:32px;flex-direction:column;overflow:hidden;word-wrap:break-word}.accented{color:var(--text-accent)}.home-section{height:auto;min-height:100vh;min-height:100svh;min-height:100dvh;position:relative;display:flex;flex-direction:column;justify-content:center;align-items:center;overflow:hidden;z-index:10;will-change:transform,border-radius,opacity;padding-right:clamp(16px,5vw,50px)}.lang-floating{position:fixed;top:16px;right:20px;z-index:120;display:flex;gap:12px;align-items:center}@media(max-width:1500px){.home-section{padding-left:250px;padding-right:30px}.screens{padding-left:250px}}@media(max-width:1100px){.home-section,.screens{padding-left:200px}.home-section{padding-right:25px}}@media(min-width:769px)and (max-width:1100px){.home-section,.screens{padding-left:2vw}}@media(min-width:1101px)and (max-width:1300px){.home-section,.screens{padding-left:5vw}}@media(max-width:1024px){.sections{padding-left:0}.screen{width:95%;padding:28px 20px}}@media(max-width:768px){.home-section{min-height:100vh;min-height:100svh;min-height:100dvh;padding:1rem;transition:transform .2s ease-out,opacity .2s ease-out}.screens{padding-left:0}.screen{width:95%;padding:24px 16px}.sections{padding-bottom:calc(80px + env(safe-area-inset-bottom))}.lang-floating{top:8px;right:8px;gap:8px}}@media(max-width:480px){.screen{padding:20px 12px}.home-section{padding:.8rem}}@media(max-width:1100px)and (orientation:landscape){.home-section{padding-left:5vw;padding-right:5vw}.screens{padding-left:10vw}}@media(min-height:769px)and (max-height:890px){.sections{padding-left:2rem}.home-section{padding-left:1.5rem;padding-top:0}}
